|
|
|
@ -1925,46 +1925,6 @@ static void print_sdp(AVFormatContext **avc, int n) |
|
|
|
|
fflush(stdout); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
static int copy_chapters(int infile, int outfile) |
|
|
|
|
{ |
|
|
|
|
AVFormatContext *is = input_files[infile].ctx; |
|
|
|
|
AVFormatContext *os = output_files[outfile]; |
|
|
|
|
int i; |
|
|
|
|
|
|
|
|
|
for (i = 0; i < is->nb_chapters; i++) { |
|
|
|
|
AVChapter *in_ch = is->chapters[i], *out_ch; |
|
|
|
|
int64_t ts_off = av_rescale_q(start_time - input_files[infile].ts_offset, |
|
|
|
|
AV_TIME_BASE_Q, in_ch->time_base); |
|
|
|
|
int64_t rt = (recording_time == INT64_MAX) ? INT64_MAX : |
|
|
|
|
av_rescale_q(recording_time, AV_TIME_BASE_Q, in_ch->time_base); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (in_ch->end < ts_off) |
|
|
|
|
continue; |
|
|
|
|
if (rt != INT64_MAX && in_ch->start > rt + ts_off) |
|
|
|
|
break; |
|
|
|
|
|
|
|
|
|
out_ch = av_mallocz(sizeof(AVChapter)); |
|
|
|
|
if (!out_ch) |
|
|
|
|
return AVERROR(ENOMEM); |
|
|
|
|
|
|
|
|
|
out_ch->id = in_ch->id; |
|
|
|
|
out_ch->time_base = in_ch->time_base; |
|
|
|
|
out_ch->start = FFMAX(0, in_ch->start - ts_off); |
|
|
|
|
out_ch->end = FFMIN(rt, in_ch->end - ts_off); |
|
|
|
|
|
|
|
|
|
if (metadata_chapters_autocopy) |
|
|
|
|
av_dict_copy(&out_ch->metadata, in_ch->metadata, 0); |
|
|
|
|
|
|
|
|
|
os->nb_chapters++; |
|
|
|
|
os->chapters = av_realloc(os->chapters, sizeof(AVChapter)*os->nb_chapters); |
|
|
|
|
if (!os->chapters) |
|
|
|
|
return AVERROR(ENOMEM); |
|
|
|
|
os->chapters[os->nb_chapters - 1] = out_ch; |
|
|
|
|
} |
|
|
|
|
return 0; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* The following code is the main loop of the file converter |
|
|
|
|
*/ |
|
|
|
@ -3430,6 +3390,46 @@ static int opt_streamid(const char *opt, const char *arg) |
|
|
|
|
return 0; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
static int copy_chapters(int infile, int outfile) |
|
|
|
|
{ |
|
|
|
|
AVFormatContext *is = input_files[infile].ctx; |
|
|
|
|
AVFormatContext *os = output_files[outfile]; |
|
|
|
|
int i; |
|
|
|
|
|
|
|
|
|
for (i = 0; i < is->nb_chapters; i++) { |
|
|
|
|
AVChapter *in_ch = is->chapters[i], *out_ch; |
|
|
|
|
int64_t ts_off = av_rescale_q(start_time - input_files[infile].ts_offset, |
|
|
|
|
AV_TIME_BASE_Q, in_ch->time_base); |
|
|
|
|
int64_t rt = (recording_time == INT64_MAX) ? INT64_MAX : |
|
|
|
|
av_rescale_q(recording_time, AV_TIME_BASE_Q, in_ch->time_base); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (in_ch->end < ts_off) |
|
|
|
|
continue; |
|
|
|
|
if (rt != INT64_MAX && in_ch->start > rt + ts_off) |
|
|
|
|
break; |
|
|
|
|
|
|
|
|
|
out_ch = av_mallocz(sizeof(AVChapter)); |
|
|
|
|
if (!out_ch) |
|
|
|
|
return AVERROR(ENOMEM); |
|
|
|
|
|
|
|
|
|
out_ch->id = in_ch->id; |
|
|
|
|
out_ch->time_base = in_ch->time_base; |
|
|
|
|
out_ch->start = FFMAX(0, in_ch->start - ts_off); |
|
|
|
|
out_ch->end = FFMIN(rt, in_ch->end - ts_off); |
|
|
|
|
|
|
|
|
|
if (metadata_chapters_autocopy) |
|
|
|
|
av_dict_copy(&out_ch->metadata, in_ch->metadata, 0); |
|
|
|
|
|
|
|
|
|
os->nb_chapters++; |
|
|
|
|
os->chapters = av_realloc(os->chapters, sizeof(AVChapter)*os->nb_chapters); |
|
|
|
|
if (!os->chapters) |
|
|
|
|
return AVERROR(ENOMEM); |
|
|
|
|
os->chapters[os->nb_chapters - 1] = out_ch; |
|
|
|
|
} |
|
|
|
|
return 0; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
static void opt_output_file(const char *filename) |
|
|
|
|
{ |
|
|
|
|
AVFormatContext *oc; |
|
|
|
|