[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