aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDavid Oberhollenzer <david.oberhollenzer@sigma-star.at>2023-05-29 15:39:08 +0200
committerDavid Oberhollenzer <david.oberhollenzer@sigma-star.at>2023-05-30 12:22:56 +0200
commitbcfa8cd22c44f08c5cf17708c1c1c26622e98f52 (patch)
tree4472cff18b676e7eacc010b497e1d77e9180bfb0
parent5197d47639146111bfb365fd543c83c539c8a9c5 (diff)
gensquashfs: Cleanup glob error handling
Move the error handling to the end of the function, make sure we properly handle all allocation failures. Signed-off-by: David Oberhollenzer <david.oberhollenzer@sigma-star.at>
-rw-r--r--bin/gensquashfs/src/glob.c94
1 files changed, 52 insertions, 42 deletions
diff --git a/bin/gensquashfs/src/glob.c b/bin/gensquashfs/src/glob.c
index c95d06d..48a687c 100644
--- a/bin/gensquashfs/src/glob.c
+++ b/bin/gensquashfs/src/glob.c
@@ -76,25 +76,18 @@ int glob_files(fstree_t *fs, const char *filename, size_t line_num,
/* fetch the actual target node */
root = fstree_get_node_by_path(fs, fs->root, path, true, false);
- if (root == NULL) {
- fprintf(stderr, "%s: " PRI_SZ ": %s: %s\n",
- filename, line_num, path, strerror(errno));
- return -1;
- }
+ if (root == NULL)
+ goto fail_path;
- if (!S_ISDIR(root->mode)) {
- fprintf(stderr, "%s: " PRI_SZ ": %s is not a directoy!\n",
- filename, line_num, path);
- return -1;
- }
+ if (!S_ISDIR(root->mode))
+ goto fail_not_dir;
prefix = fstree_get_path(root);
- if (canonicalize_name(prefix) != 0) {
- fprintf(stderr, "%s: " PRI_SZ ": error cannonicalizing `%s`!\n",
- filename, line_num, prefix);
- free(prefix);
- return -1;
- }
+ if (prefix == NULL)
+ goto fail_alloc;
+
+ if (canonicalize_name(prefix) != 0)
+ goto fail_prefix;
/* process options */
first_clear_flag = true;
@@ -136,11 +129,12 @@ int glob_files(fstree_t *fs, const char *filename, size_t line_num,
;
len = name_string_length(extra);
-
free(name_pattern);
name_pattern = strndup(extra, len);
- extra += len;
+ if (name_pattern == NULL)
+ goto fail_alloc;
+ extra += len;
while (isspace(*extra))
++extra;
@@ -153,11 +147,12 @@ int glob_files(fstree_t *fs, const char *filename, size_t line_num,
;
len = name_string_length(extra);
-
free(name_pattern);
name_pattern = strndup(extra, len);
- extra += len;
+ if (name_pattern == NULL)
+ goto fail_alloc;
+ extra += len;
while (isspace(*extra))
++extra;
@@ -173,12 +168,7 @@ int glob_files(fstree_t *fs, const char *filename, size_t line_num,
++extra;
break;
}
-
- fprintf(stderr, "%s: " PRI_SZ ": unknown option.\n",
- filename, line_num);
- free(name_pattern);
- free(prefix);
- return -1;
+ goto fail_unknown;
} else {
break;
}
@@ -205,29 +195,49 @@ int glob_files(fstree_t *fs, const char *filename, size_t line_num,
size_t slen = strlen(extra);
char *temp = calloc(1, plen + 1 + slen + 1);
- if (temp == NULL) {
- fprintf(stderr, "%s: " PRI_SZ ": allocation failure.\n",
- filename, line_num);
- } else {
- memcpy(temp, basepath, plen);
- temp[plen] = '/';
- memcpy(temp + plen + 1, extra, slen);
- temp[plen + 1 + slen] = '\0';
+ if (temp == NULL)
+ goto fail_alloc;
- dir = dir_tree_iterator_create(temp, &cfg);
- }
+ memcpy(temp, basepath, plen);
+ temp[plen] = '/';
+ memcpy(temp + plen + 1, extra, slen);
+ temp[plen + 1 + slen] = '\0';
+ dir = dir_tree_iterator_create(temp, &cfg);
free(temp);
}
- if (dir != NULL) {
- ret = fstree_from_dir(fs, dir);
- sqfs_drop(dir);
- } else {
- ret = -1;
- }
+ if (dir == NULL)
+ goto fail;
+
+ ret = fstree_from_dir(fs, dir);
+ sqfs_drop(dir);
free(name_pattern);
free(prefix);
return ret;
+fail_unknown:
+ fprintf(stderr, "%s: " PRI_SZ ": unknown glob option: %s.\n",
+ filename, line_num, extra);
+ goto fail;
+fail_path:
+ fprintf(stderr, "%s: " PRI_SZ ": %s: %s\n",
+ filename, line_num, path, strerror(errno));
+ goto fail;
+fail_not_dir:
+ fprintf(stderr, "%s: " PRI_SZ ": %s is not a directoy!\n",
+ filename, line_num, path);
+ goto fail;
+fail_prefix:
+ fprintf(stderr, "%s: " PRI_SZ ": error cannonicalizing `%s`!\n",
+ filename, line_num, prefix);
+ goto fail;
+fail_alloc:
+ fprintf(stderr, "%s: " PRI_SZ ": out of memory\n",
+ filename, line_num);
+ goto fail;
+fail:
+ free(name_pattern);
+ free(prefix);
+ return -1;
}