mirror of
https://github.com/hyprwm/hyprlock.git
synced 2025-01-03 02:09:49 +01:00
core: avoid double unlocks with no_fade_out (#257)
This commit is contained in:
parent
bc87adf9ec
commit
a50db6d56d
1 changed files with 11 additions and 5 deletions
|
@ -360,6 +360,8 @@ void CHyprlock::run() {
|
|||
|
||||
const auto CURRENTDESKTOP = getenv("XDG_CURRENT_DESKTOP");
|
||||
const auto SZCURRENTD = std::string{CURRENTDESKTOP ? CURRENTDESKTOP : ""};
|
||||
static auto* const PNOFADEOUT = (Hyprlang::INT* const*)g_pConfigManager->getValuePtr("general:no_fade_out");
|
||||
const bool NOFADEOUT = **PNOFADEOUT;
|
||||
|
||||
Debug::log(LOG, "Running on {}", SZCURRENTD);
|
||||
|
||||
|
@ -452,15 +454,19 @@ void CHyprlock::run() {
|
|||
|
||||
m_sLoopState.event = true; // let it process once
|
||||
|
||||
while (1) {
|
||||
while (!m_bTerminate) {
|
||||
std::unique_lock lk(m_sLoopState.eventRequestMutex);
|
||||
if (m_sLoopState.event == false)
|
||||
m_sLoopState.loopCV.wait_for(lk, std::chrono::milliseconds(5000), [this] { return m_sLoopState.event; });
|
||||
|
||||
if (m_bTerminate || (std::chrono::system_clock::now() > m_tFadeEnds && m_bFadeStarted)) {
|
||||
if (!NOFADEOUT && m_bFadeStarted && std::chrono::system_clock::now() > m_tFadeEnds) {
|
||||
releaseSessionLock();
|
||||
break;
|
||||
}
|
||||
|
||||
if (m_bTerminate)
|
||||
break;
|
||||
|
||||
std::lock_guard<std::mutex> lg(m_sLoopState.eventLoopMutex);
|
||||
|
||||
m_sLoopState.event = false;
|
||||
|
@ -506,7 +512,7 @@ void CHyprlock::run() {
|
|||
|
||||
passed.clear();
|
||||
|
||||
if (m_bTerminate || (std::chrono::system_clock::now() > m_tFadeEnds && m_bFadeStarted)) {
|
||||
if (!NOFADEOUT && m_bFadeStarted && std::chrono::system_clock::now() > m_tFadeEnds) {
|
||||
releaseSessionLock();
|
||||
break;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue