diff options
author | Anton Khirnov <anton@khirnov.net> | 2011-07-27 21:39:12 +0200 |
---|---|---|
committer | Anton Khirnov <anton@khirnov.net> | 2011-08-12 13:30:07 +0200 |
commit | b9aac90bd875c5cb6f42fcb53e3a8fde3f315a7e (patch) | |
tree | 17bcbbe83b557d51287f83d276dd1b2ffa4e2086 | |
parent | 6291d7e41605c0b1e9debfae8a2b1d4cf7b0e0b3 (diff) | |
download | ffmpeg-b9aac90bd875c5cb6f42fcb53e3a8fde3f315a7e.tar.gz |
avconv: make -map_chapters accept only the input file index.
This is consistent with how all the other options work.
-rw-r--r-- | avconv.c | 80 | ||||
-rw-r--r-- | doc/avconv.texi | 9 |
2 files changed, 28 insertions, 61 deletions
@@ -94,11 +94,6 @@ typedef struct MetadataMap { int index; //< stream/chapter/program number } MetadataMap; -typedef struct ChapterMap { - int in_file; - int out_file; -} ChapterMap; - static const OptionDef options[]; #define MAX_FILES 100 @@ -121,8 +116,7 @@ static int metadata_global_autocopy = 1; static int metadata_streams_autocopy = 1; static int metadata_chapters_autocopy = 1; -static ChapterMap *chapter_maps = NULL; -static int nb_chapter_maps; +static int chapters_input_file = INT_MAX; /* indexed by output file stream index */ static int *streamid_map = NULL; @@ -2464,38 +2458,6 @@ static int transcode(AVFormatContext **output_files, AV_DICT_DONT_OVERWRITE); } - /* copy chapters according to chapter maps */ - for (i = 0; i < nb_chapter_maps; i++) { - int infile = chapter_maps[i].in_file; - int outfile = chapter_maps[i].out_file; - - if (infile < 0 || outfile < 0) - continue; - if (infile >= nb_input_files) { - snprintf(error, sizeof(error), "Invalid input file index %d in chapter mapping.\n", infile); - ret = AVERROR(EINVAL); - goto dump_format; - } - if (outfile >= nb_output_files) { - snprintf(error, sizeof(error), "Invalid output file index %d in chapter mapping.\n",outfile); - ret = AVERROR(EINVAL); - goto dump_format; - } - copy_chapters(infile, outfile); - } - - /* copy chapters from the first input file that has them*/ - if (!nb_chapter_maps) - for (i = 0; i < nb_input_files; i++) { - if (!input_files[i].ctx->nb_chapters) - continue; - - for (j = 0; j < nb_output_files; j++) - if ((ret = copy_chapters(i, j)) < 0) - goto dump_format; - break; - } - /* open files and write file headers */ for(i=0;i<nb_output_files;i++) { os = output_files[i]; @@ -3073,22 +3035,6 @@ static int opt_map_meta_data(const char *opt, const char *arg) return opt_map_metadata(opt, arg); } -static int opt_map_chapters(const char *opt, const char *arg) -{ - ChapterMap *c; - char *p; - - chapter_maps = grow_array(chapter_maps, sizeof(*chapter_maps), &nb_chapter_maps, - nb_chapter_maps + 1); - c = &chapter_maps[nb_chapter_maps - 1]; - c->out_file = strtol(arg, &p, 0); - if (*p) - p++; - - c->in_file = strtol(p, &p, 0); - return 0; -} - static int opt_input_ts_scale(const char *opt, const char *arg) { unsigned int stream; @@ -3732,7 +3678,7 @@ static int opt_streamid(const char *opt, const char *arg) static void opt_output_file(const char *filename) { AVFormatContext *oc; - int err, use_video, use_audio, use_subtitle, use_data; + int i, err, use_video, use_audio, use_subtitle, use_data; int input_has_video, input_has_audio, input_has_subtitle, input_has_data; AVOutputFormat *file_oformat; @@ -3857,12 +3803,32 @@ static void opt_output_file(const char *filename) } oc->flags |= AVFMT_FLAG_NONBLOCK; + /* copy chapters */ + if (chapters_input_file >= nb_input_files) { + if (chapters_input_file == INT_MAX) { + /* copy chapters from the first input file that has them*/ + chapters_input_file = -1; + for (i = 0; i < nb_input_files; i++) + if (input_files[i].ctx->nb_chapters) { + chapters_input_file = i; + break; + } + } else { + av_log(NULL, AV_LOG_ERROR, "Invalid input file index %d in chapter mapping.\n", + chapters_input_file); + exit_program(1); + } + } + if (chapters_input_file >= 0) + copy_chapters(chapters_input_file, nb_output_files - 1); + frame_rate = (AVRational){0, 0}; frame_width = 0; frame_height = 0; audio_sample_rate = 0; audio_channels = 0; audio_sample_fmt = AV_SAMPLE_FMT_NONE; + chapters_input_file = INT_MAX; av_freep(&forced_key_frames); uninit_opts(); @@ -4250,7 +4216,7 @@ static const OptionDef options[] = { "outfile[,metadata]:infile[,metadata]" }, { "map_metadata", HAS_ARG | OPT_EXPERT, {(void*)opt_map_metadata}, "set metadata information of outfile from infile", "outfile[,metadata]:infile[,metadata]" }, - { "map_chapters", HAS_ARG | OPT_EXPERT, {(void*)opt_map_chapters}, "set chapters mapping", "outfile:infile" }, + { "map_chapters", OPT_INT | HAS_ARG | OPT_EXPERT, {(void*)&chapters_input_file}, "set chapters mapping", "input_file_index" }, { "t", HAS_ARG, {(void*)opt_recording_time}, "record or transcode \"duration\" seconds of audio/video", "duration" }, { "fs", HAS_ARG | OPT_INT64, {(void*)&limit_filesize}, "set the limit file size in bytes", "limit_size" }, // { "ss", HAS_ARG, {(void*)opt_start_time}, "set the start time offset", "time_off" }, diff --git a/doc/avconv.texi b/doc/avconv.texi index 2a00c58bcb..24be5529d2 100644 --- a/doc/avconv.texi +++ b/doc/avconv.texi @@ -703,10 +703,11 @@ of the output file: @example avconv -i in.ogg -map_metadata 0:0,s0 out.mp3 @end example -@item -map_chapters @var{outfile}:@var{infile} -Copy chapters from @var{infile} to @var{outfile}. If no chapter mapping is specified, -then chapters are copied from the first input file with at least one chapter to all -output files. Use a negative file index to disable any chapter copying. +@item -map_chapters @var{input_file_index} +Copy chapters from input file with index @var{input_file_index} to the next +output file. If no chapter mapping is specified, then chapters are copied from +the first input file with at least one chapter. Use a negative file index to +disable any chapter copying. @item -debug Print specific debug info. @item -benchmark |