mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-11 20:32:35 -03:00
Merge #21376: depends: Qt 5.12.10
550ed1bed2
build: update qt qpaint non determinism patch for 5.12.10 (fanquake)6093ae4d30
build: update qt no-xlib patch for 5.12.10 (fanquake)84928c4e73
build: update qt android jni static patch for 5.12.10 (fanquake)cc6f47d51a
build: update qt lrelease patch for 5.12.10 (fanquake)286d07ff17
build, qt: Fix lib paths in *.pc files (Hennadii Stepanov)fa5e97e8c2
build: disable qt SDK version checking (fanquake)1be8e0f238
build: Add QMacStyle support (Hennadii Stepanov)e674e94302
build: revert to using Qts internal zlib (fanquake)06cd0da21f
build: qt 5.12.10 (fanquake)3272e34f9c
build: Add xkbcommon 0.8.4 (Hennadii Stepanov)d769b3372d
build: only pass -optimized-tools to qt in debug mode (fanquake) Pull request description: Switch to Qt 5.12.10 in depends. Based on #21363. This is a much smaller changeset, and should be easier to review than #19716. Also postpones needing to bring a bunch of new libs into depends. Big thanks to Hebasto that has been helping with this. ACKs for top commit: laanwj: Code review ACK550ed1bed2
hebasto: ACK550ed1bed2
jarolrod: ACK550ed1bed2
, tested on macOS 11.2 built from depends Tree-SHA512: cb6b70f5a5372ba0b64f7ddfa696eda0411922cd261c67bfa2d9332c685a7b358ab18e5cfaa677b414ae8ad78296bba6ed0eecd071fdacdf736a0d030f679fe5
This commit is contained in:
commit
e828fc8f52
29 changed files with 326 additions and 289 deletions
|
@ -123,7 +123,7 @@ AC_DEFUN([BITCOIN_QT_CONFIGURE],[
|
||||||
_BITCOIN_QT_CHECK_STATIC_LIBS
|
_BITCOIN_QT_CHECK_STATIC_LIBS
|
||||||
|
|
||||||
if test "x$qt_plugin_path" != x; then
|
if test "x$qt_plugin_path" != x; then
|
||||||
QT_LIBS="$QT_LIBS -L$qt_plugin_path/platforms"
|
QT_LIBS="$QT_LIBS -L$qt_plugin_path/platforms -L$qt_plugin_path/styles"
|
||||||
if test -d "$qt_plugin_path/accessible"; then
|
if test -d "$qt_plugin_path/accessible"; then
|
||||||
QT_LIBS="$QT_LIBS -L$qt_plugin_path/accessible"
|
QT_LIBS="$QT_LIBS -L$qt_plugin_path/accessible"
|
||||||
fi
|
fi
|
||||||
|
@ -138,13 +138,23 @@ AC_DEFUN([BITCOIN_QT_CONFIGURE],[
|
||||||
AC_DEFINE(QT_QPA_PLATFORM_MINIMAL, 1, [Define this symbol if the minimal qt platform exists])
|
AC_DEFINE(QT_QPA_PLATFORM_MINIMAL, 1, [Define this symbol if the minimal qt platform exists])
|
||||||
fi
|
fi
|
||||||
if test "x$TARGET_OS" = xwindows; then
|
if test "x$TARGET_OS" = xwindows; then
|
||||||
|
dnl Linking against wtsapi32 is required. See #17749 and
|
||||||
|
dnl https://bugreports.qt.io/browse/QTBUG-27097.
|
||||||
|
AX_CHECK_LINK_FLAG([-lwtsapi32], [QT_LIBS="$QT_LIBS -lwtsapi32"], [AC_MSG_ERROR([could not link against -lwtsapi32])])
|
||||||
_BITCOIN_QT_CHECK_STATIC_PLUGIN([QWindowsIntegrationPlugin], [-lqwindows])
|
_BITCOIN_QT_CHECK_STATIC_PLUGIN([QWindowsIntegrationPlugin], [-lqwindows])
|
||||||
AC_DEFINE(QT_QPA_PLATFORM_WINDOWS, 1, [Define this symbol if the qt platform is windows])
|
AC_DEFINE(QT_QPA_PLATFORM_WINDOWS, 1, [Define this symbol if the qt platform is windows])
|
||||||
elif test "x$TARGET_OS" = xlinux; then
|
elif test "x$TARGET_OS" = xlinux; then
|
||||||
|
dnl workaround for https://bugreports.qt.io/browse/QTBUG-74874
|
||||||
|
AX_CHECK_LINK_FLAG([-lxcb-shm], [QT_LIBS="-lxcb-shm $QT_LIBS"], [AC_MSG_ERROR([could not link against -lxcb-shm])])
|
||||||
_BITCOIN_QT_CHECK_STATIC_PLUGIN([QXcbIntegrationPlugin], [-lqxcb -lxcb-static])
|
_BITCOIN_QT_CHECK_STATIC_PLUGIN([QXcbIntegrationPlugin], [-lqxcb -lxcb-static])
|
||||||
AC_DEFINE(QT_QPA_PLATFORM_XCB, 1, [Define this symbol if the qt platform is xcb])
|
AC_DEFINE(QT_QPA_PLATFORM_XCB, 1, [Define this symbol if the qt platform is xcb])
|
||||||
elif test "x$TARGET_OS" = xdarwin; then
|
elif test "x$TARGET_OS" = xdarwin; then
|
||||||
|
AX_CHECK_LINK_FLAG([[-framework Carbon]],[QT_LIBS="$QT_LIBS -framework Carbon"],[AC_MSG_ERROR(could not link against Carbon framework)])
|
||||||
|
AX_CHECK_LINK_FLAG([[-framework IOSurface]],[QT_LIBS="$QT_LIBS -framework IOSurface"],[AC_MSG_ERROR(could not link against IOSurface framework)])
|
||||||
|
AX_CHECK_LINK_FLAG([[-framework Metal]],[QT_LIBS="$QT_LIBS -framework Metal"],[AC_MSG_ERROR(could not link against Metal framework)])
|
||||||
|
AX_CHECK_LINK_FLAG([[-framework QuartzCore]],[QT_LIBS="$QT_LIBS -framework QuartzCore"],[AC_MSG_ERROR(could not link against QuartzCore framework)])
|
||||||
_BITCOIN_QT_CHECK_STATIC_PLUGIN([QCocoaIntegrationPlugin], [-lqcocoa])
|
_BITCOIN_QT_CHECK_STATIC_PLUGIN([QCocoaIntegrationPlugin], [-lqcocoa])
|
||||||
|
_BITCOIN_QT_CHECK_STATIC_PLUGIN([QMacStylePlugin], [-lqmacstyle])
|
||||||
AC_DEFINE(QT_QPA_PLATFORM_COCOA, 1, [Define this symbol if the qt platform is cocoa])
|
AC_DEFINE(QT_QPA_PLATFORM_COCOA, 1, [Define this symbol if the qt platform is cocoa])
|
||||||
elif test "x$TARGET_OS" = xandroid; then
|
elif test "x$TARGET_OS" = xandroid; then
|
||||||
QT_LIBS="-Wl,--export-dynamic,--undefined=JNI_OnLoad -lqtforandroid -ljnigraphics -landroid -lqtfreetype -lQt5EglSupport $QT_LIBS"
|
QT_LIBS="-Wl,--export-dynamic,--undefined=JNI_OnLoad -lqtforandroid -ljnigraphics -landroid -lqtfreetype -lQt5EglSupport $QT_LIBS"
|
||||||
|
@ -334,7 +344,8 @@ AC_DEFUN([_BITCOIN_QT_CHECK_STATIC_LIBS], [
|
||||||
elif test "x$TARGET_OS" = xdarwin; then
|
elif test "x$TARGET_OS" = xdarwin; then
|
||||||
PKG_CHECK_MODULES([QTCLIPBOARD], [Qt5ClipboardSupport${qt_lib_suffix}], [QT_LIBS="-lQt5ClipboardSupport${qt_lib_suffix} $QT_LIBS"])
|
PKG_CHECK_MODULES([QTCLIPBOARD], [Qt5ClipboardSupport${qt_lib_suffix}], [QT_LIBS="-lQt5ClipboardSupport${qt_lib_suffix} $QT_LIBS"])
|
||||||
PKG_CHECK_MODULES([QTGRAPHICS], [Qt5GraphicsSupport${qt_lib_suffix}], [QT_LIBS="-lQt5GraphicsSupport${qt_lib_suffix} $QT_LIBS"])
|
PKG_CHECK_MODULES([QTGRAPHICS], [Qt5GraphicsSupport${qt_lib_suffix}], [QT_LIBS="-lQt5GraphicsSupport${qt_lib_suffix} $QT_LIBS"])
|
||||||
PKG_CHECK_MODULES([QTCGL], [Qt5CglSupport${qt_lib_suffix}], [QT_LIBS="-lQt5CglSupport${qt_lib_suffix} $QT_LIBS"])
|
elif test "x$TARGET_OS" = xwindows; then
|
||||||
|
PKG_CHECK_MODULES([QTWINDOWSUIAUTOMATION], [Qt5WindowsUIAutomationSupport${qt_lib_suffix}], [QT_LIBS="-lQt5WindowsUIAutomationSupport${qt_lib_suffix} $QT_LIBS"])
|
||||||
fi
|
fi
|
||||||
])
|
])
|
||||||
|
|
||||||
|
|
|
@ -65,7 +65,7 @@ export BASE_OUTDIR=${BASE_OUTDIR:-$BASE_SCRATCH_DIR/out/$HOST}
|
||||||
export BASE_BUILD_DIR=${BASE_BUILD_DIR:-$BASE_SCRATCH_DIR/build}
|
export BASE_BUILD_DIR=${BASE_BUILD_DIR:-$BASE_SCRATCH_DIR/build}
|
||||||
export PREVIOUS_RELEASES_DIR=${PREVIOUS_RELEASES_DIR:-$BASE_ROOT_DIR/releases/$HOST}
|
export PREVIOUS_RELEASES_DIR=${PREVIOUS_RELEASES_DIR:-$BASE_ROOT_DIR/releases/$HOST}
|
||||||
export SDK_URL=${SDK_URL:-https://bitcoincore.org/depends-sources/sdks}
|
export SDK_URL=${SDK_URL:-https://bitcoincore.org/depends-sources/sdks}
|
||||||
export DOCKER_PACKAGES=${DOCKER_PACKAGES:-build-essential libtool autotools-dev automake pkg-config bsdmainutils curl ca-certificates ccache python3 rsync git procps}
|
export DOCKER_PACKAGES=${DOCKER_PACKAGES:-build-essential libtool autotools-dev automake pkg-config bsdmainutils curl ca-certificates ccache python3 rsync git procps bison}
|
||||||
export GOAL=${GOAL:-install}
|
export GOAL=${GOAL:-install}
|
||||||
export DIR_QA_ASSETS=${DIR_QA_ASSETS:-${BASE_SCRATCH_DIR}/qa-assets}
|
export DIR_QA_ASSETS=${DIR_QA_ASSETS:-${BASE_SCRATCH_DIR}/qa-assets}
|
||||||
export PATH=${BASE_ROOT_DIR}/ci/retry:$PATH
|
export PATH=${BASE_ROOT_DIR}/ci/retry:$PATH
|
||||||
|
|
|
@ -9,7 +9,7 @@ export LC_ALL=C.UTF-8
|
||||||
export HOST=i686-pc-linux-gnu
|
export HOST=i686-pc-linux-gnu
|
||||||
export CONTAINER_NAME=ci_i686_centos_8
|
export CONTAINER_NAME=ci_i686_centos_8
|
||||||
export DOCKER_NAME_TAG=centos:8
|
export DOCKER_NAME_TAG=centos:8
|
||||||
export DOCKER_PACKAGES="gcc-c++ glibc-devel.x86_64 libstdc++-devel.x86_64 glibc-devel.i686 libstdc++-devel.i686 ccache libtool make git python3 python3-zmq which patch lbzip2 dash rsync coreutils"
|
export DOCKER_PACKAGES="gcc-c++ glibc-devel.x86_64 libstdc++-devel.x86_64 glibc-devel.i686 libstdc++-devel.i686 ccache libtool make git python3 python3-zmq which patch lbzip2 dash rsync coreutils bison"
|
||||||
export GOAL="install"
|
export GOAL="install"
|
||||||
export BITCOIN_CONFIG="--enable-zmq --with-gui=qt5 --enable-reduce-exports --with-boost-process"
|
export BITCOIN_CONFIG="--enable-zmq --with-gui=qt5 --enable-reduce-exports --with-boost-process"
|
||||||
export CONFIG_SHELL="/bin/dash"
|
export CONFIG_SHELL="/bin/dash"
|
||||||
|
|
|
@ -73,6 +73,8 @@ ELF_ALLOWED_LIBRARIES = {
|
||||||
'ld-linux-riscv64-lp64d.so.1', # 64-bit RISC-V dynamic linker
|
'ld-linux-riscv64-lp64d.so.1', # 64-bit RISC-V dynamic linker
|
||||||
# bitcoin-qt only
|
# bitcoin-qt only
|
||||||
'libxcb.so.1', # part of X11
|
'libxcb.so.1', # part of X11
|
||||||
|
'libxkbcommon.so.0', # keyboard keymapping
|
||||||
|
'libxkbcommon-x11.so.0', # keyboard keymapping
|
||||||
'libfontconfig.so.1', # font support
|
'libfontconfig.so.1', # font support
|
||||||
'libfreetype.so.6', # font parsing
|
'libfreetype.so.6', # font parsing
|
||||||
'libdl.so.2' # programming interface to dynamic linker
|
'libdl.so.2' # programming interface to dynamic linker
|
||||||
|
@ -98,10 +100,15 @@ MACHO_ALLOWED_LIBRARIES = {
|
||||||
'CoreGraphics', # 2D rendering
|
'CoreGraphics', # 2D rendering
|
||||||
'CoreServices', # operating system services
|
'CoreServices', # operating system services
|
||||||
'CoreText', # interface for laying out text and handling fonts.
|
'CoreText', # interface for laying out text and handling fonts.
|
||||||
|
'CoreVideo', # video processing
|
||||||
'Foundation', # base layer functionality for apps/frameworks
|
'Foundation', # base layer functionality for apps/frameworks
|
||||||
'ImageIO', # read and write image file formats.
|
'ImageIO', # read and write image file formats.
|
||||||
'IOKit', # user-space access to hardware devices and drivers.
|
'IOKit', # user-space access to hardware devices and drivers.
|
||||||
|
'IOSurface', # cross process image/drawing buffers
|
||||||
'libobjc.A.dylib', # Objective-C runtime library
|
'libobjc.A.dylib', # Objective-C runtime library
|
||||||
|
'Metal', # 3D graphics
|
||||||
|
'Security', # access control and authentication
|
||||||
|
'QuartzCore', # animation
|
||||||
}
|
}
|
||||||
|
|
||||||
PE_ALLOWED_LIBRARIES = {
|
PE_ALLOWED_LIBRARIES = {
|
||||||
|
@ -116,12 +123,15 @@ PE_ALLOWED_LIBRARIES = {
|
||||||
'dwmapi.dll', # desktop window manager
|
'dwmapi.dll', # desktop window manager
|
||||||
'GDI32.dll', # graphics device interface
|
'GDI32.dll', # graphics device interface
|
||||||
'IMM32.dll', # input method editor
|
'IMM32.dll', # input method editor
|
||||||
|
'NETAPI32.dll',
|
||||||
'ole32.dll', # component object model
|
'ole32.dll', # component object model
|
||||||
'OLEAUT32.dll', # OLE Automation API
|
'OLEAUT32.dll', # OLE Automation API
|
||||||
'SHLWAPI.dll', # light weight shell API
|
'SHLWAPI.dll', # light weight shell API
|
||||||
|
'USERENV.dll',
|
||||||
'UxTheme.dll',
|
'UxTheme.dll',
|
||||||
'VERSION.dll', # version checking
|
'VERSION.dll', # version checking
|
||||||
'WINMM.dll', # WinMM audio API
|
'WINMM.dll', # WinMM audio API
|
||||||
|
'WTSAPI32.dll',
|
||||||
}
|
}
|
||||||
|
|
||||||
class CPPFilt(object):
|
class CPPFilt(object):
|
||||||
|
|
|
@ -11,6 +11,7 @@ packages:
|
||||||
- "autoconf"
|
- "autoconf"
|
||||||
- "automake"
|
- "automake"
|
||||||
- "binutils"
|
- "binutils"
|
||||||
|
- "bison"
|
||||||
- "bsdmainutils"
|
- "bsdmainutils"
|
||||||
- "ca-certificates"
|
- "ca-certificates"
|
||||||
- "curl"
|
- "curl"
|
||||||
|
|
|
@ -3,6 +3,7 @@
|
||||||
(gnu packages autotools)
|
(gnu packages autotools)
|
||||||
(gnu packages base)
|
(gnu packages base)
|
||||||
(gnu packages bash)
|
(gnu packages bash)
|
||||||
|
(gnu packages bison)
|
||||||
(gnu packages cdrom)
|
(gnu packages cdrom)
|
||||||
(gnu packages check)
|
(gnu packages check)
|
||||||
(gnu packages cmake)
|
(gnu packages cmake)
|
||||||
|
@ -219,6 +220,7 @@ chain for " target " development."))
|
||||||
autoconf
|
autoconf
|
||||||
automake
|
automake
|
||||||
pkg-config
|
pkg-config
|
||||||
|
bison
|
||||||
;; Scripting
|
;; Scripting
|
||||||
perl
|
perl
|
||||||
python-3
|
python-3
|
||||||
|
|
|
@ -54,7 +54,7 @@ The paths are automatically configured and no other options are needed unless ta
|
||||||
|
|
||||||
Common linux dependencies:
|
Common linux dependencies:
|
||||||
|
|
||||||
sudo apt-get install make automake cmake curl g++-multilib libtool binutils-gold bsdmainutils pkg-config python3 patch
|
sudo apt-get install make automake cmake curl g++-multilib libtool binutils-gold bsdmainutils pkg-config python3 patch bison
|
||||||
|
|
||||||
For linux ARM cross compilation:
|
For linux ARM cross compilation:
|
||||||
|
|
||||||
|
|
|
@ -15,9 +15,9 @@ $(package)_config_opts += --disable-composite --disable-damage --disable-dpms
|
||||||
$(package)_config_opts += --disable-dri2 --disable-dri3 --disable-glx
|
$(package)_config_opts += --disable-dri2 --disable-dri3 --disable-glx
|
||||||
$(package)_config_opts += --disable-present --disable-randr --disable-record
|
$(package)_config_opts += --disable-present --disable-randr --disable-record
|
||||||
$(package)_config_opts += --disable-render --disable-resource --disable-screensaver
|
$(package)_config_opts += --disable-render --disable-resource --disable-screensaver
|
||||||
$(package)_config_opts += --disable-shape --disable-shm --disable-sync
|
$(package)_config_opts += --disable-shape --disable-sync
|
||||||
$(package)_config_opts += --disable-xevie --disable-xfixes --disable-xfree86-dri
|
$(package)_config_opts += --disable-xevie --disable-xfixes --disable-xfree86-dri
|
||||||
$(package)_config_opts += --disable-xinerama --disable-xinput --disable-xkb
|
$(package)_config_opts += --disable-xinerama --disable-xinput
|
||||||
$(package)_config_opts += --disable-xprint --disable-selinux --disable-xtest
|
$(package)_config_opts += --disable-xprint --disable-selinux --disable-xtest
|
||||||
$(package)_config_opts += --disable-xv --disable-xvmc
|
$(package)_config_opts += --disable-xv --disable-xvmc
|
||||||
endef
|
endef
|
||||||
|
|
32
depends/packages/libxkbcommon.mk
Normal file
32
depends/packages/libxkbcommon.mk
Normal file
|
@ -0,0 +1,32 @@
|
||||||
|
package=libxkbcommon
|
||||||
|
$(package)_version=0.8.4
|
||||||
|
$(package)_download_path=https://xkbcommon.org/download/
|
||||||
|
$(package)_file_name=$(package)-$($(package)_version).tar.xz
|
||||||
|
$(package)_sha256_hash=60ddcff932b7fd352752d51a5c4f04f3d0403230a584df9a2e0d5ed87c486c8b
|
||||||
|
$(package)_dependencies=libxcb
|
||||||
|
|
||||||
|
define $(package)_set_vars
|
||||||
|
$(package)_config_opts = --enable-option-checking --disable-dependency-tracking
|
||||||
|
$(package)_config_opts += --disable-static --disable-docs
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_preprocess_cmds
|
||||||
|
cp -f $(BASEDIR)/config.guess $(BASEDIR)/config.sub build-aux
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_config_cmds
|
||||||
|
$($(package)_autoconf)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_build_cmds
|
||||||
|
$(MAKE)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_stage_cmds
|
||||||
|
$(MAKE) DESTDIR=$($(package)_staging_dir) install
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_postprocess_cmds
|
||||||
|
rm -rf share/man share/doc lib/*.la
|
||||||
|
endef
|
||||||
|
|
|
@ -1,10 +1,8 @@
|
||||||
packages:=boost libevent
|
packages:=boost libevent
|
||||||
|
|
||||||
qt_packages = zlib
|
|
||||||
|
|
||||||
qrencode_packages = qrencode
|
qrencode_packages = qrencode
|
||||||
|
|
||||||
qt_linux_packages:=qt expat libxcb xcb_proto libXau xproto freetype fontconfig
|
qt_linux_packages:=qt expat libxcb xcb_proto libXau xproto freetype fontconfig libxkbcommon
|
||||||
qt_android_packages=qt
|
qt_android_packages=qt
|
||||||
|
|
||||||
qt_darwin_packages=qt
|
qt_darwin_packages=qt
|
||||||
|
|
|
@ -1,23 +1,21 @@
|
||||||
PACKAGE=qt
|
PACKAGE=qt
|
||||||
$(package)_version=5.9.8
|
$(package)_version=5.12.10
|
||||||
$(package)_download_path=https://download.qt.io/official_releases/qt/5.9/$($(package)_version)/submodules
|
$(package)_download_path=https://download.qt.io/official_releases/qt/5.12/$($(package)_version)/submodules
|
||||||
$(package)_suffix=opensource-src-$($(package)_version).tar.xz
|
$(package)_suffix=everywhere-src-$($(package)_version).tar.xz
|
||||||
$(package)_file_name=qtbase-$($(package)_suffix)
|
$(package)_file_name=qtbase-$($(package)_suffix)
|
||||||
$(package)_sha256_hash=9b9dec1f67df1f94bce2955c5604de992d529dde72050239154c56352da0907d
|
$(package)_sha256_hash=8088f174e6d28e779516c083b6087b6a9e3c8322b4bc161fd1b54195e3c86940
|
||||||
$(package)_dependencies=zlib
|
$(package)_linux_dependencies=freetype fontconfig libxcb libxkbcommon
|
||||||
$(package)_linux_dependencies=freetype fontconfig libxcb
|
|
||||||
$(package)_qt_libs=corelib network widgets gui plugins testlib
|
$(package)_qt_libs=corelib network widgets gui plugins testlib
|
||||||
$(package)_patches=fix_qt_pkgconfig.patch mac-qmake.conf fix_configure_mac.patch fix_no_printer.patch
|
$(package)_patches=fix_qt_pkgconfig.patch mac-qmake.conf fix_no_printer.patch no-xlib.patch
|
||||||
$(package)_patches+= fix_rcc_determinism.patch fix_riscv64_arch.patch xkb-default.patch no-xlib.patch
|
|
||||||
$(package)_patches+= fix_android_qmake_conf.patch fix_android_jni_static.patch dont_hardcode_pwd.patch
|
$(package)_patches+= fix_android_qmake_conf.patch fix_android_jni_static.patch dont_hardcode_pwd.patch
|
||||||
$(package)_patches+= freetype_back_compat.patch drop_lrelease_dependency.patch fix_powerpc_libpng.patch
|
$(package)_patches+= drop_lrelease_dependency.patch no_sdk_version_check.patch
|
||||||
$(package)_patches+= fix_mingw_cross_compile.patch fix_qpainter_non_determinism.patch
|
$(package)_patches+= fix_qpainter_non_determinism.patch fix_lib_paths.patch
|
||||||
|
|
||||||
$(package)_qttranslations_file_name=qttranslations-$($(package)_suffix)
|
$(package)_qttranslations_file_name=qttranslations-$($(package)_suffix)
|
||||||
$(package)_qttranslations_sha256_hash=fb5a47799754af73d3bf501fe513342cfe2fc37f64e80df5533f6110e804220c
|
$(package)_qttranslations_sha256_hash=e1de58ed108b7e0a138815ea60fd46a2c4e1fc31396a707e5630e92de79c53de
|
||||||
|
|
||||||
$(package)_qttools_file_name=qttools-$($(package)_suffix)
|
$(package)_qttools_file_name=qttools-$($(package)_suffix)
|
||||||
$(package)_qttools_sha256_hash=a97556eb7b2f30252cdd8a598c396cfce2b2f79d2bae883af6d3b26a2cdcc63c
|
$(package)_qttools_sha256_hash=b0cfa6e7aac41b7c61fc59acc04843d7a98f9e1840370611751bcfc1834a636c
|
||||||
|
|
||||||
$(package)_extra_sources = $($(package)_qttranslations_file_name)
|
$(package)_extra_sources = $($(package)_qttranslations_file_name)
|
||||||
$(package)_extra_sources += $($(package)_qttools_file_name)
|
$(package)_extra_sources += $($(package)_qttools_file_name)
|
||||||
|
@ -26,6 +24,7 @@ define $(package)_set_vars
|
||||||
$(package)_config_opts_release = -release
|
$(package)_config_opts_release = -release
|
||||||
$(package)_config_opts_release += -silent
|
$(package)_config_opts_release += -silent
|
||||||
$(package)_config_opts_debug = -debug
|
$(package)_config_opts_debug = -debug
|
||||||
|
$(package)_config_opts_debug += -optimized-tools
|
||||||
$(package)_config_opts += -bindir $(build_prefix)/bin
|
$(package)_config_opts += -bindir $(build_prefix)/bin
|
||||||
$(package)_config_opts += -c++std c++1z
|
$(package)_config_opts += -c++std c++1z
|
||||||
$(package)_config_opts += -confirm-license
|
$(package)_config_opts += -confirm-license
|
||||||
|
@ -49,7 +48,6 @@ $(package)_config_opts += -no-mtdev
|
||||||
$(package)_config_opts += -no-openssl
|
$(package)_config_opts += -no-openssl
|
||||||
$(package)_config_opts += -no-openvg
|
$(package)_config_opts += -no-openvg
|
||||||
$(package)_config_opts += -no-reduce-relocations
|
$(package)_config_opts += -no-reduce-relocations
|
||||||
$(package)_config_opts += -no-qml-debug
|
|
||||||
$(package)_config_opts += -no-sctp
|
$(package)_config_opts += -no-sctp
|
||||||
$(package)_config_opts += -no-securetransport
|
$(package)_config_opts += -no-securetransport
|
||||||
$(package)_config_opts += -no-sql-db2
|
$(package)_config_opts += -no-sql-db2
|
||||||
|
@ -63,17 +61,15 @@ $(package)_config_opts += -no-sql-sqlite
|
||||||
$(package)_config_opts += -no-sql-sqlite2
|
$(package)_config_opts += -no-sql-sqlite2
|
||||||
$(package)_config_opts += -no-system-proxies
|
$(package)_config_opts += -no-system-proxies
|
||||||
$(package)_config_opts += -no-use-gold-linker
|
$(package)_config_opts += -no-use-gold-linker
|
||||||
$(package)_config_opts += -no-xinput2
|
|
||||||
$(package)_config_opts += -nomake examples
|
$(package)_config_opts += -nomake examples
|
||||||
$(package)_config_opts += -nomake tests
|
$(package)_config_opts += -nomake tests
|
||||||
$(package)_config_opts += -opensource
|
$(package)_config_opts += -opensource
|
||||||
$(package)_config_opts += -optimized-tools
|
|
||||||
$(package)_config_opts += -pkg-config
|
$(package)_config_opts += -pkg-config
|
||||||
$(package)_config_opts += -prefix $(host_prefix)
|
$(package)_config_opts += -prefix $(host_prefix)
|
||||||
$(package)_config_opts += -qt-libpng
|
$(package)_config_opts += -qt-libpng
|
||||||
$(package)_config_opts += -qt-pcre
|
$(package)_config_opts += -qt-pcre
|
||||||
$(package)_config_opts += -qt-harfbuzz
|
$(package)_config_opts += -qt-harfbuzz
|
||||||
$(package)_config_opts += -system-zlib
|
$(package)_config_opts += -qt-zlib
|
||||||
$(package)_config_opts += -static
|
$(package)_config_opts += -static
|
||||||
$(package)_config_opts += -v
|
$(package)_config_opts += -v
|
||||||
$(package)_config_opts += -no-feature-bearermanagement
|
$(package)_config_opts += -no-feature-bearermanagement
|
||||||
|
@ -94,10 +90,10 @@ $(package)_config_opts += -no-feature-printdialog
|
||||||
$(package)_config_opts += -no-feature-printer
|
$(package)_config_opts += -no-feature-printer
|
||||||
$(package)_config_opts += -no-feature-printpreviewdialog
|
$(package)_config_opts += -no-feature-printpreviewdialog
|
||||||
$(package)_config_opts += -no-feature-printpreviewwidget
|
$(package)_config_opts += -no-feature-printpreviewwidget
|
||||||
$(package)_config_opts += -no-feature-regularexpression
|
|
||||||
$(package)_config_opts += -no-feature-sessionmanager
|
$(package)_config_opts += -no-feature-sessionmanager
|
||||||
$(package)_config_opts += -no-feature-socks5
|
$(package)_config_opts += -no-feature-socks5
|
||||||
$(package)_config_opts += -no-feature-sql
|
$(package)_config_opts += -no-feature-sql
|
||||||
|
$(package)_config_opts += -no-feature-sqlmodel
|
||||||
$(package)_config_opts += -no-feature-statemachine
|
$(package)_config_opts += -no-feature-statemachine
|
||||||
$(package)_config_opts += -no-feature-syntaxhighlighter
|
$(package)_config_opts += -no-feature-syntaxhighlighter
|
||||||
$(package)_config_opts += -no-feature-textbrowser
|
$(package)_config_opts += -no-feature-textbrowser
|
||||||
|
@ -115,6 +111,7 @@ $(package)_config_opts += -no-feature-xml
|
||||||
$(package)_config_opts_darwin = -no-dbus
|
$(package)_config_opts_darwin = -no-dbus
|
||||||
$(package)_config_opts_darwin += -no-opengl
|
$(package)_config_opts_darwin += -no-opengl
|
||||||
$(package)_config_opts_darwin += -pch
|
$(package)_config_opts_darwin += -pch
|
||||||
|
$(package)_config_opts_darwin += -device-option QMAKE_MACOSX_DEPLOYMENT_TARGET=$(OSX_MIN_VERSION)
|
||||||
|
|
||||||
ifneq ($(build_os),darwin)
|
ifneq ($(build_os),darwin)
|
||||||
$(package)_config_opts_darwin += -xplatform macx-clang-linux
|
$(package)_config_opts_darwin += -xplatform macx-clang-linux
|
||||||
|
@ -129,13 +126,13 @@ endif
|
||||||
# for macOS on Apple Silicon (ARM) see https://bugreports.qt.io/browse/QTBUG-85279
|
# for macOS on Apple Silicon (ARM) see https://bugreports.qt.io/browse/QTBUG-85279
|
||||||
$(package)_config_opts_arm_darwin += -device-option QMAKE_APPLE_DEVICE_ARCHS=arm64
|
$(package)_config_opts_arm_darwin += -device-option QMAKE_APPLE_DEVICE_ARCHS=arm64
|
||||||
|
|
||||||
$(package)_config_opts_linux = -qt-xkbcommon-x11
|
$(package)_config_opts_linux = -qt-xcb
|
||||||
$(package)_config_opts_linux += -qt-xcb
|
|
||||||
$(package)_config_opts_linux += -no-xcb-xlib
|
$(package)_config_opts_linux += -no-xcb-xlib
|
||||||
$(package)_config_opts_linux += -no-feature-xlib
|
$(package)_config_opts_linux += -no-feature-xlib
|
||||||
$(package)_config_opts_linux += -system-freetype
|
$(package)_config_opts_linux += -system-freetype
|
||||||
$(package)_config_opts_linux += -fontconfig
|
$(package)_config_opts_linux += -fontconfig
|
||||||
$(package)_config_opts_linux += -no-opengl
|
$(package)_config_opts_linux += -no-opengl
|
||||||
|
$(package)_config_opts_linux += -no-feature-vulkan
|
||||||
$(package)_config_opts_linux += -dbus-runtime
|
$(package)_config_opts_linux += -dbus-runtime
|
||||||
$(package)_config_opts_arm_linux += -platform linux-g++ -xplatform bitcoin-linux-g++
|
$(package)_config_opts_arm_linux += -platform linux-g++ -xplatform bitcoin-linux-g++
|
||||||
$(package)_config_opts_i686_linux = -xplatform linux-g++-32
|
$(package)_config_opts_i686_linux = -xplatform linux-g++-32
|
||||||
|
@ -220,21 +217,16 @@ endef
|
||||||
# 8. Adjust a regex in toolchain.prf, to accommodate Guix's usage of
|
# 8. Adjust a regex in toolchain.prf, to accommodate Guix's usage of
|
||||||
# CROSS_LIBRARY_PATH. See #15277.
|
# CROSS_LIBRARY_PATH. See #15277.
|
||||||
define $(package)_preprocess_cmds
|
define $(package)_preprocess_cmds
|
||||||
patch -p1 -i $($(package)_patch_dir)/freetype_back_compat.patch && \
|
|
||||||
patch -p1 -i $($(package)_patch_dir)/fix_powerpc_libpng.patch && \
|
|
||||||
patch -p1 -i $($(package)_patch_dir)/drop_lrelease_dependency.patch && \
|
patch -p1 -i $($(package)_patch_dir)/drop_lrelease_dependency.patch && \
|
||||||
patch -p1 -i $($(package)_patch_dir)/dont_hardcode_pwd.patch && \
|
patch -p1 -i $($(package)_patch_dir)/dont_hardcode_pwd.patch && \
|
||||||
patch -p1 -i $($(package)_patch_dir)/fix_qt_pkgconfig.patch && \
|
patch -p1 -i $($(package)_patch_dir)/fix_qt_pkgconfig.patch && \
|
||||||
patch -p1 -i $($(package)_patch_dir)/fix_configure_mac.patch && \
|
|
||||||
patch -p1 -i $($(package)_patch_dir)/fix_no_printer.patch && \
|
patch -p1 -i $($(package)_patch_dir)/fix_no_printer.patch && \
|
||||||
patch -p1 -i $($(package)_patch_dir)/fix_rcc_determinism.patch && \
|
|
||||||
patch -p1 -i $($(package)_patch_dir)/xkb-default.patch && \
|
|
||||||
patch -p1 -i $($(package)_patch_dir)/fix_android_qmake_conf.patch && \
|
patch -p1 -i $($(package)_patch_dir)/fix_android_qmake_conf.patch && \
|
||||||
patch -p1 -i $($(package)_patch_dir)/fix_android_jni_static.patch && \
|
patch -p1 -i $($(package)_patch_dir)/fix_android_jni_static.patch && \
|
||||||
patch -p1 -i $($(package)_patch_dir)/fix_riscv64_arch.patch && \
|
|
||||||
patch -p1 -i $($(package)_patch_dir)/no-xlib.patch && \
|
patch -p1 -i $($(package)_patch_dir)/no-xlib.patch && \
|
||||||
patch -p1 -i $($(package)_patch_dir)/fix_mingw_cross_compile.patch && \
|
|
||||||
patch -p1 -i $($(package)_patch_dir)/fix_qpainter_non_determinism.patch &&\
|
patch -p1 -i $($(package)_patch_dir)/fix_qpainter_non_determinism.patch &&\
|
||||||
|
patch -p1 -i $($(package)_patch_dir)/no_sdk_version_check.patch && \
|
||||||
|
patch -p1 -i $($(package)_patch_dir)/fix_lib_paths.patch && \
|
||||||
sed -i.old "s|updateqm.commands = \$$$$\$$$$LRELEASE|updateqm.commands = $($(package)_extract_dir)/qttools/bin/lrelease|" qttranslations/translations/translations.pro && \
|
sed -i.old "s|updateqm.commands = \$$$$\$$$$LRELEASE|updateqm.commands = $($(package)_extract_dir)/qttools/bin/lrelease|" qttranslations/translations/translations.pro && \
|
||||||
mkdir -p qtbase/mkspecs/macx-clang-linux &&\
|
mkdir -p qtbase/mkspecs/macx-clang-linux &&\
|
||||||
cp -f qtbase/mkspecs/macx-clang/qplatformdefs.h qtbase/mkspecs/macx-clang-linux/ &&\
|
cp -f qtbase/mkspecs/macx-clang/qplatformdefs.h qtbase/mkspecs/macx-clang-linux/ &&\
|
||||||
|
@ -247,8 +239,8 @@ define $(package)_preprocess_cmds
|
||||||
sed -i.old "s|QMAKE_CFLAGS += |!host_build: QMAKE_CFLAGS = $($(package)_cflags) $($(package)_cppflags) |" qtbase/mkspecs/win32-g++/qmake.conf && \
|
sed -i.old "s|QMAKE_CFLAGS += |!host_build: QMAKE_CFLAGS = $($(package)_cflags) $($(package)_cppflags) |" qtbase/mkspecs/win32-g++/qmake.conf && \
|
||||||
sed -i.old "s|QMAKE_CXXFLAGS += |!host_build: QMAKE_CXXFLAGS = $($(package)_cxxflags) $($(package)_cppflags) |" qtbase/mkspecs/win32-g++/qmake.conf && \
|
sed -i.old "s|QMAKE_CXXFLAGS += |!host_build: QMAKE_CXXFLAGS = $($(package)_cxxflags) $($(package)_cppflags) |" qtbase/mkspecs/win32-g++/qmake.conf && \
|
||||||
sed -i.old "0,/^QMAKE_LFLAGS_/s|^QMAKE_LFLAGS_|!host_build: QMAKE_LFLAGS = $($(package)_ldflags)\n&|" qtbase/mkspecs/win32-g++/qmake.conf && \
|
sed -i.old "0,/^QMAKE_LFLAGS_/s|^QMAKE_LFLAGS_|!host_build: QMAKE_LFLAGS = $($(package)_ldflags)\n&|" qtbase/mkspecs/win32-g++/qmake.conf && \
|
||||||
sed -i.old "s|QMAKE_CC = clang|QMAKE_CC = $($(package)_cc)|" qtbase/mkspecs/common/clang.conf && \
|
sed -i.old "s|QMAKE_CC = \$$$$\$$$${CROSS_COMPILE}clang|QMAKE_CC = $($(package)_cc)|" qtbase/mkspecs/common/clang.conf && \
|
||||||
sed -i.old "s|QMAKE_CXX = clang++|QMAKE_CXX = $($(package)_cxx)|" qtbase/mkspecs/common/clang.conf && \
|
sed -i.old "s|QMAKE_CXX = \$$$$\$$$${CROSS_COMPILE}clang++|QMAKE_CXX = $($(package)_cxx)|" qtbase/mkspecs/common/clang.conf && \
|
||||||
sed -i.old "s/LIBRARY_PATH/(CROSS_)?\0/g" qtbase/mkspecs/features/toolchain.prf
|
sed -i.old "s/LIBRARY_PATH/(CROSS_)?\0/g" qtbase/mkspecs/features/toolchain.prf
|
||||||
endef
|
endef
|
||||||
|
|
||||||
|
@ -258,8 +250,6 @@ define $(package)_config_cmds
|
||||||
export PKG_CONFIG_PATH=$(host_prefix)/share/pkgconfig && \
|
export PKG_CONFIG_PATH=$(host_prefix)/share/pkgconfig && \
|
||||||
cd qtbase && \
|
cd qtbase && \
|
||||||
./configure $($(package)_config_opts) && \
|
./configure $($(package)_config_opts) && \
|
||||||
echo "host_build: QT_CONFIG ~= s/system-zlib/zlib" >> mkspecs/qconfig.pri && \
|
|
||||||
echo "CONFIG += force_bootstrap" >> mkspecs/qconfig.pri && \
|
|
||||||
cd .. && \
|
cd .. && \
|
||||||
$(MAKE) -C qtbase sub-src-clean && \
|
$(MAKE) -C qtbase sub-src-clean && \
|
||||||
qtbase/bin/qmake -o qttranslations/Makefile qttranslations/qttranslations.pro && \
|
qtbase/bin/qmake -o qttranslations/Makefile qttranslations/qttranslations.pro && \
|
||||||
|
|
|
@ -1,31 +0,0 @@
|
||||||
package=zlib
|
|
||||||
$(package)_version=1.2.11
|
|
||||||
$(package)_download_path=https://www.zlib.net
|
|
||||||
$(package)_file_name=$(package)-$($(package)_version).tar.gz
|
|
||||||
$(package)_sha256_hash=c3e5e9fdd5004dcb542feda5ee4f0ff0744628baf8ed2dd5d66f8ca1197cb1a1
|
|
||||||
|
|
||||||
define $(package)_set_vars
|
|
||||||
$(package)_config_opts= CC="$($(package)_cc)"
|
|
||||||
$(package)_config_opts+=CFLAGS="$($(package)_cflags) $($(package)_cppflags) -fPIC"
|
|
||||||
$(package)_config_opts+=RANLIB="$($(package)_ranlib)"
|
|
||||||
$(package)_config_opts+=AR="$($(package)_ar)"
|
|
||||||
$(package)_config_opts_darwin+=AR="$($(package)_libtool)"
|
|
||||||
$(package)_config_opts_darwin+=ARFLAGS="-o"
|
|
||||||
$(package)_config_opts_android+=CHOST=$(host)
|
|
||||||
endef
|
|
||||||
|
|
||||||
# zlib has its own custom configure script that takes in options like CC,
|
|
||||||
# CFLAGS, RANLIB, AR, and ARFLAGS from the environment rather than from
|
|
||||||
# command-line arguments.
|
|
||||||
define $(package)_config_cmds
|
|
||||||
env $($(package)_config_opts) ./configure --static --prefix=$(host_prefix)
|
|
||||||
endef
|
|
||||||
|
|
||||||
define $(package)_build_cmds
|
|
||||||
$(MAKE) libz.a
|
|
||||||
endef
|
|
||||||
|
|
||||||
define $(package)_stage_cmds
|
|
||||||
$(MAKE) DESTDIR=$($(package)_staging_dir) install
|
|
||||||
endef
|
|
||||||
|
|
|
@ -14,7 +14,7 @@ diff --git a/qttranslations/translations/translations.pro b/qttranslations/trans
|
||||||
index 694544c..eff339d 100644
|
index 694544c..eff339d 100644
|
||||||
--- a/qttranslations/translations/translations.pro
|
--- a/qttranslations/translations/translations.pro
|
||||||
+++ b/qttranslations/translations/translations.pro
|
+++ b/qttranslations/translations/translations.pro
|
||||||
@@ -109,3 +109,2 @@ updateqm.commands = $$LRELEASE ${QMAKE_FILE_IN} -qm ${QMAKE_FILE_OUT}
|
@@ -107,3 +107,2 @@ updateqm.commands = $$LRELEASE ${QMAKE_FILE_IN} -qm ${QMAKE_FILE_OUT}
|
||||||
silent:updateqm.commands = @echo lrelease ${QMAKE_FILE_IN} && $$updateqm.commands
|
silent:updateqm.commands = @echo lrelease ${QMAKE_FILE_IN} && $$updateqm.commands
|
||||||
-updateqm.depends = $$LRELEASE_EXE
|
-updateqm.depends = $$LRELEASE_EXE
|
||||||
updateqm.name = LRELEASE ${QMAKE_FILE_IN}
|
updateqm.name = LRELEASE ${QMAKE_FILE_IN}
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
--- old/qtbase/src/plugins/platforms/android/androidjnimain.cpp
|
--- old/qtbase/src/plugins/platforms/android/androidjnimain.cpp
|
||||||
+++ new/qtbase/src/plugins/platforms/android/androidjnimain.cpp
|
+++ new/qtbase/src/plugins/platforms/android/androidjnimain.cpp
|
||||||
@@ -890,6 +890,14 @@
|
@@ -897,6 +897,14 @@
|
||||||
__android_log_print(ANDROID_LOG_FATAL, "Qt", "registerNatives failed");
|
__android_log_print(ANDROID_LOG_FATAL, "Qt", "registerNatives failed");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,20 +1,10 @@
|
||||||
--- old/qtbase/mkspecs/android-clang/qmake.conf
|
--- old/qtbase/mkspecs/android-clang/qmake.conf
|
||||||
+++ new/qtbase/mkspecs/android-clang/qmake.conf
|
+++ new/qtbase/mkspecs/android-clang/qmake.conf
|
||||||
@@ -30,7 +30,7 @@
|
@@ -47,7 +47,7 @@ ANDROID_STDCPP_PATH = $$ANDROID_SOURCES_CXX_STL_LIBDIR/libc++_shared.so
|
||||||
QMAKE_CFLAGS += -target mips64el-none-linux-android
|
ANDROID_USE_LLVM = true
|
||||||
|
|
||||||
QMAKE_CFLAGS += -gcc-toolchain $$NDK_TOOLCHAIN_PATH
|
exists($$ANDROID_SOURCES_CXX_STL_LIBDIR/libc++.so): \
|
||||||
-QMAKE_LINK = $$QMAKE_CXX $$QMAKE_CFLAGS -Wl,--exclude-libs,libgcc.a
|
- ANDROID_CXX_STL_LIBS = -lc++
|
||||||
+QMAKE_LINK = $$QMAKE_CXX $$QMAKE_CFLAGS -Wl,--exclude-libs,libgcc.a -nostdlib++
|
+ ANDROID_CXX_STL_LIBS = -lc++_shared
|
||||||
QMAKE_CFLAGS += -DANDROID_HAS_WSTRING --sysroot=$$NDK_ROOT/sysroot \
|
else: \
|
||||||
-isystem $$NDK_ROOT/sysroot/usr/include/$$NDK_TOOLS_PREFIX \
|
ANDROID_CXX_STL_LIBS = $$ANDROID_SOURCES_CXX_STL_LIBDIR/libc++.so.$$replace(ANDROID_PLATFORM, "android-", "")
|
||||||
-isystem $$NDK_ROOT/sources/cxx-stl/llvm-libc++/include \
|
|
||||||
@@ -40,7 +40,7 @@
|
|
||||||
ANDROID_SOURCES_CXX_STL_LIBDIR = $$NDK_ROOT/sources/cxx-stl/llvm-libc++/libs/$$ANDROID_TARGET_ARCH
|
|
||||||
|
|
||||||
ANDROID_STDCPP_PATH = $$ANDROID_SOURCES_CXX_STL_LIBDIR/libc++_shared.so
|
|
||||||
-ANDROID_CXX_STL_LIBS = -lc++
|
|
||||||
+ANDROID_CXX_STL_LIBS = -lc++_shared
|
|
||||||
|
|
||||||
QMAKE_ARM_CFLAGS_RELEASE = -Oz
|
|
||||||
QMAKE_ARM_CFLAGS_RELEASE_WITH_DEBUGINFO = -g -Oz
|
|
||||||
|
|
|
@ -1,50 +0,0 @@
|
||||||
--- old/qtbase/mkspecs/features/mac/sdk.prf 2018-02-08 10:24:48.000000000 -0800
|
|
||||||
+++ new/qtbase/mkspecs/features/mac/sdk.prf 2018-03-23 10:38:56.000000000 -0700
|
|
||||||
@@ -8,21 +8,21 @@
|
|
||||||
defineReplace(xcodeSDKInfo) {
|
|
||||||
info = $$1
|
|
||||||
equals(info, "Path"): \
|
|
||||||
- info = --show-sdk-path
|
|
||||||
+ infoarg = --show-sdk-path
|
|
||||||
equals(info, "PlatformPath"): \
|
|
||||||
- info = --show-sdk-platform-path
|
|
||||||
+ infoarg = --show-sdk-platform-path
|
|
||||||
equals(info, "SDKVersion"): \
|
|
||||||
- info = --show-sdk-version
|
|
||||||
+ infoarg = --show-sdk-version
|
|
||||||
sdk = $$2
|
|
||||||
isEmpty(sdk): \
|
|
||||||
sdk = $$QMAKE_MAC_SDK
|
|
||||||
|
|
||||||
isEmpty(QMAKE_MAC_SDK.$${sdk}.$${info}) {
|
|
||||||
- QMAKE_MAC_SDK.$${sdk}.$${info} = $$system("/usr/bin/xcrun --sdk $$sdk $$info 2>/dev/null")
|
|
||||||
+ QMAKE_MAC_SDK.$${sdk}.$${info} = $$system("/usr/bin/xcrun --sdk $$sdk $$infoarg 2>/dev/null")
|
|
||||||
# --show-sdk-platform-path won't work for Command Line Tools; this is fine
|
|
||||||
# only used by the XCTest backend to testlib
|
|
||||||
- isEmpty(QMAKE_MAC_SDK.$${sdk}.$${info}):if(!isEmpty(QMAKE_XCODEBUILD_PATH)|!equals(info, "--show-sdk-platform-path")): \
|
|
||||||
- error("Could not resolve SDK $$info for \'$$sdk\'")
|
|
||||||
+ isEmpty(QMAKE_MAC_SDK.$${sdk}.$${info}):if(!isEmpty(QMAKE_XCODEBUILD_PATH)|!equals(infoarg, "--show-sdk-platform-path")): \
|
|
||||||
+ error("Could not resolve SDK $$info for \'$$sdk\' using $$infoarg")
|
|
||||||
cache(QMAKE_MAC_SDK.$${sdk}.$${info}, set stash, QMAKE_MAC_SDK.$${sdk}.$${info})
|
|
||||||
}
|
|
||||||
|
|
||||||
--- old/qtbase/configure 2018-02-08 10:24:48.000000000 -0800
|
|
||||||
+++ new/qtbase/configure 2018-03-23 05:42:29.000000000 -0700
|
|
||||||
@@ -232,8 +232,13 @@
|
|
||||||
|
|
||||||
sdk=$(getSingleQMakeVariable "QMAKE_MAC_SDK" "$1")
|
|
||||||
if [ -z "$sdk" ]; then echo "QMAKE_MAC_SDK must be set when building on Mac" >&2; exit 1; fi
|
|
||||||
- sysroot=$(/usr/bin/xcrun --sdk $sdk --show-sdk-path 2>/dev/null)
|
|
||||||
- if [ -z "$sysroot" ]; then echo "Failed to resolve SDK path for '$sdk'" >&2; exit 1; fi
|
|
||||||
+ sysroot=$(getSingleQMakeVariable "QMAKE_MAC_SDK_PATH" "$1")
|
|
||||||
+
|
|
||||||
+ echo "sysroot pre-configured as $sysroot";
|
|
||||||
+ if [ -z "$sysroot" ]; then
|
|
||||||
+ sysroot=$(/usr/bin/xcrun --sdk $sdk --show-sdk-path 2>/dev/null)
|
|
||||||
+ if [ -z "$sysroot" ]; then echo "Failed to resolve SDK path for '$sdk'" >&2; exit 1; fi
|
|
||||||
+ fi
|
|
||||||
|
|
||||||
case "$sdk" in
|
|
||||||
macosx*)
|
|
||||||
|
|
||||||
|
|
193
depends/patches/qt/fix_lib_paths.patch
Normal file
193
depends/patches/qt/fix_lib_paths.patch
Normal file
|
@ -0,0 +1,193 @@
|
||||||
|
--- old/qtbase/mkspecs/common/mac.conf
|
||||||
|
+++ new/qtbase/mkspecs/common/mac.conf
|
||||||
|
@@ -14,7 +14,6 @@
|
||||||
|
|
||||||
|
QMAKE_RESOURCE = /Developer/Tools/Rez
|
||||||
|
QMAKE_EXTENSION_SHLIB = dylib
|
||||||
|
-QMAKE_EXTENSIONS_AUX_SHLIB = tbd
|
||||||
|
QMAKE_LIBDIR =
|
||||||
|
|
||||||
|
# sdk.prf will prefix the proper SDK sysroot
|
||||||
|
|
||||||
|
--- old/qtbase/mkspecs/features/qmake_use.prf
|
||||||
|
+++ new/qtbase/mkspecs/features/qmake_use.prf
|
||||||
|
@@ -22,6 +22,8 @@
|
||||||
|
!defined(QMAKE_LIBS_$$nu, var): \
|
||||||
|
error("Library '$$lower($$replace(nu, _, -))' is not defined.")
|
||||||
|
|
||||||
|
+ QMAKE_LIBDIR += $$eval(QMAKE_LIBDIR_$$nu)
|
||||||
|
+
|
||||||
|
debug: \
|
||||||
|
LIBS$${suffix} += $$eval(QMAKE_LIBS_$${nu}_DEBUG) $$eval(QMAKE_LIBS_$$nu)
|
||||||
|
else: \
|
||||||
|
|
||||||
|
--- old/qtbase/mkspecs/features/qt_configure.prf
|
||||||
|
+++ new/qtbase/mkspecs/features/qt_configure.prf
|
||||||
|
@@ -526,98 +526,23 @@
|
||||||
|
return($$sysrootified)
|
||||||
|
}
|
||||||
|
|
||||||
|
-# libs-var, libs, in-paths, out-paths-var
|
||||||
|
+# libs-var, libs, in-paths
|
||||||
|
defineTest(qtConfResolveLibs) {
|
||||||
|
- ret = true
|
||||||
|
- paths = $$3
|
||||||
|
- out =
|
||||||
|
- copy = false
|
||||||
|
- for (l, 2) {
|
||||||
|
- $$copy {
|
||||||
|
- copy = false
|
||||||
|
- out += $$l
|
||||||
|
- } else: equals(l, "-s") {
|
||||||
|
- # em++ flag to link libraries from emscripten-ports; passed on literally.
|
||||||
|
- copy = true
|
||||||
|
- out += $$l
|
||||||
|
- } else: contains(l, "^-L.*") {
|
||||||
|
- lp = $$replace(l, "^-L", )
|
||||||
|
- gcc: lp = $$qtGccSysrootifiedPath($$lp)
|
||||||
|
- !exists($$lp/.) {
|
||||||
|
- qtLog("Library path $$val_escape(lp) is invalid.")
|
||||||
|
- ret = false
|
||||||
|
- } else {
|
||||||
|
- paths += $$lp
|
||||||
|
- }
|
||||||
|
- } else: contains(l, "^-l.*") {
|
||||||
|
- lib = $$replace(l, "^-l", )
|
||||||
|
- lcan =
|
||||||
|
- integrity:contains(lib, "^.*\\.a") {
|
||||||
|
- # INTEGRITY compiler searches for exact filename
|
||||||
|
- # if -l argument has .a suffix
|
||||||
|
- lcan += $${lib}
|
||||||
|
- } else: contains(lib, "^:.*") {
|
||||||
|
- # Use exact filename when -l:filename syntax is used.
|
||||||
|
- lib ~= s/^://
|
||||||
|
- lcan += $${lib}
|
||||||
|
- } else: unix {
|
||||||
|
- # Under UNIX, we look for actual shared libraries, in addition
|
||||||
|
- # to static ones.
|
||||||
|
- shexts = $$QMAKE_EXTENSION_SHLIB $$QMAKE_EXTENSIONS_AUX_SHLIB
|
||||||
|
- for (ext, shexts) {
|
||||||
|
- lcan += $${QMAKE_PREFIX_SHLIB}$${lib}.$${ext}
|
||||||
|
- }
|
||||||
|
- lcan += \
|
||||||
|
- $${QMAKE_PREFIX_STATICLIB}$${lib}.$${QMAKE_EXTENSION_STATICLIB}
|
||||||
|
- } else {
|
||||||
|
- # Under Windows, we look only for static libraries, as even for DLLs
|
||||||
|
- # one actually links against a static import library.
|
||||||
|
- mingw {
|
||||||
|
- lcan += \
|
||||||
|
- # MinGW supports UNIX-style library naming in addition to
|
||||||
|
- # the MSVC style.
|
||||||
|
- lib$${lib}.dll.a lib$${lib}.a \
|
||||||
|
- # Fun fact: prefix-less libraries are also supported.
|
||||||
|
- $${lib}.dll.a $${lib}.a
|
||||||
|
- }
|
||||||
|
- lcan += $${lib}.lib
|
||||||
|
- }
|
||||||
|
- l = $$qtConfFindInPathList($$lcan, $$paths $$EXTRA_LIBDIR $$QMAKE_DEFAULT_LIBDIRS)
|
||||||
|
- isEmpty(l) {
|
||||||
|
- qtLog("None of [$$val_escape(lcan)] found in [$$val_escape(paths)] and global paths.")
|
||||||
|
- ret = false
|
||||||
|
- } else {
|
||||||
|
- out += $$l
|
||||||
|
- }
|
||||||
|
- } else {
|
||||||
|
- out += $$l
|
||||||
|
- }
|
||||||
|
- }
|
||||||
|
- $$1 = $$out
|
||||||
|
+ for (path, 3): \
|
||||||
|
+ pre_lflags += -L$$path
|
||||||
|
+ $$1 = $$pre_lflags $$2
|
||||||
|
export($$1)
|
||||||
|
- !isEmpty(4) {
|
||||||
|
- $$4 = $$paths
|
||||||
|
- export($$4)
|
||||||
|
- }
|
||||||
|
- return($$ret)
|
||||||
|
-}
|
||||||
|
-
|
||||||
|
-# source-var
|
||||||
|
-defineTest(qtConfResolveAllLibs) {
|
||||||
|
- ret = true
|
||||||
|
- !qtConfResolveLibs($${1}.libs, $$eval($${1}.libs), , $${1}.libdirs): \
|
||||||
|
- ret = false
|
||||||
|
- for (b, $${1}.builds._KEYS_): \
|
||||||
|
- !qtConfResolveLibs($${1}.builds.$${b}, $$eval($${1}.builds.$${b}), $$eval($${1}.libdirs), ): \
|
||||||
|
- ret = false
|
||||||
|
- return($$ret)
|
||||||
|
+ return(true)
|
||||||
|
}
|
||||||
|
|
||||||
|
# libs-var, in-paths, libs
|
||||||
|
defineTest(qtConfResolvePathLibs) {
|
||||||
|
ret = true
|
||||||
|
- gcc: 2 = $$qtGccSysrootifiedPaths($$2)
|
||||||
|
- for (libdir, 2) {
|
||||||
|
+ gcc: \
|
||||||
|
+ local_paths = $$qtGccSysrootifiedPaths($$2)
|
||||||
|
+ else: \
|
||||||
|
+ local_paths = $$2
|
||||||
|
+ for (libdir, local_paths) {
|
||||||
|
!exists($$libdir/.) {
|
||||||
|
qtLog("Library path $$val_escape(libdir) is invalid.")
|
||||||
|
ret = false
|
||||||
|
@@ -667,8 +592,11 @@
|
||||||
|
# includes-var, in-paths, test-object-var
|
||||||
|
defineTest(qtConfResolvePathIncs) {
|
||||||
|
ret = true
|
||||||
|
- gcc: 2 = $$qtGccSysrootifiedPaths($$2)
|
||||||
|
- for (incdir, 2) {
|
||||||
|
+ gcc: \
|
||||||
|
+ local_paths = $$qtGccSysrootifiedPaths($$2)
|
||||||
|
+ else: \
|
||||||
|
+ local_paths = $$2
|
||||||
|
+ for (incdir, local_paths) {
|
||||||
|
!exists($$incdir/.) {
|
||||||
|
qtLog("Include path $$val_escape(incdir) is invalid.")
|
||||||
|
ret = false
|
||||||
|
@@ -727,6 +655,7 @@
|
||||||
|
vars += $$eval(config.commandline.rev_assignments.$${iv})
|
||||||
|
defined(config.input.$${iv}, var) {
|
||||||
|
eval($${1}.builds.$${b} = $$eval(config.input.$${iv}))
|
||||||
|
+ export($${1}.builds.$${b})
|
||||||
|
$${1}.builds._KEYS_ *= $${b}
|
||||||
|
any = true
|
||||||
|
} else {
|
||||||
|
@@ -741,11 +670,14 @@
|
||||||
|
export($${1}.builds._KEYS_)
|
||||||
|
# we also reset the generic libs, to avoid surprises.
|
||||||
|
$${1}.libs =
|
||||||
|
+ export($${1}.libs)
|
||||||
|
}
|
||||||
|
|
||||||
|
# direct libs. overwrites inline libs.
|
||||||
|
- defined(config.input.$${input}.libs, var): \
|
||||||
|
+ defined(config.input.$${input}.libs, var) {
|
||||||
|
eval($${1}.libs = $$eval(config.input.$${input}.libs))
|
||||||
|
+ export($${1}.libs)
|
||||||
|
+ }
|
||||||
|
|
||||||
|
includes = $$eval(config.input.$${input}.incdir)
|
||||||
|
|
||||||
|
@@ -754,6 +686,7 @@
|
||||||
|
!isEmpty(prefix) {
|
||||||
|
includes += $$prefix/include
|
||||||
|
$${1}.libs = -L$$prefix/lib $$eval($${1}.libs)
|
||||||
|
+ export($${1}.libs)
|
||||||
|
}
|
||||||
|
|
||||||
|
libdir = $$eval(config.input.$${input}.libdir)
|
||||||
|
@@ -762,11 +695,9 @@
|
||||||
|
for (ld, libdir): \
|
||||||
|
libs += -L$$ld
|
||||||
|
$${1}.libs = $$libs $$eval($${1}.libs)
|
||||||
|
+ export($${1}.libs)
|
||||||
|
}
|
||||||
|
|
||||||
|
- !qtConfResolveAllLibs($$1): \
|
||||||
|
- return(false)
|
||||||
|
-
|
||||||
|
!qtConfResolvePathIncs($${1}.includedir, $$includes, $$2): \
|
||||||
|
return(false)
|
||||||
|
|
|
@ -1,25 +0,0 @@
|
||||||
commit 5a992a549adfe5a587bbcd6cd2b2cee47d236e27
|
|
||||||
Author: fanquake <fanquake@gmail.com>
|
|
||||||
Date: Fri Sep 4 08:13:44 2020 +0800
|
|
||||||
|
|
||||||
Work around broken mingw cross-compilation
|
|
||||||
|
|
||||||
See upstream issues:
|
|
||||||
https://bugreports.qt.io/browse/QTBUG-63637
|
|
||||||
https://bugreports.qt.io/browse/QTBUG-63659
|
|
||||||
https://codereview.qt-project.org/q/8bebded9
|
|
||||||
|
|
||||||
We should be able to drop this once we are building qt 5.10.1 or later.
|
|
||||||
|
|
||||||
Added in #12971.
|
|
||||||
|
|
||||||
diff --git a/qtbase/mkspecs/win32-g++/qmake.conf b/qtbase/mkspecs/win32-g++/qmake.conf
|
|
||||||
index e071a0d1..ad229b10 100644
|
|
||||||
--- a/qtbase/mkspecs/win32-g++/qmake.conf
|
|
||||||
+++ b/qtbase/mkspecs/win32-g++/qmake.conf
|
|
||||||
@@ -87,3 +87,5 @@ QMAKE_NM = $${CROSS_COMPILE}nm -P
|
|
||||||
include(../common/angle.conf)
|
|
||||||
|
|
||||||
load(qt_config)
|
|
||||||
+QMAKE_LINK_OBJECT_MAX = 10
|
|
||||||
+QMAKE_LINK_OBJECT_SCRIPT = object_script
|
|
|
@ -10,10 +10,10 @@
|
||||||
|
|
||||||
--- x/qtbase/src/plugins/plugins.pro
|
--- x/qtbase/src/plugins/plugins.pro
|
||||||
+++ y/qtbase/src/plugins/plugins.pro
|
+++ y/qtbase/src/plugins/plugins.pro
|
||||||
@@ -8,6 +8,3 @@ qtHaveModule(gui) {
|
@@ -9,6 +9,3 @@ qtHaveModule(gui) {
|
||||||
qtConfig(imageformatplugin): SUBDIRS *= imageformats
|
|
||||||
!android:qtConfig(library): SUBDIRS *= generic
|
!android:qtConfig(library): SUBDIRS *= generic
|
||||||
}
|
}
|
||||||
|
qtHaveModule(widgets): SUBDIRS += styles
|
||||||
-
|
-
|
||||||
-!winrt:qtHaveModule(printsupport): \
|
-!winrt:qtHaveModule(printsupport): \
|
||||||
- SUBDIRS += printsupport
|
- SUBDIRS += printsupport
|
||||||
|
|
|
@ -1,23 +0,0 @@
|
||||||
commit 6f9feb773a43c5abfa3455da2e324180e789285b
|
|
||||||
Author: fanquake <fanquake@gmail.com>
|
|
||||||
Date: Tue Sep 15 21:44:31 2020 +0800
|
|
||||||
|
|
||||||
Fix PowerPC build of libpng
|
|
||||||
|
|
||||||
See https://bugreports.qt.io/browse/QTBUG-66388.
|
|
||||||
|
|
||||||
Can be dropped when we are building qt 5.12.0 or later.
|
|
||||||
|
|
||||||
diff --git a/qtbase/src/3rdparty/libpng/libpng.pro b/qtbase/src/3rdparty/libpng/libpng.pro
|
|
||||||
index 577b61d8..a2f56669 100644
|
|
||||||
--- a/qtbase/src/3rdparty/libpng/libpng.pro
|
|
||||||
+++ b/qtbase/src/3rdparty/libpng/libpng.pro
|
|
||||||
@@ -10,7 +10,7 @@ MODULE_INCLUDEPATH = $$PWD
|
|
||||||
|
|
||||||
load(qt_helper_lib)
|
|
||||||
|
|
||||||
-DEFINES += PNG_ARM_NEON_OPT=0
|
|
||||||
+DEFINES += PNG_ARM_NEON_OPT=0 PNG_POWERPC_VSX_OPT=0
|
|
||||||
SOURCES += \
|
|
||||||
png.c \
|
|
||||||
pngerror.c \
|
|
|
@ -22,7 +22,7 @@ diff --git a/qtbase/src/gui/painting/qpaintengine_raster.cpp b/qtbase/src/gui/pa
|
||||||
index 92ab6e8375..f018009e0b 100644
|
index 92ab6e8375..f018009e0b 100644
|
||||||
--- a/qtbase/src/gui/painting/qpaintengine_raster.cpp
|
--- a/qtbase/src/gui/painting/qpaintengine_raster.cpp
|
||||||
+++ b/qtbase/src/gui/painting/qpaintengine_raster.cpp
|
+++ b/qtbase/src/gui/painting/qpaintengine_raster.cpp
|
||||||
@@ -3971,22 +3971,23 @@ static const QSpan *qt_intersect_spans(const QClipData *clip, int *currentClip,
|
@@ -4128,22 +4128,23 @@ static const QSpan *qt_intersect_spans(const QClipData *clip, int *currentClip,
|
||||||
const QSpan *clipEnd = clip->m_spans + clip->count;
|
const QSpan *clipEnd = clip->m_spans + clip->count;
|
||||||
|
|
||||||
while (available && spans < end ) {
|
while (available && spans < end ) {
|
||||||
|
@ -51,7 +51,7 @@ index 92ab6e8375..f018009e0b 100644
|
||||||
|
|
||||||
int sx1 = spans->x;
|
int sx1 = spans->x;
|
||||||
int sx2 = sx1 + spans->len;
|
int sx2 = sx1 + spans->len;
|
||||||
@@ -4005,7 +4006,7 @@ static const QSpan *qt_intersect_spans(const QClipData *clip, int *currentClip,
|
@@ -4162,7 +4163,7 @@ static const QSpan *qt_intersect_spans(const QClipData *clip, int *currentClip,
|
||||||
if (len) {
|
if (len) {
|
||||||
out->x = qMax(sx1, cx1);
|
out->x = qMax(sx1, cx1);
|
||||||
out->len = qMin(sx2, cx2) - out->x;
|
out->len = qMin(sx2, cx2) - out->x;
|
||||||
|
|
|
@ -1,17 +1,17 @@
|
||||||
--- old/qtbase/mkspecs/features/qt_module.prf
|
--- old/qtbase/mkspecs/features/qt_module.prf
|
||||||
+++ new/qtbase/mkspecs/features/qt_module.prf
|
+++ new/qtbase/mkspecs/features/qt_module.prf
|
||||||
@@ -264,7 +264,7 @@
|
@@ -269,7 +269,7 @@ load(qt_installs)
|
||||||
load(qt_targets)
|
load(qt_targets)
|
||||||
|
|
||||||
# this builds on top of qt_common
|
# this builds on top of qt_common
|
||||||
-!internal_module:!lib_bundle:if(unix|mingw) {
|
-!internal_module:if(unix|mingw) {
|
||||||
+if(unix|mingw):!if(darwin:debug_and_release:CONFIG(debug, debug|release)) {
|
+if(unix|mingw):!if(darwin:debug_and_release:CONFIG(debug, debug|release)) {
|
||||||
CONFIG += create_pc
|
CONFIG += create_pc
|
||||||
QMAKE_PKGCONFIG_DESTDIR = pkgconfig
|
QMAKE_PKGCONFIG_DESTDIR = pkgconfig
|
||||||
host_build: \
|
host_build: \
|
||||||
@@ -274,9 +274,9 @@
|
@@ -284,9 +284,9 @@ load(qt_targets)
|
||||||
QMAKE_PKGCONFIG_INCDIR = $$[QT_INSTALL_HEADERS/raw]
|
QMAKE_PKGCONFIG_CFLAGS = -D$$MODULE_DEFINE -I${includedir}/$$MODULE_INCNAME
|
||||||
QMAKE_PKGCONFIG_CFLAGS = -I${includedir}/$$MODULE_INCNAME
|
}
|
||||||
QMAKE_PKGCONFIG_NAME = $$replace(TARGET, ^Qt, "Qt$$QT_MAJOR_VERSION ")
|
QMAKE_PKGCONFIG_NAME = $$replace(TARGET, ^Qt, "Qt$$QT_MAJOR_VERSION ")
|
||||||
- QMAKE_PKGCONFIG_FILE = $$replace(TARGET, ^Qt, Qt$$QT_MAJOR_VERSION)
|
- QMAKE_PKGCONFIG_FILE = $$replace(TARGET, ^Qt, Qt$$QT_MAJOR_VERSION)
|
||||||
+ QMAKE_PKGCONFIG_FILE = $$replace(TARGET, ^Qt, Qt$$QT_MAJOR_VERSION)$$qtPlatformTargetSuffix()
|
+ QMAKE_PKGCONFIG_FILE = $$replace(TARGET, ^Qt, Qt$$QT_MAJOR_VERSION)$$qtPlatformTargetSuffix()
|
||||||
|
@ -20,4 +20,4 @@
|
||||||
+ QMAKE_PKGCONFIG_REQUIRES += $$replace(QT.$${i}.name, ^Qt, Qt$$section(QT.$${i}.VERSION, ., 0, 0))$$qtPlatformTargetSuffix()
|
+ QMAKE_PKGCONFIG_REQUIRES += $$replace(QT.$${i}.name, ^Qt, Qt$$section(QT.$${i}.VERSION, ., 0, 0))$$qtPlatformTargetSuffix()
|
||||||
isEmpty(QMAKE_PKGCONFIG_DESCRIPTION): \
|
isEmpty(QMAKE_PKGCONFIG_DESCRIPTION): \
|
||||||
QMAKE_PKGCONFIG_DESCRIPTION = $$replace(TARGET, ^Qt, "Qt ") module
|
QMAKE_PKGCONFIG_DESCRIPTION = $$replace(TARGET, ^Qt, "Qt ") module
|
||||||
pclib_replace.match = $$lib_replace.match
|
!isEmpty(lib_replace0.match) {
|
||||||
|
|
|
@ -1,15 +0,0 @@
|
||||||
--- old/qtbase/src/tools/rcc/rcc.cpp
|
|
||||||
+++ new/qtbase/src/tools/rcc/rcc.cpp
|
|
||||||
@@ -207,7 +207,11 @@ void RCCFileInfo::writeDataInfo(RCCResourceLibrary &lib)
|
|
||||||
if (lib.formatVersion() >= 2) {
|
|
||||||
// last modified time stamp
|
|
||||||
const QDateTime lastModified = m_fileInfo.lastModified();
|
|
||||||
- lib.writeNumber8(quint64(lastModified.isValid() ? lastModified.toMSecsSinceEpoch() : 0));
|
|
||||||
+ quint64 lastmod = quint64(lastModified.isValid() ? lastModified.toMSecsSinceEpoch() : 0);
|
|
||||||
+ static const quint64 sourceDate = 1000 * qgetenv("QT_RCC_SOURCE_DATE_OVERRIDE").toULongLong();
|
|
||||||
+ if (sourceDate != 0)
|
|
||||||
+ lastmod = sourceDate;
|
|
||||||
+ lib.writeNumber8(lastmod);
|
|
||||||
if (text || pass1)
|
|
||||||
lib.writeChar('\n');
|
|
||||||
}
|
|
|
@ -1,14 +0,0 @@
|
||||||
diff --git a/qtbase/src/3rdparty/double-conversion/include/double-conversion/utils.h b/qtbase/src/3rdparty/double-conversion/include/double-conversion/utils.h
|
|
||||||
index 20bfd36..93729fa 100644
|
|
||||||
--- a/qtbase/src/3rdparty/double-conversion/include/double-conversion/utils.h
|
|
||||||
+++ b/qtbase/src/3rdparty/double-conversion/include/double-conversion/utils.h
|
|
||||||
@@ -65,7 +65,8 @@
|
|
||||||
defined(__sparc__) || defined(__sparc) || defined(__s390__) || \
|
|
||||||
defined(__SH4__) || defined(__alpha__) || \
|
|
||||||
defined(_MIPS_ARCH_MIPS32R2) || \
|
|
||||||
- defined(__AARCH64EL__)
|
|
||||||
+ defined(__AARCH64EL__) || defined(__aarch64__) || \
|
|
||||||
+ defined(__riscv)
|
|
||||||
#define DOUBLE_CONVERSION_CORRECT_DOUBLE_OPERATIONS 1
|
|
||||||
#elif defined(_M_IX86) || defined(__i386__) || defined(__i386)
|
|
||||||
#if defined(_WIN32)
|
|
|
@ -1,28 +0,0 @@
|
||||||
commit 14bc77db61bf9d56f9b6c8b84aa02573605c19c6
|
|
||||||
Author: fanquake <fanquake@gmail.com>
|
|
||||||
Date: Tue Aug 18 15:15:08 2020 +0800
|
|
||||||
|
|
||||||
Fix backwards compatibility with older Freetype versions at runtime
|
|
||||||
|
|
||||||
A few years ago, libfreetype introduced FT_Get_Font_Format() as an alias
|
|
||||||
for FT_Get_X11_Font_Format(), but FT_Get_X11_Font_Format() was kept for abi
|
|
||||||
backwards-compatibility.
|
|
||||||
|
|
||||||
Qt 5.9 introduced a call to FT_Get_Font_Format(). Replace it with FT_Get_X11_Font_Format()
|
|
||||||
in order to remain compatible with older freetype, which is still used by e.g. Ubuntu Trusty.
|
|
||||||
|
|
||||||
See #14348.
|
|
||||||
|
|
||||||
diff --git a/qtbase/src/platformsupport/fontdatabases/freetype/qfontengine_ft.cpp b/qtbase/src/platformsupport/fontdatabases/freetype/qfontengine_ft.cpp
|
|
||||||
index 3f543755..8ecc1c8c 100644
|
|
||||||
--- a/qtbase/src/platformsupport/fontdatabases/freetype/qfontengine_ft.cpp
|
|
||||||
+++ b/qtbase/src/platformsupport/fontdatabases/freetype/qfontengine_ft.cpp
|
|
||||||
@@ -898,7 +898,7 @@ bool QFontEngineFT::init(FaceId faceId, bool antialias, GlyphFormat format,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#if defined(FT_FONT_FORMATS_H)
|
|
||||||
- const char *fmt = FT_Get_Font_Format(face);
|
|
||||||
+ const char *fmt = FT_Get_X11_Font_Format(face);
|
|
||||||
if (fmt && qstrncmp(fmt, "CFF", 4) == 0) {
|
|
||||||
FT_Bool no_stem_darkening = true;
|
|
||||||
FT_Error err = FT_Property_Get(qt_getFreetype(), "cff", "no-stem-darkening", &no_stem_darkening);
|
|
|
@ -22,15 +22,15 @@ index 7c62c2e2b3..c05c6c0a07 100644
|
||||||
#include <xcb/xfixes.h>
|
#include <xcb/xfixes.h>
|
||||||
#include <xcb/xcb_image.h>
|
#include <xcb/xcb_image.h>
|
||||||
|
|
||||||
@@ -384,6 +386,7 @@ void QXcbCursor::changeCursor(QCursor *cursor, QWindow *widget)
|
@@ -391,6 +393,7 @@ void QXcbCursor::changeCursor(QCursor *cursor, QWindow *window)
|
||||||
w->setCursor(c, isBitmapCursor);
|
xcb_flush(xcb_connection());
|
||||||
}
|
}
|
||||||
|
|
||||||
+#if QT_CONFIG(xcb_xlib) && QT_CONFIG(library)
|
+#if QT_CONFIG(xcb_xlib) && QT_CONFIG(library)
|
||||||
static int cursorIdForShape(int cshape)
|
static int cursorIdForShape(int cshape)
|
||||||
{
|
{
|
||||||
int cursorId = 0;
|
int cursorId = 0;
|
||||||
@@ -437,6 +440,7 @@ static int cursorIdForShape(int cshape)
|
@@ -444,6 +447,7 @@ static int cursorIdForShape(int cshape)
|
||||||
}
|
}
|
||||||
return cursorId;
|
return cursorId;
|
||||||
}
|
}
|
||||||
|
@ -38,7 +38,7 @@ index 7c62c2e2b3..c05c6c0a07 100644
|
||||||
|
|
||||||
xcb_cursor_t QXcbCursor::createNonStandardCursor(int cshape)
|
xcb_cursor_t QXcbCursor::createNonStandardCursor(int cshape)
|
||||||
{
|
{
|
||||||
@@ -558,7 +562,9 @@ static xcb_cursor_t loadCursor(void *dpy, int cshape)
|
@@ -556,7 +560,9 @@ static xcb_cursor_t loadCursor(void *dpy, int cshape)
|
||||||
xcb_cursor_t QXcbCursor::createFontCursor(int cshape)
|
xcb_cursor_t QXcbCursor::createFontCursor(int cshape)
|
||||||
{
|
{
|
||||||
xcb_connection_t *conn = xcb_connection();
|
xcb_connection_t *conn = xcb_connection();
|
||||||
|
@ -48,22 +48,23 @@ index 7c62c2e2b3..c05c6c0a07 100644
|
||||||
xcb_cursor_t cursor = XCB_NONE;
|
xcb_cursor_t cursor = XCB_NONE;
|
||||||
|
|
||||||
// Try Xcursor first
|
// Try Xcursor first
|
||||||
@@ -589,6 +595,7 @@ xcb_cursor_t QXcbCursor::createFontCursor(int cshape)
|
@@ -585,7 +591,7 @@ xcb_cursor_t QXcbCursor::createFontCursor(int cshape)
|
||||||
|
|
||||||
// Non-standard X11 cursors are created from bitmaps
|
// Non-standard X11 cursors are created from bitmaps
|
||||||
cursor = createNonStandardCursor(cshape);
|
cursor = createNonStandardCursor(cshape);
|
||||||
|
-
|
||||||
+#if QT_CONFIG(xcb_xlib) && QT_CONFIG(library)
|
+#if QT_CONFIG(xcb_xlib) && QT_CONFIG(library)
|
||||||
// Create a glpyh cursor if everything else failed
|
// Create a glpyh cursor if everything else failed
|
||||||
if (!cursor && cursorId) {
|
if (!cursor && cursorId) {
|
||||||
cursor = xcb_generate_id(conn);
|
cursor = xcb_generate_id(conn);
|
||||||
@@ -596,6 +603,7 @@ xcb_cursor_t QXcbCursor::createFontCursor(int cshape)
|
@@ -593,6 +599,7 @@ xcb_cursor_t QXcbCursor::createFontCursor(int cshape)
|
||||||
cursorId, cursorId + 1,
|
cursorId, cursorId + 1,
|
||||||
0xFFFF, 0xFFFF, 0xFFFF, 0, 0, 0);
|
0xFFFF, 0xFFFF, 0xFFFF, 0, 0, 0);
|
||||||
}
|
}
|
||||||
+#endif
|
+#endif
|
||||||
|
|
||||||
if (cursor && cshape >= 0 && cshape < Qt::LastCursor && connection()->hasXFixes()) {
|
if (cursor && cshape >= 0 && cshape < Qt::LastCursor && connection()->hasXFixes()) {
|
||||||
const char *name = cursorNames[cshape];
|
const char *name = cursorNames[cshape].front();
|
||||||
--
|
--
|
||||||
2.22.0
|
2.22.0
|
||||||
|
|
||||||
|
|
20
depends/patches/qt/no_sdk_version_check.patch
Normal file
20
depends/patches/qt/no_sdk_version_check.patch
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
commit f5eb142cd04be2bc4ca610ed3b5b7e8ce3520ee3
|
||||||
|
Author: fanquake <fanquake@gmail.com>
|
||||||
|
Date: Tue Jan 5 16:08:49 2021 +0800
|
||||||
|
|
||||||
|
Don't invoke macOS SDK version checking
|
||||||
|
|
||||||
|
This tries to use xcrun which is not available when cross-compiling.
|
||||||
|
|
||||||
|
diff --git a/qtbase/mkspecs/features/mac/default_post.prf b/qtbase/mkspecs/features/mac/default_post.prf
|
||||||
|
index 92a9112bca6..447e186eb26 100644
|
||||||
|
--- a/qtbase/mkspecs/features/mac/default_post.prf
|
||||||
|
+++ b/qtbase/mkspecs/features/mac/default_post.prf
|
||||||
|
@@ -8,7 +8,6 @@ contains(TEMPLATE, .*app) {
|
||||||
|
!macx-xcode:if(isEmpty(BUILDS)|build_pass) {
|
||||||
|
# Detect changes to the platform SDK
|
||||||
|
QMAKE_EXTRA_VARIABLES += QMAKE_MAC_SDK QMAKE_MAC_SDK_VERSION QMAKE_XCODE_DEVELOPER_PATH
|
||||||
|
- QMAKE_EXTRA_INCLUDES += $$shell_quote($$PWD/sdk.mk)
|
||||||
|
}
|
||||||
|
|
||||||
|
# Detect incompatible SDK versions
|
|
@ -1,26 +0,0 @@
|
||||||
--- old/qtbase/src/gui/configure.pri 2018-06-06 17:28:10.000000000 -0400
|
|
||||||
+++ new/qtbase/src/gui/configure.pri 2018-08-17 18:43:01.589384567 -0400
|
|
||||||
@@ -43,18 +43,11 @@
|
|
||||||
}
|
|
||||||
|
|
||||||
defineTest(qtConfTest_xkbConfigRoot) {
|
|
||||||
- qtConfTest_getPkgConfigVariable($${1}): return(true)
|
|
||||||
-
|
|
||||||
- for (dir, $$list("/usr/share/X11/xkb", "/usr/local/share/X11/xkb")) {
|
|
||||||
- exists($$dir) {
|
|
||||||
- $${1}.value = $$dir
|
|
||||||
- export($${1}.value)
|
|
||||||
- $${1}.cache += value
|
|
||||||
- export($${1}.cache)
|
|
||||||
- return(true)
|
|
||||||
- }
|
|
||||||
- }
|
|
||||||
- return(false)
|
|
||||||
+ $${1}.value = "/usr/share/X11/xkb"
|
|
||||||
+ export($${1}.value)
|
|
||||||
+ $${1}.cache += value
|
|
||||||
+ export($${1}.cache)
|
|
||||||
+ return(true)
|
|
||||||
}
|
|
||||||
|
|
||||||
defineTest(qtConfTest_qpaDefaultPlatform) {
|
|
|
@ -62,6 +62,7 @@ Q_IMPORT_PLUGIN(QXcbIntegrationPlugin);
|
||||||
Q_IMPORT_PLUGIN(QWindowsIntegrationPlugin);
|
Q_IMPORT_PLUGIN(QWindowsIntegrationPlugin);
|
||||||
#elif defined(QT_QPA_PLATFORM_COCOA)
|
#elif defined(QT_QPA_PLATFORM_COCOA)
|
||||||
Q_IMPORT_PLUGIN(QCocoaIntegrationPlugin);
|
Q_IMPORT_PLUGIN(QCocoaIntegrationPlugin);
|
||||||
|
Q_IMPORT_PLUGIN(QMacStylePlugin);
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue