/[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.56 Revision 1.57
1# Copyright 1999-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.56 2009/12/22 17:04:07 abcd 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="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
46 !>x11-libs/qt-xmlpatterns-${PV}-r9999 46 !>x11-libs/qt-xmlpatterns-${PV}-r9999
47" 47"
48 48
49MY_PV=${PV/_/-} 49MY_PV=${PV/_/-}
50 50
51HOMEPAGE="http://qt.nokia.com/"
51if version_is_at_least 4.5.99999999 ${PV} ; then 52if version_is_at_least 4.5.99999999 ${PV} ; then
52 MY_P=qt-everywhere-opensource-src-${MY_PV} 53 SRC_URI="http://get.qt.nokia.com/qt/source/qt-everywhere-opensource-src-${MY_PV}.tar.gz"
53else 54else
54 MY_P=qt-x11-opensource-src-${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 )"
55fi 57fi
56 58
57S=${WORKDIR}/${MY_P}
58
59HOMEPAGE="http://qt.nokia.com/"
60SRC_URI="http://get.qt.nokia.com/qt/source/${MY_P}.tar.gz"
61
62LICENSE="|| ( LGPL-2.1 GPL-3 )" 59LICENSE="|| ( LGPL-2.1 GPL-3 )"
63 60
64# @FUNCTION: qt4-build_pkg_setup 61# @FUNCTION: qt4-build_pkg_setup
65# @DESCRIPTION: 62# @DESCRIPTION:
66# Sets up PATH and LD_LIBRARY_PATH 63# Sets up S, MY_P, PATH, and LD_LIBRARY_PATH
67qt4-build_pkg_setup() { 64qt4-build_pkg_setup() {
65 [[ ${EAPI} == 2 ]] && use !prefix && EPREFIX=
66
67 local MY_GE
68 if version_is_at_least 4.5.99999999 ${PV} ; then
69 MY_P=qt-everywhere-opensource-src-${MY_PV}
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
68 PATH="${S}/bin${PATH:+:}${PATH}" 78 PATH="${S}/bin${PATH:+:}${PATH}"
79 if [[ ${CHOST} != *-darwin* ]]; then
69 LD_LIBRARY_PATH="${S}/lib${LD_LIBRARY_PATH:+:}${LD_LIBRARY_PATH}" 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"
91 fi
92 fi
70 93
71 # Make sure ebuilds use the required EAPI 94 # Make sure ebuilds use the required EAPI
72 if [[ ${EAPI} != 2 ]]; then 95 if [[ ${EAPI} != [23] ]]; then
73 eerror "The qt4-build eclass requires EAPI=2, but this ebuild does not" 96 eerror "The qt4-build eclass requires EAPI=2 or EAPI=3, but this ebuild is using"
74 eerror "have EAPI=2 set. The ebuild author or editor failed. This ebuild needs" 97 eerror "EAPI=${EAPI:-0}. The ebuild author or editor failed. This ebuild needs to be"
75 eerror "to be fixed. Using qt4-build eclass without EAPI=2 will fail." 98 eerror "fixed. Using qt4-build eclass without EAPI=2 or EAPI=3 will fail."
76 die "qt4-build eclass requires EAPI=2" 99 die "qt4-build eclass requires EAPI=2 or EAPI=3"
77 fi 100 fi
78 101
79 if ! version_is_at_least 4.1 $(gcc-version); then 102 if ! version_is_at_least 4.1 $(gcc-version); then
80 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!"
81 echo 104 echo
141# 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.
142qt4-build_src_prepare() { 165qt4-build_src_prepare() {
143 setqtenv 166 setqtenv
144 cd "${S}" 167 cd "${S}"
145 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
146 if [[ ${PN} != qt-core ]]; then 178 if [[ ${PN} != qt-core ]]; then
147 skip_qmake_build_patch 179 skip_qmake_build_patch
148 skip_project_generation_patch 180 skip_project_generation_patch
149 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
150 fi 187 fi
151 188
152 # Bug 282984 && Bug 295530 189 # Bug 282984 && Bug 295530
153 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:" \
154 -i configure || die "sed qmake compilers failed" 191 -i configure || die "sed qmake compilers failed"
181 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \ 218 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \
182 -e "s:QMAKE_LFLAGS_RELEASE.*=.*:QMAKE_LFLAGS_RELEASE=${LDFLAGS}:" \ 219 -e "s:QMAKE_LFLAGS_RELEASE.*=.*:QMAKE_LFLAGS_RELEASE=${LDFLAGS}:" \
183 -e "s:X11R6/::" \ 220 -e "s:X11R6/::" \
184 -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"
185 222
223 if [[ ${CHOST} != *-darwin* ]]; then
186 sed -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \ 224 sed -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \
187 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \ 225 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \
188 -e "s:QMAKE_LFLAGS_RELEASE.*=.*:QMAKE_LFLAGS_RELEASE=${LDFLAGS}:" \ 226 -e "s:QMAKE_LFLAGS_RELEASE.*=.*:QMAKE_LFLAGS_RELEASE=${LDFLAGS}:" \
189 -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
190 278
191 base_src_prepare 279 base_src_prepare
192} 280}
193 281
194# @FUNCTION: qt4-build_src_configure 282# @FUNCTION: qt4-build_src_configure
196# Default configure phase 284# Default configure phase
197qt4-build_src_configure() { 285qt4-build_src_configure() {
198 setqtenv 286 setqtenv
199 myconf="$(standard_configure_options) ${myconf}" 287 myconf="$(standard_configure_options) ${myconf}"
200 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
201 echo ./configure ${myconf} 325 echo ./configure ${myconf}
202 ./configure ${myconf} || die "./configure failed" 326 ./configure ${myconf} || die "./configure failed"
203 myconf="" 327 myconf=""
204} 328}
205 329
209 setqtenv 333 setqtenv
210 334
211 build_directories ${QT4_TARGET_DIRECTORIES} 335 build_directories ${QT4_TARGET_DIRECTORIES}
212} 336}
213 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
362}
363
214# @FUNCTION: qt4-build_src_install 364# @FUNCTION: qt4-build_src_install
215# @DESCRIPTION: 365# @DESCRIPTION:
216# Perform the actual installation including some library fixes. 366# Perform the actual installation including some library fixes.
217qt4-build_src_install() { 367qt4-build_src_install() {
368 [[ ${EAPI} == 2 ]] && use !prefix && ED=${D}
218 setqtenv 369 setqtenv
219 install_directories ${QT4_TARGET_DIRECTORIES} 370 install_directories ${QT4_TARGET_DIRECTORIES}
220 install_qconfigs 371 install_qconfigs
221 fix_library_files 372 fix_library_files
373 fix_includes
222} 374}
223 375
224# @FUNCTION: setqtenv 376# @FUNCTION: setqtenv
225setqtenv() { 377setqtenv() {
226 # Set up installation directories 378 # Set up installation directories
227 QTBASEDIR=/usr/$(get_libdir)/qt4 379 QTBASEDIR=${EPREFIX}/usr/$(get_libdir)/qt4
228 QTPREFIXDIR=/usr 380 QTPREFIXDIR=${EPREFIX}/usr
229 QTBINDIR=/usr/bin 381 QTBINDIR=${EPREFIX}/usr/bin
230 QTLIBDIR=/usr/$(get_libdir)/qt4 382 QTLIBDIR=${EPREFIX}/usr/$(get_libdir)/qt4
231 QMAKE_LIBDIR_QT=${QTLIBDIR} 383 QMAKE_LIBDIR_QT=${QTLIBDIR}
232 QTPCDIR=/usr/$(get_libdir)/pkgconfig 384 QTPCDIR=${EPREFIX}/usr/$(get_libdir)/pkgconfig
233 QTDATADIR=/usr/share/qt4 385 QTDATADIR=${EPREFIX}/usr/share/qt4
234 QTDOCDIR=/usr/share/doc/qt-${PV} 386 QTDOCDIR=${EPREFIX}/usr/share/doc/qt-${PV}
235 QTHEADERDIR=/usr/include/qt4 387 QTHEADERDIR=${EPREFIX}/usr/include/qt4
236 QTPLUGINDIR=${QTLIBDIR}/plugins 388 QTPLUGINDIR=${QTLIBDIR}/plugins
237 QTSYSCONFDIR=/etc/qt4 389 QTSYSCONFDIR=${EPREFIX}/etc/qt4
238 QTTRANSDIR=${QTDATADIR}/translations 390 QTTRANSDIR=${QTDATADIR}/translations
239 QTEXAMPLESDIR=${QTDATADIR}/examples 391 QTEXAMPLESDIR=${QTDATADIR}/examples
240 QTDEMOSDIR=${QTDATADIR}/demos 392 QTDEMOSDIR=${QTDATADIR}/demos
241 QT_INSTALL_PREFIX=/usr/$(get_libdir)/qt4 393 QT_INSTALL_PREFIX=${EPREFIX}/usr/$(get_libdir)/qt4
242 PLATFORM=$(qt_mkspecs_dir) 394 PLATFORM=$(qt_mkspecs_dir)
243 395
244 unset QMAKESPEC 396 unset QMAKESPEC
245} 397}
246 398
249# Sets up some standard configure options, like libdir (if necessary), whether 401# Sets up some standard configure options, like libdir (if necessary), whether
250# debug info is wanted or not. 402# debug info is wanted or not.
251standard_configure_options() { 403standard_configure_options() {
252 local myconf= 404 local myconf=
253 405
406 # Doesn't need ${EPREFIX} because get_libdir() is *always* lib on prefix
254 [[ $(get_libdir) != lib ]] && myconf+=" -L/usr/$(get_libdir)" 407 [[ $(get_libdir) != lib ]] && myconf+=" -L/usr/$(get_libdir)"
255 408
256 # Disable visibility explicitly if gcc version isn't 4 409 # Disable visibility explicitly if gcc version isn't 4
257 if [[ $(gcc-major-version) -lt 4 ]]; then 410 if [[ $(gcc-major-version) -lt 4 ]]; then
258 myconf+=" -no-reduce-exports" 411 myconf+=" -no-reduce-exports"
266 else 419 else
267 myconf+=" -release" 420 myconf+=" -release"
268 fi 421 fi
269 myconf+=" -no-separate-debug-info" 422 myconf+=" -no-separate-debug-info"
270 423
424 use aqua && myconf+=" -no-framework"
425
271 # 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
272 # $(tc-arch). Therefore we convert it to supported values. 427 # $(tc-arch). Therefore we convert it to supported values.
273 case "$(tc-arch)" in 428 case "$(tc-arch)" in
274 amd64) myconf+=" -arch x86_64" ;; 429 amd64|x64-*) myconf+=" -arch x86_64" ;;
430 ppc-macos) myconf+=" -arch ppc" ;;
275 ppc|ppc64) myconf+=" -arch powerpc" ;; 431 ppc|ppc64|ppc-*) myconf+=" -arch powerpc" ;;
432 sparc|sparc-*) myconf+=" -arch sparc" ;;
433 x86-macos) myconf+=" -arch x86" ;;
276 x86|x86-*) myconf+=" -arch i386" ;; 434 x86|x86-*) myconf+=" -arch i386" ;;
277 alpha|arm|ia64|mips|s390|sparc) myconf+=" -arch $(tc-arch)" ;; 435 alpha|arm|ia64|mips|s390|sparc) myconf+=" -arch $(tc-arch)" ;;
278 hppa|sh) myconf+=" -arch generic" ;; 436 hppa|sh) myconf+=" -arch generic" ;;
279 *) 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." ;;
280 esac 438 esac
282 # 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
283 local exceptions= 441 local exceptions=
284 case "${PV}" in 442 case "${PV}" in
285 4.6.*) 443 4.6.*)
286 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 *)
287 exceptions="-no-exceptions" 451 exceptions="-no-exceptions"
452 ;;
453 esac
288 fi 454 fi
289 ;; 455 ;;
290 *) 456 *)
291 [[ ${PN} == "qt-xmlpatterns" ]] || exceptions="-no-exceptions" 457 [[ ${PN} == "qt-xmlpatterns" ]] || exceptions="-no-exceptions"
292 ;; 458 ;;
293 esac 459 esac
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"
294 467
295 myconf+=" -platform $(qt_mkspecs_dir) -stl -verbose -largefile -confirm-license 468 myconf+=" -platform $(qt_mkspecs_dir) -stl -verbose -largefile -confirm-license
296 -prefix ${QTPREFIXDIR} -bindir ${QTBINDIR} -libdir ${QTLIBDIR} 469 -prefix ${QTPREFIXDIR} -bindir ${QTBINDIR} -libdir ${QTLIBDIR}
297 -datadir ${QTDATADIR} -docdir ${QTDOCDIR} -headerdir ${QTHEADERDIR} 470 -datadir ${QTDATADIR} -docdir ${QTDOCDIR} -headerdir ${QTHEADERDIR}
298 -plugindir ${QTPLUGINDIR} -sysconfdir ${QTSYSCONFDIR} 471 -plugindir ${QTPLUGINDIR} -sysconfdir ${QTSYSCONFDIR}
299 -translationdir ${QTTRANSDIR} -examplesdir ${QTEXAMPLESDIR} 472 -translationdir ${QTTRANSDIR} -examplesdir ${QTEXAMPLESDIR}
300 -demosdir ${QTDEMOSDIR} -silent -fast -opensource 473 -demosdir ${QTDEMOSDIR} -silent -fast -opensource
301 ${exceptions} 474 ${exceptions}
302 -reduce-relocations -nomake examples -nomake demos" 475 -nomake examples -nomake demos"
303 476
304 echo "${myconf}" 477 echo "${myconf}"
305} 478}
306 479
307# @FUNCTION: build_directories 480# @FUNCTION: build_directories
308# @USAGE: < directories > 481# @USAGE: < directories >
309# @DESCRIPTION: 482# @DESCRIPTION:
310# Compiles the code in $QT4_TARGET_DIRECTORIES 483# Compiles the code in $QT4_TARGET_DIRECTORIES
311build_directories() { 484build_directories() {
312 for x in "$@"; do 485 for x in "$@"; do
313 cd "${S}"/${x} 486 pushd "${S}"/${x} >/dev/null
314 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
315 "${S}"/bin/qmake "LIBS+=-L${QTLIBDIR}" "CONFIG+=nostrip" || die "qmake failed" 488 "${S}"/bin/qmake "LIBS+=-L${QTLIBDIR}" "CONFIG+=nostrip" || die "qmake failed"
316 emake CC="@echo compiling \$< && $(tc-getCC)" \ 489 emake CC="@echo compiling \$< && $(tc-getCC)" \
317 CXX="@echo compiling \$< && $(tc-getCXX)" \ 490 CXX="@echo compiling \$< && $(tc-getCXX)" \
318 LINK="@echo linking \$@ && $(tc-getCXX)" || die "emake failed" 491 LINK="@echo linking \$@ && $(tc-getCXX)" || die "emake failed"
492 popd >/dev/null
319 done 493 done
320} 494}
321 495
322# @FUNCTION: install_directories 496# @FUNCTION: install_directories
323# @USAGE: < directories > 497# @USAGE: < directories >
352 local x 526 local x
353 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} ]]; then 527 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} ]]; then
354 for x in QCONFIG_ADD QCONFIG_REMOVE; do 528 for x in QCONFIG_ADD QCONFIG_REMOVE; do
355 [[ -n ${!x} ]] && echo ${x}=${!x} >> "${T}"/${PN}-qconfig.pri 529 [[ -n ${!x} ]] && echo ${x}=${!x} >> "${T}"/${PN}-qconfig.pri
356 done 530 done
357 insinto ${QTDATADIR}/mkspecs/gentoo 531 insinto ${QTDATADIR#${EPREFIX}}/mkspecs/gentoo
358 doins "${T}"/${PN}-qconfig.pri || die "installing ${PN}-qconfig.pri failed" 532 doins "${T}"/${PN}-qconfig.pri || die "installing ${PN}-qconfig.pri failed"
359 fi 533 fi
360 534
361 if [[ -n ${QCONFIG_DEFINE} ]]; then 535 if [[ -n ${QCONFIG_DEFINE} ]]; then
362 for x in ${QCONFIG_DEFINE}; do 536 for x in ${QCONFIG_DEFINE}; do
363 echo "#define ${x}" >> "${T}"/gentoo-${PN}-qconfig.h 537 echo "#define ${x}" >> "${T}"/gentoo-${PN}-qconfig.h
364 done 538 done
365 insinto ${QTHEADERDIR}/Gentoo 539 insinto ${QTHEADERDIR#${EPREFIX}}/Gentoo
366 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"
367 fi 541 fi
368} 542}
369 543
370# @FUNCTION: generate_qconfigs 544# @FUNCTION: generate_qconfigs
497 for libfile in "${D}"/${QTLIBDIR}/pkgconfig/*.pc; do 671 for libfile in "${D}"/${QTLIBDIR}/pkgconfig/*.pc; do
498 if [[ -e ${libfile} ]]; then 672 if [[ -e ${libfile} ]]; then
499 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"
500 674
501 # Move .pc files into the pkgconfig directory 675 # Move .pc files into the pkgconfig directory
502 dodir ${QTPCDIR} 676 dodir ${QTPCDIR#${EPREFIX}}
503 mv ${libfile} "${D}"/${QTPCDIR}/ \ 677 mv ${libfile} "${D}"/${QTPCDIR}/ \
504 || die "Moving ${libfile} to ${D}/${QTPCDIR}/ failed." 678 || die "Moving ${libfile} to ${D}/${QTPCDIR}/ failed."
505 fi 679 fi
506 done 680 done
507 681
545 *-openbsd*) 719 *-openbsd*)
546 spec=openbsd ;; 720 spec=openbsd ;;
547 *-netbsd*) 721 *-netbsd*)
548 spec=netbsd ;; 722 spec=netbsd ;;
549 *-darwin*) 723 *-darwin*)
724 if use aqua; then
725 # mac with carbon/cocoa
726 spec=macx
727 else
728 # darwin/mac with x11
550 spec=darwin ;; 729 spec=darwin
730 fi
731 ;;
732 *-solaris*)
733 spec=solaris ;;
551 *-linux-*|*-linux) 734 *-linux-*|*-linux)
552 spec=linux ;; 735 spec=linux ;;
553 *) 736 *)
554 die "Unknown CHOST, no platform choosen." 737 die "Unknown CHOST, no platform choosen."
555 esac 738 esac
564 fi 747 fi
565 if [[ -n ${LIBDIR/lib} ]]; then 748 if [[ -n ${LIBDIR/lib} ]]; then
566 spec+=-${LIBDIR/lib} 749 spec+=-${LIBDIR/lib}
567 fi 750 fi
568 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
760 fi
761
569 echo "${spec}" 762 echo "${spec}"
570} 763}
571 764
572EXPORT_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

Legend:
Removed from v.1.56  
changed lines
  Added in v.1.57

  ViewVC Help
Powered by ViewVC 1.1.20