aboutsummaryrefslogtreecommitdiffstats
path: root/libavformat
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2004-07-13 20:59:29 +0000
committerMichael Niedermayer <michaelni@gmx.at>2004-07-13 20:59:29 +0000
commitffdd57d47e7d95a34d3ccf14f226e44b78a391ce (patch)
tree4fcbcc8615b112dab422747de5b037c7597d59cd /libavformat
parent37776c3bac4c214fd07740d990a4d86587987c14 (diff)
downloadffmpeg-ffdd57d47e7d95a34d3ccf14f226e44b78a391ce.tar.gz
warn user if ms style codec tag is used
remove " " codec tag Originally committed as revision 3307 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavformat')
-rw-r--r--libavformat/movenc.c39
1 files changed, 27 insertions, 12 deletions
diff --git a/libavformat/movenc.c b/libavformat/movenc.c
index 0315d18b69..9c6783ea62 100644
--- a/libavformat/movenc.c
+++ b/libavformat/movenc.c
@@ -252,7 +252,8 @@ const CodecTag codec_movaudio_tags[] = {
static int mov_write_audio_tag(ByteIOContext *pb, MOVTrack* track)
{
- int pos = url_ftell(pb), tag;
+ int pos = url_ftell(pb);
+ int tag;
put_be32(pb, 0); /* size */
@@ -261,13 +262,9 @@ static int mov_write_audio_tag(ByteIOContext *pb, MOVTrack* track)
if (!tag)
{
int tmp = codec_get_tag(codec_wav_tags, track->enc->codec_id);
- if (tmp)
- tag = MKTAG('m', 's', ((tmp >> 8) & 0xff), (tmp & 0xff));
+ tag = MKTAG('m', 's', ((tmp >> 8) & 0xff), (tmp & 0xff));
}
- if (!tag)
- put_tag(pb, " ");
- else
- put_le32(pb, tag); // store it byteswapped
+ put_le32(pb, tag); // store it byteswapped
put_be32(pb, 0); /* Reserved */
put_be16(pb, 0); /* Reserved */
@@ -442,7 +439,8 @@ const CodecTag codec_movvideo_tags[] = {
static int mov_write_video_tag(ByteIOContext *pb, MOVTrack* track)
{
- int pos = url_ftell(pb), tag;
+ int pos = url_ftell(pb);
+ int tag;
put_be32(pb, 0); /* size */
@@ -450,10 +448,7 @@ static int mov_write_video_tag(ByteIOContext *pb, MOVTrack* track)
// if no mac fcc found, try with Microsoft tags
if (!tag)
tag = codec_get_tag(codec_bmp_tags, track->enc->codec_id);
- if (!tag)
- put_tag(pb, " ");
- else
- put_le32(pb, tag); // store it byteswapped
+ put_le32(pb, tag); // store it byteswapped
put_be32(pb, 0); /* Reserved */
put_be16(pb, 0); /* Reserved */
@@ -930,6 +925,26 @@ static int mov_write_header(AVFormatContext *s)
MOVContext *mov = s->priv_data;
int i;
+ for(i=0; i<s->nb_streams; i++){
+ AVCodecContext *c= &s->streams[i]->codec;
+
+ if (c->codec_type == CODEC_TYPE_VIDEO){
+ if (!codec_get_tag(codec_movvideo_tags, c->codec_id)){
+ if(!codec_get_tag(codec_bmp_tags, c->codec_id))
+ return -1;
+ else
+ av_log(s, AV_LOG_INFO, "Warning, using MS style video codec tag, the file may be unplayable!\n");
+ }
+ }else if(c->codec_type == CODEC_TYPE_AUDIO){
+ if (!codec_get_tag(codec_movaudio_tags, c->codec_id)){
+ if(!codec_get_tag(codec_wav_tags, c->codec_id))
+ return -1;
+ else
+ av_log(s, AV_LOG_INFO, "Warning, using MS style audio codec tag, the file may be unplayable!\n");
+ }
+ }
+ }
+
/* Default mode == MP4 */
mov->mode = MODE_MP4;