[FFmpeg-cvslog] r20797 - trunk/libavformat/rtmpproto.c

kostya subversion
Fri Dec 11 12:37:22 CET 2009


Author: kostya
Date: Fri Dec 11 12:37:21 2009
New Revision: 20797

Log:
Do not try to interact with RTMP server after "stop" command was received.
Patch by Martin Storsj? ($name at $name dot `Sao Tome and Principe domain`)

Modified:
   trunk/libavformat/rtmpproto.c

Modified: trunk/libavformat/rtmpproto.c
==============================================================================
--- trunk/libavformat/rtmpproto.c	Fri Dec 11 00:06:23 2009	(r20796)
+++ trunk/libavformat/rtmpproto.c	Fri Dec 11 12:37:21 2009	(r20797)
@@ -53,6 +53,7 @@ typedef enum {
     STATE_READY,      ///< client has sent all needed commands and waits for server reply
     STATE_PLAYING,    ///< client has started receiving multimedia data from server
     STATE_PUBLISHING, ///< client has started sending multimedia data to server (for output)
+    STATE_STOPPED,    ///< the broadcast has been stopped
 } ClientState;
 
 /** protocol handler context */
@@ -619,6 +620,8 @@ static int rtmp_parse_result(URLContext 
             t = ff_amf_get_field_value(ptr, data_end,
                                        "code", tmpstr, sizeof(tmpstr));
             if (!t && !strcmp(tmpstr, "NetStream.Play.Start")) rt->state = STATE_PLAYING;
+            if (!t && !strcmp(tmpstr, "NetStream.Play.Stop")) rt->state = STATE_STOPPED;
+            if (!t && !strcmp(tmpstr, "NetStream.Play.UnpublishNotify")) rt->state = STATE_STOPPED;
             if (!t && !strcmp(tmpstr, "NetStream.Publish.Start")) rt->state = STATE_PUBLISHING;
         }
         break;
@@ -642,6 +645,9 @@ static int get_packet(URLContext *s, int
     RTMPContext *rt = s->priv_data;
     int ret;
 
+    if (rt->state == STATE_STOPPED)
+        return AVERROR_EOF;
+
     for (;;) {
         RTMPPacket rpkt;
         if ((ret = ff_rtmp_packet_read(rt->stream, &rpkt,
@@ -658,6 +664,10 @@ static int get_packet(URLContext *s, int
             ff_rtmp_packet_destroy(&rpkt);
             return -1;
         }
+        if (rt->state == STATE_STOPPED) {
+            ff_rtmp_packet_destroy(&rpkt);
+            return AVERROR_EOF;
+        }
         if (for_header && (rt->state == STATE_PLAYING || rt->state == STATE_PUBLISHING)) {
             ff_rtmp_packet_destroy(&rpkt);
             return 0;



More information about the ffmpeg-cvslog mailing list