[FFmpeg-devel] [PATCH 2/7] ffmpeg: dynamically allocate input_files_ts_scale
Aurélien Jacobs
aurel
Fri Aug 13 20:24:15 CEST 2010
From: Aurelien Jacobs <aurel at gnuage.org>
---
ffmpeg.c | 11 ++++++++---
1 files changed, 8 insertions(+), 3 deletions(-)
diff --git a/ffmpeg.c b/ffmpeg.c
index 1546582..3813b49 100644
--- a/ffmpeg.c
+++ b/ffmpeg.c
@@ -106,10 +106,11 @@ static const OptionDef options[];
static const char *last_asked_format = NULL;
static AVFormatContext *input_files[MAX_FILES];
static int64_t input_files_ts_offset[MAX_FILES];
-static double input_files_ts_scale[MAX_FILES][MAX_STREAMS];
+static double *input_files_ts_scale[MAX_FILES] = {NULL};
static AVCodec *input_codecs[MAX_FILES*MAX_STREAMS];
static int nb_input_files = 0;
static int nb_icodecs;
+static int nb_input_files_ts_scale[MAX_FILES] = {0};
static AVFormatContext *output_files[MAX_FILES];
static AVCodec *output_codecs[MAX_FILES*MAX_STREAMS];
@@ -605,8 +606,10 @@ static int ffmpeg_exit(int ret)
av_metadata_free(&s->metadata);
av_free(s);
}
- for(i=0;i<nb_input_files;i++)
+ for(i=0;i<nb_input_files;i++) {
av_close_input_file(input_files[i]);
+ av_free(input_files_ts_scale[i]);
+ }
av_free(intra_matrix);
av_free(inter_matrix);
@@ -2595,7 +2598,8 @@ static int transcode(AVFormatContext **output_files,
if (pkt.pts != AV_NOPTS_VALUE)
pkt.pts += av_rescale_q(input_files_ts_offset[ist->file_index], AV_TIME_BASE_Q, ist->st->time_base);
- if(input_files_ts_scale[file_index][pkt.stream_index]){
+ if (pkt.stream_index < nb_input_files_ts_scale[file_index]
+ && input_files_ts_scale[file_index][pkt.stream_index]){
if(pkt.pts != AV_NOPTS_VALUE)
pkt.pts *= input_files_ts_scale[file_index][pkt.stream_index];
if(pkt.dts != AV_NOPTS_VALUE)
@@ -3068,6 +3072,7 @@ static void opt_input_ts_scale(const char *arg)
if(stream >= MAX_STREAMS)
ffmpeg_exit(1);
+ GROW_ARRAY(input_files_ts_scale[nb_input_files], stream + 1);
input_files_ts_scale[nb_input_files][stream]= scale;
}
--
1.7.1
More information about the ffmpeg-devel
mailing list