Merge commit '28f2d3c5a5a3a3c14a68cf691054f15e4f23355a' into release/0.10
authorMichael Niedermayer <michaelni@gmx.at>
Sat, 9 Aug 2014 17:15:49 +0000 (19:15 +0200)
committerMichael Niedermayer <michaelni@gmx.at>
Sat, 9 Aug 2014 17:15:49 +0000 (19:15 +0200)
* commit '28f2d3c5a5a3a3c14a68cf691054f15e4f23355a':
  cmdutils: Conditionally compile libswscale-related bits

Conflicts:
cmdutils.c

Merged-by: Michael Niedermayer <michaelni@gmx.at>
1  2 
cmdutils.c

diff --cc cmdutils.c
@@@ -402,45 -361,34 +402,47 @@@ void parse_loglevel(int argc, char **ar
          idx = locate_option(argc, argv, options, "v");
      if (idx && argv[idx + 1])
          opt_loglevel("loglevel", argv[idx + 1]);
 +    idx = locate_option(argc, argv, options, "report");
 +    if (idx || getenv("FFREPORT")) {
 +        opt_report("report");
 +        if (report_file) {
 +            int i;
 +            fprintf(report_file, "Command line:\n");
 +            for (i = 0; i < argc; i++) {
 +                dump_argument(argv[i]);
 +                fputc(i < argc - 1 ? ' ' : '\n', report_file);
 +            }
 +            fflush(report_file);
 +        }
 +    }
  }
  
 -#define FLAGS (o->type == AV_OPT_TYPE_FLAGS) ? AV_DICT_APPEND : 0
 +#define FLAGS(o) ((o)->type == AV_OPT_TYPE_FLAGS) ? AV_DICT_APPEND : 0
  int opt_default(const char *opt, const char *arg)
  {
 -    const AVOption *o;
 +    const AVOption *oc, *of, *os;
      char opt_stripped[128];
      const char *p;
-     const AVClass *cc = avcodec_get_class(), *fc = avformat_get_class(), *sc;
+     const AVClass *cc = avcodec_get_class(), *fc = avformat_get_class();
+ #if CONFIG_SWSCALE
+     const AVClass *sc = sws_get_class();
+ #endif
  
      if (!(p = strchr(opt, ':')))
          p = opt + strlen(opt);
      av_strlcpy(opt_stripped, opt, FFMIN(sizeof(opt_stripped), p - opt + 1));
  
 -    if ((o = av_opt_find(&cc, opt_stripped, NULL, 0,
 +    if ((oc = av_opt_find(&cc, opt_stripped, NULL, 0,
                           AV_OPT_SEARCH_CHILDREN | AV_OPT_SEARCH_FAKE_OBJ)) ||
          ((opt[0] == 'v' || opt[0] == 'a' || opt[0] == 's') &&
 -         (o = av_opt_find(&cc, opt + 1, NULL, 0, AV_OPT_SEARCH_FAKE_OBJ))))
 -        av_dict_set(&codec_opts, opt, arg, FLAGS);
 -    else if ((o = av_opt_find(&fc, opt, NULL, 0,
 -                              AV_OPT_SEARCH_CHILDREN | AV_OPT_SEARCH_FAKE_OBJ)))
 -        av_dict_set(&format_opts, opt, arg, FLAGS);
 +         (oc = av_opt_find(&cc, opt + 1, NULL, 0, AV_OPT_SEARCH_FAKE_OBJ))))
 +        av_dict_set(&codec_opts, opt, arg, FLAGS(oc));
 +    if ((of = av_opt_find(&fc, opt, NULL, 0,
 +                          AV_OPT_SEARCH_CHILDREN | AV_OPT_SEARCH_FAKE_OBJ)))
 +        av_dict_set(&format_opts, opt, arg, FLAGS(of));
  #if CONFIG_SWSCALE
-     sc = sws_get_class();
 -    else if ((o = av_opt_find(&sc, opt, NULL, 0,
 -                              AV_OPT_SEARCH_CHILDREN | AV_OPT_SEARCH_FAKE_OBJ))) {
 +    if ((os = av_opt_find(&sc, opt, NULL, 0,
 +                          AV_OPT_SEARCH_CHILDREN | AV_OPT_SEARCH_FAKE_OBJ))) {
          // XXX we only support sws_flags, not arbitrary sws options
          int ret = av_opt_set(sws_opts, opt, arg, 0);
          if (ret < 0) {