]> git.sesse.net Git - ffmpeg/commitdiff
more factoriztaion and a FIXME note
authorMichael Niedermayer <michaelni@gmx.at>
Tue, 10 Oct 2006 23:56:49 +0000 (23:56 +0000)
committerMichael Niedermayer <michaelni@gmx.at>
Tue, 10 Oct 2006 23:56:49 +0000 (23:56 +0000)
Originally committed as revision 6636 to svn://svn.ffmpeg.org/ffmpeg/trunk

libavformat/amr.c

index 9992f09959b950334bbcef485e455b904e34c4ef..f271750fdfd2cbd8511b3569c7834b73ba050aaa 100644 (file)
@@ -91,6 +91,11 @@ static int amr_read_header(AVFormatContext *s,
 
     get_buffer(pb, header, 6);
 
+    st = av_new_stream(s, 0);
+    if (!st)
+    {
+        return AVERROR_NOMEM;
+    }
     if(memcmp(header,AMR_header,6)!=0)
     {
         get_buffer(pb, header+6, 3);
@@ -98,11 +103,6 @@ static int amr_read_header(AVFormatContext *s,
         {
             return -1;
         }
-        st = av_new_stream(s, 0);
-        if (!st)
-        {
-            return AVERROR_NOMEM;
-        }
 
         st->codec->codec_tag = MKTAG('s', 'a', 'w', 'b');
         st->codec->codec_id = CODEC_ID_AMR_WB;
@@ -110,12 +110,6 @@ static int amr_read_header(AVFormatContext *s,
     }
     else
     {
-        st = av_new_stream(s, 0);
-        if (!st)
-        {
-            return AVERROR_NOMEM;
-        }
-
         st->codec->codec_tag = MKTAG('s', 'a', 'm', 'r');
         st->codec->codec_id = CODEC_ID_AMR_NB;
         st->codec->sample_rate = 8000;
@@ -140,6 +134,7 @@ static int amr_read_packet(AVFormatContext *s,
         return AVERROR_IO;
     }
 
+//FIXME this is wrong, this should rather be in a AVParset
     toc=get_byte(&s->pb);
     mode = (toc >> 3) & 0x0F;