diff options
author | Jim Meyering <jim@meyering.net> | 2002-11-24 16:12:52 +0000 |
---|---|---|
committer | Jim Meyering <jim@meyering.net> | 2002-11-24 16:12:52 +0000 |
commit | 4b8fa5d8ad97056eb4e5ec4c60ba223520570e0a (patch) | |
tree | ff9411a68b89dfbe95413a04709688c61f1aa69a | |
parent | 6f5375c038aea496240581fc527baf69b7676980 (diff) | |
download | coreutils-4b8fa5d8ad97056eb4e5ec4c60ba223520570e0a.tar.xz |
(du_files): Don't strip any trailing slash.
Rewrite so that `/' is no longer represented internally as
the empty string.
(count_entry): When appending a file name component,
account for the fact that the current path may end in `/'.
François Pinard reported that `du symlink-to-dir/' was not
equivalent to `du symlink-to-dir/.'. Now it is.
-rw-r--r-- | src/du.c | 27 |
1 files changed, 7 insertions, 20 deletions
@@ -427,6 +427,7 @@ count_entry (const char *ent, int top, dev_t last_dev, int depth) if (S_ISDIR (stat_buf.st_mode)) { unsigned pathlen; + unsigned prev_len; dev_t dir_dev; char *name_space; char *namep; @@ -488,7 +489,9 @@ count_entry (const char *ent, int top, dev_t last_dev, int depth) /* Remember the current path. */ - str_concatc (path, "/"); + prev_len = path->length; + if (prev_len && path->text[prev_len - 1] != '/') + str_concatc (path, "/"); pathlen = path->length; for (namep = name_space; *namep; namep += strlen (namep) + 1) @@ -504,7 +507,7 @@ count_entry (const char *ent, int top, dev_t last_dev, int depth) free (name_space); pop_dir (cwd, path->text); - str_trunc (path, pathlen - 1); /* Remove the "/" we added. */ + str_trunc (path, prev_len); /* Remove any "/" we added. */ if (depth <= max_depth || top) print_size (size, path->length > 0 ? path->text : "/"); return opt_separate_dirs ? 0 : size; @@ -530,24 +533,8 @@ du_files (char **files) for (i = 0; files[i]; i++) { - char *arg; - int s; - - arg = files[i]; - - /* Delete final slash in the argument, unless the slash is alone. */ - s = strlen (arg) - 1; - if (s != 0) - { - if (arg[s] == '/') - arg[s] = 0; - - str_copyc (path, arg); - } - else if (arg[0] == '/') - str_trunc (path, 0); /* Null path for root directory. */ - else - str_copyc (path, arg); + char const *arg = files[i]; + str_copyc (path, arg); if (!print_totals) hash_clear (htab); |