[FFmpeg-devel] [PATCH 2/2] avformat/teeproto: Support parsing protocol options

Michael Niedermayer michael at niedermayer.cc
Mon Aug 1 03:51:57 EEST 2016


Signed-off-by: Michael Niedermayer <michael at niedermayer.cc>
---
 libavformat/Makefile   |    2 +-
 libavformat/teeproto.c |   19 ++++++++++++++-----
 2 files changed, 15 insertions(+), 6 deletions(-)

diff --git a/libavformat/Makefile b/libavformat/Makefile
index 783b96a..ac0c2ca 100644
--- a/libavformat/Makefile
+++ b/libavformat/Makefile
@@ -568,7 +568,7 @@ OBJS-$(CONFIG_RTP_PROTOCOL)              += rtpproto.o
 OBJS-$(CONFIG_SCTP_PROTOCOL)             += sctp.o
 OBJS-$(CONFIG_SRTP_PROTOCOL)             += srtpproto.o srtp.o
 OBJS-$(CONFIG_SUBFILE_PROTOCOL)          += subfile.o
-OBJS-$(CONFIG_TEE_PROTOCOL)              += teeproto.o
+OBJS-$(CONFIG_TEE_PROTOCOL)              += teeproto.o tee_common.o
 OBJS-$(CONFIG_TCP_PROTOCOL)              += tcp.o
 OBJS-$(CONFIG_TLS_GNUTLS_PROTOCOL)       += tls_gnutls.o tls.o
 OBJS-$(CONFIG_TLS_OPENSSL_PROTOCOL)      += tls_openssl.o tls.o
diff --git a/libavformat/teeproto.c b/libavformat/teeproto.c
index 12d5423..e22fba2 100644
--- a/libavformat/teeproto.c
+++ b/libavformat/teeproto.c
@@ -23,6 +23,7 @@
 #include "libavutil/opt.h"
 #include "avformat.h"
 #include "avio_internal.h"
+#include "tee_common.h"
 
 typedef struct ChildContext {
     URLContext *url_context;
@@ -89,9 +90,11 @@ static int tee_open(URLContext *h, const char *filename, int flags)
         return AVERROR(ENOSYS);
 
     while (*filename) {
-        char *child_name = av_get_token(&filename, child_delim);
+        char *child_string = av_get_token(&filename, child_delim);
+        char *child_name = NULL;
         void *tmp;
-        if (!child_name) {
+        AVDictionary *options = NULL;
+        if (!child_string) {
             ret = AVERROR(ENOMEM);
             goto fail;
         }
@@ -99,16 +102,22 @@ static int tee_open(URLContext *h, const char *filename, int flags)
         tmp = av_realloc_array(c->child, c->child_count + 1, sizeof(*c->child));
         if (!tmp) {
             ret = AVERROR(ENOMEM);
-            goto fail;
+            goto loop_fail;
         }
         c->child = tmp;
         memset(&c->child[c->child_count], 0, sizeof(c->child[c->child_count]));
 
+        ret = ff_tee_parse_slave_options(h, child_string, &options, &child_name);
+        if (ret < 0)
+            goto loop_fail;
+
         ret = ffurl_open_whitelist(&c->child[c->child_count].url_context, child_name, flags,
-                                   &h->interrupt_callback, /*AVDictionary **options*/NULL,
+                                   &h->interrupt_callback, &options,
                                    h->protocol_whitelist, h->protocol_blacklist,
                                    h);
-        av_free(child_name);
+loop_fail:
+        av_freep(&child_string);
+        av_dict_free(&options);
         if (ret < 0)
             goto fail;
         c->child_count++;
-- 
1.7.9.5



More information about the ffmpeg-devel mailing list