/[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.99 Revision 1.113
1# Copyright 1999-2011 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.99 2011/11/19 20:00:35 pesa Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/qt4-build.eclass,v 1.113 2011/12/31 00:46:04 pesa Exp $
4 4
5# @ECLASS: qt4-build.eclass 5# @ECLASS: qt4-build.eclass
6# @MAINTAINER: 6# @MAINTAINER:
7# Qt herd <qt@gentoo.org> 7# Qt herd <qt@gentoo.org>
8# @BLURB: Eclass for Qt4 split ebuilds. 8# @BLURB: Eclass for Qt4 split ebuilds.
10# This eclass contains various functions that are used when building Qt4. 10# This eclass contains various functions that are used when building Qt4.
11 11
12inherit base eutils multilib toolchain-funcs flag-o-matic versionator 12inherit base eutils multilib toolchain-funcs flag-o-matic versionator
13 13
14MY_PV=${PV/_/-} 14MY_PV=${PV/_/-}
15if version_is_at_least 4.5.99999999; then
16 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
17 [[ ${CATEGORY}/${PN} != x11-libs/qt-xmlpatterns ]] && 23[[ ${CATEGORY}/${PN} != x11-libs/qt-xmlpatterns ]] &&
18 [[ ${CATEGORY}/${PN} != x11-themes/qgtkstyle ]] && 24[[ ${CATEGORY}/${PN} != x11-themes/qgtkstyle ]] &&
19 IUSE="+exceptions" 25 IUSE+=" +exceptions"
20else
21 MY_P=qt-x11-opensource-src-${MY_PV}
22fi
23 26
24if version_is_at_least 4.7.99999999; then 27if version_is_at_least 4.7.99999999; then
25 IUSE+=" c++0x qpa" 28 IUSE+=" c++0x qpa"
26fi 29fi
27 30
28HOMEPAGE="http://qt.nokia.com/" 31DEPEND="dev-util/pkgconfig"
29SRC_URI="http://get.qt.nokia.com/qt/source/${MY_P}.tar.gz"
30
31LICENSE="|| ( LGPL-2.1 GPL-3 )"
32IUSE+=" debug pch aqua"
33
34RDEPEND=" 32RDEPEND="
35 !<x11-libs/qt-assistant-${PV} 33 !<x11-libs/qt-assistant-${PV}
36 !>x11-libs/qt-assistant-${PV}-r9999 34 !>x11-libs/qt-assistant-${PV}-r9999
37 !<x11-libs/qt-core-${PV} 35 !<x11-libs/qt-core-${PV}
38 !>x11-libs/qt-core-${PV}-r9999 36 !>x11-libs/qt-core-${PV}-r9999
39 !<x11-libs/qt-dbus-${PV} 37 !<x11-libs/qt-dbus-${PV}
40 !>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
41 !<x11-libs/qt-demo-${PV} 41 !<x11-libs/qt-demo-${PV}
42 !>x11-libs/qt-demo-${PV}-r9999 42 !>x11-libs/qt-demo-${PV}-r9999
43 !<x11-libs/qt-gui-${PV} 43 !<x11-libs/qt-gui-${PV}
44 !>x11-libs/qt-gui-${PV}-r9999 44 !>x11-libs/qt-gui-${PV}-r9999
45 !<x11-libs/qt-multimedia-${PV} 45 !<x11-libs/qt-multimedia-${PV}
66 66
67S=${WORKDIR}/${MY_P} 67S=${WORKDIR}/${MY_P}
68 68
69# @FUNCTION: qt4-build_pkg_setup 69# @FUNCTION: qt4-build_pkg_setup
70# @DESCRIPTION: 70# @DESCRIPTION:
71# Sets up S, MY_P, PATH, and LD_LIBRARY_PATH 71# Sets up PATH and LD_LIBRARY_PATH.
72qt4-build_pkg_setup() { 72qt4-build_pkg_setup() {
73 [[ ${EAPI} == 2 ]] && use !prefix && EPREFIX= 73 [[ ${EAPI} == 2 ]] && use !prefix && EPREFIX=
74 74
75 # Protect users by not allowing downgrades between releases 75 # Protect users by not allowing downgrades between releases
76 # Downgrading revisions within the same release should be allowed 76 # Downgrading revisions within the same release should be allowed
77 if has_version '>'${CATEGORY}/${P}-r9999 ; then 77 if has_version '>'${CATEGORY}/${P}-r9999; then
78 if [[ -z $I_KNOW_WHAT_I_AM_DOING ]] ; then 78 if [[ -z ${I_KNOW_WHAT_I_AM_DOING} ]]; then
79 eerror "Sanity check to keep you from breaking your system:" 79 eerror "Sanity check to keep you from breaking your system:"
80 eerror " Downgrading Qt is completely unsupported and will break your system!" 80 eerror " Downgrading Qt is completely unsupported and will break your system!"
81 die "aborting to save your system" 81 die "aborting to save your system"
82 else 82 else
83 ewarn "Downgrading Qt is completely unsupported and will break your system!" 83 ewarn "Downgrading Qt is completely unsupported and will break your system!"
123 fi 123 fi
124} 124}
125 125
126# @ECLASS-VARIABLE: QT4_TARGET_DIRECTORIES 126# @ECLASS-VARIABLE: QT4_TARGET_DIRECTORIES
127# @DESCRIPTION: 127# @DESCRIPTION:
128# Arguments for build_target_directories. Takes the directories, in which the 128# Arguments for build_target_directories. Takes the directories in which the
129# code should be compiled. This is a space-separated list 129# code should be compiled. This is a space-separated list.
130 130
131# @ECLASS-VARIABLE: QT4_EXTRACT_DIRECTORIES 131# @ECLASS-VARIABLE: QT4_EXTRACT_DIRECTORIES
132# @DESCRIPTION: 132# @DESCRIPTION:
133# Space separated list including the directories that will be extracted from Qt 133# Space-separated list including the directories that will be extracted from
134# tarball 134# Qt tarball.
135 135
136# @FUNCTION: qt4-build_src_unpack 136# @FUNCTION: qt4-build_src_unpack
137# @DESCRIPTION: 137# @DESCRIPTION:
138# Unpacks the sources 138# Unpacks the sources.
139qt4-build_src_unpack() { 139qt4-build_src_unpack() {
140 setqtenv 140 setqtenv
141 local unpack_p="${MY_P}" 141
142 case "${PV}" in 142 local tarball="${MY_P}.tar.gz" target= targets=
143 4.8.0_*)
144 unpack_p="qt-everywhere-opensource-src-${PV/_*}"
145 ;;
146 esac
147 local target targets=
148 for target in configure LICENSE.GPL3 LICENSE.LGPL projects.pro \ 143 for target in configure LICENSE.GPL3 LICENSE.LGPL projects.pro \
149 src/{qbase,qt_targets,qt_install}.pri bin config.tests mkspecs qmake \ 144 src/{qbase,qt_targets,qt_install}.pri bin config.tests \
150 ${QT4_EXTRACT_DIRECTORIES}; do 145 mkspecs qmake ${QT4_EXTRACT_DIRECTORIES}
146 do
151 targets+=" ${unpack_p}/${target}" 147 targets+="${MY_P}/${target} "
152 done 148 done
153 149
150 ebegin "Unpacking parts of ${tarball}:" ${targets//${MY_P}\/}
154 echo tar xzf "${DISTDIR}"/${MY_P}.tar.gz ${targets} 151 tar -xzf "${DISTDIR}/${tarball}" ${targets}
155 tar xzf "${DISTDIR}"/${MY_P}.tar.gz ${targets} || die 152 eend $? || die "failed to unpack"
156 case "${PV}" in
157 4.8.0_*)
158 mv ${WORKDIR}/qt-everywhere-opensource-src-${PV/_*} \
159 ${WORKDIR}/qt-everywhere-opensource-src-${MY_PV}
160 ;;
161 esac
162} 153}
163 154
164# @ECLASS-VARIABLE: PATCHES 155# @ECLASS-VARIABLE: PATCHES
156# @DEFAULT_UNSET
165# @DESCRIPTION: 157# @DESCRIPTION:
166# 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.
167# 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.
168# example: 160# Make sure to specify the full path. This variable is utilised in
169# PATCHES="${FILESDIR}"/mypatch.patch 161# src_unpack/src_prepare phase, based on EAPI.
170# ${FILESDIR}"/mypatch2.patch"
171# 162#
163# @CODE
164# PATCHES=( "${FILESDIR}/mypatch.patch"
165# "${FILESDIR}/patches_folder/" )
166# @CODE
172 167
173# @FUNCTION: qt4-build_src_prepare 168# @FUNCTION: qt4-build_src_prepare
174# @DESCRIPTION: 169# @DESCRIPTION:
175# 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
176# 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.
177qt4-build_src_prepare() { 172qt4-build_src_prepare() {
178 setqtenv 173 setqtenv
179 cd "${S}" 174 cd "${S}"
180
181 # fix qt 4.7 regression that skips -fvisibility=hidden
182 if version_is_at_least "4.7.0_beta1"; then
183 sed -e "s/^gcc|g++)/*gcc|*g++)/" \
184 -i config.tests/unix/fvisibility.test ||
185 die "visibility fixing sed failed"
186 fi
187 175
188 if version_is_at_least "4.7"; then 176 if version_is_at_least "4.7"; then
189 # fix libX11 dependency on non X packages 177 # fix libX11 dependency on non X packages
190 local nolibx11_pkgs="qt-core qt-dbus qt-script qt-sql qt-test qt-xmlpatterns" 178 local nolibx11_pkgs="qt-core qt-dbus qt-script qt-sql qt-test qt-xmlpatterns"
191 has ${PN} ${nolibx11_pkgs} && qt_nolibx11 179 has ${PN} ${nolibx11_pkgs} && qt_nolibx11
197 # provide a proper macx-g++-64 185 # provide a proper macx-g++-64
198 use x64-macos && ln -s macx-g++ mkspecs/$(qt_mkspecs_dir) 186 use x64-macos && ln -s macx-g++ mkspecs/$(qt_mkspecs_dir)
199 187
200 sed -e '/^CONFIG/s:app_bundle::' \ 188 sed -e '/^CONFIG/s:app_bundle::' \
201 -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:' \
202 -i mkspecs/$(qt_mkspecs_dir)/qmake.conf || die "sed failed" 190 -i mkspecs/$(qt_mkspecs_dir)/qmake.conf || die
203 fi 191 fi
204 192
205 if [[ ${PN} != qt-core ]]; then 193 if [[ ${PN} != qt-core ]]; then
206 skip_qmake_build_patch 194 skip_qmake_build
207 skip_project_generation_patch 195 skip_project_generation
208 symlink_binaries_to_buildtree 196 symlink_binaries_to_buildtree
209 fi 197 fi
210 198
211 if [[ ${CHOST} == *86*-apple-darwin* ]] ; then 199 if [[ ${CHOST} == *86*-apple-darwin* ]] ; then
212 # qmake bus errors with -O2 but -O3 works 200 # qmake bus errors with -O2 but -O3 works
217 if [[ $(gcc-major-version) == 3 ]] && use amd64; then 205 if [[ $(gcc-major-version) == 3 ]] && use amd64; then
218 ewarn "Appending -fno-gcse to CFLAGS/CXXFLAGS" 206 ewarn "Appending -fno-gcse to CFLAGS/CXXFLAGS"
219 append-flags -fno-gcse 207 append-flags -fno-gcse
220 fi 208 fi
221 209
222 if has c++0x ${IUSE//+} && use c++0x; then 210 if use_if_iuse c++0x; then
223 ewarn "You are about to build Qt4 using the C++11 standard. Even though" 211 ewarn "You are about to build Qt4 using the C++11 standard. Even though"
224 ewarn "this is an official standard, some of the reverse dependencies" 212 ewarn "this is an official standard, some of the reverse dependencies"
225 ewarn "may fail to compile or link againt the Qt4 libraries. Before" 213 ewarn "may fail to compile or link againt the Qt4 libraries. Before"
226 ewarn "reporting a bug, make sure your bug is reproducible with c++0x" 214 ewarn "reporting a bug, make sure your bug is reproducible with c++0x"
227 ewarn "disabled." 215 ewarn "disabled."
232 if [[ $(gcc-major-version) -lt 4 ]] ; then 220 if [[ $(gcc-major-version) -lt 4 ]] ; then
233 ewarn "Appending -fno-stack-protector to CXXFLAGS" 221 ewarn "Appending -fno-stack-protector to CXXFLAGS"
234 append-cxxflags -fno-stack-protector 222 append-cxxflags -fno-stack-protector
235 # Bug 253127 223 # Bug 253127
236 sed -e "/^QMAKE_CFLAGS\t/ s:$: -fno-stack-protector-all:" \ 224 sed -e "/^QMAKE_CFLAGS\t/ s:$: -fno-stack-protector-all:" \
237 -i "${S}"/mkspecs/common/g++.conf || die "sed ${S}/mkspecs/common/g++.conf failed" 225 -i mkspecs/common/g++.conf || die
238 fi 226 fi
239 227
240 # Bug 261632 228 # Bug 261632
241 if use ppc64; then 229 if use ppc64; then
242 ewarn "Appending -mminimal-toc to CFLAGS/CXXFLAGS" 230 ewarn "Appending -mminimal-toc to CFLAGS/CXXFLAGS"
243 append-flags -mminimal-toc 231 append-flags -mminimal-toc
244 fi 232 fi
245 233
246 # Bug 282984 && Bug 295530 234 # Respect CC, CXX, {C,CXX,LD}FLAGS in .qmake.cache
247 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 \
248 -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"
249 242
250 # Bug 321335 243 # Respect CC, CXX, LINK and *FLAGS in config.tests
251 if version_is_at_least 4.6; then 244 find config.tests/unix -name '*.test' -type f -print0 | xargs -0 \
252 find ./config.tests/unix -name "*.test" -type f -exec grep -lZ \$MAKE '{}' \; | \ 245 sed -i -e "/bin\/qmake/ s: \"QT_BUILD_TREE=: \
253 xargs -0 \ 246 'QMAKE_CC=$(tc-getCC)' 'QMAKE_CXX=$(tc-getCXX)' 'QMAKE_LINK=$(tc-getCXX)' \
254 sed -e "s:\(\$MAKE\):\1 CC=\"$(tc-getCC)\" CXX=\"$(tc-getCXX)\" LD=\"$(tc-getCXX)\" LINK=\"$(tc-getCXX)\":g" \ 247 'QMAKE_CFLAGS+=${CFLAGS}' 'QMAKE_CXXFLAGS+=${CXXFLAGS}' 'QMAKE_LFLAGS+=${LDFLAGS}'&:" \
255 -i || die "sed test compilers failed" 248 || die "sed config.tests failed"
256 fi
257 249
258 # Bug 172219 250 # Bug 172219
259 sed -e "s:X11R6/::" \ 251 sed -e 's:/X11R6/:/:' -i mkspecs/$(qt_mkspecs_dir)/qmake.conf || die
260 -i "${S}"/mkspecs/$(qt_mkspecs_dir)/qmake.conf || die "sed ${S}/mkspecs/$(qt_mkspecs_dir)/qmake.conf failed"
261 252
262 if [[ ${CHOST} == *-darwin* ]]; then 253 if [[ ${CHOST} == *-darwin* ]]; then
263 # Set FLAGS *and* remove -arch, since our gcc-apple is multilib 254 # Set FLAGS *and* remove -arch, since our gcc-apple is multilib
264 # crippled (by design) :/ 255 # crippled (by design) :/
265 sed -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \ 256 sed -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \
279 -e "s:-arch \$i::" \ 270 -e "s:-arch \$i::" \
280 -e "/if \[ ! -z \"\$NATIVE_64_ARCH\" \]; then/,/fi/ d" \ 271 -e "/if \[ ! -z \"\$NATIVE_64_ARCH\" \]; then/,/fi/ d" \
281 -e "s:CFG_MAC_XARCH=yes:CFG_MAC_XARCH=no:g" \ 272 -e "s:CFG_MAC_XARCH=yes:CFG_MAC_XARCH=no:g" \
282 -e "s:-Xarch_x86_64::g" \ 273 -e "s:-Xarch_x86_64::g" \
283 -e "s:-Xarch_ppc64::g" \ 274 -e "s:-Xarch_ppc64::g" \
284 -i configure mkspecs/common/mac-g++.conf || die "sed configure failed" 275 -i configure mkspecs/common/mac-g++.conf || die "sed -arch/-Xarch failed"
285 276
286 # On Snow Leopard don't fall back to 10.5 deployment target. 277 # On Snow Leopard don't fall back to 10.5 deployment target.
287 if [[ ${CHOST} == *-apple-darwin10 ]] ; then 278 if [[ ${CHOST} == *-apple-darwin10 ]] ; then
288 sed -e "s:QMakeVar set QMAKE_MACOSX_DEPLOYMENT_TARGET.*:QMakeVar set QMAKE_MACOSX_DEPLOYMENT_TARGET 10.6:g" \ 279 sed -e "s:QMakeVar set QMAKE_MACOSX_DEPLOYMENT_TARGET.*:QMakeVar set QMAKE_MACOSX_DEPLOYMENT_TARGET 10.6:g" \
289 -e "s:-mmacosx-version-min=10.[0-9]:-mmacosx-version-min=10.6:g" \ 280 -e "s:-mmacosx-version-min=10.[0-9]:-mmacosx-version-min=10.6:g" \
290 -i configure mkspecs/common/mac-g++.conf || die "sed configure failed" 281 -i configure mkspecs/common/mac-g++.conf || die "sed deployment target failed"
291 fi 282 fi
292 fi 283 fi
293 284
294 # this one is needed for all systems with a separate -liconv, apart from 285 # this one is needed for all systems with a separate -liconv, apart from
295 # Darwin, for which the sources already cater for -liconv 286 # Darwin, for which the sources already cater for -liconv
307 # use GCC over SunStudio 298 # use GCC over SunStudio
308 sed -i -e '/PLATFORM=solaris-cc/s/cc/g++/' configure || die 299 sed -i -e '/PLATFORM=solaris-cc/s/cc/g++/' configure || die
309 # don't flirt with non-Prefix stuff, we're quite possessive 300 # don't flirt with non-Prefix stuff, we're quite possessive
310 sed -i -e '/^QMAKE_\(LIB\|INC\)DIR\(_X11\|_OPENGL\|\)\t/s/=.*$/=/' \ 301 sed -i -e '/^QMAKE_\(LIB\|INC\)DIR\(_X11\|_OPENGL\|\)\t/s/=.*$/=/' \
311 mkspecs/$(qt_mkspecs_dir)/qmake.conf || die 302 mkspecs/$(qt_mkspecs_dir)/qmake.conf || die
303
312 # strip predefined CFLAGS from qmake ( bug #312689 ) 304 # strip predefined CFLAGS from mkspecs (bug 312689)
313 sed -i '/^QMAKE_CFLAGS_RELEASE/s:+=.*:+=:' mkspecs/common/g++.conf 305 sed -i -e '/^QMAKE_CFLAGS_RELEASE/s:+=.*:+=:' mkspecs/common/g++.conf
314 306
315 base_src_prepare 307 base_src_prepare
316} 308}
317 309
318# @FUNCTION: qt4-build_src_configure 310# @FUNCTION: qt4-build_src_configure
365 # freetype2 include dir is non-standard, thus include it on configure 357 # freetype2 include dir is non-standard, thus include it on configure
366 # use -I from configure 358 # use -I from configure
367 myconf+=" $(pkg-config --cflags freetype2)" 359 myconf+=" $(pkg-config --cflags freetype2)"
368 fi 360 fi
369 361
370 # Disable SSE4.x, since auto-detection is currently broken
371 # Upstream bug http://bugreports.qt.nokia.com/browse/QTBUG-13623
372 [[ ${PV} == "4.7.1" ]] && myconf+=" -no-sse4.1 -no-sse4.2"
373
374 echo ./configure ${myconf} 362 echo ./configure ${myconf}
375 ./configure ${myconf} || die "./configure failed" 363 ./configure ${myconf} || die "./configure failed"
376 myconf="" 364 myconf=""
377 365
378 prepare_directories ${QT4_TARGET_DIRECTORIES} 366 prepare_directories ${QT4_TARGET_DIRECTORIES}
396 done 384 done
397} 385}
398 386
399# @FUNCTION: fix_includes 387# @FUNCTION: fix_includes
400# @DESCRIPTION: 388# @DESCRIPTION:
401# For MacOSX we need to add some symlinks when frameworks are 389# For MacOS X we need to add some symlinks when frameworks are
402# being used, to avoid complications with some more or less stupid packages. 390# being used, to avoid complications with some more or less stupid packages.
403fix_includes() { 391fix_includes() {
404 if use aqua && [[ ${CHOST##*-darwin} -ge 9 ]] ; then 392 if use aqua && [[ ${CHOST##*-darwin} -ge 9 ]] ; then
405 # Some packages tend to include <Qt/...> 393 # Some packages tend to include <Qt/...>
406 dodir "${QTHEADERDIR#${EPREFIX}}"/Qt 394 dodir "${QTHEADERDIR#${EPREFIX}}"/Qt
437 # remove .la files since we are building only shared Qt libraries 425 # remove .la files since we are building only shared Qt libraries
438 find "${D}"${QTLIBDIR} -name "*.la" -print0 | xargs -0 rm 426 find "${D}"${QTLIBDIR} -name "*.la" -print0 | xargs -0 rm
439} 427}
440 428
441# @FUNCTION: setqtenv 429# @FUNCTION: setqtenv
430# @INTERNAL
442setqtenv() { 431setqtenv() {
443 # Set up installation directories 432 # Set up installation directories
444 QTBASEDIR=${EPREFIX}/usr/$(get_libdir)/qt4
445 QTPREFIXDIR=${EPREFIX}/usr 433 QTPREFIXDIR=${EPREFIX}/usr
446 QTBINDIR=${EPREFIX}/usr/bin 434 QTBINDIR=${EPREFIX}/usr/bin
447 QTLIBDIR=${EPREFIX}/usr/$(get_libdir)/qt4 435 QTLIBDIR=${EPREFIX}/usr/$(get_libdir)/qt4
448 QMAKE_LIBDIR_QT=${QTLIBDIR}
449 QTPCDIR=${EPREFIX}/usr/$(get_libdir)/pkgconfig 436 QTPCDIR=${EPREFIX}/usr/$(get_libdir)/pkgconfig
450 QTDATADIR=${EPREFIX}/usr/share/qt4
451 QTDOCDIR=${EPREFIX}/usr/share/doc/qt-${PV} 437 QTDOCDIR=${EPREFIX}/usr/share/doc/qt-${PV}
452 QTHEADERDIR=${EPREFIX}/usr/include/qt4 438 QTHEADERDIR=${EPREFIX}/usr/include/qt4
453 QTPLUGINDIR=${QTLIBDIR}/plugins 439 QTPLUGINDIR=${QTLIBDIR}/plugins
440 QTIMPORTDIR=${QTLIBDIR}/imports
441 QTDATADIR=${EPREFIX}/usr/share/qt4
442 QTTRANSDIR=${QTDATADIR}/translations
454 QTSYSCONFDIR=${EPREFIX}/etc/qt4 443 QTSYSCONFDIR=${EPREFIX}/etc/qt4
455 QTTRANSDIR=${QTDATADIR}/translations
456 QTEXAMPLESDIR=${QTDATADIR}/examples 444 QTEXAMPLESDIR=${QTDATADIR}/examples
457 QTDEMOSDIR=${QTDATADIR}/demos 445 QTDEMOSDIR=${QTDATADIR}/demos
446 QMAKE_LIBDIR_QT=${QTLIBDIR}
458 QT_INSTALL_PREFIX=${EPREFIX}/usr/$(get_libdir)/qt4 447 QT_INSTALL_PREFIX=${EPREFIX}/usr/$(get_libdir)/qt4
448
459 PLATFORM=$(qt_mkspecs_dir) 449 PLATFORM=$(qt_mkspecs_dir)
460 450
461 unset QMAKESPEC 451 unset QMAKESPEC
462} 452}
463 453
464# @FUNCTION: standard_configure_options 454# @FUNCTION: standard_configure_options
455# @INTERNAL
465# @DESCRIPTION: 456# @DESCRIPTION:
466# Sets up some standard configure options, like libdir (if necessary), whether 457# Sets up some standard configure options, like libdir (if necessary), whether
467# debug info is wanted or not. 458# debug info is wanted or not.
468standard_configure_options() { 459standard_configure_options() {
469 local myconf= 460 local myconf="-prefix ${QTPREFIXDIR} -bindir ${QTBINDIR} -libdir ${QTLIBDIR}
461 -docdir ${QTDOCDIR} -headerdir ${QTHEADERDIR} -plugindir ${QTPLUGINDIR}
462 -importdir ${QTIMPORTDIR} -datadir ${QTDATADIR} -translationdir ${QTTRANSDIR}
463 -sysconfdir ${QTSYSCONFDIR} -examplesdir ${QTEXAMPLESDIR} -demosdir ${QTDEMOSDIR}
464 -opensource -confirm-license -shared -fast -largefile -stl -verbose
465 -platform $(qt_mkspecs_dir) -nomake examples -nomake demos"
470 466
471 [[ $(get_libdir) != lib ]] && myconf+=" -L${EPREFIX}/usr/$(get_libdir)" 467 [[ $(get_libdir) != lib ]] && myconf+=" -L${EPREFIX}/usr/$(get_libdir)"
472 468
473 # Disable visibility explicitly if gcc version isn't 4 469 # debug/release
474 if [[ $(gcc-major-version) -lt 4 ]]; then
475 myconf+=" -no-reduce-exports"
476 fi
477
478 # precompiled headers doesn't work on hardened, where the flag is masked.
479 myconf+=" $(qt_use pch)"
480
481 if use debug; then 470 if use debug; then
482 myconf+=" -debug" 471 myconf+=" -debug"
483 else 472 else
484 myconf+=" -release" 473 myconf+=" -release"
485 fi 474 fi
486 myconf+=" -no-separate-debug-info" 475 myconf+=" -no-separate-debug-info"
487 476
477 # exceptions USE flag
478 local exceptions="-exceptions"
479 in_iuse exceptions && exceptions="$(qt_use exceptions)"
480 myconf+=" ${exceptions}"
481
482 # disable RPATH on Qt >= 4.8 (bug 380415)
483 version_is_at_least 4.8 && myconf+=" -no-rpath"
484
485 # precompiled headers don't work on hardened, where the flag is masked
486 myconf+=" $(qt_use pch)"
487
488 # -reduce-relocations
489 # This flag seems to introduce major breakage to applications,
490 # mostly to be seen as a core dump with the message "QPixmap: Must
491 # construct a QApplication before a QPaintDevice" on Solaris.
492 # -- Daniel Vergien
493 [[ ${CHOST} != *-solaris* ]] && myconf+=" -reduce-relocations"
494
488 use aqua && myconf+=" -no-framework" 495 use aqua && myconf+=" -no-framework"
489 496
490 # ARCH is set on Gentoo. Qt now falls back to generic on an unsupported 497 # ARCH is set on Gentoo. Qt now falls back to generic on an unsupported
491 # $(tc-arch). Therefore we convert it to supported values. 498 # $(tc-arch). Therefore we convert it to supported values.
492 case "$(tc-arch)" in 499 case "$(tc-arch)" in
493 amd64|x64-*) myconf+=" -arch x86_64" ;; 500 amd64|x64-*) myconf+=" -arch x86_64" ;;
494 ppc-macos) myconf+=" -arch ppc" ;; 501 ppc-macos) myconf+=" -arch ppc" ;;
495 ppc|ppc64|ppc-*) myconf+=" -arch powerpc" ;; 502 ppc|ppc64|ppc-*) myconf+=" -arch powerpc" ;;
496 sparc|sparc-*) myconf+=" -arch sparc" ;; 503 sparc|sparc-*|sparc64-*) myconf+=" -arch sparc" ;;
497 x86-macos) myconf+=" -arch x86" ;; 504 x86-macos) myconf+=" -arch x86" ;;
498 x86|x86-*) myconf+=" -arch i386" ;; 505 x86|x86-*) myconf+=" -arch i386" ;;
499 alpha|arm|ia64|mips|s390|sparc) myconf+=" -arch $(tc-arch)" ;; 506 alpha|arm|ia64|mips|s390) myconf+=" -arch $(tc-arch)" ;;
500 hppa|sh) myconf+=" -arch generic" ;; 507 hppa|sh) myconf+=" -arch generic" ;;
501 *) die "$(tc-arch) is unsupported by this eclass. Please file a bug." ;; 508 *) die "$(tc-arch) is unsupported by this eclass. Please file a bug." ;;
502 esac 509 esac
503 510
504 # 4.5: build everything but qt-xmlpatterns w/o exceptions
505 # 4.6: exceptions USE flag
506 local exceptions="-exceptions"
507 case "${PV}" in
508 4.5.*)
509 [[ ${PN} == "qt-xmlpatterns" ]] || exceptions="-no-exceptions"
510 ;;
511 *)
512 has exceptions "${IUSE//+}" && exceptions="$(qt_use exceptions)"
513 ;;
514 esac
515
516 # note about -reduce-relocations:
517 # That flag seems to introduce major breakage to applications,
518 # mostly to be seen as a core dump with the message "QPixmap: Must
519 # construct a QApplication before a QPaintDevice" on Solaris
520 # -- Daniel Vergien
521 [[ ${CHOST} != *-solaris* ]] && myconf+=" -reduce-relocations"
522
523 myconf+=" -platform $(qt_mkspecs_dir) -stl -verbose -largefile -confirm-license
524 -prefix ${QTPREFIXDIR} -bindir ${QTBINDIR} -libdir ${QTLIBDIR}
525 -datadir ${QTDATADIR} -docdir ${QTDOCDIR} -headerdir ${QTHEADERDIR}
526 -plugindir ${QTPLUGINDIR} -sysconfdir ${QTSYSCONFDIR}
527 -translationdir ${QTTRANSDIR} -examplesdir ${QTEXAMPLESDIR}
528 -demosdir ${QTDEMOSDIR} -silent -fast -opensource
529 ${exceptions}
530 -nomake examples -nomake demos"
531
532 echo "${myconf}" 511 echo "${myconf}"
533} 512}
534 513
535# @FUNCTION: prepare_directories 514# @FUNCTION: prepare_directories
536# @USAGE: < directories > 515# @USAGE: < directories >
516# @INTERNAL
537# @DESCRIPTION: 517# @DESCRIPTION:
538# Generates makefiles for the directories set in $QT4_TARGET_DIRECTORIES 518# Generates Makefiles for the given list of directories.
539prepare_directories() { 519prepare_directories() {
540 for x in "$@"; do 520 for x in "$@"; do
541 pushd "${S}"/${x} >/dev/null 521 pushd "${S}"/${x} >/dev/null || die
542 einfo "Running qmake in: ${x}" 522 einfo "Running qmake in: ${x}"
543 # avoid running over the maximum argument number, bug #299810 523 # avoid running over the maximum argument number, bug #299810
544 { 524 {
545 echo "${S}"/mkspecs/common/*.conf 525 echo "${S}"/mkspecs/common/*.conf
546 find "${S}" -name '*.pr[io]' 526 find "${S}" -name '*.pr[io]'
547 } | xargs sed -i -e "s:\$\$\[QT_INSTALL_LIBS\]:${EPREFIX}/usr/$(get_libdir)/qt4:g" || die 527 } | xargs sed -i \
528 -e "s:\$\$\[QT_INSTALL_LIBS\]:${QTLIBDIR}:g" \
529 -e "s:\$\$\[QT_INSTALL_PLUGINS\]:${QTPLUGINDIR}:g" \
530 || die
548 "${S}"/bin/qmake "LIBS+=-L${QTLIBDIR}" "CONFIG+=nostrip" || die "qmake failed" 531 "${S}"/bin/qmake "LIBS+=-L${QTLIBDIR}" "CONFIG+=nostrip" || die "qmake failed"
549 popd >/dev/null 532 popd >/dev/null || die
550 done 533 done
551} 534}
552 535
553 536
554# @FUNCTION: build_directories 537# @FUNCTION: build_directories
555# @USAGE: < directories > 538# @USAGE: < directories >
539# @INTERNAL
556# @DESCRIPTION: 540# @DESCRIPTION:
557# Compiles the code in $QT4_TARGET_DIRECTORIES 541# Compiles the code in the given list of directories.
558build_directories() { 542build_directories() {
559 for x in "$@"; do 543 for x in "$@"; do
560 pushd "${S}"/${x} >/dev/null 544 pushd "${S}"/${x} >/dev/null || die
561 emake CC="$(tc-getCC)" \ 545 emake CC="$(tc-getCC)" \
562 CXX="$(tc-getCXX)" \ 546 CXX="$(tc-getCXX)" \
563 LINK="$(tc-getCXX)" || die "emake failed" 547 LINK="$(tc-getCXX)" || die "emake failed"
564 popd >/dev/null 548 popd >/dev/null || die
565 done 549 done
566} 550}
567 551
568# @FUNCTION: install_directories 552# @FUNCTION: install_directories
569# @USAGE: < directories > 553# @USAGE: < directories >
554# @INTERNAL
570# @DESCRIPTION: 555# @DESCRIPTION:
571# run emake install in the given directories, which are separated by spaces 556# Runs emake install in the given directories, which are separated by spaces.
572install_directories() { 557install_directories() {
573 for x in "$@"; do 558 for x in "$@"; do
574 pushd "${S}"/${x} >/dev/null || die "Can't pushd ${S}/${x}" 559 pushd "${S}"/${x} >/dev/null || die
575 emake INSTALL_ROOT="${D}" install || die "emake install failed" 560 emake INSTALL_ROOT="${D}" install || die "emake install failed"
576 popd >/dev/null || die "Can't popd from ${S}/${x}" 561 popd >/dev/null || die
577 done 562 done
578} 563}
579 564
580# @ECLASS-VARIABLE: QCONFIG_ADD 565# @ECLASS-VARIABLE: QCONFIG_ADD
581# @DESCRIPTION: 566# @DESCRIPTION:
591# @DESCRIPTION: 576# @DESCRIPTION:
592# List variables that should be defined at the top of QtCore/qconfig.h 577# List variables that should be defined at the top of QtCore/qconfig.h
593: ${QCONFIG_DEFINE:=} 578: ${QCONFIG_DEFINE:=}
594 579
595# @FUNCTION: install_qconfigs 580# @FUNCTION: install_qconfigs
581# @INTERNAL
596# @DESCRIPTION: 582# @DESCRIPTION:
597# Install gentoo-specific mkspecs configurations 583# Install gentoo-specific mkspecs configurations.
598install_qconfigs() { 584install_qconfigs() {
599 local x 585 local x
600 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} ]]; then 586 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} ]]; then
601 for x in QCONFIG_ADD QCONFIG_REMOVE; do 587 for x in QCONFIG_ADD QCONFIG_REMOVE; do
602 [[ -n ${!x} ]] && echo ${x}=${!x} >> "${T}"/${PN}-qconfig.pri 588 [[ -n ${!x} ]] && echo ${x}=${!x} >> "${T}"/${PN}-qconfig.pri
613 doins "${T}"/gentoo-${PN}-qconfig.h || die "installing ${PN}-qconfig.h failed" 599 doins "${T}"/gentoo-${PN}-qconfig.h || die "installing ${PN}-qconfig.h failed"
614 fi 600 fi
615} 601}
616 602
617# @FUNCTION: generate_qconfigs 603# @FUNCTION: generate_qconfigs
604# @INTERNAL
618# @DESCRIPTION: 605# @DESCRIPTION:
619# Generates gentoo-specific configurations 606# Generates gentoo-specific qconfig.{h,pri}.
620generate_qconfigs() { 607generate_qconfigs() {
621 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} || -n ${QCONFIG_DEFINE} || ${CATEGORY}/${PN} == x11-libs/qt-core ]]; then 608 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} || -n ${QCONFIG_DEFINE} || ${CATEGORY}/${PN} == x11-libs/qt-core ]]; then
622 local x qconfig_add qconfig_remove qconfig_new 609 local x qconfig_add qconfig_remove qconfig_new
623 for x in "${ROOT}${QTDATADIR}"/mkspecs/gentoo/*-qconfig.pri; do 610 for x in "${ROOT}${QTDATADIR}"/mkspecs/gentoo/*-qconfig.pri; do
624 [[ -f ${x} ]] || continue 611 [[ -f ${x} ]] || continue
673 fi 660 fi
674} 661}
675 662
676# @FUNCTION: qt4-build_pkg_postrm 663# @FUNCTION: qt4-build_pkg_postrm
677# @DESCRIPTION: 664# @DESCRIPTION:
678# Generate configurations when the package is completely removed 665# Regenerate configuration when the package is completely removed.
679qt4-build_pkg_postrm() { 666qt4-build_pkg_postrm() {
680 generate_qconfigs 667 generate_qconfigs
681} 668}
682 669
683# @FUNCTION: qt4-build_pkg_postinst 670# @FUNCTION: qt4-build_pkg_postinst
684# @DESCRIPTION: 671# @DESCRIPTION:
685# Generate configuration, plus throws a message about possible 672# Regenerate configuration, plus throw a message about possible
686# breakages and proposed solutions. 673# breakages and proposed solutions.
687qt4-build_pkg_postinst() { 674qt4-build_pkg_postinst() {
688 generate_qconfigs 675 generate_qconfigs
689} 676}
690 677
691# @FUNCTION: skip_qmake_build_patch 678# @FUNCTION: skip_qmake_build
679# @INTERNAL
692# @DESCRIPTION: 680# @DESCRIPTION:
693# Don't need to build qmake, as it's already installed from qt-core 681# Patches configure to skip qmake compilation, as it's already installed by qt-core.
694skip_qmake_build_patch() { 682skip_qmake_build() {
695 # Don't need to build qmake, as it's already installed from qt-core
696 sed -i -e "s:if true:if false:g" "${S}"/configure || die "sed failed" 683 sed -i -e "s:if true:if false:g" "${S}"/configure || die
697} 684}
698 685
699# @FUNCTION: skip_project_generation_patch 686# @FUNCTION: skip_project_generation
687# @INTERNAL
700# @DESCRIPTION: 688# @DESCRIPTION:
701# Exit the script early by throwing in an exit before all of the .pro files are scanned 689# Exit the script early by throwing in an exit before all of the .pro files are scanned.
702skip_project_generation_patch() { 690skip_project_generation() {
703 # Exit the script early by throwing in an exit before all of the .pro files are scanned
704 sed -e "s:echo \"Finding:exit 0\n\necho \"Finding:g" \ 691 sed -i -e "s:echo \"Finding:exit 0\n\necho \"Finding:g" "${S}"/configure || die
705 -i "${S}"/configure || die "sed failed"
706} 692}
707 693
708# @FUNCTION: symlink_binaries_to_buildtree 694# @FUNCTION: symlink_binaries_to_buildtree
695# @INTERNAL
709# @DESCRIPTION: 696# @DESCRIPTION:
710# Symlink generated binaries to buildtree so they can be used during compilation 697# Symlinks generated binaries to buildtree, so they can be used during compilation time.
711# time
712symlink_binaries_to_buildtree() { 698symlink_binaries_to_buildtree() {
713 for bin in qmake moc uic rcc; do 699 for bin in qmake moc uic rcc; do
714 ln -s ${QTBINDIR}/${bin} "${S}"/bin/ || die "symlinking ${bin} to ${S}/bin failed" 700 ln -s "${QTBINDIR}"/${bin} "${S}"/bin/ || die "symlinking ${bin} to ${S}/bin failed"
715 done 701 done
716} 702}
717 703
718# @FUNCTION: fix_library_files 704# @FUNCTION: fix_library_files
705# @INTERNAL
719# @DESCRIPTION: 706# @DESCRIPTION:
720# Fixes the pathes in *.la, *.prl, *.pc, as they are wrong due to sandbox and 707# Fixes the paths in *.la, *.prl, *.pc, as they are wrong due to sandbox and
721# moves the *.pc-files into the pkgconfig directory 708# moves the *.pc files into the pkgconfig directory.
722fix_library_files() { 709fix_library_files() {
710 local libfile
723 for libfile in "${D}"/${QTLIBDIR}/{*.la,*.prl,pkgconfig/*.pc}; do 711 for libfile in "${D}"/${QTLIBDIR}/{*.la,*.prl,pkgconfig/*.pc}; do
724 if [[ -e ${libfile} ]]; then 712 if [[ -e ${libfile} ]]; then
725 sed -i -e "s:${S}/lib:${QTLIBDIR}:g" ${libfile} || die "sed on ${libfile} failed" 713 sed -i -e "s:${S}/lib:${QTLIBDIR}:g" ${libfile} || die "sed on ${libfile} failed"
726 fi 714 fi
727 done 715 done
728 716
729 # pkgconfig files refer to WORKDIR/bin as the moc and uic locations. Fix: 717 # pkgconfig files refer to WORKDIR/bin as the moc and uic locations
730 for libfile in "${D}"/${QTLIBDIR}/pkgconfig/*.pc; do 718 for libfile in "${D}"/${QTLIBDIR}/pkgconfig/*.pc; do
731 if [[ -e ${libfile} ]]; then 719 if [[ -e ${libfile} ]]; then
732 sed -i -e "s:${S}/bin:${QTBINDIR}:g" ${libfile} || die "sed failed" 720 sed -i -e "s:${S}/bin:${QTBINDIR}:g" ${libfile} || die "sed on ${libfile} failed"
733 721
734 # Move .pc files into the pkgconfig directory 722 # Move .pc files into the pkgconfig directory
735 dodir ${QTPCDIR#${EPREFIX}} 723 dodir ${QTPCDIR#${EPREFIX}}
736 mv ${libfile} "${D}"/${QTPCDIR}/ \ 724 mv ${libfile} "${D}"/${QTPCDIR}/ || die "moving ${libfile} to ${D}/${QTPCDIR}/ failed"
737 || die "moving ${libfile} to ${D}/${QTPCDIR}/ failed"
738 fi 725 fi
739 done 726 done
740 727
741 # Don't install an empty directory 728 # Don't install an empty directory
742 rmdir "${D}"/${QTLIBDIR}/pkgconfig 729 rmdir "${D}"/${QTLIBDIR}/pkgconfig
743} 730}
744 731
745# @FUNCTION: qt_use 732# @FUNCTION: qt_use
746# @USAGE: < flag > [ feature ] [ enableval ] 733# @USAGE: < flag > [ feature ] [ enableval ]
747# @DESCRIPTION: 734# @DESCRIPTION:
748# This will echo "${enableval}-${feature}" if <flag> is enabled, or 735# This will echo "-${enableval}-${feature}" if <flag> is enabled, or
749# "-no-${feature} if the flag is disabled. If [feature] is not specified <flag> 736# "-no-${feature}" if it's disabled. If [feature] is not specified, <flag>
750# will be used for that. If [enableval] is not specified, it omits the 737# will be used for that. If [enableval] is not specified, it omits the
751# assignment-part 738# "-${enableval}" part.
752qt_use() { 739qt_use() {
753 local flag=$1 740 use "$1" && echo "${3:+-$3}-${2:-$1}" || echo "-no-${2:-$1}"
754 local feature=$1
755 local enableval=
756
757 [[ -n $2 ]] && feature=$2
758 [[ -n $3 ]] && enableval=-$3
759
760 if use ${flag}; then
761 echo "${enableval}-${feature}"
762 else
763 echo "-no-${feature}"
764 fi
765} 741}
766 742
767# @FUNCTION: qt_mkspecs_dir 743# @FUNCTION: qt_mkspecs_dir
768# @RETURN: the specs-directory w/o path 744# @RETURN: the specs-directory w/o path
769# @DESCRIPTION: 745# @DESCRIPTION:
770# Allows us to define which mkspecs dir we want to use. 746# Allows us to define which mkspecs dir we want to use.
771qt_mkspecs_dir() { 747qt_mkspecs_dir() {
772 # Allows us to define which mkspecs dir we want to use.
773 local spec 748 local spec=
774
775 case ${CHOST} in 749 case ${CHOST} in
776 *-freebsd*|*-dragonfly*) 750 *-freebsd*|*-dragonfly*)
777 spec=freebsd ;; 751 spec=freebsd ;;
778 *-openbsd*) 752 *-openbsd*)
779 spec=openbsd ;; 753 spec=openbsd ;;
791 *-solaris*) 765 *-solaris*)
792 spec=solaris ;; 766 spec=solaris ;;
793 *-linux-*|*-linux) 767 *-linux-*|*-linux)
794 spec=linux ;; 768 spec=linux ;;
795 *) 769 *)
796 die "Unknown CHOST, no platform chosen." 770 die "Unknown CHOST, no platform chosen"
797 esac 771 esac
798 772
799 CXX=$(tc-getCXX) 773 CXX=$(tc-getCXX)
800 if [[ ${CXX} == *g++* ]]; then 774 if [[ ${CXX} == *g++* ]]; then
801 spec+=-g++ 775 spec+=-g++
802 elif [[ ${CXX} == *icpc* ]]; then 776 elif [[ ${CXX} == *icpc* ]]; then
803 spec+=-icc 777 spec+=-icc
804 else 778 else
805 die "Unknown compiler '${CXX}'." 779 die "Unknown compiler '${CXX}'"
806 fi 780 fi
807 if [[ -n ${LIBDIR/lib} ]]; then 781 if [[ -n ${LIBDIR/lib} ]]; then
808 spec+=-${LIBDIR/lib} 782 spec+=-${LIBDIR/lib}
809 fi 783 fi
810 784
820 794
821 echo "${spec}" 795 echo "${spec}"
822} 796}
823 797
824# @FUNCTION: qt_assistant_cleanup 798# @FUNCTION: qt_assistant_cleanup
825# @RETURN: nothing 799# @INTERNAL
826# @DESCRIPTION: 800# @DESCRIPTION:
827# Tries to clean up tools.pro for qt-assistant ebuilds. 801# Tries to clean up tools.pro for qt-assistant ebuilds.
828# Meant to be called in src_prepare(). 802# Meant to be called in src_prepare().
829# Since Qt 4.7.4 this function is a no-op. 803# Since Qt 4.7.4 this function is a no-op.
830qt_assistant_cleanup() { 804qt_assistant_cleanup() {
850 ;; 824 ;;
851 esac 825 esac
852} 826}
853 827
854# @FUNCTION: qt_nolibx11 828# @FUNCTION: qt_nolibx11
855# @RETURN: nothing 829# @INTERNAL
856# @DESCRIPTION: 830# @DESCRIPTION:
857# Ignore X11 tests for packages that don't need X libraries installed 831# Ignore X11 tests for packages that don't need X libraries installed.
858qt_nolibx11() { 832qt_nolibx11() {
859 einfo "Removing X11 check to allow X-less compilation"
860 sed -i "/unixtests\/compile.test.*config.tests\/x11\/xlib/,/fi$/d" "${S}"/configure || 833 sed -i "/unixtests\/compile.test.*config.tests\/x11\/xlib/,/fi$/d" "${S}"/configure ||
861 die "x11 check sed failed" 834 die "x11 check sed failed"
862} 835}
863 836
864EXPORT_FUNCTIONS pkg_setup src_unpack src_prepare src_configure src_compile src_install src_test pkg_postrm pkg_postinst 837EXPORT_FUNCTIONS pkg_setup src_unpack src_prepare src_configure src_compile src_install src_test pkg_postrm pkg_postinst

Legend:
Removed from v.1.99  
changed lines
  Added in v.1.113

  ViewVC Help
Powered by ViewVC 1.1.20