From mboxrd@z Thu Jan  1 00:00:00 1970
Received: from pigeon.gentoo.org ([208.92.234.80] helo=lists.gentoo.org)
	by finch.gentoo.org with esmtp (Exim 4.60)
	(envelope-from <gentoo-commits+bounces-443607-garchives=archives.gentoo.org@lists.gentoo.org>)
	id 1SDddM-0000iw-8J
	for garchives@archives.gentoo.org; Fri, 30 Mar 2012 15:21:05 +0000
Received: from pigeon.gentoo.org (localhost [127.0.0.1])
	by pigeon.gentoo.org (Postfix) with SMTP id 81E3DE0AD6;
	Fri, 30 Mar 2012 15:20:48 +0000 (UTC)
Received: from smtp.gentoo.org (smtp.gentoo.org [140.211.166.183])
	by pigeon.gentoo.org (Postfix) with ESMTP id 2E721E0AD6
	for <gentoo-commits@lists.gentoo.org>; Fri, 30 Mar 2012 15:20:47 +0000 (UTC)
Received: from hornbill.gentoo.org (hornbill.gentoo.org [94.100.119.163])
	(using TLSv1 with cipher AECDH-AES256-SHA (256/256 bits))
	(No client certificate requested)
	by smtp.gentoo.org (Postfix) with ESMTPS id 4734D64401
	for <gentoo-commits@lists.gentoo.org>; Fri, 30 Mar 2012 15:20:47 +0000 (UTC)
Received: from localhost.localdomain (localhost [127.0.0.1])
	by hornbill.gentoo.org (Postfix) with ESMTP id ADF22E5402
	for <gentoo-commits@lists.gentoo.org>; Fri, 30 Mar 2012 15:20:44 +0000 (UTC)
From: "Davide Pesavento" <pesa@gentoo.org>
To: gentoo-commits@lists.gentoo.org
Content-type: text/plain; charset=UTF-8
Reply-To: gentoo-dev@lists.gentoo.org, "Davide Pesavento" <pesa@gentoo.org>
Message-ID: <1333120655.ad0d41c7708c73f94d49c58c873baa79d062450e.pesa@gentoo>
Subject: [gentoo-commits] proj/qt:master commit in: eclass/
X-VCS-Repository: proj/qt
X-VCS-Files: eclass/qt4-build.eclass
X-VCS-Directories: eclass/
X-VCS-Committer: pesa
X-VCS-Committer-Name: Davide Pesavento
X-VCS-Revision: ad0d41c7708c73f94d49c58c873baa79d062450e
X-VCS-Branch: master
Date: Fri, 30 Mar 2012 15:20:44 +0000 (UTC)
Precedence: bulk
List-Post: <mailto:gentoo-commits@lists.gentoo.org>
List-Help: <mailto:gentoo-commits+help@lists.gentoo.org>
List-Unsubscribe: <mailto:gentoo-commits+unsubscribe@lists.gentoo.org>
List-Subscribe: <mailto:gentoo-commits+subscribe@lists.gentoo.org>
List-Id: Gentoo Linux mail <gentoo-commits.gentoo.org>
X-BeenThere: gentoo-commits@lists.gentoo.org
Content-Transfer-Encoding: quoted-printable
X-Archives-Salt: 836792c6-3666-4e20-92dd-9b3e4ddc4191
X-Archives-Hash: 3e45fbb0dc1e98c62775c559819ee788

commit:     ad0d41c7708c73f94d49c58c873baa79d062450e
Author:     Davide Pesavento <davidepesa <AT> gmail <DOT> com>
AuthorDate: Fri Mar 30 15:17:35 2012 +0000
Commit:     Davide Pesavento <pesa <AT> gentoo <DOT> org>
CommitDate: Fri Mar 30 15:17:35 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=3Dproj/qt.git;a=3Dco=
mmit;h=3Dad0d41c7

Merged qt4-build and qt4-build-edge eclasses.

---
 eclass/qt4-build.eclass |  872 +++++++++++++++++++++++++++++++++++++++++=
++++++
 1 files changed, 872 insertions(+), 0 deletions(-)

