# Copyright 2005-2009 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 # $Header: /var/cvsroot/gentoo-x86/eclass/qt4.eclass,v 1.61 2010/01/14 21:15:22 abcd Exp $ # @ECLASS: qt4.eclass # @MAINTAINER: # Ben de Groot <yngwin@gentoo.org>, # Markos Chandras <hwoarang@gentoo.org>, # Caleb Tennis <caleb@gentoo.org>, # Przemyslaw Maciag <troll@gentoo.org>, # Davide Pesavento <davidepesa@gmail.com> # @BLURB: Eclass for Qt4 packages # @DESCRIPTION: # This eclass contains various functions that may be useful # when dealing with packages using Qt4 libraries. inherit base eutils multilib toolchain-funcs versionator export XDG_CONFIG_HOME="${T}" qt4_monolithic_to_split_flag() { case ${1} in zlib) # Qt 4.4+ is always built with zlib enabled, so this flag isn't needed ;; gif|jpeg|png) # qt-gui always installs with these enabled checkpkgs+=" x11-libs/qt-gui" ;; dbus|opengl) # Make sure the qt-${1} package has been installed already checkpkgs+=" x11-libs/qt-${1}" ;; qt3support) checkpkgs+=" x11-libs/qt-${1}" checkflags+=" x11-libs/qt-core:${1} x11-libs/qt-gui:${1} x11-libs/qt-sql:${1}" ;; ssl) # qt-core controls this flag checkflags+=" x11-libs/qt-core:${1}" ;; cups|mng|nas|nis|tiff|xinerama|input_devices_wacom) # qt-gui controls these flags checkflags+=" x11-libs/qt-gui:${1}" ;; firebird|mysql|odbc|postgres|sqlite3) # qt-sql controls these flags. sqlite2 is no longer supported so it uses sqlite instead of sqlite3. checkflags+=" x11-libs/qt-sql:${1%3}" ;; accessibility) eerror "(QA message): Use guiaccessibility and/or qt3accessibility to specify which of qt-gui and qt-qt3support are relevant for this package." # deal with this gracefully by checking the flag for what is available for y in gui qt3support; do has_version x11-libs/qt-${y} && checkflags+=" x11-libs/qt-${y}:${1}" done ;; guiaccessibility) checkflags+=" x11-libs/qt-gui:accessibility" ;; qt3accessibility) checkflags+=" x11-libs/qt-qt3support:accessibility" ;; debug|doc|examples|glib|pch|sqlite|*) # packages probably shouldn't be checking these flags so we don't handle them currently eerror "qt4.eclass currently doesn't handle the use flag ${1} in QT4_BUILT_WITH_USE_CHECK for qt-4.4. This is either an" eerror "eclass bug or an ebuild bug. Please report it at http://bugs.gentoo.org/" ((fatalerrors+=1)) ;; esac } # @FUNCTION: qt4_pkg_setup # @DESCRIPTION: # Default pkg_setup function for packages that depends on qt4. If you have to # create ebuilds own pkg_setup in your ebuild, call qt4_pkg_setup in it. # This function uses two global vars from ebuild: # - QT4_BUILT_WITH_USE_CHECK - contains use flags that need to be turned on for # =x11-libs/qt-4* # - QT4_OPTIONAL_BUILT_WITH_USE_CHECK - qt4 flags that provides some # functionality, but can alternatively be disabled in ${CATEGORY}/${PN} # (so qt4 don't have to be recompiled) # # NOTE: Using the above vars is now deprecated in favor of eapi-2 use deps # # flags to watch for for Qt4.4: # zlib png | opengl dbus qt3support | sqlite3 ssl qt4_pkg_setup() { local x y checkpkgs checkflags fatalerrors=0 requiredflags="" # lots of has_version calls can be very expensive if [[ -n ${QT4_BUILT_WITH_USE_CHECK}${QT4_OPTIONAL_BUILT_WITH_USE_CHECK} ]]; then ewarn "QA notice: The QT4_BUILT_WITH_USE functionality is deprecated and" ewarn "will be removed from future versions of qt4.eclass. Please update" ewarn "the ebuild to use eapi-2 use dependencies instead." has_version x11-libs/qt-core && local QT44=true fi for x in ${QT4_BUILT_WITH_USE_CHECK}; do if [[ -n ${QT44} ]]; then # The use flags are different in 4.4 and above, and it's split packages, so this is used to catch # the various use flag combos specified in the ebuilds to make sure we don't error out for no reason. qt4_monolithic_to_split_flag ${x} else [[ ${x} == *accessibility ]] && x=${x#gui} && x=${x#qt3} if ! built_with_use =x11-libs/qt-4* ${x}; then requiredflags="${requiredflags} ${x}" fi fi done local optionalflags="" for x in ${QT4_OPTIONAL_BUILT_WITH_USE_CHECK}; do if use ${x}; then if [[ -n ${QT44} ]]; then # The use flags are different in 4.4 and above, and it's split packages, so this is used to catch # the various use flag combos specified in the ebuilds to make sure we don't error out for no reason. qt4_monolithic_to_split_flag ${x} elif ! built_with_use =x11-libs/qt-4* ${x}; then optionalflags="${optionalflags} ${x}" fi fi done # The use flags are different in 4.4 and above, and it's split packages, so this is used to catch # the various use flag combos specified in the ebuilds to make sure we don't error out for no reason. for y in ${checkpkgs}; do if ! has_version ${y}; then eerror "You must first install the ${y} package. It should be added to the dependencies for this package (${CATEGORY}/${PN}). See bug #217161." ((fatalerrors+=1)) fi done for y in ${checkflags}; do if ! has_version ${y%:*}; then eerror "You must first install the ${y%:*} package with the ${y##*:} flag enabled." eerror "It should be added to the dependencies for this package (${CATEGORY}/${PN}). See bug #217161." ((fatalerrors+=1)) else if ! built_with_use ${y%:*} ${y##*:}; then eerror "You must first install the ${y%:*} package with the ${y##*:} flag enabled." ((fatalerrors+=1)) fi fi done local diemessage="" if [[ ${fatalerrors} -ne 0 ]]; then diemessage="${fatalerrors} fatal errors were detected. Please read the above error messages and act accordingly." fi if [[ -n ${requiredflags} ]]; then eerror eerror "(1) In order to compile ${CATEGORY}/${PN} first you need to build" eerror "=x11-libs/qt-4* with USE=\"${requiredflags}\" flag(s)" eerror diemessage="(1) recompile qt4 with \"${requiredflags}\" USE flag(s) ; " fi if [[ -n ${optionalflags} ]]; then eerror eerror "(2) You are trying to compile ${CATEGORY}/${PN} package with" eerror "USE=\"${optionalflags}\"" eerror "while qt4 is built without this particular flag(s): it will" eerror "not work." eerror eerror "Possible solutions to this problem are:" eerror "a) install package ${CATEGORY}/${PN} without \"${optionalflags}\" USE flag(s)" eerror "b) re-emerge qt4 with \"${optionalflags}\" USE flag(s)" eerror diemessage="${diemessage}(2) recompile qt4 with \"${optionalflags}\" USE flag(s) or disable them for ${PN} package\n" fi [[ -n ${diemessage} ]] && die "can't install ${CATEGORY}/${PN}: ${diemessage}" } # @ECLASS-VARIABLE: PATCHES # @DESCRIPTION: # In case you have patches to apply, specify them in the PATCHES variable. # Make sure to specify the full path. This variable is necessary for the # src_prepare phase. # example: # PATCHES=( # "${FILESDIR}/mypatch.patch" # "${FILESDIR}/mypatch2.patch" # ) # # @FUNCTION: qt4_src_prepare # @DESCRIPTION: # Default src_prepare function for packages that depend on qt4. If you have to # override src_prepare in your ebuild, you should call qt4_src_prepare in it, # otherwise autopatcher will not work! qt4_src_prepare() { debug-print-function $FUNCNAME "$@" base_src_prepare } # @FUNCTION: eqmake4 # @USAGE: [.pro file] [additional parameters to qmake] # @DESCRIPTION: # Runs qmake on the specified .pro file (defaults to ${PN}.pro if called # without arguments). Additional parameters are appended unmodified to # qmake command line. For recursive build systems, i.e. those based on # the subdirs template, you should run eqmake4 on the top-level project # file only, unless you have strong reasons to do things differently. # During the building, qmake will be automatically re-invoked with the # right arguments on every directory specified inside the top-level # project file by the SUBDIRS variable. eqmake4() { has "${EAPI:-0}" 0 1 2 && use !prefix && EPREFIX= local projectfile="${1:-${PN}.pro}" shift if [[ ! -f ${projectfile} ]]; then echo eerror "Project file '${projectfile#${WORKDIR}/}' does not exists!" eerror "eqmake4 cannot handle non-existing project files." eerror eerror "This shouldn't happen - please send a bug report to http://bugs.gentoo.org/" echo die "Project file not found in ${CATEGORY}/${PN} sources." fi ebegin "Running qmake on ${projectfile}" # make sure CONFIG variable is correctly set for both release and debug builds local CONFIG_ADD="release" local CONFIG_REMOVE="debug" if has debug ${IUSE} && use debug; then CONFIG_ADD="debug" CONFIG_REMOVE="release" fi local awkscript='BEGIN { printf "### eqmake4 was here ###\n" > file; fixed=0; } /^[[:blank:]]*CONFIG[[:blank:]]*[\+\*]?=/ { for (i=1; i <= NF; i++) { if ($i ~ rem || $i ~ /debug_and_release/) { $i=add; fixed=1; } } } /^[[:blank:]]*CONFIG[[:blank:]]*-=/ { for (i=1; i <= NF; i++) { if ($i ~ add) { $i=rem; fixed=1; } } } { print >> file; } END { printf "\nCONFIG -= debug_and_release %s\n", rem >> file; printf "CONFIG += %s\n", add >> file; print fixed; }' local filepath= while read filepath; do local file="${filepath#./}" grep -q '^### eqmake4 was here ###$' "${file}" && continue local retval=$({ rm -f "${file}" || echo "FAILED" awk -v file="${file}" -- "${awkscript}" add=${CONFIG_ADD} rem=${CONFIG_REMOVE} || echo "FAILED" } < "${file}") if [[ ${retval} == 1 ]]; then einfo " Fixed CONFIG in ${file}" elif [[ ${retval} != 0 ]]; then eerror " An error occurred while processing ${file}" die "eqmake4 failed to process '${file}'." fi done < <(find "$(dirname "${projectfile}")" -type f -name "*.pr[io]" 2>/dev/null) "${EPREFIX}"/usr/bin/qmake -makefile -nocache \ QTDIR="${EPREFIX}"/usr/$(get_libdir) \ QMAKE="${EPREFIX}"/usr/bin/qmake \ QMAKE_CC=$(tc-getCC) \ QMAKE_CXX=$(tc-getCXX) \ QMAKE_LINK=$(tc-getCXX) \ QMAKE_CFLAGS_RELEASE="${CFLAGS}" \ QMAKE_CFLAGS_DEBUG="${CFLAGS}" \ QMAKE_CXXFLAGS_RELEASE="${CXXFLAGS}" \ QMAKE_CXXFLAGS_DEBUG="${CXXFLAGS}" \ QMAKE_LFLAGS_RELEASE="${LDFLAGS}" \ QMAKE_LFLAGS_DEBUG="${LDFLAGS}" \ QMAKE_STRIP= \ "${projectfile}" "${@}" eend $? # was qmake successful? if [[ $? -ne 0 ]]; then echo eerror "Running qmake on '${projectfile#${WORKDIR}/}' has failed!" eerror "This shouldn't happen - please send a bug report to http://bugs.gentoo.org/" echo die "qmake failed on '${projectfile}'." fi return 0 } case ${EAPI:-0} in 2|3) EXPORT_FUNCTIONS pkg_setup src_prepare ;; 0|1) EXPORT_FUNCTIONS pkg_setup ;; esac