#pragma once #include #include #include namespace DB { /// An atomic variable that is used to block and interrupt certain actions. /// If it is not zero then actions related with it should be considered as interrupted. /// Uses shared_ptr and the lock uses weak_ptr to be able to "hold" a lock when an object with blocker has already died. class ActionBlocker { public: ActionBlocker() : counter(std::make_shared(0)) {} bool isCancelled() const { return *counter > 0; } /// Temporary blocks corresponding actions (while the returned object is alive) friend class ActionLock; [[nodiscard]] ActionLock cancel() { return ActionLock(*this); } /// Cancel the actions forever. void cancelForever() { ++(*counter); } /// Returns reference to counter to allow to watch on it directly. const std::atomic & getCounter() const { return *counter; } private: using Counter = std::atomic; using CounterPtr = std::shared_ptr; CounterPtr counter; }; }