Commit cd3d0d54 authored by Lukasz Marek's avatar Lukasz Marek

lavf/ftp: remove fixed length buffers from context

It saves some memory.
Signed-off-by: 's avatarLukasz Marek <lukasz.m.luki2@gmail.com>
parent c043def9
...@@ -43,10 +43,10 @@ typedef struct { ...@@ -43,10 +43,10 @@ typedef struct {
uint8_t *control_buf_ptr, *control_buf_end; uint8_t *control_buf_ptr, *control_buf_end;
int server_data_port; /**< Data connection port opened by server, -1 on error. */ int server_data_port; /**< Data connection port opened by server, -1 on error. */
int server_control_port; /**< Control connection port, default is 21 */ int server_control_port; /**< Control connection port, default is 21 */
char hostname[512]; /**< Server address. */ char *hostname; /**< Server address. */
char *user; /**< Server user */ char *user; /**< Server user */
char *password; /**< Server user's password */ char *password; /**< Server user's password */
char path[MAX_URL_SIZE]; /**< Path to resource on server. */ char *path; /**< Path to resource on server. */
int64_t filesize; /**< Size of file on server, -1 on error. */ int64_t filesize; /**< Size of file on server, -1 on error. */
int64_t position; /**< Current position, calculated. */ int64_t position; /**< Current position, calculated. */
int rw_timeout; /**< Network timeout. */ int rw_timeout; /**< Network timeout. */
...@@ -351,9 +351,12 @@ static int ftp_current_dir(FTPContext *s) ...@@ -351,9 +351,12 @@ static int ftp_current_dir(FTPContext *s)
end[-1] = '\0'; end[-1] = '\0';
} else } else
*end = '\0'; *end = '\0';
av_strlcpy(s->path, start, sizeof(s->path)); s->path = av_strdup(start);
av_free(res); av_free(res);
if (!s->path)
return AVERROR(ENOMEM);
return 0; return 0;
fail: fail:
...@@ -569,10 +572,11 @@ static int ftp_abort(URLContext *h) ...@@ -569,10 +572,11 @@ static int ftp_abort(URLContext *h)
static int ftp_open(URLContext *h, const char *url, int flags) static int ftp_open(URLContext *h, const char *url, int flags)
{ {
char proto[10], path[MAX_URL_SIZE], credencials[MAX_URL_SIZE]; char proto[10], path[MAX_URL_SIZE], credencials[MAX_URL_SIZE], hostname[MAX_URL_SIZE];
const char *tok_user = NULL, *tok_pass = NULL; const char *tok_user = NULL, *tok_pass = NULL;
char *end = NULL; char *end = NULL;
int err; int err;
size_t pathlen;
FTPContext *s = h->priv_data; FTPContext *s = h->priv_data;
av_dlog(h, "ftp protocol open\n"); av_dlog(h, "ftp protocol open\n");
...@@ -583,7 +587,7 @@ static int ftp_open(URLContext *h, const char *url, int flags) ...@@ -583,7 +587,7 @@ static int ftp_open(URLContext *h, const char *url, int flags)
av_url_split(proto, sizeof(proto), av_url_split(proto, sizeof(proto),
credencials, sizeof(credencials), credencials, sizeof(credencials),
s->hostname, sizeof(s->hostname), hostname, sizeof(hostname),
&s->server_control_port, &s->server_control_port,
path, sizeof(path), path, sizeof(path),
url); url);
...@@ -596,7 +600,8 @@ static int ftp_open(URLContext *h, const char *url, int flags) ...@@ -596,7 +600,8 @@ static int ftp_open(URLContext *h, const char *url, int flags)
} }
s->user = av_strdup(tok_user); s->user = av_strdup(tok_user);
s->password = av_strdup(tok_pass); s->password = av_strdup(tok_pass);
if (!s->user || (tok_pass && !s->password)) { s->hostname = av_strdup(hostname);
if (!s->hostname || !s->user || (tok_pass && !s->password)) {
err = AVERROR(ENOMEM); err = AVERROR(ENOMEM);
goto fail; goto fail;
} }
...@@ -609,7 +614,10 @@ static int ftp_open(URLContext *h, const char *url, int flags) ...@@ -609,7 +614,10 @@ static int ftp_open(URLContext *h, const char *url, int flags)
if ((err = ftp_current_dir(s)) < 0) if ((err = ftp_current_dir(s)) < 0)
goto fail; goto fail;
av_strlcat(s->path, path, sizeof(s->path)); pathlen = strlen(s->path) + strlen(path) + 1;
if ((err = av_reallocp(&s->path, pathlen)) < 0)
goto fail;
av_strlcat(s->path + strlen(s->path), path, pathlen);
if (ftp_restart(s, 0) < 0) { if (ftp_restart(s, 0) < 0) {
h->is_streamed = 1; h->is_streamed = 1;
...@@ -766,6 +774,8 @@ static int ftp_close(URLContext *h) ...@@ -766,6 +774,8 @@ static int ftp_close(URLContext *h)
ftp_close_both_connections(s); ftp_close_both_connections(s);
av_freep(&s->user); av_freep(&s->user);
av_freep(&s->password); av_freep(&s->password);
av_freep(&s->hostname);
av_freep(&s->path);
return 0; return 0;
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment