summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/du.c26
1 files changed, 19 insertions, 7 deletions
diff --git a/src/du.c b/src/du.c
index 9419e0fae..fbc07b534 100644
--- a/src/du.c
+++ b/src/du.c
@@ -359,16 +359,28 @@ process_file (const char *file, const struct stat *sb, int file_type,
break;
}
- if (!opt_count_all
- && 1 < sb->st_nlink
- && hash_ins (sb->st_ino, sb->st_dev))
- return 0; /* Have counted this already. */
+ /* If the file is being excluded or if it has already been counted
+ via a hard link, then don't let it contribute to the sums. */
+ if ((info->skip = excluded_filename (exclude, file + info->base))
+ || (!opt_count_all
+ && 1 < sb->st_nlink
+ && hash_ins (sb->st_ino, sb->st_dev)))
+ {
+ /* Note that we must not simply return here.
+ We still have to update prev_level and maybe propagate
+ some sums up the hierarchy. */
+ s = size = 0;
+ }
+ else
+ {
+ s = size = ST_NBLOCKS (*sb);
+ }
- if (excluded_filename (exclude, file + info->base))
+ /* If this is the first (pre-order) encounter with a directory,
+ return right away. */
+ if (file_type == FTW_DPRE)
return 0;
- s = size = ST_NBLOCKS (*sb);
-
if (first_call)
{
n_alloc = info->level + 10;