JUCE-7.0.12-0-g4f43011b96 JUCE-7.0.12-0-g4f43011b96
JUCE — C++ application framework with suport for VST, VST3, LV2 audio plug-ins

« « « Anklang Documentation
Loading...
Searching...
No Matches
juce_ScopedWriteLock.h
Go to the documentation of this file.
1 /*
2 ==============================================================================
3
4 This file is part of the JUCE library.
5 Copyright (c) 2022 - Raw Material Software Limited
6
7 JUCE is an open source library subject to commercial or open-source
8 licensing.
9
10 The code included in this file is provided under the terms of the ISC license
11 http://www.isc.org/downloads/software-support-policy/isc-license. Permission
12 To use, copy, modify, and/or distribute this software for any purpose with or
13 without fee is hereby granted provided that the above copyright notice and
14 this permission notice appear in all copies.
15
16 JUCE IS PROVIDED "AS IS" WITHOUT ANY WARRANTY, AND ALL WARRANTIES, WHETHER
17 EXPRESSED OR IMPLIED, INCLUDING MERCHANTABILITY AND FITNESS FOR PURPOSE, ARE
18 DISCLAIMED.
19
20 ==============================================================================
21*/
22
23namespace juce
24{
25
26//==============================================================================
51class JUCE_API ScopedWriteLock
52{
53public:
54 //==============================================================================
65 inline explicit ScopedWriteLock (const ReadWriteLock& lock) noexcept : lock_ (lock) { lock.enterWrite(); }
66
74 inline ~ScopedWriteLock() noexcept { lock_.exitWrite(); }
75
76
77private:
78 //==============================================================================
79 const ReadWriteLock& lock_;
80
82};
83
84//==============================================================================
119class JUCE_API ScopedTryWriteLock
120{
121public:
122 //==============================================================================
132 : ScopedTryWriteLock (lockIn, true) {}
133
144 ScopedTryWriteLock (ReadWriteLock& lockIn, bool acquireLockOnInitialisation) noexcept
145 : lock (lockIn), lockWasSuccessful (acquireLockOnInitialisation && lock.tryEnterWrite()) {}
146
154 ~ScopedTryWriteLock() noexcept { if (lockWasSuccessful) lock.exitWrite(); }
155
157 bool isLocked() const noexcept { return lockWasSuccessful; }
158
160 bool retryLock() noexcept { return lockWasSuccessful = lock.tryEnterWrite(); }
161
162private:
163 //==============================================================================
164 ReadWriteLock& lock;
165 bool lockWasSuccessful;
166
168};
169
170}
A critical section that allows multiple simultaneous readers.
Automatically locks and unlocks a ReadWriteLock object.
bool retryLock() noexcept
Retry gaining the lock by calling tryEnter on the underlying lock.
ScopedTryWriteLock(ReadWriteLock &lockIn, bool acquireLockOnInitialisation) noexcept
Creates a ScopedTryWriteLock.
ScopedTryWriteLock(ReadWriteLock &lockIn) noexcept
Creates a ScopedTryWriteLock and calls ReadWriteLock::tryEnterWrite() immediately.
~ScopedTryWriteLock() noexcept
Destructor.
bool isLocked() const noexcept
Returns true if the mutex was successfully locked.
Automatically locks and unlocks a ReadWriteLock object.
ScopedWriteLock(const ReadWriteLock &lock) noexcept
Creates a ScopedWriteLock.
~ScopedWriteLock() noexcept
Destructor.
#define JUCE_DECLARE_NON_COPYABLE(className)
This is a shorthand macro for deleting a class's copy constructor and copy assignment operator.
JUCE Namespace.