diff options
author | Eelco Dolstra <e.dolstra@tudelft.nl> | 2005-12-15T21·11+0000 |
---|---|---|
committer | Eelco Dolstra <e.dolstra@tudelft.nl> | 2005-12-15T21·11+0000 |
commit | 530b27df1e71852580d8b0d474543aeffe65618f (patch) | |
tree | 166f79c170b19ad82ca6bf9a3c77b96325b72aa1 /src/libutil/util.cc | |
parent | 5144f750c471cdb629750e96ddc913fb01fb9eef (diff) |
* `nix-store --gc' prints out the number of bytes freed on stdout
(even when it is interrupted by a signal).
Diffstat (limited to 'src/libutil/util.cc')
-rw-r--r-- | src/libutil/util.cc | 16 |
1 files changed, 13 insertions, 3 deletions
diff --git a/src/libutil/util.cc b/src/libutil/util.cc index 2e684e9c1441..5a728617dbd4 100644 --- a/src/libutil/util.cc +++ b/src/libutil/util.cc @@ -194,7 +194,7 @@ void writeFile(const Path & path, const string & s) } -static void _deletePath(const Path & path) +static void _deletePath(const Path & path, unsigned long long & bytesFreed) { checkInterrupt(); @@ -204,6 +204,8 @@ static void _deletePath(const Path & path) if (lstat(path.c_str(), &st)) throw SysError(format("getting attributes of path `%1%'") % path); + bytesFreed += st.st_size; + if (S_ISDIR(st.st_mode)) { Strings names = readDirectory(path); @@ -214,7 +216,7 @@ static void _deletePath(const Path & path) } for (Strings::iterator i = names.begin(); i != names.end(); ++i) - _deletePath(path + "/" + *i); + _deletePath(path + "/" + *i, bytesFreed); } if (remove(path.c_str()) == -1) @@ -224,9 +226,17 @@ static void _deletePath(const Path & path) void deletePath(const Path & path) { + unsigned long long dummy; + deletePath(path, dummy); +} + + +void deletePath(const Path & path, unsigned long long & bytesFreed) +{ startNest(nest, lvlDebug, format("recursively deleting path `%1%'") % path); - _deletePath(path); + bytesFreed = 0; + _deletePath(path, bytesFreed); } |