summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMike Frysinger2005-04-25 05:24:35 +0000
committerMike Frysinger2005-04-25 05:24:35 +0000
commitc238a97a9e90734da15163ba54d6862bb8e360e9 (patch)
tree5f7aa8b3884f523eea53f35e69a77362ca352235
parent7eb6457c4cf76ace4e738c01911c78ec52e51840 (diff)
downloadbusybox-c238a97a9e90734da15163ba54d6862bb8e360e9.zip
busybox-c238a97a9e90734da15163ba54d6862bb8e360e9.tar.gz
use asprintf in place of malloc/sprintf as suggested by solar
-rw-r--r--e2fsprogs/chattr.c8
-rw-r--r--e2fsprogs/lsattr.c18
2 files changed, 13 insertions, 13 deletions
diff --git a/e2fsprogs/chattr.c b/e2fsprogs/chattr.c
index 5aaa14f..07cee8f 100644
--- a/e2fsprogs/chattr.c
+++ b/e2fsprogs/chattr.c
@@ -167,11 +167,9 @@ static int chattr_dir_proc(const char *dir_name, struct dirent *de,
/*if (strcmp(de->d_name, ".") && strcmp(de->d_name, "..")) {*/
if (de->d_name[0] == '.' && (de->d_name[1] == '\0' || \
(de->d_name[1] == '.' && de->d_name[2] == '\0'))) {
-
- char *path = malloc(strlen(dir_name) + 1 + strlen(de->d_name) + 1);
- if (!path)
- bb_error_msg_and_die("Couldn't allocate path variable in chattr_dir_proc");
- sprintf(path, "%s/%s", dir_name, de->d_name);
+ char *path;
+ if (asprintf(&path, "%s/%s", dir_name, de->d_name) == -1)
+ bb_error_msg_and_die("asprintf failed");
change_attributes(path);
free(path);
}
diff --git a/e2fsprogs/lsattr.c b/e2fsprogs/lsattr.c
index be5723c..d389663 100644
--- a/e2fsprogs/lsattr.c
+++ b/e2fsprogs/lsattr.c
@@ -101,29 +101,31 @@ static int lsattr_dir_proc(const char *dir_name, struct dirent *de,
{
STRUCT_STAT st;
char *path;
- int dir_len = strlen(dir_name);
+ int i = strlen(dir_name);
- path = malloc(dir_len + strlen(de->d_name) + 2);
-
- if (dir_len && dir_name[dir_len-1] == '/')
- sprintf(path, "%s%s", dir_name, de->d_name);
+ if (i && dir_name[i-1] == '/')
+ i = asprintf(&path, "%s%s", dir_name, de->d_name);
else
- sprintf(path, "%s/%s", dir_name, de->d_name);
+ i = asprintf(&path, "%s/%s", dir_name, de->d_name);
+ if (i == -1)
+ bb_perror_msg_and_die("asprintf failed");
+
if (LSTAT(path, &st) == -1)
bb_perror_msg(path);
else {
if (de->d_name[0] != '.' || (flags & OPT_ALL)) {
list_attributes(path);
if (S_ISDIR(st.st_mode) && (flags & OPT_RECUR) &&
- strcmp(de->d_name, ".") &&
- strcmp(de->d_name, "..")) {
+ strcmp(de->d_name, ".") && strcmp(de->d_name, "..")) {
printf("\n%s:\n", path);
iterate_on_dir(path, lsattr_dir_proc, NULL);
printf("\n");
}
}
}
+
free(path);
+
return 0;
}