diff options
author | swarmer <swarmer@yandex-team.ru> | 2022-02-10 16:46:31 +0300 |
---|---|---|
committer | Daniil Cherednik <dcherednik@yandex-team.ru> | 2022-02-10 16:46:31 +0300 |
commit | 317da38588b7898a99fd9168571408123350012b (patch) | |
tree | 25eebc31526019ad39a6c1b13f492963d97ba439 /util/system/atexit.cpp | |
parent | 3b2241461d41d41ba1a706b0750c4f0f55c344f6 (diff) | |
download | ydb-317da38588b7898a99fd9168571408123350012b.tar.gz |
Restoring authorship annotation for <swarmer@yandex-team.ru>. Commit 1 of 2.
Diffstat (limited to 'util/system/atexit.cpp')
-rw-r--r-- | util/system/atexit.cpp | 32 |
1 files changed, 16 insertions, 16 deletions
diff --git a/util/system/atexit.cpp b/util/system/atexit.cpp index 74fb10b6b1..9f77f07a06 100644 --- a/util/system/atexit.cpp +++ b/util/system/atexit.cpp @@ -1,5 +1,5 @@ #include "atexit.h" -#include "atomic.h" +#include "atomic.h" #include "yassert.h" #include "spinlock.h" #include "thread.h" @@ -77,29 +77,29 @@ namespace { }; static TAtomic atExitLock = 0; - static TAtExit* volatile atExitPtr = nullptr; + static TAtExit* volatile atExitPtr = nullptr; alignas(TAtExit) static char atExitMem[sizeof(TAtExit)]; static void OnExit() { - if (TAtExit* const atExit = AtomicGet(atExitPtr)) { + if (TAtExit* const atExit = AtomicGet(atExitPtr)) { atExit->Finish(); atExit->~TAtExit(); - AtomicSet(atExitPtr, nullptr); + AtomicSet(atExitPtr, nullptr); } } static inline TAtExit* Instance() { - if (TAtExit* const atExit = AtomicGet(atExitPtr)) { - return atExit; - } + if (TAtExit* const atExit = AtomicGet(atExitPtr)) { + return atExit; + } with_lock (atExitLock) { - if (TAtExit* const atExit = AtomicGet(atExitPtr)) { - return atExit; + if (TAtExit* const atExit = AtomicGet(atExitPtr)) { + return atExit; } - atexit(OnExit); - TAtExit* const atExit = new (atExitMem) TAtExit; - AtomicSet(atExitPtr, atExit); - return atExit; + atexit(OnExit); + TAtExit* const atExit = new (atExitMem) TAtExit; + AtomicSet(atExitPtr, atExit); + return atExit; } } } @@ -109,10 +109,10 @@ void ManualRunAtExitFinalizers() { } bool ExitStarted() { - if (TAtExit* const atExit = AtomicGet(atExitPtr)) { - return atExit->FinishStarted(); + if (TAtExit* const atExit = AtomicGet(atExitPtr)) { + return atExit->FinishStarted(); } - return false; + return false; } void AtExit(TAtExitFunc func, void* ctx, size_t priority) { |