summaryrefslogtreecommitdiff
path: root/src/tool_urlglob.c
diff options
context:
space:
mode:
authorYang Tse <yangsita@gmail.com>2011-10-05 22:01:42 +0200
committerYang Tse <yangsita@gmail.com>2011-10-05 22:01:42 +0200
commit7296b2aa256049bec7ea7a372dee5cb319c7feca (patch)
tree5d64e31d6b369b774a85d2d4801af57f0d2b41c1 /src/tool_urlglob.c
parent6c849321d7545bcba1eb014d53b55db561015e52 (diff)
downloadcurl-7296b2aa256049bec7ea7a372dee5cb319c7feca.tar.gz
curl tool: OOM handling fixes
Diffstat (limited to 'src/tool_urlglob.c')
-rw-r--r--src/tool_urlglob.c35
1 files changed, 24 insertions, 11 deletions
diff --git a/src/tool_urlglob.c b/src/tool_urlglob.c
index 108fc3987..f5c09a1e8 100644
--- a/src/tool_urlglob.c
+++ b/src/tool_urlglob.c
@@ -419,7 +419,7 @@ void glob_cleanup(URLGlob* glob)
Curl_safefree(glob);
}
-char *glob_next_url(URLGlob *glob)
+int glob_next_url(char **globbed, URLGlob *glob)
{
URLPattern *pat;
char *lit;
@@ -429,6 +429,8 @@ char *glob_next_url(URLGlob *glob)
size_t buflen = glob->urllen + 1;
char *buf = glob->glob_buffer;
+ *globbed = NULL;
+
if(!glob->beenhere)
glob->beenhere = 1;
else {
@@ -464,11 +466,13 @@ char *glob_next_url(URLGlob *glob)
break;
default:
printf("internal error: invalid pattern type (%d)\n", (int)pat->type);
- exit (CURLE_FAILED_INIT);
+ return CURLE_FAILED_INIT;
}
}
- if(carry) /* first pattern ptr has run into overflow, done! */
- return NULL;
+ if(carry) { /* first pattern ptr has run into overflow, done! */
+ /* TODO: verify if this should actally return CURLE_OK. */
+ return CURLE_OK; /* CURLE_OK to match previous behavior */
+ }
}
for(j = 0; j < glob->size; ++j) {
@@ -502,15 +506,20 @@ char *glob_next_url(URLGlob *glob)
break;
default:
printf("internal error: invalid pattern type (%d)\n", (int)pat->type);
- exit (CURLE_FAILED_INIT);
+ return CURLE_FAILED_INIT;
}
}
}
*buf = '\0';
- return strdup(glob->glob_buffer);
+
+ *globbed = strdup(glob->glob_buffer);
+ if(!*globbed)
+ return CURLE_OUT_OF_MEMORY;
+
+ return CURLE_OK;
}
-char *glob_match_url(char *filename, URLGlob *glob)
+int glob_match_url(char **result, char *filename, URLGlob *glob)
{
char *target;
size_t allocsize;
@@ -519,6 +528,8 @@ char *glob_match_url(char *filename, URLGlob *glob)
size_t appendlen = 0;
size_t stringlen = 0;
+ *result = NULL;
+
/* We cannot use the glob_buffer for storage here since the filename may
* be longer than the URL we use. We allocate a good start size, then
* we need to realloc in case of need.
@@ -527,7 +538,7 @@ char *glob_match_url(char *filename, URLGlob *glob)
trailing zero */
target = malloc(allocsize);
if(!target)
- return NULL; /* major failure */
+ return CURLE_OUT_OF_MEMORY;
while(*filename) {
if(*filename == '#' && ISDIGIT(filename[1])) {
@@ -563,7 +574,7 @@ char *glob_match_url(char *filename, URLGlob *glob)
printf("internal error: invalid pattern type (%d)\n",
(int)pat.type);
Curl_safefree(target);
- return NULL;
+ return CURLE_FAILED_INIT;
}
}
else {
@@ -585,7 +596,7 @@ char *glob_match_url(char *filename, URLGlob *glob)
newstr = realloc(target, allocsize + 1);
if(!newstr) {
Curl_safefree(target);
- return NULL;
+ return CURLE_OUT_OF_MEMORY;
}
target = newstr;
}
@@ -593,5 +604,7 @@ char *glob_match_url(char *filename, URLGlob *glob)
stringlen += appendlen;
}
target[stringlen]= '\0';
- return target;
+ *result = target;
+ return CURLE_OK;
}
+