diff options
author | Martchus | 2016-08-19 22:10:25 +0200 |
---|---|---|
committer | Martchus | 2016-08-19 22:10:25 +0200 |
commit | 8941cbd2337ef7fe5eca54195f1cac36c2a9a143 (patch) | |
tree | 0036b66acb8bf0f0697b5d5e5a3729b95dc6c5ae | |
parent | e45f5022350e57eccd87f7b19de63f47c8ec80de (diff) | |
download | aur-8941cbd2337ef7fe5eca54195f1cac36c2a9a143.tar.gz |
Add static version of further Qt modules
-rw-r--r-- | .SRCINFO | 13 | ||||
-rwxr-xr-x | PKGBUILD | 87 | ||||
-rw-r--r-- | qt5-declarative-gcc6.patch | 12 |
3 files changed, 81 insertions, 31 deletions
@@ -1,25 +1,32 @@ # Generated by mksrcinfo v8 -# Wed Jun 22 18:35:58 UTC 2016 +# Fri Aug 19 20:10:09 UTC 2016 pkgbase = mingw-w64-qt5-declarative pkgdesc = Classes for QML and JavaScript languages (mingw-w64) pkgver = 5.7.0 - pkgrel = 1 + pkgrel = 2 url = https://www.qt.io/ arch = i686 arch = x86_64 groups = mingw-w64-qt groups = mingw-w64-qt5 - license = custom, FDL, GPL3, LGPL + license = GPL3 + license = LGPL3 + license = FDL + license = custom makedepends = mingw-w64-gcc makedepends = python + makedepends = mingw-w64-qt5-base-static depends = mingw-w64-qt5-base + optdepends = mingw-w64-qt5-base-static: use of static libraries options = !strip options = !buildflags options = staticlibs source = https://download.qt.io/official_releases/qt/5.7/5.7.0/submodules/qtdeclarative-opensource-src-5.7.0.tar.xz source = qt5-build-qmldevtools-as-shared-library.patch + source = qt5-declarative-gcc6.patch md5sums = 0d9e461aa54dba4793253fa2eb501f9b md5sums = 8f90ec8c2379b85de0b04847865b230c + md5sums = fb2a2a118b356a0a4635111f2e0b0ee6 pkgname = mingw-w64-qt5-declarative @@ -5,62 +5,93 @@ # All my PKGBUILDs are managed at https://github.com/Martchus/PKGBUILDs where # you also find the URL of a binary repository. +# Includes dynamic and static versions; if only one version is requried, just +# set $NO_STATIC_LIBS or $NO_SHARED_LIBS. + _qt_module=qtdeclarative pkgname=mingw-w64-qt5-declarative pkgver=5.7.0 -pkgrel=1 +pkgrel=2 arch=('i686' 'x86_64') pkgdesc="Classes for QML and JavaScript languages (mingw-w64)" -depends=(mingw-w64-qt5-base) -makedepends=(mingw-w64-gcc python) +depends=('mingw-w64-qt5-base') +makedepends=('mingw-w64-gcc' 'python') options=(!strip !buildflags staticlibs) groups=(mingw-w64-qt mingw-w64-qt5) -license=("custom, FDL, GPL3, LGPL") +license=('GPL3' 'LGPL3' 'FDL' 'custom') url="https://www.qt.io/" _pkgfqn="${_qt_module}-opensource-src-${pkgver}" source=("https://download.qt.io/official_releases/qt/${pkgver:0:3}/${pkgver}/submodules/${_pkgfqn}.tar.xz" - "qt5-build-qmldevtools-as-shared-library.patch") + "qt5-build-qmldevtools-as-shared-library.patch" + "qt5-declarative-gcc6.patch") md5sums=('0d9e461aa54dba4793253fa2eb501f9b' - '8f90ec8c2379b85de0b04847865b230c') + '8f90ec8c2379b85de0b04847865b230c' + 'fb2a2a118b356a0a4635111f2e0b0ee6') -_architectures="i686-w64-mingw32 x86_64-w64-mingw32" +_architectures='i686-w64-mingw32 x86_64-w64-mingw32' +[[ $NO_STATIC_LIBS ]] || \ + makedepends+=('mingw-w64-qt5-base-static') \ + optdepends+=('mingw-w64-qt5-base-static: use of static libraries') \ + _configurations+=('CONFIG+=static') +[[ $NO_SHARED_LIBS ]] || \ + _configurations+=('CONFIG+=shared') prepare() { cd "${srcdir}/${_pkgfqn}" + + # Build native/non-cross library Qt5QmlDevTools as shared library patch -p1 -i "${srcdir}"/qt5-build-qmldevtools-as-shared-library.patch + + # Fix i686 segfaults with GCC 6 https://bugreports.qt.io/browse/QTBUG-52057 (Fedora patch) + patch -p1 -i "${srcdir}"/qt5-declarative-gcc6.patch } build() { cd "${srcdir}/${_pkgfqn}" for _arch in ${_architectures}; do - mkdir -p build-${_arch} && pushd build-${_arch} - ${_arch}-qmake-qt5 ../${_qt_module}.pro + for _config in "${_configurations[@]}"; do + msg2 "Building ${_config##*=} version for ${_arch}" + mkdir -p build-${_arch}-${_config##*=} && pushd build-${_arch}-${_config##*=} + ${_arch}-qmake-qt5 ../${_qt_module}.pro ${_config} - # search paths for host standard library (/usr/lib) and for Qt5Bootstrap (/usr/$_arch/lib) are not set correctly by qmake - # hence we need insert those paths manually - make qmake_all - find ./src/qmldevtools -type f -iname 'Makefile' -exec sed -i "s|-lQt5Bootstrap|-L/usr/lib -L/usr/$_arch/lib -lQt5Bootstrap|g" {} \; - find . -type f -iname 'Makefile' -exec sed -i "s|-L$PWD/lib -lQt5Bootstrap|-L/usr/lib -L$PWD/lib -L/usr/$_arch/lib -lQt5Bootstrap|g" {} \; - find . -type f -iname 'Makefile' -exec sed -i "s|-L$PWD/lib -lQt5QmlDevTools -lQt5Bootstrap|-L/usr/lib -L$PWD/lib -L/usr/$_arch/lib -lQt5QmlDevTools -lQt5Bootstrap|g" {} \; + # Search paths for host standard library (/usr/lib) and for Qt5Bootstrap (/usr/$_arch/lib) are not set correctly by qmake + # hence we need insert those paths manually + make qmake_all + find ./src/qmldevtools -type f -iname 'Makefile' -exec sed -i "s|-L/usr/$_arch/lib -lQt5Bootstrap|-L/usr/lib -L/usr/$_arch/lib -lQt5Bootstrap|g" {} \; + find . -type f -iname 'Makefile' -exec sed -i "s|-L$PWD/lib -L/usr/$_arch/lib -lQt5Bootstrap|-L/usr/lib -L$PWD/lib -L/usr/$_arch/lib -lQt5Bootstrap|g" {} \; + find . -type f -iname 'Makefile' -exec sed -i "s|-L$PWD/lib -lQt5QmlDevTools|-L/usr/lib -L$PWD/lib -L/usr/$_arch/lib -lQt5QmlDevTools|g" {} \; - make - popd + make + popd + done done } package() { cd "${srcdir}/${_pkgfqn}" for _arch in ${_architectures}; do - pushd build-${_arch} - make INSTALL_ROOT="$pkgdir" install - # The .dll's are installed in both bindir and libdir - # One copy of the .dll's is sufficient - rm -f "${pkgdir}/usr/${_arch}/lib/"*.dll - find "${pkgdir}/usr/${_arch}" -name "*.exe" -o -name "*.bat" -o -name "*.def" -o -name "*.exp" -o -name '*.prl' | xargs -rtl1 rm - find "${pkgdir}/usr/${_arch}" -name "*.dll" -exec ${_arch}-strip --strip-unneeded {} \; - find "${pkgdir}/usr/${_arch}" -name "*.a" -o -name "*.dll" | xargs -rtl1 ${_arch}-strip -g - strip --strip-all "${pkgdir}/usr/${_arch}/lib/qt/bin/"* - strip --strip-unneeded "${pkgdir}/usr/${_arch}/lib/"*.so.$pkgver - popd + for _config in "${_configurations[@]}"; do + pushd build-${_arch}-${_config##*=} + make INSTALL_ROOT="$pkgdir" install + find "${pkgdir}/usr/${_arch}/lib" -maxdepth 1 -name "*.dll" -exec rm {} \; + [ "$NO_STATIC_EXECUTABLES" -a "${_config##*=}" = static -o "$NO_EXECUTABLES" ] && \ + find "${pkgdir}/usr/${_arch}" -name "*.exe" -exec rm {} \; || \ + find "${pkgdir}/usr/${_arch}" -name "*.exe" -exec ${_arch}-strip --strip-all {} \; + find "${pkgdir}/usr/${_arch}" -name "*.dll" -exec ${_arch}-strip --strip-unneeded {} \; + find "${pkgdir}/usr/${_arch}" -name "*.a" -exec ${_arch}-strip -g {} \; + [[ -d "${pkgdir}/usr/${_arch}/lib/qt/bin/" ]] && \ + find "${pkgdir}/usr/${_arch}/lib/qt/bin/" -exec strip --strip-all {} \; + find "${pkgdir}/usr/${_arch}/lib/" -iname "*.so.$pkgver" -exec strip --strip-unneeded {} \; + popd + done + done + + # Make sure the executables don't conflict with their mingw-qt4 counterpart + # Actually only qmlplugindump.exe conflicts, but for consistency all executables + # will be suffixed. + for _arch in ${_architectures}; do + for exe_file in "${pkgdir}/usr/${_arch}/bin/"*.exe; do + [[ -f $exe_file ]] && mv "${exe_file}" "${exe_file%.exe}-qt5.exe" + done done } diff --git a/qt5-declarative-gcc6.patch b/qt5-declarative-gcc6.patch new file mode 100644 index 000000000000..eaf677ea552c --- /dev/null +++ b/qt5-declarative-gcc6.patch @@ -0,0 +1,12 @@ +diff -up qtdeclarative-opensource-src-5.6.0/src/qml/qml.pro.1135 qtdeclarative-opensource-src-5.6.0/src/qml/qml.pro +--- qtdeclarative-opensource-src-5.6.0/src/qml/qml.pro.1135 2016-06-02 08:43:24.509068141 -0500 ++++ qtdeclarative-opensource-src-5.6.0/src/qml/qml.pro 2016-06-02 10:25:28.813766581 -0500 +@@ -21,7 +21,7 @@ exists("qqml_enable_gcov") { + + greaterThan(QT_GCC_MAJOR_VERSION, 5) { + # Our code is bad. Temporary workaround. +- QMAKE_CXXFLAGS += -fno-delete-null-pointer-checks ++ QMAKE_CXXFLAGS += -fno-delete-null-pointer-checks -fno-lifetime-dse + } + + QMAKE_DOCS = $$PWD/doc/qtqml.qdocconf |