diff options
author | Volker Hilsheimer <volker.hilsheimer@qt.io> | 2023-10-25 07:53:45 +0000 |
---|---|---|
committer | Volker Hilsheimer <volker.hilsheimer@qt.io> | 2023-10-25 15:56:54 +0000 |
commit | 342b37f3884e62f2097addda1aacb1d15be38bf7 (patch) | |
tree | 20d9f3515de2d34951ea284abd368668e0468dd7 /src/corelib/thread/qatomic.h | |
parent | 1af821825a4173532cf14024ea9bebc75bf3c62c (diff) |
Revert "QAtomic: remove the copy ctor and assignment operator"
This reverts commit 6a93ec2435b8a453d43956fef6afa5f091d70ffc.
Reason for revert: Breaks qtdeclarative build, submodules need
to be clean before we deprecate or remove APIs.
Change-Id: Id0726b9bfad6072065b380b44b6ff6dffda79e45
Reviewed-by: Fabian Kosmale <fabian.kosmale@qt.io>
Reviewed-by: Friedemann Kleint <Friedemann.Kleint@qt.io>
Diffstat (limited to 'src/corelib/thread/qatomic.h')
-rw-r--r-- | src/corelib/thread/qatomic.h | 34 |
1 files changed, 29 insertions, 5 deletions
diff --git a/src/corelib/thread/qatomic.h b/src/corelib/thread/qatomic.h index 26369d28f8..7fe5ac69b9 100644 --- a/src/corelib/thread/qatomic.h +++ b/src/corelib/thread/qatomic.h @@ -17,8 +17,20 @@ template <typename T> class QAtomicInteger : public QBasicAtomicInteger<T> { public: + // Non-atomic API constexpr QAtomicInteger(T value = 0) noexcept : QBasicAtomicInteger<T>(value) {} - using QBasicAtomicInteger<T>::operator=; + + inline QAtomicInteger(const QAtomicInteger &other) noexcept + : QBasicAtomicInteger<T>() + { + this->storeRelease(other.loadAcquire()); + } + + inline QAtomicInteger &operator=(const QAtomicInteger &other) noexcept + { + this->storeRelease(other.loadAcquire()); + return *this; + } #ifdef Q_QDOC T loadRelaxed() const; @@ -96,12 +108,13 @@ public: #endif }; -// ### Qt 7: make QAtomicInt a typedef class QAtomicInt : public QAtomicInteger<int> { public: - using QAtomicInteger<int>::QAtomicInteger; - using QAtomicInteger<int>::operator=; + // Non-atomic API + // We could use QT_COMPILER_INHERITING_CONSTRUCTORS, but we need only one; + // the implicit definition for all the others is fine. + constexpr QAtomicInt(int value = 0) noexcept : QAtomicInteger<int>(value) {} }; // High-level atomic pointer operations @@ -110,7 +123,18 @@ class QAtomicPointer : public QBasicAtomicPointer<T> { public: constexpr QAtomicPointer(T *value = nullptr) noexcept : QBasicAtomicPointer<T>(value) {} - using QBasicAtomicPointer<T>::operator=; + + inline QAtomicPointer(const QAtomicPointer<T> &other) noexcept + : QBasicAtomicPointer<T>() + { + this->storeRelease(other.loadAcquire()); + } + + inline QAtomicPointer<T> &operator=(const QAtomicPointer<T> &other) noexcept + { + this->storeRelease(other.loadAcquire()); + return *this; + } #ifdef Q_QDOC T *loadAcquire() const; |