]> git.sesse.net Git - ffmpeg/commitdiff
avformat/dashenc: use AV_OPT_TYPE_DICT for http_opts
authorMarton Balint <cus@passwd.hu>
Sun, 2 Feb 2020 21:58:08 +0000 (22:58 +0100)
committerMarton Balint <cus@passwd.hu>
Mon, 3 Feb 2020 20:42:35 +0000 (21:42 +0100)
This changes the separator character from comma to colon, but since this option
was only added recently I think it should be done for consistency with other
similar options.

Signed-off-by: Marton Balint <cus@passwd.hu>
doc/muxers.texi
libavformat/dashenc.c

index 05bf483ba53159ddf0a936cc14bfe4d67e01c878..ef5c4b10bcd1962d134cebce34942163ad515e53 100644 (file)
@@ -345,7 +345,8 @@ prft boxes in the underlying muxer. Applicable only when the @var{utc_url} optio
 Set one or more manifest profiles.
 
 @item -http_opts @var{http_opts}
-List of options to pass to the underlying HTTP protocol. Applicable only for HTTP output.
+A :-separated list of key=value options to pass to the underlying HTTP
+protocol. Applicable only for HTTP output.
 
 @item -target_latency @var{target_latency}
 Set an intended target latency in seconds (fractional value can be set) for serving. Applicable only when @var{streaming} and @var{write_prft} options are enabled.
index 3b651b951444cc0323a5162a7dac54ce09aa8e84..9a8dde98e90f643a9e2070c1d440014c034abe6d 100644 (file)
@@ -167,7 +167,7 @@ typedef struct DASHContext {
     const char *utc_timing_url;
     const char *method;
     const char *user_agent;
-    char *http_opts;
+    AVDictionary *http_opts;
     int hls_playlist;
     int http_persistent;
     int master_playlist_created;
@@ -479,8 +479,7 @@ static void set_http_options(AVDictionary **options, DASHContext *c)
 {
     if (c->method)
         av_dict_set(options, "method", c->method, 0);
-    if (c->http_opts)
-        av_dict_parse_string(options, c->http_opts, "=", ",", 0);
+    av_dict_copy(options, c->http_opts, 0);
     if (c->user_agent)
         av_dict_set(options, "user_agent", c->user_agent, 0);
     if (c->http_persistent)
@@ -2273,7 +2272,7 @@ static const AVOption options[] = {
     { "mpd_profile", "Set profiles. Elements and values used in the manifest may be constrained by them", OFFSET(profile), AV_OPT_TYPE_FLAGS, {.i64 = MPD_PROFILE_DASH }, 0, UINT_MAX, E, "mpd_profile"},
     { "dash", "MPEG-DASH ISO Base media file format live profile", 0, AV_OPT_TYPE_CONST, {.i64 = MPD_PROFILE_DASH }, 0, UINT_MAX, E, "mpd_profile"},
     { "dvb_dash", "DVB-DASH profile", 0, AV_OPT_TYPE_CONST, {.i64 = MPD_PROFILE_DVB }, 0, UINT_MAX, E, "mpd_profile"},
-    { "http_opts", "HTTP protocol options", OFFSET(http_opts), AV_OPT_TYPE_STRING, { .str = NULL }, 0, 0, E },
+    { "http_opts", "HTTP protocol options", OFFSET(http_opts), AV_OPT_TYPE_DICT, { .str = NULL }, 0, 0, E },
     { "target_latency", "Set desired target latency for Low-latency dash", OFFSET(target_latency), AV_OPT_TYPE_DURATION, { .i64 = 0 }, 0, INT_MAX, E },
     { NULL },
 };