[SCM] libav/experimental: Move "app" string into RTMP protocol context. Patch by Sergiy (com.gmail at piratfm)

siretart at users.alioth.debian.org siretart at users.alioth.debian.org
Sun Jun 30 16:55:25 UTC 2013


The following commit has been merged in the experimental branch:
commit 5e9ad75985a77efe1ab4cc15056c8e74b152aa3b
Author: Sergiy <piratfm at gmail.com>
Date:   Thu Dec 3 15:47:00 2009 +0000

    Move "app" string into RTMP protocol context.
    Patch by Sergiy (com.gmail at piratfm)
    
    Originally committed as revision 20715 to svn://svn.ffmpeg.org/ffmpeg/trunk

diff --git a/libavformat/rtmpproto.c b/libavformat/rtmpproto.c
index bdaa30f..296cb7e 100644
--- a/libavformat/rtmpproto.c
+++ b/libavformat/rtmpproto.c
@@ -59,6 +59,7 @@ typedef struct RTMPContext {
     int           chunk_size;                 ///< size of the chunks RTMP packets are divided into
     int           is_input;                   ///< input/output flag
     char          playpath[256];              ///< path to filename to play (with possible "mp4:" prefix)
+    char          app[128];                   ///< application
     ClientState   state;                      ///< current state
     int           main_channel_id;            ///< an additional channel ID which is used for some invocations
     uint8_t*      flv_data;                   ///< buffer with data for demuxer
@@ -93,7 +94,7 @@ static const uint8_t rtmp_server_key[] = {
  * Generates 'connect' call and sends it to the server.
  */
 static void gen_connect(URLContext *s, RTMPContext *rt, const char *proto,
-                        const char *host, int port, const char *app)
+                        const char *host, int port)
 {
     RTMPPacket pkt;
     uint8_t ver[32], *p;
@@ -102,12 +103,12 @@ static void gen_connect(URLContext *s, RTMPContext *rt, const char *proto,
     ff_rtmp_packet_create(&pkt, RTMP_VIDEO_CHANNEL, RTMP_PT_INVOKE, 0, 4096);
     p = pkt.data;
 
-    snprintf(tcurl, sizeof(tcurl), "%s://%s:%d/%s", proto, host, port, app);
+    snprintf(tcurl, sizeof(tcurl), "%s://%s:%d/%s", proto, host, port, rt->app);
     ff_amf_write_string(&p, "connect");
     ff_amf_write_number(&p, 1.0);
     ff_amf_write_object_start(&p);
     ff_amf_write_field_name(&p, "app");
-    ff_amf_write_string(&p, app);
+    ff_amf_write_string(&p, rt->app);
 
     snprintf(ver, sizeof(ver), "%s %d,%d,%d,%d", RTMP_CLIENT_PLATFORM, RTMP_CLIENT_VER1,
              RTMP_CLIENT_VER2, RTMP_CLIENT_VER3, RTMP_CLIENT_VER4);
@@ -563,7 +564,7 @@ static int rtmp_close(URLContext *h)
 static int rtmp_open(URLContext *s, const char *uri, int flags)
 {
     RTMPContext *rt;
-    char proto[8], hostname[256], path[1024], app[128], *fname;
+    char proto[8], hostname[256], path[1024], *fname;
     uint8_t buf[2048];
     int port;
     int ret;
@@ -599,21 +600,21 @@ static int rtmp_open(URLContext *s, const char *uri, int flags)
         //extract "app" part from path
         if (!strncmp(path, "/ondemand/", 10)) {
             fname = path + 10;
-            memcpy(app, "ondemand", 9);
+            memcpy(rt->app, "ondemand", 9);
         } else {
             char *p = strchr(path + 1, '/');
             if (!p) {
                 fname = path + 1;
-                app[0] = '\0';
+                rt->app[0] = '\0';
             } else {
                 char *c = strchr(p + 1, ':');
                 fname = strchr(p + 1, '/');
                 if (!fname || c < fname) {
                     fname = p + 1;
-                    av_strlcpy(app, path + 1, p - path);
+                    av_strlcpy(rt->app, path + 1, p - path);
                 } else {
                     fname++;
-                    av_strlcpy(app, path + 1, fname - path - 1);
+                    av_strlcpy(rt->app, path + 1, fname - path - 1);
                 }
             }
         }
@@ -627,8 +628,8 @@ static int rtmp_open(URLContext *s, const char *uri, int flags)
         strncat(rt->playpath, fname, sizeof(rt->playpath) - 5);
 
         av_log(LOG_CONTEXT, AV_LOG_DEBUG, "Proto = %s, path = %s, app = %s, fname = %s\n",
-               proto, path, app, rt->playpath);
-        gen_connect(s, rt, proto, hostname, port, app);
+               proto, path, rt->app, rt->playpath);
+        gen_connect(s, rt, proto, hostname, port);
 
         do {
             ret = get_packet(s, 1);

-- 
Libav/FFmpeg packaging



More information about the pkg-multimedia-commits mailing list