diff options
-rw-r--r-- | src/tag.c | 2 | ||||
-rw-r--r-- | src/utf8.c | 6 |
2 files changed, 5 insertions, 3 deletions
@@ -25,6 +25,7 @@ #include "aac_decode.h" #include "utils.h" #include "utf8.h" +#include "log.h" #include <sys/stat.h> #include <stdlib.h> @@ -61,6 +62,7 @@ void printMpdTag(FILE * fp, MpdTag * tag) { #define fixUtf8(str) { \ if(str && !validUtf8String(str)) { \ char * temp; \ + DEBUG("not valid utf8 in tag: %s\n",str); \ temp = asciiStrToUtf8Dup(str); \ free(str); \ str = temp; \ diff --git a/src/utf8.c b/src/utf8.c index aa427e99b..140316150 100644 --- a/src/utf8.c +++ b/src/utf8.c @@ -59,7 +59,7 @@ int validateUtf8Char(unsigned char * utf8Char) { if(utf8Char[0]>=0xC0 && utf8Char[0]<=0xFD) { int count = 1; - unsigned char t = 0x20; + unsigned char t = 1 << 5; int i; while(count < 6 && (t & utf8Char[0])) { t = (t >> 1); @@ -69,7 +69,7 @@ int validateUtf8Char(unsigned char * utf8Char) { for(i=1;i<=count;i++) { if(utf8Char[i] < 0x80 || utf8Char[i] > 0xBF) return 0; } - return count; + return count+1; } else return 0; } @@ -79,7 +79,7 @@ int validUtf8String(unsigned char * string) { while(*string) { ret = validateUtf8Char(string); - if(!ret) return 0; + if(0==ret) return 0; string+= ret; } |