/[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.48 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.48 2009/10/16 15:02:15 wired 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>,
12# @DESCRIPTION: 12# @DESCRIPTION:
13# This eclass contains various functions that are used when building Qt4 13# This eclass contains various functions that are used when building Qt4
14 14
15inherit base eutils multilib toolchain-funcs flag-o-matic versionator 15inherit base eutils multilib toolchain-funcs flag-o-matic versionator
16 16
17IUSE="${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
18RDEPEND=" 35RDEPEND="
19 !<x11-libs/qt-assistant-${PV} 36 !<x11-libs/qt-assistant-${PV}
20 !>x11-libs/qt-assistant-${PV}-r9999 37 !>x11-libs/qt-assistant-${PV}-r9999
21 !<x11-libs/qt-core-${PV} 38 !<x11-libs/qt-core-${PV}
22 !>x11-libs/qt-core-${PV}-r9999 39 !>x11-libs/qt-core-${PV}-r9999
24 !>x11-libs/qt-dbus-${PV}-r9999 41 !>x11-libs/qt-dbus-${PV}-r9999
25 !<x11-libs/qt-demo-${PV} 42 !<x11-libs/qt-demo-${PV}
26 !>x11-libs/qt-demo-${PV}-r9999 43 !>x11-libs/qt-demo-${PV}-r9999
27 !<x11-libs/qt-gui-${PV} 44 !<x11-libs/qt-gui-${PV}
28 !>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
29 !<x11-libs/qt-opengl-${PV} 48 !<x11-libs/qt-opengl-${PV}
30 !>x11-libs/qt-opengl-${PV}-r9999 49 !>x11-libs/qt-opengl-${PV}-r9999
31 !<x11-libs/qt-phonon-${PV} 50 !<x11-libs/qt-phonon-${PV}
32 !>x11-libs/qt-phonon-${PV}-r9999 51 !>x11-libs/qt-phonon-${PV}-r9999
33 !<x11-libs/qt-qt3support-${PV} 52 !<x11-libs/qt-qt3support-${PV}
43 !<x11-libs/qt-webkit-${PV} 62 !<x11-libs/qt-webkit-${PV}
44 !>x11-libs/qt-webkit-${PV}-r9999 63 !>x11-libs/qt-webkit-${PV}-r9999
45 !<x11-libs/qt-xmlpatterns-${PV} 64 !<x11-libs/qt-xmlpatterns-${PV}
46 !>x11-libs/qt-xmlpatterns-${PV}-r9999 65 !>x11-libs/qt-xmlpatterns-${PV}-r9999
47" 66"
48case "${PV}" in
49 4.?.?_rc* | 4.?.?_beta* )
50 SRCTYPE="${SRCTYPE:-opensource-src}"
51 MY_PV="${PV/_/-}"
52 ;;
53 *)
54 SRCTYPE="${SRCTYPE:-opensource-src}"
55 MY_PV="${PV}"
56 ;;
57esac
58 67
59if version_is_at_least 4.5.99999999 ${PV} ; then
60 MY_P="qt-everywhere-${SRCTYPE}-${MY_PV}"
61else
62 MY_P="qt-x11-${SRCTYPE}-${MY_PV}"
63fi
64S=${WORKDIR}/${MY_P} 68S=${WORKDIR}/${MY_P}
65 69
66HOMEPAGE="http://qt.nokia.com/"
67if version_is_at_least 4.5.3 ${PV} ; then
68 SRC_URI="http://get.qt.nokia.com/qt/source/${MY_P}.tar.gz"
69else
70 SRC_URI="http://get.qt.nokia.com/qt/source/${MY_P}.tar.bz2"
71fi
72
73case "${PV}" in
74 4.4.?) SRC_URI="${SRC_URI} mirror://gentoo/${MY_P}-headers.tar.bz2" ;;
75 *) ;;
76esac
77
78if version_is_at_least 4.5 ${PV} ; then
79 LICENSE="|| ( LGPL-2.1 GPL-3 )"
80fi
81
82# @FUNCTION: qt4-build_pkg_setup 70# @FUNCTION: qt4-build_pkg_setup
83# @DESCRIPTION: 71# @DESCRIPTION:
84# Sets up installation directories, PLATFORM, PATH, and LD_LIBRARY_PATH 72# Sets up S, MY_P, PATH, and LD_LIBRARY_PATH
85qt4-build_pkg_setup() { 73qt4-build_pkg_setup() {
86 # EAPI=2 ebuilds set use-deps, others need this: 74 [[ ${EAPI} == 2 ]] && use !prefix && EPREFIX=
87 if [[ $EAPI != 2 ]]; then 75
88 # Make sure debug setting corresponds with qt-core (bug 258512) 76 # Protect users by not allowing downgrades between releases
89 if [[ $PN != "qt-core" ]]; then 77 # Downgrading revisions within the same release should be allowed
90 use debug && QT4_BUILT_WITH_USE_CHECK="${QT4_BUILT_WITH_USE_CHECK} 78 if has_version '>'${CATEGORY}/${P}-r9999 ; then
91 ~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!"
92 fi 85 fi
86 fi
93 87
94 # Check USE requirements 88 if [[ "${PN}" == "qt-webkit" ]]; then
95 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
96 fi 97 fi
98 eshopts_pop
99 fi
97 100
98 PATH="${S}/bin:${PATH}" 101 PATH="${S}/bin${PATH:+:}${PATH}"
102 if [[ ${CHOST} != *-darwin* ]]; then
99 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
100 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
101 if ! version_is_at_least 4.1 $(gcc-version) ; then 122 if ! version_is_at_least 4.1 $(gcc-version); then
102 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!"
103 echo
104 ebeep 3
105 fi 124 fi
106} 125}
107 126
108# @ECLASS-VARIABLE: QT4_TARGET_DIRECTORIES 127# @ECLASS-VARIABLE: QT4_TARGET_DIRECTORIES
109# @DESCRIPTION: 128# @DESCRIPTION:
118# @FUNCTION: qt4-build_src_unpack 137# @FUNCTION: qt4-build_src_unpack
119# @DESCRIPTION: 138# @DESCRIPTION:
120# Unpacks the sources 139# Unpacks the sources
121qt4-build_src_unpack() { 140qt4-build_src_unpack() {
122 setqtenv 141 setqtenv
123 local target targets licenses tar_pkg tar_args 142 local target targets=
124 if version_is_at_least 4.5 ${PV} ; then 143 for target in configure LICENSE.GPL3 LICENSE.LGPL projects.pro \
125 licenses="LICENSE.GPL3 LICENSE.LGPL"
126 else
127 licenses="LICENSE.GPL2 LICENSE.GPL3"
128 fi
129 for target in configure ${licenses} projects.pro \
130 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 \
131 ${QT4_EXTRACT_DIRECTORIES}; do 145 ${QT4_EXTRACT_DIRECTORIES}; do
132 targets="${targets} ${MY_P}/${target}" 146 targets+=" ${MY_P}/${target}"
133 done 147 done
134 148
135 tar_pkg=${MY_P}.tar.bz2
136 tar_args="xjpf"
137 if version_is_at_least 4.5.3 ${PV} ; then
138 tar_pkg=${tar_pkg/bz2/gz}
139 tar_args="xzpf"
140 fi
141
142 echo tar ${tar_args} "${DISTDIR}"/${tar_pkg} ${targets} 149 echo tar xzf "${DISTDIR}"/${MY_P}.tar.gz ${targets}
143 tar ${tar_args} "${DISTDIR}"/${tar_pkg} ${targets} 150 tar xzf "${DISTDIR}"/${MY_P}.tar.gz ${targets} || die
144
145 case "${PV}" in
146 4.4.?)
147 echo tar xjpf "${DISTDIR}"/${MY_P}-headers.tar.bz2
148 tar xjpf "${DISTDIR}"/${MY_P}-headers.tar.bz2
149 ;;
150 esac
151
152 # Be backwards compatible for now
153 if [[ $EAPI != 2 ]]; then
154 qt4-build_src_prepare
155 fi
156} 151}
157 152
158# @ECLASS-VARIABLE: PATCHES 153# @ECLASS-VARIABLE: PATCHES
159# @DESCRIPTION: 154# @DESCRIPTION:
160# 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
169# 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
170# 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.
171qt4-build_src_prepare() { 166qt4-build_src_prepare() {
172 setqtenv 167 setqtenv
173 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
174 191
175 if [[ ${PN} != qt-core ]]; then 192 if [[ ${PN} != qt-core ]]; then
176 skip_qmake_build_patch 193 skip_qmake_build_patch
177 skip_project_generation_patch 194 skip_project_generation_patch
178 symlink_binaries_to_buildtree 195 symlink_binaries_to_buildtree
179 fi 196 fi
180 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
181 # Bug 178652 203 # Bug 178652
182 if [[ "$(gcc-major-version)" == "3" ]] && use amd64; then 204 if [[ $(gcc-major-version) == 3 ]] && use amd64; then
183 ewarn "Appending -fno-gcse to CFLAGS/CXXFLAGS" 205 ewarn "Appending -fno-gcse to CFLAGS/CXXFLAGS"
184 append-flags -fno-gcse 206 append-flags -fno-gcse
185 fi 207 fi
186 208
187 # Unsupported old gcc versions - hardened needs this :( 209 # Unsupported old gcc versions - hardened needs this :(
188 if [[ $(gcc-major-version) -lt "4" ]] ; then 210 if [[ $(gcc-major-version) -lt 4 ]] ; then
189 ewarn "Appending -fno-stack-protector to CXXFLAGS" 211 ewarn "Appending -fno-stack-protector to CXXFLAGS"
190 append-cxxflags -fno-stack-protector 212 append-cxxflags -fno-stack-protector
191 # Bug 253127 213 # Bug 253127
192 sed -e "/^QMAKE_CFLAGS\t/ s:$: -fno-stack-protector-all:" \ 214 sed -e "/^QMAKE_CFLAGS\t/ s:$: -fno-stack-protector-all:" \
193 -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"
194 fi 216 fi
195 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
196 # Bug 172219 235 # Bug 172219
197 sed -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \
198 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \
199 -e "s:QMAKE_LFLAGS_RELEASE.*=.*:QMAKE_LFLAGS_RELEASE=${LDFLAGS}:" \
200 -e "s:X11R6/::" \ 236 sed -e "s:X11R6/::" \
201 -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"
202 238
239 if [[ ${CHOST} == *-darwin* ]]; then
240 # Set FLAGS *and* remove -arch, since our gcc-apple is multilib
241 # crippled (by design) :/
203 sed -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \ 242 sed -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \
204 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \ 243 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \
205 -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" \
206 -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
207 291
208 base_src_prepare 292 base_src_prepare
209} 293}
210 294
211# @FUNCTION: qt4-build_src_configure 295# @FUNCTION: qt4-build_src_configure
213# Default configure phase 297# Default configure phase
214qt4-build_src_configure() { 298qt4-build_src_configure() {
215 setqtenv 299 setqtenv
216 myconf="$(standard_configure_options) ${myconf}" 300 myconf="$(standard_configure_options) ${myconf}"
217 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
218 echo ./configure ${myconf} 344 echo ./configure ${myconf}
219 ./configure ${myconf} || die "./configure failed" 345 ./configure ${myconf} || die "./configure failed"
220 myconf="" 346 myconf=""
221} 347}
222 348
223# @FUNCTION: qt4-build_src_compile 349# @FUNCTION: qt4-build_src_compile
224# @DESCRIPTION: Actual compile phase 350# @DESCRIPTION: Actual compile phase
225qt4-build_src_compile() { 351qt4-build_src_compile() {
226 setqtenv 352 setqtenv
227 # Be backwards compatible for now
228 if [[ $EAPI != 2 ]]; then
229 qt4-build_src_configure
230 fi
231 353
232 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
233} 390}
234 391
235# @FUNCTION: qt4-build_src_install 392# @FUNCTION: qt4-build_src_install
236# @DESCRIPTION: 393# @DESCRIPTION:
237# Perform the actual installation including some library fixes. 394# Perform the actual installation including some library fixes.
238qt4-build_src_install() { 395qt4-build_src_install() {
396 [[ ${EAPI} == 2 ]] && use !prefix && ED=${D}
239 setqtenv 397 setqtenv
240 install_directories "${QT4_TARGET_DIRECTORIES}" 398 install_directories ${QT4_TARGET_DIRECTORIES}
241 install_qconfigs 399 install_qconfigs
242 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
243} 404}
244 405
245# @FUNCTION: setqtenv 406# @FUNCTION: setqtenv
246setqtenv() { 407setqtenv() {
247 # Set up installation directories 408 # Set up installation directories
248 QTBASEDIR=/usr/$(get_libdir)/qt4 409 QTBASEDIR=${EPREFIX}/usr/$(get_libdir)/qt4
249 QTPREFIXDIR=/usr 410 QTPREFIXDIR=${EPREFIX}/usr
250 QTBINDIR=/usr/bin 411 QTBINDIR=${EPREFIX}/usr/bin
251 QTLIBDIR=/usr/$(get_libdir)/qt4 412 QTLIBDIR=${EPREFIX}/usr/$(get_libdir)/qt4
252 QMAKE_LIBDIR_QT=${QTLIBDIR} 413 QMAKE_LIBDIR_QT=${QTLIBDIR}
253 QTPCDIR=/usr/$(get_libdir)/pkgconfig 414 QTPCDIR=${EPREFIX}/usr/$(get_libdir)/pkgconfig
254 QTDATADIR=/usr/share/qt4 415 QTDATADIR=${EPREFIX}/usr/share/qt4
255 QTDOCDIR=/usr/share/doc/qt-${PV} 416 QTDOCDIR=${EPREFIX}/usr/share/doc/qt-${PV}
256 QTHEADERDIR=/usr/include/qt4 417 QTHEADERDIR=${EPREFIX}/usr/include/qt4
257 QTPLUGINDIR=${QTLIBDIR}/plugins 418 QTPLUGINDIR=${QTLIBDIR}/plugins
258 QTSYSCONFDIR=/etc/qt4 419 QTSYSCONFDIR=${EPREFIX}/etc/qt4
259 QTTRANSDIR=${QTDATADIR}/translations 420 QTTRANSDIR=${QTDATADIR}/translations
260 QTEXAMPLESDIR=${QTDATADIR}/examples 421 QTEXAMPLESDIR=${QTDATADIR}/examples
261 QTDEMOSDIR=${QTDATADIR}/demos 422 QTDEMOSDIR=${QTDATADIR}/demos
262 QT_INSTALL_PREFIX=/usr/$(get_libdir)/qt4 423 QT_INSTALL_PREFIX=${EPREFIX}/usr/$(get_libdir)/qt4
263 PLATFORM=$(qt_mkspecs_dir) 424 PLATFORM=$(qt_mkspecs_dir)
264 425
265 unset QMAKESPEC 426 unset QMAKESPEC
266} 427}
267 428
268# @FUNCTION: standard_configure_options 429# @FUNCTION: standard_configure_options
269# @DESCRIPTION: 430# @DESCRIPTION:
270# Sets up some standard configure options, like libdir (if necessary), whether 431# Sets up some standard configure options, like libdir (if necessary), whether
271# debug info is wanted or not. 432# debug info is wanted or not.
272standard_configure_options() { 433standard_configure_options() {
273 local myconf="" 434 local myconf=
274 435
275 [[ $(get_libdir) != "lib" ]] && myconf="${myconf} -L/usr/$(get_libdir)" 436 [[ $(get_libdir) != lib ]] && myconf+=" -L${EPREFIX}/usr/$(get_libdir)"
276 437
277 # Disable visibility explicitly if gcc version isn't 4 438 # Disable visibility explicitly if gcc version isn't 4
278 if [[ "$(gcc-major-version)" -lt "4" ]]; then 439 if [[ $(gcc-major-version) -lt 4 ]]; then
279 myconf="${myconf} -no-reduce-exports" 440 myconf+=" -no-reduce-exports"
280 fi 441 fi
281 442
282 # 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
283 if use pch; then 446 if use debug; then
284 myconf="${myconf} -pch" 447 myconf+=" -debug"
285 else 448 else
286 myconf="${myconf} -no-pch" 449 myconf+=" -release"
287 fi 450 fi
288
289 if use debug; then
290 myconf="${myconf} -debug -no-separate-debug-info" 451 myconf+=" -no-separate-debug-info"
291 else 452
292 myconf="${myconf} -release -no-separate-debug-info" 453 use aqua && myconf+=" -no-framework"
293 fi
294 454
295 # 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
296 # $(tc-arch). Therefore we convert it to supported values. 456 # $(tc-arch). Therefore we convert it to supported values.
297 case "$(tc-arch)" in 457 case "$(tc-arch)" in
298 amd64) myconf="${myconf} -arch x86_64" ;; 458 amd64|x64-*) myconf+=" -arch x86_64" ;;
459 ppc-macos) myconf+=" -arch ppc" ;;
299 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" ;;
300 x86|x86-*) myconf="${myconf} -arch i386" ;; 463 x86|x86-*) myconf+=" -arch i386" ;;
301 alpha|arm|ia64|mips|s390|sparc) myconf="${myconf} -arch $(tc-arch)" ;; 464 alpha|arm|ia64|mips|s390|sparc) myconf+=" -arch $(tc-arch)" ;;
302 hppa|sh) myconf="${myconf} -arch generic" ;; 465 hppa|sh) myconf+=" -arch generic" ;;
303 *) 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." ;;
304 esac 467 esac
305 468
306 # 4.6: build qt-core with exceptions or qt-xmlpatterns won't build 469 # 4.5: build everything but qt-xmlpatterns w/o exceptions
307 local exceptions= 470 # 4.6: exceptions USE flag
471 local exceptions="-exceptions"
308 case "${PV}" in 472 case "${PV}" in
309 4.6.*) 473 4.5.*)
310 if [[ ${PN} != "qt-core" ]] && [[ ${PN} != "qt-xmlpatterns" ]]; then 474 [[ ${PN} == "qt-xmlpatterns" ]] || exceptions="-no-exceptions"
311 exceptions="-no-exceptions"
312 fi
313 ;; 475 ;;
314 *) 476 *)
315 [[ ${PN} == "qt-xmlpatterns" ]] || exceptions="-no-exceptions" 477 has exceptions "${IUSE//+}" && exceptions="$(qt_use exceptions)"
316 ;; 478 ;;
317 esac 479 esac
318 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
319 myconf="${myconf} -platform $(qt_mkspecs_dir) -stl -verbose -largefile -confirm-license -no-rpath 488 myconf+=" -platform $(qt_mkspecs_dir) -stl -verbose -largefile -confirm-license
320 -prefix ${QTPREFIXDIR} -bindir ${QTBINDIR} -libdir ${QTLIBDIR} 489 -prefix ${QTPREFIXDIR} -bindir ${QTBINDIR} -libdir ${QTLIBDIR}
321 -datadir ${QTDATADIR} -docdir ${QTDOCDIR} -headerdir ${QTHEADERDIR} 490 -datadir ${QTDATADIR} -docdir ${QTDOCDIR} -headerdir ${QTHEADERDIR}
322 -plugindir ${QTPLUGINDIR} -sysconfdir ${QTSYSCONFDIR} 491 -plugindir ${QTPLUGINDIR} -sysconfdir ${QTSYSCONFDIR}
323 -translationdir ${QTTRANSDIR} -examplesdir ${QTEXAMPLESDIR} 492 -translationdir ${QTTRANSDIR} -examplesdir ${QTEXAMPLESDIR}
324 -demosdir ${QTDEMOSDIR} -silent -fast 493 -demosdir ${QTDEMOSDIR} -silent -fast -opensource
325 ${exceptions} 494 ${exceptions}
326 -reduce-relocations -nomake examples -nomake demos" 495 -nomake examples -nomake demos"
327
328 # Make eclass >= 4.5.x ready
329 case "${MY_PV}" in
330 4.5.* | 4.6.* )
331 myconf="${myconf} -opensource"
332 ;;
333 esac
334 496
335 echo "${myconf}" 497 echo "${myconf}"
336} 498}
337 499
338# @FUNCTION: build_directories 500# @FUNCTION: build_directories
339# @USAGE: < directories > 501# @USAGE: < directories >
340# @DESCRIPTION: 502# @DESCRIPTION:
341# Compiles the code in $QT4_TARGET_DIRECTORIES 503# Compiles the code in $QT4_TARGET_DIRECTORIES
342build_directories() { 504build_directories() {
343 local dirs="$@"
344 for x in ${dirs}; do 505 for x in "$@"; do
345 cd "${S}"/${x} 506 pushd "${S}"/${x} >/dev/null
346 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
347 "${S}"/bin/qmake "LIBS+=-L${QTLIBDIR}" "CONFIG+=nostrip" || die "qmake failed" 512 "${S}"/bin/qmake "LIBS+=-L${QTLIBDIR}" "CONFIG+=nostrip" || die "qmake failed"
348 emake CC="@echo compiling \$< && $(tc-getCC)" \ 513 emake CC="$(tc-getCC)" \
349 CXX="@echo compiling \$< && $(tc-getCXX)" \ 514 CXX="$(tc-getCXX)" \
350 LINK="@echo linking \$@ && $(tc-getCXX)" || die "emake failed" 515 LINK="$(tc-getCXX)" || die "emake failed"
516 popd >/dev/null
351 done 517 done
352} 518}
353 519
354# @FUNCTION: install_directories 520# @FUNCTION: install_directories
355# @USAGE: < directories > 521# @USAGE: < directories >
356# @DESCRIPTION: 522# @DESCRIPTION:
357# 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
358install_directories() { 524install_directories() {
359 local dirs="$@"
360 for x in ${dirs}; do 525 for x in "$@"; do
361 pushd "${S}"/${x} >/dev/null || die "Can't pushd ${S}/${x}" 526 pushd "${S}"/${x} >/dev/null || die "Can't pushd ${S}/${x}"
362 emake INSTALL_ROOT="${D}" install || die "emake install failed" 527 emake INSTALL_ROOT="${D}" install || die "emake install failed"
363 popd >/dev/null || die "Can't popd from ${S}/${x}" 528 popd >/dev/null || die "Can't popd from ${S}/${x}"
364 done 529 done
365} 530}
366 531
367# @ECLASS-VARIABLE: QCONFIG_ADD 532# @ECLASS-VARIABLE: QCONFIG_ADD
368# @DESCRIPTION: 533# @DESCRIPTION:
369# 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
370QCONFIG_ADD="${QCONFIG_ADD:-}" 535: ${QCONFIG_ADD:=}
371 536
372# @ECLASS-VARIABLE: QCONFIG_REMOVE 537# @ECLASS-VARIABLE: QCONFIG_REMOVE
373# @DESCRIPTION: 538# @DESCRIPTION:
374# 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
375QCONFIG_REMOVE="${QCONFIG_REMOVE:-}" 540: ${QCONFIG_REMOVE:=}
376 541
377# @ECLASS-VARIABLE: QCONFIG_DEFINE 542# @ECLASS-VARIABLE: QCONFIG_DEFINE
378# @DESCRIPTION: 543# @DESCRIPTION:
379# 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
380QCONFIG_DEFINE="${QCONFIG_DEFINE:-}" 545: ${QCONFIG_DEFINE:=}
381 546
382# @FUNCTION: install_qconfigs 547# @FUNCTION: install_qconfigs
383# @DESCRIPTION: Install gentoo-specific mkspecs configurations 548# @DESCRIPTION: Install gentoo-specific mkspecs configurations
384install_qconfigs() { 549install_qconfigs() {
385 local x 550 local x
386 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} ]]; then 551 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} ]]; then
387 for x in QCONFIG_ADD QCONFIG_REMOVE; do 552 for x in QCONFIG_ADD QCONFIG_REMOVE; do
388 [[ -n ${!x} ]] && echo ${x}=${!x} >> "${T}"/${PN}-qconfig.pri 553 [[ -n ${!x} ]] && echo ${x}=${!x} >> "${T}"/${PN}-qconfig.pri
389 done 554 done
390 insinto ${QTDATADIR}/mkspecs/gentoo 555 insinto ${QTDATADIR#${EPREFIX}}/mkspecs/gentoo
391 doins "${T}"/${PN}-qconfig.pri || die "installing ${PN}-qconfig.pri failed" 556 doins "${T}"/${PN}-qconfig.pri || die "installing ${PN}-qconfig.pri failed"
392 fi 557 fi
393 558
394 if [[ -n ${QCONFIG_DEFINE} ]]; then 559 if [[ -n ${QCONFIG_DEFINE} ]]; then
395 for x in ${QCONFIG_DEFINE}; do 560 for x in ${QCONFIG_DEFINE}; do
396 echo "#define ${x}" >> "${T}"/gentoo-${PN}-qconfig.h 561 echo "#define ${x}" >> "${T}"/gentoo-${PN}-qconfig.h
397 done 562 done
398 insinto ${QTHEADERDIR}/Gentoo 563 insinto ${QTHEADERDIR#${EPREFIX}}/Gentoo
399 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"
400 fi 565 fi
401} 566}
402 567
403# @FUNCTION: generate_qconfigs 568# @FUNCTION: generate_qconfigs
405generate_qconfigs() { 570generate_qconfigs() {
406 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
407 local x qconfig_add qconfig_remove qconfig_new 572 local x qconfig_add qconfig_remove qconfig_new
408 for x in "${ROOT}${QTDATADIR}"/mkspecs/gentoo/*-qconfig.pri; do 573 for x in "${ROOT}${QTDATADIR}"/mkspecs/gentoo/*-qconfig.pri; do
409 [[ -f ${x} ]] || continue 574 [[ -f ${x} ]] || continue
410 qconfig_add="${qconfig_add} $(sed -n 's/^QCONFIG_ADD=//p' "${x}")" 575 qconfig_add+=" $(sed -n 's/^QCONFIG_ADD=//p' "${x}")"
411 qconfig_remove="${qconfig_remove} $(sed -n 's/^QCONFIG_REMOVE=//p' "${x}")" 576 qconfig_remove+=" $(sed -n 's/^QCONFIG_REMOVE=//p' "${x}")"
412 done 577 done
413 578
414 # 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}
415 # just makes things worse. 580 # just makes things worse.
416 if [[ -e "${ROOT}${QTDATADIR}"/mkspecs/gentoo/qconfig.pri ]]; then 581 if [[ -e "${ROOT}${QTDATADIR}"/mkspecs/gentoo/qconfig.pri ]]; then
423 588
424 # generate list of QT_CONFIG entries from the existing list 589 # generate list of QT_CONFIG entries from the existing list
425 # including qconfig_add and excluding qconfig_remove 590 # including qconfig_add and excluding qconfig_remove
426 for x in $(sed -n 's/^QT_CONFIG +=//p' \ 591 for x in $(sed -n 's/^QT_CONFIG +=//p' \
427 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri) ${qconfig_add}; do 592 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri) ${qconfig_add}; do
428 hasq ${x} ${qconfig_remove} || qconfig_new="${qconfig_new} ${x}" 593 hasq ${x} ${qconfig_remove} || qconfig_new+=" ${x}"
429 done 594 done
430 595
431 # replace the existing QT_CONFIG list with qconfig_new 596 # replace the existing QT_CONFIG list with qconfig_new
432 if ! sed -i -e "s/QT_CONFIG +=.*/QT_CONFIG += ${qconfig_new}/" \ 597 if ! sed -i -e "s/QT_CONFIG +=.*/QT_CONFIG += ${qconfig_new}/" \
433 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri; then 598 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri; then
467# @FUNCTION: qt4-build_pkg_postinst 632# @FUNCTION: qt4-build_pkg_postinst
468# @DESCRIPTION: Generate configuration, plus throws a message about possible 633# @DESCRIPTION: Generate configuration, plus throws a message about possible
469# breakages and proposed solutions. 634# breakages and proposed solutions.
470qt4-build_pkg_postinst() { 635qt4-build_pkg_postinst() {
471 generate_qconfigs 636 generate_qconfigs
472 echo
473 ewarn "After a rebuild or upgrade of Qt, it can happen that Qt plugins (such as Qt"
474 ewarn "and KDE styles and widgets) can no longer be loaded. In this situation you"
475 ewarn "should recompile the packages providing these plugins. Also, make sure you"
476 ewarn "compile the Qt packages, and the packages that depend on it, with the same"
477 ewarn "GCC version and the same USE flag settings (especially the debug flag)."
478 ewarn
479 ewarn "Packages that typically need to be recompiled are kdelibs from KDE4, any"
480 ewarn "additional KDE4/Qt4 styles, qscintilla and PyQt4. Before filing a bug report,"
481 ewarn "make sure all your Qt4 packages are up-to-date and built with the same"
482 ewarn "configuration."
483 ewarn
484 ewarn "For more information, see http://doc.trolltech.com/${PV%.*}/plugins-howto.html"
485 echo
486} 637}
487 638
488# @FUNCTION: skip_qmake_build_patch 639# @FUNCTION: skip_qmake_build_patch
489# @DESCRIPTION: 640# @DESCRIPTION:
490# 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
526 # 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:
527 for libfile in "${D}"/${QTLIBDIR}/pkgconfig/*.pc; do 678 for libfile in "${D}"/${QTLIBDIR}/pkgconfig/*.pc; do
528 if [[ -e ${libfile} ]]; then 679 if [[ -e ${libfile} ]]; then
529 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"
530 681
531 # Move .pc files into the pkgconfig directory 682 # Move .pc files into the pkgconfig directory
532 dodir ${QTPCDIR} 683 dodir ${QTPCDIR#${EPREFIX}}
533 mv ${libfile} "${D}"/${QTPCDIR}/ \ 684 mv ${libfile} "${D}"/${QTPCDIR}/ \
534 || die "Moving ${libfile} to ${D}/${QTPCDIR}/ failed." 685 || die "Moving ${libfile} to ${D}/${QTPCDIR}/ failed."
535 fi 686 fi
536 done 687 done
537 688
545# This will echo "${enableval}-${feature}" if <flag> is enabled, or 696# This will echo "${enableval}-${feature}" if <flag> is enabled, or
546# "-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>
547# 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
548# assignment-part 699# assignment-part
549qt_use() { 700qt_use() {
550 local flag="${1}" 701 local flag=$1
551 local feature="${1}" 702 local feature=$1
552 local enableval= 703 local enableval=
553 704
554 [[ -n ${2} ]] && feature=${2} 705 [[ -n $2 ]] && feature=$2
555 [[ -n ${3} ]] && enableval="-${3}" 706 [[ -n $3 ]] && enableval=-$3
556 707
557 if use ${flag}; then 708 if use ${flag}; then
558 echo "${enableval}-${feature}" 709 echo "${enableval}-${feature}"
559 else 710 else
560 echo "-no-${feature}" 711 echo "-no-${feature}"
561 fi 712 fi
562} 713}
563 714
564# @ECLASS-VARIABLE: QT4_BUILT_WITH_USE_CHECK
565# @DESCRIPTION:
566# The contents of $QT4_BUILT_WITH_USE_CHECK gets fed to built_with_use
567# (eutils.eclass), line per line.
568#
569# Example:
570# @CODE
571# pkg_setup() {
572# use qt3support && QT4_BUILT_WITH_USE_CHECK="${QT4_BUILT_WITH_USE_CHECK}
573# ~x11-libs/qt-gui-${PV} qt3support"
574# qt4-build_check_use
575# }
576# @CODE
577
578# Run built_with_use on each flag and print appropriate error messages if any
579# flags are missing
580
581_qt_built_with_use() {
582 local missing opt pkg flag flags
583
584 if [[ ${1} = "--missing" ]]; then
585 missing="${1} ${2}" && shift 2
586 fi
587 if [[ ${1:0:1} = "-" ]]; then
588 opt=${1} && shift
589 fi
590
591 pkg=${1} && shift
592
593 for flag in "${@}"; do
594 flags="${flags} ${flag}"
595 if ! built_with_use ${missing} ${opt} ${pkg} ${flag}; then
596 flags="${flags}*"
597 else
598 [[ ${opt} = "-o" ]] && return 0
599 fi
600 done
601 if [[ "${flags# }" = "${@}" ]]; then
602 return 0
603 fi
604 if [[ ${opt} = "-o" ]]; then
605 eerror "This package requires '${pkg}' to be built with any of the following USE flags: '$*'."
606 else
607 eerror "This package requires '${pkg}' to be built with the following USE flags: '${flags# }'."
608 fi
609 return 1
610}
611
612# @FUNCTION: qt4-build_check_use
613# @DESCRIPTION:
614# Check if the listed packages in $QT4_BUILT_WITH_USE_CHECK are built with the
615# USE flags listed.
616#
617# If any of the required USE flags are missing, an eerror will be printed for
618# each package with missing USE flags.
619qt4-build_check_use() {
620 local line missing
621 while read line; do
622 [[ -z ${line} ]] && continue
623 if ! _qt_built_with_use ${line}; then
624 missing=true
625 fi
626 done <<< "${QT4_BUILT_WITH_USE_CHECK}"
627 if [[ -n ${missing} ]]; then
628 echo
629 eerror "Flags marked with an * are missing."
630 die "Missing USE flags found"
631 fi
632}
633
634# @FUNCTION: qt_mkspecs_dir 715# @FUNCTION: qt_mkspecs_dir
635# @RETURN: the specs-directory w/o path 716# @RETURN: the specs-directory w/o path
636# @DESCRIPTION: 717# @DESCRIPTION:
637# Allows us to define which mkspecs dir we want to use. 718# Allows us to define which mkspecs dir we want to use.
638qt_mkspecs_dir() { 719qt_mkspecs_dir() {
639 # Allows us to define which mkspecs dir we want to use. 720 # Allows us to define which mkspecs dir we want to use.
640 local spec 721 local spec
641 722
642 case ${CHOST} in 723 case ${CHOST} in
643 *-freebsd*|*-dragonfly*) 724 *-freebsd*|*-dragonfly*)
644 spec="freebsd" ;; 725 spec=freebsd ;;
645 *-openbsd*) 726 *-openbsd*)
646 spec="openbsd" ;; 727 spec=openbsd ;;
647 *-netbsd*) 728 *-netbsd*)
648 spec="netbsd" ;; 729 spec=netbsd ;;
649 *-darwin*) 730 *-darwin*)
731 if use aqua; then
732 # mac with carbon/cocoa
733 spec=macx
734 else
735 # darwin/mac with x11
650 spec="darwin" ;; 736 spec=darwin
737 fi
738 ;;
739 *-solaris*)
740 spec=solaris ;;
651 *-linux-*|*-linux) 741 *-linux-*|*-linux)
652 spec="linux" ;; 742 spec=linux ;;
653 *) 743 *)
654 die "Unknown CHOST, no platform choosen." 744 die "Unknown CHOST, no platform choosen."
655 esac 745 esac
656 746
657 CXX=$(tc-getCXX) 747 CXX=$(tc-getCXX)
658 if [[ ${CXX/g++/} != ${CXX} ]]; then 748 if [[ ${CXX} == *g++* ]]; then
659 spec="${spec}-g++" 749 spec+=-g++
660 elif [[ ${CXX/icpc/} != ${CXX} ]]; then 750 elif [[ ${CXX} == *icpc* ]]; then
661 spec="${spec}-icc" 751 spec+=-icc
662 else 752 else
663 die "Unknown compiler ${CXX}." 753 die "Unknown compiler ${CXX}."
664 fi 754 fi
665 if [[ -n "${LIBDIR/lib}" ]]; then 755 if [[ -n ${LIBDIR/lib} ]]; then
666 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
667 fi 767 fi
668 768
669 echo "${spec}" 769 echo "${spec}"
670} 770}
671 771
672case ${EAPI:-0} in 772# @FUNCTION: qt_assistant_cleanup
673 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
674 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
675esac

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

  ViewVC Help
Powered by ViewVC 1.1.20