]> git.sesse.net Git - ffmpeg/blobdiff - libavutil/avstring.c
Merge commit 'd0c093021943e9b9c23528b12cd61ca2a5b01b4f'
[ffmpeg] / libavutil / avstring.c
index ac7f98ae74b044f0abbadb655f92a29ece1d981b..25c65b4238b3daf678a1bbc38c45c4e91ee640ce 100644 (file)
@@ -404,22 +404,21 @@ end:
 
 int av_match_list(const char *name, const char *list, char separator)
 {
-    const char *p;
-    char ext1[128], *q;
-    int i;
-
-    p = list;
-    for (i = 1;; i++) {
-        q = ext1;
-        while (*p != '\0' && *p != separator  && q - ext1 < sizeof(ext1) - 1)
-            *q++ = *p++;
-        *q = '\0';
-        if (!av_strcasecmp(ext1, name))
-            return i;
-        if (*p == '\0')
-            break;
-        p++;
+    const char *p, *q;
+
+    for (p = name; p && *p; ) {
+        for (q = list; q && *q; ) {
+            int k;
+            for (k = 0; p[k] == q[k] || (p[k]*q[k] == 0 && p[k]+q[k] == separator); k++)
+                if (k && (!p[k] || p[k] == separator))
+                    return 1;
+            q = strchr(q, separator);
+            q += !!q;
+        }
+        p = strchr(p, separator);
+        p += !!p;
     }
+
     return 0;
 }