commit: a36d8633a1bfcb27ec359c91b896e2b66ae7308d Author: Davide Pesavento <pesa <AT> gentoo <DOT> org> AuthorDate: Mon Nov 17 01:40:23 2014 +0000 Commit: Davide Pesavento <pesa <AT> gentoo <DOT> org> CommitDate: Mon Nov 17 01:40:23 2014 +0000 URL: http://sources.gentoo.org/gitweb/?p=proj/qt.git;a=commit;h=a36d8633
Delete unused qt4-build.eclass --- eclass/qt4-build.eclass | 797 ------------------------------------------- eclass/tests/tests-common.sh | 79 ----- eclass/tests/ut_qt4-build.sh | 244 ------------- 3 files changed, 1120 deletions(-) diff --git a/eclass/qt4-build.eclass b/eclass/qt4-build.eclass deleted file mode 100644 index 07b9aac..0000000 --- a/eclass/qt4-build.eclass +++ /dev/null @@ -1,797 +0,0 @@ -# Copyright 1999-2014 Gentoo Foundation -# Distributed under the terms of the GNU General Public License v2 -# $Header: $ - -# @ECLASS: qt4-build.eclass -# @MAINTAINER: -# Qt herd <q...@gentoo.org> -# @BLURB: Eclass for Qt4 split ebuilds. -# @DESCRIPTION: -# This eclass contains various functions that are used when building Qt4. - -case ${EAPI} in - 4|5) : ;; - *) die "qt4-build.eclass: unsupported EAPI=${EAPI:-0}" ;; -esac - -inherit eutils flag-o-matic multilib toolchain-funcs - -HOMEPAGE="https://www.qt.io/ https://qt-project.org/" -LICENSE="|| ( LGPL-2.1 GPL-3 )" -SLOT="4" - -case ${PV} in - 4.?.9999) - QT4_BUILD_TYPE="live" - EGIT_REPO_URI=( - "git://gitorious.org/qt/qt.git" - "https://git.gitorious.org/qt/qt.git" - ) - EGIT_BRANCH=${PV%.9999} - inherit git-r3 - ;; - *) - QT4_BUILD_TYPE="release" - MY_P=qt-everywhere-opensource-src-${PV/_/-} - SRC_URI="http://download.qt-project.org/archive/qt/${PV%.*}/${PV}/${MY_P}.tar.gz" - S=${WORKDIR}/${MY_P} - ;; -esac - -IUSE="aqua debug pch" -[[ ${PN} != qtxmlpatterns ]] && IUSE+=" +exceptions" - -DEPEND="virtual/pkgconfig" -if [[ ${QT4_BUILD_TYPE} == live ]]; then - DEPEND+=" dev-lang/perl" -fi - -# @FUNCTION: qt4-build_pkg_setup -# @DESCRIPTION: -# Sets up PATH and LD_LIBRARY_PATH. -qt4-build_pkg_setup() { - # Warn users of possible breakage when downgrading to a previous release. - # Downgrading revisions within the same release is safe. - if has_version ">${CATEGORY}/${P}-r9999:4"; then - ewarn - ewarn "Downgrading Qt is completely unsupported and can break your system!" - ewarn - fi - - PATH="${S}/bin${PATH:+:}${PATH}" - if [[ ${CHOST} != *-darwin* ]]; then - LD_LIBRARY_PATH="${S}/lib${LD_LIBRARY_PATH:+:}${LD_LIBRARY_PATH}" - else - DYLD_LIBRARY_PATH="${S}/lib${DYLD_LIBRARY_PATH:+:}${DYLD_LIBRARY_PATH}" - # On MacOS we *need* at least src/gui/kernel/qapplication_mac.mm for - # platform detection. Note: needs to come before any directories to - # avoid extract failure. - [[ ${CHOST} == *-apple-darwin* ]] && \ - QT4_EXTRACT_DIRECTORIES="src/gui/kernel/qapplication_mac.mm - ${QT4_EXTRACT_DIRECTORIES}" - fi -} - -# @ECLASS-VARIABLE: PATCHES -# @DEFAULT_UNSET -# @DESCRIPTION: -# Array variable containing all the patches to be applied. This variable -# is expected to be defined in the global scope of ebuilds. Make sure to -# specify the full path. This variable is used in src_prepare phase. -# -# Example: -# @CODE -# PATCHES=( -# "${FILESDIR}/mypatch.patch" -# "${FILESDIR}/patches_folder/" -# ) -# @CODE - -# @ECLASS-VARIABLE: QT4_EXTRACT_DIRECTORIES -# @DEFAULT_UNSET -# @DESCRIPTION: -# Space-separated list of directories that will be extracted -# from Qt tarball. - -# @ECLASS-VARIABLE: QT4_TARGET_DIRECTORIES -# @DEFAULT_UNSET -# @DESCRIPTION: -# Space-separated list of directories that will be configured, -# compiled, and installed. All paths must be relative to ${S}. - -# @FUNCTION: qt4-build_src_unpack -# @DESCRIPTION: -# Unpacks the sources. -qt4-build_src_unpack() { - setqtenv - - if [[ $(gcc-major-version) -lt 4 ]] || [[ $(gcc-major-version) -eq 4 && $(gcc-minor-version) -lt 4 ]]; then - ewarn - ewarn "Using a GCC version lower than 4.4 is not supported." - ewarn - fi - - if [[ ${PN} == qtwebkit ]]; then - eshopts_push -s extglob - if is-flagq '-g?(gdb)?([1-9])'; then - ewarn - ewarn "You have enabled debug info (probably have -g or -ggdb in your CFLAGS/CXXFLAGS)." - ewarn "You may experience really long compilation times and/or increased memory usage." - ewarn "If compilation fails, please try removing -g/-ggdb before reporting a bug." - ewarn "For more info check out https://bugs.gentoo.org/307861" - ewarn - fi - eshopts_pop - fi - - case ${QT4_BUILD_TYPE} in - live) - git-r3_src_unpack - ;; - release) - local tarball="${MY_P}.tar.gz" target= targets= - for target in configure LICENSE.GPL3 LICENSE.LGPL projects.pro \ - src/{qbase,qt_targets,qt_install}.pri bin config.tests \ - mkspecs qmake ${QT4_EXTRACT_DIRECTORIES} - do - targets+="${MY_P}/${target} " - done - - ebegin "Unpacking parts of ${tarball}:" ${targets//${MY_P}\/} - tar -xzf "${DISTDIR}/${tarball}" ${targets} - eend $? || die "failed to unpack" - ;; - esac -} - -# @FUNCTION: qt4-build_src_prepare -# @DESCRIPTION: -# Prepare the sources before the configure phase. Strip CFLAGS if necessary, and fix -# the build system in order to respect CFLAGS/CXXFLAGS/LDFLAGS specified in make.conf. -qt4-build_src_prepare() { - setqtenv - - if [[ ${QT4_BUILD_TYPE} == live ]]; then - QTDIR="." ./bin/syncqt || die "syncqt failed" - fi - - # avoid X11 dependency in non-gui packages - local nolibx11_pkgs="qtbearer qtcore qtdbus qtscript qtsql qttest qtxmlpatterns" - has ${PN} ${nolibx11_pkgs} && qt_nolibx11 - - if use aqua; then - # provide a proper macx-g++-64 - use x64-macos && ln -s macx-g++ mkspecs/$(qt_mkspecs_dir) - - sed -e '/^CONFIG/s:app_bundle::' \ - -e '/^CONFIG/s:plugin_no_soname:plugin_with_soname absolute_library_soname:' \ - -i mkspecs/$(qt_mkspecs_dir)/qmake.conf || die - fi - - if [[ ${CATEGORY}/${PN} != dev-qt/qtcore ]]; then - skip_qmake_build - skip_project_generation - symlink_binaries_to_buildtree - fi - - if use_if_iuse c++0x; then - append-cxxflags -std=c++0x - fi - - # Bug 261632 - if use ppc64; then - append-flags -mminimal-toc - fi - - # Bug 373061 - # qmake bus errors with -O2 or -O3 but -O1 works - if [[ ${CHOST} == *86*-apple-darwin* ]]; then - replace-flags -O[23] -O1 - fi - - # Bug 417105 - # graphite on gcc 4.7 causes miscompilations - if [[ $(gcc-version) == "4.7" ]]; then - filter-flags -fgraphite-identity - fi - - # Respect CC, CXX, {C,CXX,LD}FLAGS in .qmake.cache - sed -e "/^SYSTEM_VARIABLES=/i \ - CC='$(tc-getCC)'\n\ - CXX='$(tc-getCXX)'\n\ - CFLAGS='${CFLAGS}'\n\ - CXXFLAGS='${CXXFLAGS}'\n\ - LDFLAGS='${LDFLAGS}'\n\ - QMakeVar set QMAKE_CFLAGS_RELEASE\n\ - QMakeVar set QMAKE_CFLAGS_DEBUG\n\ - QMakeVar set QMAKE_CXXFLAGS_RELEASE\n\ - QMakeVar set QMAKE_CXXFLAGS_DEBUG\n\ - QMakeVar set QMAKE_LFLAGS_RELEASE\n\ - QMakeVar set QMAKE_LFLAGS_DEBUG\n"\ - -i configure \ - || die "sed SYSTEM_VARIABLES failed" - - # Respect CC, CXX, LINK and *FLAGS in config.tests - find config.tests/unix -name '*.test' -type f -print0 | xargs -0 \ - sed -i -e "/bin\/qmake/ s: \"\$SRCDIR/: \ - 'QMAKE_CC=$(tc-getCC)' 'QMAKE_CXX=$(tc-getCXX)' 'QMAKE_LINK=$(tc-getCXX)' \ - 'QMAKE_CFLAGS+=${CFLAGS}' 'QMAKE_CXXFLAGS+=${CXXFLAGS}' 'QMAKE_LFLAGS+=${LDFLAGS}'&:" \ - || die "sed config.tests failed" - - # Bug 172219 - sed -e 's:/X11R6/:/:' -i mkspecs/$(qt_mkspecs_dir)/qmake.conf || die - - if [[ ${CHOST} == *-darwin* ]]; then - # Set FLAGS *and* remove -arch, since our gcc-apple is multilib - # crippled (by design) :/ - local mac_gpp_conf= - if [[ -f mkspecs/common/mac-g++.conf ]]; then - # qt < 4.8 has mac-g++.conf - mac_gpp_conf="mkspecs/common/mac-g++.conf" - elif [[ -f mkspecs/common/g++-macx.conf ]]; then - # qt >= 4.8 has g++-macx.conf - mac_gpp_conf="mkspecs/common/g++-macx.conf" - else - die "no known conf file for mac found" - fi - sed \ - -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \ - -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \ - -e "s:QMAKE_LFLAGS_RELEASE.*=.*:QMAKE_LFLAGS_RELEASE=-headerpad_max_install_names ${LDFLAGS}:" \ - -e "s:-arch\s\w*::g" \ - -i ${mac_gpp_conf} \ - || die "sed ${mac_gpp_conf} failed" - - # Fix configure's -arch settings that appear in qmake/Makefile and also - # fix arch handling (automagically duplicates our -arch arg and breaks - # pch). Additionally disable Xarch support. - local mac_gcc_confs="${mac_gpp_conf}" - if [[ -f mkspecs/common/gcc-base-macx.conf ]]; then - mac_gcc_confs+=" mkspecs/common/gcc-base-macx.conf" - fi - sed \ - -e "s:-arch i386::" \ - -e "s:-arch ppc::" \ - -e "s:-arch x86_64::" \ - -e "s:-arch ppc64::" \ - -e "s:-arch \$i::" \ - -e "/if \[ ! -z \"\$NATIVE_64_ARCH\" \]; then/,/fi/ d" \ - -e "s:CFG_MAC_XARCH=yes:CFG_MAC_XARCH=no:g" \ - -e "s:-Xarch_x86_64::g" \ - -e "s:-Xarch_ppc64::g" \ - -i configure ${mac_gcc_confs} \ - || die "sed -arch/-Xarch failed" - - # On Snow Leopard don't fall back to 10.5 deployment target. - if [[ ${CHOST} == *-apple-darwin10 ]]; then - sed -e "s:QMakeVar set QMAKE_MACOSX_DEPLOYMENT_TARGET.*:QMakeVar set QMAKE_MACOSX_DEPLOYMENT_TARGET 10.6:g" \ - -e "s:-mmacosx-version-min=10.[0-9]:-mmacosx-version-min=10.6:g" \ - -i configure ${mac_gpp_conf} \ - || die "sed deployment target failed" - fi - fi - - # this one is needed for all systems with a separate -liconv, apart from - # Darwin, for which the sources already cater for -liconv - if use !elibc_glibc && [[ ${CHOST} != *-darwin* ]]; then - sed -e 's|mac:\(LIBS += -liconv\)|\1|g' \ - -i config.tests/unix/iconv/iconv.pro \ - || die "sed iconv.pro failed" - fi - - # we need some patches for Solaris - sed -i -e '/^QMAKE_LFLAGS_THREAD/a\QMAKE_LFLAGS_DYNAMIC_LIST = -Wl,--dynamic-list,' \ - mkspecs/$(qt_mkspecs_dir)/qmake.conf || die - # use GCC over SunStudio - sed -i -e '/PLATFORM=solaris-cc/s/cc/g++/' configure || die - # do not flirt with non-Prefix stuff, we're quite possessive - sed -i -e '/^QMAKE_\(LIB\|INC\)DIR\(_X11\|_OPENGL\|\)\t/s/=.*$/=/' \ - mkspecs/$(qt_mkspecs_dir)/qmake.conf || die - - # apply patches - [[ -n ${PATCHES[@]} ]] && epatch "${PATCHES[@]}" - epatch_user -} - -# @FUNCTION: qt4-build_src_configure -# @DESCRIPTION: -# Default configure phase -qt4-build_src_configure() { - setqtenv - - local conf=" - -prefix ${QTPREFIXDIR} - -bindir ${QTBINDIR} - -libdir ${QTLIBDIR} - -docdir ${QTDOCDIR} - -headerdir ${QTHEADERDIR} - -plugindir ${QTPLUGINDIR} - -importdir ${QTIMPORTDIR} - -datadir ${QTDATADIR} - -translationdir ${QTTRANSDIR} - -sysconfdir ${QTSYSCONFDIR} - -examplesdir ${QTEXAMPLESDIR} - -demosdir ${QTDEMOSDIR} - -opensource -confirm-license - -shared -fast -largefile -stl -verbose - -nomake examples -nomake demos" - - # ARCH is set on Gentoo. Qt now falls back to generic on an unsupported - # $(tc-arch). Therefore we convert it to supported values. - case "$(tc-arch)" in - amd64|x64-*) conf+=" -arch x86_64" ;; - ppc-macos) conf+=" -arch ppc" ;; - ppc|ppc64|ppc-*) conf+=" -arch powerpc" ;; - sparc|sparc-*|sparc64-*) conf+=" -arch sparc" ;; - x86-macos) conf+=" -arch x86" ;; - x86|x86-*) conf+=" -arch i386" ;; - alpha|arm|ia64|mips|s390) conf+=" -arch $(tc-arch)" ;; - hppa|sh) conf+=" -arch generic" ;; - *) die "$(tc-arch) is unsupported by this eclass. Please file a bug." ;; - esac - - conf+=" -platform $(qt_mkspecs_dir)" - - [[ $(get_libdir) != lib ]] && conf+=" -L${EPREFIX}/usr/$(get_libdir)" - - # debug/release - if use debug; then - conf+=" -debug" - else - conf+=" -release" - fi - conf+=" -no-separate-debug-info" - - # exceptions USE flag - conf+=" $(in_iuse exceptions && qt_use exceptions || echo -exceptions)" - - # disable rpath (bug 380415), except on prefix (bug 417169) - use prefix || conf+=" -no-rpath" - - # precompiled headers don't work on hardened, where the flag is masked - conf+=" $(qt_use pch)" - - # -reduce-relocations - # This flag seems to introduce major breakage to applications, - # mostly to be seen as a core dump with the message "QPixmap: Must - # construct a QApplication before a QPaintDevice" on Solaris. - # -- Daniel Vergien - [[ ${CHOST} != *-solaris* ]] && conf+=" -reduce-relocations" - - # this one is needed for all systems with a separate -liconv, apart from - # Darwin, for which the sources already cater for -liconv - if use !elibc_glibc && [[ ${CHOST} != *-darwin* ]]; then - conf+=" -liconv" - fi - - if use_if_iuse glib; then - local glibflags="$(pkg-config --cflags --libs glib-2.0 gthread-2.0)" - # avoid the -pthread argument - conf+=" ${glibflags//-pthread}" - unset glibflags - fi - - if use aqua; then - # On (snow) leopard use the new (frameworked) cocoa code. - if [[ ${CHOST##*-darwin} -ge 9 ]]; then - conf+=" -cocoa -framework" - # We need the source's headers, not the installed ones. - conf+=" -I${S}/include" - # Add hint for the framework location. - conf+=" -F${QTLIBDIR}" - - # We are crazy and build cocoa + qt3support :-) - if use qt3support; then - sed -e "/case \"\$PLATFORM,\$CFG_MAC_COCOA\" in/,/;;/ s|CFG_QT3SUPPORT=\"no\"|CFG_QT3SUPPORT=\"yes\"|" \ - -i configure || die - fi - else - conf+=" -no-framework" - fi - else - # freetype2 include dir is non-standard, thus pass it to configure - conf+=" $(pkg-config --cflags-only-I freetype2)" - fi - - conf+=" ${myconf}" - myconf= - - echo ./configure ${conf} - ./configure ${conf} || die "./configure failed" - - prepare_directories ${QT4_TARGET_DIRECTORIES} -} - -# @FUNCTION: qt4-build_src_compile -# @DESCRIPTION: -# Actual compile phase -qt4-build_src_compile() { - setqtenv - - build_directories ${QT4_TARGET_DIRECTORIES} -} - -# @FUNCTION: qt4-build_src_test -# @DESCRIPTION: -# Runs tests only in target directories. -qt4-build_src_test() { - # QtMultimedia does not have any test suite (bug #332299) - [[ ${CATEGORY}/${PN} == dev-qt/qtmultimedia ]] && return - - for dir in ${QT4_TARGET_DIRECTORIES}; do - emake -j1 check -C ${dir} - done -} - -# @FUNCTION: fix_includes -# @DESCRIPTION: -# For MacOS X we need to add some symlinks when frameworks are -# being used, to avoid complications with some more or less stupid packages. -fix_includes() { - if use aqua && [[ ${CHOST##*-darwin} -ge 9 ]]; then - local frw dest f h rdir - # Some packages tend to include <Qt/...> - dodir "${QTHEADERDIR#${EPREFIX}}"/Qt - - # Fake normal headers when frameworks are installed... eases life later - # on, make sure we use relative links though, as some ebuilds assume - # these dirs exist in src_install to add additional files - f=${QTHEADERDIR} - h=${QTLIBDIR} - while [[ -n ${f} && ${f%%/*} == ${h%%/*} ]] ; do - f=${f#*/} - h=${h#*/} - done - rdir=${h} - f="../" - while [[ ${h} == */* ]] ; do - f="${f}../" - h=${h#*/} - done - rdir="${f}${rdir}" - - for frw in "${D}${QTLIBDIR}"/*.framework; do - [[ -e "${frw}"/Headers ]] || continue - f=$(basename ${frw}) - dest="${QTHEADERDIR#${EPREFIX}}"/${f%.framework} - dosym "${rdir}"/${f}/Headers "${dest}" - - # Link normal headers as well. - for hdr in "${D}/${QTLIBDIR}/${f}"/Headers/*; do - h=$(basename ${hdr}) - dosym "../${rdir}"/${f}/Headers/${h} \ - "${QTHEADERDIR#${EPREFIX}}"/Qt/${h} - done - done - fi -} - -# @FUNCTION: qt4-build_src_install -# @DESCRIPTION: -# Perform the actual installation including some library fixes. -qt4-build_src_install() { - setqtenv - - install_directories ${QT4_TARGET_DIRECTORIES} - install_qconfigs - fix_library_files - fix_includes - - # remove .la files since we are building only shared libraries - prune_libtool_files -} - -# @FUNCTION: setqtenv -# @INTERNAL -setqtenv() { - # Set up installation directories - QTPREFIXDIR=${EPREFIX}/usr - QTBINDIR=${QTPREFIXDIR}/bin - QTLIBDIR=${QTPREFIXDIR}/$(get_libdir)/qt4 - QTPCDIR=${QTPREFIXDIR}/$(get_libdir)/pkgconfig - QTDOCDIR=${QTPREFIXDIR}/share/doc/qt-${PV} - QTHEADERDIR=${QTPREFIXDIR}/include/qt4 - QTPLUGINDIR=${QTLIBDIR}/plugins - QTIMPORTDIR=${QTLIBDIR}/imports - QTDATADIR=${QTPREFIXDIR}/share/qt4 - QTTRANSDIR=${QTDATADIR}/translations - QTSYSCONFDIR=${EPREFIX}/etc/qt4 - QTEXAMPLESDIR=${QTDATADIR}/examples - QTDEMOSDIR=${QTDATADIR}/demos - QMAKE_LIBDIR_QT=${QTLIBDIR} - - PLATFORM=$(qt_mkspecs_dir) - unset QMAKESPEC - - export XDG_CONFIG_HOME="${T}" -} - -# @FUNCTION: prepare_directories -# @USAGE: < directories > -# @INTERNAL -# @DESCRIPTION: -# Generates Makefiles for the given list of directories. -prepare_directories() { - for x in "$@"; do - pushd "${S}"/${x} >/dev/null || die - einfo "Running qmake in: ${x}" - "${S}"/bin/qmake \ - "LIBS+=-L${QTLIBDIR}" \ - "CONFIG+=nostrip" \ - || die "qmake failed" - popd >/dev/null || die - done -} - -# @FUNCTION: build_directories -# @USAGE: < directories > -# @INTERNAL -# @DESCRIPTION: -# Compiles the code in the given list of directories. -build_directories() { - for x in "$@"; do - pushd "${S}"/${x} >/dev/null || die - emake \ - AR="$(tc-getAR) cqs" \ - CC="$(tc-getCC)" \ - CXX="$(tc-getCXX)" \ - LINK="$(tc-getCXX)" \ - RANLIB=":" \ - STRIP=":" - popd >/dev/null || die - done -} - -# @FUNCTION: install_directories -# @USAGE: < directories > -# @INTERNAL -# @DESCRIPTION: -# Runs emake install in the given directories, which are separated by spaces. -install_directories() { - for x in "$@"; do - pushd "${S}"/${x} >/dev/null || die - emake INSTALL_ROOT="${D}" install - popd >/dev/null || die - done -} - -# @ECLASS-VARIABLE: QCONFIG_ADD -# @DESCRIPTION: -# List options that need to be added to QT_CONFIG in qconfig.pri -: ${QCONFIG_ADD:=} - -# @ECLASS-VARIABLE: QCONFIG_REMOVE -# @DESCRIPTION: -# List options that need to be removed from QT_CONFIG in qconfig.pri -: ${QCONFIG_REMOVE:=} - -# @ECLASS-VARIABLE: QCONFIG_DEFINE -# @DESCRIPTION: -# List variables that should be defined at the top of QtCore/qconfig.h -: ${QCONFIG_DEFINE:=} - -# @FUNCTION: install_qconfigs -# @INTERNAL -# @DESCRIPTION: -# Install gentoo-specific mkspecs configurations. -install_qconfigs() { - local x - if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} ]]; then - for x in QCONFIG_ADD QCONFIG_REMOVE; do - [[ -n ${!x} ]] && echo ${x}=${!x} >> "${T}"/${PN}-qconfig.pri - done - insinto ${QTDATADIR#${EPREFIX}}/mkspecs/gentoo - doins "${T}"/${PN}-qconfig.pri - fi - - if [[ -n ${QCONFIG_DEFINE} ]]; then - for x in ${QCONFIG_DEFINE}; do - echo "#define ${x}" >> "${T}"/gentoo-${PN}-qconfig.h - done - insinto ${QTHEADERDIR#${EPREFIX}}/Gentoo - doins "${T}"/gentoo-${PN}-qconfig.h - fi -} - -# @FUNCTION: generate_qconfigs -# @INTERNAL -# @DESCRIPTION: -# Generates gentoo-specific qconfig.{h,pri}. -generate_qconfigs() { - if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} || -n ${QCONFIG_DEFINE} || ${CATEGORY}/${PN} == dev-qt/qtcore ]]; then - local x qconfig_add qconfig_remove qconfig_new - for x in "${ROOT}${QTDATADIR}"/mkspecs/gentoo/*-qconfig.pri; do - [[ -f ${x} ]] || continue - qconfig_add+=" $(sed -n 's/^QCONFIG_ADD=//p' "${x}")" - qconfig_remove+=" $(sed -n 's/^QCONFIG_REMOVE=//p' "${x}")" - done - - # these error checks do not use die because dying in pkg_post{inst,rm} - # just makes things worse. - if [[ -e "${ROOT}${QTDATADIR}"/mkspecs/gentoo/qconfig.pri ]]; then - # start with the qconfig.pri that qtcore installed - if ! cp "${ROOT}${QTDATADIR}"/mkspecs/gentoo/qconfig.pri \ - "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri; then - eerror "cp qconfig failed." - return 1 - fi - - # generate list of QT_CONFIG entries from the existing list - # including qconfig_add and excluding qconfig_remove - for x in $(sed -n 's/^QT_CONFIG +=//p' \ - "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri) ${qconfig_add}; do - has ${x} ${qconfig_remove} || qconfig_new+=" ${x}" - done - - # replace the existing QT_CONFIG list with qconfig_new - if ! sed -i -e "s/QT_CONFIG +=.*/QT_CONFIG += ${qconfig_new}/" \ - "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri; then - eerror "Sed for QT_CONFIG failed" - return 1 - fi - - # create Gentoo/qconfig.h - if [[ ! -e ${ROOT}${QTHEADERDIR}/Gentoo ]]; then - if ! mkdir -p "${ROOT}${QTHEADERDIR}"/Gentoo; then - eerror "mkdir ${QTHEADERDIR}/Gentoo failed" - return 1 - fi - fi - : > "${ROOT}${QTHEADERDIR}"/Gentoo/gentoo-qconfig.h - for x in "${ROOT}${QTHEADERDIR}"/Gentoo/gentoo-*-qconfig.h; do - [[ -f ${x} ]] || continue - cat "${x}" >> "${ROOT}${QTHEADERDIR}"/Gentoo/gentoo-qconfig.h - done - else - rm -f "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri - rm -f "${ROOT}${QTHEADERDIR}"/Gentoo/gentoo-qconfig.h - rmdir "${ROOT}${QTDATADIR}"/mkspecs \ - "${ROOT}${QTDATADIR}" \ - "${ROOT}${QTHEADERDIR}"/Gentoo \ - "${ROOT}${QTHEADERDIR}" 2>/dev/null - fi - fi -} - -# @FUNCTION: qt4-build_pkg_postrm -# @DESCRIPTION: -# Regenerate configuration when the package is completely removed. -qt4-build_pkg_postrm() { - generate_qconfigs -} - -# @FUNCTION: qt4-build_pkg_postinst -# @DESCRIPTION: -# Regenerate configuration, plus throw a message about possible -# breakages and proposed solutions. -qt4-build_pkg_postinst() { - generate_qconfigs -} - -# @FUNCTION: skip_qmake_build -# @INTERNAL -# @DESCRIPTION: -# Patches configure to skip qmake compilation, as it's already installed by qtcore. -skip_qmake_build() { - sed -i -e "s:if true:if false:g" "${S}"/configure || die -} - -# @FUNCTION: skip_project_generation -# @INTERNAL -# @DESCRIPTION: -# Exit the script early by throwing in an exit before all of the .pro files are scanned. -skip_project_generation() { - sed -i -e "s:echo \"Finding:exit 0\n\necho \"Finding:g" "${S}"/configure || die -} - -# @FUNCTION: symlink_binaries_to_buildtree -# @INTERNAL -# @DESCRIPTION: -# Symlinks generated binaries to buildtree, so they can be used during compilation time. -symlink_binaries_to_buildtree() { - for bin in qmake moc uic rcc; do - ln -s "${QTBINDIR}"/${bin} "${S}"/bin/ || die "symlinking ${bin} to ${S}/bin failed" - done -} - -# @FUNCTION: fix_library_files -# @INTERNAL -# @DESCRIPTION: -# Fixes the paths in *.la, *.prl, *.pc, as they are wrong due to sandbox and -# moves the *.pc files into the pkgconfig directory. -fix_library_files() { - local libfile - for libfile in "${D}"/${QTLIBDIR}/{*.la,*.prl,pkgconfig/*.pc}; do - if [[ -e ${libfile} ]]; then - sed -i -e "s:${S}/lib:${QTLIBDIR}:g" ${libfile} || die "sed on ${libfile} failed" - fi - done - - # pkgconfig files refer to WORKDIR/bin as the moc and uic locations - for libfile in "${D}"/${QTLIBDIR}/pkgconfig/*.pc; do - if [[ -e ${libfile} ]]; then - sed -i -e "s:${S}/bin:${QTBINDIR}:g" ${libfile} || die "sed on ${libfile} failed" - - # Move .pc files into the pkgconfig directory - dodir ${QTPCDIR#${EPREFIX}} - mv ${libfile} "${D}"/${QTPCDIR}/ || die "moving ${libfile} to ${D}/${QTPCDIR}/ failed" - fi - done - - # Don't install an empty directory - rmdir "${D}"/${QTLIBDIR}/pkgconfig -} - -# @FUNCTION: qt_use -# @USAGE: < flag > [ feature ] [ enableval ] -# @DESCRIPTION: -# This will echo "-${enableval}-${feature}" if <flag> is enabled, or -# "-no-${feature}" if it's disabled. If [feature] is not specified, <flag> -# will be used for that. If [enableval] is not specified, it omits the -# "-${enableval}" part. -qt_use() { - use "$1" && echo "${3:+-$3}-${2:-$1}" || echo "-no-${2:-$1}" -} - -# @FUNCTION: qt_mkspecs_dir -# @RETURN: the specs-directory w/o path -# @DESCRIPTION: -# Allows us to define which mkspecs dir we want to use. -qt_mkspecs_dir() { - local spec= - - case "${CHOST}" in - *-freebsd*|*-dragonfly*) - spec=freebsd ;; - *-openbsd*) - spec=openbsd ;; - *-netbsd*) - spec=netbsd ;; - *-darwin*) - if use aqua; then - # mac with carbon/cocoa - spec=macx - else - # darwin/mac with x11 - spec=darwin - fi - ;; - *-solaris*) - spec=solaris ;; - *-linux-*|*-linux) - spec=linux ;; - *) - die "${FUNCNAME}(): Unknown CHOST '${CHOST}'" ;; - esac - - case "$(tc-getCXX)" in - *g++*) - spec+=-g++ ;; - *icpc*) - spec+=-icc ;; - *) - die "${FUNCNAME}(): Unknown compiler '$(tc-getCXX)'" ;; - esac - - # Add -64 for 64bit profiles - if use x64-freebsd || - use amd64-linux || - use x64-macos || - use x64-solaris || - use sparc64-solaris - then - spec+=-64 - fi - - echo "${spec}" -} - -# @FUNCTION: qt_nolibx11 -# @INTERNAL -# @DESCRIPTION: -# Skip X11 tests for packages that don't need X libraries installed. -qt_nolibx11() { - sed -i -e '/^if.*PLATFORM_X11.*CFG_GUI/,/^fi$/d' "${S}"/configure || die -} - -EXPORT_FUNCTIONS pkg_setup src_unpack src_prepare src_configure src_compile src_install src_test pkg_postrm pkg_postinst diff --git a/eclass/tests/tests-common.sh b/eclass/tests/tests-common.sh deleted file mode 100644 index b5c532d..0000000 --- a/eclass/tests/tests-common.sh +++ /dev/null @@ -1,79 +0,0 @@ -#!/bin/bash - -source /etc/make.globals -source /etc/init.d/functions.sh - -etest() { - ebegin "$1" - eindent - local pass=0 fail=0 res=false - $1 - - einfo "Passed: ${pass}, Failed: ${fail}" - [[ ${fail} -eq 0 ]] && res=true - if ${res}; then - let PASSING++ - eend 0 - else - let FAILING++ - eend 1 - fi - eoutdent -} - -inherit() { - for e in "$@" ; do - source ${PORTDIR}/eclass/${e}.eclass 2&>/dev/null - done -} - -emake() { - echo "emake $*" -} - -qmake() { - echo "qmake $*" -} - -find() { - echo "find $*" -} - -sed() { - echo "sed $*" -} - -die() { - return -} - -use() { - local u=$1 - local found=0 - - # if we got something like '!flag', then invert the return value - if [[ ${u:0:1} == "!" ]] ; then - u=${u:1} - found=1 - fi - - # Make sure we have this USE flag in IUSE - if [[ -n $PORTAGE_IUSE ]] ; then - [[ $u =~ $PORTAGE_IUSE ]] || \ - echo "QA Notice: USE Flag '${u}' not" \ - "in IUSE for ${CATEGORY}/${PF}" - exit - fi - - if [[ ${USE} =~ -${u} ]]; then - return $((!found)) - else - return ${found} - fi -} - -parse_version() { - PN="${1}" - PV="${2}" - P="${PN}-${PV}" -} diff --git a/eclass/tests/ut_qt4-build.sh b/eclass/tests/ut_qt4-build.sh deleted file mode 100755 index a295a9f..0000000 --- a/eclass/tests/ut_qt4-build.sh +++ /dev/null @@ -1,244 +0,0 @@ -#!/bin/bash -# -# qt4-build.eclass Unit Test -# -# Dominik Kapusta <a...@gentoo.org> - -source tests-common.sh - -test_standard_configure_options-USE_data() { - if [[ -z "$1" ]]; then - echo 4 - else - case $1 in - 1) - USE=pch - # don't match -no-pch - myconf_string="[^o]-pch" - ;; - 2) - USE=-pch - myconf_string="-no-pch" - ;; - 3) - USE=debug - myconf_string="-debug -no-separate-debug-info" - ;; - 4) - USE=-debug - myconf_string="-release -no-separate-debug-info" - ;; - *) - ;; - esac - fi -} - -test_standard_configure_options-USE() { - local data_sets=$(${FUNCNAME}_data) - local myconf_string= - parse_version "qt-gui" "4.6.0" - - for x in $(seq 1 ${data_sets}); do - ${FUNCNAME}_data ${x} - - ebegin "Testing USE=\"${USE}\"" - - inherit qt4-build - - local myconf=$(standard_configure_options) - if [[ "${myconf}" =~ ${myconf_string} ]]; then - let pass++ - eend 0 - else - let fail++ - eend 1 - fi - done -} - -test_standard_configure_options-PV_data() { - if [[ -z "$1" ]]; then - echo 6 - else - case $1 in - 1) - PV="4.4.2" - opensource=false - ;; - 2) - PV="4.5.0" - opensource=true - ;; - 3) - PV="4.5.1" - opensource=true - ;; - 4) - PV="4.5.2" - opensource=true - ;; - 5) - PV="4.5.3" - opensource=true - ;; - 6) - PV="4.6.0_beta1" - opensource=true - ;; - *) - ;; - esac - fi -} - -test_standard_configure_options-PV() { - local data_sets=$(${FUNCNAME}_data) - local opensource= - - for x in $(seq 1 ${data_sets}); do - ${FUNCNAME}_data ${x} - parse_version "qt-core" ${PV} - - ebegin "Testing PV=\"${PV}\"" - - inherit qt4-build - - local myconf=$(standard_configure_options) - [[ "${myconf}" =~ -opensource ]] - local res=$? - #test $? && res=true || res=false - if ${opensource}; then - res=$((!res)) - fi - if (( ${res} )); then - let pass++ - eend 0 - else - let fail++ - eend 1 - fi - done -} - -test_standard_configure_options-ARCH_data() { - if [[ -z "$1" ]]; then - echo 4 - else - case $1 in - 1) - CHOST="i386" - myconf_string="-arch ${CHOST}" - ;; - 2) - CHOST="x86_64" - myconf_string="-arch ${CHOST}" - ;; - 3) - CHOST="powerpc" - myconf_string="-arch ${CHOST}" - ;; - 4) - CHOST="arm" - myconf_string="-arch ${CHOST}" - ;; - *) - ;; - esac - fi -} - -test_standard_configure_options-ARCH() { - local data_sets=$(${FUNCNAME}_data) - local myconf_string= - - for x in $(seq 1 ${data_sets}); do - ${FUNCNAME}_data ${x} - parse_version "qt-core" ${PV} - - ebegin "Testing CHOST=\"${CHOST}\"" - - inherit qt4-build - - local myconf=$(standard_configure_options) - if [[ "${myconf}" =~ ${myconf_string} ]]; then - let pass++ - eend 0 - else - let fail++ - eend 1 - fi - done -} - -test_MY_P_data() { - if [[ -z "$1" ]]; then - echo 6 - else - case $1 in - 1) - PV="4.4.2" - TEST_MY_P="qt-x11-opensource-src-4.4.2" - ;; - 2) - PV="4.5.0" - TEST_MY_P="qt-x11-opensource-src-4.5.0" - ;; - 3) - PV="4.5.1" - TEST_MY_P="qt-x11-opensource-src-4.5.1" - ;; - 4) - PV="4.5.2" - TEST_MY_P="qt-x11-opensource-src-4.5.2" - ;; - 5) - PV="4.5.3" - TEST_MY_P="qt-x11-opensource-src-4.5.3" - ;; - 6) - PV="4.6.0_beta1" - TEST_MY_P="qt-everywhere-opensource-src-4.6.0-beta1" - ;; - *) - ;; - esac - fi -} - -test_MY_P() { - local data_sets=$(${FUNCNAME}_data) - local myconf_string= - - for x in $(seq 1 ${data_sets}); do - ${FUNCNAME}_data ${x} - parse_version "qt-core" ${PV} - - ebegin "Testing PV=\"${PV}\"" - - inherit qt4-build - - if [[ ${MY_P} == ${TEST_MY_P} ]]; then - let pass++ - eend 0 - else - let fail++ - eend 1 - fi - done -} - - -PASSING=0 -FAILING=0 - -ebegin "Unit testing qt4-build.eclass" -eindent -etest test_standard_configure_options-USE -etest test_standard_configure_options-PV -etest test_standard_configure_options-ARCH -etest test_MY_P -eoutdent -einfo "TOTAL: ${PASSING} passing, ${FAILING} failing" -[[ ${FAILING} -eq 0 ]] -eend $?