# HG changeset patch # User reimar # Date 1165876148 0 # Node ID 8a710a7b68ea265528fdac78c56a7fccec6fa8d5 # Parent 034ba9cabe170a693d29f946ae9f63ca960884d3 Reuse utf8_get_char in subtitle rendering code. diff -r 034ba9cabe17 -r 8a710a7b68ea libvo/sub.c --- a/libvo/sub.c Mon Dec 11 19:49:04 2006 +0000 +++ b/libvo/sub.c Mon Dec 11 22:29:08 2006 +0000 @@ -428,20 +428,13 @@ x = 1; // reading the subtitle words from vo_sub->text[] - for (j=0;j<=len;j++){ - if ((c=t[j])>=0x80){ - if (sub_utf8){ - if ((c & 0xe0) == 0xc0) /* 2 bytes U+00080..U+0007FF*/ - c = (c & 0x1f)<<6 | (t[++j] & 0x3f); - else if((c & 0xf0) == 0xe0){ /* 3 bytes U+00800..U+00FFFF*/ - c = (((c & 0x0f)<<6) | (t[++j] & 0x3f))<<6; - c |= (t[++j] & 0x3f); - } - } else if (sub_unicode) - c = (c<<8) + t[++j]; - } + while (*t) { + if (sub_utf8) + c = utf8_get_char(&t); + else if ((c = *t++) >= 0x80 && sub_unicode) + c = (c<<8) + *t++; if (k==MAX_UCS){ - len=j; // end here + t += strlen(t); // end here mp_msg(MSGT_OSD,MSGL_WARN,"\nMAX_UCS exceeded!\n"); } if (!c) c++; // avoid UCS 0