diff options
author | Liang Qi <liang.qi@theqtcompany.com> | 2015-09-25 14:02:04 +0200 |
---|---|---|
committer | Liang Qi <liang.qi@theqtcompany.com> | 2015-09-25 14:02:04 +0200 |
commit | a1ad9a74ebb3c556c5f70f7e03be68b09598ac53 (patch) | |
tree | 615a96db418219a57a745a5899e39a9ac90744ec /config.tests | |
parent | 6d78b7a0c46ea04f4bb771d960e2f7dff1362341 (diff) | |
parent | 462f355e4fb16cc7a1838fa2dda0f763eee58c84 (diff) |
Merge remote-tracking branch 'origin/5.6' into dev
Conflicts:
src/corelib/io/io.pri
src/corelib/io/qdatastream.cpp
src/corelib/io/qdatastream.h
src/network/socket/qabstractsocket.cpp
src/plugins/platforminputcontexts/ibus/qibusplatforminputcontext.cpp
src/plugins/platforms/cocoa/qcocoaaccessibilityelement.h
src/widgets/styles/qgtkstyle.cpp
tests/auto/corelib/mimetypes/qmimedatabase/qmimedatabase-cache/qmimedatabase-cache.pro
tests/auto/corelib/mimetypes/qmimedatabase/qmimedatabase-xml/qmimedatabase-xml.pro
tests/auto/dbus/qdbusconnection/qdbusconnection.pro
tests/auto/dbus/qdbuspendingcall/tst_qdbuspendingcall.cpp
tests/auto/network/access/qnetworkreply/tst_qnetworkreply.cpp
Change-Id: I347549a024eb5bfa986699e0a11f96cc55c797a7
Diffstat (limited to 'config.tests')
-rw-r--r-- | config.tests/common/atomic64/atomic64.cpp | 54 | ||||
-rw-r--r-- | config.tests/common/atomic64/atomic64.pro | 3 | ||||
-rw-r--r-- | config.tests/common/c++14/c++14.cpp | 40 | ||||
-rw-r--r-- | config.tests/common/c++14/c++14.pro | 3 | ||||
-rw-r--r-- | config.tests/common/c++1z/c++1z.cpp | 40 | ||||
-rw-r--r-- | config.tests/common/c++1z/c++1z.pro | 3 | ||||
-rw-r--r-- | config.tests/common/c++default/c++default.cpp | 1 | ||||
-rw-r--r-- | config.tests/common/c++default/c++default.pro | 14 | ||||
-rwxr-xr-x | config.tests/unix/ptrsize.test | 5 |
9 files changed, 162 insertions, 1 deletions
diff --git a/config.tests/common/atomic64/atomic64.cpp b/config.tests/common/atomic64/atomic64.cpp new file mode 100644 index 0000000000..8dbea96c8b --- /dev/null +++ b/config.tests/common/atomic64/atomic64.cpp @@ -0,0 +1,54 @@ +/**************************************************************************** +** +** Copyright (C) 2015 Intel Corporation. +** Contact: http://www.qt.io/licensing/ +** +** This file is part of the FOO module of the Qt Toolkit. +** +** $QT_BEGIN_LICENSE:LGPL21$ +** Commercial License Usage +** Licensees holding valid commercial Qt licenses may use this file in +** accordance with the commercial license agreement provided with the +** Software or, alternatively, in accordance with the terms contained in +** a written agreement between you and The Qt Company. For licensing terms +** and conditions see http://www.qt.io/terms-conditions. For further +** information use the contact form at http://www.qt.io/contact-us. +** +** GNU Lesser General Public License Usage +** Alternatively, this file may be used under the terms of the GNU Lesser +** General Public License version 2.1 or version 3 as published by the Free +** Software Foundation and appearing in the file LICENSE.LGPLv21 and +** LICENSE.LGPLv3 included in the packaging of this file. Please review the +** following information to ensure the GNU Lesser General Public License +** requirements will be met: https://www.gnu.org/licenses/lgpl.html and +** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. +** +** As a special exception, The Qt Company gives you certain additional +** rights. These rights are described in The Qt Company LGPL Exception +** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. +** +** $QT_END_LICENSE$ +** +****************************************************************************/ + +#include <atomic> +#include <cstdint> + +void test(volatile std::atomic<std::int64_t> &a) +{ + std::int64_t v = a.load(std::memory_order_acquire); + while (!a.compare_exchange_strong(v, v + 1, + std::memory_order_acq_rel, + std::memory_order_acquire)) { + v = a.exchange(v - 1); + } + + a.store(v + 1, std::memory_order_release); +} + +int main(int, char **) +{ + void *ptr = (void*)0xffffffc0; // any random pointer + test(*reinterpret_cast<std::atomic<std::int64_t> *>(ptr)); + return 0; +} diff --git a/config.tests/common/atomic64/atomic64.pro b/config.tests/common/atomic64/atomic64.pro new file mode 100644 index 0000000000..c9a85817ca --- /dev/null +++ b/config.tests/common/atomic64/atomic64.pro @@ -0,0 +1,3 @@ +SOURCES = atomic64.cpp +CONFIG += c++11 console +CONFIG -= qt diff --git a/config.tests/common/c++14/c++14.cpp b/config.tests/common/c++14/c++14.cpp new file mode 100644 index 0000000000..e17e51831d --- /dev/null +++ b/config.tests/common/c++14/c++14.cpp @@ -0,0 +1,40 @@ +/**************************************************************************** +** +** Copyright (C) 2015 Intel Corporation. +** Contact: http://www.qt.io/licensing/ +** +** This file is part of the configuration module of the Qt Toolkit. +** +** $QT_BEGIN_LICENSE:LGPL21$ +** Commercial License Usage +** Licensees holding valid commercial Qt licenses may use this file in +** accordance with the commercial license agreement provided with the +** Software or, alternatively, in accordance with the terms contained in +** a written agreement between you and The Qt Company. For licensing terms +** and conditions see http://www.qt.io/terms-conditions. For further +** information use the contact form at http://www.qt.io/contact-us. +** +** GNU Lesser General Public License Usage +** Alternatively, this file may be used under the terms of the GNU Lesser +** General Public License version 2.1 or version 3 as published by the Free +** Software Foundation and appearing in the file LICENSE.LGPLv21 and +** LICENSE.LGPLv3 included in the packaging of this file. Please review the +** following information to ensure the GNU Lesser General Public License +** requirements will be met: https://www.gnu.org/licenses/lgpl.html and +** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. +** +** As a special exception, The Qt Company gives you certain additional +** rights. These rights are described in The Qt Company LGPL Exception +** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. +** +** $QT_END_LICENSE$ +** +****************************************************************************/ + +#if __cplusplus > 201103L +// Compiler claims to support C++14, trust it +#else +# error "__cplusplus must be > 201103L (the value of C++11)" +#endif + +int main(int, char **) { return 0; } diff --git a/config.tests/common/c++14/c++14.pro b/config.tests/common/c++14/c++14.pro new file mode 100644 index 0000000000..cbd78ba6fe --- /dev/null +++ b/config.tests/common/c++14/c++14.pro @@ -0,0 +1,3 @@ +SOURCES = c++14.cpp +CONFIG += c++11 c++14 console +CONFIG -= qt diff --git a/config.tests/common/c++1z/c++1z.cpp b/config.tests/common/c++1z/c++1z.cpp new file mode 100644 index 0000000000..2b61cfec49 --- /dev/null +++ b/config.tests/common/c++1z/c++1z.cpp @@ -0,0 +1,40 @@ +/**************************************************************************** +** +** Copyright (C) 2015 Intel Corporation. +** Contact: http://www.qt.io/licensing/ +** +** This file is part of the configuration module of the Qt Toolkit. +** +** $QT_BEGIN_LICENSE:LGPL21$ +** Commercial License Usage +** Licensees holding valid commercial Qt licenses may use this file in +** accordance with the commercial license agreement provided with the +** Software or, alternatively, in accordance with the terms contained in +** a written agreement between you and The Qt Company. For licensing terms +** and conditions see http://www.qt.io/terms-conditions. For further +** information use the contact form at http://www.qt.io/contact-us. +** +** GNU Lesser General Public License Usage +** Alternatively, this file may be used under the terms of the GNU Lesser +** General Public License version 2.1 or version 3 as published by the Free +** Software Foundation and appearing in the file LICENSE.LGPLv21 and +** LICENSE.LGPLv3 included in the packaging of this file. Please review the +** following information to ensure the GNU Lesser General Public License +** requirements will be met: https://www.gnu.org/licenses/lgpl.html and +** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. +** +** As a special exception, The Qt Company gives you certain additional +** rights. These rights are described in The Qt Company LGPL Exception +** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. +** +** $QT_END_LICENSE$ +** +****************************************************************************/ + +#if __cplusplus > 201402L +// Compiler claims to support experimental C++1z, trust it +#else +# error "__cplusplus must be > 201402L (the value for C++14)" +#endif + +int main(int, char **) { return 0; } diff --git a/config.tests/common/c++1z/c++1z.pro b/config.tests/common/c++1z/c++1z.pro new file mode 100644 index 0000000000..3a24946276 --- /dev/null +++ b/config.tests/common/c++1z/c++1z.pro @@ -0,0 +1,3 @@ +SOURCES = c++1z.cpp +CONFIG += c++11 c++14 c++1z console +CONFIG -= qt diff --git a/config.tests/common/c++default/c++default.cpp b/config.tests/common/c++default/c++default.cpp new file mode 100644 index 0000000000..018963beb3 --- /dev/null +++ b/config.tests/common/c++default/c++default.cpp @@ -0,0 +1 @@ +__cplusplus diff --git a/config.tests/common/c++default/c++default.pro b/config.tests/common/c++default/c++default.pro new file mode 100644 index 0000000000..7e6bcefe69 --- /dev/null +++ b/config.tests/common/c++default/c++default.pro @@ -0,0 +1,14 @@ +TEMPLATE = aux +CONFIG -= qt c++11 +PREPROCESSOR_SOURCES += c++default.cpp + +preprocessor.commands = $(CXX) $(CXXFLAGS) $(INCPATH) -o $@ -E $< +msvc:preprocessor.commands = $(CXX) $(CXXFLAGS) $(INCPATH) -E ${QMAKE_FILE_IN} > ${QMAKE_FILE_OUT} +preprocessor.output = ${QMAKE_FILE_BASE}.ii +preprocessor.input = PREPROCESSOR_SOURCES +preprocessor.variable_out = GENERATED_FILES +QMAKE_EXTRA_COMPILERS += preprocessor + +all.target = all +all.depends += c++default.ii +QMAKE_EXTRA_TARGETS += all diff --git a/config.tests/unix/ptrsize.test b/config.tests/unix/ptrsize.test index 4f42c6d11d..7d7bde57e5 100755 --- a/config.tests/unix/ptrsize.test +++ b/config.tests/unix/ptrsize.test @@ -5,12 +5,15 @@ VERBOSE=$2 SRCDIR=$3 OUTDIR=$4 +LFLAGS=$SYSROOT_FLAG +CXXFLAGS=$SYSROOT_FLAG + # debuggery [ "$VERBOSE" = "yes" ] && echo "Testing size of pointers ... ($*)" # build and run a test program test -d "$OUTDIR/config.tests/unix/ptrsize" || mkdir -p "$OUTDIR/config.tests/unix/ptrsize" -"$OUTDIR/bin/qmake" -nocache -spec "$QMKSPEC" "CONFIG-=app_bundle" "$SRCDIR/config.tests/unix/ptrsize/ptrsizetest.pro" -o "$OUTDIR/config.tests/unix/ptrsize/Makefile" >/dev/null 2>&1 +"$OUTDIR/bin/qmake" -nocache -spec "$QMKSPEC" "CONFIG-=app_bundle" "QMAKE_LFLAGS*=$LFLAGS" "QMAKE_CXXFLAGS*=$CXXFLAGS" "$SRCDIR/config.tests/unix/ptrsize/ptrsizetest.pro" -o "$OUTDIR/config.tests/unix/ptrsize/Makefile" >/dev/null 2>&1 cd "$OUTDIR/config.tests/unix/ptrsize" if [ "$VERBOSE" = "yes" ]; then |