diff options
| author | Yuqian Yang <crupest@crupest.life> | 2025-11-16 12:14:47 +0800 |
|---|---|---|
| committer | Yuqian Yang <crupest@crupest.life> | 2025-11-16 12:14:47 +0800 |
| commit | faf73c4af74bdae1abf394a33b573149b98ec2b1 (patch) | |
| tree | aa985593c35a256e7190eddf47e023962a717ade /include/cru/base/Event.h | |
| parent | 4e0b7d82cd64ef8016dcb49247a8a5e4de8a0b3d (diff) | |
| download | cru-faf73c4af74bdae1abf394a33b573149b98ec2b1.tar.gz cru-faf73c4af74bdae1abf394a33b573149b98ec2b1.tar.bz2 cru-faf73c4af74bdae1abf394a33b573149b98ec2b1.zip | |
Clean DeleteLater.
Diffstat (limited to 'include/cru/base/Event.h')
| -rw-r--r-- | include/cru/base/Event.h | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/include/cru/base/Event.h b/include/cru/base/Event.h index 1f57e100..226c2ea4 100644 --- a/include/cru/base/Event.h +++ b/include/cru/base/Event.h @@ -16,7 +16,11 @@ class EventHandlerRevoker; class EventBase : public Object, public SelfResolvable<EventBase> { friend EventHandlerRevoker; + public: + CRU_DELETE_COPY(EventBase) + protected: + EventBase() = default; using EventHandlerToken = int; /** @@ -33,7 +37,7 @@ class EventHandlerRevoker { private: EventHandlerRevoker(ObjectResolver<EventBase>&& resolver, - EventBase::EventHandlerToken token) + EventBase::EventHandlerToken token) : resolver_(std::move(resolver)), token_(token) {} public: @@ -163,13 +167,15 @@ class EventHandlerRevokerGuard { } private: - std::unique_ptr<EventHandlerRevoker, details::EventHandlerRevokerDestroyer> revoker_; + std::unique_ptr<EventHandlerRevoker, details::EventHandlerRevokerDestroyer> + revoker_; }; class EventHandlerRevokerListGuard { public: void Add(EventHandlerRevoker&& revoker) { - event_revoker_guard_list_.push_back(EventHandlerRevokerGuard(std::move(revoker))); + event_revoker_guard_list_.push_back( + EventHandlerRevokerGuard(std::move(revoker))); } EventHandlerRevokerListGuard& operator+=(EventHandlerRevoker&& revoker) { |