diff --git a/eclass/qt4-build.eclass b/eclass/qt4-build.eclass
new file mode 100644
index 0000000..e3c60cf
--- /dev/null
+++ b/eclass/qt4-build.eclass
@@ -0,0 +1,872 @@
+# Copyright 1999-2012 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/eclass/qt4-build.eclass,v 1.123 2012/=
03/08 14:24:40 pesa Exp $
+
+# @ECLASS: qt4-build.eclass
+# @MAINTAINER:
+# Qt herd <qt@gentoo.org>
+# @BLURB: Eclass for Qt4 split ebuilds.
+# @DESCRIPTION:
+# This eclass contains various functions that are used when building Qt4=
.
+
+case ${EAPI} in
+	2|3|4)	: ;;
+	*)	die "qt4-build.eclass requires EAPI 2, 3 or 4." ;;
+esac
+
+inherit base eutils flag-o-matic multilib toolchain-funcs versionator
+
+if [[ ${PV} =3D=3D *9999* ]]; then
+	QT4_BUILD_TYPE=3D"live"
+	inherit git-2
+else
+	QT4_BUILD_TYPE=3D"release"
+fi
+
+HOMEPAGE=3D"http://qt-project.org/ http://qt.nokia.com/"
+LICENSE=3D"|| ( LGPL-2.1 GPL-3 )"
+
+MY_PV=3D${PV/_/-}
+MY_P=3Dqt-everywhere-opensource-src-${MY_PV}
+
+case ${QT4_BUILD_TYPE} in
+	live)
+		EGIT_REPO_URI=3D"git://gitorious.org/qt/qt.git
+			https://git.gitorious.org/qt/qt.git"
+		EGIT_BRANCH=3D"${PV%.9999}"
+		;;
+	release)
+		SRC_URI=3D"http://get.qt.nokia.com/qt/source/${MY_P}.tar.gz"
+		;;
+esac
+
+IUSE=3D"aqua debug pch"
+if [[ ${CATEGORY}/${PN} !=3D x11-libs/qt-xmlpatterns ]]; then
+	IUSE+=3D" +exceptions"
+fi
+if version_is_at_least 4.8; then
+	IUSE+=3D" c++0x qpa"
+fi
+
+DEPEND=3D"dev-util/pkgconfig"
+if [[ ${QT4_BUILD_TYPE} =3D=3D live ]]; then
+	DEPEND+=3D" dev-lang/perl"
+fi
+
+RDEPEND=3D"
+	!<x11-libs/qt-assistant-${PV}
+	!>x11-libs/qt-assistant-${PV}-r9999
+	!<x11-libs/qt-core-${PV}
+	!>x11-libs/qt-core-${PV}-r9999
+	!<x11-libs/qt-dbus-${PV}
+	!>x11-libs/qt-dbus-${PV}-r9999
+	!<x11-libs/qt-declarative-${PV}
+	!>x11-libs/qt-declarative-${PV}-r9999
+	!<x11-libs/qt-demo-${PV}
+	!>x11-libs/qt-demo-${PV}-r9999
+	!<x11-libs/qt-gui-${PV}
+	!>x11-libs/qt-gui-${PV}-r9999
+	!<x11-libs/qt-multimedia-${PV}
+	!>x11-libs/qt-multimedia-${PV}-r9999
+	!<x11-libs/qt-opengl-${PV}
+	!>x11-libs/qt-opengl-${PV}-r9999
+	!<x11-libs/qt-openvg-${PV}
+	!>x11-libs/qt-openvg-${PV}-r9999
+	!<x11-libs/qt-phonon-${PV}
+	!>x11-libs/qt-phonon-${PV}-r9999
+	!<x11-libs/qt-qt3support-${PV}
+	!>x11-libs/qt-qt3support-${PV}-r9999
+	!<x11-libs/qt-script-${PV}
+	!>x11-libs/qt-script-${PV}-r9999
+	!<x11-libs/qt-sql-${PV}
+	!>x11-libs/qt-sql-${PV}-r9999
+	!<x11-libs/qt-svg-${PV}
+	!>x11-libs/qt-svg-${PV}-r9999
+	!<x11-libs/qt-test-${PV}
+	!>x11-libs/qt-test-${PV}-r9999
+	!<x11-libs/qt-webkit-${PV}
+	!>x11-libs/qt-webkit-${PV}-r9999
+	!<x11-libs/qt-xmlpatterns-${PV}
+	!>x11-libs/qt-xmlpatterns-${PV}-r9999
+"
+
+S=3D${WORKDIR}/${MY_P}
+
+# @FUNCTION: qt4-build_pkg_setup
+# @DESCRIPTION:
+# Sets up PATH and LD_LIBRARY_PATH.
+qt4-build_pkg_setup() {
+	[[ ${EAPI} =3D=3D 2 ]] && use !prefix && EPREFIX=3D
+
+	# Protect users by not allowing downgrades between releases
+	# Downgrading revisions within the same release should be allowed
+	if has_version '>'${CATEGORY}/${P}-r9999; then
+		if [[ -z ${I_KNOW_WHAT_I_AM_DOING} ]]; then
+			eerror
+			eerror "Sanity check to keep you from breaking your system:"
+			eerror "  Downgrading Qt is completely unsupported and will break you=
r system!"
+			eerror
+			die "aborting to save your system"
+		else
+			ewarn "Downgrading Qt is completely unsupported and will break your s=
ystem!"
+		fi
+	fi
+
+	if [[ ${PN} =3D=3D qt-webkit ]]; then
+		eshopts_push -s extglob
+		if is-flagq '-g?(gdb)?([1-9])'; then
+			echo
+			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 increa=
sed memory usage."
+			ewarn "If compilation fails, please try removing -g/-ggdb before repo=
rting a bug."
+			ewarn "For more info check out bug #307861"
+			echo
+		fi
+		eshopts_pop
+	fi
+
+	PATH=3D"${S}/bin${PATH:+:}${PATH}"
+	if [[ ${CHOST} !=3D *-darwin* ]]; then
+		LD_LIBRARY_PATH=3D"${S}/lib${LD_LIBRARY_PATH:+:}${LD_LIBRARY_PATH}"
+	else
+		DYLD_LIBRARY_PATH=3D"${S}/lib${DYLD_LIBRARY_PATH:+:}${DYLD_LIBRARY_PAT=
H}"
+		# 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} =3D=3D *-apple-darwin* ]] && \
+			QT4_EXTRACT_DIRECTORIES=3D"src/gui/kernel/qapplication_mac.mm
+				${QT4_EXTRACT_DIRECTORIES}"
+	fi
+
+	if ! version_is_at_least 4.1 $(gcc-version); then
+		ewarn "Using a GCC version lower than 4.1 is not supported."
+	fi
+}
+
+# @ECLASS-VARIABLE: QT4_TARGET_DIRECTORIES
+# @DESCRIPTION:
+# Arguments for build_target_directories. Takes the directories in which=
 the
