sbase

suckless unix tools
git clone git://git.2f30.org/sbase
Log | Files | Refs | README | LICENSE

commit 9b38355ae80e21afd156b5ddbdcea74c15011603
parent 2c42905f63c34de912df9b23096db55142d6687f
Author: sin <sin@2f30.org>
Date:   Wed, 19 Nov 2014 15:08:57 +0000

Break out if stat fails on the source file in cp(1)

Save one level of indentation.

Diffstat:
Mlibutil/cp.c | 86++++++++++++++++++++++++++++++++++++++++---------------------------------------
1 file changed, 44 insertions(+), 42 deletions(-)

diff --git a/libutil/cp.c b/libutil/cp.c @@ -39,61 +39,62 @@ cp(const char *s1, const char *s2) if (cp_vflag) printf("'%s' -> '%s'\n", s1, s2); - if (cp_dflag) - r = lstat(s1, &st); - else - r = stat(s1, &st); + r = cp_dflag ? lstat(s1, &st) : stat(s1, &st); + if (r < 0) { + weprintf("%s %s:", cp_dflag ? "lstat" : "stat", s1); + cp_status = 1; + return 0; + } - if (r == 0) { - if (cp_dflag && S_ISLNK(st.st_mode)) { - if (readlink(s1, buf, sizeof(buf) - 1) >= 0) { - if (cp_fflag) - unlink(s2); - if (symlink(buf, s2) != 0) { - weprintf("%s: can't create '%s'\n", argv0, s2); - cp_status = 1; - return 0; - } + if (cp_dflag && S_ISLNK(st.st_mode)) { + if (readlink(s1, buf, sizeof(buf) - 1) >= 0) { + if (cp_fflag) + unlink(s2); + if (symlink(buf, s2) != 0) { + weprintf("%s: can't create '%s'\n", argv0, s2); + cp_status = 1; + return 0; } - goto preserve; } - if (S_ISDIR(st.st_mode)) { - if (!cp_rflag) - eprintf("%s: is a directory\n", s1); + goto preserve; + } + + if (S_ISDIR(st.st_mode)) { + if (!cp_rflag) + eprintf("%s: is a directory\n", s1); - if (!(dp = opendir(s1))) - eprintf("opendir %s:", s1); + if (!(dp = opendir(s1))) + eprintf("opendir %s:", s1); - if (mkdir(s2, st.st_mode) == -1 && errno != EEXIST) - eprintf("mkdir %s:", s2); + if (mkdir(s2, st.st_mode) == -1 && errno != EEXIST) + eprintf("mkdir %s:", s2); - apathmax(&ns1, &size1); - apathmax(&ns2, &size2); - while ((d = readdir(dp))) { - if (strcmp(d->d_name, ".") && strcmp(d->d_name, "..")) { - r = snprintf(ns1, size1, "%s/%s", s1, d->d_name); - if (r >= size1 || r < 0) { - eprintf("%s/%s: filename too long\n", - s1, d->d_name); - } - r = snprintf(ns2, size2, "%s/%s", s2, d->d_name); - if (r >= size2 || r < 0) { - eprintf("%s/%s: filename too long\n", - s2, d->d_name); - } - fnck(ns1, ns2, cp); + apathmax(&ns1, &size1); + apathmax(&ns2, &size2); + while ((d = readdir(dp))) { + if (strcmp(d->d_name, ".") && strcmp(d->d_name, "..")) { + r = snprintf(ns1, size1, "%s/%s", s1, d->d_name); + if (r >= size1 || r < 0) { + eprintf("%s/%s: filename too long\n", + s1, d->d_name); } + r = snprintf(ns2, size2, "%s/%s", s2, d->d_name); + if (r >= size2 || r < 0) { + eprintf("%s/%s: filename too long\n", + s2, d->d_name); + } + fnck(ns1, ns2, cp); } - closedir(dp); - free(ns1); - free(ns2); - goto preserve; } + closedir(dp); + free(ns1); + free(ns2); + goto preserve; } if (cp_aflag) { if (S_ISBLK(st.st_mode) || S_ISCHR(st.st_mode) || - S_ISSOCK(st.st_mode) || S_ISFIFO(st.st_mode)) { + S_ISSOCK(st.st_mode) || S_ISFIFO(st.st_mode)) { unlink(s2); if (mknod(s2, st.st_mode, st.st_rdev) < 0) { weprintf("%s: can't create '%s':", argv0, s2); @@ -125,6 +126,7 @@ cp(const char *s1, const char *s2) } } concat(f1, s1, f2, s2); + /* preserve permissions by default */ fchmod(fileno(f2), st.st_mode); fclose(f2); fclose(f1);