}
my ($mode_what,$mode_locknb,$mode_action);
if (-M _ <= $treeexpiredays) {
- if (!lstat "$gcdone") {
- $! == ENOENT or hkfail "$gcdone: lstat: $!";
- logm 'debug',
- "housekeeping: subdirs $subdir: touched recently, never gc'd!";
- } elsif (-M _ <= $gcintervaldays) {
- logm 'debug',
- "housekeeping: subdirs $subdir: touched recently, gc'd recently";
- next;
- } else {
- logm 'debug',
- "housekeeping: subdirs $subdir: touched recently, needs gc";
- }
+ my $gccheck = sub {
+ if (!lstat "$gcdone") {
+ $! == ENOENT or hkfail "$gcdone: lstat: $!";
+ return 1, "touched recently, never gc'd!";
+ } elsif (-M _ <= $gcintervaldays) {
+ return 0, "touched recently, gc'd recently";
+ } else {
+ return 1, "touched recently, needs gc";
+ }
+ };
+ my ($needsgc, $gcmsg) = $gccheck->();
+ logm 'debug', "housekeeping: subdirs $subdir: $gcmsg";
+ next unless $needsgc;
$mode_what = 'garbage collecting';
$mode_locknb = 0;
$mode_action = sub {