/[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.55 Revision 1.76
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.55 2009/12/22 16:04:13 abcd Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/qt4-build.eclass,v 1.76 2010/07/03 15:49:39 ayoy 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
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 )"
17IUSE="debug pch" 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}
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"
48 63
49MY_PV=${PV/_/-}
50
51if version_is_at_least 4.5.99999999 ${PV} ; then
52 MY_P=qt-everywhere-opensource-src-${MY_PV}
53else
54 MY_P=qt-x11-opensource-src-${MY_PV}
55fi
56
57S=${WORKDIR}/${MY_P} 64S=${WORKDIR}/${MY_P}
58 65
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 )"
63
64# @FUNCTION: qt4-build_pkg_setup 66# @FUNCTION: qt4-build_pkg_setup
65# @DESCRIPTION: 67# @DESCRIPTION:
66# Sets up PATH and LD_LIBRARY_PATH 68# Sets up S, MY_P, PATH, and LD_LIBRARY_PATH
67qt4-build_pkg_setup() { 69qt4-build_pkg_setup() {
70 [[ ${EAPI} == 2 ]] && use !prefix && EPREFIX=
71
72 # Protect users by not allowing downgrades between releases
73 # Downgrading revisions within the same release should be allowed
74 if has_version '>'${CATEGORY}/${P}-r9999 ; then
75 if [[ -z $I_KNOW_WHAT_I_AM_DOING ]] ; then
76 eerror "Sanity check to keep you from breaking your system:"
77 eerror " Downgrading Qt is completely unsupported and will break your system!"
78 die "aborting to save your system"
79 else
80 ewarn "Downgrading Qt is completely unsupported and will break your system!"
81 fi
82 fi
83
84 if [[ "${PN}" == "qt-webkit" ]]; then
85 eshopts_push -s extglob
86 if is-flagq '-g?(gdb)?([0-9])'; then
87 echo
88 ewarn "You have enabled debug info (probably have -g or -ggdb in your \$C{,XX}FLAGS)."
89 ewarn "You may experience really long compilation times and/or increased memory usage."
90 ewarn "If compilation fails, please try removing -g{,gdb} before reporting a bug."
91 ewarn "For more info check out bug #307861"
92 echo
93 fi
94 eshopts_pop
95 fi
96
68 PATH="${S}/bin${PATH:+:}${PATH}" 97 PATH="${S}/bin${PATH:+:}${PATH}"
98 if [[ ${CHOST} != *-darwin* ]]; then
69 LD_LIBRARY_PATH="${S}/lib${LD_LIBRARY_PATH:+:}${LD_LIBRARY_PATH}" 99 LD_LIBRARY_PATH="${S}/lib${LD_LIBRARY_PATH:+:}${LD_LIBRARY_PATH}"
100 else
101 DYLD_LIBRARY_PATH="${S}/lib${DYLD_LIBRARY_PATH:+:}${DYLD_LIBRARY_PATH}"
102 # On MacOS we *need* at least src/gui/kernel/qapplication_mac.mm for
103 # platform detection. Note: needs to come before any directories to
104 # avoid extract failure.
105 [[ ${CHOST} == *-apple-darwin* ]] && \
106 QT4_EXTRACT_DIRECTORIES="src/gui/kernel/qapplication_mac.mm
107 ${QT4_EXTRACT_DIRECTORIES}"
108 fi
70 109
71 # Make sure ebuilds use the required EAPI 110 # Make sure ebuilds use the required EAPI
72 if [[ ${EAPI} != 2 ]]; then 111 if [[ ${EAPI} != [23] ]]; then
73 eerror "The qt4-build eclass requires EAPI=2, but this ebuild does not" 112 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" 113 eerror "EAPI=${EAPI:-0}. The ebuild author or editor failed. This ebuild needs to be"
75 eerror "to be fixed. Using qt4-build-edge eclass without EAPI=2 will fail." 114 eerror "fixed. Using qt4-build eclass without EAPI=2 or EAPI=3 will fail."
76 die "qt4-build-edge eclass requires EAPI=2" 115 die "qt4-build eclass requires EAPI=2 or EAPI=3"
77 fi 116 fi
78 117
79 if ! version_is_at_least 4.1 $(gcc-version); then 118 if ! version_is_at_least 4.1 $(gcc-version); then
80 ewarn "Using a GCC version lower than 4.1 is not supported!" 119 ewarn "Using a GCC version lower than 4.1 is not supported!"
81 echo
82 ebeep 3
83 fi 120 fi
84
85 if [[ ${P} == qt-core-4.6.0_rc1 ]]; then
86 ewarn
87 ewarn "Binary compatibility broke between 4.6.0_beta1 and 4.6.0_rc1."
88 ewarn "If you are upgrading from 4.6.0_beta1, you'll have to"
89 ewarn "re-emerge everything that depends on Qt."
90 ewarn "Use the following command:"
91 ewarn
92 ewarn " emerge -av1 \$(for i in \$(qlist -IC x11-libs/qt-);"
93 ewarn " do equery -q d \$i | grep -v 'x11-libs/qt-' |"
94 ewarn " sed \"s/^/=/\"; done)"
95 ewarn
96 ewarn "YOU'VE BEEN WARNED"
97 ewarn
98 ebeep 3
99 fi
100
101} 121}
102 122
103# @ECLASS-VARIABLE: QT4_TARGET_DIRECTORIES 123# @ECLASS-VARIABLE: QT4_TARGET_DIRECTORIES
104# @DESCRIPTION: 124# @DESCRIPTION:
105# Arguments for build_target_directories. Takes the directories, in which the 125# Arguments for build_target_directories. Takes the directories, in which the
120 src/{qbase,qt_targets,qt_install}.pri bin config.tests mkspecs qmake \ 140 src/{qbase,qt_targets,qt_install}.pri bin config.tests mkspecs qmake \
121 ${QT4_EXTRACT_DIRECTORIES}; do 141 ${QT4_EXTRACT_DIRECTORIES}; do
122 targets+=" ${MY_P}/${target}" 142 targets+=" ${MY_P}/${target}"
123 done 143 done
124 144
125 echo tar xzpf "${DISTDIR}"/${MY_P}.tar.gz ${targets} 145 echo tar xzf "${DISTDIR}"/${MY_P}.tar.gz ${targets}
126 tar xzpf "${DISTDIR}"/${MY_P}.tar.gz ${targets} 146 tar xzf "${DISTDIR}"/${MY_P}.tar.gz ${targets} || die
127} 147}
128 148
129# @ECLASS-VARIABLE: PATCHES 149# @ECLASS-VARIABLE: PATCHES
130# @DESCRIPTION: 150# @DESCRIPTION:
131# In case you have patches to apply, specify them in PATCHES variable. Make sure 151# In case you have patches to apply, specify them in PATCHES variable. Make sure
141# source files in order to respect CFLAGS/CXXFLAGS/LDFLAGS specified on /etc/make.conf. 161# source files in order to respect CFLAGS/CXXFLAGS/LDFLAGS specified on /etc/make.conf.
142qt4-build_src_prepare() { 162qt4-build_src_prepare() {
143 setqtenv 163 setqtenv
144 cd "${S}" 164 cd "${S}"
145 165
166 # fix qt 4.7 regression that skips -fvisibility=hidden
167 if version_is_at_least "4.7.0_beta1"; then
168 sed -e "s/^gcc|g++)/*gcc|*g++)/" \
169 -i config.tests/unix/fvisibility.test ||
170 die "visibility fixing sed failed"
171 fi
172
173 if use aqua; then
174 # provide a proper macx-g++-64
175 use x64-macos && ln -s macx-g++ mkspecs/$(qt_mkspecs_dir)
176
177 sed -e '/^CONFIG/s:app_bundle::' \
178 -e '/^CONFIG/s:plugin_no_soname:plugin_with_soname absolute_library_soname:' \
179 -i mkspecs/$(qt_mkspecs_dir)/qmake.conf || die "sed failed"
180 fi
181
146 if [[ ${PN} != qt-core ]]; then 182 if [[ ${PN} != qt-core ]]; then
147 skip_qmake_build_patch 183 skip_qmake_build_patch
148 skip_project_generation_patch 184 skip_project_generation_patch
149 symlink_binaries_to_buildtree 185 symlink_binaries_to_buildtree
150 fi 186 fi
151 187
152 # Bug 282984 && Bug 295530 188 if [[ ${CHOST} == *86*-apple-darwin* ]] ; then
153 sed -e "s:\(^SYSTEM_VARIABLES\):CC=$(tc-getCC)\nCXX=$(tc-getCXX)\n\1:" \ 189 # qmake bus errors with -O2 but -O3 works
154 -i configure || die "sed qmake compilers failed" 190 replace-flags -O2 -O3
155 sed -e "s:\(\$MAKE\):\1 CC=$(tc-getCC) CXX=$(tc-getCXX) LD=$(tc-getCXX):" \ 191 fi
156 -i config.tests/unix/compile.test || die "sed test compilers failed"
157 192
158 # Bug 178652 193 # Bug 178652
159 if [[ $(gcc-major-version) == 3 ]] && use amd64; then 194 if [[ $(gcc-major-version) == 3 ]] && use amd64; then
160 ewarn "Appending -fno-gcse to CFLAGS/CXXFLAGS" 195 ewarn "Appending -fno-gcse to CFLAGS/CXXFLAGS"
161 append-flags -fno-gcse 196 append-flags -fno-gcse
174 if use ppc64; then 209 if use ppc64; then
175 ewarn "Appending -mminimal-toc to CFLAGS/CXXFLAGS" 210 ewarn "Appending -mminimal-toc to CFLAGS/CXXFLAGS"
176 append-flags -mminimal-toc 211 append-flags -mminimal-toc
177 fi 212 fi
178 213
214 # Bug 282984 && Bug 295530
215 sed -e "s:\(^SYSTEM_VARIABLES\):CC=$(tc-getCC)\nCXX=$(tc-getCXX)\nCFLAGS=\"${CFLAGS}\"\nCXXFLAGS=\"${CXXFLAGS}\"\nLDFLAGS=\"${LDFLAGS}\"\n\1:" \
216 -i configure || die "sed qmake compilers failed"
217 # bug 321335
218 if version_is_at_least 4.6; then
219 find ./config.tests/unix -name "*.test" -type f -exec grep -lZ \$MAKE '{}' \; | \
220 xargs -0 \
221 sed -e "s:\(\$MAKE\):\1 CC=$(tc-getCC) CXX=$(tc-getCXX) LD=$(tc-getCXX) LINK=$(tc-getCXX):g" \
222 -i || die "sed test compilers failed"
223 fi
224
179 # Bug 172219 225 # Bug 172219
180 sed -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \
181 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \
182 -e "s:QMAKE_LFLAGS_RELEASE.*=.*:QMAKE_LFLAGS_RELEASE=${LDFLAGS}:" \
183 -e "s:X11R6/::" \ 226 sed -e "s:X11R6/::" \
184 -i "${S}"/mkspecs/$(qt_mkspecs_dir)/qmake.conf || die "sed ${S}/mkspecs/$(qt_mkspecs_dir)/qmake.conf failed" 227 -i "${S}"/mkspecs/$(qt_mkspecs_dir)/qmake.conf || die "sed ${S}/mkspecs/$(qt_mkspecs_dir)/qmake.conf failed"
185 228
229 if [[ ${CHOST} == *-darwin* ]]; then
230 # Set FLAGS *and* remove -arch, since our gcc-apple is multilib
231 # crippled (by design) :/
186 sed -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \ 232 sed -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \
187 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \ 233 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \
188 -e "s:QMAKE_LFLAGS_RELEASE.*=.*:QMAKE_LFLAGS_RELEASE=${LDFLAGS}:" \ 234 -e "s:QMAKE_LFLAGS_RELEASE.*=.*:QMAKE_LFLAGS_RELEASE=-headerpad_max_install_names ${LDFLAGS}:" \
235 -e "s:-arch\s\w*::g" \
189 -i "${S}"/mkspecs/common/g++.conf || die "sed ${S}/mkspecs/common/g++.conf failed" 236 -i mkspecs/common/mac-g++.conf || die "sed mkspecs/common/mac-g++.conf failed"
237
238 # Fix configure's -arch settings that appear in qmake/Makefile and also
239 # fix arch handling (automagically duplicates our -arch arg and breaks
240 # pch). Additionally disable Xarch support.
241 sed \
242 -e "s:-arch i386::" \
243 -e "s:-arch ppc::" \
244 -e "s:-arch x86_64::" \
245 -e "s:-arch ppc64::" \
246 -e "s:-arch \$i::" \
247 -e "/if \[ ! -z \"\$NATIVE_64_ARCH\" \]; then/,/fi/ d" \
248 -e "s:CFG_MAC_XARCH=yes:CFG_MAC_XARCH=no:g" \
249 -e "s:-Xarch_x86_64::g" \
250 -e "s:-Xarch_ppc64::g" \
251 -i configure mkspecs/common/mac-g++.conf || die "sed configure failed"
252
253 # On Snow Leopard don't fall back to 10.5 deployment target.
254 if [[ ${CHOST} == *-apple-darwin10 ]] ; then
255 sed -e "s:QMakeVar set QMAKE_MACOSX_DEPLOYMENT_TARGET.*:QMakeVar set QMAKE_MACOSX_DEPLOYMENT_TARGET 10.6:g" \
256 -e "s:-mmacosx-version-min=10.[0-9]:-mmacosx-version-min=10.6:g" \
257 -i configure mkspecs/common/mac-g++.conf || die "sed configure failed"
258 fi
259 fi
260
261 # this one is needed for all systems with a separate -liconv, apart from
262 # Darwin, for which the sources already cater for -liconv
263 if use !elibc_glibc && [[ ${CHOST} != *-darwin* ]] ; then
264 sed \
265 -e "s|mac:LIBS += -liconv|LIBS += -liconv|g" \
266 -i config.tests/unix/iconv/iconv.pro \
267 || die "sed on iconv.pro failed"
268 fi
269
270 # we need some patches for Solaris
271 sed -i \
272 -e '/^QMAKE_LFLAGS_THREAD/a\QMAKE_LFLAGS_DYNAMIC_LIST = -Wl,--dynamic-list,' \
273 mkspecs/$(qt_mkspecs_dir)/qmake.conf || die
274 # use GCC over SunStudio
275 sed -i -e '/PLATFORM=solaris-cc/s/cc/g++/' configure || die
276 # don't flirt with non-Prefix stuff, we're quite possessive
277 sed -i -e '/^QMAKE_\(LIB\|INC\)DIR\(_X11\|_OPENGL\|\)\t/s/=.*$/=/' \
278 mkspecs/$(qt_mkspecs_dir)/qmake.conf || die
279 # strip predefined CFLAGS from qmake ( bug #312689 )
280 sed -i '/^QMAKE_CFLAGS_\(RELEASE\|DEBUG\)/s:+=.*:+=:' mkspecs/common/g++.conf
190 281
191 base_src_prepare 282 base_src_prepare
192} 283}
193 284
194# @FUNCTION: qt4-build_src_configure 285# @FUNCTION: qt4-build_src_configure
196# Default configure phase 287# Default configure phase
197qt4-build_src_configure() { 288qt4-build_src_configure() {
198 setqtenv 289 setqtenv
199 myconf="$(standard_configure_options) ${myconf}" 290 myconf="$(standard_configure_options) ${myconf}"
200 291
292 # this one is needed for all systems with a separate -liconv, apart from
293 # Darwin, for which the sources already cater for -liconv
294 use !elibc_glibc && [[ ${CHOST} != *-darwin* ]] && \
295 myconf+=" -liconv"
296
297 if has glib ${IUSE//+} && use glib; then
298 # use -I, -L and -l from configure
299 local glibflags="$(pkg-config --cflags --libs glib-2.0 gthread-2.0)"
300 # avoid the -pthread argument
301 myconf+=" ${glibflags//-pthread}"
302 unset glibflags
303 fi
304
305 if use aqua ; then
306 # On (snow) leopard use the new (frameworked) cocoa code.
307 if [[ ${CHOST##*-darwin} -ge 9 ]] ; then
308 myconf+=" -cocoa -framework"
309
310 # We are crazy and build cocoa + qt3support :-)
311 if use qt3support; then
312 sed -e "/case \"\$PLATFORM,\$CFG_MAC_COCOA\" in/,/;;/ s|CFG_QT3SUPPORT=\"no\"|CFG_QT3SUPPORT=\"yes\"|" \
313 -i configure
314 fi
315
316 # We need the source's headers, not the installed ones.
317 myconf+=" -I${S}/include"
318
319 # Add hint for the framework location.
320 myconf+=" -F${QTLIBDIR}"
321 fi
322 else
323 # freetype2 include dir is non-standard, thus include it on configure
324 # use -I from configure
325 myconf+=" $(pkg-config --cflags freetype2)"
326 fi
327
201 echo ./configure ${myconf} 328 echo ./configure ${myconf}
202 ./configure ${myconf} || die "./configure failed" 329 ./configure ${myconf} || die "./configure failed"
203 myconf="" 330 myconf=""
204} 331}
205 332
209 setqtenv 336 setqtenv
210 337
211 build_directories ${QT4_TARGET_DIRECTORIES} 338 build_directories ${QT4_TARGET_DIRECTORIES}
212} 339}
213 340
341# @FUNCTION: qt4-build_src_test
342# @DESCRIPTION:
343# Runs tests only in target directories.
344qt4-build_src_test() {
345 for dir in ${QT4_TARGET_DIRECTORIES}; do
346 emake -j1 check -C ${dir}
347 done
348}
349
350# @FUNCTION: fix_includes
351# @DESCRIPTION:
352# For MacOSX we need to add some symlinks when frameworks are
353# being used, to avoid complications with some more or less stupid packages.
354fix_includes() {
355 if use aqua && [[ ${CHOST##*-darwin} -ge 9 ]] ; then
356 # Some packages tend to include <Qt/...>
357 dodir "${QTHEADERDIR#${EPREFIX}}"/Qt
358
359 # Fake normal headers when frameworks are installed... eases life later on
360 local dest f
361 for frw in "${D}${QTLIBDIR}"/*.framework; do
362 [[ -e "${frw}"/Headers ]] || continue
363 f=$(basename ${frw})
364 dest="${QTHEADERDIR#${EPREFIX}}"/${f%.framework}
365 dosym "${QTLIBDIR#${EPREFIX}}"/${f}/Headers "${dest}"
366
367 # Link normal headers as well.
368 for hdr in "${D}/${QTLIBDIR}/${f}"/Headers/*; do
369 h=$(basename ${hdr})
370 dosym "${QTLIBDIR#${EPREFIX}}"/${f}/Headers/${h} "${QTHEADERDIR#${EPREFIX}}"/Qt/${h}
371 done
372 done
373 fi
374}
375
214# @FUNCTION: qt4-build_src_install 376# @FUNCTION: qt4-build_src_install
215# @DESCRIPTION: 377# @DESCRIPTION:
216# Perform the actual installation including some library fixes. 378# Perform the actual installation including some library fixes.
217qt4-build_src_install() { 379qt4-build_src_install() {
380 [[ ${EAPI} == 2 ]] && use !prefix && ED=${D}
218 setqtenv 381 setqtenv
219 install_directories ${QT4_TARGET_DIRECTORIES} 382 install_directories ${QT4_TARGET_DIRECTORIES}
220 install_qconfigs 383 install_qconfigs
221 fix_library_files 384 fix_library_files
385 fix_includes
222} 386}
223 387
224# @FUNCTION: setqtenv 388# @FUNCTION: setqtenv
225setqtenv() { 389setqtenv() {
226 # Set up installation directories 390 # Set up installation directories
227 QTBASEDIR=/usr/$(get_libdir)/qt4 391 QTBASEDIR=${EPREFIX}/usr/$(get_libdir)/qt4
228 QTPREFIXDIR=/usr 392 QTPREFIXDIR=${EPREFIX}/usr
229 QTBINDIR=/usr/bin 393 QTBINDIR=${EPREFIX}/usr/bin
230 QTLIBDIR=/usr/$(get_libdir)/qt4 394 QTLIBDIR=${EPREFIX}/usr/$(get_libdir)/qt4
231 QMAKE_LIBDIR_QT=${QTLIBDIR} 395 QMAKE_LIBDIR_QT=${QTLIBDIR}
232 QTPCDIR=/usr/$(get_libdir)/pkgconfig 396 QTPCDIR=${EPREFIX}/usr/$(get_libdir)/pkgconfig
233 QTDATADIR=/usr/share/qt4 397 QTDATADIR=${EPREFIX}/usr/share/qt4
234 QTDOCDIR=/usr/share/doc/qt-${PV} 398 QTDOCDIR=${EPREFIX}/usr/share/doc/qt-${PV}
235 QTHEADERDIR=/usr/include/qt4 399 QTHEADERDIR=${EPREFIX}/usr/include/qt4
236 QTPLUGINDIR=${QTLIBDIR}/plugins 400 QTPLUGINDIR=${QTLIBDIR}/plugins
237 QTSYSCONFDIR=/etc/qt4 401 QTSYSCONFDIR=${EPREFIX}/etc/qt4
238 QTTRANSDIR=${QTDATADIR}/translations 402 QTTRANSDIR=${QTDATADIR}/translations
239 QTEXAMPLESDIR=${QTDATADIR}/examples 403 QTEXAMPLESDIR=${QTDATADIR}/examples
240 QTDEMOSDIR=${QTDATADIR}/demos 404 QTDEMOSDIR=${QTDATADIR}/demos
241 QT_INSTALL_PREFIX=/usr/$(get_libdir)/qt4 405 QT_INSTALL_PREFIX=${EPREFIX}/usr/$(get_libdir)/qt4
242 PLATFORM=$(qt_mkspecs_dir) 406 PLATFORM=$(qt_mkspecs_dir)
243 407
244 unset QMAKESPEC 408 unset QMAKESPEC
245} 409}
246 410
249# Sets up some standard configure options, like libdir (if necessary), whether 413# Sets up some standard configure options, like libdir (if necessary), whether
250# debug info is wanted or not. 414# debug info is wanted or not.
251standard_configure_options() { 415standard_configure_options() {
252 local myconf= 416 local myconf=
253 417
254 [[ $(get_libdir) != lib ]] && myconf+=" -L/usr/$(get_libdir)" 418 [[ $(get_libdir) != lib ]] && myconf+=" -L${EPREFIX}/usr/$(get_libdir)"
255 419
256 # Disable visibility explicitly if gcc version isn't 4 420 # Disable visibility explicitly if gcc version isn't 4
257 if [[ $(gcc-major-version) -lt 4 ]]; then 421 if [[ $(gcc-major-version) -lt 4 ]]; then
258 myconf+=" -no-reduce-exports" 422 myconf+=" -no-reduce-exports"
259 fi 423 fi
266 else 430 else
267 myconf+=" -release" 431 myconf+=" -release"
268 fi 432 fi
269 myconf+=" -no-separate-debug-info" 433 myconf+=" -no-separate-debug-info"
270 434
435 use aqua && myconf+=" -no-framework"
436
271 # ARCH is set on Gentoo. Qt now falls back to generic on an unsupported 437 # ARCH is set on Gentoo. Qt now falls back to generic on an unsupported
272 # $(tc-arch). Therefore we convert it to supported values. 438 # $(tc-arch). Therefore we convert it to supported values.
273 case "$(tc-arch)" in 439 case "$(tc-arch)" in
274 amd64) myconf+=" -arch x86_64" ;; 440 amd64|x64-*) myconf+=" -arch x86_64" ;;
441 ppc-macos) myconf+=" -arch ppc" ;;
275 ppc|ppc64) myconf+=" -arch powerpc" ;; 442 ppc|ppc64|ppc-*) myconf+=" -arch powerpc" ;;
443 sparc|sparc-*) myconf+=" -arch sparc" ;;
444 x86-macos) myconf+=" -arch x86" ;;
276 x86|x86-*) myconf+=" -arch i386" ;; 445 x86|x86-*) myconf+=" -arch i386" ;;
277 alpha|arm|ia64|mips|s390|sparc) myconf+=" -arch $(tc-arch)" ;; 446 alpha|arm|ia64|mips|s390|sparc) myconf+=" -arch $(tc-arch)" ;;
278 hppa|sh) myconf+=" -arch generic" ;; 447 hppa|sh) myconf+=" -arch generic" ;;
279 *) die "$(tc-arch) is unsupported by this eclass. Please file a bug." ;; 448 *) die "$(tc-arch) is unsupported by this eclass. Please file a bug." ;;
280 esac 449 esac
281 450
282 # 4.6: build qt-core with exceptions or qt-xmlpatterns won't build 451 # 4.5: build everything but qt-xmlpatterns w/o exceptions
283 local exceptions= 452 # 4.6: exceptions USE flag
453 local exceptions="-exceptions"
284 case "${PV}" in 454 case "${PV}" in
285 4.6.*) 455 4.5.*)
286 if [[ ${PN} != "qt-core" ]] && [[ ${PN} != "qt-xmlpatterns" ]]; then 456 [[ ${PN} == "qt-xmlpatterns" ]] || exceptions="-no-exceptions"
287 exceptions="-no-exceptions"
288 fi
289 ;; 457 ;;
290 *) 458 *)
291 [[ ${PN} == "qt-xmlpatterns" ]] || exceptions="-no-exceptions" 459 has exceptions "${IUSE//+}" && exceptions="$(qt_use exceptions)"
292 ;; 460 ;;
293 esac 461 esac
462
463 # note about -reduce-relocations:
464 # That flag seems to introduce major breakage to applications,
465 # mostly to be seen as a core dump with the message "QPixmap: Must
466 # construct a QApplication before a QPaintDevice" on Solaris
467 # -- Daniel Vergien
468 [[ ${CHOST} != *-solaris* ]] && myconf+=" -reduce-relocations"
294 469
295 myconf+=" -platform $(qt_mkspecs_dir) -stl -verbose -largefile -confirm-license 470 myconf+=" -platform $(qt_mkspecs_dir) -stl -verbose -largefile -confirm-license
296 -prefix ${QTPREFIXDIR} -bindir ${QTBINDIR} -libdir ${QTLIBDIR} 471 -prefix ${QTPREFIXDIR} -bindir ${QTBINDIR} -libdir ${QTLIBDIR}
297 -datadir ${QTDATADIR} -docdir ${QTDOCDIR} -headerdir ${QTHEADERDIR} 472 -datadir ${QTDATADIR} -docdir ${QTDOCDIR} -headerdir ${QTHEADERDIR}
298 -plugindir ${QTPLUGINDIR} -sysconfdir ${QTSYSCONFDIR} 473 -plugindir ${QTPLUGINDIR} -sysconfdir ${QTSYSCONFDIR}
299 -translationdir ${QTTRANSDIR} -examplesdir ${QTEXAMPLESDIR} 474 -translationdir ${QTTRANSDIR} -examplesdir ${QTEXAMPLESDIR}
300 -demosdir ${QTDEMOSDIR} -silent -fast -opensource 475 -demosdir ${QTDEMOSDIR} -silent -fast -opensource
301 ${exceptions} 476 ${exceptions}
302 -reduce-relocations -nomake examples -nomake demos" 477 -nomake examples -nomake demos"
303 478
304 echo "${myconf}" 479 echo "${myconf}"
305} 480}
306 481
307# @FUNCTION: build_directories 482# @FUNCTION: build_directories
308# @USAGE: < directories > 483# @USAGE: < directories >
309# @DESCRIPTION: 484# @DESCRIPTION:
310# Compiles the code in $QT4_TARGET_DIRECTORIES 485# Compiles the code in $QT4_TARGET_DIRECTORIES
311build_directories() { 486build_directories() {
312 for x in "$@"; do 487 for x in "$@"; do
313 cd "${S}"/${x} 488 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 489 # avoid running over the maximum argument number, bug #299810
490 {
491 echo "${S}"/mkspecs/common/*.conf
492 find "${S}" -name '*.pr[io]'
493 } | xargs sed -i -e "s:\$\$\[QT_INSTALL_LIBS\]:${EPREFIX}/usr/$(get_libdir)/qt4:g" || die
315 "${S}"/bin/qmake "LIBS+=-L${QTLIBDIR}" "CONFIG+=nostrip" || die "qmake failed" 494 "${S}"/bin/qmake "LIBS+=-L${QTLIBDIR}" "CONFIG+=nostrip" || die "qmake failed"
316 emake CC="@echo compiling \$< && $(tc-getCC)" \ 495 emake CC="$(tc-getCC)" \
317 CXX="@echo compiling \$< && $(tc-getCXX)" \ 496 CXX="$(tc-getCXX)" \
318 LINK="@echo linking \$@ && $(tc-getCXX)" || die "emake failed" 497 LINK="$(tc-getCXX)" || die "emake failed"
498 popd >/dev/null
319 done 499 done
320} 500}
321 501
322# @FUNCTION: install_directories 502# @FUNCTION: install_directories
323# @USAGE: < directories > 503# @USAGE: < directories >
352 local x 532 local x
353 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} ]]; then 533 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} ]]; then
354 for x in QCONFIG_ADD QCONFIG_REMOVE; do 534 for x in QCONFIG_ADD QCONFIG_REMOVE; do
355 [[ -n ${!x} ]] && echo ${x}=${!x} >> "${T}"/${PN}-qconfig.pri 535 [[ -n ${!x} ]] && echo ${x}=${!x} >> "${T}"/${PN}-qconfig.pri
356 done 536 done
357 insinto ${QTDATADIR}/mkspecs/gentoo 537 insinto ${QTDATADIR#${EPREFIX}}/mkspecs/gentoo
358 doins "${T}"/${PN}-qconfig.pri || die "installing ${PN}-qconfig.pri failed" 538 doins "${T}"/${PN}-qconfig.pri || die "installing ${PN}-qconfig.pri failed"
359 fi 539 fi
360 540
361 if [[ -n ${QCONFIG_DEFINE} ]]; then 541 if [[ -n ${QCONFIG_DEFINE} ]]; then
362 for x in ${QCONFIG_DEFINE}; do 542 for x in ${QCONFIG_DEFINE}; do
363 echo "#define ${x}" >> "${T}"/gentoo-${PN}-qconfig.h 543 echo "#define ${x}" >> "${T}"/gentoo-${PN}-qconfig.h
364 done 544 done
365 insinto ${QTHEADERDIR}/Gentoo 545 insinto ${QTHEADERDIR#${EPREFIX}}/Gentoo
366 doins "${T}"/gentoo-${PN}-qconfig.h || die "installing ${PN}-qconfig.h failed" 546 doins "${T}"/gentoo-${PN}-qconfig.h || die "installing ${PN}-qconfig.h failed"
367 fi 547 fi
368} 548}
369 549
370# @FUNCTION: generate_qconfigs 550# @FUNCTION: generate_qconfigs
434# @FUNCTION: qt4-build_pkg_postinst 614# @FUNCTION: qt4-build_pkg_postinst
435# @DESCRIPTION: Generate configuration, plus throws a message about possible 615# @DESCRIPTION: Generate configuration, plus throws a message about possible
436# breakages and proposed solutions. 616# breakages and proposed solutions.
437qt4-build_pkg_postinst() { 617qt4-build_pkg_postinst() {
438 generate_qconfigs 618 generate_qconfigs
439
440 if [[ "${PN}" == "qt-core" ]]; then
441 echo
442 ewarn "After a rebuild or upgrade of Qt, it can happen that Qt plugins (such as Qt"
443 ewarn "and KDE styles and widgets) can no longer be loaded. In this situation you"
444 ewarn "should recompile the packages providing these plugins. Also, make sure you"
445 ewarn "compile the Qt packages, and the packages that depend on it, with the same"
446 ewarn "GCC version and the same USE flag settings (especially the debug flag)."
447 ewarn
448 ewarn "Packages that typically need to be recompiled are kdelibs from KDE4, any"
449 ewarn "additional KDE4/Qt4 styles, qscintilla and PyQt4. Before filing a bug report,"
450 ewarn "make sure all your Qt4 packages are up-to-date and built with the same"
451 ewarn "configuration."
452 ewarn
453 ewarn "For more information, see http://doc.trolltech.com/${PV%.*}/plugins-howto.html"
454 echo
455 fi
456} 619}
457 620
458# @FUNCTION: skip_qmake_build_patch 621# @FUNCTION: skip_qmake_build_patch
459# @DESCRIPTION: 622# @DESCRIPTION:
460# Don't need to build qmake, as it's already installed from qt-core 623# Don't need to build qmake, as it's already installed from qt-core
497 for libfile in "${D}"/${QTLIBDIR}/pkgconfig/*.pc; do 660 for libfile in "${D}"/${QTLIBDIR}/pkgconfig/*.pc; do
498 if [[ -e ${libfile} ]]; then 661 if [[ -e ${libfile} ]]; then
499 sed -i -e "s:${S}/bin:${QTBINDIR}:g" ${libfile} || die "Sed failed" 662 sed -i -e "s:${S}/bin:${QTBINDIR}:g" ${libfile} || die "Sed failed"
500 663
501 # Move .pc files into the pkgconfig directory 664 # Move .pc files into the pkgconfig directory
502 dodir ${QTPCDIR} 665 dodir ${QTPCDIR#${EPREFIX}}
503 mv ${libfile} "${D}"/${QTPCDIR}/ \ 666 mv ${libfile} "${D}"/${QTPCDIR}/ \
504 || die "Moving ${libfile} to ${D}/${QTPCDIR}/ failed." 667 || die "Moving ${libfile} to ${D}/${QTPCDIR}/ failed."
505 fi 668 fi
506 done 669 done
507 670
545 *-openbsd*) 708 *-openbsd*)
546 spec=openbsd ;; 709 spec=openbsd ;;
547 *-netbsd*) 710 *-netbsd*)
548 spec=netbsd ;; 711 spec=netbsd ;;
549 *-darwin*) 712 *-darwin*)
713 if use aqua; then
714 # mac with carbon/cocoa
715 spec=macx
716 else
717 # darwin/mac with x11
550 spec=darwin ;; 718 spec=darwin
719 fi
720 ;;
721 *-solaris*)
722 spec=solaris ;;
551 *-linux-*|*-linux) 723 *-linux-*|*-linux)
552 spec=linux ;; 724 spec=linux ;;
553 *) 725 *)
554 die "Unknown CHOST, no platform choosen." 726 die "Unknown CHOST, no platform choosen."
555 esac 727 esac
564 fi 736 fi
565 if [[ -n ${LIBDIR/lib} ]]; then 737 if [[ -n ${LIBDIR/lib} ]]; then
566 spec+=-${LIBDIR/lib} 738 spec+=-${LIBDIR/lib}
567 fi 739 fi
568 740
741 # Add -64 for 64bit profiles
742 if use x64-freebsd ||
743 use amd64-linux ||
744 use x64-macos ||
745 use x64-solaris ||
746 use sparc64-solaris
747 then
748 spec+=-64
749 fi
750
569 echo "${spec}" 751 echo "${spec}"
570} 752}
571 753
572EXPORT_FUNCTIONS pkg_setup src_unpack src_prepare src_configure src_compile src_install pkg_postrm pkg_postinst 754EXPORT_FUNCTIONS pkg_setup src_unpack src_prepare src_configure src_compile src_install src_test pkg_postrm pkg_postinst

Legend:
Removed from v.1.55  
changed lines
  Added in v.1.76

  ViewVC Help
Powered by ViewVC 1.1.20