[FFmpeg-cvslog] r10112 - in trunk: cmdutils.c cmdutils.h ffmpeg.c ffplay.c
diego
subversion
Tue Aug 14 01:03:36 CEST 2007
Author: diego
Date: Tue Aug 14 01:03:36 2007
New Revision: 10112
Log:
Make cmdutils.c:parse_options accept as argument a function to parse
bare command line parameters.
patch by Stefano Sabatini, stefano.sabatini-lala poste it
Modified:
trunk/cmdutils.c
trunk/cmdutils.h
trunk/ffmpeg.c
trunk/ffplay.c
Modified: trunk/cmdutils.c
==============================================================================
--- trunk/cmdutils.c (original)
+++ trunk/cmdutils.c Tue Aug 14 01:03:36 2007
@@ -61,7 +61,8 @@ static const OptionDef* find_option(cons
return po;
}
-void parse_options(int argc, char **argv, const OptionDef *options)
+void parse_options(int argc, char **argv, const OptionDef *options,
+ void (* parse_arg_function)(const char*))
{
const char *opt, *arg;
int optindex, handleoptions=1;
@@ -112,7 +113,8 @@ unknown_opt:
po->u.func_arg(arg);
}
} else {
- parse_arg_file(opt);
+ if (parse_arg_function)
+ parse_arg_function(opt);
}
}
}
Modified: trunk/cmdutils.h
==============================================================================
--- trunk/cmdutils.h (original)
+++ trunk/cmdutils.h Tue Aug 14 01:03:36 2007
@@ -50,8 +50,18 @@ typedef struct {
} OptionDef;
void show_help_options(const OptionDef *options, const char *msg, int mask, int value);
-void parse_options(int argc, char **argv, const OptionDef *options);
-void parse_arg_file(const char *filename);
+
+/**
+ * Parses the command line arguments.
+ * @param options Array with the definitions required to interpret every
+ * option of the form: -<option_name> [<argument>]
+ * @param parse_arg_function Name of the function called to process every
+ * argument without a leading option name flag. NULL if such arguments do
+ * not have to be processed.
+ */
+void parse_options(int argc, char **argv, const OptionDef *options,
+ void (* parse_arg_function)(const char*));
+
void print_error(const char *filename, int err);
#endif /* _CMD_UTILS_H */
Modified: trunk/ffmpeg.c
==============================================================================
--- trunk/ffmpeg.c (original)
+++ trunk/ffmpeg.c Tue Aug 14 01:03:36 2007
@@ -3806,11 +3806,6 @@ static void show_help(void)
av_opt_show(sws_opts, NULL);
}
-void parse_arg_file(const char *filename)
-{
- opt_output_file(filename);
-}
-
int main(int argc, char **argv)
{
int i;
@@ -3831,7 +3826,7 @@ int main(int argc, char **argv)
}
/* parse options */
- parse_options(argc, argv, options);
+ parse_options(argc, argv, options, opt_output_file);
/* file converter / grab */
if (nb_output_files <= 0) {
Modified: trunk/ffplay.c
==============================================================================
--- trunk/ffplay.c (original)
+++ trunk/ffplay.c Tue Aug 14 01:03:36 2007
@@ -2530,7 +2530,7 @@ int main(int argc, char **argv)
/* register all codecs, demux and protocols */
av_register_all();
- parse_options(argc, argv, options);
+ parse_options(argc, argv, options, parse_arg_file);
if (!input_filename) {
show_help();
More information about the ffmpeg-cvslog
mailing list