From 3cda35dbcbbe1e3854b880169c0efa0fc7a79264 Mon Sep 17 00:00:00 2001 From: Yuqian Yang Date: Fri, 21 Nov 2025 14:31:45 +0800 Subject: Use AutoDestruct to impl EventHandlerRevokerGuard. --- include/cru/base/Event.h | 37 +++++------------------------------- include/cru/base/Guard.h | 4 ++-- include/cru/base/platform/win/Base.h | 6 ++++-- 3 files changed, 11 insertions(+), 36 deletions(-) (limited to 'include/cru/base') diff --git a/include/cru/base/Event.h b/include/cru/base/Event.h index 0bf54475..bdaf3ea6 100644 --- a/include/cru/base/Event.h +++ b/include/cru/base/Event.h @@ -1,11 +1,11 @@ #pragma once #include "Base.h" +#include "Guard.h" #include "SelfResolvable.h" #include #include #include -#include #include #include @@ -142,40 +142,13 @@ class Event : public EventBase, public IEvent { ::cru::IEvent* name##Event() { return &name##Event_; } namespace details { -struct EventHandlerRevokerDestroyer { - void operator()(EventHandlerRevoker* p) { - (*p)(); - delete p; - } +struct EventHandlerRevokerCaller { + void operator()(const EventHandlerRevoker& revoker) { revoker(); } }; } // namespace details -// A guard class for event revoker. Automatically revoke it when destroyed. -class EventHandlerRevokerGuard { - public: - EventHandlerRevokerGuard() = default; - explicit EventHandlerRevokerGuard(EventHandlerRevoker&& revoker) - : revoker_(new EventHandlerRevoker(std::move(revoker))) {} - - EventHandlerRevoker Get() { - // revoker is only null when this is moved - // you shouldn't use a moved instance - assert(revoker_); - return *revoker_; - } - - EventHandlerRevoker Release() { return std::move(*revoker_.release()); } - - void Reset() { revoker_.reset(); } - - void Reset(EventHandlerRevoker&& revoker) { - revoker_.reset(new EventHandlerRevoker(std::move(revoker))); - } - - private: - std::unique_ptr - revoker_; -}; +using EventHandlerRevokerGuard = + AutoDestruct; class EventHandlerRevokerListGuard { public: diff --git a/include/cru/base/Guard.h b/include/cru/base/Guard.h index a23e2574..ae120f5a 100644 --- a/include/cru/base/Guard.h +++ b/include/cru/base/Guard.h @@ -43,7 +43,7 @@ inline AutoFreePtr MakeAutoFree(T* ptr) { return AutoFreePtr(ptr); } -template +template class AutoDestruct { public: AutoDestruct() : value_(std::nullopt), auto_destruct_(false) {} @@ -110,7 +110,7 @@ class AutoDestruct { private: void DoDestruct() { if (auto_destruct_ && value_) { - DestructFunc(*value_); + Destructor{}(*value_); } } diff --git a/include/cru/base/platform/win/Base.h b/include/cru/base/platform/win/Base.h index cdd92541..cd5007e3 100644 --- a/include/cru/base/platform/win/Base.h +++ b/include/cru/base/platform/win/Base.h @@ -55,10 +55,12 @@ inline void CheckWinReturn(BOOL r, std::string_view message = "") { } namespace details { -inline void MyCloseHandle(HANDLE handle) noexcept { ::CloseHandle(handle); } +struct HandleCloser { + void operator()(HANDLE handle) noexcept { ::CloseHandle(handle); } +}; } // namespace details -using Win32Handle = AutoDestruct; +using Win32Handle = AutoDestruct; struct UniDirectionalWin32PipeResult { Win32Handle read; -- cgit v1.2.3