From 530b27df1e71852580d8b0d474543aeffe65618f Mon Sep 17 00:00:00 2001 From: Eelco Dolstra Date: Thu, 15 Dec 2005 21:11:39 +0000 Subject: * `nix-store --gc' prints out the number of bytes freed on stdout (even when it is interrupted by a signal). --- src/libutil/util.cc | 16 +++++++++++++--- src/libutil/util.hh | 5 ++++- 2 files changed, 17 insertions(+), 4 deletions(-) (limited to 'src/libutil') 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) @@ -223,10 +225,18 @@ 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); } diff --git a/src/libutil/util.hh b/src/libutil/util.hh index 9e7eb11bd16d..9601e65b3c63 100644 --- a/src/libutil/util.hh +++ b/src/libutil/util.hh @@ -98,9 +98,12 @@ string readFile(const Path & path); void writeFile(const Path & path, const string & s); /* Delete a path; i.e., in the case of a directory, it is deleted - recursively. Don't use this at home, kids. */ + recursively. Don't use this at home, kids. The second variant + returns the number of bytes freed. */ void deletePath(const Path & path); +void deletePath(const Path & path, unsigned long long & bytesFreed); + /* Make a path read-only recursively. */ void makePathReadOnly(const Path & path); -- cgit 1.4.1