changeset 3731:8b8773577dd9 libavcodec

Add support for SI (k, M, ...) and IEC/IEEE (Ki, Mi, ...) units.
author takis
date Mon, 18 Sep 2006 11:35:48 +0000
parents aae4aed137ea
children 2c0b93338765
files eval.c opt.c
diffstat 2 files changed, 55 insertions(+), 57 deletions(-) [+]
line wrap: on
line diff
--- 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;
     }
--- 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;
 }