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

Legend:
Removed from v.1.60  
changed lines
  Added in v.1.108

  ViewVC Help
Powered by ViewVC 1.1.20