# HG changeset patch # User takis # Date 1158579348 0 # Node ID 8b8773577dd9a63ad9dfe7fd8c5f6ebf10647cf9 # Parent aae4aed137eab2dd421901ab190d5d9442a608d2 Add support for SI (k, M, ...) and IEC/IEEE (Ki, Mi, ...) units. diff -r aae4aed137ea -r 8b8773577dd9 eval.c --- a/eval.c Sun Sep 17 10:22:01 2006 +0000 +++ b/eval.c Mon Sep 18 11:35:48 2006 +0000 @@ -64,49 +64,14 @@ return 1; } -static int8_t si_prefixes['z' - 'E' + 1]={ - ['y'-'E']= -24, - ['z'-'E']= -21, - ['a'-'E']= -18, - ['f'-'E']= -15, - ['p'-'E']= -12, - ['n'-'E']= - 9, - ['u'-'E']= - 6, - ['m'-'E']= - 3, - ['c'-'E']= - 2, - ['d'-'E']= - 1, - ['h'-'E']= 2, - ['k'-'E']= 3, - ['K'-'E']= 3, - ['M'-'E']= 6, - ['G'-'E']= 9, - ['T'-'E']= 12, - ['P'-'E']= 15, - ['E'-'E']= 18, - ['Z'-'E']= 21, - ['Y'-'E']= 24, -}; - static double evalPrimary(Parser *p){ double d, d2=NAN; char *next= p->s; int i; /* number */ - d= strtod(p->s, &next); + d= av_strtod(p->s, &next); if(next != p->s){ - if(*next >= 'E' && *next <= 'z'){ - int e= si_prefixes[*next - 'E']; - if(e){ - if(next[1] == 'i'){ - d*= pow( 2, e/0.3); - next+=2; - }else{ - d*= pow(10, e); - next++; - } - } - } p->s= next; return d; } diff -r aae4aed137ea -r 8b8773577dd9 opt.c --- a/opt.c Sun Sep 17 10:22:01 2006 +0000 +++ b/opt.c Mon Sep 18 11:35:48 2006 +0000 @@ -27,30 +27,63 @@ #include "avcodec.h" #include "opt.h" -/** - * strtod() function extended with 'k', 'M' and 'B' postfixes. - * This allows using kB, MB, k, M and B as a postfix. This function - * assumes that the unit of numbers is bits not bytes. +static int8_t si_prefixes['z' - 'E' + 1]={ + ['y'-'E']= -24, + ['z'-'E']= -21, + ['a'-'E']= -18, + ['f'-'E']= -15, + ['p'-'E']= -12, + ['n'-'E']= - 9, + ['u'-'E']= - 6, + ['m'-'E']= - 3, + ['c'-'E']= - 2, + ['d'-'E']= - 1, + ['h'-'E']= 2, + ['k'-'E']= 3, + ['K'-'E']= 3, + ['M'-'E']= 6, + ['G'-'E']= 9, + ['T'-'E']= 12, + ['P'-'E']= 15, + ['E'-'E']= 18, + ['Z'-'E']= 21, + ['Y'-'E']= 24, +}; + +/** strtod() function extended with 'k', 'M', 'G', 'ki', 'Mi', 'Gi' and 'B' + * postfixes. This allows using f.e. kB, MiB, G and B as a postfix. This + * function assumes that the unit of numbers is bits not bytes. */ -static double av_strtod(const char *name, char **tail) { +double av_strtod(const char *name, char **tail) { double d; - d= strtod(name, tail); - if(*tail>name && (**tail=='k')) { - d*=1000; - (*tail)++; + int p = 0; + char *next; + d = strtod(name, &next); + /* if parsing succeeded, check for and interpret postfixes */ + if (next!=name) { + + if(*next >= 'E' && *next <= 'z'){ + int e= si_prefixes[*next - 'E']; + if(e){ + if(next[1] == 'i'){ + d*= pow( 2, e/0.3); + next+=2; + }else{ + d*= pow(10, e); + next++; + } + } + } + + if(*next=='B') { + d*=8; + *next++; + } } - else if(*tail && (**tail=='M')) { - d*=1000000; - (*tail)++; - } - else if(*tail && (**tail=='G')) { - d*=1000000000; - (*tail)++; - } - if(*tail && (**tail=='B')) { - d*=8; - (*tail)++; - } + /* if requested, fill in tail with the position after the last parsed + character */ + if (tail) + *tail = next; return d; }