Commit a5cc196a authored by stefano's avatar stefano

Make graphparser.c use av_get_token().

This also avoids the need for '\=' escaping.


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@18726 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 65babbda
...@@ -26,6 +26,7 @@ ...@@ -26,6 +26,7 @@
#include "graphparser.h" #include "graphparser.h"
#include "avfilter.h" #include "avfilter.h"
#include "avfiltergraph.h" #include "avfiltergraph.h"
#include "parseutils.h"
#define WHITESPACES " \n\t" #define WHITESPACES " \n\t"
...@@ -43,49 +44,6 @@ static int link_filter(AVFilterContext *src, int srcpad, ...@@ -43,49 +44,6 @@ static int link_filter(AVFilterContext *src, int srcpad,
return 0; return 0;
} }
/**
* Consumes a string from *buf.
* @return a copy of the consumed string, which should be free'd after use
*/
static char *consume_string(const char **buf)
{
char *out = av_malloc(strlen(*buf) + 1);
char *ret = out;
*buf += strspn(*buf, WHITESPACES);
do{
char c = *(*buf)++;
switch (c) {
case '\\':
*out++ = *(*buf)++;
break;
case '\'':
while(**buf && **buf != '\'')
*out++ = *(*buf)++;
if(**buf) (*buf)++;
break;
case 0:
case ']':
case '[':
case '=':
case ',':
case ';':
case ' ':
case '\n':
*out++ = 0;
break;
default:
*out++ = c;
}
} while(out[-1]);
(*buf)--;
*buf += strspn(*buf, WHITESPACES);
return ret;
}
/** /**
* Parse "[linkname]" * Parse "[linkname]"
* @param name a pointer (that need to be free'd after use) to the name between * @param name a pointer (that need to be free'd after use) to the name between
...@@ -97,7 +55,7 @@ static char *parse_link_name(const char **buf, AVClass *log_ctx) ...@@ -97,7 +55,7 @@ static char *parse_link_name(const char **buf, AVClass *log_ctx)
char *name; char *name;
(*buf)++; (*buf)++;
name = consume_string(buf); name = av_get_token(buf, "]");
if(!name[0]) { if(!name[0]) {
av_log(log_ctx, AV_LOG_ERROR, av_log(log_ctx, AV_LOG_ERROR,
...@@ -162,12 +120,12 @@ static AVFilterContext *parse_filter(const char **buf, AVFilterGraph *graph, ...@@ -162,12 +120,12 @@ static AVFilterContext *parse_filter(const char **buf, AVFilterGraph *graph,
int index, AVClass *log_ctx) int index, AVClass *log_ctx)
{ {
char *opts = NULL; char *opts = NULL;
char *name = consume_string(buf); char *name = av_get_token(buf, "=,");
AVFilterContext *ret; AVFilterContext *ret;
if(**buf == '=') { if(**buf == '=') {
(*buf)++; (*buf)++;
opts = consume_string(buf); opts = av_get_token(buf, "[],\n");
} }
ret = create_filter(graph, index, name, opts, log_ctx); ret = create_filter(graph, index, name, opts, log_ctx);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment