On Mon, Apr 6, 2015 at 1:02 AM, Michael Niedermayer <michae...@gmx.at> wrote:
> On Sun, Apr 05, 2015 at 05:58:39PM +0200, Stephan Holljes wrote:
>> With this patch http can be used to listen for POST data to be used as an 
>> input stream.
>>
>> Signed-off-by: Stephan Holljes <klaxa1...@googlemail.com>
>> ---
>>  libavformat/http.c | 7 +++++--
>>  1 file changed, 5 insertions(+), 2 deletions(-)
>>
>> diff --git a/libavformat/http.c b/libavformat/http.c
>> index 3276737..8961981 100644
>> --- a/libavformat/http.c
>> +++ b/libavformat/http.c
>> @@ -128,13 +128,14 @@ static const AVOption options[] = {
>>      { "end_offset", "try to limit the request to bytes preceding this 
>> offset", OFFSET(end_off), AV_OPT_TYPE_INT64, { .i64 = 0 }, 0, INT64_MAX, D },
>>      { "method", "Override the HTTP method", OFFSET(method), 
>> AV_OPT_TYPE_STRING, { .str = NULL }, 0, 0, E },
>>      { "reconnect", "auto reconnect after disconnect before EOF", 
>> OFFSET(reconnect), AV_OPT_TYPE_INT, { .i64 = 0 }, 0, 1, D },
>> -    { "listen", "listen on HTTP", OFFSET(listen), AV_OPT_TYPE_INT, { .i64 = 
>> 0 }, 0, 1, E },
>> +    { "listen", "listen on HTTP", OFFSET(listen), AV_OPT_TYPE_INT, { .i64 = 
>> 0 }, 0, 1, D | E },
>>      { NULL }
>>  };
>>
>>  static int http_connect(URLContext *h, const char *path, const char 
>> *local_path,
>>                          const char *hoststr, const char *auth,
>>                          const char *proxyauth, int *new_location);
>> +static int http_read_header(URLContext *h, int *new_location);
>>
>>  void ff_http_init_auth_state(URLContext *dest, const URLContext *src)
>>  {
>> @@ -305,7 +306,7 @@ static int http_listen(URLContext *h, const char *uri, 
>> int flags,
>>      static const char header[] = "HTTP/1.1 200 OK\r\nContent-Type: 
>> application/octet-stream\r\nTransfer-Encoding: chunked\r\n\r\n";
>>      char hostname[1024];
>>      char lower_url[100];
>> -    int port;
>> +    int port, new_location;
>>      av_url_split(NULL, 0, NULL, 0, hostname, sizeof(hostname), &port,
>>                   NULL, 0, uri);
>>      ff_url_join(lower_url, sizeof(lower_url), "tcp", NULL, hostname, port,
>> @@ -316,6 +317,8 @@ static int http_listen(URLContext *h, const char *uri, 
>> int flags,
>>          goto fail;
>>      if (ret = ffurl_write(s->hd, header, strlen(header)) < 0)
>>          goto fail;
>
>> +    if (ret = http_read_header(h, &new_location) < 0)
>
> this looks like it is missing some () around the =

The other two if-statements are missing them too then.
I added the fixes for those to the patch or should it be a separate patch?

>
> [...]
>
> --
> Michael     GnuPG fingerprint: 9FF2128B147EF6730BADF133611EC787040B0FAB
>
> Democracy is the form of government in which you can choose your dictator
>
> _______________________________________________
> ffmpeg-devel mailing list
> ffmpeg-devel@ffmpeg.org
> http://ffmpeg.org/mailman/listinfo/ffmpeg-devel
>

Regards,
Stephan Holljes
From d540d0f041c75b76f60e682851b38c58b00906f3 Mon Sep 17 00:00:00 2001
From: Stephan Holljes <klaxa1...@googlemail.com>
Date: Mon, 6 Apr 2015 05:11:17 +0200
Subject: [PATCH] libavformat/http.c: Make http-listen work as an input stream.

With this patch http can be used to listen for POST data to be used as an input stream.

Signed-off-by: Stephan Holljes <klaxa1...@googlemail.com>
---
 libavformat/http.c | 8 ++++----
 1 file changed, 4 insertions(+), 4 deletions(-)

diff --git a/libavformat/http.c b/libavformat/http.c
index 8961981..7883fea 100644
--- a/libavformat/http.c
+++ b/libavformat/http.c
@@ -312,12 +312,12 @@ static int http_listen(URLContext *h, const char *uri, int flags,
     ff_url_join(lower_url, sizeof(lower_url), "tcp", NULL, hostname, port,
                 NULL);
     av_dict_set(options, "listen", "1", 0);
-    if (ret = ffurl_open(&s->hd, lower_url, AVIO_FLAG_READ_WRITE,
-                         &h->interrupt_callback, options) < 0)
+    if ((ret = ffurl_open(&s->hd, lower_url, AVIO_FLAG_READ_WRITE,
+                          &h->interrupt_callback, options)) < 0)
         goto fail;
-    if (ret = ffurl_write(s->hd, header, strlen(header)) < 0)
+    if ((ret = ffurl_write(s->hd, header, strlen(header))) < 0)
         goto fail;
-    if (ret = http_read_header(h, &new_location) < 0)
+    if ((ret = http_read_header(h, &new_location)) < 0)
         goto fail;
     return 0;
 
-- 
2.3.3

_______________________________________________
ffmpeg-devel mailing list
ffmpeg-devel@ffmpeg.org
http://ffmpeg.org/mailman/listinfo/ffmpeg-devel

Reply via email to