diff options
author | Anton Samokhvalov <pg83@yandex.ru> | 2022-02-10 16:45:17 +0300 |
---|---|---|
committer | Daniil Cherednik <dcherednik@yandex-team.ru> | 2022-02-10 16:45:17 +0300 |
commit | d3a398281c6fd1d3672036cb2d63f842d2cb28c5 (patch) | |
tree | dd4bd3ca0f36b817e96812825ffaf10d645803f2 /library/cpp/coroutine/engine/impl.cpp | |
parent | 72cb13b4aff9bc9cf22e49251bc8fd143f82538f (diff) | |
download | ydb-d3a398281c6fd1d3672036cb2d63f842d2cb28c5.tar.gz |
Restoring authorship annotation for Anton Samokhvalov <pg83@yandex.ru>. Commit 2 of 2.
Diffstat (limited to 'library/cpp/coroutine/engine/impl.cpp')
-rw-r--r-- | library/cpp/coroutine/engine/impl.cpp | 36 |
1 files changed, 18 insertions, 18 deletions
diff --git a/library/cpp/coroutine/engine/impl.cpp b/library/cpp/coroutine/engine/impl.cpp index df08ddd3cc..7ae6f74051 100644 --- a/library/cpp/coroutine/engine/impl.cpp +++ b/library/cpp/coroutine/engine/impl.cpp @@ -1,15 +1,15 @@ #include "impl.h" - + #include "stack/stack_allocator.h" #include "stack/stack_guards.h" #include <util/generic/scope.h> #include <util/thread/singleton.h> #include <util/stream/format.h> -#include <util/stream/output.h> +#include <util/stream/output.h> #include <util/system/yassert.h> - - + + TCont::TJoinWait::TJoinWait(TCont& c) noexcept : Cont_(c) {} @@ -35,12 +35,12 @@ TCont::TCont(NCoro::NStack::IAllocator& allocator, void TCont::PrintMe(IOutputStream& out) const noexcept { - out << "cont(" + out << "cont(" << "name = " << Name_ << ", " << "addr = " << Hex((size_t)this) - << ")"; -} - + << ")"; +} + bool TCont::Join(TCont* c, TInstant deadLine) noexcept { TJoinWait ev(*this); c->Waiters_.PushBack(&ev); @@ -148,8 +148,8 @@ void TContExecutor::Execute(TContFunc func, void* arg) noexcept { func(cont, arg); }, "sys_main"); RunScheduler(); -} - +} + void TContExecutor::WaitForIO() { while (Ready_.Empty() && !WaitQueue_.Empty()) { const auto now = Now(); @@ -190,8 +190,8 @@ void TContExecutor::WaitForIO() { Ready_.Append(ReadyNext_); } -} - +} + void TContExecutor::Poll(TInstant deadline) { Poller_.Wait(PollerEvents_, deadline); LastPoll_ = Now(); @@ -217,8 +217,8 @@ void TContExecutor::Poll(TInstant deadline) { } } } -} - +} + void TContExecutor::Abort() noexcept { WaitQueue_.Abort(); auto visitor = [](TCont* c) { @@ -324,7 +324,7 @@ void TContExecutor::RunScheduler() noexcept { } TCont* cont = Ready_.PopFront(); - + if (ScheduleCallback_) { ScheduleCallback_->OnSchedule(*this, *cont); } @@ -347,9 +347,9 @@ void TContExecutor::RunScheduler() noexcept { } catch (...) { TBackTrace::FromCurrentException().PrintTo(Cerr); Y_FAIL("Uncaught exception in the scheduler: %s", CurrentExceptionMessage().c_str()); - } + } } - + void TContExecutor::Pause() { if (auto cont = Running()) { Paused_ = true; @@ -371,4 +371,4 @@ TInstant TContExecutor::Now() { template <> void Out<TCont>(IOutputStream& out, const TCont& c) { c.PrintMe(out); -} +} |