/[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.139 Revision 1.159
1# Copyright 1999-2012 Gentoo Foundation 1# Copyright 1999-2015 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.139 2012/11/12 09:28:53 pesa Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/qt4-build.eclass,v 1.159 2015/03/06 14:08:07 dlan 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 3|4|5) : ;; 13 4|5) : ;;
14 *) die "qt4-build.eclass: unsupported EAPI=${EAPI:-0}" ;; 14 *) die "qt4-build.eclass: unsupported EAPI=${EAPI:-0}" ;;
15esac 15esac
16 16
17inherit eutils flag-o-matic multilib toolchain-funcs versionator 17inherit eutils flag-o-matic multilib toolchain-funcs
18 18
19if [[ ${PV} == *9999* ]]; then 19HOMEPAGE="https://www.qt.io/ https://qt-project.org/"
20 QT4_BUILD_TYPE="live"
21 inherit git-2
22else
23 QT4_BUILD_TYPE="release"
24fi
25
26HOMEPAGE="http://qt-project.org/ http://qt.digia.com/"
27LICENSE="|| ( LGPL-2.1 GPL-3 )" 20LICENSE="|| ( LGPL-2.1 GPL-3 )"
21SLOT="4"
28 22
29MY_PV=${PV/_/-} 23case ${PV} in
30MY_P=qt-everywhere-opensource-src-${MY_PV} 24 4.?.9999)
31 25 QT4_BUILD_TYPE="live"
32case ${QT4_BUILD_TYPE} in 26 EGIT_REPO_URI=(
33 live)
34 EGIT_REPO_URI="git://gitorious.org/qt/qt.git 27 "git://gitorious.org/qt/qt.git"
35 https://git.gitorious.org/qt/qt.git" 28 "https://git.gitorious.org/qt/qt.git"
29 )
36 EGIT_BRANCH=${PV%.9999} 30 EGIT_BRANCH=${PV%.9999}
31 inherit git-r3
37 ;; 32 ;;
38 release) 33 *)
39 if version_is_at_least 4.8.1; then 34 QT4_BUILD_TYPE="release"
40 SRC_URI="http://releases.qt-project.org/qt4/source/${MY_P}.tar.gz" 35 MY_P=qt-everywhere-opensource-src-${PV/_/-}
41 else 36 SRC_URI="http://download.qt.io/archive/qt/${PV%.*}/${PV}/${MY_P}.tar.gz"
42 SRC_URI="http://get.qt.nokia.com/qt/source/${MY_P}.tar.gz" 37 S=${WORKDIR}/${MY_P}
43 fi
44 ;; 38 ;;
45esac 39esac
46 40
47IUSE="aqua debug pch" 41IUSE="aqua debug pch"
48[[ ${CATEGORY}/${PN} != x11-libs/qt-xmlpatterns ]] && IUSE+=" +exceptions" 42[[ ${PN} != qtxmlpatterns ]] && IUSE+=" +exceptions"
49if version_is_at_least 4.8; then
50 [[ ${CATEGORY}/${PN} != x11-libs/qt-webkit ]] && IUSE+=" c++0x"
51 version_is_at_least 4.8.3 || IUSE+=" qpa"
52fi
53 43
54DEPEND="virtual/pkgconfig" 44DEPEND="virtual/pkgconfig"
55if [[ ${QT4_BUILD_TYPE} == live ]]; then 45if [[ ${QT4_BUILD_TYPE} == live ]]; then
56 DEPEND+=" dev-lang/perl" 46 DEPEND+=" dev-lang/perl"
57fi 47fi
58 48
59RDEPEND="
60 !<x11-libs/qt-assistant-${PV}:4
61 !>x11-libs/qt-assistant-${PV}-r9999:4
62 !<x11-libs/qt-bearer-${PV}:4
63 !>x11-libs/qt-bearer-${PV}-r9999:4
64 !<x11-libs/qt-core-${PV}:4
65 !>x11-libs/qt-core-${PV}-r9999:4
66 !<x11-libs/qt-dbus-${PV}:4
67 !>x11-libs/qt-dbus-${PV}-r9999:4
68 !<x11-libs/qt-declarative-${PV}:4
69 !>x11-libs/qt-declarative-${PV}-r9999:4
70 !<x11-libs/qt-demo-${PV}:4
71 !>x11-libs/qt-demo-${PV}-r9999:4
72 !<x11-libs/qt-gui-${PV}:4
73 !>x11-libs/qt-gui-${PV}-r9999:4
74 !<x11-libs/qt-multimedia-${PV}:4
75 !>x11-libs/qt-multimedia-${PV}-r9999:4
76 !<x11-libs/qt-opengl-${PV}:4
77 !>x11-libs/qt-opengl-${PV}-r9999:4
78 !<x11-libs/qt-openvg-${PV}:4
79 !>x11-libs/qt-openvg-${PV}-r9999:4
80 !<x11-libs/qt-phonon-${PV}:4
81 !>x11-libs/qt-phonon-${PV}-r9999:4
82 !<x11-libs/qt-qt3support-${PV}:4
83 !>x11-libs/qt-qt3support-${PV}-r9999:4
84 !<x11-libs/qt-script-${PV}:4
85 !>x11-libs/qt-script-${PV}-r9999:4
86 !<x11-libs/qt-sql-${PV}:4
87 !>x11-libs/qt-sql-${PV}-r9999:4
88 !<x11-libs/qt-svg-${PV}:4
89 !>x11-libs/qt-svg-${PV}-r9999:4
90 !<x11-libs/qt-test-${PV}:4
91 !>x11-libs/qt-test-${PV}-r9999:4
92 !<x11-libs/qt-webkit-${PV}:4
93 !>x11-libs/qt-webkit-${PV}-r9999:4
94 !<x11-libs/qt-xmlpatterns-${PV}:4
95 !>x11-libs/qt-xmlpatterns-${PV}-r9999:4
96"
97
98S=${WORKDIR}/${MY_P}
99
100# @FUNCTION: qt4-build_pkg_setup 49# @FUNCTION: qt4-build_pkg_setup
101# @DESCRIPTION: 50# @DESCRIPTION:
102# Sets up PATH and LD_LIBRARY_PATH. 51# Sets up PATH and LD_LIBRARY_PATH.
103qt4-build_pkg_setup() { 52qt4-build_pkg_setup() {
104 # Protect users by not allowing downgrades between releases. 53 # Warn users of possible breakage when downgrading to a previous release.
105 # Downgrading revisions within the same release should be allowed. 54 # Downgrading revisions within the same release is safe.
106 if has_version ">${CATEGORY}/${P}-r9999:4"; then 55 if has_version ">${CATEGORY}/${P}-r9999:4"; then
107 if [[ -z ${I_KNOW_WHAT_I_AM_DOING} ]]; then 56 ewarn
108 eerror " *** Sanity check to keep you from breaking your system ***"
109 eerror "Downgrading Qt is completely unsupported and will break your system!"
110 die "aborting to save your system"
111 else
112 ewarn "Downgrading Qt is completely unsupported and will break your system!" 57 ewarn "Downgrading Qt is completely unsupported and can break your system!"
113 fi 58 ewarn
114 fi 59 fi
115 60
116 PATH="${S}/bin${PATH:+:}${PATH}" 61 PATH="${S}/bin${PATH:+:}${PATH}"
117 if [[ ${CHOST} != *-darwin* ]]; then 62 if [[ ${CHOST} != *-darwin* ]]; then
118 LD_LIBRARY_PATH="${S}/lib${LD_LIBRARY_PATH:+:}${LD_LIBRARY_PATH}" 63 LD_LIBRARY_PATH="${S}/lib${LD_LIBRARY_PATH:+:}${LD_LIBRARY_PATH}"
125 QT4_EXTRACT_DIRECTORIES="src/gui/kernel/qapplication_mac.mm 70 QT4_EXTRACT_DIRECTORIES="src/gui/kernel/qapplication_mac.mm
126 ${QT4_EXTRACT_DIRECTORIES}" 71 ${QT4_EXTRACT_DIRECTORIES}"
127 fi 72 fi
128} 73}
129 74
75# @ECLASS-VARIABLE: PATCHES
76# @DEFAULT_UNSET
77# @DESCRIPTION:
78# Array variable containing all the patches to be applied. This variable
79# is expected to be defined in the global scope of ebuilds. Make sure to
80# specify the full path. This variable is used in src_prepare phase.
81#
82# Example:
83# @CODE
84# PATCHES=(
85# "${FILESDIR}/mypatch.patch"
86# "${FILESDIR}/patches_folder/"
87# )
88# @CODE
89
130# @ECLASS-VARIABLE: QT4_EXTRACT_DIRECTORIES 90# @ECLASS-VARIABLE: QT4_EXTRACT_DIRECTORIES
131# @DEFAULT_UNSET 91# @DEFAULT_UNSET
132# @DESCRIPTION: 92# @DESCRIPTION:
133# Space-separated list including the directories that will be extracted from 93# Space-separated list of directories that will be extracted
134# Qt tarball. 94# from Qt tarball.
135 95
136# @ECLASS-VARIABLE: QT4_TARGET_DIRECTORIES 96# @ECLASS-VARIABLE: QT4_TARGET_DIRECTORIES
137# @DEFAULT_UNSET 97# @DEFAULT_UNSET
138# @DESCRIPTION: 98# @DESCRIPTION:
139# Arguments for build_target_directories. Takes the directories in which the 99# Space-separated list of directories that will be configured,
140# code should be compiled. This is a space-separated list. 100# compiled, and installed. All paths must be relative to ${S}.
141 101
142# @FUNCTION: qt4-build_src_unpack 102# @FUNCTION: qt4-build_src_unpack
143# @DESCRIPTION: 103# @DESCRIPTION:
144# Unpacks the sources. 104# Unpacks the sources.
145qt4-build_src_unpack() { 105qt4-build_src_unpack() {
146 setqtenv 106 setqtenv
147 107
148 if ! version_is_at_least 4.1 $(gcc-version); then 108 if [[ $(gcc-major-version) -lt 4 ]] || [[ $(gcc-major-version) -eq 4 && $(gcc-minor-version) -lt 4 ]]; then
109 ewarn
149 ewarn "Using a GCC version lower than 4.1 is not supported." 110 ewarn "Using a GCC version lower than 4.4 is not supported."
111 ewarn
150 fi 112 fi
151 113
152 if [[ ${PN} == qt-webkit ]]; then 114 if [[ ${PN} == qtwebkit ]]; then
153 eshopts_push -s extglob 115 eshopts_push -s extglob
154 if is-flagq '-g?(gdb)?([1-9])'; then 116 if is-flagq '-g?(gdb)?([1-9])'; then
155 echo 117 ewarn
156 ewarn "You have enabled debug info (probably have -g or -ggdb in your CFLAGS/CXXFLAGS)." 118 ewarn "You have enabled debug info (probably have -g or -ggdb in your CFLAGS/CXXFLAGS)."
157 ewarn "You may experience really long compilation times and/or increased memory usage." 119 ewarn "You may experience really long compilation times and/or increased memory usage."
158 ewarn "If compilation fails, please try removing -g/-ggdb before reporting a bug." 120 ewarn "If compilation fails, please try removing -g/-ggdb before reporting a bug."
159 ewarn "For more info check out https://bugs.gentoo.org/307861" 121 ewarn "For more info check out https://bugs.gentoo.org/307861"
160 echo 122 ewarn
161 fi 123 fi
162 eshopts_pop 124 eshopts_pop
163 fi 125 fi
164 126
165 case ${QT4_BUILD_TYPE} in 127 case ${QT4_BUILD_TYPE} in
166 live) 128 live)
167 git-2_src_unpack 129 git-r3_src_unpack
168 ;; 130 ;;
169 release) 131 release)
170 local tarball="${MY_P}.tar.gz" target= targets= 132 local tarball="${MY_P}.tar.gz" target= targets=
171 for target in configure LICENSE.GPL3 LICENSE.LGPL projects.pro \ 133 for target in configure LICENSE.GPL3 LICENSE.LGPL projects.pro \
172 src/{qbase,qt_targets,qt_install}.pri bin config.tests \ 134 src/{qbase,qt_targets,qt_install}.pri bin config.tests \
180 eend $? || die "failed to unpack" 142 eend $? || die "failed to unpack"
181 ;; 143 ;;
182 esac 144 esac
183} 145}
184 146
185# @ECLASS-VARIABLE: PATCHES
186# @DEFAULT_UNSET
187# @DESCRIPTION:
188# PATCHES array variable containing all various patches to be applied.
189# This variable is expected to be defined in global scope of ebuild.
190# Make sure to specify the full path. This variable is utilised in
191# src_prepare() phase.
192#
193# @CODE
194# PATCHES=( "${FILESDIR}/mypatch.patch"
195# "${FILESDIR}/patches_folder/" )
196# @CODE
197
198# @FUNCTION: qt4-build_src_prepare 147# @FUNCTION: qt4-build_src_prepare
199# @DESCRIPTION: 148# @DESCRIPTION:
200# Prepare the sources before the configure phase. Strip CFLAGS if necessary, and fix 149# Prepare the sources before the configure phase. Strip CFLAGS if necessary, and fix
201# the build system in order to respect CFLAGS/CXXFLAGS/LDFLAGS specified in /etc/make.conf. 150# the build system in order to respect CFLAGS/CXXFLAGS/LDFLAGS specified in make.conf.
202qt4-build_src_prepare() { 151qt4-build_src_prepare() {
203 setqtenv 152 setqtenv
204 153
205 if [[ ${QT4_BUILD_TYPE} == live ]]; then 154 if [[ ${QT4_BUILD_TYPE} == live ]]; then
206 QTDIR="." ./bin/syncqt || die "syncqt failed" 155 QTDIR="." ./bin/syncqt || die "syncqt failed"
207 fi 156 fi
208 157
209 # avoid X11 dependency in non-gui packages 158 # avoid X11 dependency in non-gui packages
210 local nolibx11_pkgs="qt-core qt-dbus qt-script qt-sql qt-test qt-xmlpatterns" 159 local nolibx11_pkgs="qtbearer qtcore qtdbus qtscript qtsql qttest qtxmlpatterns"
211 has ${PN} ${nolibx11_pkgs} && qt_nolibx11 160 has ${PN} ${nolibx11_pkgs} && qt_nolibx11
212 161
213 if use aqua; then 162 if use aqua; then
214 # provide a proper macx-g++-64 163 # provide a proper macx-g++-64
215 use x64-macos && ln -s macx-g++ mkspecs/$(qt_mkspecs_dir) 164 use x64-macos && ln -s macx-g++ mkspecs/$(qt_mkspecs_dir)
217 sed -e '/^CONFIG/s:app_bundle::' \ 166 sed -e '/^CONFIG/s:app_bundle::' \
218 -e '/^CONFIG/s:plugin_no_soname:plugin_with_soname absolute_library_soname:' \ 167 -e '/^CONFIG/s:plugin_no_soname:plugin_with_soname absolute_library_soname:' \
219 -i mkspecs/$(qt_mkspecs_dir)/qmake.conf || die 168 -i mkspecs/$(qt_mkspecs_dir)/qmake.conf || die
220 fi 169 fi
221 170
222 if [[ ${PN} != qt-core ]]; then 171 if [[ ${CATEGORY}/${PN} != dev-qt/qtcore ]]; then
223 skip_qmake_build 172 skip_qmake_build
224 skip_project_generation 173 skip_project_generation
225 symlink_binaries_to_buildtree 174 symlink_binaries_to_buildtree
226 fi 175 fi
227 176
228 if [[ ${CHOST} == *86*-apple-darwin* ]]; then
229 # qmake bus errors with -O2 or -O3 but -O1 works
230 # Bug 373061
231 replace-flags -O[23] -O1
232 fi
233
234 # Bug 178652
235 if [[ $(gcc-major-version) == 3 ]] && use amd64; then
236 ewarn "Appending -fno-gcse to CFLAGS/CXXFLAGS"
237 append-flags -fno-gcse
238 fi
239
240 if use_if_iuse c++0x; then 177 if use_if_iuse c++0x; then
241 append-cxxflags -std=c++0x 178 append-cxxflags -std=c++0x
242 fi 179 fi
243 180
244 # Unsupported old gcc versions - hardened needs this :(
245 if [[ $(gcc-major-version) -lt 4 ]]; then
246 ewarn "Appending -fno-stack-protector to CXXFLAGS"
247 append-cxxflags -fno-stack-protector
248 # Bug 253127
249 sed -e "/^QMAKE_CFLAGS\t/ s:$: -fno-stack-protector-all:" \
250 -i mkspecs/common/g++.conf || die
251 fi
252
253 # Bug 261632 181 # Bug 261632
254 if use ppc64; then 182 if use ppc64; then
255 ewarn "Appending -mminimal-toc to CFLAGS/CXXFLAGS"
256 append-flags -mminimal-toc 183 append-flags -mminimal-toc
184 fi
185
186 # Bug 373061
187 # qmake bus errors with -O2 or -O3 but -O1 works
188 if [[ ${CHOST} == *86*-apple-darwin* ]]; then
189 replace-flags -O[23] -O1
190 fi
191
192 # Bug 417105
193 # graphite on gcc 4.7 causes miscompilations
194 if [[ $(gcc-version) == "4.7" ]]; then
195 filter-flags -fgraphite-identity
257 fi 196 fi
258 197
259 # Respect CC, CXX, {C,CXX,LD}FLAGS in .qmake.cache 198 # Respect CC, CXX, {C,CXX,LD}FLAGS in .qmake.cache
260 sed -e "/^SYSTEM_VARIABLES=/i \ 199 sed -e "/^SYSTEM_VARIABLES=/i \
261 CC='$(tc-getCC)'\n\ 200 CC='$(tc-getCC)'\n\
272 -i configure \ 211 -i configure \
273 || die "sed SYSTEM_VARIABLES failed" 212 || die "sed SYSTEM_VARIABLES failed"
274 213
275 # Respect CC, CXX, LINK and *FLAGS in config.tests 214 # Respect CC, CXX, LINK and *FLAGS in config.tests
276 find config.tests/unix -name '*.test' -type f -print0 | xargs -0 \ 215 find config.tests/unix -name '*.test' -type f -print0 | xargs -0 \
277 sed -i -e "/bin\/qmake/ s: \"QT_BUILD_TREE=: \ 216 sed -i -e "/bin\/qmake/ s: \"\$SRCDIR/: \
278 'QMAKE_CC=$(tc-getCC)' 'QMAKE_CXX=$(tc-getCXX)' 'QMAKE_LINK=$(tc-getCXX)' \ 217 'QMAKE_CC=$(tc-getCC)' 'QMAKE_CXX=$(tc-getCXX)' 'QMAKE_LINK=$(tc-getCXX)' \
279 'QMAKE_CFLAGS+=${CFLAGS}' 'QMAKE_CXXFLAGS+=${CXXFLAGS}' 'QMAKE_LFLAGS+=${LDFLAGS}'&:" \ 218 'QMAKE_CFLAGS+=${CFLAGS}' 'QMAKE_CXXFLAGS+=${CXXFLAGS}' 'QMAKE_LFLAGS+=${LDFLAGS}'&:" \
280 || die "sed config.tests failed" 219 || die "sed config.tests failed"
281
282 if ! version_is_at_least 4.8; then
283 # Strip predefined CFLAGS from mkspecs (bugs 312689 and 352778)
284 sed -i -e '/^QMAKE_CFLAGS_RELEASE/s:+=.*:+=:' mkspecs/common/g++.conf || die
285 fi
286 220
287 # Bug 172219 221 # Bug 172219
288 sed -e 's:/X11R6/:/:' -i mkspecs/$(qt_mkspecs_dir)/qmake.conf || die 222 sed -e 's:/X11R6/:/:' -i mkspecs/$(qt_mkspecs_dir)/qmake.conf || die
289 223
290 if [[ ${CHOST} == *-darwin* ]]; then 224 if [[ ${CHOST} == *-darwin* ]]; then
389 ppc-macos) conf+=" -arch ppc" ;; 323 ppc-macos) conf+=" -arch ppc" ;;
390 ppc|ppc64|ppc-*) conf+=" -arch powerpc" ;; 324 ppc|ppc64|ppc-*) conf+=" -arch powerpc" ;;
391 sparc|sparc-*|sparc64-*) conf+=" -arch sparc" ;; 325 sparc|sparc-*|sparc64-*) conf+=" -arch sparc" ;;
392 x86-macos) conf+=" -arch x86" ;; 326 x86-macos) conf+=" -arch x86" ;;
393 x86|x86-*) conf+=" -arch i386" ;; 327 x86|x86-*) conf+=" -arch i386" ;;
394 alpha|arm|ia64|mips|s390) conf+=" -arch $(tc-arch)" ;; 328 alpha|arm|arm64|ia64|mips|s390) conf+=" -arch $(tc-arch)" ;;
395 hppa|sh) conf+=" -arch generic" ;; 329 hppa|sh) conf+=" -arch generic" ;;
396 *) die "$(tc-arch) is unsupported by this eclass. Please file a bug." ;; 330 *) die "$(tc-arch) is unsupported by this eclass. Please file a bug." ;;
397 esac 331 esac
398 332
399 conf+=" -platform $(qt_mkspecs_dir)" 333 conf+=" -platform $(qt_mkspecs_dir)"
409 conf+=" -no-separate-debug-info" 343 conf+=" -no-separate-debug-info"
410 344
411 # exceptions USE flag 345 # exceptions USE flag
412 conf+=" $(in_iuse exceptions && qt_use exceptions || echo -exceptions)" 346 conf+=" $(in_iuse exceptions && qt_use exceptions || echo -exceptions)"
413 347
414 # disable rpath on Qt >= 4.8 (bug 380415) 348 # disable rpath (bug 380415), except on prefix (bug 417169)
415 # but leave it enabled on prefix (bug 417169) 349 use prefix || conf+=" -no-rpath"
416 version_is_at_least 4.8 && use !prefix && conf+=" -no-rpath"
417 350
418 # precompiled headers don't work on hardened, where the flag is masked 351 # precompiled headers don't work on hardened, where the flag is masked
419 conf+=" $(qt_use pch)" 352 conf+=" $(qt_use pch)"
420 353
421 # -reduce-relocations 354 # -reduce-relocations
434 if use_if_iuse glib; then 367 if use_if_iuse glib; then
435 local glibflags="$(pkg-config --cflags --libs glib-2.0 gthread-2.0)" 368 local glibflags="$(pkg-config --cflags --libs glib-2.0 gthread-2.0)"
436 # avoid the -pthread argument 369 # avoid the -pthread argument
437 conf+=" ${glibflags//-pthread}" 370 conf+=" ${glibflags//-pthread}"
438 unset glibflags 371 unset glibflags
439 fi
440
441 if use_if_iuse qpa; then
442 echo
443 ewarn "The qpa useflag enables the Qt Platform Abstraction, formely"
444 ewarn "known as Qt Lighthouse. If you are not sure what that is, then"
445 ewarn "disable it before reporting any bugs related to this useflag."
446 echo
447 conf+=" -qpa"
448 fi 372 fi
449 373
450 if use aqua; then 374 if use aqua; then
451 # On (snow) leopard use the new (frameworked) cocoa code. 375 # On (snow) leopard use the new (frameworked) cocoa code.
452 if [[ ${CHOST##*-darwin} -ge 9 ]]; then 376 if [[ ${CHOST##*-darwin} -ge 9 ]]; then
490# @FUNCTION: qt4-build_src_test 414# @FUNCTION: qt4-build_src_test
491# @DESCRIPTION: 415# @DESCRIPTION:
492# Runs tests only in target directories. 416# Runs tests only in target directories.
493qt4-build_src_test() { 417qt4-build_src_test() {
494 # QtMultimedia does not have any test suite (bug #332299) 418 # QtMultimedia does not have any test suite (bug #332299)
495 [[ ${PN} == qt-multimedia ]] && return 419 [[ ${CATEGORY}/${PN} == dev-qt/qtmultimedia ]] && return
496 420
497 for dir in ${QT4_TARGET_DIRECTORIES}; do 421 for dir in ${QT4_TARGET_DIRECTORIES}; do
498 emake -j1 check -C ${dir} 422 emake -j1 check -C ${dir}
499 done 423 done
500} 424}
586# @USAGE: < directories > 510# @USAGE: < directories >
587# @INTERNAL 511# @INTERNAL
588# @DESCRIPTION: 512# @DESCRIPTION:
589# Generates Makefiles for the given list of directories. 513# Generates Makefiles for the given list of directories.
590prepare_directories() { 514prepare_directories() {
591 # avoid running over the maximum argument number, bug #299810
592 {
593 echo "${S}"/mkspecs/common/*.conf
594 find "${S}" -name '*.pr[io]'
595 } | xargs sed -i \
596 -e "s:\$\$\[QT_INSTALL_LIBS\]:${QTLIBDIR}:g" \
597 -e "s:\$\$\[QT_INSTALL_PLUGINS\]:${QTPLUGINDIR}:g" \
598 || die
599
600 for x in "$@"; do 515 for x in "$@"; do
601 pushd "${S}"/${x} >/dev/null || die 516 pushd "${S}"/${x} >/dev/null || die
602 einfo "Running qmake in: ${x}" 517 einfo "Running qmake in: ${x}"
603 "${S}"/bin/qmake \ 518 "${S}"/bin/qmake \
604 "LIBS+=-L${QTLIBDIR}" \ 519 "LIBS+=-L${QTLIBDIR}" \
620 AR="$(tc-getAR) cqs" \ 535 AR="$(tc-getAR) cqs" \
621 CC="$(tc-getCC)" \ 536 CC="$(tc-getCC)" \
622 CXX="$(tc-getCXX)" \ 537 CXX="$(tc-getCXX)" \
623 LINK="$(tc-getCXX)" \ 538 LINK="$(tc-getCXX)" \
624 RANLIB=":" \ 539 RANLIB=":" \
625 STRIP=":" \ 540 STRIP=":"
626 || die "emake failed"
627 popd >/dev/null || die 541 popd >/dev/null || die
628 done 542 done
629} 543}
630 544
631# @FUNCTION: install_directories 545# @FUNCTION: install_directories
634# @DESCRIPTION: 548# @DESCRIPTION:
635# Runs emake install in the given directories, which are separated by spaces. 549# Runs emake install in the given directories, which are separated by spaces.
636install_directories() { 550install_directories() {
637 for x in "$@"; do 551 for x in "$@"; do
638 pushd "${S}"/${x} >/dev/null || die 552 pushd "${S}"/${x} >/dev/null || die
639 emake INSTALL_ROOT="${D}" install || die "emake install failed" 553 emake INSTALL_ROOT="${D}" install
640 popd >/dev/null || die 554 popd >/dev/null || die
641 done 555 done
642} 556}
643 557
644# @ECLASS-VARIABLE: QCONFIG_ADD 558# @ECLASS-VARIABLE: QCONFIG_ADD
665 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} ]]; then 579 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} ]]; then
666 for x in QCONFIG_ADD QCONFIG_REMOVE; do 580 for x in QCONFIG_ADD QCONFIG_REMOVE; do
667 [[ -n ${!x} ]] && echo ${x}=${!x} >> "${T}"/${PN}-qconfig.pri 581 [[ -n ${!x} ]] && echo ${x}=${!x} >> "${T}"/${PN}-qconfig.pri
668 done 582 done
669 insinto ${QTDATADIR#${EPREFIX}}/mkspecs/gentoo 583 insinto ${QTDATADIR#${EPREFIX}}/mkspecs/gentoo
670 doins "${T}"/${PN}-qconfig.pri || die "installing ${PN}-qconfig.pri failed" 584 doins "${T}"/${PN}-qconfig.pri
671 fi 585 fi
672 586
673 if [[ -n ${QCONFIG_DEFINE} ]]; then 587 if [[ -n ${QCONFIG_DEFINE} ]]; then
674 for x in ${QCONFIG_DEFINE}; do 588 for x in ${QCONFIG_DEFINE}; do
675 echo "#define ${x}" >> "${T}"/gentoo-${PN}-qconfig.h 589 echo "#define ${x}" >> "${T}"/gentoo-${PN}-qconfig.h
676 done 590 done
677 insinto ${QTHEADERDIR#${EPREFIX}}/Gentoo 591 insinto ${QTHEADERDIR#${EPREFIX}}/Gentoo
678 doins "${T}"/gentoo-${PN}-qconfig.h || die "installing ${PN}-qconfig.h failed" 592 doins "${T}"/gentoo-${PN}-qconfig.h
679 fi 593 fi
680} 594}
681 595
682# @FUNCTION: generate_qconfigs 596# @FUNCTION: generate_qconfigs
683# @INTERNAL 597# @INTERNAL
684# @DESCRIPTION: 598# @DESCRIPTION:
685# Generates gentoo-specific qconfig.{h,pri}. 599# Generates gentoo-specific qconfig.{h,pri}.
686generate_qconfigs() { 600generate_qconfigs() {
687 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} || -n ${QCONFIG_DEFINE} || ${PN} == qt-core ]]; then 601 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} || -n ${QCONFIG_DEFINE} || ${CATEGORY}/${PN} == dev-qt/qtcore ]]; then
688 local x qconfig_add qconfig_remove qconfig_new 602 local x qconfig_add qconfig_remove qconfig_new
689 for x in "${ROOT}${QTDATADIR}"/mkspecs/gentoo/*-qconfig.pri; do 603 for x in "${ROOT}${QTDATADIR}"/mkspecs/gentoo/*-qconfig.pri; do
690 [[ -f ${x} ]] || continue 604 [[ -f ${x} ]] || continue
691 qconfig_add+=" $(sed -n 's/^QCONFIG_ADD=//p' "${x}")" 605 qconfig_add+=" $(sed -n 's/^QCONFIG_ADD=//p' "${x}")"
692 qconfig_remove+=" $(sed -n 's/^QCONFIG_REMOVE=//p' "${x}")" 606 qconfig_remove+=" $(sed -n 's/^QCONFIG_REMOVE=//p' "${x}")"
693 done 607 done
694 608
695 # these error checks do not use die because dying in pkg_post{inst,rm} 609 # these error checks do not use die because dying in pkg_post{inst,rm}
696 # just makes things worse. 610 # just makes things worse.
697 if [[ -e "${ROOT}${QTDATADIR}"/mkspecs/gentoo/qconfig.pri ]]; then 611 if [[ -e "${ROOT}${QTDATADIR}"/mkspecs/gentoo/qconfig.pri ]]; then
698 # start with the qconfig.pri that qt-core installed 612 # start with the qconfig.pri that qtcore installed
699 if ! cp "${ROOT}${QTDATADIR}"/mkspecs/gentoo/qconfig.pri \ 613 if ! cp "${ROOT}${QTDATADIR}"/mkspecs/gentoo/qconfig.pri \
700 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri; then 614 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri; then
701 eerror "cp qconfig failed." 615 eerror "cp qconfig failed."
702 return 1 616 return 1
703 fi 617 fi
755} 669}
756 670
757# @FUNCTION: skip_qmake_build 671# @FUNCTION: skip_qmake_build
758# @INTERNAL 672# @INTERNAL
759# @DESCRIPTION: 673# @DESCRIPTION:
760# Patches configure to skip qmake compilation, as it's already installed by qt-core. 674# Patches configure to skip qmake compilation, as it's already installed by qtcore.
761skip_qmake_build() { 675skip_qmake_build() {
762 sed -i -e "s:if true:if false:g" "${S}"/configure || die 676 sed -i -e "s:if true:if false:g" "${S}"/configure || die
763} 677}
764 678
765# @FUNCTION: skip_project_generation 679# @FUNCTION: skip_project_generation
873} 787}
874 788
875# @FUNCTION: qt_nolibx11 789# @FUNCTION: qt_nolibx11
876# @INTERNAL 790# @INTERNAL
877# @DESCRIPTION: 791# @DESCRIPTION:
878# Ignore X11 tests for packages that don't need X libraries installed. 792# Skip X11 tests for packages that don't need X libraries installed.
879qt_nolibx11() { 793qt_nolibx11() {
880 sed -i "/unixtests\/compile.test.*config.tests\/x11\/xlib/,/fi$/d" "${S}"/configure || 794 sed -i -e '/^if.*PLATFORM_X11.*CFG_GUI/,/^fi$/d' "${S}"/configure || die
881 die "x11 check sed failed"
882} 795}
883 796
884EXPORT_FUNCTIONS pkg_setup src_unpack src_prepare src_configure src_compile src_install src_test pkg_postrm pkg_postinst 797EXPORT_FUNCTIONS pkg_setup src_unpack src_prepare src_configure src_compile src_install src_test pkg_postrm pkg_postinst

Legend:
Removed from v.1.139  
changed lines
  Added in v.1.159

  ViewVC Help
Powered by ViewVC 1.1.20