include/boost/corosio/detail/conditionally_enabled_mutex.hpp
92.3% Lines (24/26)
88.9% List of functions (8/9)
Functions (9)
Function
Calls
Lines
Blocks
boost::corosio::detail::conditionally_enabled_mutex::conditionally_enabled_mutex(bool)
:33
25883x
100.0%
100.0%
boost::corosio::detail::conditionally_enabled_mutex::set_enabled(bool)
:46
16947x
100.0%
100.0%
boost::corosio::detail::conditionally_enabled_mutex::lock()
:52
110756x
100.0%
100.0%
boost::corosio::detail::conditionally_enabled_mutex::unlock()
:53
110756x
100.0%
100.0%
boost::corosio::detail::conditionally_enabled_mutex::scoped_lock::scoped_lock(boost::corosio::detail::conditionally_enabled_mutex&)
:62
502291x
100.0%
83.0%
boost::corosio::detail::conditionally_enabled_mutex::scoped_lock::lock()
:73
465851x
100.0%
100.0%
boost::corosio::detail::conditionally_enabled_mutex::scoped_lock::unlock()
:79
468167x
100.0%
100.0%
boost::corosio::detail::conditionally_enabled_mutex::scoped_lock::owns_lock() const
:85
474518x
100.0%
100.0%
boost::corosio::detail::conditionally_enabled_mutex::scoped_lock::underlying()
:92
0
0.0%
0.0%
| Line | TLA | Hits | Source Code |
|---|---|---|---|
| 1 | // | ||
| 2 | // Copyright (c) 2026 Michael Vandeberg | ||
| 3 | // | ||
| 4 | // Distributed under the Boost Software License, Version 1.0. (See accompanying | ||
| 5 | // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) | ||
| 6 | // | ||
| 7 | // Official repository: https://github.com/cppalliance/corosio | ||
| 8 | // | ||
| 9 | |||
| 10 | #ifndef BOOST_COROSIO_DETAIL_CONDITIONALLY_ENABLED_MUTEX_HPP | ||
| 11 | #define BOOST_COROSIO_DETAIL_CONDITIONALLY_ENABLED_MUTEX_HPP | ||
| 12 | |||
| 13 | #include <mutex> | ||
| 14 | |||
| 15 | namespace boost::corosio::detail { | ||
| 16 | |||
| 17 | /* Mutex wrapper that becomes a no-op when disabled. | ||
| 18 | |||
| 19 | When enabled (the default), lock/unlock delegate to an | ||
| 20 | underlying std::mutex. When disabled, all operations are | ||
| 21 | no-ops. The enabled flag is fixed after construction. | ||
| 22 | |||
| 23 | scoped_lock wraps std::unique_lock<std::mutex> internally | ||
| 24 | so that condvar wait paths (which require the real lock | ||
| 25 | type) compile and work in multi-threaded mode. | ||
| 26 | */ | ||
| 27 | class conditionally_enabled_mutex | ||
| 28 | { | ||
| 29 | std::mutex mutex_; | ||
| 30 | bool enabled_; | ||
| 31 | |||
| 32 | public: | ||
| 33 | 25883x | explicit conditionally_enabled_mutex(bool enabled = true) noexcept | |
| 34 | 25883x | : enabled_(enabled) | |
| 35 | { | ||
| 36 | 25883x | } | |
| 37 | |||
| 38 | conditionally_enabled_mutex(conditionally_enabled_mutex const&) = delete; | ||
| 39 | conditionally_enabled_mutex& operator=(conditionally_enabled_mutex const&) = delete; | ||
| 40 | |||
| 41 | bool enabled() const noexcept | ||
| 42 | { | ||
| 43 | return enabled_; | ||
| 44 | } | ||
| 45 | |||
| 46 | 16947x | void set_enabled(bool v) noexcept | |
| 47 | { | ||
| 48 | 16947x | enabled_ = v; | |
| 49 | 16947x | } | |
| 50 | |||
| 51 | // Lockable interface — allows std::lock_guard<conditionally_enabled_mutex> | ||
| 52 | 110756x | void lock() { if (enabled_) mutex_.lock(); } | |
| 53 | 110756x | void unlock() { if (enabled_) mutex_.unlock(); } | |
| 54 | bool try_lock() { return !enabled_ || mutex_.try_lock(); } | ||
| 55 | |||
| 56 | class scoped_lock | ||
| 57 | { | ||
| 58 | std::unique_lock<std::mutex> lock_; | ||
| 59 | bool enabled_; | ||
| 60 | |||
| 61 | public: | ||
| 62 | 502291x | explicit scoped_lock(conditionally_enabled_mutex& m) | |
| 63 | 502291x | : lock_(m.mutex_, std::defer_lock) | |
| 64 | 502291x | , enabled_(m.enabled_) | |
| 65 | { | ||
| 66 | 502291x | if (enabled_) | |
| 67 | 502291x | lock_.lock(); | |
| 68 | 502291x | } | |
| 69 | |||
| 70 | scoped_lock(scoped_lock const&) = delete; | ||
| 71 | scoped_lock& operator=(scoped_lock const&) = delete; | ||
| 72 | |||
| 73 | 465851x | void lock() | |
| 74 | { | ||
| 75 | 465851x | if (enabled_) | |
| 76 | 465851x | lock_.lock(); | |
| 77 | 465851x | } | |
| 78 | |||
| 79 | 468167x | void unlock() | |
| 80 | { | ||
| 81 | 468167x | if (enabled_) | |
| 82 | 468167x | lock_.unlock(); | |
| 83 | 468167x | } | |
| 84 | |||
| 85 | 474518x | bool owns_lock() const noexcept | |
| 86 | { | ||
| 87 | 474518x | return enabled_ && lock_.owns_lock(); | |
| 88 | } | ||
| 89 | |||
| 90 | // Access the underlying unique_lock for condvar wait(). | ||
| 91 | // Only called when locking is enabled. | ||
| 92 | ✗ | std::unique_lock<std::mutex>& underlying() noexcept | |
| 93 | { | ||
| 94 | ✗ | return lock_; | |
| 95 | } | ||
| 96 | }; | ||
| 97 | }; | ||
| 98 | |||
| 99 | } // namespace boost::corosio::detail | ||
| 100 | |||
| 101 | #endif // BOOST_COROSIO_DETAIL_CONDITIONALLY_ENABLED_MUTEX_HPP | ||
| 102 |