/[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.57
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.57 2009/12/24 21:40:23 abcd 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" 17IUSE="debug pch aqua"
18RDEPEND=" 18RDEPEND="
19 !<x11-libs/qt-assistant-${PV} 19 !<x11-libs/qt-assistant-${PV}
20 !>x11-libs/qt-assistant-${PV}-r9999 20 !>x11-libs/qt-assistant-${PV}-r9999
21 !<x11-libs/qt-core-${PV} 21 !<x11-libs/qt-core-${PV}
22 !>x11-libs/qt-core-${PV}-r9999 22 !>x11-libs/qt-core-${PV}-r9999
43 !<x11-libs/qt-webkit-${PV} 43 !<x11-libs/qt-webkit-${PV}
44 !>x11-libs/qt-webkit-${PV}-r9999 44 !>x11-libs/qt-webkit-${PV}-r9999
45 !<x11-libs/qt-xmlpatterns-${PV} 45 !<x11-libs/qt-xmlpatterns-${PV}
46 !>x11-libs/qt-xmlpatterns-${PV}-r9999 46 !>x11-libs/qt-xmlpatterns-${PV}-r9999
47" 47"
48case "${PV}" in 48
49 4.?.?_rc* | 4.?.?_beta* )
50 SRCTYPE="${SRCTYPE:-opensource-src}"
51 MY_PV="${PV/_/-}" 49MY_PV=${PV/_/-}
52 ;;
53 *)
54 SRCTYPE="${SRCTYPE:-opensource-src}"
55 MY_PV="${PV}"
56 ;;
57esac
58 50
51HOMEPAGE="http://qt.nokia.com/"
59if version_is_at_least 4.5.99999999 ${PV} ; then 52if version_is_at_least 4.5.99999999 ${PV} ; then
60 MY_P="qt-everywhere-${SRCTYPE}-${MY_PV}" 53 SRC_URI="http://get.qt.nokia.com/qt/source/qt-everywhere-opensource-src-${MY_PV}.tar.gz"
61else 54else
62 MY_P="qt-x11-${SRCTYPE}-${MY_PV}" 55 SRC_URI="aqua? ( http://get.qt.nokia.com/qt/source/qt-mac-opensource-src-${MY_PV}.tar.gz )
56 !aqua? ( http://get.qt.nokia.com/qt/source/qt-x11-opensource-src-${MY_PV}.tar.gz )"
63fi 57fi
64S=${WORKDIR}/${MY_P}
65 58
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 )" 59LICENSE="|| ( LGPL-2.1 GPL-3 )"
80fi
81 60
82# @FUNCTION: qt4-build_pkg_setup 61# @FUNCTION: qt4-build_pkg_setup
83# @DESCRIPTION: 62# @DESCRIPTION:
84# Sets up installation directories, PLATFORM, PATH, and LD_LIBRARY_PATH 63# Sets up S, MY_P, PATH, and LD_LIBRARY_PATH
85qt4-build_pkg_setup() { 64qt4-build_pkg_setup() {
86 # EAPI=2 ebuilds set use-deps, others need this: 65 [[ ${EAPI} == 2 ]] && use !prefix && EPREFIX=
87 if [[ $EAPI != 2 ]]; then 66
88 # Make sure debug setting corresponds with qt-core (bug 258512) 67 local MY_GE
89 if [[ $PN != "qt-core" ]]; then 68 if version_is_at_least 4.5.99999999 ${PV} ; then
90 use debug && QT4_BUILT_WITH_USE_CHECK="${QT4_BUILT_WITH_USE_CHECK} 69 MY_P=qt-everywhere-opensource-src-${MY_PV}
91 ~x11-libs/qt-core-${PV} debug" 70 else
71 use aqua \
72 && MY_GE=mac \
73 || MY_GE=x11
74 MY_P=qt-${MY_GE}-opensource-src-${MY_PV}
75 fi
76 S=${WORKDIR}/${MY_P}
77
78 PATH="${S}/bin${PATH:+:}${PATH}"
79 if [[ ${CHOST} != *-darwin* ]]; then
80 LD_LIBRARY_PATH="${S}/lib${LD_LIBRARY_PATH:+:}${LD_LIBRARY_PATH}"
81 else
82 DYLD_LIBRARY_PATH="${S}/lib${DYLD_LIBRARY_PATH:+:}${DYLD_LIBRARY_PATH}"
83 # on mac we *need* src/gui/kernel/qapplication_mac.cpp for platfrom
84 # detection since the x11-headers package b0rkens the header
85 # installation, we have to extract src/ and include/ completely on mac
86 # tools is needed for qt-demo and some others
87 QT4_EXTRACT_DIRECTORIES+=" src include"
88
89 if [[ ${PN} == qt-demo || ${PN} == qt-qt3support || ${PN} == qt-webkit ]]; then
90 QT4_EXTRACT_DIRECTORIES+=" tools"
92 fi 91 fi
93
94 # Check USE requirements
95 qt4-build_check_use
96 fi 92 fi
97 93
98 PATH="${S}/bin:${PATH}" 94 # Make sure ebuilds use the required EAPI
99 LD_LIBRARY_PATH="${S}/lib:${LD_LIBRARY_PATH}" 95 if [[ ${EAPI} != [23] ]]; then
96 eerror "The qt4-build eclass requires EAPI=2 or EAPI=3, but this ebuild is using"
97 eerror "EAPI=${EAPI:-0}. The ebuild author or editor failed. This ebuild needs to be"
98 eerror "fixed. Using qt4-build eclass without EAPI=2 or EAPI=3 will fail."
99 die "qt4-build eclass requires EAPI=2 or EAPI=3"
100 fi
100 101
101 if ! version_is_at_least 4.1 $(gcc-version) ; then 102 if ! version_is_at_least 4.1 $(gcc-version); then
102 ewarn "Using a GCC version lower than 4.1 is not supported!" 103 ewarn "Using a GCC version lower than 4.1 is not supported!"
103 echo 104 echo
104 ebeep 3 105 ebeep 3
105 fi 106 fi
106 107
107 if [[ "${P}" == "qt-core-4.6.0_rc1" ]]; then 108 if [[ ${P} == qt-core-4.6.0_rc1 ]]; then
108 ewarn 109 ewarn
109 ewarn "Binary compatibility broke between 4.6.0_beta1 and 4.6.0_rc1." 110 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 "If you are upgrading from 4.6.0_beta1, you'll have to"
111 ewarn "re-emerge everything that depends on Qt." 112 ewarn "re-emerge everything that depends on Qt."
112 ewarn "Use the following command:" 113 ewarn "Use the following command:"
113 ewarn 114 ewarn
114 ewarn " emerge -av1 \$(for i in \$(qlist -IC x11-libs/qt-);" 115 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 " do equery -q d \$i | grep -v 'x11-libs/qt-' |"
116 ewarn " sed \"s/^/=/\"; done)" 117 ewarn " sed \"s/^/=/\"; done)"
117 ewarn 118 ewarn
118 ewarn "YOU'VE BEEN WARNED" 119 ewarn "YOU'VE BEEN WARNED"
119 ewarn 120 ewarn
120 ebeep 3 121 ebeep 3
121 fi 122 fi
122 123
123} 124}
124 125
125# @ECLASS-VARIABLE: QT4_TARGET_DIRECTORIES 126# @ECLASS-VARIABLE: QT4_TARGET_DIRECTORIES
126# @DESCRIPTION: 127# @DESCRIPTION:
127# Arguments for build_target_directories. Takes the directories, in which the 128# Arguments for build_target_directories. Takes the directories, in which the
135# @FUNCTION: qt4-build_src_unpack 136# @FUNCTION: qt4-build_src_unpack
136# @DESCRIPTION: 137# @DESCRIPTION:
137# Unpacks the sources 138# Unpacks the sources
138qt4-build_src_unpack() { 139qt4-build_src_unpack() {
139 setqtenv 140 setqtenv
140 local target targets licenses tar_pkg tar_args 141 local target targets=
141 if version_is_at_least 4.5 ${PV} ; then 142 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 \ 143 src/{qbase,qt_targets,qt_install}.pri bin config.tests mkspecs qmake \
148 ${QT4_EXTRACT_DIRECTORIES}; do 144 ${QT4_EXTRACT_DIRECTORIES}; do
149 targets="${targets} ${MY_P}/${target}" 145 targets+=" ${MY_P}/${target}"
150 done 146 done
151 147
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 148 echo tar xzpf "${DISTDIR}"/${MY_P}.tar.gz ${targets}
165 tar xjpf "${DISTDIR}"/${MY_P}-headers.tar.bz2 149 tar xzpf "${DISTDIR}"/${MY_P}.tar.gz ${targets}
166 ;;
167 esac
168
169 # Be backwards compatible for now
170 if [[ $EAPI != 2 ]]; then
171 qt4-build_src_prepare
172 fi
173} 150}
174 151
175# @ECLASS-VARIABLE: PATCHES 152# @ECLASS-VARIABLE: PATCHES
176# @DESCRIPTION: 153# @DESCRIPTION:
177# In case you have patches to apply, specify them in PATCHES variable. Make sure 154# 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. 164# source files in order to respect CFLAGS/CXXFLAGS/LDFLAGS specified on /etc/make.conf.
188qt4-build_src_prepare() { 165qt4-build_src_prepare() {
189 setqtenv 166 setqtenv
190 cd "${S}" 167 cd "${S}"
191 168
169 if use aqua; then
170 # provide a proper macx-g++-64
171 use x64-macos && ln -s macx-g++ mkspecs/$(qt_mkspecs_dir)
172
173 sed -e '/^CONFIG/s:app_bundle::' \
174 -e '/^CONFIG/s:plugin_no_soname:plugin_with_soname absolute_library_soname:' \
175 -i mkspecs/$(qt_mkspecs_dir)/qmake.conf || die "sed failed"
176 fi
177
192 if [[ ${PN} != qt-core ]]; then 178 if [[ ${PN} != qt-core ]]; then
193 skip_qmake_build_patch 179 skip_qmake_build_patch
194 skip_project_generation_patch 180 skip_project_generation_patch
195 symlink_binaries_to_buildtree 181 symlink_binaries_to_buildtree
182 fi
183
184 if [[ ${CHOST} == *86*-apple-darwin* ]] ; then
185 # qmake bus errors with -O2 but -O3 works
186 replace-flags -O2 -O3
196 fi 187 fi
197 188
198 # Bug 282984 && Bug 295530 189 # Bug 282984 && Bug 295530
199 sed -e "s:\(^SYSTEM_VARIABLES\):CC=$(tc-getCC)\nCXX=$(tc-getCXX)\n\1:" \ 190 sed -e "s:\(^SYSTEM_VARIABLES\):CC=$(tc-getCC)\nCXX=$(tc-getCXX)\n\1:" \
200 -i configure || die "sed qmake compilers failed" 191 -i configure || die "sed qmake compilers failed"
201 sed -e "s:\(\$MAKE\):\1 CC=$(tc-getCC) CXX=$(tc-getCXX) LD=$(tc-getCXX):" \ 192 sed -e "s:\(\$MAKE\):\1 CC=$(tc-getCC) CXX=$(tc-getCXX) LD=$(tc-getCXX):" \
202 -i config.tests/unix/compile.test || die "sed test compilers failed" 193 -i config.tests/unix/compile.test || die "sed test compilers failed"
203 194
204 # Bug 178652 195 # Bug 178652
205 if [[ "$(gcc-major-version)" == "3" ]] && use amd64; then 196 if [[ $(gcc-major-version) == 3 ]] && use amd64; then
206 ewarn "Appending -fno-gcse to CFLAGS/CXXFLAGS" 197 ewarn "Appending -fno-gcse to CFLAGS/CXXFLAGS"
207 append-flags -fno-gcse 198 append-flags -fno-gcse
208 fi 199 fi
209 200
210 # Unsupported old gcc versions - hardened needs this :( 201 # Unsupported old gcc versions - hardened needs this :(
211 if [[ $(gcc-major-version) -lt "4" ]] ; then 202 if [[ $(gcc-major-version) -lt 4 ]] ; then
212 ewarn "Appending -fno-stack-protector to CXXFLAGS" 203 ewarn "Appending -fno-stack-protector to CXXFLAGS"
213 append-cxxflags -fno-stack-protector 204 append-cxxflags -fno-stack-protector
214 # Bug 253127 205 # Bug 253127
215 sed -e "/^QMAKE_CFLAGS\t/ s:$: -fno-stack-protector-all:" \ 206 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" 207 -i "${S}"/mkspecs/common/g++.conf || die "sed ${S}/mkspecs/common/g++.conf failed"
227 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \ 218 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \
228 -e "s:QMAKE_LFLAGS_RELEASE.*=.*:QMAKE_LFLAGS_RELEASE=${LDFLAGS}:" \ 219 -e "s:QMAKE_LFLAGS_RELEASE.*=.*:QMAKE_LFLAGS_RELEASE=${LDFLAGS}:" \
229 -e "s:X11R6/::" \ 220 -e "s:X11R6/::" \
230 -i "${S}"/mkspecs/$(qt_mkspecs_dir)/qmake.conf || die "sed ${S}/mkspecs/$(qt_mkspecs_dir)/qmake.conf failed" 221 -i "${S}"/mkspecs/$(qt_mkspecs_dir)/qmake.conf || die "sed ${S}/mkspecs/$(qt_mkspecs_dir)/qmake.conf failed"
231 222
223 if [[ ${CHOST} != *-darwin* ]]; then
232 sed -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \ 224 sed -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \
233 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \ 225 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \
234 -e "s:QMAKE_LFLAGS_RELEASE.*=.*:QMAKE_LFLAGS_RELEASE=${LDFLAGS}:" \ 226 -e "s:QMAKE_LFLAGS_RELEASE.*=.*:QMAKE_LFLAGS_RELEASE=${LDFLAGS}:" \
235 -i "${S}"/mkspecs/common/g++.conf || die "sed ${S}/mkspecs/common/g++.conf failed" 227 -i mkspecs/common/g++.conf || die "sed mkspecs/common/g++.conf failed"
228 else
229 # Set FLAGS *and* remove -arch, since our gcc-apple is multilib
230 # crippled (by design) :/
231 sed -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \
232 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \
233 -e "s:QMAKE_LFLAGS_RELEASE.*=.*:QMAKE_LFLAGS_RELEASE=-headerpad_max_install_names ${LDFLAGS}:" \
234 -e "s:-arch\s\w*::g" \
235 -i mkspecs/common/mac-g++.conf || die "sed mkspecs/common/mac-g++.conf failed"
236
237 # Fix configure's -arch settings that appear in qmake/Makefile and also
238 # fix arch handling (automagically duplicates our -arch arg and breaks
239 # pch). Additionally disable Xarch support.
240 sed \
241 -e "s:-arch i386::" \
242 -e "s:-arch ppc::" \
243 -e "s:-arch x86_64::" \
244 -e "s:-arch ppc64::" \
245 -e "s:-arch \$i::" \
246 -e "/if \[ ! -z \"\$NATIVE_64_ARCH\" \]; then/,/fi/ d" \
247 -e "s:CFG_MAC_XARCH=yes:CFG_MAC_XARCH=no:g" \
248 -e "s:-Xarch_x86_64::g" \
249 -e "s:-Xarch_ppc64::g" \
250 -i configure mkspecs/common/mac-g++.conf || die "sed configure failed"
251
252 # On Snow Leopard don't fall back to 10.5 deployment target.
253 if [[ ${CHOST} == *-apple-darwin10 ]] ; then
254 sed -e "s:QMakeVar set QMAKE_MACOSX_DEPLOYMENT_TARGET.*:QMakeVar set QMAKE_MACOSX_DEPLOYMENT_TARGET 10.6:g" \
255 -e "s:-mmacosx-version-min=10.[0-9]:-mmacosx-version-min=10.6:g" \
256 -i configure mkspecs/common/mac-g++.conf || die "sed configure failed"
257 fi
258 fi
259
260 # this one is needed for all systems with a separate -liconv, apart from
261 # Darwin, for which the sources already cater for -liconv
262 if use !elibc_glibc && [[ ${CHOST} != *-darwin* ]] ; then
263 sed \
264 -e "s|mac:LIBS += -liconv|LIBS += -liconv|g" \
265 -i config.tests/unix/iconv/iconv.pro \
266 || die "sed on iconv.pro failed"
267 fi
268
269 # we need some patches for Solaris
270 sed -i \
271 -e '/^QMAKE_LFLAGS_THREAD/a\QMAKE_LFLAGS_DYNAMIC_LIST = -Wl,--dynamic-list,' \
272 mkspecs/$(qt_mkspecs_dir)/qmake.conf || die
273 # use GCC over SunStudio
274 sed -i -e '/PLATFORM=solaris-cc/s/cc/g++/' configure || die
275 # don't flirt with non-Prefix stuff, we're quite possessive
276 sed -i -e '/^QMAKE_\(LIB\|INC\)DIR\(_X11\|_OPENGL\|\)\t/s/=.*$/=/' \
277 mkspecs/$(qt_mkspecs_dir)/qmake.conf || die
236 278
237 base_src_prepare 279 base_src_prepare
238} 280}
239 281
240# @FUNCTION: qt4-build_src_configure 282# @FUNCTION: qt4-build_src_configure
242# Default configure phase 284# Default configure phase
243qt4-build_src_configure() { 285qt4-build_src_configure() {
244 setqtenv 286 setqtenv
245 myconf="$(standard_configure_options) ${myconf}" 287 myconf="$(standard_configure_options) ${myconf}"
246 288
289 # this one is needed for all systems with a separate -liconv, apart from
290 # Darwin, for which the sources already cater for -liconv
291 use !elibc_glibc && [[ ${CHOST} != *-darwin* ]] && \
292 myconf+=" -liconv"
293
294 if has glib ${IUSE//+} && use glib; then
295 # use -I, -L and -l from configure
296 local glibflags="$(pkg-config --cflags --libs glib-2.0 gthread-2.0)"
297 # avoid the -pthread argument
298 myconf+=" ${glibflags//-pthread}"
299 unset glibflags
300 fi
301
302 if use aqua ; then
303 # On (snow) leopard use the new (frameworked) cocoa code.
304 if [[ $(uname -r | cut -d . -f 1) -ge 9 ]] ; then
305 myconf+=" -cocoa -framework"
306
307 # We are crazy and build cocoa + qt3support :-)
308 if use qt3support; then
309 sed -e "/case \"\$PLATFORM,\$CFG_MAC_COCOA\" in/,/;;/ s|CFG_QT3SUPPORT=\"no\"|CFG_QT3SUPPORT=\"yes\"|" \
310 -i configure
311 fi
312
313 # We need the source's headers, not the installed ones.
314 myconf+=" -I${S}/include"
315
316 # Add hint for the framework location.
317 myconf+=" -F${QTLIBDIR}"
318 fi
319 else
320 # freetype2 include dir is non-standard, thus include it on configure
321 # use -I from configure
322 myconf+=" $(pkg-config --cflags freetype2)"
323 fi
324
247 echo ./configure ${myconf} 325 echo ./configure ${myconf}
248 ./configure ${myconf} || die "./configure failed" 326 ./configure ${myconf} || die "./configure failed"
249 myconf="" 327 myconf=""
250} 328}
251 329
252# @FUNCTION: qt4-build_src_compile 330# @FUNCTION: qt4-build_src_compile
253# @DESCRIPTION: Actual compile phase 331# @DESCRIPTION: Actual compile phase
254qt4-build_src_compile() { 332qt4-build_src_compile() {
255 setqtenv 333 setqtenv
256 # Be backwards compatible for now
257 if [[ $EAPI != 2 ]]; then
258 qt4-build_src_configure
259 fi
260 334
261 build_directories "${QT4_TARGET_DIRECTORIES}" 335 build_directories ${QT4_TARGET_DIRECTORIES}
336}
337
338# @FUNCTION: fix_includes
339# @DESCRIPTION:
340# For MacOSX we need to add some symlinks when frameworks are
341# being used, to avoid complications with some more or less stupid packages.
342fix_includes() {
343 if use aqua && [[ $(uname -r | cut -d . -f 1) -ge 9 ]] ; then
344 # Some packages tend to include <Qt/...>
345 dodir "${QTHEADERDIR#${EPREFIX}}"/Qt
346
347 # Fake normal headers when frameworks are installed... eases life later on
348 local dest f
349 for frw in "${D}${QTLIBDIR}"/*.framework; do
350 [[ -e "${frw}"/Headers ]] || continue
351 f=$(basename ${frw})
352 dest="${QTHEADERDIR#${EPREFIX}}"/${f%.framework}
353 dosym "${QTLIBDIR#${EPREFIX}}"/${f}/Headers "${dest}"
354
355 # Link normal headers as well.
356 for hdr in "${D}/${QTLIBDIR}/${f}"/Headers/*; do
357 h=$(basename ${hdr})
358 dosym "${QTLIBDIR#${EPREFIX}}"/${f}/Headers/${h} "${QTHEADERDIR#${EPREFIX}}"/Qt/${h}
359 done
360 done
361 fi
262} 362}
263 363
264# @FUNCTION: qt4-build_src_install 364# @FUNCTION: qt4-build_src_install
265# @DESCRIPTION: 365# @DESCRIPTION:
266# Perform the actual installation including some library fixes. 366# Perform the actual installation including some library fixes.
267qt4-build_src_install() { 367qt4-build_src_install() {
368 [[ ${EAPI} == 2 ]] && use !prefix && ED=${D}
268 setqtenv 369 setqtenv
269 install_directories "${QT4_TARGET_DIRECTORIES}" 370 install_directories ${QT4_TARGET_DIRECTORIES}
270 install_qconfigs 371 install_qconfigs
271 fix_library_files 372 fix_library_files
373 fix_includes
272} 374}
273 375
274# @FUNCTION: setqtenv 376# @FUNCTION: setqtenv
275setqtenv() { 377setqtenv() {
276 # Set up installation directories 378 # Set up installation directories
277 QTBASEDIR=/usr/$(get_libdir)/qt4 379 QTBASEDIR=${EPREFIX}/usr/$(get_libdir)/qt4
278 QTPREFIXDIR=/usr 380 QTPREFIXDIR=${EPREFIX}/usr
279 QTBINDIR=/usr/bin 381 QTBINDIR=${EPREFIX}/usr/bin
280 QTLIBDIR=/usr/$(get_libdir)/qt4 382 QTLIBDIR=${EPREFIX}/usr/$(get_libdir)/qt4
281 QMAKE_LIBDIR_QT=${QTLIBDIR} 383 QMAKE_LIBDIR_QT=${QTLIBDIR}
282 QTPCDIR=/usr/$(get_libdir)/pkgconfig 384 QTPCDIR=${EPREFIX}/usr/$(get_libdir)/pkgconfig
283 QTDATADIR=/usr/share/qt4 385 QTDATADIR=${EPREFIX}/usr/share/qt4
284 QTDOCDIR=/usr/share/doc/qt-${PV} 386 QTDOCDIR=${EPREFIX}/usr/share/doc/qt-${PV}
285 QTHEADERDIR=/usr/include/qt4 387 QTHEADERDIR=${EPREFIX}/usr/include/qt4
286 QTPLUGINDIR=${QTLIBDIR}/plugins 388 QTPLUGINDIR=${QTLIBDIR}/plugins
287 QTSYSCONFDIR=/etc/qt4 389 QTSYSCONFDIR=${EPREFIX}/etc/qt4
288 QTTRANSDIR=${QTDATADIR}/translations 390 QTTRANSDIR=${QTDATADIR}/translations
289 QTEXAMPLESDIR=${QTDATADIR}/examples 391 QTEXAMPLESDIR=${QTDATADIR}/examples
290 QTDEMOSDIR=${QTDATADIR}/demos 392 QTDEMOSDIR=${QTDATADIR}/demos
291 QT_INSTALL_PREFIX=/usr/$(get_libdir)/qt4 393 QT_INSTALL_PREFIX=${EPREFIX}/usr/$(get_libdir)/qt4
292 PLATFORM=$(qt_mkspecs_dir) 394 PLATFORM=$(qt_mkspecs_dir)
293 395
294 unset QMAKESPEC 396 unset QMAKESPEC
295} 397}
296 398
297# @FUNCTION: standard_configure_options 399# @FUNCTION: standard_configure_options
298# @DESCRIPTION: 400# @DESCRIPTION:
299# Sets up some standard configure options, like libdir (if necessary), whether 401# Sets up some standard configure options, like libdir (if necessary), whether
300# debug info is wanted or not. 402# debug info is wanted or not.
301standard_configure_options() { 403standard_configure_options() {
302 local myconf="" 404 local myconf=
303 405
406 # Doesn't need ${EPREFIX} because get_libdir() is *always* lib on prefix
304 [[ $(get_libdir) != "lib" ]] && myconf="${myconf} -L/usr/$(get_libdir)" 407 [[ $(get_libdir) != lib ]] && myconf+=" -L/usr/$(get_libdir)"
305 408
306 # Disable visibility explicitly if gcc version isn't 4 409 # Disable visibility explicitly if gcc version isn't 4
307 if [[ "$(gcc-major-version)" -lt "4" ]]; then 410 if [[ $(gcc-major-version) -lt 4 ]]; then
308 myconf="${myconf} -no-reduce-exports" 411 myconf+=" -no-reduce-exports"
309 fi 412 fi
310 413
311 # precompiled headers doesn't work on hardened, where the flag is masked. 414 # precompiled headers doesn't work on hardened, where the flag is masked.
415 myconf+=" $(qt_use pch)"
416
312 if use pch; then 417 if use debug; then
313 myconf="${myconf} -pch" 418 myconf+=" -debug"
314 else 419 else
315 myconf="${myconf} -no-pch" 420 myconf+=" -release"
316 fi 421 fi
317
318 if use debug; then
319 myconf="${myconf} -debug -no-separate-debug-info" 422 myconf+=" -no-separate-debug-info"
320 else 423
321 myconf="${myconf} -release -no-separate-debug-info" 424 use aqua && myconf+=" -no-framework"
322 fi
323 425
324 # ARCH is set on Gentoo. Qt now falls back to generic on an unsupported 426 # ARCH is set on Gentoo. Qt now falls back to generic on an unsupported
325 # $(tc-arch). Therefore we convert it to supported values. 427 # $(tc-arch). Therefore we convert it to supported values.
326 case "$(tc-arch)" in 428 case "$(tc-arch)" in
327 amd64) myconf="${myconf} -arch x86_64" ;; 429 amd64|x64-*) myconf+=" -arch x86_64" ;;
430 ppc-macos) myconf+=" -arch ppc" ;;
328 ppc|ppc64) myconf="${myconf} -arch powerpc" ;; 431 ppc|ppc64|ppc-*) myconf+=" -arch powerpc" ;;
432 sparc|sparc-*) myconf+=" -arch sparc" ;;
433 x86-macos) myconf+=" -arch x86" ;;
329 x86|x86-*) myconf="${myconf} -arch i386" ;; 434 x86|x86-*) myconf+=" -arch i386" ;;
330 alpha|arm|ia64|mips|s390|sparc) myconf="${myconf} -arch $(tc-arch)" ;; 435 alpha|arm|ia64|mips|s390|sparc) myconf+=" -arch $(tc-arch)" ;;
331 hppa|sh) myconf="${myconf} -arch generic" ;; 436 hppa|sh) myconf+=" -arch generic" ;;
332 *) die "$(tc-arch) is unsupported by this eclass. Please file a bug." ;; 437 *) die "$(tc-arch) is unsupported by this eclass. Please file a bug." ;;
333 esac 438 esac
334 439
335 # 4.6: build qt-core with exceptions or qt-xmlpatterns won't build 440 # 4.6: build qt-core with exceptions or qt-xmlpatterns won't build
336 local exceptions= 441 local exceptions=
337 case "${PV}" in 442 case "${PV}" in
338 4.6.*) 443 4.6.*)
339 if [[ ${PN} != "qt-core" ]] && [[ ${PN} != "qt-xmlpatterns" ]]; then 444 if [[ ${PN} != "qt-core" ]] && [[ ${PN} != "qt-xmlpatterns" ]]; then
445 case "${PV}:${CHOST}" in
446 4.6.0*:*-darwin*)
447 : # http://bugreports.qt.nokia.com/browse/QTBUG-5909
448 # workaround for compilation error on OSX (qt-gui)
449 ;;
450 *)
340 exceptions="-no-exceptions" 451 exceptions="-no-exceptions"
452 ;;
453 esac
341 fi 454 fi
342 ;; 455 ;;
343 *) 456 *)
344 [[ ${PN} == "qt-xmlpatterns" ]] || exceptions="-no-exceptions" 457 [[ ${PN} == "qt-xmlpatterns" ]] || exceptions="-no-exceptions"
345 ;; 458 ;;
346 esac 459 esac
347 460
461 # note about -reduce-relocations:
462 # That flag seems to introduce major breakage to applications,
463 # mostly to be seen as a core dump with the message "QPixmap: Must
464 # construct a QApplication before a QPaintDevice" on Solaris
465 # -- Daniel Vergien
466 [[ ${CHOST} != *-solaris* ]] && myconf+=" -reduce-relocations"
467
348 myconf="${myconf} -platform $(qt_mkspecs_dir) -stl -verbose -largefile -confirm-license 468 myconf+=" -platform $(qt_mkspecs_dir) -stl -verbose -largefile -confirm-license
349 -prefix ${QTPREFIXDIR} -bindir ${QTBINDIR} -libdir ${QTLIBDIR} 469 -prefix ${QTPREFIXDIR} -bindir ${QTBINDIR} -libdir ${QTLIBDIR}
350 -datadir ${QTDATADIR} -docdir ${QTDOCDIR} -headerdir ${QTHEADERDIR} 470 -datadir ${QTDATADIR} -docdir ${QTDOCDIR} -headerdir ${QTHEADERDIR}
351 -plugindir ${QTPLUGINDIR} -sysconfdir ${QTSYSCONFDIR} 471 -plugindir ${QTPLUGINDIR} -sysconfdir ${QTSYSCONFDIR}
352 -translationdir ${QTTRANSDIR} -examplesdir ${QTEXAMPLESDIR} 472 -translationdir ${QTTRANSDIR} -examplesdir ${QTEXAMPLESDIR}
353 -demosdir ${QTDEMOSDIR} -silent -fast 473 -demosdir ${QTDEMOSDIR} -silent -fast -opensource
354 ${exceptions} 474 ${exceptions}
355 -reduce-relocations -nomake examples -nomake demos" 475 -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 476
364 echo "${myconf}" 477 echo "${myconf}"
365} 478}
366 479
367# @FUNCTION: build_directories 480# @FUNCTION: build_directories
368# @USAGE: < directories > 481# @USAGE: < directories >
369# @DESCRIPTION: 482# @DESCRIPTION:
370# Compiles the code in $QT4_TARGET_DIRECTORIES 483# Compiles the code in $QT4_TARGET_DIRECTORIES
371build_directories() { 484build_directories() {
372 local dirs="$@"
373 for x in ${dirs}; do 485 for x in "$@"; do
374 cd "${S}"/${x} 486 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 487 sed -i -e "s:\$\$\[QT_INSTALL_LIBS\]:${EPREFIX}/usr/$(get_libdir)/qt4:g" $(find "${S}" -name '*.pr[io]') "${S}"/mkspecs/common/*.conf || die
376 "${S}"/bin/qmake "LIBS+=-L${QTLIBDIR}" "CONFIG+=nostrip" || die "qmake failed" 488 "${S}"/bin/qmake "LIBS+=-L${QTLIBDIR}" "CONFIG+=nostrip" || die "qmake failed"
377 emake CC="@echo compiling \$< && $(tc-getCC)" \ 489 emake CC="@echo compiling \$< && $(tc-getCC)" \
378 CXX="@echo compiling \$< && $(tc-getCXX)" \ 490 CXX="@echo compiling \$< && $(tc-getCXX)" \
379 LINK="@echo linking \$@ && $(tc-getCXX)" || die "emake failed" 491 LINK="@echo linking \$@ && $(tc-getCXX)" || die "emake failed"
492 popd >/dev/null
380 done 493 done
381} 494}
382 495
383# @FUNCTION: install_directories 496# @FUNCTION: install_directories
384# @USAGE: < directories > 497# @USAGE: < directories >
385# @DESCRIPTION: 498# @DESCRIPTION:
386# run emake install in the given directories, which are separated by spaces 499# run emake install in the given directories, which are separated by spaces
387install_directories() { 500install_directories() {
388 local dirs="$@"
389 for x in ${dirs}; do 501 for x in "$@"; do
390 pushd "${S}"/${x} >/dev/null || die "Can't pushd ${S}/${x}" 502 pushd "${S}"/${x} >/dev/null || die "Can't pushd ${S}/${x}"
391 emake INSTALL_ROOT="${D}" install || die "emake install failed" 503 emake INSTALL_ROOT="${D}" install || die "emake install failed"
392 popd >/dev/null || die "Can't popd from ${S}/${x}" 504 popd >/dev/null || die "Can't popd from ${S}/${x}"
393 done 505 done
394} 506}
395 507
396# @ECLASS-VARIABLE: QCONFIG_ADD 508# @ECLASS-VARIABLE: QCONFIG_ADD
397# @DESCRIPTION: 509# @DESCRIPTION:
398# List options that need to be added to QT_CONFIG in qconfig.pri 510# List options that need to be added to QT_CONFIG in qconfig.pri
399QCONFIG_ADD="${QCONFIG_ADD:-}" 511: ${QCONFIG_ADD:=}
400 512
401# @ECLASS-VARIABLE: QCONFIG_REMOVE 513# @ECLASS-VARIABLE: QCONFIG_REMOVE
402# @DESCRIPTION: 514# @DESCRIPTION:
403# List options that need to be removed from QT_CONFIG in qconfig.pri 515# List options that need to be removed from QT_CONFIG in qconfig.pri
404QCONFIG_REMOVE="${QCONFIG_REMOVE:-}" 516: ${QCONFIG_REMOVE:=}
405 517
406# @ECLASS-VARIABLE: QCONFIG_DEFINE 518# @ECLASS-VARIABLE: QCONFIG_DEFINE
407# @DESCRIPTION: 519# @DESCRIPTION:
408# List variables that should be defined at the top of QtCore/qconfig.h 520# List variables that should be defined at the top of QtCore/qconfig.h
409QCONFIG_DEFINE="${QCONFIG_DEFINE:-}" 521: ${QCONFIG_DEFINE:=}
410 522
411# @FUNCTION: install_qconfigs 523# @FUNCTION: install_qconfigs
412# @DESCRIPTION: Install gentoo-specific mkspecs configurations 524# @DESCRIPTION: Install gentoo-specific mkspecs configurations
413install_qconfigs() { 525install_qconfigs() {
414 local x 526 local x
415 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} ]]; then 527 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} ]]; then
416 for x in QCONFIG_ADD QCONFIG_REMOVE; do 528 for x in QCONFIG_ADD QCONFIG_REMOVE; do
417 [[ -n ${!x} ]] && echo ${x}=${!x} >> "${T}"/${PN}-qconfig.pri 529 [[ -n ${!x} ]] && echo ${x}=${!x} >> "${T}"/${PN}-qconfig.pri
418 done 530 done
419 insinto ${QTDATADIR}/mkspecs/gentoo 531 insinto ${QTDATADIR#${EPREFIX}}/mkspecs/gentoo
420 doins "${T}"/${PN}-qconfig.pri || die "installing ${PN}-qconfig.pri failed" 532 doins "${T}"/${PN}-qconfig.pri || die "installing ${PN}-qconfig.pri failed"
421 fi 533 fi
422 534
423 if [[ -n ${QCONFIG_DEFINE} ]]; then 535 if [[ -n ${QCONFIG_DEFINE} ]]; then
424 for x in ${QCONFIG_DEFINE}; do 536 for x in ${QCONFIG_DEFINE}; do
425 echo "#define ${x}" >> "${T}"/gentoo-${PN}-qconfig.h 537 echo "#define ${x}" >> "${T}"/gentoo-${PN}-qconfig.h
426 done 538 done
427 insinto ${QTHEADERDIR}/Gentoo 539 insinto ${QTHEADERDIR#${EPREFIX}}/Gentoo
428 doins "${T}"/gentoo-${PN}-qconfig.h || die "installing ${PN}-qconfig.h failed" 540 doins "${T}"/gentoo-${PN}-qconfig.h || die "installing ${PN}-qconfig.h failed"
429 fi 541 fi
430} 542}
431 543
432# @FUNCTION: generate_qconfigs 544# @FUNCTION: generate_qconfigs
434generate_qconfigs() { 546generate_qconfigs() {
435 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} || -n ${QCONFIG_DEFINE} || ${CATEGORY}/${PN} == x11-libs/qt-core ]]; then 547 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 548 local x qconfig_add qconfig_remove qconfig_new
437 for x in "${ROOT}${QTDATADIR}"/mkspecs/gentoo/*-qconfig.pri; do 549 for x in "${ROOT}${QTDATADIR}"/mkspecs/gentoo/*-qconfig.pri; do
438 [[ -f ${x} ]] || continue 550 [[ -f ${x} ]] || continue
439 qconfig_add="${qconfig_add} $(sed -n 's/^QCONFIG_ADD=//p' "${x}")" 551 qconfig_add+=" $(sed -n 's/^QCONFIG_ADD=//p' "${x}")"
440 qconfig_remove="${qconfig_remove} $(sed -n 's/^QCONFIG_REMOVE=//p' "${x}")" 552 qconfig_remove+=" $(sed -n 's/^QCONFIG_REMOVE=//p' "${x}")"
441 done 553 done
442 554
443 # these error checks do not use die because dying in pkg_post{inst,rm} 555 # these error checks do not use die because dying in pkg_post{inst,rm}
444 # just makes things worse. 556 # just makes things worse.
445 if [[ -e "${ROOT}${QTDATADIR}"/mkspecs/gentoo/qconfig.pri ]]; then 557 if [[ -e "${ROOT}${QTDATADIR}"/mkspecs/gentoo/qconfig.pri ]]; then
452 564
453 # generate list of QT_CONFIG entries from the existing list 565 # generate list of QT_CONFIG entries from the existing list
454 # including qconfig_add and excluding qconfig_remove 566 # including qconfig_add and excluding qconfig_remove
455 for x in $(sed -n 's/^QT_CONFIG +=//p' \ 567 for x in $(sed -n 's/^QT_CONFIG +=//p' \
456 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri) ${qconfig_add}; do 568 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri) ${qconfig_add}; do
457 hasq ${x} ${qconfig_remove} || qconfig_new="${qconfig_new} ${x}" 569 hasq ${x} ${qconfig_remove} || qconfig_new+=" ${x}"
458 done 570 done
459 571
460 # replace the existing QT_CONFIG list with qconfig_new 572 # replace the existing QT_CONFIG list with qconfig_new
461 if ! sed -i -e "s/QT_CONFIG +=.*/QT_CONFIG += ${qconfig_new}/" \ 573 if ! sed -i -e "s/QT_CONFIG +=.*/QT_CONFIG += ${qconfig_new}/" \
462 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri; then 574 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri; then
558 # pkgconfig files refer to WORKDIR/bin as the moc and uic locations. Fix: 670 # pkgconfig files refer to WORKDIR/bin as the moc and uic locations. Fix:
559 for libfile in "${D}"/${QTLIBDIR}/pkgconfig/*.pc; do 671 for libfile in "${D}"/${QTLIBDIR}/pkgconfig/*.pc; do
560 if [[ -e ${libfile} ]]; then 672 if [[ -e ${libfile} ]]; then
561 sed -i -e "s:${S}/bin:${QTBINDIR}:g" ${libfile} || die "Sed failed" 673 sed -i -e "s:${S}/bin:${QTBINDIR}:g" ${libfile} || die "Sed failed"
562 674
563 # Move .pc files into the pkgconfig directory 675 # Move .pc files into the pkgconfig directory
564 dodir ${QTPCDIR} 676 dodir ${QTPCDIR#${EPREFIX}}
565 mv ${libfile} "${D}"/${QTPCDIR}/ \ 677 mv ${libfile} "${D}"/${QTPCDIR}/ \
566 || die "Moving ${libfile} to ${D}/${QTPCDIR}/ failed." 678 || die "Moving ${libfile} to ${D}/${QTPCDIR}/ failed."
567 fi 679 fi
568 done 680 done
569 681
577# This will echo "${enableval}-${feature}" if <flag> is enabled, or 689# This will echo "${enableval}-${feature}" if <flag> is enabled, or
578# "-no-${feature} if the flag is disabled. If [feature] is not specified <flag> 690# "-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 691# will be used for that. If [enableval] is not specified, it omits the
580# assignment-part 692# assignment-part
581qt_use() { 693qt_use() {
582 local flag="${1}" 694 local flag=$1
583 local feature="${1}" 695 local feature=$1
584 local enableval= 696 local enableval=
585 697
586 [[ -n ${2} ]] && feature=${2} 698 [[ -n $2 ]] && feature=$2
587 [[ -n ${3} ]] && enableval="-${3}" 699 [[ -n $3 ]] && enableval=-$3
588 700
589 if use ${flag}; then 701 if use ${flag}; then
590 echo "${enableval}-${feature}" 702 echo "${enableval}-${feature}"
591 else 703 else
592 echo "-no-${feature}" 704 echo "-no-${feature}"
593 fi 705 fi
594} 706}
595 707
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 708# @FUNCTION: qt_mkspecs_dir
667# @RETURN: the specs-directory w/o path 709# @RETURN: the specs-directory w/o path
668# @DESCRIPTION: 710# @DESCRIPTION:
669# Allows us to define which mkspecs dir we want to use. 711# Allows us to define which mkspecs dir we want to use.
670qt_mkspecs_dir() { 712qt_mkspecs_dir() {
671 # Allows us to define which mkspecs dir we want to use. 713 # Allows us to define which mkspecs dir we want to use.
672 local spec 714 local spec
673 715
674 case ${CHOST} in 716 case ${CHOST} in
675 *-freebsd*|*-dragonfly*) 717 *-freebsd*|*-dragonfly*)
676 spec="freebsd" ;; 718 spec=freebsd ;;
677 *-openbsd*) 719 *-openbsd*)
678 spec="openbsd" ;; 720 spec=openbsd ;;
679 *-netbsd*) 721 *-netbsd*)
680 spec="netbsd" ;; 722 spec=netbsd ;;
681 *-darwin*) 723 *-darwin*)
724 if use aqua; then
725 # mac with carbon/cocoa
726 spec=macx
727 else
728 # darwin/mac with x11
682 spec="darwin" ;; 729 spec=darwin
730 fi
731 ;;
732 *-solaris*)
733 spec=solaris ;;
683 *-linux-*|*-linux) 734 *-linux-*|*-linux)
684 spec="linux" ;; 735 spec=linux ;;
685 *) 736 *)
686 die "Unknown CHOST, no platform choosen." 737 die "Unknown CHOST, no platform choosen."
687 esac 738 esac
688 739
689 CXX=$(tc-getCXX) 740 CXX=$(tc-getCXX)
690 if [[ ${CXX/g++/} != ${CXX} ]]; then 741 if [[ ${CXX} == *g++* ]]; then
691 spec="${spec}-g++" 742 spec+=-g++
692 elif [[ ${CXX/icpc/} != ${CXX} ]]; then 743 elif [[ ${CXX} == *icpc* ]]; then
693 spec="${spec}-icc" 744 spec+=-icc
694 else 745 else
695 die "Unknown compiler ${CXX}." 746 die "Unknown compiler ${CXX}."
696 fi 747 fi
697 if [[ -n "${LIBDIR/lib}" ]]; then 748 if [[ -n ${LIBDIR/lib} ]]; then
698 spec="${spec}-${LIBDIR/lib}" 749 spec+=-${LIBDIR/lib}
750 fi
751
752 # Add -64 for 64bit profiles
753 if use x64-freebsd ||
754 use amd64-linux ||
755 use x64-macos ||
756 use x64-solaris ||
757 use sparc64-solaris
758 then
759 spec+=-64
699 fi 760 fi
700 761
701 echo "${spec}" 762 echo "${spec}"
702} 763}
703 764
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 ;; 765EXPORT_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.57

  ViewVC Help
Powered by ViewVC 1.1.20