Split Q_COMPILER_DEFAULT_DELETE_MEMBERS

Based on reviewer comments on
https://codereview.qt-project.org/#change,25992, split
Q_COMPILER_DEFAULT_DELETE_MEMBERS into
Q_COMPILER_DEFAULT_MEMBERS and Q_COMPILER_DELETE_MEMBERS. Clang provides
2 separate feature checks for these, all other compilers always define
both.

Keep the Q_COMPILER_DEFAULT_DELETE_MEMBERS define, though, for any
existing code that may be using it.

Change-Id: I8969e10989c776a822da153152cfecb99dda8cb9
Reviewed-by: Olivier Goffart <ogoffart@woboq.com>
Reviewed-by: Thiago Macieira <thiago.macieira@intel.com>
This commit is contained in:
Bradley T. Hughes 2012-05-14 09:22:40 +02:00 committed by Qt by Nokia
parent 3976339ca9
commit e1cee9222d
2 changed files with 25 additions and 8 deletions

View File

@ -451,7 +451,8 @@
* N2437 Q_COMPILER_CLASS_ENUM * N2437 Q_COMPILER_CLASS_ENUM
* N2235 Q_COMPILER_CONSTEXPR * N2235 Q_COMPILER_CONSTEXPR
* N2343 N3276 Q_COMPILER_DECLTYPE * N2343 N3276 Q_COMPILER_DECLTYPE
* N2346 Q_COMPILER_DEFAULT_DELETE_MEMBERS * N2346 Q_COMPILER_DEFAULT_MEMBERS
* N2346 Q_COMPILER_DELETE_MEMBERS
* N1986 Q_COMPILER_DELEGATING_CONSTRUCTORS * N1986 Q_COMPILER_DELEGATING_CONSTRUCTORS
* N3206 N3272 Q_COMPILER_EXPLICIT_OVERRIDES (v0.9 and above only) * N3206 N3272 Q_COMPILER_EXPLICIT_OVERRIDES (v0.9 and above only)
* N1987 Q_COMPILER_EXTERN_TEMPLATES * N1987 Q_COMPILER_EXTERN_TEMPLATES
@ -484,7 +485,8 @@
# define Q_COMPILER_AUTO_TYPE # define Q_COMPILER_AUTO_TYPE
# define Q_COMPILER_CLASS_ENUM # define Q_COMPILER_CLASS_ENUM
# define Q_COMPILER_DECLTYPE # define Q_COMPILER_DECLTYPE
# define Q_COMPILER_DEFAULT_DELETE_MEMBERS # define Q_COMPILER_DEFAULT_MEMBERS
# define Q_COMPILER_DELETE_MEMBERS
# define Q_COMPILER_EXTERN_TEMPLATES # define Q_COMPILER_EXTERN_TEMPLATES
# define Q_COMPILER_LAMBDA # define Q_COMPILER_LAMBDA
# define Q_COMPILER_RVALUE_REFS # define Q_COMPILER_RVALUE_REFS
@ -540,8 +542,11 @@
# if __has_feature(cxx_decltype) /* && __has_feature(cxx_decltype_incomplete_return_types) */ # if __has_feature(cxx_decltype) /* && __has_feature(cxx_decltype_incomplete_return_types) */
# define Q_COMPILER_DECLTYPE # define Q_COMPILER_DECLTYPE
# endif # endif
# if __has_feature(cxx_defaulted_functions) && __has_feature(cxx_deleted_functions) /* defaulted members in 3.0, deleted members in 2.9 */ # if __has_feature(cxx_defaulted_functions)
# define Q_COMPILER_DEFAULT_DELETE_MEMBERS # define Q_COMPILER_DEFAULT_MEMBERS
# endif
# if __has_feature(cxx_deleted_functions)
# define Q_COMPILER_DELETE_MEMBERS
# endif # endif
# if __has_feature(cxx_delegating_constructors) # if __has_feature(cxx_delegating_constructors)
# define Q_COMPILER_DELEGATING_CONSTRUCTORS # define Q_COMPILER_DELEGATING_CONSTRUCTORS
@ -620,7 +625,8 @@
# define Q_COMPILER_AUTO_FUNCTION # define Q_COMPILER_AUTO_FUNCTION
# define Q_COMPILER_AUTO_TYPE # define Q_COMPILER_AUTO_TYPE
# define Q_COMPILER_CLASS_ENUM # define Q_COMPILER_CLASS_ENUM
# define Q_COMPILER_DEFAULT_DELETE_MEMBERS # define Q_COMPILER_DEFAULT_MEMBERS
# define Q_COMPILER_DELETE_MEMBERS
# define Q_COMPILER_EXTERN_TEMPLATES # define Q_COMPILER_EXTERN_TEMPLATES
# define Q_COMPILER_INITIALIZER_LISTS # define Q_COMPILER_INITIALIZER_LISTS
# define Q_COMPILER_UNICODE_STRINGS # define Q_COMPILER_UNICODE_STRINGS
@ -668,12 +674,23 @@
# define Q_NULLPTR 0 # define Q_NULLPTR 0
#endif #endif
#ifdef Q_COMPILER_DEFAULT_DELETE_MEMBERS #ifdef Q_COMPILER_DEFAULT_MEMBERS
# define Q_DECL_EQ_DEFAULT = default
#else
# define Q_DECL_EQ_DEFAULT
#endif
#ifdef Q_COMPILER_DELETE_MEMBERS
# define Q_DECL_EQ_DELETE = delete # define Q_DECL_EQ_DELETE = delete
#else #else
# define Q_DECL_EQ_DELETE # define Q_DECL_EQ_DELETE
#endif #endif
// Don't break code that is already using Q_COMPILER_DEFAULT_DELETE_MEMBERS
#if defined(Q_COMPILER_DEFAULT_MEMBERS) && defined(Q_COMPILER_DELETE_MEMBERS)
# define Q_COMPILER_DEFAULT_DELETE_MEMBERS
#endif
#ifdef Q_COMPILER_CONSTEXPR #ifdef Q_COMPILER_CONSTEXPR
# define Q_DECL_CONSTEXPR constexpr # define Q_DECL_CONSTEXPR constexpr
#else #else

