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

Legend:
Removed from v.1.45  
changed lines
  Added in v.1.86

  ViewVC Help
Powered by ViewVC 1.1.20