]> granicus.if.org Git - libass/commitdiff
Support fractional arguments for some override tags.
authoreugeni <eugeni@b3059339-0415-0410-9bf9-f77b7e298cf2>
Fri, 27 Feb 2009 23:06:47 +0000 (23:06 +0000)
committereugeni <eugeni@b3059339-0415-0410-9bf9-f77b7e298cf2>
Fri, 27 Feb 2009 23:06:47 +0000 (23:06 +0000)
Done by parsing all integers as doubles first and then converting them to the
nearest integer. Patch by Grigori G (greg chown ath cx).

git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@28752 b3059339-0415-0410-9bf9-f77b7e298cf2

libass/ass_render.c
libass/ass_utils.c
libass/ass_utils.h

index d083eef07c57092bd5f7c91092343c8a1f577f34..a4912724cf4b97511d6bd544855ac63cb0ac86a8 100644 (file)
@@ -781,18 +781,18 @@ static char* parse_tag(char* p, double pwr) {
                double x, y;
                double k;
                skip('(');
-               x1 = strtol(p, &p, 10);
+               mystrtoi(&p, 10, &x1);
                skip(',');
-               y1 = strtol(p, &p, 10);
+               mystrtoi(&p, 10, &y1);
                skip(',');
-               x2 = strtol(p, &p, 10);
+               mystrtoi(&p, 10, &x2);
                skip(',');
-               y2 = strtol(p, &p, 10);
+               mystrtoi(&p, 10, &y2);
                if (*p == ',') {
                        skip(',');
-                       t1 = strtoll(p, &p, 10);
+                       mystrtoll(&p, 10, &t1);
                        skip(',');
-                       t2 = strtoll(p, &p, 10);
+                       mystrtoll(&p, 10, &t2);
                        mp_msg(MSGT_ASS, MSGL_DBG2, "movement6: (%d, %d) -> (%d, %d), (%" PRId64 " .. %" PRId64 ")\n", 
                                x1, y1, x2, y2, (int64_t)t1, (int64_t)t2);
                } else {
@@ -886,9 +886,9 @@ static char* parse_tag(char* p, double pwr) {
        } else if (mystrcmp(&p, "pos")) {
                int v1, v2;
                skip('(');
-               v1 = strtol(p, &p, 10);
+               mystrtoi(&p, 10, &v1);
                skip(',');
-               v2 = strtol(p, &p, 10);
+               mystrtoi(&p, 10, &v2);
                skip(')');
                mp_msg(MSGT_ASS, MSGL_DBG2, "pos(%d, %d)\n", v1, v2);
                if (render_context.evt_type != EVENT_POSITIONED) {
@@ -902,9 +902,9 @@ static char* parse_tag(char* p, double pwr) {
                long long t1, t2, t3, t4;
                if (*p == 'e') ++p; // either \fad or \fade
                skip('(');
-               a1 = strtol(p, &p, 10);
+               mystrtoi(&p, 10, &a1);
                skip(',');
-               a2 = strtol(p, &p, 10);
+               mystrtoi(&p, 10, &a2);
                if (*p == ')') {
                        // 2-argument version (\fad, according to specs)
                        // a1 and a2 are fade-in and fade-out durations
@@ -919,24 +919,24 @@ static char* parse_tag(char* p, double pwr) {
                        // 6-argument version (\fade)
                        // a1 and a2 (and a3) are opacity values
                        skip(',');
-                       a3 = strtol(p, &p, 10);
+                       mystrtoi(&p, 10, &a3);
                        skip(',');
-                       t1 = strtoll(p, &p, 10);
+                       mystrtoll(&p, 10, &t1);
                        skip(',');
-                       t2 = strtoll(p, &p, 10);
+                       mystrtoll(&p, 10, &t2);
                        skip(',');
-                       t3 = strtoll(p, &p, 10);
+                       mystrtoll(&p, 10, &t3);
                        skip(',');
-                       t4 = strtoll(p, &p, 10);
+                       mystrtoll(&p, 10, &t4);
                }
                skip(')');
                render_context.fade = interpolate_alpha(frame_context.time - render_context.event->Start, t1, t2, t3, t4, a1, a2, a3);
        } else if (mystrcmp(&p, "org")) {
                int v1, v2;
                skip('(');
-               v1 = strtol(p, &p, 10);
+               mystrtoi(&p, 10, &v1);
                skip(',');
-               v2 = strtol(p, &p, 10);
+               mystrtoi(&p, 10, &v2);
                skip(')');
                mp_msg(MSGT_ASS, MSGL_DBG2, "org(%d, %d)\n", v1, v2);
                //                              render_context.evt_type = EVENT_POSITIONED;
@@ -1063,19 +1063,22 @@ static char* parse_tag(char* p, double pwr) {
                        render_context.italic = render_context.style->Italic;
                update_font();
        } else if (mystrcmp(&p, "kf") || mystrcmp(&p, "K")) {
-               int val = strtol(p, &p, 10);
+               int val = 0;
+               mystrtoi(&p, 10, &val);
                render_context.effect_type = EF_KARAOKE_KF;
                if (render_context.effect_timing)
                        render_context.effect_skip_timing += render_context.effect_timing;
                render_context.effect_timing = val * 10;
        } else if (mystrcmp(&p, "ko")) {
-               int val = strtol(p, &p, 10);
+               int val = 0;
+               mystrtoi(&p, 10, &val);
                render_context.effect_type = EF_KARAOKE_KO;
                if (render_context.effect_timing)
                        render_context.effect_skip_timing += render_context.effect_timing;
                render_context.effect_timing = val * 10;
        } else if (mystrcmp(&p, "k")) {
-               int val = strtol(p, &p, 10);
+               int val = 0;
+               mystrtoi(&p, 10, &val);
                render_context.effect_type = EF_KARAOKE;
                if (render_context.effect_timing)
                        render_context.effect_skip_timing += render_context.effect_timing;
@@ -1087,7 +1090,8 @@ static char* parse_tag(char* p, double pwr) {
                else
                        render_context.shadow = render_context.style->Shadow;
        } else if (mystrcmp(&p, "pbo")) {
-               (void)strtol(p, &p, 10); // ignored
+               int val = 0;
+               mystrtoi(&p, 10, &val); // ignored
        } else if (mystrcmp(&p, "p")) {
                int val;
                if (!mystrtoi(&p, 10, &val))
index d48685c631bf59b6262052d949a11504e28cb0d8..91b55eb8034e870cb5cb471245507da9f04c432b 100644 (file)
 
 int mystrtoi(char** p, int base, int* res)
 {
+       // NOTE: base argument is ignored, but not used in libass anyway
+       double temp_res;
        char* start = *p;
-       *res = strtol(*p, p, base);
+       temp_res = strtod(*p, p);
+       *res = (int) (temp_res + 0.5);
+       if (*p != start) return 1;
+       else return 0;
+}
+
+int mystrtoll(char** p, int base, long long* res)
+{
+       double temp_res;
+       char* start = *p;
+       temp_res = strtod(*p, p);
+       *res = (long long) (temp_res + 0.5);
        if (*p != start) return 1;
        else return 0;
 }
index d7501c485d3b8e2af3e4b91171dce1be7014fe41..fb751ffd207dc3d6a5743063ccb8d961c34ff3cd 100644 (file)
@@ -26,6 +26,7 @@
 #include <stdint.h>
 
 int mystrtoi(char** p, int base, int* res);
+int mystrtoll(char** p, int base, long long* res);
 int mystrtou32(char** p, int base, uint32_t* res);
 int mystrtod(char** p, double* res);
 int strtocolor(char** q, uint32_t* res);