summaryrefslogtreecommitdiffstats
path: root/src/corelib/thread/qatomic.h
diff options
context:
space:
mode:
authorVolker Hilsheimer <volker.hilsheimer@qt.io>2023-10-25 07:53:45 +0000
committerVolker Hilsheimer <volker.hilsheimer@qt.io>2023-10-25 15:56:54 +0000
commit342b37f3884e62f2097addda1aacb1d15be38bf7 (patch)
tree20d9f3515de2d34951ea284abd368668e0468dd7 /src/corelib/thread/qatomic.h
parent1af821825a4173532cf14024ea9bebc75bf3c62c (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.h34
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;