/[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.129 Revision 1.146
1# Copyright 1999-2012 Gentoo Foundation 1# Copyright 1999-2013 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.129 2012/05/20 17:12:34 pesa Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/qt4-build.eclass,v 1.146 2013/04/28 16:15:33 zmedico Exp $
4 4
5# @ECLASS: qt4-build.eclass 5# @ECLASS: qt4-build.eclass
6# @MAINTAINER: 6# @MAINTAINER:
7# Qt herd <qt@gentoo.org> 7# Qt herd <qt@gentoo.org>
8# @BLURB: Eclass for Qt4 split ebuilds. 8# @BLURB: Eclass for Qt4 split ebuilds.
9# @DESCRIPTION: 9# @DESCRIPTION:
10# This eclass contains various functions that are used when building Qt4. 10# This eclass contains various functions that are used when building Qt4.
11 11
12case ${EAPI} in 12case ${EAPI} in
13 2|3|4) : ;; 13 3|4|5) : ;;
14 *) die "qt4-build.eclass requires EAPI 2, 3 or 4." ;; 14 *) die "qt4-build.eclass: unsupported EAPI=${EAPI:-0}" ;;
15esac 15esac
16 16
17inherit base eutils flag-o-matic multilib toolchain-funcs versionator 17inherit eutils flag-o-matic multilib toolchain-funcs versionator
18 18
19if [[ ${PV} == *9999* ]]; then 19if [[ ${PV} == *9999* ]]; then
20 QT4_BUILD_TYPE="live" 20 QT4_BUILD_TYPE="live"
21 inherit git-2 21 inherit git-2
22else 22else
23 QT4_BUILD_TYPE="release" 23 QT4_BUILD_TYPE="release"
24fi 24fi
25 25
26HOMEPAGE="http://qt-project.org/ http://qt.nokia.com/" 26HOMEPAGE="http://qt-project.org/ http://qt.digia.com/"
27LICENSE="|| ( LGPL-2.1 GPL-3 )" 27LICENSE="|| ( LGPL-2.1 GPL-3 )"
28 28
29MY_PV=${PV/_/-} 29MY_PV=${PV/_/-}
30MY_P=qt-everywhere-opensource-src-${MY_PV} 30MY_P=qt-everywhere-opensource-src-${MY_PV}
31 31
32case ${QT4_BUILD_TYPE} in 32case ${QT4_BUILD_TYPE} in
33 live) 33 live)
34 EGIT_REPO_URI="git://gitorious.org/qt/qt.git 34 EGIT_REPO_URI="git://gitorious.org/qt/qt.git
35 https://git.gitorious.org/qt/qt.git" 35 https://git.gitorious.org/qt/qt.git"
36 EGIT_BRANCH="${PV%.9999}" 36 EGIT_BRANCH=${PV%.9999}
37 ;; 37 ;;
38 release) 38 release)
39 SRC_URI="http://get.qt.nokia.com/qt/source/${MY_P}.tar.gz" 39 SRC_URI="http://releases.qt-project.org/qt4/source/${MY_P}.tar.gz"
40 ;; 40 ;;
41esac 41esac
42 42
43IUSE="aqua debug pch" 43IUSE="aqua debug pch"
44if [[ ${CATEGORY}/${PN} != x11-libs/qt-xmlpatterns ]]; then 44[[ ${CATEGORY}/${PN} != dev-qt/qtwebkit ]] && IUSE+=" c++0x"
45 IUSE+=" +exceptions" 45[[ ${CATEGORY}/${PN} != dev-qt/qtxmlpatterns ]] && IUSE+=" +exceptions"
46fi
47if version_is_at_least 4.8; then
48 IUSE+=" c++0x qpa"
49fi
50 46
51DEPEND="virtual/pkgconfig" 47DEPEND="virtual/pkgconfig"
52if [[ ${QT4_BUILD_TYPE} == live ]]; then 48if [[ ${QT4_BUILD_TYPE} == live ]]; then
53 DEPEND+=" dev-lang/perl" 49 DEPEND+=" dev-lang/perl"
54fi 50fi
55 51
56RDEPEND="
57 !<x11-libs/qt-assistant-${PV}
58 !>x11-libs/qt-assistant-${PV}-r9999
59 !<x11-libs/qt-bearer-${PV}
60 !>x11-libs/qt-bearer-${PV}-r9999
61 !<x11-libs/qt-core-${PV}
62 !>x11-libs/qt-core-${PV}-r9999
63 !<x11-libs/qt-dbus-${PV}
64 !>x11-libs/qt-dbus-${PV}-r9999
65 !<x11-libs/qt-declarative-${PV}
66 !>x11-libs/qt-declarative-${PV}-r9999
67 !<x11-libs/qt-demo-${PV}
68 !>x11-libs/qt-demo-${PV}-r9999
69 !<x11-libs/qt-gui-${PV}
70 !>x11-libs/qt-gui-${PV}-r9999
71 !<x11-libs/qt-multimedia-${PV}
72 !>x11-libs/qt-multimedia-${PV}-r9999
73 !<x11-libs/qt-opengl-${PV}
74 !>x11-libs/qt-opengl-${PV}-r9999
75 !<x11-libs/qt-openvg-${PV}
76 !>x11-libs/qt-openvg-${PV}-r9999
77 !<x11-libs/qt-phonon-${PV}
78 !>x11-libs/qt-phonon-${PV}-r9999
79 !<x11-libs/qt-qt3support-${PV}
80 !>x11-libs/qt-qt3support-${PV}-r9999
81 !<x11-libs/qt-script-${PV}
82 !>x11-libs/qt-script-${PV}-r9999
83 !<x11-libs/qt-sql-${PV}
84 !>x11-libs/qt-sql-${PV}-r9999
85 !<x11-libs/qt-svg-${PV}
86 !>x11-libs/qt-svg-${PV}-r9999
87 !<x11-libs/qt-test-${PV}
88 !>x11-libs/qt-test-${PV}-r9999
89 !<x11-libs/qt-webkit-${PV}
90 !>x11-libs/qt-webkit-${PV}-r9999
91 !<x11-libs/qt-xmlpatterns-${PV}
92 !>x11-libs/qt-xmlpatterns-${PV}-r9999
93"
94
95S=${WORKDIR}/${MY_P} 52S=${WORKDIR}/${MY_P}
96 53
97# @FUNCTION: qt4-build_pkg_setup 54# @FUNCTION: qt4-build_pkg_setup
98# @DESCRIPTION: 55# @DESCRIPTION:
99# Sets up PATH and LD_LIBRARY_PATH. 56# Sets up PATH and LD_LIBRARY_PATH.
100qt4-build_pkg_setup() { 57qt4-build_pkg_setup() {
101 [[ ${EAPI} == 2 ]] && use !prefix && EPREFIX=
102
103 # Protect users by not allowing downgrades between releases 58 # Protect users by not allowing downgrades between releases.
104 # Downgrading revisions within the same release should be allowed 59 # Downgrading revisions within the same release should be allowed.
105 if has_version '>'${CATEGORY}/${P}-r9999; then 60 if has_version ">${CATEGORY}/${P}-r9999:4"; then
106 if [[ -z ${I_KNOW_WHAT_I_AM_DOING} ]]; then 61 if [[ -z ${I_KNOW_WHAT_I_AM_DOING} ]]; then
107 eerror
108 eerror "Sanity check to keep you from breaking your system:" 62 eerror " *** Sanity check to keep you from breaking your system ***"
109 eerror " Downgrading Qt is completely unsupported and will break your system!" 63 eerror "Downgrading Qt is completely unsupported and will break your system!"
110 eerror
111 die "aborting to save your system" 64 die "aborting to save your system"
112 else 65 else
113 ewarn "Downgrading Qt is completely unsupported and will break your system!" 66 ewarn "Downgrading Qt is completely unsupported and will break your system!"
114 fi 67 fi
115 fi
116
117 if [[ ${PN} == qt-webkit ]]; then
118 eshopts_push -s extglob
119 if is-flagq '-g?(gdb)?([1-9])'; then
120 echo
121 ewarn "You have enabled debug info (probably have -g or -ggdb in your CFLAGS/CXXFLAGS)."
122 ewarn "You may experience really long compilation times and/or increased memory usage."
123 ewarn "If compilation fails, please try removing -g/-ggdb before reporting a bug."
124 ewarn "For more info check out bug #307861"
125 echo
126 fi
127 eshopts_pop
128 fi 68 fi
129 69
130 PATH="${S}/bin${PATH:+:}${PATH}" 70 PATH="${S}/bin${PATH:+:}${PATH}"
131 if [[ ${CHOST} != *-darwin* ]]; then 71 if [[ ${CHOST} != *-darwin* ]]; then
132 LD_LIBRARY_PATH="${S}/lib${LD_LIBRARY_PATH:+:}${LD_LIBRARY_PATH}" 72 LD_LIBRARY_PATH="${S}/lib${LD_LIBRARY_PATH:+:}${LD_LIBRARY_PATH}"
137 # avoid extract failure. 77 # avoid extract failure.
138 [[ ${CHOST} == *-apple-darwin* ]] && \ 78 [[ ${CHOST} == *-apple-darwin* ]] && \
139 QT4_EXTRACT_DIRECTORIES="src/gui/kernel/qapplication_mac.mm 79 QT4_EXTRACT_DIRECTORIES="src/gui/kernel/qapplication_mac.mm
140 ${QT4_EXTRACT_DIRECTORIES}" 80 ${QT4_EXTRACT_DIRECTORIES}"
141 fi 81 fi
142
143 if ! version_is_at_least 4.1 $(gcc-version); then
144 ewarn "Using a GCC version lower than 4.1 is not supported."
145 fi
146} 82}
83
84# @ECLASS-VARIABLE: QT4_EXTRACT_DIRECTORIES
85# @DEFAULT_UNSET
86# @DESCRIPTION:
87# Space-separated list including the directories that will be extracted from
88# Qt tarball.
147 89
148# @ECLASS-VARIABLE: QT4_TARGET_DIRECTORIES 90# @ECLASS-VARIABLE: QT4_TARGET_DIRECTORIES
91# @DEFAULT_UNSET
149# @DESCRIPTION: 92# @DESCRIPTION:
150# Arguments for build_target_directories. Takes the directories in which the 93# Arguments for build_target_directories. Takes the directories in which the
151# code should be compiled. This is a space-separated list. 94# code should be compiled. This is a space-separated list.
152
153# @ECLASS-VARIABLE: QT4_EXTRACT_DIRECTORIES
154# @DESCRIPTION:
155# Space-separated list including the directories that will be extracted from
156# Qt tarball.
157 95
158# @FUNCTION: qt4-build_src_unpack 96# @FUNCTION: qt4-build_src_unpack
159# @DESCRIPTION: 97# @DESCRIPTION:
160# Unpacks the sources. 98# Unpacks the sources.
161qt4-build_src_unpack() { 99qt4-build_src_unpack() {
162 setqtenv 100 setqtenv
101
102 if ! version_is_at_least 4.1 $(gcc-version); then
103 ewarn "Using a GCC version lower than 4.1 is not supported."
104 fi
105
106 if [[ ${CATEGORY}/${PN} == dev-qt/qtwebkit ]]; then
107 eshopts_push -s extglob
108 if is-flagq '-g?(gdb)?([1-9])'; then
109 echo
110 ewarn "You have enabled debug info (probably have -g or -ggdb in your CFLAGS/CXXFLAGS)."
111 ewarn "You may experience really long compilation times and/or increased memory usage."
112 ewarn "If compilation fails, please try removing -g/-ggdb before reporting a bug."
113 ewarn "For more info check out https://bugs.gentoo.org/307861"
114 echo
115 fi
116 eshopts_pop
117 fi
163 118
164 case ${QT4_BUILD_TYPE} in 119 case ${QT4_BUILD_TYPE} in
165 live) 120 live)
166 git-2_src_unpack 121 git-2_src_unpack
167 ;; 122 ;;
185# @DEFAULT_UNSET 140# @DEFAULT_UNSET
186# @DESCRIPTION: 141# @DESCRIPTION:
187# PATCHES array variable containing all various patches to be applied. 142# PATCHES array variable containing all various patches to be applied.
188# This variable is expected to be defined in global scope of ebuild. 143# This variable is expected to be defined in global scope of ebuild.
189# Make sure to specify the full path. This variable is utilised in 144# Make sure to specify the full path. This variable is utilised in
190# src_unpack/src_prepare phase, based on EAPI. 145# src_prepare() phase.
191# 146#
192# @CODE 147# @CODE
193# PATCHES=( "${FILESDIR}/mypatch.patch" 148# PATCHES=( "${FILESDIR}/mypatch.patch"
194# "${FILESDIR}/patches_folder/" ) 149# "${FILESDIR}/patches_folder/" )
195# @CODE 150# @CODE
196 151
197# @FUNCTION: qt4-build_src_prepare 152# @FUNCTION: qt4-build_src_prepare
198# @DESCRIPTION: 153# @DESCRIPTION:
199# Prepare the sources before the configure phase. Strip CFLAGS if necessary, and fix 154# Prepare the sources before the configure phase. Strip CFLAGS if necessary, and fix
200# the build system in order to respect CFLAGS/CXXFLAGS/LDFLAGS specified in /etc/make.conf. 155# the build system in order to respect CFLAGS/CXXFLAGS/LDFLAGS specified in make.conf.
201qt4-build_src_prepare() { 156qt4-build_src_prepare() {
202 setqtenv 157 setqtenv
203 158
204 if [[ ${QT4_BUILD_TYPE} == live ]]; then 159 if [[ ${QT4_BUILD_TYPE} == live ]]; then
205 QTDIR="." ./bin/syncqt || die "syncqt failed" 160 QTDIR="." ./bin/syncqt || die "syncqt failed"
206 fi 161 fi
207 162
208 if version_is_at_least 4.7; then
209 # fix libX11 dependency on non X packages 163 # avoid X11 dependency in non-gui packages
210 local nolibx11_pkgs="qt-core qt-dbus qt-script qt-sql qt-test qt-xmlpatterns" 164 local nolibx11_pkgs="qtcore qtdbus qtscript qtsql qttest qtxmlpatterns"
211 has ${PN} ${nolibx11_pkgs} && qt_nolibx11 165 has ${PN} ${nolibx11_pkgs} && qt_nolibx11
212
213 qt_assistant_cleanup
214 fi
215 166
216 if use aqua; then 167 if use aqua; then
217 # provide a proper macx-g++-64 168 # provide a proper macx-g++-64
218 use x64-macos && ln -s macx-g++ mkspecs/$(qt_mkspecs_dir) 169 use x64-macos && ln -s macx-g++ mkspecs/$(qt_mkspecs_dir)
219 170
220 sed -e '/^CONFIG/s:app_bundle::' \ 171 sed -e '/^CONFIG/s:app_bundle::' \
221 -e '/^CONFIG/s:plugin_no_soname:plugin_with_soname absolute_library_soname:' \ 172 -e '/^CONFIG/s:plugin_no_soname:plugin_with_soname absolute_library_soname:' \
222 -i mkspecs/$(qt_mkspecs_dir)/qmake.conf || die 173 -i mkspecs/$(qt_mkspecs_dir)/qmake.conf || die
223 fi 174 fi
224 175
225 if [[ ${PN} != qt-core ]]; then 176 if [[ ${CATEGORY}/${PN} != dev-qt/qtcore ]]; then
226 skip_qmake_build 177 skip_qmake_build
227 skip_project_generation 178 skip_project_generation
228 symlink_binaries_to_buildtree 179 symlink_binaries_to_buildtree
229 fi 180 fi
230 181
239 ewarn "Appending -fno-gcse to CFLAGS/CXXFLAGS" 190 ewarn "Appending -fno-gcse to CFLAGS/CXXFLAGS"
240 append-flags -fno-gcse 191 append-flags -fno-gcse
241 fi 192 fi
242 193
243 if use_if_iuse c++0x; then 194 if use_if_iuse c++0x; then
244 echo
245 ewarn "You are about to build Qt4 using the C++11 standard. Even though"
246 ewarn "this is an official standard, some of the reverse dependencies"
247 ewarn "may fail to compile or link againt the Qt4 libraries. Before"
248 ewarn "reporting a bug, make sure your bug is reproducible with c++0x"
249 ewarn "disabled."
250 echo
251 append-flags -std=c++0x 195 append-cxxflags -std=c++0x
252 fi 196 fi
253 197
254 # Unsupported old gcc versions - hardened needs this :( 198 # Unsupported old gcc versions - hardened needs this :(
255 if [[ $(gcc-major-version) -lt 4 ]]; then 199 if [[ $(gcc-major-version) -lt 4 ]]; then
256 ewarn "Appending -fno-stack-protector to CXXFLAGS" 200 ewarn "Appending -fno-stack-protector to CXXFLAGS"
270 sed -e "/^SYSTEM_VARIABLES=/i \ 214 sed -e "/^SYSTEM_VARIABLES=/i \
271 CC='$(tc-getCC)'\n\ 215 CC='$(tc-getCC)'\n\
272 CXX='$(tc-getCXX)'\n\ 216 CXX='$(tc-getCXX)'\n\
273 CFLAGS='${CFLAGS}'\n\ 217 CFLAGS='${CFLAGS}'\n\
274 CXXFLAGS='${CXXFLAGS}'\n\ 218 CXXFLAGS='${CXXFLAGS}'\n\
275 LDFLAGS='${LDFLAGS}'\n" \ 219 LDFLAGS='${LDFLAGS}'\n\
220 QMakeVar set QMAKE_CFLAGS_RELEASE\n\
221 QMakeVar set QMAKE_CFLAGS_DEBUG\n\
222 QMakeVar set QMAKE_CXXFLAGS_RELEASE\n\
223 QMakeVar set QMAKE_CXXFLAGS_DEBUG\n\
224 QMakeVar set QMAKE_LFLAGS_RELEASE\n\
225 QMakeVar set QMAKE_LFLAGS_DEBUG\n"\
276 -i configure \ 226 -i configure \
277 || die "sed SYSTEM_VARIABLES failed" 227 || die "sed SYSTEM_VARIABLES failed"
278 228
279 # Respect CC, CXX, LINK and *FLAGS in config.tests 229 # Respect CC, CXX, LINK and *FLAGS in config.tests
280 find config.tests/unix -name '*.test' -type f -print0 | xargs -0 \ 230 find config.tests/unix -name '*.test' -type f -print0 | xargs -0 \
281 sed -i -e "/bin\/qmake/ s: \"QT_BUILD_TREE=: \ 231 sed -i -e "/bin\/qmake/ s: \"\$SRCDIR/: \
282 'QMAKE_CC=$(tc-getCC)' 'QMAKE_CXX=$(tc-getCXX)' 'QMAKE_LINK=$(tc-getCXX)' \ 232 'QMAKE_CC=$(tc-getCC)' 'QMAKE_CXX=$(tc-getCXX)' 'QMAKE_LINK=$(tc-getCXX)' \
283 'QMAKE_CFLAGS+=${CFLAGS}' 'QMAKE_CXXFLAGS+=${CXXFLAGS}' 'QMAKE_LFLAGS+=${LDFLAGS}'&:" \ 233 'QMAKE_CFLAGS+=${CFLAGS}' 'QMAKE_CXXFLAGS+=${CXXFLAGS}' 'QMAKE_LFLAGS+=${LDFLAGS}'&:" \
284 || die "sed config.tests failed" 234 || die "sed config.tests failed"
285
286 if ! version_is_at_least 4.8; then
287 # Strip predefined CFLAGS from mkspecs (bugs 312689 and 352778)
288 sed -i -e '/^QMAKE_CFLAGS_RELEASE/s:+=.*:+=:' mkspecs/common/g++.conf || die
289 fi
290 235
291 # Bug 172219 236 # Bug 172219
292 sed -e 's:/X11R6/:/:' -i mkspecs/$(qt_mkspecs_dir)/qmake.conf || die 237 sed -e 's:/X11R6/:/:' -i mkspecs/$(qt_mkspecs_dir)/qmake.conf || die
293 238
294 if [[ ${CHOST} == *-darwin* ]]; then 239 if [[ ${CHOST} == *-darwin* ]]; then
356 sed -i -e '/PLATFORM=solaris-cc/s/cc/g++/' configure || die 301 sed -i -e '/PLATFORM=solaris-cc/s/cc/g++/' configure || die
357 # do not flirt with non-Prefix stuff, we're quite possessive 302 # do not flirt with non-Prefix stuff, we're quite possessive
358 sed -i -e '/^QMAKE_\(LIB\|INC\)DIR\(_X11\|_OPENGL\|\)\t/s/=.*$/=/' \ 303 sed -i -e '/^QMAKE_\(LIB\|INC\)DIR\(_X11\|_OPENGL\|\)\t/s/=.*$/=/' \
359 mkspecs/$(qt_mkspecs_dir)/qmake.conf || die 304 mkspecs/$(qt_mkspecs_dir)/qmake.conf || die
360 305
361 base_src_prepare 306 # apply patches
307 [[ -n ${PATCHES[@]} ]] && epatch "${PATCHES[@]}"
308 epatch_user
362} 309}
363 310
364# @FUNCTION: qt4-build_src_configure 311# @FUNCTION: qt4-build_src_configure
365# @DESCRIPTION: 312# @DESCRIPTION:
366# Default configure phase 313# Default configure phase
372 -bindir ${QTBINDIR} 319 -bindir ${QTBINDIR}
373 -libdir ${QTLIBDIR} 320 -libdir ${QTLIBDIR}
374 -docdir ${QTDOCDIR} 321 -docdir ${QTDOCDIR}
375 -headerdir ${QTHEADERDIR} 322 -headerdir ${QTHEADERDIR}
376 -plugindir ${QTPLUGINDIR} 323 -plugindir ${QTPLUGINDIR}
377 $(version_is_at_least 4.7 && echo -importdir ${QTIMPORTDIR}) 324 -importdir ${QTIMPORTDIR}
378 -datadir ${QTDATADIR} 325 -datadir ${QTDATADIR}
379 -translationdir ${QTTRANSDIR} 326 -translationdir ${QTTRANSDIR}
380 -sysconfdir ${QTSYSCONFDIR} 327 -sysconfdir ${QTSYSCONFDIR}
381 -examplesdir ${QTEXAMPLESDIR} 328 -examplesdir ${QTEXAMPLESDIR}
382 -demosdir ${QTDEMOSDIR} 329 -demosdir ${QTDEMOSDIR}
411 conf+=" -no-separate-debug-info" 358 conf+=" -no-separate-debug-info"
412 359
413 # exceptions USE flag 360 # exceptions USE flag
414 conf+=" $(in_iuse exceptions && qt_use exceptions || echo -exceptions)" 361 conf+=" $(in_iuse exceptions && qt_use exceptions || echo -exceptions)"
415 362
416 # disable RPATH on Qt >= 4.8 (bug 380415) 363 # disable rpath (bug 380415), except on prefix (bug 417169)
417 version_is_at_least 4.8 && conf+=" -no-rpath" 364 use prefix || conf+=" -no-rpath"
418 365
419 # precompiled headers don't work on hardened, where the flag is masked 366 # precompiled headers don't work on hardened, where the flag is masked
420 conf+=" $(qt_use pch)" 367 conf+=" $(qt_use pch)"
421 368
422 # -reduce-relocations 369 # -reduce-relocations
435 if use_if_iuse glib; then 382 if use_if_iuse glib; then
436 local glibflags="$(pkg-config --cflags --libs glib-2.0 gthread-2.0)" 383 local glibflags="$(pkg-config --cflags --libs glib-2.0 gthread-2.0)"
437 # avoid the -pthread argument 384 # avoid the -pthread argument
438 conf+=" ${glibflags//-pthread}" 385 conf+=" ${glibflags//-pthread}"
439 unset glibflags 386 unset glibflags
440 fi
441
442 if use_if_iuse qpa; then
443 echo
444 ewarn "The qpa useflag enables the Qt Platform Abstraction, formely"
445 ewarn "known as Qt Lighthouse. If you are not sure what that is, then"
446 ewarn "disable it before reporting any bugs related to this useflag."
447 echo
448 conf+=" -qpa"
449 fi 387 fi
450 388
451 if use aqua; then 389 if use aqua; then
452 # On (snow) leopard use the new (frameworked) cocoa code. 390 # On (snow) leopard use the new (frameworked) cocoa code.
453 if [[ ${CHOST##*-darwin} -ge 9 ]]; then 391 if [[ ${CHOST##*-darwin} -ge 9 ]]; then
491# @FUNCTION: qt4-build_src_test 429# @FUNCTION: qt4-build_src_test
492# @DESCRIPTION: 430# @DESCRIPTION:
493# Runs tests only in target directories. 431# Runs tests only in target directories.
494qt4-build_src_test() { 432qt4-build_src_test() {
495 # QtMultimedia does not have any test suite (bug #332299) 433 # QtMultimedia does not have any test suite (bug #332299)
496 [[ ${PN} == qt-multimedia ]] && return 434 [[ ${CATEGORY}/${PN} == dev-qt/qtmultimedia ]] && return
497 435
498 for dir in ${QT4_TARGET_DIRECTORIES}; do 436 for dir in ${QT4_TARGET_DIRECTORIES}; do
499 emake -j1 check -C ${dir} 437 emake -j1 check -C ${dir}
500 done 438 done
501} 439}
545 483
546# @FUNCTION: qt4-build_src_install 484# @FUNCTION: qt4-build_src_install
547# @DESCRIPTION: 485# @DESCRIPTION:
548# Perform the actual installation including some library fixes. 486# Perform the actual installation including some library fixes.
549qt4-build_src_install() { 487qt4-build_src_install() {
550 [[ ${EAPI} == 2 ]] && use !prefix && ED=${D}
551 setqtenv 488 setqtenv
552 489
553 install_directories ${QT4_TARGET_DIRECTORIES} 490 install_directories ${QT4_TARGET_DIRECTORIES}
554 install_qconfigs 491 install_qconfigs
555 fix_library_files 492 fix_library_files
556 fix_includes 493 fix_includes
557 494
558 # remove .la files since we are building only shared Qt libraries 495 # remove .la files since we are building only shared libraries
559 find "${D}"${QTLIBDIR} -type f -name '*.la' -print0 | xargs -0 rm -f 496 prune_libtool_files
560} 497}
561 498
562# @FUNCTION: setqtenv 499# @FUNCTION: setqtenv
563# @INTERNAL 500# @INTERNAL
564setqtenv() { 501setqtenv() {
565 # Set up installation directories 502 # Set up installation directories
566 QTPREFIXDIR=${EPREFIX}/usr 503 QTPREFIXDIR=${EPREFIX}/usr
567 QTBINDIR=${EPREFIX}/usr/bin 504 QTBINDIR=${QTPREFIXDIR}/bin
568 QTLIBDIR=${EPREFIX}/usr/$(get_libdir)/qt4 505 QTLIBDIR=${QTPREFIXDIR}/$(get_libdir)/qt4
569 QTPCDIR=${EPREFIX}/usr/$(get_libdir)/pkgconfig 506 QTPCDIR=${QTPREFIXDIR}/$(get_libdir)/pkgconfig
570 QTDOCDIR=${EPREFIX}/usr/share/doc/qt-${PV} 507 QTDOCDIR=${QTPREFIXDIR}/share/doc/qt-${PV}
571 QTHEADERDIR=${EPREFIX}/usr/include/qt4 508 QTHEADERDIR=${QTPREFIXDIR}/include/qt4
572 QTPLUGINDIR=${QTLIBDIR}/plugins 509 QTPLUGINDIR=${QTLIBDIR}/plugins
573 QTIMPORTDIR=${QTLIBDIR}/imports 510 QTIMPORTDIR=${QTLIBDIR}/imports
574 QTDATADIR=${EPREFIX}/usr/share/qt4 511 QTDATADIR=${QTPREFIXDIR}/share/qt4
575 QTTRANSDIR=${QTDATADIR}/translations 512 QTTRANSDIR=${QTDATADIR}/translations
576 QTSYSCONFDIR=${EPREFIX}/etc/qt4 513 QTSYSCONFDIR=${EPREFIX}/etc/qt4
577 QTEXAMPLESDIR=${QTDATADIR}/examples 514 QTEXAMPLESDIR=${QTDATADIR}/examples
578 QTDEMOSDIR=${QTDATADIR}/demos 515 QTDEMOSDIR=${QTDATADIR}/demos
579 QMAKE_LIBDIR_QT=${QTLIBDIR} 516 QMAKE_LIBDIR_QT=${QTLIBDIR}
580 QT_INSTALL_PREFIX=${EPREFIX}/usr/$(get_libdir)/qt4
581 517
582 PLATFORM=$(qt_mkspecs_dir) 518 PLATFORM=$(qt_mkspecs_dir)
583 unset QMAKESPEC 519 unset QMAKESPEC
584 520
585 export XDG_CONFIG_HOME="${T}" 521 export XDG_CONFIG_HOME="${T}"
592# Generates Makefiles for the given list of directories. 528# Generates Makefiles for the given list of directories.
593prepare_directories() { 529prepare_directories() {
594 for x in "$@"; do 530 for x in "$@"; do
595 pushd "${S}"/${x} >/dev/null || die 531 pushd "${S}"/${x} >/dev/null || die
596 einfo "Running qmake in: ${x}" 532 einfo "Running qmake in: ${x}"
597 # avoid running over the maximum argument number, bug #299810 533 "${S}"/bin/qmake \
598 { 534 "LIBS+=-L${QTLIBDIR}" \
599 echo "${S}"/mkspecs/common/*.conf 535 "CONFIG+=nostrip" \
600 find "${S}" -name '*.pr[io]' 536 || die "qmake failed"
601 } | xargs sed -i \
602 -e "s:\$\$\[QT_INSTALL_LIBS\]:${QTLIBDIR}:g" \
603 -e "s:\$\$\[QT_INSTALL_PLUGINS\]:${QTPLUGINDIR}:g" \
604 || die
605 "${S}"/bin/qmake "LIBS+=-L${QTLIBDIR}" "CONFIG+=nostrip" || die "qmake failed"
606 popd >/dev/null || die 537 popd >/dev/null || die
607 done 538 done
608} 539}
609
610 540
611# @FUNCTION: build_directories 541# @FUNCTION: build_directories
612# @USAGE: < directories > 542# @USAGE: < directories >
613# @INTERNAL 543# @INTERNAL
614# @DESCRIPTION: 544# @DESCRIPTION:
615# Compiles the code in the given list of directories. 545# Compiles the code in the given list of directories.
616build_directories() { 546build_directories() {
617 for x in "$@"; do 547 for x in "$@"; do
618 pushd "${S}"/${x} >/dev/null || die 548 pushd "${S}"/${x} >/dev/null || die
549 emake \
550 AR="$(tc-getAR) cqs" \
619 emake CC="$(tc-getCC)" \ 551 CC="$(tc-getCC)" \
620 CXX="$(tc-getCXX)" \ 552 CXX="$(tc-getCXX)" \
621 LINK="$(tc-getCXX)" || die "emake failed" 553 LINK="$(tc-getCXX)" \
554 RANLIB=":" \
555 STRIP=":" \
556 || die "emake failed"
622 popd >/dev/null || die 557 popd >/dev/null || die
623 done 558 done
624} 559}
625 560
626# @FUNCTION: install_directories 561# @FUNCTION: install_directories
677# @FUNCTION: generate_qconfigs 612# @FUNCTION: generate_qconfigs
678# @INTERNAL 613# @INTERNAL
679# @DESCRIPTION: 614# @DESCRIPTION:
680# Generates gentoo-specific qconfig.{h,pri}. 615# Generates gentoo-specific qconfig.{h,pri}.
681generate_qconfigs() { 616generate_qconfigs() {
682 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} || -n ${QCONFIG_DEFINE} || ${PN} == qt-core ]]; then 617 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} || -n ${QCONFIG_DEFINE} || ${CATEGORY}/${PN} == dev-qt/qtcore ]]; then
683 local x qconfig_add qconfig_remove qconfig_new 618 local x qconfig_add qconfig_remove qconfig_new
684 for x in "${ROOT}${QTDATADIR}"/mkspecs/gentoo/*-qconfig.pri; do 619 for x in "${ROOT}${QTDATADIR}"/mkspecs/gentoo/*-qconfig.pri; do
685 [[ -f ${x} ]] || continue 620 [[ -f ${x} ]] || continue
686 qconfig_add+=" $(sed -n 's/^QCONFIG_ADD=//p' "${x}")" 621 qconfig_add+=" $(sed -n 's/^QCONFIG_ADD=//p' "${x}")"
687 qconfig_remove+=" $(sed -n 's/^QCONFIG_REMOVE=//p' "${x}")" 622 qconfig_remove+=" $(sed -n 's/^QCONFIG_REMOVE=//p' "${x}")"
688 done 623 done
689 624
690 # these error checks do not use die because dying in pkg_post{inst,rm} 625 # these error checks do not use die because dying in pkg_post{inst,rm}
691 # just makes things worse. 626 # just makes things worse.
692 if [[ -e "${ROOT}${QTDATADIR}"/mkspecs/gentoo/qconfig.pri ]]; then 627 if [[ -e "${ROOT}${QTDATADIR}"/mkspecs/gentoo/qconfig.pri ]]; then
693 # start with the qconfig.pri that qt-core installed 628 # start with the qconfig.pri that qtcore installed
694 if ! cp "${ROOT}${QTDATADIR}"/mkspecs/gentoo/qconfig.pri \ 629 if ! cp "${ROOT}${QTDATADIR}"/mkspecs/gentoo/qconfig.pri \
695 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri; then 630 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri; then
696 eerror "cp qconfig failed." 631 eerror "cp qconfig failed."
697 return 1 632 return 1
698 fi 633 fi
750} 685}
751 686
752# @FUNCTION: skip_qmake_build 687# @FUNCTION: skip_qmake_build
753# @INTERNAL 688# @INTERNAL
754# @DESCRIPTION: 689# @DESCRIPTION:
755# Patches configure to skip qmake compilation, as it's already installed by qt-core. 690# Patches configure to skip qmake compilation, as it's already installed by qtcore.
756skip_qmake_build() { 691skip_qmake_build() {
757 sed -i -e "s:if true:if false:g" "${S}"/configure || die 692 sed -i -e "s:if true:if false:g" "${S}"/configure || die
758} 693}
759 694
760# @FUNCTION: skip_project_generation 695# @FUNCTION: skip_project_generation
865 fi 800 fi
866 801
867 echo "${spec}" 802 echo "${spec}"
868} 803}
869 804
870# @FUNCTION: qt_assistant_cleanup
871# @INTERNAL
872# @DESCRIPTION:
873# Tries to clean up tools.pro for qt-assistant ebuilds.
874# Meant to be called in src_prepare().
875# Since Qt 4.7.4 this function is a no-op.
876qt_assistant_cleanup() {
877 # apply patching to qt-assistant ebuilds only
878 [[ ${PN} != qt-assistant ]] && return
879
880 # no longer needed for 4.7.4 and later
881 version_is_at_least 4.7.4 && return
882
883 # different versions (and branches...) may need different handling,
884 # add a case if you need special handling
885 case "${MY_PV_EXTRA}" in
886 *kde-qt*)
887 sed -e "/^[ \t]*porting/,/^[ \t]*win32.*activeqt$/d" \
888 -e "/mac/,/^embedded.*makeqpf$/d" \
889 -i tools/tools.pro || die "patching tools.pro failed"
890 ;;
891 *)
892 sed -e "/^[ \t]*porting/,/^[ \t]*win32.*activeqt$/d" \
893 -e "/mac/,/^embedded.*makeqpf$/d" \
894 -e "s/^\([ \t]*pixeltool\) /\1 qdoc3 /" \
895 -i tools/tools.pro || die "patching tools.pro failed"
896 ;;
897 esac
898}
899
900# @FUNCTION: qt_nolibx11 805# @FUNCTION: qt_nolibx11
901# @INTERNAL 806# @INTERNAL
902# @DESCRIPTION: 807# @DESCRIPTION:
903# Ignore X11 tests for packages that don't need X libraries installed. 808# Ignore X11 tests for packages that don't need X libraries installed.
904qt_nolibx11() { 809qt_nolibx11() {

Legend:
Removed from v.1.129  
changed lines
  Added in v.1.146

  ViewVC Help
Powered by ViewVC 1.1.20