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

Legend:
Removed from v.1.67  
changed lines
  Added in v.1.112

  ViewVC Help
Powered by ViewVC 1.1.20