+# code should be compiled. This is a space-separated list.
+
+# @ECLASS-VARIABLE: QT4_EXTRACT_DIRECTORIES
+# @DESCRIPTION:
+# Space-separated list including the directories that will be extracted =
from
+# Qt tarball.
+
+# @FUNCTION: qt4-build_src_unpack
+# @DESCRIPTION:
+# Unpacks the sources.
+qt4-build_src_unpack() {
+	setqtenv
+
+	case ${QT4_BUILD_TYPE} in
+		live)
+			git-2_src_unpack
+			;;
+		release)
+			local tarball=3D"${MY_P}.tar.gz" target=3D targets=3D
+			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+=3D"${MY_P}/${target} "
+			done
+
+			ebegin "Unpacking parts of ${tarball}:" ${targets//${MY_P}\/}
+			tar -xzf "${DISTDIR}/${tarball}" ${targets}
+			eend $? || die "failed to unpack"
+			;;
+	esac
+}
+
+# @ECLASS-VARIABLE: PATCHES
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# PATCHES array variable containing all various patches to be applied.
+# This variable is expected to be defined in global scope of ebuild.
+# Make sure to specify the full path. This variable is utilised in
+# src_unpack/src_prepare phase, based on EAPI.
+#
+# @CODE
+#   PATCHES=3D( "${FILESDIR}/mypatch.patch"
+#             "${FILESDIR}/patches_folder/" )
+# @CODE
+
+# @FUNCTION: qt4-build_src_prepare
+# @DESCRIPTION:
+# Prepare the sources before the configure phase. Strip CFLAGS if necess=
ary, and fix
+# the build system in order to respect CFLAGS/CXXFLAGS/LDFLAGS specified=
 in /etc/make.conf.
