/[gentoo-x86]/eclass/qt4-build.eclass
Gentoo

Diff of /eclass/qt4-build.eclass

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

Revision 1.85 Revision 1.151
1# Copyright 1999-2009 Gentoo Foundation 1# Copyright 1999-2013 Gentoo Foundation
2# Distributed under the terms of the GNU General Public License v2 2# Distributed under the terms of the GNU General Public License v2
3# $Header: /var/cvsroot/gentoo-x86/eclass/qt4-build.eclass,v 1.85 2010/11/10 13:45:38 wired Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/qt4-build.eclass,v 1.151 2013/10/14 17:24:36 pesa Exp $
4 4
5# @ECLASS: qt4-build.eclass 5# @ECLASS: qt4-build.eclass
6# @MAINTAINER: 6# @MAINTAINER:
7# Ben de Groot <yngwin@gentoo.org>, 7# Qt herd <qt@gentoo.org>
8# Markos Chandras <hwoarang@gentoo.org>,
9# Caleb Tennis <caleb@gentoo.org>
10# Alex Alexander <wired@gentoo.org>
11# @BLURB: Eclass for Qt4 split ebuilds. 8# @BLURB: Eclass for Qt4 split ebuilds.
12# @DESCRIPTION: 9# @DESCRIPTION:
13# This eclass contains various functions that are used when building Qt4 10# This eclass contains various functions that are used when building Qt4.
14 11
12case ${EAPI} in
13 4|5) : ;;
14 *) die "qt4-build.eclass: unsupported EAPI=${EAPI:-0}" ;;
15esac
16
15inherit base eutils multilib toolchain-funcs flag-o-matic versionator 17inherit eutils flag-o-matic multilib toolchain-funcs versionator
18
19if [[ ${PV} == *9999* ]]; then
20 QT4_BUILD_TYPE="live"
21 inherit git-r3
22else
23 QT4_BUILD_TYPE="release"
24fi
25
26HOMEPAGE="http://qt-project.org/ http://qt.digia.com/"
27LICENSE="|| ( LGPL-2.1 GPL-3 )"
16 28
17MY_PV=${PV/_/-} 29MY_PV=${PV/_/-}
18if version_is_at_least 4.5.99999999; then
19 MY_P=qt-everywhere-opensource-src-${MY_PV} 30MY_P=qt-everywhere-opensource-src-${MY_PV}
31
32case ${QT4_BUILD_TYPE} in
33 live)
34 EGIT_REPO_URI=(
35 "git://gitorious.org/qt/qt.git"
36 "https://git.gitorious.org/qt/qt.git"
37 )
38 EGIT_BRANCH=${PV%.9999}
39 ;;
40 release)
41 SRC_URI="http://download.qt-project.org/official_releases/qt/${PV%.*}/${PV}/${MY_P}.tar.gz"
42 ;;
43esac
44
45IUSE="aqua debug pch"
46[[ ${CATEGORY}/${PN} != dev-qt/qtwebkit ]] && IUSE+=" c++0x"
20 [[ ${CATEGORY}/${PN} != x11-libs/qt-xmlpatterns ]] && IUSE="+exceptions" 47[[ ${CATEGORY}/${PN} != dev-qt/qtxmlpatterns ]] && IUSE+=" +exceptions"
21else 48
22 MY_P=qt-x11-opensource-src-${MY_PV} 49DEPEND="virtual/pkgconfig"
50if [[ ${QT4_BUILD_TYPE} == live ]]; then
51 DEPEND+=" dev-lang/perl"
23fi 52fi
24 53
25HOMEPAGE="http://qt.nokia.com/"
26SRC_URI="http://get.qt.nokia.com/qt/source/${MY_P}.tar.gz"
27
28LICENSE="|| ( LGPL-2.1 GPL-3 )"
29IUSE+=" debug pch aqua"
30
31RDEPEND="
32 !<x11-libs/qt-assistant-${PV}
33 !>x11-libs/qt-assistant-${PV}-r9999
34 !<x11-libs/qt-core-${PV}
35 !>x11-libs/qt-core-${PV}-r9999
36 !<x11-libs/qt-dbus-${PV}
37 !>x11-libs/qt-dbus-${PV}-r9999
38 !<x11-libs/qt-demo-${PV}
39 !>x11-libs/qt-demo-${PV}-r9999
40 !<x11-libs/qt-gui-${PV}
41 !>x11-libs/qt-gui-${PV}-r9999
42 !<x11-libs/qt-multimedia-${PV}
43 !>x11-libs/qt-multimedia-${PV}-r9999
44 !<x11-libs/qt-opengl-${PV}
45 !>x11-libs/qt-opengl-${PV}-r9999
46 !<x11-libs/qt-phonon-${PV}
47 !>x11-libs/qt-phonon-${PV}-r9999
48 !<x11-libs/qt-qt3support-${PV}
49 !>x11-libs/qt-qt3support-${PV}-r9999
50 !<x11-libs/qt-script-${PV}
51 !>x11-libs/qt-script-${PV}-r9999
52 !<x11-libs/qt-sql-${PV}
53 !>x11-libs/qt-sql-${PV}-r9999
54 !<x11-libs/qt-svg-${PV}
55 !>x11-libs/qt-svg-${PV}-r9999
56 !<x11-libs/qt-test-${PV}
57 !>x11-libs/qt-test-${PV}-r9999
58 !<x11-libs/qt-webkit-${PV}
59 !>x11-libs/qt-webkit-${PV}-r9999
60 !<x11-libs/qt-xmlpatterns-${PV}
61 !>x11-libs/qt-xmlpatterns-${PV}-r9999
62"
63
64S=${WORKDIR}/${MY_P} 54S=${WORKDIR}/${MY_P}
65 55
66# @FUNCTION: qt4-build_pkg_setup 56# @FUNCTION: qt4-build_pkg_setup
67# @DESCRIPTION: 57# @DESCRIPTION:
68# Sets up S, MY_P, PATH, and LD_LIBRARY_PATH 58# Sets up PATH and LD_LIBRARY_PATH.
69qt4-build_pkg_setup() { 59qt4-build_pkg_setup() {
70 [[ ${EAPI} == 2 ]] && use !prefix && EPREFIX=
71
72 # Protect users by not allowing downgrades between releases 60 # Protect users by not allowing downgrades between releases.
73 # Downgrading revisions within the same release should be allowed 61 # Downgrading revisions within the same release should be allowed.
74 if has_version '>'${CATEGORY}/${P}-r9999 ; then 62 if has_version ">${CATEGORY}/${P}-r9999:4"; then
75 if [[ -z $I_KNOW_WHAT_I_AM_DOING ]] ; then 63 if [[ -z ${I_KNOW_WHAT_I_AM_DOING} ]]; then
76 eerror "Sanity check to keep you from breaking your system:" 64 eerror " *** Sanity check to keep you from breaking your system ***"
77 eerror " Downgrading Qt is completely unsupported and will break your system!" 65 eerror "Downgrading Qt is completely unsupported and will break your system!"
78 die "aborting to save your system" 66 die "aborting to save your system"
79 else 67 else
80 ewarn "Downgrading Qt is completely unsupported and will break your system!" 68 ewarn "Downgrading Qt is completely unsupported and will break your system!"
81 fi 69 fi
82 fi
83
84 if [[ "${PN}" == "qt-webkit" ]]; then
85 eshopts_push -s extglob
86 if is-flagq '-g?(gdb)?([1-9])'; then
87 echo
88 ewarn "You have enabled debug info (probably have -g or -ggdb in your \$C{,XX}FLAGS)."
89 ewarn "You may experience really long compilation times and/or increased memory usage."
90 ewarn "If compilation fails, please try removing -g{,gdb} before reporting a bug."
91 ewarn "For more info check out bug #307861"
92 echo
93 fi
94 eshopts_pop
95 fi 70 fi
96 71
97 PATH="${S}/bin${PATH:+:}${PATH}" 72 PATH="${S}/bin${PATH:+:}${PATH}"
98 if [[ ${CHOST} != *-darwin* ]]; then 73 if [[ ${CHOST} != *-darwin* ]]; then
99 LD_LIBRARY_PATH="${S}/lib${LD_LIBRARY_PATH:+:}${LD_LIBRARY_PATH}" 74 LD_LIBRARY_PATH="${S}/lib${LD_LIBRARY_PATH:+:}${LD_LIBRARY_PATH}"
104 # avoid extract failure. 79 # avoid extract failure.
105 [[ ${CHOST} == *-apple-darwin* ]] && \ 80 [[ ${CHOST} == *-apple-darwin* ]] && \
106 QT4_EXTRACT_DIRECTORIES="src/gui/kernel/qapplication_mac.mm 81 QT4_EXTRACT_DIRECTORIES="src/gui/kernel/qapplication_mac.mm
107 ${QT4_EXTRACT_DIRECTORIES}" 82 ${QT4_EXTRACT_DIRECTORIES}"
108 fi 83 fi
109
110 # Make sure ebuilds use the required EAPI
111 if [[ ${EAPI} != [23] ]]; then
112 eerror "The qt4-build eclass requires EAPI=2 or EAPI=3, but this ebuild is using"
113 eerror "EAPI=${EAPI:-0}. The ebuild author or editor failed. This ebuild needs to be"
114 eerror "fixed. Using qt4-build eclass without EAPI=2 or EAPI=3 will fail."
115 die "qt4-build eclass requires EAPI=2 or EAPI=3"
116 fi
117
118 if ! version_is_at_least 4.1 $(gcc-version); then
119 ewarn "Using a GCC version lower than 4.1 is not supported!"
120 fi
121} 84}
85
86# @ECLASS-VARIABLE: QT4_EXTRACT_DIRECTORIES
87# @DEFAULT_UNSET
88# @DESCRIPTION:
89# Space-separated list including the directories that will be extracted from
90# Qt tarball.
122 91
123# @ECLASS-VARIABLE: QT4_TARGET_DIRECTORIES 92# @ECLASS-VARIABLE: QT4_TARGET_DIRECTORIES
93# @DEFAULT_UNSET
124# @DESCRIPTION: 94# @DESCRIPTION:
125# Arguments for build_target_directories. Takes the directories, in which the 95# Arguments for build_target_directories. Takes the directories in which the
126# code should be compiled. This is a space-separated list 96# code should be compiled. This is a space-separated list.
127
128# @ECLASS-VARIABLE: QT4_EXTRACT_DIRECTORIES
129# @DESCRIPTION:
130# Space separated list including the directories that will be extracted from Qt
131# tarball
132 97
133# @FUNCTION: qt4-build_src_unpack 98# @FUNCTION: qt4-build_src_unpack
134# @DESCRIPTION: 99# @DESCRIPTION:
135# Unpacks the sources 100# Unpacks the sources.
136qt4-build_src_unpack() { 101qt4-build_src_unpack() {
137 setqtenv 102 setqtenv
138 local target targets= 103
104 if ! version_is_at_least 4.1 $(gcc-version); then
105 ewarn "Using a GCC version lower than 4.1 is not supported."
106 elif use_if_iuse c++0x && ! version_is_at_least 4.4 $(gcc-version); then
107 ewarn "USE=c++0x requires GCC 4.4 or later."
108 fi
109
110 if [[ ${CATEGORY}/${PN} == dev-qt/qtwebkit ]]; then
111 eshopts_push -s extglob
112 if is-flagq '-g?(gdb)?([1-9])'; then
113 echo
114 ewarn "You have enabled debug info (probably have -g or -ggdb in your CFLAGS/CXXFLAGS)."
115 ewarn "You may experience really long compilation times and/or increased memory usage."
116 ewarn "If compilation fails, please try removing -g/-ggdb before reporting a bug."
117 ewarn "For more info check out https://bugs.gentoo.org/307861"
118 echo
119 fi
120 eshopts_pop
121 fi
122
123 case ${QT4_BUILD_TYPE} in
124 live)
125 git-r3_src_unpack
126 ;;
127 release)
128 local tarball="${MY_P}.tar.gz" target= targets=
139 for target in configure LICENSE.GPL3 LICENSE.LGPL projects.pro \ 129 for target in configure LICENSE.GPL3 LICENSE.LGPL projects.pro \
140 src/{qbase,qt_targets,qt_install}.pri bin config.tests mkspecs qmake \ 130 src/{qbase,qt_targets,qt_install}.pri bin config.tests \
141 ${QT4_EXTRACT_DIRECTORIES}; do 131 mkspecs qmake ${QT4_EXTRACT_DIRECTORIES}
132 do
142 targets+=" ${MY_P}/${target}" 133 targets+="${MY_P}/${target} "
143 done 134 done
144 135
136 ebegin "Unpacking parts of ${tarball}:" ${targets//${MY_P}\/}
145 echo tar xzf "${DISTDIR}"/${MY_P}.tar.gz ${targets} 137 tar -xzf "${DISTDIR}/${tarball}" ${targets}
146 tar xzf "${DISTDIR}"/${MY_P}.tar.gz ${targets} || die 138 eend $? || die "failed to unpack"
139 ;;
140 esac
147} 141}
148 142
149# @ECLASS-VARIABLE: PATCHES 143# @ECLASS-VARIABLE: PATCHES
144# @DEFAULT_UNSET
150# @DESCRIPTION: 145# @DESCRIPTION:
151# In case you have patches to apply, specify them in PATCHES variable. Make sure 146# PATCHES array variable containing all various patches to be applied.
152# to specify the full path. This variable is necessary for src_prepare phase. 147# This variable is expected to be defined in global scope of ebuild.
153# example: 148# Make sure to specify the full path. This variable is utilised in
154# PATCHES="${FILESDIR}"/mypatch.patch 149# src_prepare() phase.
155# ${FILESDIR}"/mypatch2.patch"
156# 150#
151# @CODE
152# PATCHES=( "${FILESDIR}/mypatch.patch"
153# "${FILESDIR}/patches_folder/" )
154# @CODE
157 155
158# @FUNCTION: qt4-build_src_prepare 156# @FUNCTION: qt4-build_src_prepare
159# @DESCRIPTION: 157# @DESCRIPTION:
160# Prepare the sources before the configure phase. Strip CFLAGS if necessary, and fix 158# Prepare the sources before the configure phase. Strip CFLAGS if necessary, and fix
161# source files in order to respect CFLAGS/CXXFLAGS/LDFLAGS specified on /etc/make.conf. 159# the build system in order to respect CFLAGS/CXXFLAGS/LDFLAGS specified in make.conf.
162qt4-build_src_prepare() { 160qt4-build_src_prepare() {
163 setqtenv 161 setqtenv
164 cd "${S}" 162
165 163 if [[ ${QT4_BUILD_TYPE} == live ]]; then
166 # fix qt 4.7 regression that skips -fvisibility=hidden 164 QTDIR="." ./bin/syncqt || die "syncqt failed"
167 if version_is_at_least "4.7.0_beta1"; then
168 sed -e "s/^gcc|g++)/*gcc|*g++)/" \
169 -i config.tests/unix/fvisibility.test ||
170 die "visibility fixing sed failed"
171 fi 165 fi
166
172 # fix libx11 dependency on non X packages 167 # avoid X11 dependency in non-gui packages
173 if version_is_at_least "4.7.0_beta2"; then
174 local NOLIBX11PKG="qt-core qt-dbus qt-script qt-sql qt-test qt-xmlpatterns" 168 local nolibx11_pkgs="qtcore qtdbus qtscript qtsql qttest qtxmlpatterns"
175 hasq ${PN} ${NOLIBX11PKG} && qt_nolibx11 169 has ${PN} ${nolibx11_pkgs} && qt_nolibx11
176 [[ ${PN} == "qt-assistant" ]] && qt_assistant_cleanup
177 fi
178 170
179 if use aqua; then 171 if use aqua; then
180 # provide a proper macx-g++-64 172 # provide a proper macx-g++-64
181 use x64-macos && ln -s macx-g++ mkspecs/$(qt_mkspecs_dir) 173 use x64-macos && ln -s macx-g++ mkspecs/$(qt_mkspecs_dir)
182 174
183 sed -e '/^CONFIG/s:app_bundle::' \ 175 sed -e '/^CONFIG/s:app_bundle::' \
184 -e '/^CONFIG/s:plugin_no_soname:plugin_with_soname absolute_library_soname:' \ 176 -e '/^CONFIG/s:plugin_no_soname:plugin_with_soname absolute_library_soname:' \
185 -i mkspecs/$(qt_mkspecs_dir)/qmake.conf || die "sed failed" 177 -i mkspecs/$(qt_mkspecs_dir)/qmake.conf || die
186 fi 178 fi
187 179
188 if [[ ${PN} != qt-core ]]; then 180 if [[ ${CATEGORY}/${PN} != dev-qt/qtcore ]]; then
189 skip_qmake_build_patch 181 skip_qmake_build
190 skip_project_generation_patch 182 skip_project_generation
191 symlink_binaries_to_buildtree 183 symlink_binaries_to_buildtree
192 fi 184 fi
193 185
194 if [[ ${CHOST} == *86*-apple-darwin* ]] ; then 186 if use_if_iuse c++0x; then
195 # qmake bus errors with -O2 but -O3 works 187 append-cxxflags -std=c++0x
196 replace-flags -O2 -O3
197 fi
198
199 # Bug 178652
200 if [[ $(gcc-major-version) == 3 ]] && use amd64; then
201 ewarn "Appending -fno-gcse to CFLAGS/CXXFLAGS"
202 append-flags -fno-gcse
203 fi
204
205 # Unsupported old gcc versions - hardened needs this :(
206 if [[ $(gcc-major-version) -lt 4 ]] ; then
207 ewarn "Appending -fno-stack-protector to CXXFLAGS"
208 append-cxxflags -fno-stack-protector
209 # Bug 253127
210 sed -e "/^QMAKE_CFLAGS\t/ s:$: -fno-stack-protector-all:" \
211 -i "${S}"/mkspecs/common/g++.conf || die "sed ${S}/mkspecs/common/g++.conf failed"
212 fi 188 fi
213 189
214 # Bug 261632 190 # Bug 261632
215 if use ppc64; then 191 if use ppc64; then
216 ewarn "Appending -mminimal-toc to CFLAGS/CXXFLAGS"
217 append-flags -mminimal-toc 192 append-flags -mminimal-toc
218 fi 193 fi
219 194
220 # Bug 282984 && Bug 295530 195 # Bug 373061
221 sed -e "s:\(^SYSTEM_VARIABLES\):CC="$(tc-getCC)"\nCXX="$(tc-getCXX)"\nCFLAGS=\"${CFLAGS}\"\nCXXFLAGS=\"${CXXFLAGS}\"\nLDFLAGS=\"${LDFLAGS}\"\n\1:" \ 196 # qmake bus errors with -O2 or -O3 but -O1 works
222 -i configure || die "sed qmake compilers failed" 197 if [[ ${CHOST} == *86*-apple-darwin* ]]; then
223 # bug 321335 198 replace-flags -O[23] -O1
224 if version_is_at_least 4.6; then
225 find ./config.tests/unix -name "*.test" -type f -exec grep -lZ \$MAKE '{}' \; | \
226 xargs -0 \
227 sed -e "s:\(\$MAKE\):\1 CC="$(tc-getCC)" CXX="$(tc-getCXX)" LD="$(tc-getCXX)" LINK="$(tc-getCXX)":g" \
228 -i || die "sed test compilers failed"
229 fi 199 fi
200
201 # Bug 417105
202 # graphite on gcc 4.7 causes miscompilations
203 if [[ $(gcc-version) == "4.7" ]]; then
204 filter-flags -fgraphite-identity
205 fi
206
207 # Respect CC, CXX, {C,CXX,LD}FLAGS in .qmake.cache
208 sed -e "/^SYSTEM_VARIABLES=/i \
209 CC='$(tc-getCC)'\n\
210 CXX='$(tc-getCXX)'\n\
211 CFLAGS='${CFLAGS}'\n\
212 CXXFLAGS='${CXXFLAGS}'\n\
213 LDFLAGS='${LDFLAGS}'\n\
214 QMakeVar set QMAKE_CFLAGS_RELEASE\n\
215 QMakeVar set QMAKE_CFLAGS_DEBUG\n\
216 QMakeVar set QMAKE_CXXFLAGS_RELEASE\n\
217 QMakeVar set QMAKE_CXXFLAGS_DEBUG\n\
218 QMakeVar set QMAKE_LFLAGS_RELEASE\n\
219 QMakeVar set QMAKE_LFLAGS_DEBUG\n"\
220 -i configure \
221 || die "sed SYSTEM_VARIABLES failed"
222
223 # Respect CC, CXX, LINK and *FLAGS in config.tests
224 find config.tests/unix -name '*.test' -type f -print0 | xargs -0 \
225 sed -i -e "/bin\/qmake/ s: \"\$SRCDIR/: \
226 'QMAKE_CC=$(tc-getCC)' 'QMAKE_CXX=$(tc-getCXX)' 'QMAKE_LINK=$(tc-getCXX)' \
227 'QMAKE_CFLAGS+=${CFLAGS}' 'QMAKE_CXXFLAGS+=${CXXFLAGS}' 'QMAKE_LFLAGS+=${LDFLAGS}'&:" \
228 || die "sed config.tests failed"
230 229
231 # Bug 172219 230 # Bug 172219
232 sed -e "s:X11R6/::" \ 231 sed -e 's:/X11R6/:/:' -i mkspecs/$(qt_mkspecs_dir)/qmake.conf || die
233 -i "${S}"/mkspecs/$(qt_mkspecs_dir)/qmake.conf || die "sed ${S}/mkspecs/$(qt_mkspecs_dir)/qmake.conf failed"
234 232
235 if [[ ${CHOST} == *-darwin* ]]; then 233 if [[ ${CHOST} == *-darwin* ]]; then
236 # Set FLAGS *and* remove -arch, since our gcc-apple is multilib 234 # Set FLAGS *and* remove -arch, since our gcc-apple is multilib
237 # crippled (by design) :/ 235 # crippled (by design) :/
236 local mac_gpp_conf=
237 if [[ -f mkspecs/common/mac-g++.conf ]]; then
238 # qt < 4.8 has mac-g++.conf
239 mac_gpp_conf="mkspecs/common/mac-g++.conf"
240 elif [[ -f mkspecs/common/g++-macx.conf ]]; then
241 # qt >= 4.8 has g++-macx.conf
242 mac_gpp_conf="mkspecs/common/g++-macx.conf"
243 else
244 die "no known conf file for mac found"
245 fi
246 sed \
238 sed -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \ 247 -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \
239 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \ 248 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \
240 -e "s:QMAKE_LFLAGS_RELEASE.*=.*:QMAKE_LFLAGS_RELEASE=-headerpad_max_install_names ${LDFLAGS}:" \ 249 -e "s:QMAKE_LFLAGS_RELEASE.*=.*:QMAKE_LFLAGS_RELEASE=-headerpad_max_install_names ${LDFLAGS}:" \
241 -e "s:-arch\s\w*::g" \ 250 -e "s:-arch\s\w*::g" \
242 -i mkspecs/common/mac-g++.conf || die "sed mkspecs/common/mac-g++.conf failed" 251 -i ${mac_gpp_conf} \
252 || die "sed ${mac_gpp_conf} failed"
243 253
244 # Fix configure's -arch settings that appear in qmake/Makefile and also 254 # Fix configure's -arch settings that appear in qmake/Makefile and also
245 # fix arch handling (automagically duplicates our -arch arg and breaks 255 # fix arch handling (automagically duplicates our -arch arg and breaks
246 # pch). Additionally disable Xarch support. 256 # pch). Additionally disable Xarch support.
257 local mac_gcc_confs="${mac_gpp_conf}"
258 if [[ -f mkspecs/common/gcc-base-macx.conf ]]; then
259 mac_gcc_confs+=" mkspecs/common/gcc-base-macx.conf"
260 fi
247 sed \ 261 sed \
248 -e "s:-arch i386::" \ 262 -e "s:-arch i386::" \
249 -e "s:-arch ppc::" \ 263 -e "s:-arch ppc::" \
250 -e "s:-arch x86_64::" \ 264 -e "s:-arch x86_64::" \
251 -e "s:-arch ppc64::" \ 265 -e "s:-arch ppc64::" \
252 -e "s:-arch \$i::" \ 266 -e "s:-arch \$i::" \
253 -e "/if \[ ! -z \"\$NATIVE_64_ARCH\" \]; then/,/fi/ d" \ 267 -e "/if \[ ! -z \"\$NATIVE_64_ARCH\" \]; then/,/fi/ d" \
254 -e "s:CFG_MAC_XARCH=yes:CFG_MAC_XARCH=no:g" \ 268 -e "s:CFG_MAC_XARCH=yes:CFG_MAC_XARCH=no:g" \
255 -e "s:-Xarch_x86_64::g" \ 269 -e "s:-Xarch_x86_64::g" \
256 -e "s:-Xarch_ppc64::g" \ 270 -e "s:-Xarch_ppc64::g" \
257 -i configure mkspecs/common/mac-g++.conf || die "sed configure failed" 271 -i configure ${mac_gcc_confs} \
272 || die "sed -arch/-Xarch failed"
258 273
259 # On Snow Leopard don't fall back to 10.5 deployment target. 274 # On Snow Leopard don't fall back to 10.5 deployment target.
260 if [[ ${CHOST} == *-apple-darwin10 ]] ; then 275 if [[ ${CHOST} == *-apple-darwin10 ]]; then
261 sed -e "s:QMakeVar set QMAKE_MACOSX_DEPLOYMENT_TARGET.*:QMakeVar set QMAKE_MACOSX_DEPLOYMENT_TARGET 10.6:g" \ 276 sed -e "s:QMakeVar set QMAKE_MACOSX_DEPLOYMENT_TARGET.*:QMakeVar set QMAKE_MACOSX_DEPLOYMENT_TARGET 10.6:g" \
262 -e "s:-mmacosx-version-min=10.[0-9]:-mmacosx-version-min=10.6:g" \ 277 -e "s:-mmacosx-version-min=10.[0-9]:-mmacosx-version-min=10.6:g" \
263 -i configure mkspecs/common/mac-g++.conf || die "sed configure failed" 278 -i configure ${mac_gpp_conf} \
279 || die "sed deployment target failed"
264 fi 280 fi
265 fi 281 fi
266 282
267 # this one is needed for all systems with a separate -liconv, apart from 283 # this one is needed for all systems with a separate -liconv, apart from
268 # Darwin, for which the sources already cater for -liconv 284 # Darwin, for which the sources already cater for -liconv
269 if use !elibc_glibc && [[ ${CHOST} != *-darwin* ]] ; then 285 if use !elibc_glibc && [[ ${CHOST} != *-darwin* ]]; then
270 sed \ 286 sed -e 's|mac:\(LIBS += -liconv\)|\1|g' \
271 -e "s|mac:LIBS += -liconv|LIBS += -liconv|g" \
272 -i config.tests/unix/iconv/iconv.pro \ 287 -i config.tests/unix/iconv/iconv.pro \
273 || die "sed on iconv.pro failed" 288 || die "sed iconv.pro failed"
274 fi 289 fi
275 290
276 # we need some patches for Solaris 291 # we need some patches for Solaris
277 sed -i \
278 -e '/^QMAKE_LFLAGS_THREAD/a\QMAKE_LFLAGS_DYNAMIC_LIST = -Wl,--dynamic-list,' \ 292 sed -i -e '/^QMAKE_LFLAGS_THREAD/a\QMAKE_LFLAGS_DYNAMIC_LIST = -Wl,--dynamic-list,' \
279 mkspecs/$(qt_mkspecs_dir)/qmake.conf || die 293 mkspecs/$(qt_mkspecs_dir)/qmake.conf || die
280 # use GCC over SunStudio 294 # use GCC over SunStudio
281 sed -i -e '/PLATFORM=solaris-cc/s/cc/g++/' configure || die 295 sed -i -e '/PLATFORM=solaris-cc/s/cc/g++/' configure || die
282 # don't flirt with non-Prefix stuff, we're quite possessive 296 # do not flirt with non-Prefix stuff, we're quite possessive
283 sed -i -e '/^QMAKE_\(LIB\|INC\)DIR\(_X11\|_OPENGL\|\)\t/s/=.*$/=/' \ 297 sed -i -e '/^QMAKE_\(LIB\|INC\)DIR\(_X11\|_OPENGL\|\)\t/s/=.*$/=/' \
284 mkspecs/$(qt_mkspecs_dir)/qmake.conf || die 298 mkspecs/$(qt_mkspecs_dir)/qmake.conf || die
285 # strip predefined CFLAGS from qmake ( bug #312689 )
286 sed -i '/^QMAKE_CFLAGS_RELEASE/s:+=.*:+=:' mkspecs/common/g++.conf
287 299
288 base_src_prepare 300 # apply patches
301 [[ -n ${PATCHES[@]} ]] && epatch "${PATCHES[@]}"
302 epatch_user
289} 303}
290 304
291# @FUNCTION: qt4-build_src_configure 305# @FUNCTION: qt4-build_src_configure
292# @DESCRIPTION: 306# @DESCRIPTION:
293# Default configure phase 307# Default configure phase
294qt4-build_src_configure() { 308qt4-build_src_configure() {
295 setqtenv 309 setqtenv
296 myconf="$(standard_configure_options) ${myconf}" 310
311 local conf="
312 -prefix ${QTPREFIXDIR}
313 -bindir ${QTBINDIR}
314 -libdir ${QTLIBDIR}
315 -docdir ${QTDOCDIR}
316 -headerdir ${QTHEADERDIR}
317 -plugindir ${QTPLUGINDIR}
318 -importdir ${QTIMPORTDIR}
319 -datadir ${QTDATADIR}
320 -translationdir ${QTTRANSDIR}
321 -sysconfdir ${QTSYSCONFDIR}
322 -examplesdir ${QTEXAMPLESDIR}
323 -demosdir ${QTDEMOSDIR}
324 -opensource -confirm-license
325 -shared -fast -largefile -stl -verbose
326 -nomake examples -nomake demos"
327
328 # ARCH is set on Gentoo. Qt now falls back to generic on an unsupported
329 # $(tc-arch). Therefore we convert it to supported values.
330 case "$(tc-arch)" in
331 amd64|x64-*) conf+=" -arch x86_64" ;;
332 ppc-macos) conf+=" -arch ppc" ;;
333 ppc|ppc64|ppc-*) conf+=" -arch powerpc" ;;
334 sparc|sparc-*|sparc64-*) conf+=" -arch sparc" ;;
335 x86-macos) conf+=" -arch x86" ;;
336 x86|x86-*) conf+=" -arch i386" ;;
337 alpha|arm|ia64|mips|s390) conf+=" -arch $(tc-arch)" ;;
338 hppa|sh) conf+=" -arch generic" ;;
339 *) die "$(tc-arch) is unsupported by this eclass. Please file a bug." ;;
340 esac
341
342 conf+=" -platform $(qt_mkspecs_dir)"
343
344 [[ $(get_libdir) != lib ]] && conf+=" -L${EPREFIX}/usr/$(get_libdir)"
345
346 # debug/release
347 if use debug; then
348 conf+=" -debug"
349 else
350 conf+=" -release"
351 fi
352 conf+=" -no-separate-debug-info"
353
354 # exceptions USE flag
355 conf+=" $(in_iuse exceptions && qt_use exceptions || echo -exceptions)"
356
357 # disable rpath (bug 380415), except on prefix (bug 417169)
358 use prefix || conf+=" -no-rpath"
359
360 # precompiled headers don't work on hardened, where the flag is masked
361 conf+=" $(qt_use pch)"
362
363 # -reduce-relocations
364 # This flag seems to introduce major breakage to applications,
365 # mostly to be seen as a core dump with the message "QPixmap: Must
366 # construct a QApplication before a QPaintDevice" on Solaris.
367 # -- Daniel Vergien
368 [[ ${CHOST} != *-solaris* ]] && conf+=" -reduce-relocations"
297 369
298 # this one is needed for all systems with a separate -liconv, apart from 370 # this one is needed for all systems with a separate -liconv, apart from
299 # Darwin, for which the sources already cater for -liconv 371 # Darwin, for which the sources already cater for -liconv
300 use !elibc_glibc && [[ ${CHOST} != *-darwin* ]] && \ 372 if use !elibc_glibc && [[ ${CHOST} != *-darwin* ]]; then
301 myconf+=" -liconv" 373 conf+=" -liconv"
374 fi
302 375
303 if has glib ${IUSE//+} && use glib; then 376 if use_if_iuse glib; then
304 # use -I, -L and -l from configure
305 local glibflags="$(pkg-config --cflags --libs glib-2.0 gthread-2.0)" 377 local glibflags="$(pkg-config --cflags --libs glib-2.0 gthread-2.0)"
306 # avoid the -pthread argument 378 # avoid the -pthread argument
307 myconf+=" ${glibflags//-pthread}" 379 conf+=" ${glibflags//-pthread}"
308 unset glibflags 380 unset glibflags
309 fi 381 fi
310 382
311 if use aqua ; then 383 if use aqua; then
312 # On (snow) leopard use the new (frameworked) cocoa code. 384 # On (snow) leopard use the new (frameworked) cocoa code.
313 if [[ ${CHOST##*-darwin} -ge 9 ]] ; then 385 if [[ ${CHOST##*-darwin} -ge 9 ]]; then
314 myconf+=" -cocoa -framework" 386 conf+=" -cocoa -framework"
387 # We need the source's headers, not the installed ones.
388 conf+=" -I${S}/include"
389 # Add hint for the framework location.
390 conf+=" -F${QTLIBDIR}"
315 391
316 # We are crazy and build cocoa + qt3support :-) 392 # We are crazy and build cocoa + qt3support :-)
317 if use qt3support; then 393 if use qt3support; then
318 sed -e "/case \"\$PLATFORM,\$CFG_MAC_COCOA\" in/,/;;/ s|CFG_QT3SUPPORT=\"no\"|CFG_QT3SUPPORT=\"yes\"|" \ 394 sed -e "/case \"\$PLATFORM,\$CFG_MAC_COCOA\" in/,/;;/ s|CFG_QT3SUPPORT=\"no\"|CFG_QT3SUPPORT=\"yes\"|" \
319 -i configure 395 -i configure || die
320 fi 396 fi
321 397 else
322 # We need the source's headers, not the installed ones. 398 conf+=" -no-framework"
323 myconf+=" -I${S}/include"
324
325 # Add hint for the framework location.
326 myconf+=" -F${QTLIBDIR}"
327 fi 399 fi
328 else 400 else
329 # freetype2 include dir is non-standard, thus include it on configure 401 # freetype2 include dir is non-standard, thus pass it to configure
330 # use -I from configure
331 myconf+=" $(pkg-config --cflags freetype2)" 402 conf+=" $(pkg-config --cflags-only-I freetype2)"
332 fi 403 fi
333 404
334 # Disable SSE4.x, since auto-detection is currently broken 405 conf+=" ${myconf}"
335 # Upstream bug http://bugreports.qt.nokia.com/browse/QTBUG-13623 406 myconf=
336 if version_is_at_least 4.7.1; then
337 myconf+=" -no-sse4.1 -no-sse4.2"
338 fi
339 407
340 echo ./configure ${myconf} 408 echo ./configure ${conf}
341 ./configure ${myconf} || die "./configure failed" 409 ./configure ${conf} || die "./configure failed"
342 myconf="" 410
411 prepare_directories ${QT4_TARGET_DIRECTORIES}
343} 412}
344 413
345# @FUNCTION: qt4-build_src_compile 414# @FUNCTION: qt4-build_src_compile
415# @DESCRIPTION:
346# @DESCRIPTION: Actual compile phase 416# Actual compile phase
347qt4-build_src_compile() { 417qt4-build_src_compile() {
348 setqtenv 418 setqtenv
349 419
350 build_directories ${QT4_TARGET_DIRECTORIES} 420 build_directories ${QT4_TARGET_DIRECTORIES}
351} 421}
352 422
353# @FUNCTION: qt4-build_src_test 423# @FUNCTION: qt4-build_src_test
354# @DESCRIPTION: 424# @DESCRIPTION:
355# Runs tests only in target directories. 425# Runs tests only in target directories.
356qt4-build_src_test() { 426qt4-build_src_test() {
427 # QtMultimedia does not have any test suite (bug #332299)
428 [[ ${CATEGORY}/${PN} == dev-qt/qtmultimedia ]] && return
429
357 for dir in ${QT4_TARGET_DIRECTORIES}; do 430 for dir in ${QT4_TARGET_DIRECTORIES}; do
358 emake -j1 check -C ${dir} 431 emake -j1 check -C ${dir}
359 done 432 done
360} 433}
361 434
362# @FUNCTION: fix_includes 435# @FUNCTION: fix_includes
363# @DESCRIPTION: 436# @DESCRIPTION:
364# For MacOSX we need to add some symlinks when frameworks are 437# For MacOS X we need to add some symlinks when frameworks are
365# being used, to avoid complications with some more or less stupid packages. 438# being used, to avoid complications with some more or less stupid packages.
366fix_includes() { 439fix_includes() {
367 if use aqua && [[ ${CHOST##*-darwin} -ge 9 ]] ; then 440 if use aqua && [[ ${CHOST##*-darwin} -ge 9 ]]; then
441 local frw dest f h rdir
368 # Some packages tend to include <Qt/...> 442 # Some packages tend to include <Qt/...>
369 dodir "${QTHEADERDIR#${EPREFIX}}"/Qt 443 dodir "${QTHEADERDIR#${EPREFIX}}"/Qt
370 444
371 # Fake normal headers when frameworks are installed... eases life later on 445 # Fake normal headers when frameworks are installed... eases life later
372 local dest f 446 # on, make sure we use relative links though, as some ebuilds assume
447 # these dirs exist in src_install to add additional files
448 f=${QTHEADERDIR}
449 h=${QTLIBDIR}
450 while [[ -n ${f} && ${f%%/*} == ${h%%/*} ]] ; do
451 f=${f#*/}
452 h=${h#*/}
453 done
454 rdir=${h}
455 f="../"
456 while [[ ${h} == */* ]] ; do
457 f="${f}../"
458 h=${h#*/}
459 done
460 rdir="${f}${rdir}"
461
373 for frw in "${D}${QTLIBDIR}"/*.framework; do 462 for frw in "${D}${QTLIBDIR}"/*.framework; do
374 [[ -e "${frw}"/Headers ]] || continue 463 [[ -e "${frw}"/Headers ]] || continue
375 f=$(basename ${frw}) 464 f=$(basename ${frw})
376 dest="${QTHEADERDIR#${EPREFIX}}"/${f%.framework} 465 dest="${QTHEADERDIR#${EPREFIX}}"/${f%.framework}
377 dosym "${QTLIBDIR#${EPREFIX}}"/${f}/Headers "${dest}" 466 dosym "${rdir}"/${f}/Headers "${dest}"
378 467
379 # Link normal headers as well. 468 # Link normal headers as well.
380 for hdr in "${D}/${QTLIBDIR}/${f}"/Headers/*; do 469 for hdr in "${D}/${QTLIBDIR}/${f}"/Headers/*; do
381 h=$(basename ${hdr}) 470 h=$(basename ${hdr})
382 dosym "${QTLIBDIR#${EPREFIX}}"/${f}/Headers/${h} "${QTHEADERDIR#${EPREFIX}}"/Qt/${h} 471 dosym "../${rdir}"/${f}/Headers/${h} \
472 "${QTHEADERDIR#${EPREFIX}}"/Qt/${h}
383 done 473 done
384 done 474 done
385 fi 475 fi
386} 476}
387 477
388# @FUNCTION: qt4-build_src_install 478# @FUNCTION: qt4-build_src_install
389# @DESCRIPTION: 479# @DESCRIPTION:
390# Perform the actual installation including some library fixes. 480# Perform the actual installation including some library fixes.
391qt4-build_src_install() { 481qt4-build_src_install() {
392 [[ ${EAPI} == 2 ]] && use !prefix && ED=${D}
393 setqtenv 482 setqtenv
483
394 install_directories ${QT4_TARGET_DIRECTORIES} 484 install_directories ${QT4_TARGET_DIRECTORIES}
395 install_qconfigs 485 install_qconfigs
396 fix_library_files 486 fix_library_files
397 fix_includes 487 fix_includes
488
398 # remove .la files since we are building only shared Qt libraries 489 # remove .la files since we are building only shared libraries
399 find "${D}"${QTLIBDIR} -name "*.la" -print0 | xargs -0 rm 490 prune_libtool_files
400} 491}
401 492
402# @FUNCTION: setqtenv 493# @FUNCTION: setqtenv
494# @INTERNAL
403setqtenv() { 495setqtenv() {
404 # Set up installation directories 496 # Set up installation directories
405 QTBASEDIR=${EPREFIX}/usr/$(get_libdir)/qt4
406 QTPREFIXDIR=${EPREFIX}/usr 497 QTPREFIXDIR=${EPREFIX}/usr
407 QTBINDIR=${EPREFIX}/usr/bin 498 QTBINDIR=${QTPREFIXDIR}/bin
408 QTLIBDIR=${EPREFIX}/usr/$(get_libdir)/qt4 499 QTLIBDIR=${QTPREFIXDIR}/$(get_libdir)/qt4
409 QMAKE_LIBDIR_QT=${QTLIBDIR}
410 QTPCDIR=${EPREFIX}/usr/$(get_libdir)/pkgconfig 500 QTPCDIR=${QTPREFIXDIR}/$(get_libdir)/pkgconfig
411 QTDATADIR=${EPREFIX}/usr/share/qt4
412 QTDOCDIR=${EPREFIX}/usr/share/doc/qt-${PV} 501 QTDOCDIR=${QTPREFIXDIR}/share/doc/qt-${PV}
413 QTHEADERDIR=${EPREFIX}/usr/include/qt4 502 QTHEADERDIR=${QTPREFIXDIR}/include/qt4
414 QTPLUGINDIR=${QTLIBDIR}/plugins 503 QTPLUGINDIR=${QTLIBDIR}/plugins
504 QTIMPORTDIR=${QTLIBDIR}/imports
505 QTDATADIR=${QTPREFIXDIR}/share/qt4
506 QTTRANSDIR=${QTDATADIR}/translations
415 QTSYSCONFDIR=${EPREFIX}/etc/qt4 507 QTSYSCONFDIR=${EPREFIX}/etc/qt4
416 QTTRANSDIR=${QTDATADIR}/translations
417 QTEXAMPLESDIR=${QTDATADIR}/examples 508 QTEXAMPLESDIR=${QTDATADIR}/examples
418 QTDEMOSDIR=${QTDATADIR}/demos 509 QTDEMOSDIR=${QTDATADIR}/demos
419 QT_INSTALL_PREFIX=${EPREFIX}/usr/$(get_libdir)/qt4 510 QMAKE_LIBDIR_QT=${QTLIBDIR}
511
420 PLATFORM=$(qt_mkspecs_dir) 512 PLATFORM=$(qt_mkspecs_dir)
421
422 unset QMAKESPEC 513 unset QMAKESPEC
423}
424 514
425# @FUNCTION: standard_configure_options 515 export XDG_CONFIG_HOME="${T}"
426# @DESCRIPTION: 516}
427# Sets up some standard configure options, like libdir (if necessary), whether
428# debug info is wanted or not.
429standard_configure_options() {
430 local myconf=
431 517
432 [[ $(get_libdir) != lib ]] && myconf+=" -L${EPREFIX}/usr/$(get_libdir)" 518# @FUNCTION: prepare_directories
433 519# @USAGE: < directories >
434 # Disable visibility explicitly if gcc version isn't 4 520# @INTERNAL
435 if [[ $(gcc-major-version) -lt 4 ]]; then 521# @DESCRIPTION:
436 myconf+=" -no-reduce-exports" 522# Generates Makefiles for the given list of directories.
437 fi 523prepare_directories() {
438 524 for x in "$@"; do
439 # precompiled headers doesn't work on hardened, where the flag is masked. 525 pushd "${S}"/${x} >/dev/null || die
440 myconf+=" $(qt_use pch)" 526 einfo "Running qmake in: ${x}"
441 527 "${S}"/bin/qmake \
442 if use debug; then 528 "LIBS+=-L${QTLIBDIR}" \
443 myconf+=" -debug" 529 "CONFIG+=nostrip" \
444 else 530 || die "qmake failed"
445 myconf+=" -release" 531 popd >/dev/null || die
446 fi 532 done
447 myconf+=" -no-separate-debug-info"
448
449 use aqua && myconf+=" -no-framework"
450
451 # ARCH is set on Gentoo. Qt now falls back to generic on an unsupported
452 # $(tc-arch). Therefore we convert it to supported values.
453 case "$(tc-arch)" in
454 amd64|x64-*) myconf+=" -arch x86_64" ;;
455 ppc-macos) myconf+=" -arch ppc" ;;
456 ppc|ppc64|ppc-*) myconf+=" -arch powerpc" ;;
457 sparc|sparc-*) myconf+=" -arch sparc" ;;
458 x86-macos) myconf+=" -arch x86" ;;
459 x86|x86-*) myconf+=" -arch i386" ;;
460 alpha|arm|ia64|mips|s390|sparc) myconf+=" -arch $(tc-arch)" ;;
461 hppa|sh) myconf+=" -arch generic" ;;
462 *) die "$(tc-arch) is unsupported by this eclass. Please file a bug." ;;
463 esac
464
465 # 4.5: build everything but qt-xmlpatterns w/o exceptions
466 # 4.6: exceptions USE flag
467 local exceptions="-exceptions"
468 case "${PV}" in
469 4.5.*)
470 [[ ${PN} == "qt-xmlpatterns" ]] || exceptions="-no-exceptions"
471 ;;
472 *)
473 has exceptions "${IUSE//+}" && exceptions="$(qt_use exceptions)"
474 ;;
475 esac
476
477 # note about -reduce-relocations:
478 # That flag seems to introduce major breakage to applications,
479 # mostly to be seen as a core dump with the message "QPixmap: Must
480 # construct a QApplication before a QPaintDevice" on Solaris
481 # -- Daniel Vergien
482 [[ ${CHOST} != *-solaris* ]] && myconf+=" -reduce-relocations"
483
484 myconf+=" -platform $(qt_mkspecs_dir) -stl -verbose -largefile -confirm-license
485 -prefix ${QTPREFIXDIR} -bindir ${QTBINDIR} -libdir ${QTLIBDIR}
486 -datadir ${QTDATADIR} -docdir ${QTDOCDIR} -headerdir ${QTHEADERDIR}
487 -plugindir ${QTPLUGINDIR} -sysconfdir ${QTSYSCONFDIR}
488 -translationdir ${QTTRANSDIR} -examplesdir ${QTEXAMPLESDIR}
489 -demosdir ${QTDEMOSDIR} -silent -fast -opensource
490 ${exceptions}
491 -nomake examples -nomake demos"
492
493 echo "${myconf}"
494} 533}
495 534
496# @FUNCTION: build_directories 535# @FUNCTION: build_directories
497# @USAGE: < directories > 536# @USAGE: < directories >
537# @INTERNAL
498# @DESCRIPTION: 538# @DESCRIPTION:
499# Compiles the code in $QT4_TARGET_DIRECTORIES 539# Compiles the code in the given list of directories.
500build_directories() { 540build_directories() {
501 for x in "$@"; do 541 for x in "$@"; do
502 pushd "${S}"/${x} >/dev/null 542 pushd "${S}"/${x} >/dev/null || die
503 # avoid running over the maximum argument number, bug #299810 543 emake \
504 { 544 AR="$(tc-getAR) cqs" \
505 echo "${S}"/mkspecs/common/*.conf
506 find "${S}" -name '*.pr[io]'
507 } | xargs sed -i -e "s:\$\$\[QT_INSTALL_LIBS\]:${EPREFIX}/usr/$(get_libdir)/qt4:g" || die
508 "${S}"/bin/qmake "LIBS+=-L${QTLIBDIR}" "CONFIG+=nostrip" || die "qmake failed"
509 emake CC="$(tc-getCC)" \ 545 CC="$(tc-getCC)" \
510 CXX="$(tc-getCXX)" \ 546 CXX="$(tc-getCXX)" \
511 LINK="$(tc-getCXX)" || die "emake failed" 547 LINK="$(tc-getCXX)" \
548 RANLIB=":" \
549 STRIP=":"
512 popd >/dev/null 550 popd >/dev/null || die
513 done 551 done
514} 552}
515 553
516# @FUNCTION: install_directories 554# @FUNCTION: install_directories
517# @USAGE: < directories > 555# @USAGE: < directories >
556# @INTERNAL
518# @DESCRIPTION: 557# @DESCRIPTION:
519# run emake install in the given directories, which are separated by spaces 558# Runs emake install in the given directories, which are separated by spaces.
520install_directories() { 559install_directories() {
521 for x in "$@"; do 560 for x in "$@"; do
522 pushd "${S}"/${x} >/dev/null || die "Can't pushd ${S}/${x}" 561 pushd "${S}"/${x} >/dev/null || die
523 emake INSTALL_ROOT="${D}" install || die "emake install failed" 562 emake INSTALL_ROOT="${D}" install
524 popd >/dev/null || die "Can't popd from ${S}/${x}" 563 popd >/dev/null || die
525 done 564 done
526} 565}
527 566
528# @ECLASS-VARIABLE: QCONFIG_ADD 567# @ECLASS-VARIABLE: QCONFIG_ADD
529# @DESCRIPTION: 568# @DESCRIPTION:
539# @DESCRIPTION: 578# @DESCRIPTION:
540# List variables that should be defined at the top of QtCore/qconfig.h 579# List variables that should be defined at the top of QtCore/qconfig.h
541: ${QCONFIG_DEFINE:=} 580: ${QCONFIG_DEFINE:=}
542 581
543# @FUNCTION: install_qconfigs 582# @FUNCTION: install_qconfigs
583# @INTERNAL
584# @DESCRIPTION:
544# @DESCRIPTION: Install gentoo-specific mkspecs configurations 585# Install gentoo-specific mkspecs configurations.
545install_qconfigs() { 586install_qconfigs() {
546 local x 587 local x
547 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} ]]; then 588 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} ]]; then
548 for x in QCONFIG_ADD QCONFIG_REMOVE; do 589 for x in QCONFIG_ADD QCONFIG_REMOVE; do
549 [[ -n ${!x} ]] && echo ${x}=${!x} >> "${T}"/${PN}-qconfig.pri 590 [[ -n ${!x} ]] && echo ${x}=${!x} >> "${T}"/${PN}-qconfig.pri
550 done 591 done
551 insinto ${QTDATADIR#${EPREFIX}}/mkspecs/gentoo 592 insinto ${QTDATADIR#${EPREFIX}}/mkspecs/gentoo
552 doins "${T}"/${PN}-qconfig.pri || die "installing ${PN}-qconfig.pri failed" 593 doins "${T}"/${PN}-qconfig.pri
553 fi 594 fi
554 595
555 if [[ -n ${QCONFIG_DEFINE} ]]; then 596 if [[ -n ${QCONFIG_DEFINE} ]]; then
556 for x in ${QCONFIG_DEFINE}; do 597 for x in ${QCONFIG_DEFINE}; do
557 echo "#define ${x}" >> "${T}"/gentoo-${PN}-qconfig.h 598 echo "#define ${x}" >> "${T}"/gentoo-${PN}-qconfig.h
558 done 599 done
559 insinto ${QTHEADERDIR#${EPREFIX}}/Gentoo 600 insinto ${QTHEADERDIR#${EPREFIX}}/Gentoo
560 doins "${T}"/gentoo-${PN}-qconfig.h || die "installing ${PN}-qconfig.h failed" 601 doins "${T}"/gentoo-${PN}-qconfig.h
561 fi 602 fi
562} 603}
563 604
564# @FUNCTION: generate_qconfigs 605# @FUNCTION: generate_qconfigs
565# @DESCRIPTION: Generates gentoo-specific configurations 606# @INTERNAL
607# @DESCRIPTION:
608# Generates gentoo-specific qconfig.{h,pri}.
566generate_qconfigs() { 609generate_qconfigs() {
567 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} || -n ${QCONFIG_DEFINE} || ${CATEGORY}/${PN} == x11-libs/qt-core ]]; then 610 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} || -n ${QCONFIG_DEFINE} || ${CATEGORY}/${PN} == dev-qt/qtcore ]]; then
568 local x qconfig_add qconfig_remove qconfig_new 611 local x qconfig_add qconfig_remove qconfig_new
569 for x in "${ROOT}${QTDATADIR}"/mkspecs/gentoo/*-qconfig.pri; do 612 for x in "${ROOT}${QTDATADIR}"/mkspecs/gentoo/*-qconfig.pri; do
570 [[ -f ${x} ]] || continue 613 [[ -f ${x} ]] || continue
571 qconfig_add+=" $(sed -n 's/^QCONFIG_ADD=//p' "${x}")" 614 qconfig_add+=" $(sed -n 's/^QCONFIG_ADD=//p' "${x}")"
572 qconfig_remove+=" $(sed -n 's/^QCONFIG_REMOVE=//p' "${x}")" 615 qconfig_remove+=" $(sed -n 's/^QCONFIG_REMOVE=//p' "${x}")"
573 done 616 done
574 617
575 # these error checks do not use die because dying in pkg_post{inst,rm} 618 # these error checks do not use die because dying in pkg_post{inst,rm}
576 # just makes things worse. 619 # just makes things worse.
577 if [[ -e "${ROOT}${QTDATADIR}"/mkspecs/gentoo/qconfig.pri ]]; then 620 if [[ -e "${ROOT}${QTDATADIR}"/mkspecs/gentoo/qconfig.pri ]]; then
578 # start with the qconfig.pri that qt-core installed 621 # start with the qconfig.pri that qtcore installed
579 if ! cp "${ROOT}${QTDATADIR}"/mkspecs/gentoo/qconfig.pri \ 622 if ! cp "${ROOT}${QTDATADIR}"/mkspecs/gentoo/qconfig.pri \
580 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri; then 623 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri; then
581 eerror "cp qconfig failed." 624 eerror "cp qconfig failed."
582 return 1 625 return 1
583 fi 626 fi
584 627
585 # generate list of QT_CONFIG entries from the existing list 628 # generate list of QT_CONFIG entries from the existing list
586 # including qconfig_add and excluding qconfig_remove 629 # including qconfig_add and excluding qconfig_remove
587 for x in $(sed -n 's/^QT_CONFIG +=//p' \ 630 for x in $(sed -n 's/^QT_CONFIG +=//p' \
588 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri) ${qconfig_add}; do 631 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri) ${qconfig_add}; do
589 hasq ${x} ${qconfig_remove} || qconfig_new+=" ${x}" 632 has ${x} ${qconfig_remove} || qconfig_new+=" ${x}"
590 done 633 done
591 634
592 # replace the existing QT_CONFIG list with qconfig_new 635 # replace the existing QT_CONFIG list with qconfig_new
593 if ! sed -i -e "s/QT_CONFIG +=.*/QT_CONFIG += ${qconfig_new}/" \ 636 if ! sed -i -e "s/QT_CONFIG +=.*/QT_CONFIG += ${qconfig_new}/" \
594 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri; then 637 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri; then
618 fi 661 fi
619 fi 662 fi
620} 663}
621 664
622# @FUNCTION: qt4-build_pkg_postrm 665# @FUNCTION: qt4-build_pkg_postrm
666# @DESCRIPTION:
623# @DESCRIPTION: Generate configurations when the package is completely removed 667# Regenerate configuration when the package is completely removed.
624qt4-build_pkg_postrm() { 668qt4-build_pkg_postrm() {
625 generate_qconfigs 669 generate_qconfigs
626} 670}
627 671
628# @FUNCTION: qt4-build_pkg_postinst 672# @FUNCTION: qt4-build_pkg_postinst
673# @DESCRIPTION:
629# @DESCRIPTION: Generate configuration, plus throws a message about possible 674# Regenerate configuration, plus throw a message about possible
630# breakages and proposed solutions. 675# breakages and proposed solutions.
631qt4-build_pkg_postinst() { 676qt4-build_pkg_postinst() {
632 generate_qconfigs 677 generate_qconfigs
633} 678}
634 679
635# @FUNCTION: skip_qmake_build_patch 680# @FUNCTION: skip_qmake_build
681# @INTERNAL
636# @DESCRIPTION: 682# @DESCRIPTION:
637# Don't need to build qmake, as it's already installed from qt-core 683# Patches configure to skip qmake compilation, as it's already installed by qtcore.
638skip_qmake_build_patch() { 684skip_qmake_build() {
639 # Don't need to build qmake, as it's already installed from qt-core
640 sed -i -e "s:if true:if false:g" "${S}"/configure || die "Sed failed" 685 sed -i -e "s:if true:if false:g" "${S}"/configure || die
641} 686}
642 687
643# @FUNCTION: skip_project_generation_patch 688# @FUNCTION: skip_project_generation
689# @INTERNAL
644# @DESCRIPTION: 690# @DESCRIPTION:
645# Exit the script early by throwing in an exit before all of the .pro files are scanned 691# Exit the script early by throwing in an exit before all of the .pro files are scanned.
646skip_project_generation_patch() { 692skip_project_generation() {
647 # Exit the script early by throwing in an exit before all of the .pro files are scanned
648 sed -e "s:echo \"Finding:exit 0\n\necho \"Finding:g" \ 693 sed -i -e "s:echo \"Finding:exit 0\n\necho \"Finding:g" "${S}"/configure || die
649 -i "${S}"/configure || die "Sed failed"
650} 694}
651 695
652# @FUNCTION: symlink_binaries_to_buildtree 696# @FUNCTION: symlink_binaries_to_buildtree
697# @INTERNAL
653# @DESCRIPTION: 698# @DESCRIPTION:
654# Symlink generated binaries to buildtree so they can be used during compilation 699# Symlinks generated binaries to buildtree, so they can be used during compilation time.
655# time
656symlink_binaries_to_buildtree() { 700symlink_binaries_to_buildtree() {
657 for bin in qmake moc uic rcc; do 701 for bin in qmake moc uic rcc; do
658 ln -s ${QTBINDIR}/${bin} "${S}"/bin/ || die "Symlinking ${bin} to ${S}/bin failed." 702 ln -s "${QTBINDIR}"/${bin} "${S}"/bin/ || die "symlinking ${bin} to ${S}/bin failed"
659 done 703 done
660} 704}
661 705
662# @FUNCTION: fix_library_files 706# @FUNCTION: fix_library_files
707# @INTERNAL
663# @DESCRIPTION: 708# @DESCRIPTION:
664# Fixes the pathes in *.la, *.prl, *.pc, as they are wrong due to sandbox and 709# Fixes the paths in *.la, *.prl, *.pc, as they are wrong due to sandbox and
665# moves the *.pc-files into the pkgconfig directory 710# moves the *.pc files into the pkgconfig directory.
666fix_library_files() { 711fix_library_files() {
712 local libfile
667 for libfile in "${D}"/${QTLIBDIR}/{*.la,*.prl,pkgconfig/*.pc}; do 713 for libfile in "${D}"/${QTLIBDIR}/{*.la,*.prl,pkgconfig/*.pc}; do
668 if [[ -e ${libfile} ]]; then 714 if [[ -e ${libfile} ]]; then
669 sed -i -e "s:${S}/lib:${QTLIBDIR}:g" ${libfile} || die "Sed on ${libfile} failed." 715 sed -i -e "s:${S}/lib:${QTLIBDIR}:g" ${libfile} || die "sed on ${libfile} failed"
670 fi 716 fi
671 done 717 done
672 718
673 # pkgconfig files refer to WORKDIR/bin as the moc and uic locations. Fix: 719 # pkgconfig files refer to WORKDIR/bin as the moc and uic locations
674 for libfile in "${D}"/${QTLIBDIR}/pkgconfig/*.pc; do 720 for libfile in "${D}"/${QTLIBDIR}/pkgconfig/*.pc; do
675 if [[ -e ${libfile} ]]; then 721 if [[ -e ${libfile} ]]; then
676 sed -i -e "s:${S}/bin:${QTBINDIR}:g" ${libfile} || die "Sed failed" 722 sed -i -e "s:${S}/bin:${QTBINDIR}:g" ${libfile} || die "sed on ${libfile} failed"
677 723
678 # Move .pc files into the pkgconfig directory 724 # Move .pc files into the pkgconfig directory
679 dodir ${QTPCDIR#${EPREFIX}} 725 dodir ${QTPCDIR#${EPREFIX}}
680 mv ${libfile} "${D}"/${QTPCDIR}/ \ 726 mv ${libfile} "${D}"/${QTPCDIR}/ || die "moving ${libfile} to ${D}/${QTPCDIR}/ failed"
681 || die "Moving ${libfile} to ${D}/${QTPCDIR}/ failed."
682 fi 727 fi
683 done 728 done
684 729
685 # Don't install an empty directory 730 # Don't install an empty directory
686 rmdir "${D}"/${QTLIBDIR}/pkgconfig 731 rmdir "${D}"/${QTLIBDIR}/pkgconfig
687} 732}
688 733
689# @FUNCTION: qt_use 734# @FUNCTION: qt_use
690# @USAGE: < flag > [ feature ] [ enableval ] 735# @USAGE: < flag > [ feature ] [ enableval ]
691# @DESCRIPTION: 736# @DESCRIPTION:
692# This will echo "${enableval}-${feature}" if <flag> is enabled, or 737# This will echo "-${enableval}-${feature}" if <flag> is enabled, or
693# "-no-${feature} if the flag is disabled. If [feature] is not specified <flag> 738# "-no-${feature}" if it's disabled. If [feature] is not specified, <flag>
694# will be used for that. If [enableval] is not specified, it omits the 739# will be used for that. If [enableval] is not specified, it omits the
695# assignment-part 740# "-${enableval}" part.
696qt_use() { 741qt_use() {
697 local flag=$1 742 use "$1" && echo "${3:+-$3}-${2:-$1}" || echo "-no-${2:-$1}"
698 local feature=$1
699 local enableval=
700
701 [[ -n $2 ]] && feature=$2
702 [[ -n $3 ]] && enableval=-$3
703
704 if use ${flag}; then
705 echo "${enableval}-${feature}"
706 else
707 echo "-no-${feature}"
708 fi
709} 743}
710 744
711# @FUNCTION: qt_mkspecs_dir 745# @FUNCTION: qt_mkspecs_dir
712# @RETURN: the specs-directory w/o path 746# @RETURN: the specs-directory w/o path
713# @DESCRIPTION: 747# @DESCRIPTION:
714# Allows us to define which mkspecs dir we want to use. 748# Allows us to define which mkspecs dir we want to use.
715qt_mkspecs_dir() { 749qt_mkspecs_dir() {
716 # Allows us to define which mkspecs dir we want to use.
717 local spec 750 local spec=
718 751
719 case ${CHOST} in 752 case "${CHOST}" in
720 *-freebsd*|*-dragonfly*) 753 *-freebsd*|*-dragonfly*)
721 spec=freebsd ;; 754 spec=freebsd ;;
722 *-openbsd*) 755 *-openbsd*)
723 spec=openbsd ;; 756 spec=openbsd ;;
724 *-netbsd*) 757 *-netbsd*)
735 *-solaris*) 768 *-solaris*)
736 spec=solaris ;; 769 spec=solaris ;;
737 *-linux-*|*-linux) 770 *-linux-*|*-linux)
738 spec=linux ;; 771 spec=linux ;;
739 *) 772 *)
740 die "Unknown CHOST, no platform choosen." 773 die "${FUNCNAME}(): Unknown CHOST '${CHOST}'" ;;
741 esac 774 esac
742 775
743 CXX=$(tc-getCXX) 776 case "$(tc-getCXX)" in
744 if [[ ${CXX} == *g++* ]]; then 777 *g++*)
745 spec+=-g++ 778 spec+=-g++ ;;
746 elif [[ ${CXX} == *icpc* ]]; then 779 *icpc*)
747 spec+=-icc 780 spec+=-icc ;;
748 else 781 *)
749 die "Unknown compiler ${CXX}." 782 die "${FUNCNAME}(): Unknown compiler '$(tc-getCXX)'" ;;
750 fi 783 esac
751 if [[ -n ${LIBDIR/lib} ]]; then
752 spec+=-${LIBDIR/lib}
753 fi
754 784
755 # Add -64 for 64bit profiles 785 # Add -64 for 64bit profiles
756 if use x64-freebsd || 786 if use x64-freebsd ||
757 use amd64-linux || 787 use amd64-linux ||
758 use x64-macos || 788 use x64-macos ||
763 fi 793 fi
764 794
765 echo "${spec}" 795 echo "${spec}"
766} 796}
767 797
768# @FUNCTION: qt_assistant_cleanup
769# @RETURN: nothing
770# @DESCRIPTION:
771# Tries to clean up tools.pro for qt-assistant ebuilds
772# Meant to be called in src_prepare
773qt_assistant_cleanup() {
774 # different versions (and branches...) may need different handling,
775 # add a case if you need special handling
776 case "${MY_PV_EXTRA}" in
777 *kde-qt*)
778 sed -e "/^[ \t]*porting/,/^[ \t]*win32.*activeqt$/d" \
779 -e "/mac/,/^embedded.*makeqpf$/d" \
780 -i tools/tools.pro || die "patching tools.pro failed"
781 ;;
782 *)
783 sed -e "/^[ \t]*porting/,/^[ \t]*win32.*activeqt$/d" \
784 -e "/mac/,/^embedded.*makeqpf$/d" \
785 -e "s/^\([ \t]*pixeltool\) /\1 qdoc3 /" \
786 -i tools/tools.pro || die "patching tools.pro failed"
787 ;;
788 esac
789}
790
791# @FUNCTION: qt_nolibx11 798# @FUNCTION: qt_nolibx11
792# @RETURN: nothing 799# @INTERNAL
793# @DESCRIPTION: 800# @DESCRIPTION:
794# Ignore X11 tests for packages that don't need X libraries installed 801# Skip X11 tests for packages that don't need X libraries installed.
795qt_nolibx11() { 802qt_nolibx11() {
796 einfo "removing X11 check to allow X-less compilation" 803 sed -i -e '/^if.*PLATFORM_X11.*CFG_GUI/,/^fi$/d' "${S}"/configure || die
797 sed -i "/unixtests\/compile.test.*config.tests\/x11\/xlib/,/fi$/d" "${S}"/configure ||
798 die "x11 check sed failed"
799} 804}
800 805
801EXPORT_FUNCTIONS pkg_setup src_unpack src_prepare src_configure src_compile src_install src_test pkg_postrm pkg_postinst 806EXPORT_FUNCTIONS pkg_setup src_unpack src_prepare src_configure src_compile src_install src_test pkg_postrm pkg_postinst

Legend:
Removed from v.1.85  
changed lines
  Added in v.1.151

  ViewVC Help
Powered by ViewVC 1.1.20