summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'eclass/qt4-build.eclass')
-rw-r--r--eclass/qt4-build.eclass106
1 files changed, 68 insertions, 38 deletions
diff --git a/eclass/qt4-build.eclass b/eclass/qt4-build.eclass
index cbcacc1289cf..01e49f95bc7c 100644
--- a/eclass/qt4-build.eclass
+++ b/eclass/qt4-build.eclass
@@ -1,24 +1,22 @@
-# Copyright 2007-2008 Gentoo Foundation
+# Copyright 2007-2009 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
-# $Header: /var/cvsroot/gentoo-x86/eclass/qt4-build.eclass,v 1.19 2009/01/29 18:45:29 aballier Exp $
+# $Header: /var/cvsroot/gentoo-x86/eclass/qt4-build.eclass,v 1.20 2009/02/11 21:14:59 yngwin Exp $
# @ECLASS: qt4-build.eclass
# @MAINTAINER:
+# Ben de Groot <yngwin@gentoo.org>
+# Markos Chandras <hwoarang@gentoo.org>
# Caleb Tennis <caleb@gentoo.org>
# @BLURB: Eclass for Qt4 split ebuilds.
# @DESCRIPTION:
# This eclass contains various functions that are used when building Qt4
-inherit eutils multilib toolchain-funcs flag-o-matic
+inherit eutils multilib toolchain-funcs flag-o-matic versionator
-IUSE="${IUSE} debug pch"
+IUSE="${IUSE} custom-cxxflags debug pch"
case "${PV}" in
- 4.4.0_beta*)
- SRCTYPE="${SRCTYPE:-opensource-src}"
- MY_PV="${PV/_beta/-beta}"
- ;;
- 4.4.0_rc*)
+ 4.?.?_rc*)
SRCTYPE="${SRCTYPE:-opensource-src}"
MY_PV="${PV/_rc/-rc}"
;;
@@ -30,19 +28,26 @@ esac
MY_P=qt-x11-${SRCTYPE}-${MY_PV}
S=${WORKDIR}/${MY_P}
+HOMEPAGE="http://www.qtsoftware.com/"
SRC_URI="ftp://ftp.trolltech.com/qt/source/${MY_P}.tar.bz2"
case "${PV}" in
- 4.4.2|4.4.1|4.4.0|4.4.0_rc*)
- SRC_URI="${SRC_URI} mirror://gentoo/${MY_P}-headers.tar.bz2"
- ;;
- *)
- ;;
+ 4.4.?) SRC_URI="${SRC_URI} mirror://gentoo/${MY_P}-headers.tar.bz2" ;;
+ *) ;;
esac
qt4-build_pkg_setup() {
- # Check USE requirements
- qt4-build_check_use
+ # EAPI=2 ebuilds set use-deps, others need this:
+ if [[ $EAPI != 2 ]]; then
+ # Make sure debug setting corresponds with qt-core (bug 258512)
+ if [[ $PN != "qt-core" ]]; then
+ use debug && QT4_BUILT_WITH_USE_CHECK="${QT4_BUILT_WITH_USE_CHECK}
+ ~x11-libs/qt-core-${PV} debug"
+ fi
+
+ # Check USE requirements
+ qt4-build_check_use
+ fi
# Set up installation directories
QTBASEDIR=/usr/$(get_libdir)/qt4
@@ -63,9 +68,15 @@ qt4-build_pkg_setup() {
PATH="${S}/bin:${PATH}"
LD_LIBRARY_PATH="${S}/lib:${LD_LIBRARY_PATH}"
+
+ if ! version_is_at_least 4.1 $(gcc-version) ; then
+ ewarn "Using a GCC version lower than 4.1 is not supported!"
+ echo
+ ebeep 5
+ fi
}
-qt4_unpack() {
+qt4-build_src_unpack() {
local target targets
for target in configure LICENSE.{GPL2,GPL3} projects.pro \
src/{qbase,qt_targets,qt_install}.pri bin config.tests mkspecs qmake \
@@ -77,17 +88,22 @@ qt4_unpack() {
tar xjpf "${DISTDIR}"/${MY_P}.tar.bz2 ${targets}
case "${PV}" in
- 4.4.2|4.4.1|4.4.0|4.4.0_rc*)
+ 4.4.?)
echo tar xjpf "${DISTDIR}"/${MY_P}-headers.tar.bz2
tar xjpf "${DISTDIR}"/${MY_P}-headers.tar.bz2
;;
esac
+
+ # Be backwards compatible for now
+ if [[ $EAPI != 2 ]]; then
+ qt4-build_src_prepare
+ fi
}
-qt4-build_src_unpack() {
- qt4_unpack
+qt4-build_src_prepare() {
+ cd "${S}"
+
if [[ ${PN} != qt-core ]]; then
- cd "${S}"
skip_qmake_build_patch
skip_project_generation_patch
symlink_binaries_to_buildtree
@@ -111,12 +127,22 @@ qt4-build_src_unpack() {
-i "${S}"/mkspecs/common/g++.conf || die "sed ${S}/mkspecs/common/g++.conf failed"
}
-qt4-build_src_compile() {
- # Don't let the user go too overboard with flags. If you really want to, uncomment
- # out the line below and give 'er a whirl.
- strip-flags
- replace-flags -O3 -O2
+qt4-build_src_configure() {
+ if use custom-cxxflags; then
+ echo
+ ewarn "You have set USE=custom-cxxflags, which means Qt will be built with the"
+ ewarn "CXXFLAGS you have set in /etc/make.conf. This is not supported, and we"
+ ewarn "recommend to unset this useflag. But you are free to experiment with it."
+ ewarn "Just do not start crying if it breaks your system, or eats your kitten"
+ ewarn "for breakfast. ;-) "
+ echo
+ else
+ # Don't let the user go too overboard with flags.
+ strip-flags
+ replace-flags -O3 -O2
+ 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
@@ -132,8 +158,15 @@ qt4-build_src_compile() {
echo ./configure ${myconf}
./configure ${myconf} || die "./configure failed"
+}
- build_target_directories
+qt4-build_src_compile() {
+ # Be backwards compatible for now
+ if [[ $EAPI != 2 ]]; then
+ qt4-build_src_configure
+ fi
+
+ build_directories "${QT4_TARGET_DIRECTORIES}"
}
qt4-build_src_install() {
@@ -165,7 +198,7 @@ standard_configure_options() {
myconf="${myconf} -release -no-separate-debug-info"
fi
- # ARCH is set on Gentoo. QT now falls back to generic on an unsupported
+ # ARCH is set on Gentoo. Qt now falls back to generic on an unsupported
# ${ARCH}. Therefore we convert it to supported values.
case "${ARCH}" in
amd64) myconf="${myconf} -arch x86_64" ;;
@@ -181,16 +214,14 @@ standard_configure_options() {
-datadir ${QTDATADIR} -docdir ${QTDOCDIR} -headerdir ${QTHEADERDIR}
-plugindir ${QTPLUGINDIR} -sysconfdir ${QTSYSCONFDIR}
-translationdir ${QTTRANSDIR} -examplesdir ${QTEXAMPLESDIR}
- -demosdir ${QTDEMOSDIR} -silent -fast $(use x86-fbsd || echo -reduce-relocations)
+ -demosdir ${QTDEMOSDIR} -silent -fast
+ $([[ ${PN} == qt-xmlpatterns ]] || echo -no-exceptions)
+ $(use x86-fbsd || echo -reduce-relocations)
-nomake examples -nomake demos"
echo "${myconf}"
}
-build_target_directories() {
- build_directories "${QT4_TARGET_DIRECTORIES}"
-}
-
build_directories() {
local dirs="$@"
for x in ${dirs}; do
@@ -243,10 +274,6 @@ install_qconfigs() {
fi
}
-# Stubs for functions used by the Qt 4.4.0_technical_preview_1.
-qconfig_add_option() { : ; }
-qconfig_remove_option() { : ; }
-
generate_qconfigs() {
if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} || -n ${QCONFIG_DEFINE} || ${CATEGORY}/${PN} == x11-libs/qt-core ]]; then
local x qconfig_add qconfig_remove qconfig_new
@@ -481,4 +508,7 @@ qt_mkspecs_dir() {
echo "${spec}"
}
-EXPORT_FUNCTIONS pkg_setup src_unpack src_compile src_install pkg_postrm pkg_postinst
+case ${EAPI:-0} in
+ 0|1) EXPORT_FUNCTIONS pkg_setup src_unpack src_compile src_install pkg_postrm pkg_postinst ;;
+ 2) EXPORT_FUNCTIONS pkg_setup src_unpack src_prepare src_configure src_compile src_install pkg_postrm pkg_postinst ;;
+esac