diff options
author | Yang Tse <yangsita@gmail.com> | 2012-04-04 17:30:12 +0200 |
---|---|---|
committer | Yang Tse <yangsita@gmail.com> | 2012-04-04 17:31:11 +0200 |
commit | 9753c6bec51faacd5f1783caaa00cb5f0e0fb8df (patch) | |
tree | 3b9c9c71e2ba9df583445f98a9b2611a0b03ef64 | |
parent | b16e3da12acf6860d3956a09285e42f29761789b (diff) |
ftp.c: ftplistparser related OOM handling fix
-rw-r--r-- | lib/ftp.c | 26 |
1 files changed, 19 insertions, 7 deletions
@@ -3824,15 +3824,17 @@ static CURLcode init_wc_data(struct connectdata *conn) resources for wildcard transfer */ /* allocate ftp protocol specific temporary wildcard data */ - ftp_tmp = malloc(sizeof(struct ftp_wc_tmpdata)); + ftp_tmp = calloc(1, sizeof(struct ftp_wc_tmpdata)); if(!ftp_tmp) { + Curl_safefree(wildcard->pattern); return CURLE_OUT_OF_MEMORY; } /* INITIALIZE parselist structure */ ftp_tmp->parser = Curl_ftp_parselist_data_alloc(); if(!ftp_tmp->parser) { - free(ftp_tmp); + Curl_safefree(wildcard->pattern); + Curl_safefree(ftp_tmp); return CURLE_OUT_OF_MEMORY; } @@ -3846,9 +3848,22 @@ static CURLcode init_wc_data(struct connectdata *conn) /* try to parse ftp url */ ret = ftp_parse_url_path(conn); if(ret) { + Curl_safefree(wildcard->pattern); + wildcard->tmp_dtor(wildcard->tmp); + wildcard->tmp_dtor = ZERO_NULL; + wildcard->tmp = NULL; return ret; } + wildcard->path = strdup(conn->data->state.path); + if(!wildcard->path) { + Curl_safefree(wildcard->pattern); + wildcard->tmp_dtor(wildcard->tmp); + wildcard->tmp_dtor = ZERO_NULL; + wildcard->tmp = NULL; + return CURLE_OUT_OF_MEMORY; + } + /* backup old write_function */ ftp_tmp->backup.write_function = conn->data->set.fwrite_func; /* parsing write function */ @@ -3858,11 +3873,6 @@ static CURLcode init_wc_data(struct connectdata *conn) /* let the writefunc callback know what curl pointer is working with */ conn->data->set.out = conn; - wildcard->path = strdup(conn->data->state.path); - if(!wildcard->path) { - return CURLE_OUT_OF_MEMORY; - } - infof(conn->data, "Wildcard - Parsing started\n"); return CURLE_OK; } @@ -3889,6 +3899,8 @@ static CURLcode wc_statemach(struct connectdata *conn) struct ftp_wc_tmpdata *ftp_tmp = wildcard->tmp; conn->data->set.fwrite_func = ftp_tmp->backup.write_function; conn->data->set.out = ftp_tmp->backup.file_descriptor; + ftp_tmp->backup.write_function = ZERO_NULL; + ftp_tmp->backup.file_descriptor = NULL; wildcard->state = CURLWC_DOWNLOADING; if(Curl_ftp_parselist_geterror(ftp_tmp->parser)) { |