aboutsummaryrefslogtreecommitdiffstats
path: root/cmdutils.c
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2012-12-20 12:06:15 +0100
committerMichael Niedermayer <michaelni@gmx.at>2012-12-20 12:06:15 +0100
commit40ea3438661e6cc30b60bc019ae01fb073eabb35 (patch)
tree618cba03caedda423e3c34f9bd463afcd94f0800 /cmdutils.c
parent174c483e2e751c71ca9ae4e9ca33082bbb1eea56 (diff)
parentc661cb6672af5ebcb900ec8766b24761bd2ab011 (diff)
downloadffmpeg-40ea3438661e6cc30b60bc019ae01fb073eabb35.tar.gz
Merge commit 'c661cb6672af5ebcb900ec8766b24761bd2ab011'
* commit 'c661cb6672af5ebcb900ec8766b24761bd2ab011': cmdutils: pass number of groups to split_commandline(). mov: handle h263 and flv1 for codec_tag 'H','2','6','3' h264: fix sps parsing for SVC and CAVLC 4:4:4 Intra profiles Conflicts: libavcodec/h264_ps.c libavformat/isom.c libavformat/mov.c Merged-by: Michael Niedermayer <michaelni@gmx.at>
Diffstat (limited to 'cmdutils.c')
-rw-r--r--cmdutils.c24
1 files changed, 11 insertions, 13 deletions
diff --git a/cmdutils.c b/cmdutils.c
index 31c6ad618a..666b0394e4 100644
--- a/cmdutils.c
+++ b/cmdutils.c
@@ -537,14 +537,15 @@ int opt_default(void *optctx, const char *opt, const char *arg)
*
* @return index of the group definition that matched or -1 if none
*/
-static int match_group_separator(const OptionGroupDef *groups, const char *opt)
+static int match_group_separator(const OptionGroupDef *groups, int nb_groups,
+ const char *opt)
{
- const OptionGroupDef *p = groups;
+ int i;
- while (p->name) {
+ for (i = 0; i < nb_groups; i++) {
+ const OptionGroupDef *p = &groups[i];
if (p->sep && !strcmp(p->sep, opt))
- return p - groups;
- p++;
+ return i;
}
return -1;
@@ -602,17 +603,14 @@ static void add_opt(OptionParseContext *octx, const OptionDef *opt,
}
static void init_parse_context(OptionParseContext *octx,
- const OptionGroupDef *groups)
+ const OptionGroupDef *groups, int nb_groups)
{
static const OptionGroupDef global_group = { "global" };
- const OptionGroupDef *g = groups;
int i;
memset(octx, 0, sizeof(*octx));
- while (g->name)
- g++;
- octx->nb_groups = g - groups;
+ octx->nb_groups = nb_groups;
octx->groups = av_mallocz(sizeof(*octx->groups) * octx->nb_groups);
if (!octx->groups)
exit(1);
@@ -655,14 +653,14 @@ void uninit_parse_context(OptionParseContext *octx)
int split_commandline(OptionParseContext *octx, int argc, char *argv[],
const OptionDef *options,
- const OptionGroupDef *groups)
+ const OptionGroupDef *groups, int nb_groups)
{
int optindex = 1;
/* perform system-dependent conversions for arguments list */
prepare_app_arguments(&argc, &argv);
- init_parse_context(octx, groups);
+ init_parse_context(octx, groups, nb_groups);
av_log(NULL, AV_LOG_DEBUG, "Splitting the commandline.\n");
while (optindex < argc) {
@@ -690,7 +688,7 @@ do { \
} while (0)
/* named group separators, e.g. -i */
- if ((ret = match_group_separator(groups, opt)) >= 0) {
+ if ((ret = match_group_separator(groups, nb_groups, opt)) >= 0) {
GET_ARG(arg);
finish_group(octx, ret, arg);
av_log(NULL, AV_LOG_DEBUG, " matched as %s with argument '%s'.\n",