summaryrefslogtreecommitdiff
path: root/libavformat/mxfenc.c
diff options
context:
space:
mode:
authorBaptiste Coudurier <baptiste.coudurier@gmail.com>2008-08-30 23:47:58 +0000
committerBaptiste Coudurier <baptiste.coudurier@gmail.com>2008-08-30 23:47:58 +0000
commit179308768a8742d215eb8450f0718dc2ee8ea133 (patch)
treedfcce947571a6528c1288fc23b09fb8f499dbd1a /libavformat/mxfenc.c
parent851a8297e88bdfef4d3f53cb9ae1f02191e9adcc (diff)
move per track code in mxf_write_header to be able to check for unsupported configuration
Originally committed as revision 15070 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavformat/mxfenc.c')
-rw-r--r--libavformat/mxfenc.c32
1 files changed, 14 insertions, 18 deletions
diff --git a/libavformat/mxfenc.c b/libavformat/mxfenc.c
index 7d821784c8..54e327d6be 100644
--- a/libavformat/mxfenc.c
+++ b/libavformat/mxfenc.c
@@ -702,27 +702,9 @@ static void mxf_build_structural_metadata(AVFormatContext *s, enum MXFMetadataSe
static int mxf_write_header_metadata_sets(AVFormatContext *s)
{
- AVStream *st;
- MXFStreamContext *sc = NULL;
- int i;
-
mxf_write_preface(s);
mxf_write_identification(s);
mxf_write_content_storage(s);
-
- for (i = 0; i < s->nb_streams; i++) {
- st = s->streams[i];
- sc = av_mallocz(sizeof(MXFStreamContext));
- if (!sc)
- return AVERROR(ENOMEM);
- st->priv_data = sc;
- // set pts information
- if (st->codec->codec_type == CODEC_TYPE_VIDEO)
- av_set_pts_info(st, 64, 1, st->codec->time_base.den);
- else if (st->codec->codec_type == CODEC_TYPE_AUDIO)
- av_set_pts_info(st, 64, 1, st->codec->sample_rate);
- }
-
mxf_build_structural_metadata(s, MaterialPackage);
mxf_build_structural_metadata(s, SourcePackage);
return 0;
@@ -774,6 +756,20 @@ static int mux_write_header(AVFormatContext *s)
MXFContext *mxf = s->priv_data;
ByteIOContext *pb = s->pb;
int64_t header_metadata_start, offset_now;
+ int i;
+
+ for (i = 0; i < s->nb_streams; i++) {
+ AVStream *st = s->streams[i];
+ MXFStreamContext *sc = av_mallocz(sizeof(MXFStreamContext));
+ if (!sc)
+ return AVERROR(ENOMEM);
+ st->priv_data = sc;
+ // set pts information
+ if (st->codec->codec_type == CODEC_TYPE_VIDEO)
+ av_set_pts_info(st, 64, 1, st->codec->time_base.den);
+ else if (st->codec->codec_type == CODEC_TYPE_AUDIO)
+ av_set_pts_info(st, 64, 1, st->codec->sample_rate);
+ }
mxf_write_partition(s, 0, 1, header_partition_key);