mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2024-12-23 12:43:46 +02:00
ffmpeg: cosmetics -- move copy_chapters().
It's only used in opt_output_file(), so move it right above opt_output_file().
This commit is contained in:
parent
c692eda3e7
commit
6f610fa144
80
ffmpeg.c
80
ffmpeg.c
@ -1986,46 +1986,6 @@ static void print_sdp(AVFormatContext **avc, int n)
|
|||||||
fflush(stdout);
|
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
|
* The following code is the main loop of the file converter
|
||||||
*/
|
*/
|
||||||
@ -3641,6 +3601,46 @@ static int opt_streamid(const char *opt, const char *arg)
|
|||||||
return 0;
|
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 int opt_output_file(const char *opt, const char *filename)
|
static int opt_output_file(const char *opt, const char *filename)
|
||||||
{
|
{
|
||||||
AVFormatContext *oc;
|
AVFormatContext *oc;
|
||||||
|
Loading…
Reference in New Issue
Block a user