eb233e728f
unreachable paths that haven't been used for N hours. For instance, `nix-collect-garbage --min-age 168' only deletes paths that haven't been accessed in the last week. This is useful for instance in the build farm where many derivations can be shared between consecutive builds, and we wouldn't want a garbage collect to throw them all away. We could of course register them as roots, but then we'd to unregister them at some point, which would be a pain to manage. The `--min-age' flag gives us a sort of MRU caching scheme. BUG: this really shouldn't be in gc.cc since that violates mechanism/policy separation.
26 lines
1.1 KiB
C++
26 lines
1.1 KiB
C++
#ifndef __GC_H
|
|
#define __GC_H
|
|
|
|
#include "storeexpr.hh"
|
|
|
|
|
|
/* Determine the set of "live" store paths, given a set of root store
|
|
expressions. The live store paths are those that are reachable
|
|
from the roots. The roots are reachable by definition. Any path
|
|
mentioned in a reachable store expression is also reachable. If a
|
|
derivation store expression is reachable, then its successor (if it
|
|
exists) if also reachable. It is not an error for store
|
|
expressions not to exist (since this can happen on derivation store
|
|
expressions, for instance, due to the substitute mechanism), but
|
|
successor links are followed even for non-existant derivations. */
|
|
PathSet findLivePaths(const Paths & roots);
|
|
|
|
/* Given a set of "live" store paths, determine the set of "dead"
|
|
store paths (which are simply all store paths that are not in the
|
|
live set). The value `minAge' specifies the minimum age in seconds
|
|
for an unreachable file to be considered dead (0 meaning that any
|
|
unreachable file is dead). */
|
|
PathSet findDeadPaths(const PathSet & live, time_t minAge);
|
|
|
|
|
|
#endif /* !__GC_H */
|