forked from lix-project/lix
Fix abort when the GC thread gets an exception
This commit is contained in:
parent
0b606aad46
commit
1277aab219
1 changed files with 21 additions and 13 deletions
|
@ -887,24 +887,32 @@ void LocalStore::autoGC(bool sync)
|
||||||
|
|
||||||
std::thread([promise{std::move(promise)}, this, avail, getAvail]() mutable {
|
std::thread([promise{std::move(promise)}, this, avail, getAvail]() mutable {
|
||||||
|
|
||||||
/* Wake up any threads waiting for the auto-GC to finish. */
|
try {
|
||||||
Finally wakeup([&]() {
|
|
||||||
auto state(_state.lock());
|
|
||||||
state->gcRunning = false;
|
|
||||||
state->lastGCCheck = std::chrono::steady_clock::now();
|
|
||||||
promise.set_value();
|
|
||||||
});
|
|
||||||
|
|
||||||
printInfo("running auto-GC to free %d bytes", settings.maxFree - avail);
|
/* Wake up any threads waiting for the auto-GC to finish. */
|
||||||
|
Finally wakeup([&]() {
|
||||||
|
auto state(_state.lock());
|
||||||
|
state->gcRunning = false;
|
||||||
|
state->lastGCCheck = std::chrono::steady_clock::now();
|
||||||
|
promise.set_value();
|
||||||
|
});
|
||||||
|
|
||||||
GCOptions options;
|
printInfo("running auto-GC to free %d bytes", settings.maxFree - avail);
|
||||||
options.maxFreed = settings.maxFree - avail;
|
|
||||||
|
|
||||||
GCResults results;
|
GCOptions options;
|
||||||
|
options.maxFreed = settings.maxFree - avail;
|
||||||
|
|
||||||
collectGarbage(options, results);
|
GCResults results;
|
||||||
|
|
||||||
_state.lock()->availAfterGC = getAvail();
|
collectGarbage(options, results);
|
||||||
|
|
||||||
|
_state.lock()->availAfterGC = getAvail();
|
||||||
|
|
||||||
|
} catch (...) {
|
||||||
|
// FIXME: we could propagate the exception to the
|
||||||
|
// future, but we don't really care.
|
||||||
|
ignoreException();
|
||||||
|
}
|
||||||
|
|
||||||
}).detach();
|
}).detach();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue