/[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.66 Revision 1.100
1# Copyright 1999-2009 Gentoo Foundation 1# Copyright 1999-2011 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.66 2010/03/24 14:36:28 yngwin Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/qt4-build.eclass,v 1.100 2011/11/19 20:31:12 pesa 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# Qt herd <qt@gentoo.org>
8# Markos Chandras <hwoarang@gentoo.org>,
9# Caleb Tennis <caleb@gentoo.org>
10# Alex Alexander <wired@gentoo.org>
11# @BLURB: Eclass for Qt4 split ebuilds. 8# @BLURB: Eclass for Qt4 split ebuilds.
12# @DESCRIPTION: 9# @DESCRIPTION:
13# This eclass contains various functions that are used when building Qt4 10# This eclass contains various functions that are used when building Qt4.
14 11
15inherit base eutils multilib toolchain-funcs flag-o-matic versionator 12inherit base eutils multilib toolchain-funcs flag-o-matic versionator
16 13
17MY_PV=${PV/_/-} 14MY_PV=${PV/_/-}
18if version_is_at_least 4.5.99999999; then
19 MY_P=qt-everywhere-opensource-src-${MY_PV} 15MY_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 16
25HOMEPAGE="http://qt.nokia.com/" 17HOMEPAGE="http://qt.nokia.com/"
26SRC_URI="http://get.qt.nokia.com/qt/source/${MY_P}.tar.gz" 18SRC_URI="http://get.qt.nokia.com/qt/source/${MY_P}.tar.gz"
27
28LICENSE="|| ( LGPL-2.1 GPL-3 )" 19LICENSE="|| ( LGPL-2.1 GPL-3 )"
20
29IUSE+=" debug pch aqua" 21IUSE="aqua debug pch"
22
23[[ ${CATEGORY}/${PN} != x11-libs/qt-xmlpatterns ]] &&
24[[ ${CATEGORY}/${PN} != x11-themes/qgtkstyle ]] &&
25 IUSE+=" +exceptions"
26
27if version_is_at_least 4.7.99999999; then
28 IUSE+=" c++0x qpa"
29fi
30 30
31RDEPEND=" 31RDEPEND="
32 !<x11-libs/qt-assistant-${PV} 32 !<x11-libs/qt-assistant-${PV}
33 !>x11-libs/qt-assistant-${PV}-r9999 33 !>x11-libs/qt-assistant-${PV}-r9999
34 !<x11-libs/qt-core-${PV} 34 !<x11-libs/qt-core-${PV}
35 !>x11-libs/qt-core-${PV}-r9999 35 !>x11-libs/qt-core-${PV}-r9999
36 !<x11-libs/qt-dbus-${PV} 36 !<x11-libs/qt-dbus-${PV}
37 !>x11-libs/qt-dbus-${PV}-r9999 37 !>x11-libs/qt-dbus-${PV}-r9999
38 !<x11-libs/qt-declarative-${PV}
39 !>x11-libs/qt-declarative-${PV}-r9999
38 !<x11-libs/qt-demo-${PV} 40 !<x11-libs/qt-demo-${PV}
39 !>x11-libs/qt-demo-${PV}-r9999 41 !>x11-libs/qt-demo-${PV}-r9999
40 !<x11-libs/qt-gui-${PV} 42 !<x11-libs/qt-gui-${PV}
41 !>x11-libs/qt-gui-${PV}-r9999 43 !>x11-libs/qt-gui-${PV}-r9999
42 !<x11-libs/qt-multimedia-${PV} 44 !<x11-libs/qt-multimedia-${PV}
69qt4-build_pkg_setup() { 71qt4-build_pkg_setup() {
70 [[ ${EAPI} == 2 ]] && use !prefix && EPREFIX= 72 [[ ${EAPI} == 2 ]] && use !prefix && EPREFIX=
71 73
72 # Protect users by not allowing downgrades between releases 74 # Protect users by not allowing downgrades between releases
73 # Downgrading revisions within the same release should be allowed 75 # Downgrading revisions within the same release should be allowed
74 if has_version '>'${CATEGORY}/${P}-r9999 ; then 76 if has_version '>'${CATEGORY}/${P}-r9999; then
75 if [[ -z $I_KNOW_WHAT_I_AM_DOING ]] ; then 77 if [[ -z ${I_KNOW_WHAT_I_AM_DOING} ]]; then
76 eerror "Sanity check to keep you from breaking your system:" 78 eerror "Sanity check to keep you from breaking your system:"
77 eerror " Downgrading Qt is completely unsupported and will break your system!" 79 eerror " Downgrading Qt is completely unsupported and will break your system!"
78 die "aborting to save your system" 80 die "aborting to save your system"
79 else 81 else
80 ewarn "Downgrading Qt is completely unsupported and will break your system!" 82 ewarn "Downgrading Qt is completely unsupported and will break your system!"
81 fi 83 fi
84 fi
85
86 if [[ ${PN} == "qt-webkit" ]]; then
87 eshopts_push -s extglob
88 if is-flagq '-g?(gdb)?([1-9])'; then
89 echo
90 ewarn "You have enabled debug info (probably have -g or -ggdb in your \$C{,XX}FLAGS)."
91 ewarn "You may experience really long compilation times and/or increased memory usage."
92 ewarn "If compilation fails, please try removing -g{,gdb} before reporting a bug."
93 ewarn "For more info check out bug #307861"
94 echo
95 fi
96 eshopts_pop
82 fi 97 fi
83 98
84 PATH="${S}/bin${PATH:+:}${PATH}" 99 PATH="${S}/bin${PATH:+:}${PATH}"
85 if [[ ${CHOST} != *-darwin* ]]; then 100 if [[ ${CHOST} != *-darwin* ]]; then
86 LD_LIBRARY_PATH="${S}/lib${LD_LIBRARY_PATH:+:}${LD_LIBRARY_PATH}" 101 LD_LIBRARY_PATH="${S}/lib${LD_LIBRARY_PATH:+:}${LD_LIBRARY_PATH}"
120# @FUNCTION: qt4-build_src_unpack 135# @FUNCTION: qt4-build_src_unpack
121# @DESCRIPTION: 136# @DESCRIPTION:
122# Unpacks the sources 137# Unpacks the sources
123qt4-build_src_unpack() { 138qt4-build_src_unpack() {
124 setqtenv 139 setqtenv
140 local unpack_p="${MY_P}"
141 case "${PV}" in
142 4.8.0_*)
143 unpack_p="qt-everywhere-opensource-src-${PV/_*}"
144 ;;
145 esac
125 local target targets= 146 local target targets=
126 for target in configure LICENSE.GPL3 LICENSE.LGPL projects.pro \ 147 for target in configure LICENSE.GPL3 LICENSE.LGPL projects.pro \
127 src/{qbase,qt_targets,qt_install}.pri bin config.tests mkspecs qmake \ 148 src/{qbase,qt_targets,qt_install}.pri bin config.tests mkspecs qmake \
128 ${QT4_EXTRACT_DIRECTORIES}; do 149 ${QT4_EXTRACT_DIRECTORIES}; do
129 targets+=" ${MY_P}/${target}" 150 targets+=" ${unpack_p}/${target}"
130 done 151 done
131 152
132 echo tar xzpf "${DISTDIR}"/${MY_P}.tar.gz ${targets} 153 echo tar xzf "${DISTDIR}"/${MY_P}.tar.gz ${targets}
133 tar xzpf "${DISTDIR}"/${MY_P}.tar.gz ${targets} || die 154 tar xzf "${DISTDIR}"/${MY_P}.tar.gz ${targets} || die
155 case "${PV}" in
156 4.8.0_*)
157 mv ${WORKDIR}/qt-everywhere-opensource-src-${PV/_*} \
158 ${WORKDIR}/qt-everywhere-opensource-src-${MY_PV}
159 ;;
160 esac
134} 161}
135 162
136# @ECLASS-VARIABLE: PATCHES 163# @ECLASS-VARIABLE: PATCHES
137# @DESCRIPTION: 164# @DESCRIPTION:
138# In case you have patches to apply, specify them in PATCHES variable. Make sure 165# In case you have patches to apply, specify them in PATCHES variable. Make sure
148# source files in order to respect CFLAGS/CXXFLAGS/LDFLAGS specified on /etc/make.conf. 175# source files in order to respect CFLAGS/CXXFLAGS/LDFLAGS specified on /etc/make.conf.
149qt4-build_src_prepare() { 176qt4-build_src_prepare() {
150 setqtenv 177 setqtenv
151 cd "${S}" 178 cd "${S}"
152 179
180 # fix qt 4.7 regression that skips -fvisibility=hidden
181 if version_is_at_least "4.7.0_beta1"; then
182 sed -e "s/^gcc|g++)/*gcc|*g++)/" \
183 -i config.tests/unix/fvisibility.test ||
184 die "visibility fixing sed failed"
185 fi
186
187 if version_is_at_least "4.7"; then
188 # fix libX11 dependency on non X packages
189 local nolibx11_pkgs="qt-core qt-dbus qt-script qt-sql qt-test qt-xmlpatterns"
190 has ${PN} ${nolibx11_pkgs} && qt_nolibx11
191
192 qt_assistant_cleanup
193 fi
194
153 if use aqua; then 195 if use aqua; then
154 # provide a proper macx-g++-64 196 # provide a proper macx-g++-64
155 use x64-macos && ln -s macx-g++ mkspecs/$(qt_mkspecs_dir) 197 use x64-macos && ln -s macx-g++ mkspecs/$(qt_mkspecs_dir)
156 198
157 sed -e '/^CONFIG/s:app_bundle::' \ 199 sed -e '/^CONFIG/s:app_bundle::' \
158 -e '/^CONFIG/s:plugin_no_soname:plugin_with_soname absolute_library_soname:' \ 200 -e '/^CONFIG/s:plugin_no_soname:plugin_with_soname absolute_library_soname:' \
159 -i mkspecs/$(qt_mkspecs_dir)/qmake.conf || die "sed failed" 201 -i mkspecs/$(qt_mkspecs_dir)/qmake.conf || die "sed failed"
160 fi 202 fi
161 203
162 if [[ ${PN} != qt-core ]]; then 204 if [[ ${PN} != qt-core ]]; then
163 skip_qmake_build_patch 205 skip_qmake_build
164 skip_project_generation_patch 206 skip_project_generation
165 symlink_binaries_to_buildtree 207 symlink_binaries_to_buildtree
166 fi 208 fi
167 209
168 if [[ ${CHOST} == *86*-apple-darwin* ]] ; then 210 if [[ ${CHOST} == *86*-apple-darwin* ]] ; then
169 # qmake bus errors with -O2 but -O3 works 211 # qmake bus errors with -O2 but -O3 works
170 replace-flags -O2 -O3 212 replace-flags -O2 -O3
171 fi 213 fi
172
173 # Bug 282984 && Bug 295530
174 sed -e "s:\(^SYSTEM_VARIABLES\):CC=$(tc-getCC)\nCXX=$(tc-getCXX)\n\1:" \
175 -i configure || die "sed qmake compilers failed"
176 sed -e "s:\(\$MAKE\):\1 CC=$(tc-getCC) CXX=$(tc-getCXX) LD=$(tc-getCXX):" \
177 -i config.tests/unix/compile.test || die "sed test compilers failed"
178 214
179 # Bug 178652 215 # Bug 178652
180 if [[ $(gcc-major-version) == 3 ]] && use amd64; then 216 if [[ $(gcc-major-version) == 3 ]] && use amd64; then
181 ewarn "Appending -fno-gcse to CFLAGS/CXXFLAGS" 217 ewarn "Appending -fno-gcse to CFLAGS/CXXFLAGS"
182 append-flags -fno-gcse 218 append-flags -fno-gcse
219 fi
220
221 if use_if_iuse c++0x; then
222 ewarn "You are about to build Qt4 using the C++11 standard. Even though"
223 ewarn "this is an official standard, some of the reverse dependencies"
224 ewarn "may fail to compile or link againt the Qt4 libraries. Before"
225 ewarn "reporting a bug, make sure your bug is reproducible with c++0x"
226 ewarn "disabled."
227 append-flags -std=c++0x
183 fi 228 fi
184 229
185 # Unsupported old gcc versions - hardened needs this :( 230 # Unsupported old gcc versions - hardened needs this :(
186 if [[ $(gcc-major-version) -lt 4 ]] ; then 231 if [[ $(gcc-major-version) -lt 4 ]] ; then
187 ewarn "Appending -fno-stack-protector to CXXFLAGS" 232 ewarn "Appending -fno-stack-protector to CXXFLAGS"
195 if use ppc64; then 240 if use ppc64; then
196 ewarn "Appending -mminimal-toc to CFLAGS/CXXFLAGS" 241 ewarn "Appending -mminimal-toc to CFLAGS/CXXFLAGS"
197 append-flags -mminimal-toc 242 append-flags -mminimal-toc
198 fi 243 fi
199 244
245 # Bug 282984 && Bug 295530
246 sed -e "s:\(^SYSTEM_VARIABLES\):CC=\"$(tc-getCC)\"\nCXX=\"$(tc-getCXX)\"\nCFLAGS=\"${CFLAGS}\"\nCXXFLAGS=\"${CXXFLAGS}\"\nLDFLAGS=\"${LDFLAGS}\"\n\1:" \
247 -i configure || die "sed qmake compilers failed"
248
249 # Bug 321335
250 if version_is_at_least 4.6; then
251 find ./config.tests/unix -name "*.test" -type f -exec grep -lZ \$MAKE '{}' \; | \
252 xargs -0 \
253 sed -e "s:\(\$MAKE\):\1 CC=\"$(tc-getCC)\" CXX=\"$(tc-getCXX)\" LD=\"$(tc-getCXX)\" LINK=\"$(tc-getCXX)\":g" \
254 -i || die "sed test compilers failed"
255 fi
256
200 # Bug 172219 257 # Bug 172219
201 sed -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \
202 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \
203 -e "s:QMAKE_LFLAGS_RELEASE.*=.*:QMAKE_LFLAGS_RELEASE=${LDFLAGS}:" \
204 -e "s:X11R6/::" \ 258 sed -e "s:X11R6/::" \
205 -i "${S}"/mkspecs/$(qt_mkspecs_dir)/qmake.conf || die "sed ${S}/mkspecs/$(qt_mkspecs_dir)/qmake.conf failed" 259 -i "${S}"/mkspecs/$(qt_mkspecs_dir)/qmake.conf || die "sed ${S}/mkspecs/$(qt_mkspecs_dir)/qmake.conf failed"
206 260
207 if [[ ${CHOST} != *-darwin* ]]; then 261 if [[ ${CHOST} == *-darwin* ]]; then
208 sed -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \
209 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \
210 -e "s:QMAKE_LFLAGS_RELEASE.*=.*:QMAKE_LFLAGS_RELEASE=${LDFLAGS}:" \
211 -i mkspecs/common/g++.conf || die "sed mkspecs/common/g++.conf failed"
212 else
213 # Set FLAGS *and* remove -arch, since our gcc-apple is multilib 262 # Set FLAGS *and* remove -arch, since our gcc-apple is multilib
214 # crippled (by design) :/ 263 # crippled (by design) :/
215 sed -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \ 264 sed -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \
216 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \ 265 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \
217 -e "s:QMAKE_LFLAGS_RELEASE.*=.*:QMAKE_LFLAGS_RELEASE=-headerpad_max_install_names ${LDFLAGS}:" \ 266 -e "s:QMAKE_LFLAGS_RELEASE.*=.*:QMAKE_LFLAGS_RELEASE=-headerpad_max_install_names ${LDFLAGS}:" \
257 # use GCC over SunStudio 306 # use GCC over SunStudio
258 sed -i -e '/PLATFORM=solaris-cc/s/cc/g++/' configure || die 307 sed -i -e '/PLATFORM=solaris-cc/s/cc/g++/' configure || die
259 # don't flirt with non-Prefix stuff, we're quite possessive 308 # don't flirt with non-Prefix stuff, we're quite possessive
260 sed -i -e '/^QMAKE_\(LIB\|INC\)DIR\(_X11\|_OPENGL\|\)\t/s/=.*$/=/' \ 309 sed -i -e '/^QMAKE_\(LIB\|INC\)DIR\(_X11\|_OPENGL\|\)\t/s/=.*$/=/' \
261 mkspecs/$(qt_mkspecs_dir)/qmake.conf || die 310 mkspecs/$(qt_mkspecs_dir)/qmake.conf || die
311 # strip predefined CFLAGS from qmake ( bug #312689 )
312 sed -i '/^QMAKE_CFLAGS_RELEASE/s:+=.*:+=:' mkspecs/common/g++.conf
262 313
263 base_src_prepare 314 base_src_prepare
264} 315}
265 316
266# @FUNCTION: qt4-build_src_configure 317# @FUNCTION: qt4-build_src_configure
273 # this one is needed for all systems with a separate -liconv, apart from 324 # this one is needed for all systems with a separate -liconv, apart from
274 # Darwin, for which the sources already cater for -liconv 325 # Darwin, for which the sources already cater for -liconv
275 use !elibc_glibc && [[ ${CHOST} != *-darwin* ]] && \ 326 use !elibc_glibc && [[ ${CHOST} != *-darwin* ]] && \
276 myconf+=" -liconv" 327 myconf+=" -liconv"
277 328
278 if has glib ${IUSE//+} && use glib; then 329 if use_if_iuse glib; then
279 # use -I, -L and -l from configure 330 # use -I, -L and -l from configure
280 local glibflags="$(pkg-config --cflags --libs glib-2.0 gthread-2.0)" 331 local glibflags="$(pkg-config --cflags --libs glib-2.0 gthread-2.0)"
281 # avoid the -pthread argument 332 # avoid the -pthread argument
282 myconf+=" ${glibflags//-pthread}" 333 myconf+=" ${glibflags//-pthread}"
283 unset glibflags 334 unset glibflags
335 fi
336
337 if use_if_iuse qpa; then
338 ewarn
339 ewarn "The qpa useflag enables the Qt Platform Abstraction, formely"
340 ewarn "known as Qt Lighthouse. If you are not sure what that is, then"
341 ewarn "disable it before reporting any bugs related to this useflag."
342 ewarn
343 myconf+=" -qpa"
284 fi 344 fi
285 345
286 if use aqua ; then 346 if use aqua ; then
287 # On (snow) leopard use the new (frameworked) cocoa code. 347 # On (snow) leopard use the new (frameworked) cocoa code.
288 if [[ ${CHOST##*-darwin} -ge 9 ]] ; then 348 if [[ ${CHOST##*-darwin} -ge 9 ]] ; then
304 # freetype2 include dir is non-standard, thus include it on configure 364 # freetype2 include dir is non-standard, thus include it on configure
305 # use -I from configure 365 # use -I from configure
306 myconf+=" $(pkg-config --cflags freetype2)" 366 myconf+=" $(pkg-config --cflags freetype2)"
307 fi 367 fi
308 368
369 # Disable SSE4.x, since auto-detection is currently broken
370 # Upstream bug http://bugreports.qt.nokia.com/browse/QTBUG-13623
371 [[ ${PV} == "4.7.1" ]] && myconf+=" -no-sse4.1 -no-sse4.2"
372
309 echo ./configure ${myconf} 373 echo ./configure ${myconf}
310 ./configure ${myconf} || die "./configure failed" 374 ./configure ${myconf} || die "./configure failed"
311 myconf="" 375 myconf=""
376
377 prepare_directories ${QT4_TARGET_DIRECTORIES}
312} 378}
313 379
314# @FUNCTION: qt4-build_src_compile 380# @FUNCTION: qt4-build_src_compile
381# @DESCRIPTION:
315# @DESCRIPTION: Actual compile phase 382# Actual compile phase
316qt4-build_src_compile() { 383qt4-build_src_compile() {
317 setqtenv 384 setqtenv
318 385
319 build_directories ${QT4_TARGET_DIRECTORIES} 386 build_directories ${QT4_TARGET_DIRECTORIES}
387}
388
389# @FUNCTION: qt4-build_src_test
390# @DESCRIPTION:
391# Runs tests only in target directories.
392qt4-build_src_test() {
393 for dir in ${QT4_TARGET_DIRECTORIES}; do
394 emake -j1 check -C ${dir}
395 done
320} 396}
321 397
322# @FUNCTION: fix_includes 398# @FUNCTION: fix_includes
323# @DESCRIPTION: 399# @DESCRIPTION:
324# For MacOSX we need to add some symlinks when frameworks are 400# For MacOSX we need to add some symlinks when frameworks are
349# @DESCRIPTION: 425# @DESCRIPTION:
350# Perform the actual installation including some library fixes. 426# Perform the actual installation including some library fixes.
351qt4-build_src_install() { 427qt4-build_src_install() {
352 [[ ${EAPI} == 2 ]] && use !prefix && ED=${D} 428 [[ ${EAPI} == 2 ]] && use !prefix && ED=${D}
353 setqtenv 429 setqtenv
430
354 install_directories ${QT4_TARGET_DIRECTORIES} 431 install_directories ${QT4_TARGET_DIRECTORIES}
355 install_qconfigs 432 install_qconfigs
356 fix_library_files 433 fix_library_files
357 fix_includes 434 fix_includes
435
436 # remove .la files since we are building only shared Qt libraries
437 find "${D}"${QTLIBDIR} -name "*.la" -print0 | xargs -0 rm
358} 438}
359 439
360# @FUNCTION: setqtenv 440# @FUNCTION: setqtenv
361setqtenv() { 441setqtenv() {
362 # Set up installation directories 442 # Set up installation directories
418 alpha|arm|ia64|mips|s390|sparc) myconf+=" -arch $(tc-arch)" ;; 498 alpha|arm|ia64|mips|s390|sparc) myconf+=" -arch $(tc-arch)" ;;
419 hppa|sh) myconf+=" -arch generic" ;; 499 hppa|sh) myconf+=" -arch generic" ;;
420 *) die "$(tc-arch) is unsupported by this eclass. Please file a bug." ;; 500 *) die "$(tc-arch) is unsupported by this eclass. Please file a bug." ;;
421 esac 501 esac
422 502
423 # 4.5: build everything but qt-xmlpatterns w/o exceptions
424 # 4.6: exceptions USE flag 503 # exceptions USE flag
425 local exceptions="-exceptions" 504 local exceptions="-exceptions"
426 case "${PV}" in
427 4.5.*)
428 [[ ${PN} == "qt-xmlpatterns" ]] || exceptions="-no-exceptions"
429 ;;
430 *)
431 has exceptions "${IUSE//+}" && exceptions="$(qt_use exceptions)" 505 in_iuse exceptions && exceptions="$(qt_use exceptions)"
432 ;;
433 esac
434 506
435 # note about -reduce-relocations: 507 # note about -reduce-relocations:
436 # That flag seems to introduce major breakage to applications, 508 # That flag seems to introduce major breakage to applications,
437 # mostly to be seen as a core dump with the message "QPixmap: Must 509 # mostly to be seen as a core dump with the message "QPixmap: Must
438 # construct a QApplication before a QPaintDevice" on Solaris 510 # construct a QApplication before a QPaintDevice" on Solaris
449 -nomake examples -nomake demos" 521 -nomake examples -nomake demos"
450 522
451 echo "${myconf}" 523 echo "${myconf}"
452} 524}
453 525
454# @FUNCTION: build_directories 526# @FUNCTION: prepare_directories
455# @USAGE: < directories > 527# @USAGE: < directories >
456# @DESCRIPTION: 528# @DESCRIPTION:
457# Compiles the code in $QT4_TARGET_DIRECTORIES 529# Generates makefiles for the directories set in $QT4_TARGET_DIRECTORIES
458build_directories() { 530prepare_directories() {
459 for x in "$@"; do 531 for x in "$@"; do
460 pushd "${S}"/${x} >/dev/null 532 pushd "${S}"/${x} >/dev/null
533 einfo "Running qmake in: ${x}"
461 # avoid running over the maximum argument number, bug #299810 534 # avoid running over the maximum argument number, bug #299810
462 { 535 {
463 echo "${S}"/mkspecs/common/*.conf 536 echo "${S}"/mkspecs/common/*.conf
464 find "${S}" -name '*.pr[io]' 537 find "${S}" -name '*.pr[io]'
465 } | xargs sed -i -e "s:\$\$\[QT_INSTALL_LIBS\]:${EPREFIX}/usr/$(get_libdir)/qt4:g" || die 538 } | xargs sed -i -e "s:\$\$\[QT_INSTALL_LIBS\]:${EPREFIX}/usr/$(get_libdir)/qt4:g" || die
466 "${S}"/bin/qmake "LIBS+=-L${QTLIBDIR}" "CONFIG+=nostrip" || die "qmake failed" 539 "${S}"/bin/qmake "LIBS+=-L${QTLIBDIR}" "CONFIG+=nostrip" || die "qmake failed"
467 emake CC="@echo compiling \$< && $(tc-getCC)" \ 540 popd >/dev/null
468 CXX="@echo compiling \$< && $(tc-getCXX)" \ 541 done
542}
543
544
545# @FUNCTION: build_directories
546# @USAGE: < directories >
547# @DESCRIPTION:
548# Compiles the code in $QT4_TARGET_DIRECTORIES
549build_directories() {
550 for x in "$@"; do
551 pushd "${S}"/${x} >/dev/null
552 emake CC="$(tc-getCC)" \
553 CXX="$(tc-getCXX)" \
469 LINK="@echo linking \$@ && $(tc-getCXX)" || die "emake failed" 554 LINK="$(tc-getCXX)" || die "emake failed"
470 popd >/dev/null 555 popd >/dev/null
471 done 556 done
472} 557}
473 558
474# @FUNCTION: install_directories 559# @FUNCTION: install_directories
497# @DESCRIPTION: 582# @DESCRIPTION:
498# List variables that should be defined at the top of QtCore/qconfig.h 583# List variables that should be defined at the top of QtCore/qconfig.h
499: ${QCONFIG_DEFINE:=} 584: ${QCONFIG_DEFINE:=}
500 585
501# @FUNCTION: install_qconfigs 586# @FUNCTION: install_qconfigs
587# @DESCRIPTION:
502# @DESCRIPTION: Install gentoo-specific mkspecs configurations 588# Install gentoo-specific mkspecs configurations
503install_qconfigs() { 589install_qconfigs() {
504 local x 590 local x
505 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} ]]; then 591 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} ]]; then
506 for x in QCONFIG_ADD QCONFIG_REMOVE; do 592 for x in QCONFIG_ADD QCONFIG_REMOVE; do
507 [[ -n ${!x} ]] && echo ${x}=${!x} >> "${T}"/${PN}-qconfig.pri 593 [[ -n ${!x} ]] && echo ${x}=${!x} >> "${T}"/${PN}-qconfig.pri
518 doins "${T}"/gentoo-${PN}-qconfig.h || die "installing ${PN}-qconfig.h failed" 604 doins "${T}"/gentoo-${PN}-qconfig.h || die "installing ${PN}-qconfig.h failed"
519 fi 605 fi
520} 606}
521 607
522# @FUNCTION: generate_qconfigs 608# @FUNCTION: generate_qconfigs
609# @DESCRIPTION:
523# @DESCRIPTION: Generates gentoo-specific configurations 610# Generates gentoo-specific configurations
524generate_qconfigs() { 611generate_qconfigs() {
525 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} || -n ${QCONFIG_DEFINE} || ${CATEGORY}/${PN} == x11-libs/qt-core ]]; then 612 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} || -n ${QCONFIG_DEFINE} || ${CATEGORY}/${PN} == x11-libs/qt-core ]]; then
526 local x qconfig_add qconfig_remove qconfig_new 613 local x qconfig_add qconfig_remove qconfig_new
527 for x in "${ROOT}${QTDATADIR}"/mkspecs/gentoo/*-qconfig.pri; do 614 for x in "${ROOT}${QTDATADIR}"/mkspecs/gentoo/*-qconfig.pri; do
528 [[ -f ${x} ]] || continue 615 [[ -f ${x} ]] || continue
542 629
543 # generate list of QT_CONFIG entries from the existing list 630 # generate list of QT_CONFIG entries from the existing list
544 # including qconfig_add and excluding qconfig_remove 631 # including qconfig_add and excluding qconfig_remove
545 for x in $(sed -n 's/^QT_CONFIG +=//p' \ 632 for x in $(sed -n 's/^QT_CONFIG +=//p' \
546 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri) ${qconfig_add}; do 633 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri) ${qconfig_add}; do
547 hasq ${x} ${qconfig_remove} || qconfig_new+=" ${x}" 634 has ${x} ${qconfig_remove} || qconfig_new+=" ${x}"
548 done 635 done
549 636
550 # replace the existing QT_CONFIG list with qconfig_new 637 # replace the existing QT_CONFIG list with qconfig_new
551 if ! sed -i -e "s/QT_CONFIG +=.*/QT_CONFIG += ${qconfig_new}/" \ 638 if ! sed -i -e "s/QT_CONFIG +=.*/QT_CONFIG += ${qconfig_new}/" \
552 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri; then 639 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri; then
576 fi 663 fi
577 fi 664 fi
578} 665}
579 666
580# @FUNCTION: qt4-build_pkg_postrm 667# @FUNCTION: qt4-build_pkg_postrm
668# @DESCRIPTION:
581# @DESCRIPTION: Generate configurations when the package is completely removed 669# Generate configurations when the package is completely removed
582qt4-build_pkg_postrm() { 670qt4-build_pkg_postrm() {
583 generate_qconfigs 671 generate_qconfigs
584} 672}
585 673
586# @FUNCTION: qt4-build_pkg_postinst 674# @FUNCTION: qt4-build_pkg_postinst
675# @DESCRIPTION:
587# @DESCRIPTION: Generate configuration, plus throws a message about possible 676# Generate configuration, plus throws a message about possible
588# breakages and proposed solutions. 677# breakages and proposed solutions.
589qt4-build_pkg_postinst() { 678qt4-build_pkg_postinst() {
590 generate_qconfigs 679 generate_qconfigs
591} 680}
592 681
593# @FUNCTION: skip_qmake_build_patch 682# @FUNCTION: skip_qmake_build
594# @DESCRIPTION: 683# @DESCRIPTION:
595# Don't need to build qmake, as it's already installed from qt-core 684# Don't need to build qmake, as it's already installed from qt-core
596skip_qmake_build_patch() { 685skip_qmake_build() {
597 # Don't need to build qmake, as it's already installed from qt-core 686 # Don't need to build qmake, as it's already installed from qt-core
598 sed -i -e "s:if true:if false:g" "${S}"/configure || die "Sed failed" 687 sed -i -e "s:if true:if false:g" "${S}"/configure || die "sed failed"
599} 688}
600 689
601# @FUNCTION: skip_project_generation_patch 690# @FUNCTION: skip_project_generation
602# @DESCRIPTION: 691# @DESCRIPTION:
603# Exit the script early by throwing in an exit before all of the .pro files are scanned 692# Exit the script early by throwing in an exit before all of the .pro files are scanned
604skip_project_generation_patch() { 693skip_project_generation() {
605 # Exit the script early by throwing in an exit before all of the .pro files are scanned 694 # Exit the script early by throwing in an exit before all of the .pro files are scanned
606 sed -e "s:echo \"Finding:exit 0\n\necho \"Finding:g" \ 695 sed -e "s:echo \"Finding:exit 0\n\necho \"Finding:g" \
607 -i "${S}"/configure || die "Sed failed" 696 -i "${S}"/configure || die "sed failed"
608} 697}
609 698
610# @FUNCTION: symlink_binaries_to_buildtree 699# @FUNCTION: symlink_binaries_to_buildtree
611# @DESCRIPTION: 700# @DESCRIPTION:
612# Symlink generated binaries to buildtree so they can be used during compilation 701# Symlink generated binaries to buildtree so they can be used during compilation
613# time 702# time
614symlink_binaries_to_buildtree() { 703symlink_binaries_to_buildtree() {
615 for bin in qmake moc uic rcc; do 704 for bin in qmake moc uic rcc; do
616 ln -s ${QTBINDIR}/${bin} "${S}"/bin/ || die "Symlinking ${bin} to ${S}/bin failed." 705 ln -s "${QTBINDIR}"/${bin} "${S}"/bin/ || die "symlinking ${bin} to ${S}/bin failed"
617 done 706 done
618} 707}
619 708
620# @FUNCTION: fix_library_files 709# @FUNCTION: fix_library_files
621# @DESCRIPTION: 710# @DESCRIPTION:
622# Fixes the pathes in *.la, *.prl, *.pc, as they are wrong due to sandbox and 711# Fixes the pathes in *.la, *.prl, *.pc, as they are wrong due to sandbox and
623# moves the *.pc-files into the pkgconfig directory 712# moves the *.pc-files into the pkgconfig directory
624fix_library_files() { 713fix_library_files() {
625 for libfile in "${D}"/${QTLIBDIR}/{*.la,*.prl,pkgconfig/*.pc}; do 714 for libfile in "${D}"/${QTLIBDIR}/{*.la,*.prl,pkgconfig/*.pc}; do
626 if [[ -e ${libfile} ]]; then 715 if [[ -e ${libfile} ]]; then
627 sed -i -e "s:${S}/lib:${QTLIBDIR}:g" ${libfile} || die "Sed on ${libfile} failed." 716 sed -i -e "s:${S}/lib:${QTLIBDIR}:g" ${libfile} || die "sed on ${libfile} failed"
628 fi 717 fi
629 done 718 done
630 719
631 # pkgconfig files refer to WORKDIR/bin as the moc and uic locations. Fix: 720 # pkgconfig files refer to WORKDIR/bin as the moc and uic locations. Fix:
632 for libfile in "${D}"/${QTLIBDIR}/pkgconfig/*.pc; do 721 for libfile in "${D}"/${QTLIBDIR}/pkgconfig/*.pc; do
633 if [[ -e ${libfile} ]]; then 722 if [[ -e ${libfile} ]]; then
634 sed -i -e "s:${S}/bin:${QTBINDIR}:g" ${libfile} || die "Sed failed" 723 sed -i -e "s:${S}/bin:${QTBINDIR}:g" ${libfile} || die "sed failed"
635 724
636 # Move .pc files into the pkgconfig directory 725 # Move .pc files into the pkgconfig directory
637 dodir ${QTPCDIR#${EPREFIX}} 726 dodir ${QTPCDIR#${EPREFIX}}
638 mv ${libfile} "${D}"/${QTPCDIR}/ \ 727 mv ${libfile} "${D}"/${QTPCDIR}/ \
639 || die "Moving ${libfile} to ${D}/${QTPCDIR}/ failed." 728 || die "moving ${libfile} to ${D}/${QTPCDIR}/ failed"
640 fi 729 fi
641 done 730 done
642 731
643 # Don't install an empty directory 732 # Don't install an empty directory
644 rmdir "${D}"/${QTLIBDIR}/pkgconfig 733 rmdir "${D}"/${QTLIBDIR}/pkgconfig
693 *-solaris*) 782 *-solaris*)
694 spec=solaris ;; 783 spec=solaris ;;
695 *-linux-*|*-linux) 784 *-linux-*|*-linux)
696 spec=linux ;; 785 spec=linux ;;
697 *) 786 *)
698 die "Unknown CHOST, no platform choosen." 787 die "Unknown CHOST, no platform chosen"
699 esac 788 esac
700 789
701 CXX=$(tc-getCXX) 790 CXX=$(tc-getCXX)
702 if [[ ${CXX} == *g++* ]]; then 791 if [[ ${CXX} == *g++* ]]; then
703 spec+=-g++ 792 spec+=-g++
704 elif [[ ${CXX} == *icpc* ]]; then 793 elif [[ ${CXX} == *icpc* ]]; then
705 spec+=-icc 794 spec+=-icc
706 else 795 else
707 die "Unknown compiler ${CXX}." 796 die "Unknown compiler '${CXX}'"
708 fi 797 fi
709 if [[ -n ${LIBDIR/lib} ]]; then 798 if [[ -n ${LIBDIR/lib} ]]; then
710 spec+=-${LIBDIR/lib} 799 spec+=-${LIBDIR/lib}
711 fi 800 fi
712 801
721 fi 810 fi
722 811
723 echo "${spec}" 812 echo "${spec}"
724} 813}
725 814
815# @FUNCTION: qt_assistant_cleanup
816# @RETURN: nothing
817# @DESCRIPTION:
818# Tries to clean up tools.pro for qt-assistant ebuilds.
819# Meant to be called in src_prepare().
820# Since Qt 4.7.4 this function is a no-op.
821qt_assistant_cleanup() {
822 # apply patching to qt-assistant ebuilds only
823 [[ ${PN} != "qt-assistant" ]] && return
824
825 # no longer needed for 4.7.4 and later
826 version_is_at_least "4.7.4" && return
827
828 # different versions (and branches...) may need different handling,
829 # add a case if you need special handling
830 case "${MY_PV_EXTRA}" in
831 *kde-qt*)
832 sed -e "/^[ \t]*porting/,/^[ \t]*win32.*activeqt$/d" \
833 -e "/mac/,/^embedded.*makeqpf$/d" \
834 -i tools/tools.pro || die "patching tools.pro failed"
835 ;;
836 *)
837 sed -e "/^[ \t]*porting/,/^[ \t]*win32.*activeqt$/d" \
838 -e "/mac/,/^embedded.*makeqpf$/d" \
839 -e "s/^\([ \t]*pixeltool\) /\1 qdoc3 /" \
840 -i tools/tools.pro || die "patching tools.pro failed"
841 ;;
842 esac
843}
844
845# @FUNCTION: qt_nolibx11
846# @RETURN: nothing
847# @DESCRIPTION:
848# Ignore X11 tests for packages that don't need X libraries installed
849qt_nolibx11() {
850 einfo "Removing X11 check to allow X-less compilation"
851 sed -i "/unixtests\/compile.test.*config.tests\/x11\/xlib/,/fi$/d" "${S}"/configure ||
852 die "x11 check sed failed"
853}
854
726EXPORT_FUNCTIONS pkg_setup src_unpack src_prepare src_configure src_compile src_install pkg_postrm pkg_postinst 855EXPORT_FUNCTIONS pkg_setup src_unpack src_prepare src_configure src_compile src_install src_test pkg_postrm pkg_postinst

Legend:
Removed from v.1.66  
changed lines
  Added in v.1.100

  ViewVC Help
Powered by ViewVC 1.1.20