From 8f853159f6ea6f6453e69a26f4ea62f9d35f4181 Mon Sep 17 00:00:00 2001 From: Michael Niedermayer Date: Tue, 18 Feb 2014 21:43:57 +0100 Subject: avutil/opt: preserve fractions in set_string_number() This avoids going over a double precission float, which may loose precission Signed-off-by: Michael Niedermayer --- libavutil/opt.c | 9 +++++++++ 1 file changed, 9 insertions(+) (limited to 'libavutil') diff --git a/libavutil/opt.c b/libavutil/opt.c index 6ecc14eb09..c74f220ca1 100644 --- a/libavutil/opt.c +++ b/libavutil/opt.c @@ -195,6 +195,15 @@ static int set_string(void *obj, const AVOption *o, const char *val, uint8_t **d static int set_string_number(void *obj, void *target_obj, const AVOption *o, const char *val, void *dst) { int ret = 0, notfirst = 0; + int num, den; + char c; + + if (sscanf(val, "%d%*1[:/]%d%c", &num, &den, &c) == 2) { + if ((ret = write_number(obj, o, dst, 1, den, num)) >= 0) + return ret; + ret = 0; + } + for (;;) { int i, den = 1; char buf[256]; -- cgit v1.2.3