+qt4-build_src_prepare() {
+	setqtenv
+
+	if [[ ${QT4_BUILD_TYPE} =3D=3D live ]]; then
+		QTDIR=3D"." ./bin/syncqt || die "syncqt failed"
+	fi
+
+	if version_is_at_least 4.7; then
+		# fix libX11 dependency on non X packages
+		local nolibx11_pkgs=3D"qt-core qt-dbus qt-script qt-sql qt-test qt-xml=
patterns"
+		has ${PN} ${nolibx11_pkgs} && qt_nolibx11
+
+		qt_assistant_cleanup
+	fi
+
+	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_s=
oname:' \
+			-i mkspecs/$(qt_mkspecs_dir)/qmake.conf || die
+	fi
+
+	if [[ ${PN} !=3D qt-core ]]; then
+		skip_qmake_build
+		skip_project_generation
+		symlink_binaries_to_buildtree
+	fi
+
+	if [[ ${CHOST} =3D=3D *86*-apple-darwin* ]]; then
+		# qmake bus errors with -O2 but -O3 works
+		replace-flags -O2 -O3
+	fi
+
+	# Bug 178652
+	if [[ $(gcc-major-version) =3D=3D 3 ]] && use amd64; then
+		ewarn "Appending -fno-gcse to CFLAGS/CXXFLAGS"
+		append-flags -fno-gcse
+	fi
+
+	if use_if_iuse c++0x; then
+		echo
+		ewarn "You are about to build Qt4 using the C++11 standard. Even thoug=
h"
+		ewarn "this is an official standard, some of the reverse dependencies"
+		ewarn "may fail to compile or link againt the Qt4 libraries. Before"
+		ewarn "reporting a bug, make sure your bug is reproducible with c++0x"
+		ewarn "disabled."
+		echo
+		append-flags -std=3Dc++0x
+	fi
+
+	# Unsupported old gcc versions - hardened needs this :(
+	if [[ $(gcc-major-version) -lt 4 ]]; then
+		ewarn "Appending -fno-stack-protector to CXXFLAGS"
+		append-cxxflags -fno-stack-protector
+		# Bug 253127
+		sed -e "/^QMAKE_CFLAGS\t/ s:$: -fno-stack-protector-all:" \
+			-i mkspecs/common/g++.conf || die
+	fi
+
+	# Bug 261632
+	if use ppc64; then
+		ewarn "Appending -mminimal-toc to CFLAGS/CXXFLAGS"
+		append-flags -mminimal-toc
+	fi
+
+	# Respect CC, CXX, {C,CXX,LD}FLAGS in .qmake.cache
+	sed -e "/^SYSTEM_VARIABLES=3D/i \
+		CC=3D'$(tc-getCC)'\n\
+		CXX=3D'$(tc-getCXX)'\n\
+		CFLAGS=3D'${CFLAGS}'\n\
+		CXXFLAGS=3D'${CXXFLAGS}'\n\
+		LDFLAGS=3D'${LDFLAGS}'\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: \"QT_BUILD_TREE=3D: \
+			'QMAKE_CC=3D$(tc-getCC)'    'QMAKE_CXX=3D$(tc-getCXX)'      'QMAKE_LI=
NK=3D$(tc-getCXX)' \
+			'QMAKE_CFLAGS+=3D${CFLAGS}' 'QMAKE_CXXFLAGS+=3D${CXXFLAGS}' 'QMAKE_LF=
LAGS+=3D${LDFLAGS}'&:" \
+		|| die "sed config.tests failed"
+
+	# Strip predefined CFLAGS from mkspecs (bug 312689)
+	sed -i -e '/^QMAKE_CFLAGS_RELEASE/s:+=3D.*:+=3D:' mkspecs/common/g++.co=
nf || die
+
+	# Bug 172219
+	sed -e 's:/X11R6/:/:' -i mkspecs/$(qt_mkspecs_dir)/qmake.conf || die
+
+	if [[ ${CHOST} =3D=3D *-darwin* ]]; then
+		# Set FLAGS *and* remove -arch, since our gcc-apple is multilib
+		# crippled (by design) :/
+		sed \
+			-e "s:QMAKE_CFLAGS_RELEASE.*=3D.*:QMAKE_CFLAGS_RELEASE=3D${CFLAGS}:" =
\
+			-e "s:QMAKE_CXXFLAGS_RELEASE.*=3D.*:QMAKE_CXXFLAGS_RELEASE=3D${CXXFLA=
GS}:" \
+			-e "s:QMAKE_LFLAGS_RELEASE.*=3D.*:QMAKE_LFLAGS_RELEASE=3D-headerpad_m=
ax_install_names ${LDFLAGS}:" \
+			-e "s:-arch\s\w*::g" \
+			-i mkspecs/common/mac-g++.conf \
+			|| die "sed mkspecs/common/mac-g++.conf failed"
+
+		# Fix configure's -arch settings that appear in qmake/Makefile and als=
o
+		# fix arch handling (automagically duplicates our -arch arg and breaks
+		# pch). Additionally disable Xarch support.
+		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=3Dyes:CFG_MAC_XARCH=3Dno:g" \
+			-e "s:-Xarch_x86_64::g" \
+			-e "s:-Xarch_ppc64::g" \
+			-i configure mkspecs/common/mac-g++.conf \
+			|| die "sed -arch/-Xarch failed"
+
+		# On Snow Leopard don't fall back to 10.5 deployment target.
+		if [[ ${CHOST} =3D=3D *-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=3D10.[0-9]:-mmacosx-version-min=3D10.6:g"=
 \
+				-i configure mkspecs/common/mac-g++.conf \
+				|| die "sed deployment target failed"
+		fi
+	fi
+
+	# this one is needed for all systems with a separate -liconv, apart fro=
m
+	# Darwin, for which the sources already cater for -liconv
+	if use !elibc_glibc && [[ ${CHOST} !=3D *-darwin* ]]; then
+		sed -e 's|mac:\(LIBS +=3D -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 =3D -Wl,--=
dynamic-list,' \
+		mkspecs/$(qt_mkspecs_dir)/qmake.conf || die
+	# use GCC over SunStudio
+	sed -i -e '/PLATFORM=3Dsolaris-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/=3D.*$/=3D/' =
\
+		mkspecs/$(qt_mkspecs_dir)/qmake.conf || die
+
+	base_src_prepare
+}
+
+# @FUNCTION: qt4-build_src_configure
+# @DESCRIPTION:
+# Default configure phase
+qt4-build_src_configure() {
+	setqtenv
+
+	local conf=3D"
+		-prefix ${QTPREFIXDIR}
+		-bindir ${QTBINDIR}
+		-libdir ${QTLIBDIR}
+		-docdir ${QTDOCDIR}
+		-headerdir ${QTHEADERDIR}
+		-plugindir ${QTPLUGINDIR}
+		$(version_is_at_least 4.7 && echo -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+=3D" -arch x86_64" ;;
+		ppc-macos)		  conf+=3D" -arch ppc" ;;
+		ppc|ppc64|ppc-*)	  conf+=3D" -arch powerpc" ;;
+		sparc|sparc-*|sparc64-*)  conf+=3D" -arch sparc" ;;
+		x86-macos)		  conf+=3D" -arch x86" ;;
+		x86|x86-*)		  conf+=3D" -arch i386" ;;
+		alpha|arm|ia64|mips|s390) conf+=3D" -arch $(tc-arch)" ;;
+		hppa|sh)		  conf+=3D" -arch generic" ;;
+		*) die "$(tc-arch) is unsupported by this eclass. Please file a bug." =
;;
+	esac
+
+	conf+=3D" -platform $(qt_mkspecs_dir)"
+
+	[[ $(get_libdir) !=3D lib ]] && conf+=3D" -L${EPREFIX}/usr/$(get_libdir=
)"
+
+	# debug/release
+	if use debug; then
+		conf+=3D" -debug"
+	else
+		conf+=3D" -release"
+	fi
+	conf+=3D" -no-separate-debug-info"
+
+	# exceptions USE flag
+	conf+=3D" $(in_iuse exceptions && qt_use exceptions || echo -exceptions=
)"
+
+	# disable RPATH on Qt >=3D 4.8 (bug 380415)
+	version_is_at_least 4.8 && conf+=3D" -no-rpath"
+
+	# precompiled headers don't work on hardened, where the flag is masked
+	conf+=3D" $(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} !=3D *-solaris* ]] && conf+=3D" -reduce-relocations"
+
+	# this one is needed for all systems with a separate -liconv, apart fro=
m
+	# Darwin, for which the sources already cater for -liconv
+	if use !elibc_glibc && [[ ${CHOST} !=3D *-darwin* ]]; then
+		conf+=3D" -liconv"
+	fi
+
+	if use_if_iuse glib; then
+		local glibflags=3D"$(pkg-config --cflags --libs glib-2.0 gthread-2.0)"
+		# avoid the -pthread argument
+		conf+=3D" ${glibflags//-pthread}"
+		unset glibflags
+	fi
+
+	if use_if_iuse qpa; then
+		echo
+		ewarn "The qpa useflag enables the Qt Platform Abstraction, formely"
+		ewarn "known as Qt Lighthouse. If you are not sure what that is, then"
+		ewarn "disable it before reporting any bugs related to this useflag."
+		echo
+		conf+=3D" -qpa"
+	fi
+
+	if use aqua; then
+		# On (snow) leopard use the new (frameworked) cocoa code.
+		if [[ ${CHOST##*-darwin} -ge 9 ]]; then
+			conf+=3D" -cocoa -framework"
+			# We need the source's headers, not the installed ones.
+			conf+=3D" -I${S}/include"
+			# Add hint for the framework location.
+			conf+=3D" -F${QTLIBDIR}"
+
+			# We are crazy and build cocoa + qt3support :-)
+			if use qt3support; then
+				sed -e "/case \"\$PLATFORM,\$CFG_MAC_COCOA\" in/,/;;/ s|CFG_QT3SUPPO=
RT=3D\"no\"|CFG_QT3SUPPORT=3D\"yes\"|" \
+					-i configure || die
+			fi
+		else
+			conf+=3D" -no-framework"
+		fi
+	else
+		# freetype2 include dir is non-standard, thus pass it to configure
+		conf+=3D" $(pkg-config --cflags-only-I freetype2)"
+	fi
+
+	conf+=3D" ${myconf}"
+	myconf=3D
+
+	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)
+	[[ ${PN} =3D=3D qt-multimedia ]] && 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 packa=
ges.
+fix_includes() {
+	if use aqua && [[ ${CHOST##*-darwin} -ge 9 ]]; then
+		# Some packages tend to include <Qt/...>
+		dodir "${QTHEADERDIR#${EPREFIX}}"/Qt
+
+		# Fake normal headers when frameworks are installed... eases life late=
r on
+		local dest f h
+		for frw in "${D}${QTLIBDIR}"/*.framework; do
+			[[ -e "${frw}"/Headers ]] || continue
+			f=3D$(basename ${frw})
+			dest=3D"${QTHEADERDIR#${EPREFIX}}"/${f%.framework}
+			dosym "${QTLIBDIR#${EPREFIX}}"/${f}/Headers "${dest}"
+
+			# Link normal headers as well.
+			for hdr in "${D}/${QTLIBDIR}/${f}"/Headers/*; do
+				h=3D$(basename ${hdr})
+				dosym "${QTLIBDIR#${EPREFIX}}"/${f}/Headers/${h} "${QTHEADERDIR#${EP=
REFIX}}"/Qt/${h}
+			done
+		done
+	fi
+}
+
+# @FUNCTION: qt4-build_src_install
+# @DESCRIPTION:
+# Perform the actual installation including some library fixes.
+qt4-build_src_install() {
+	[[ ${EAPI} =3D=3D 2 ]] && use !prefix && ED=3D${D}
+	setqtenv
+
+	install_directories ${QT4_TARGET_DIRECTORIES}
+	install_qconfigs
+	fix_library_files
+	fix_includes
+
+	# remove .la files since we are building only shared Qt libraries
+	find "${D}"${QTLIBDIR} -type f -name '*.la' -print0 | xargs -0 rm -f
+}
+
+# @FUNCTION: setqtenv
+# @INTERNAL
+setqtenv() {
+	# Set up installation directories
+	QTPREFIXDIR=3D${EPREFIX}/usr
+	QTBINDIR=3D${EPREFIX}/usr/bin
+	QTLIBDIR=3D${EPREFIX}/usr/$(get_libdir)/qt4
+	QTPCDIR=3D${EPREFIX}/usr/$(get_libdir)/pkgconfig
+	QTDOCDIR=3D${EPREFIX}/usr/share/doc/qt-${PV}
+	QTHEADERDIR=3D${EPREFIX}/usr/include/qt4
+	QTPLUGINDIR=3D${QTLIBDIR}/plugins
+	QTIMPORTDIR=3D${QTLIBDIR}/imports
+	QTDATADIR=3D${EPREFIX}/usr/share/qt4
+	QTTRANSDIR=3D${QTDATADIR}/translations
+	QTSYSCONFDIR=3D${EPREFIX}/etc/qt4
+	QTEXAMPLESDIR=3D${QTDATADIR}/examples
+	QTDEMOSDIR=3D${QTDATADIR}/demos
+	QMAKE_LIBDIR_QT=3D${QTLIBDIR}
+	QT_INSTALL_PREFIX=3D${EPREFIX}/usr/$(get_libdir)/qt4
+
+	PLATFORM=3D$(qt_mkspecs_dir)
+
+	unset QMAKESPEC
+}
+
+# @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}"
+		# avoid running over the maximum argument number, bug #299810
+		{
+			echo "${S}"/mkspecs/common/*.conf
+			find "${S}" -name '*.pr[io]'
+		} | xargs sed -i \
+			-e "s:\$\$\[QT_INSTALL_LIBS\]:${QTLIBDIR}:g" \
+			-e "s:\$\$\[QT_INSTALL_PLUGINS\]:${QTPLUGINDIR}:g" \
+			|| die
+		"${S}"/bin/qmake "LIBS+=3D-L${QTLIBDIR}" "CONFIG+=3Dnostrip" || die "q=
make 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 CC=3D"$(tc-getCC)" \
+			CXX=3D"$(tc-getCXX)" \
+			LINK=3D"$(tc-getCXX)" || die "emake failed"
+		popd >/dev/null || die
+	done
+}
+
+# @FUNCTION: install_directories
+# @USAGE: < directories >
+# @INTERNAL
+# @DESCRIPTION:
+# Runs emake install in the given directories, which are separated by sp=
aces.
+install_directories() {
+	for x in "$@"; do
+		pushd "${S}"/${x} >/dev/null || die
+		emake INSTALL_ROOT=3D"${D}" install || die "emake install failed"
+		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:=3D}
+
+# @ECLASS-VARIABLE: QCONFIG_REMOVE
+# @DESCRIPTION:
+# List options that need to be removed from QT_CONFIG in qconfig.pri
+: ${QCONFIG_REMOVE:=3D}
+
+# @ECLASS-VARIABLE: QCONFIG_DEFINE
+# @DESCRIPTION:
+# List variables that should be defined at the top of QtCore/qconfig.h
+: ${QCONFIG_DEFINE:=3D}
+
+# @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}=3D${!x} >> "${T}"/${PN}-qconfig.pri
+		done
+		insinto ${QTDATADIR#${EPREFIX}}/mkspecs/gentoo
+		doins "${T}"/${PN}-qconfig.pri || die "installing ${PN}-qconfig.pri fa=
iled"
+	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 || die "installing ${PN}-qconfig.h=
 failed"
+	fi
+}
+
+# @FUNCTION: generate_qconfigs
+# @INTERNAL
+# @DESCRIPTION:
+# Generates gentoo-specific qconfig.{h,pri}.
+generate_qconfigs() {
+	if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} || -n ${QCONFIG_DEFINE}=
 || ${PN} =3D=3D qt-core ]]; then
+		local x qconfig_add qconfig_remove qconfig_new
+		for x in "${ROOT}${QTDATADIR}"/mkspecs/gentoo/*-qconfig.pri; do
+			[[ -f ${x} ]] || continue
+			qconfig_add+=3D" $(sed -n 's/^QCONFIG_ADD=3D//p' "${x}")"
+			qconfig_remove+=3D" $(sed -n 's/^QCONFIG_REMOVE=3D//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 qt-core 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 +=3D//p' \
+				"${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri) ${qconfig_add}; do
+					has ${x} ${qconfig_remove} || qconfig_new+=3D" ${x}"
+			done
+
+			# replace the existing QT_CONFIG list with qconfig_new
+			if ! sed -i -e "s/QT_CONFIG +=3D.*/QT_CONFIG +=3D ${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 qt-core.
+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 fi=
les are scanned.
+skip_project_generation() {
+	sed -i -e "s:echo \"Finding:exit 0\n\necho \"Finding:g" "${S}"/configur=
e || die
+}
+
+# @FUNCTION: symlink_binaries_to_buildtree
+# @INTERNAL
+# @DESCRIPTION:
+# Symlinks generated binaries to buildtree, so they can be used during c=
ompilation 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 ${libf=
ile} 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 ${libf=
ile} failed"
+
+		# Move .pc files into the pkgconfig directory
+		dodir ${QTPCDIR#${EPREFIX}}
+		mv ${libfile} "${D}"/${QTPCDIR}/ || die "moving ${libfile} to ${D}/${Q=
TPCDIR}/ 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, <fla=
g>
+# 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=3D
+
+	case "${CHOST}" in
+		*-freebsd*|*-dragonfly*)
+			spec=3Dfreebsd ;;
+		*-openbsd*)
+			spec=3Dopenbsd ;;
+		*-netbsd*)
+			spec=3Dnetbsd ;;
+		*-darwin*)
+			if use aqua; then
+				# mac with carbon/cocoa
+				spec=3Dmacx
+			else
+				# darwin/mac with x11
+				spec=3Ddarwin
+			fi
+			;;
+		*-solaris*)
+			spec=3Dsolaris ;;
+		*-linux-*|*-linux)
+			spec=3Dlinux ;;
+		*)
+			die "${FUNCNAME}(): Unknown CHOST '${CHOST}'" ;;
+	esac
+
+	case "$(tc-getCXX)" in
+		*g++*)
+			spec+=3D-g++ ;;
+		*icpc*)
+			spec+=3D-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+=3D-64
+	fi
+
+	echo "${spec}"
+}
+
+# @FUNCTION: qt_assistant_cleanup
+# @INTERNAL
+# @DESCRIPTION:
+# Tries to clean up tools.pro for qt-assistant ebuilds.
+# Meant to be called in src_prepare().
+# Since Qt 4.7.4 this function is a no-op.
+qt_assistant_cleanup() {
+	# apply patching to qt-assistant ebuilds only
+	[[ ${PN} !=3D qt-assistant ]] && return
+
+	# no longer needed for 4.7.4 and later
+	version_is_at_least 4.7.4 && return
+
+	# different versions (and branches...) may need different handling,
+	# add a case if you need special handling
+	case "${MY_PV_EXTRA}" in
+		*kde-qt*)
+			sed -e "/^[ \t]*porting/,/^[ \t]*win32.*activeqt$/d" \
+				-e "/mac/,/^embedded.*makeqpf$/d" \
+				-i tools/tools.pro || die "patching tools.pro failed"
+		;;
+		*)
+			sed -e "/^[ \t]*porting/,/^[ \t]*win32.*activeqt$/d" \
+				-e "/mac/,/^embedded.*makeqpf$/d" \
+				-e "s/^\([ \t]*pixeltool\) /\1 qdoc3 /" \
+				-i tools/tools.pro || die "patching tools.pro failed"
+		;;
+	esac
+}
+
+# @FUNCTION: qt_nolibx11
+# @INTERNAL
+# @DESCRIPTION:
+# Ignore X11 tests for packages that don't need X libraries installed.
+qt_nolibx11() {
+	sed -i "/unixtests\/compile.test.*config.tests\/x11\/xlib/,/fi$/d" "${S=
}"/configure ||
+		die "x11 check sed failed"
+}
+
+EXPORT_FUNCTIONS pkg_setup src_unpack src_prepare src_configure src_comp=
ile src_install src_test pkg_postrm pkg_postinst