aboutsummaryrefslogtreecommitdiff
path: root/lib/ftplistparser.c
diff options
context:
space:
mode:
authorDaniel Stenberg <daniel@haxx.se>2018-04-24 08:19:54 +0200
committerDaniel Stenberg <daniel@haxx.se>2018-04-24 08:19:54 +0200
commit5c39ccd83f051de3fc803584c1405b4fb5f9f899 (patch)
treed2678bd637914e34a3eef4c8961ded360ac55c68 /lib/ftplistparser.c
parenta7df35ce2130a99f26c4c8315ce46bf10804280e (diff)
Revert "ftplistparser: keep state between invokes"
This reverts commit abbc8457d85aca74b7cfda1d394b0844932b2934. Caused fuzzer problems on travis not seen when this was a PR!
Diffstat (limited to 'lib/ftplistparser.c')
-rw-r--r--lib/ftplistparser.c18
1 files changed, 7 insertions, 11 deletions
diff --git a/lib/ftplistparser.c b/lib/ftplistparser.c
index 249fe09c8..813e954c7 100644
--- a/lib/ftplistparser.c
+++ b/lib/ftplistparser.c
@@ -5,7 +5,7 @@
* | (__| |_| | _ <| |___
* \___|\___/|_| \_\_____|
*
- * Copyright (C) 1998 - 2018, Daniel Stenberg, <daniel@haxx.se>, et al.
+ * Copyright (C) 1998 - 2017, Daniel Stenberg, <daniel@haxx.se>, et al.
*
* This software is licensed as described in the file COPYING, which
* you should have received as part of this distribution. The terms
@@ -185,13 +185,10 @@ struct ftp_parselist_data *Curl_ftp_parselist_data_alloc(void)
}
-void Curl_ftp_parselist_data_free(struct ftp_parselist_data **parserp)
+void Curl_ftp_parselist_data_free(struct ftp_parselist_data **pl_data)
{
- struct ftp_parselist_data *parser = *parserp;
- if(parser)
- Curl_fileinfo_cleanup(parser->file_data);
- free(parser);
- *parserp = NULL;
+ free(*pl_data);
+ *pl_data = NULL;
}
@@ -316,7 +313,7 @@ static CURLcode ftp_pl_insert_finfo(struct connectdata *conn,
Curl_llist_insert_next(llist, llist->tail, finfo, &infop->list);
}
else {
- Curl_fileinfo_cleanup(infop);
+ Curl_fileinfo_dtor(NULL, finfo);
}
ftpwc->parser->file_data = NULL;
@@ -384,7 +381,7 @@ size_t Curl_ftp_parselist(char *buffer, size_t size, size_t nmemb,
finfo->b_data = tmp;
}
else {
- Curl_fileinfo_cleanup(parser->file_data);
+ Curl_fileinfo_dtor(NULL, parser->file_data);
parser->file_data = NULL;
parser->error = CURLE_OUT_OF_MEMORY;
goto fail;
@@ -1006,13 +1003,12 @@ size_t Curl_ftp_parselist(char *buffer, size_t size, size_t nmemb,
i++;
}
- return retsize;
fail:
/* Clean up any allocated memory. */
if(parser->file_data) {
- Curl_fileinfo_cleanup(parser->file_data);
+ Curl_fileinfo_dtor(NULL, parser->file_data);
parser->file_data = NULL;
}