summaryrefslogtreecommitdiff
path: root/lib/cookie.c
diff options
context:
space:
mode:
authorDaniel Stenberg <daniel@haxx.se>2019-02-26 16:35:07 +0100
committerDaniel Stenberg <daniel@haxx.se>2019-02-27 14:32:07 +0100
commit6373579f8abc2d6eac8beb117810587e0239da24 (patch)
tree1314104d0e9cdcf970f9d69013022b23e8205aa5 /lib/cookie.c
parent0f6c6efd814a46a51981a29a5cb64c7a0858d5eb (diff)
downloadcurl-6373579f8abc2d6eac8beb117810587e0239da24.tar.gz
cookies: only save the cookie file if the engine is enabledbagder/cookies-save-only-if-enabled
Follow-up to 8eddb8f4259. If the cookieinfo pointer is NULL there really is nothing to save. Without this fix, we got a problem when a handle was using shared object with cookies and is told to "FLUSH" it to file (which worked) and then the share object was removed and when the easy handle was closed just afterwards it has no cookieinfo and no cookies so it decided to save an empty jar (overwriting the file just flushed). Test 1905 now verifies that this works. Assisted-by: Michael Wallner
Diffstat (limited to 'lib/cookie.c')
-rw-r--r--lib/cookie.c9
1 files changed, 6 insertions, 3 deletions
diff --git a/lib/cookie.c b/lib/cookie.c
index a58ce2b35..65cc11732 100644
--- a/lib/cookie.c
+++ b/lib/cookie.c
@@ -1541,9 +1541,12 @@ static int cookie_output(struct CookieInfo *c, const char *dumphere)
unsigned int j;
struct Cookie **array;
+ if(!c)
+ /* no cookie engine alive */
+ return 0;
+
/* at first, remove expired cookies */
- if(c)
- remove_expired(c);
+ remove_expired(c);
if(!strcmp("-", dumphere)) {
/* use stdout */
@@ -1562,7 +1565,7 @@ static int cookie_output(struct CookieInfo *c, const char *dumphere)
"# This file was generated by libcurl! Edit at your own risk.\n\n",
out);
- if(c && c->numcookies) {
+ if(c->numcookies) {
array = malloc(sizeof(struct Cookie *) * c->numcookies);
if(!array) {
if(!use_stdout)