diff options
author | Peter Holik <peter@holik.at> | 2009-06-06 16:44:21 +0000 |
---|---|---|
committer | Jai Menon <jmenon86@gmail.com> | 2009-06-06 16:44:21 +0000 |
commit | 682d49f4eaa310a4958287579473982010449f95 (patch) | |
tree | f442218b0e7714d5dd46565d54b4a95d068816fd | |
parent | 3bbc46102b54f7ac7c764c03e8718331b577797d (diff) | |
download | ffmpeg-682d49f4eaa310a4958287579473982010449f95.tar.gz |
Introduce http_get_line and modify http_connect to use http_get_line.
Patch by Peter Holik <$firstname @ $lastname . at>
Originally committed as revision 19124 to svn://svn.ffmpeg.org/ffmpeg/trunk
-rw-r--r-- | libavformat/http.c | 42 |
1 files changed, 27 insertions, 15 deletions
diff --git a/libavformat/http.c b/libavformat/http.c index d904e7a1e8..f8c44ce7ae 100644 --- a/libavformat/http.c +++ b/libavformat/http.c @@ -151,6 +151,30 @@ static int http_getc(HTTPContext *s) return *s->buf_ptr++; } +static int http_get_line(HTTPContext *s, char *line, int line_size) +{ + int ch; + char *q; + + q = line; + for(;;) { + ch = http_getc(s); + if (ch < 0) + return AVERROR(EIO); + if (ch == '\n') { + /* process line */ + if (q > line && q[-1] == '\r') + q--; + *q = '\0'; + + return 0; + } else { + if ((q - line) < line_size - 1) + *q++ = ch; + } + } +} + static int process_line(URLContext *h, char *line, int line_count, int *new_location) { @@ -209,8 +233,8 @@ static int http_connect(URLContext *h, const char *path, const char *hoststr, const char *auth, int *new_location) { HTTPContext *s = h->priv_data; - int post, err, ch; - char line[1024], *q; + int post, err; + char line[1024]; char *auth_b64; int auth_b64_len = (strlen(auth) + 2) / 3 * 4 + 1; int64_t off = s->off; @@ -251,16 +275,9 @@ static int http_connect(URLContext *h, const char *path, const char *hoststr, } /* wait for header */ - q = line; for(;;) { - ch = http_getc(s); - if (ch < 0) + if (http_get_line(s, line, sizeof(line)) < 0) return AVERROR(EIO); - if (ch == '\n') { - /* process line */ - if (q > line && q[-1] == '\r') - q--; - *q = '\0'; #ifdef DEBUG printf("header='%s'\n", line); #endif @@ -270,11 +287,6 @@ static int http_connect(URLContext *h, const char *path, const char *hoststr, if (err == 0) break; s->line_count++; - q = line; - } else { - if ((q - line) < sizeof(line) - 1) - *q++ = ch; - } } return (off == s->off) ? 0 : -1; |