Fixed delay before exiting

This commit is contained in:
Ryzerth 2021-04-21 18:36:45 +02:00
parent 4849d9cf09
commit 38c9e2c894
2 changed files with 14 additions and 1 deletions

View File

@ -48,13 +48,17 @@ void ConfigManager::save(bool lock) {
void ConfigManager::enableAutoSave() {
if (!autoSaveEnabled) {
autoSaveEnabled = true;
termFlag = false;
autoSaveThread = std::thread(autoSaveWorker, this);
}
}
void ConfigManager::disableAutoSave() {
if (autoSaveEnabled) {
std::unique_lock<std::mutex> lock(termMtx);
autoSaveEnabled = false;
termFlag = true;
termCond.notify_one();
autoSaveThread.join();
}
}
@ -80,6 +84,11 @@ void ConfigManager::autoSaveWorker(ConfigManager* _this) {
_this->save(false);
}
_this->mtx.unlock();
std::this_thread::sleep_for(std::chrono::milliseconds(1000));
// Sleep but listen for wakeup call
{
std::unique_lock<std::mutex> lock(_this->termMtx);
_this->termCond.wait_for(lock, std::chrono::milliseconds(1000), [_this]() { return _this->termFlag; } );
}
}
}

View File

@ -29,4 +29,8 @@ private:
std::thread autoSaveThread;
std::mutex mtx;
std::mutex termMtx;
std::condition_variable termCond;
bool termFlag = false;
};