View File

@ -179,7 +179,7 @@ public:
T fetchAndAddOrdered(T valueToAdd) T fetchAndAddOrdered(T valueToAdd)
{ return Ops::fetchAndAddOrdered(_q_value, valueToAdd); } { return Ops::fetchAndAddOrdered(_q_value, valueToAdd); }
#if defined(Q_COMPILER_CONSTEXPR) && defined(Q_COMPILER_DEFAULT_DELETE_MEMBERS) #if defined(Q_COMPILER_CONSTEXPR) && defined(Q_COMPILER_DEFAULT_MEMBERS) && defined(Q_COMPILER_DELETE_MEMBERS)
QBasicAtomicInteger() = default; QBasicAtomicInteger() = default;
constexpr QBasicAtomicInteger(T value) : _q_value(value) {} constexpr QBasicAtomicInteger(T value) : _q_value(value) {}
QBasicAtomicInteger(const QBasicAtomicInteger &) = delete; QBasicAtomicInteger(const QBasicAtomicInteger &) = delete;
@ -243,7 +243,7 @@ public:
Type fetchAndAddOrdered(qptrdiff valueToAdd) Type fetchAndAddOrdered(qptrdiff valueToAdd)
{ return Ops::fetchAndAddOrdered(_q_value, valueToAdd); } { return Ops::fetchAndAddOrdered(_q_value, valueToAdd); }
#if defined(Q_COMPILER_CONSTEXPR) && defined(Q_COMPILER_DEFAULT_DELETE_MEMBERS) #if defined(Q_COMPILER_CONSTEXPR) && defined(Q_COMPILER_DEFAULT_MEMBERS) && defined(Q_COMPILER_DELETE_MEMBERS)
QBasicAtomicPointer() = default; QBasicAtomicPointer() = default;
constexpr QBasicAtomicPointer(Type value) : _q_value(value) {} constexpr QBasicAtomicPointer(Type value) : _q_value(value) {}
QBasicAtomicPointer(const QBasicAtomicPointer &) = delete; QBasicAtomicPointer(const QBasicAtomicPointer &) = delete;