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

Legend:
Removed from v.1.54  
changed lines
  Added in v.1.70

  ViewVC Help
Powered by ViewVC 1.1.20