diff options
author | Qt Forward Merge Bot <qt_forward_merge_bot@qt-project.org> | 2018-02-18 21:41:41 +0100 |
---|---|---|
committer | Qt Forward Merge Bot <qt_forward_merge_bot@qt-project.org> | 2018-02-18 21:41:41 +0100 |
commit | 30306d8c93d7922e732a5ea9884bcdea0fa68e7a (patch) | |
tree | 100d9274bdc9f7fd2f54b4f93be44b11d7327555 | |
parent | 74a20fda52ebfb26e81509e7001711adfeda2c57 (diff) | |
parent | 8a66924ca000fe4e05b680ca82c6587da8d28e0b (diff) |
Merge remote-tracking branch 'origin/5.11' into dev
Change-Id: I95d8a4ba3d8cedfdda63b99127abb7c57a4265e6
-rw-r--r-- | mkspecs/win32-clang-g++/qmake.conf | 90 | ||||
-rw-r--r-- | mkspecs/win32-clang-g++/qplatformdefs.h | 40 | ||||
-rw-r--r-- | src/network/configure.json | 4 | ||||
-rw-r--r-- | src/plugins/platforms/offscreen/qoffscreenintegration_x11.cpp | 8 | ||||
-rw-r--r-- | src/widgets/kernel/qdesktopwidget.h | 2 |
5 files changed, 142 insertions, 2 deletions
diff --git a/mkspecs/win32-clang-g++/qmake.conf b/mkspecs/win32-clang-g++/qmake.conf new file mode 100644 index 0000000000..1cae64ce99 --- /dev/null +++ b/mkspecs/win32-clang-g++/qmake.conf @@ -0,0 +1,90 @@ +# +# qmake configuration for win32-clang-g++ +# +# Written for MinGW-w64 / clang 6.0 or higher +# +# Cross compile example for x86_64-w64-mingw32-clang++: +# configure -xplatform win32-clang-g++ -device-option CROSS_COMPILE=x86_64-w64-mingw32- +# + +load(device_config) +include(../common/gcc-base.conf) +include(../common/g++-base.conf) +include(../common/angle.conf) +include(../common/windows-vulkan.conf) + +# modifications to gcc-base.conf and g++-base.conf + +MAKEFILE_GENERATOR = MINGW +QMAKE_PLATFORM = win32 mingw +CONFIG += debug_and_release debug_and_release_target precompile_header +DEFINES += UNICODE _UNICODE WIN32 +QMAKE_COMPILER = gcc clang llvm # clang pretends to be gcc +QMAKE_COMPILER_DEFINES += __GNUC__ _WIN32 +# can't add 'DEFINES += WIN64' and 'QMAKE_COMPILER_DEFINES += _WIN64' defines for +# x86_64 platform similar to 'msvc-desktop.conf' toolchain, because, unlike for MSVC, +# 'QMAKE_TARGET.arch' is inherently unavailable. + +QMAKE_CC = $${CROSS_COMPILE}clang +QMAKE_LEX = flex +QMAKE_LEXFLAGS = +QMAKE_YACC = bison -y +QMAKE_YACCFLAGS = -d +QMAKE_CFLAGS += +QMAKE_CFLAGS_WARN_ON += -Wextra -Wno-ignored-attributes + +QMAKE_CFLAGS_SSE2 += -mstackrealign + +QMAKE_CXX = $${CROSS_COMPILE}clang++ +QMAKE_CXXFLAGS = $$QMAKE_CFLAGS +QMAKE_CXXFLAGS_WARN_ON = $$QMAKE_CFLAGS_WARN_ON +QMAKE_CXXFLAGS_RTTI_ON = -frtti +QMAKE_CXXFLAGS_RTTI_OFF = -fno-rtti +QMAKE_CXXFLAGS_EXCEPTIONS_ON = -fexceptions -mthreads + +QMAKE_INCDIR = + +QMAKE_RUN_CC = $(CC) -c $(CFLAGS) $(INCPATH) -o $obj $src +QMAKE_RUN_CC_IMP = $(CC) -c $(CFLAGS) $(INCPATH) -o $@ $< +QMAKE_RUN_CXX = $(CXX) -c $(CXXFLAGS) $(INCPATH) -o $obj $src +QMAKE_RUN_CXX_IMP = $(CXX) -c $(CXXFLAGS) $(INCPATH) -o $@ $< + +QMAKE_LINK = $${CROSS_COMPILE}clang++ +QMAKE_LINK_C = $${CROSS_COMPILE}clang +QMAKE_LFLAGS_EXCEPTIONS_ON = -mthreads +QMAKE_LFLAGS_RELEASE = -Wl,-s +QMAKE_LFLAGS_CONSOLE = -Wl,-subsystem,console +QMAKE_LFLAGS_WINDOWS = -Wl,-subsystem,windows +QMAKE_LFLAGS_DLL = -shared +QMAKE_LFLAGS_GCSECTIONS = -Wl,--gc-sections +equals(QMAKE_HOST.os, Windows) { + QMAKE_LINK_OBJECT_MAX = 10 + QMAKE_LINK_OBJECT_SCRIPT = object_script +} +QMAKE_EXT_OBJ = .o +QMAKE_EXT_RES = _res.o +QMAKE_PREFIX_SHLIB = +QMAKE_EXTENSION_SHLIB = dll +QMAKE_PREFIX_STATICLIB = lib +QMAKE_EXTENSION_STATICLIB = a +QMAKE_LIB_EXTENSIONS = a dll.a + +QMAKE_LIBS = +QMAKE_LIBS_GUI = -lgdi32 -lcomdlg32 -loleaut32 -limm32 -lwinmm -lws2_32 -lole32 -luuid -luser32 -ladvapi32 +QMAKE_LIBS_NETWORK = -lws2_32 +QMAKE_LIBS_OPENGL = -lglu32 -lopengl32 -lgdi32 -luser32 +QMAKE_LIBS_OPENGL_ES2 = -lgdi32 -luser32 +QMAKE_LIBS_OPENGL_ES2_DEBUG = -lgdi32 -luser32 +QMAKE_LIBS_COMPAT = -ladvapi32 -lshell32 -lcomdlg32 -luser32 -lgdi32 -lws2_32 +QMAKE_LIBS_QT_ENTRY = -lmingw32 -lqtmain + +QMAKE_IDL = midl +QMAKE_LIB = $${CROSS_COMPILE}ar -rc +QMAKE_RC = $${CROSS_COMPILE}windres + +QMAKE_STRIP = $${CROSS_COMPILE}strip +QMAKE_STRIPFLAGS_LIB += --strip-unneeded +QMAKE_OBJCOPY = $${CROSS_COMPILE}objcopy +QMAKE_NM = $${CROSS_COMPILE}nm -P + +load(qt_config) diff --git a/mkspecs/win32-clang-g++/qplatformdefs.h b/mkspecs/win32-clang-g++/qplatformdefs.h new file mode 100644 index 0000000000..906e724c19 --- /dev/null +++ b/mkspecs/win32-clang-g++/qplatformdefs.h @@ -0,0 +1,40 @@ +/**************************************************************************** +** +** Copyright (C) 2018 The Qt Company Ltd. +** Contact: https://www.qt.io/licensing/ +** +** This file is part of the qmake spec of the Qt Toolkit. +** +** $QT_BEGIN_LICENSE:LGPL$ +** 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 https://www.qt.io/terms-conditions. For further +** information use the contact form at https://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 3 as published by the Free Software +** Foundation and appearing in the file LICENSE.LGPL3 included in the +** packaging of this file. Please review the following information to +** ensure the GNU Lesser General Public License version 3 requirements +** will be met: https://www.gnu.org/licenses/lgpl-3.0.html. +** +** GNU General Public License Usage +** Alternatively, this file may be used under the terms of the GNU +** General Public License version 2.0 or (at your option) the GNU General +** Public license version 3 or any later version approved by the KDE Free +** Qt Foundation. The licenses are as published by the Free Software +** Foundation and appearing in the file LICENSE.GPL2 and LICENSE.GPL3 +** included in the packaging of this file. Please review the following +** information to ensure the GNU General Public License requirements will +** be met: https://www.gnu.org/licenses/gpl-2.0.html and +** https://www.gnu.org/licenses/gpl-3.0.html. +** +** $QT_END_LICENSE$ +** +****************************************************************************/ + +#include "../win32-g++/qplatformdefs.h" diff --git a/src/network/configure.json b/src/network/configure.json index 89bb1efffa..4cbc476837 100644 --- a/src/network/configure.json +++ b/src/network/configure.json @@ -75,6 +75,10 @@ "libs": "-lssleay32 -llibeay32", "condition": "config.win32 && features.shared" }, + { + "libs": "-llibssl -llibcrypto", + "condition": "config.win32" + }, { "libs": "-lssl -lcrypto", "condition": "!config.win32" } ] } diff --git a/src/plugins/platforms/offscreen/qoffscreenintegration_x11.cpp b/src/plugins/platforms/offscreen/qoffscreenintegration_x11.cpp index b46d94dfd3..93566220e8 100644 --- a/src/plugins/platforms/offscreen/qoffscreenintegration_x11.cpp +++ b/src/plugins/platforms/offscreen/qoffscreenintegration_x11.cpp @@ -71,6 +71,9 @@ QPlatformOpenGLContext *QOffscreenX11Integration::createPlatformOpenGLContext(QO if (!m_connection) m_connection.reset(new QOffscreenX11Connection); + if (!m_connection->display()) + return nullptr; + return new QOffscreenX11GLXContext(m_connection->x11Info(), context); } @@ -81,12 +84,13 @@ QOffscreenX11Connection::QOffscreenX11Connection() QByteArray displayName = qgetenv("DISPLAY"); Display *display = XOpenDisplay(displayName.constData()); m_display = display; - m_screenNumber = DefaultScreen(display); + m_screenNumber = m_display ? DefaultScreen(m_display) : -1; } QOffscreenX11Connection::~QOffscreenX11Connection() { - XCloseDisplay((Display *)m_display); + if (m_display) + XCloseDisplay((Display *)m_display); } class QOffscreenX11Info diff --git a/src/widgets/kernel/qdesktopwidget.h b/src/widgets/kernel/qdesktopwidget.h index f53d0fe9bb..f986f0db20 100644 --- a/src/widgets/kernel/qdesktopwidget.h +++ b/src/widgets/kernel/qdesktopwidget.h @@ -112,6 +112,7 @@ private: friend class QApplicationPrivate; }; +#if QT_DEPRECATED_SINCE(5, 11) inline int QDesktopWidget::screenCount() const { QT_WARNING_PUSH @@ -119,6 +120,7 @@ QT_WARNING_DISABLE_DEPRECATED return numScreens(); QT_WARNING_POP } +#endif QT_END_NAMESPACE |