aboutsummaryrefslogtreecommitdiffstats
path: root/nihil.guard/guard.ccm
diff options
context:
space:
mode:
authorLexi Winter <lexi@le-fay.org>2025-07-02 03:05:56 +0100
committerLexi Winter <lexi@le-fay.org>2025-07-02 03:05:56 +0100
commitca697d6ca0c49f91ca13c72f0bb870d297b26767 (patch)
tree1f0e875a019804022b043878fc56404d88becd9a /nihil.guard/guard.ccm
parent83eae6f3280b237ff4fb080947658cc91fde9532 (diff)
downloadnihil-ca697d6ca0c49f91ca13c72f0bb870d297b26767.tar.gz
nihil-ca697d6ca0c49f91ca13c72f0bb870d297b26767.tar.bz2
move guard to util
Diffstat (limited to 'nihil.guard/guard.ccm')
-rw-r--r--nihil.guard/guard.ccm41
1 files changed, 0 insertions, 41 deletions
diff --git a/nihil.guard/guard.ccm b/nihil.guard/guard.ccm
deleted file mode 100644
index fdda45c..0000000
--- a/nihil.guard/guard.ccm
+++ /dev/null
@@ -1,41 +0,0 @@
-// This source code is released into the public domain.
-export module nihil.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