[FFmpeg-devel] [PATCH 2/4] Make strmatch() return 1 only if the string compared against the prefix does not contain other characters which may belong to an identifier.
Stefano Sabatini
stefano.sabatini-lala
Sun Oct 31 01:30:56 CEST 2010
This allows to distinguish for example to have different constants
with the same prefix (e.g. "foo" and "foobar").
---
libavutil/eval.c | 4 +++-
1 files changed, 3 insertions(+), 1 deletions(-)
diff --git a/libavutil/eval.c b/libavutil/eval.c
index 6e03498..27c1b6d 100644
--- a/libavutil/eval.c
+++ b/libavutil/eval.c
@@ -103,13 +103,15 @@ double av_strtod(const char *numstr, char **tail)
return d;
}
+#define IDENTIFIER_CHARS "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ_0123456789"
+
static int strmatch(const char *s, const char *prefix)
{
int i;
for (i=0; prefix[i]; i++) {
if (prefix[i] != s[i]) return 0;
}
- return 1;
+ return !strspn(s+i, IDENTIFIER_CHARS);
}
struct AVExpr {
--
1.7.1
More information about the ffmpeg-devel
mailing list