aboutsummaryrefslogtreecommitdiffstats
path: root/library/cpp/threading/future/subscription/subscription.cpp
diff options
context:
space:
mode:
authorDevtools Arcadia <arcadia-devtools@yandex-team.ru>2022-02-07 18:08:42 +0300
committerDevtools Arcadia <arcadia-devtools@mous.vla.yp-c.yandex.net>2022-02-07 18:08:42 +0300
commit1110808a9d39d4b808aef724c861a2e1a38d2a69 (patch)
treee26c9fed0de5d9873cce7e00bc214573dc2195b7 /library/cpp/threading/future/subscription/subscription.cpp
downloadydb-1110808a9d39d4b808aef724c861a2e1a38d2a69.tar.gz
intermediate changes
ref:cde9a383711a11544ce7e107a78147fb96cc4029
Diffstat (limited to 'library/cpp/threading/future/subscription/subscription.cpp')
-rw-r--r--library/cpp/threading/future/subscription/subscription.cpp65
1 files changed, 65 insertions, 0 deletions
diff --git a/library/cpp/threading/future/subscription/subscription.cpp b/library/cpp/threading/future/subscription/subscription.cpp
new file mode 100644
index 0000000000..a98b4a4f03
--- /dev/null
+++ b/library/cpp/threading/future/subscription/subscription.cpp
@@ -0,0 +1,65 @@
+#include "subscription.h"
+
+namespace NThreading {
+
+bool operator==(TSubscriptionId const& l, TSubscriptionId const& r) noexcept {
+ return l.StateId() == r.StateId() && l.SubId() == r.SubId();
+}
+
+bool operator!=(TSubscriptionId const& l, TSubscriptionId const& r) noexcept {
+ return !(l == r);
+}
+
+void TSubscriptionManager::TSubscription::operator()() {
+ Callback();
+}
+
+TSubscriptionManagerPtr TSubscriptionManager::NewInstance() {
+ return new TSubscriptionManager();
+}
+
+TSubscriptionManagerPtr TSubscriptionManager::Default() {
+ static auto instance = NewInstance();
+ return instance;
+}
+
+void TSubscriptionManager::Unsubscribe(TSubscriptionId id) {
+ with_lock(Lock) {
+ UnsubscribeImpl(id);
+ }
+}
+
+void TSubscriptionManager::Unsubscribe(TVector<TSubscriptionId> const& ids) {
+ with_lock(Lock) {
+ UnsubscribeImpl(ids);
+ }
+}
+
+void TSubscriptionManager::OnCallback(TFutureStateId stateId) noexcept {
+ THashMap<ui64, TSubscription> subscriptions;
+ with_lock(Lock) {
+ auto const it = Subscriptions.find(stateId);
+ Y_VERIFY(it != Subscriptions.end(), "The callback has been triggered more than once");
+ subscriptions.swap(it->second);
+ Subscriptions.erase(it);
+ }
+ for (auto& [_, subscription] : subscriptions) {
+ subscription();
+ }
+}
+
+void TSubscriptionManager::UnsubscribeImpl(TSubscriptionId id) {
+ auto const it = Subscriptions.find(id.StateId());
+ if (it == std::end(Subscriptions)) {
+ return;
+ }
+ it->second.erase(id.SubId());
+}
+
+void TSubscriptionManager::UnsubscribeImpl(TVector<TSubscriptionId> const& ids) {
+ for (auto const& id : ids) {
+ UnsubscribeImpl(id);
+ }
+}
+
+}