diff options
| author | Lexi Winter <lexi@le-fay.org> | 2025-07-02 04:00:06 +0100 |
|---|---|---|
| committer | Lexi Winter <lexi@le-fay.org> | 2025-07-02 04:00:06 +0100 |
| commit | 5adeb648f74c1771164c0686d6e0fc584cf36d9e (patch) | |
| tree | 060cd918d3dd9e931a1541a43c9edff1a404ff47 /nihil.util/guard.ccm | |
| parent | 06fafff8e9e9c096cc39bde0306caa53ad3a2351 (diff) | |
| download | nihil-5adeb648f74c1771164c0686d6e0fc584cf36d9e.tar.gz nihil-5adeb648f74c1771164c0686d6e0fc584cf36d9e.tar.bz2 | |
move everything from util to core
Diffstat (limited to 'nihil.util/guard.ccm')
| -rw-r--r-- | nihil.util/guard.ccm | 41 |
1 files changed, 0 insertions, 41 deletions
diff --git a/nihil.util/guard.ccm b/nihil.util/guard.ccm deleted file mode 100644 index 77394fc..0000000 --- a/nihil.util/guard.ccm +++ /dev/null @@ -1,41 +0,0 @@ -// This source code is released into the public domain. -export module nihil.util:guard; - -import nihil.std; - -namespace nihil { - -// guard: invoke a callable when this object is destroyed; this is similar to -// scope_exit from the library fundamentals TS, which LLVM doesn't implement. -export template<std::invocable F> -struct guard final { - // Initialise the guard with a callable we will invoke later. - explicit guard(F func) : m_func(std::move(func)) {} - - // We are being destroyed, so call the callable. - // If the callable throws, std::terminate() will be called. - ~guard() - { - if (m_func) - std::invoke(*m_func); - } - - // Release the guard. This turns the destructor into a no-op. - auto release(this guard &self) noexcept -> void - { - self.m_func.reset(); - } - - // Not default-constructible, movable or copyable. - guard() = delete; - guard(guard const &) = delete; - guard(guard &&) noexcept = delete; - auto operator=(this guard &, guard const &) -> guard & = delete; - auto operator=(this guard &, guard &&) noexcept -> guard & = delete; - -private: - // The callable to be invoked when we are destroyed. - std::optional<F> m_func; -}; - -} // namespace nihil |
