/[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.63 Revision 1.88
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.63 2010/02/10 20:34:17 yngwin Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/qt4-build.eclass,v 1.88 2011/01/20 23:08:09 spatz 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>,
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/_/-} 17MY_PV=${PV/_/-}
18if version_is_at_least 4.5.99999999; then 18if version_is_at_least 4.5.99999999; then
19 MY_P=qt-everywhere-opensource-src-${MY_PV} 19 MY_P=qt-everywhere-opensource-src-${MY_PV}
20 [[ ${CATEGORY}/${PN} != x11-libs/qt-xmlpatterns ]] &&
21 [[ ${CATEGORY}/${PN} != x11-themes/qgtkstyle ]] &&
22 IUSE="+exceptions"
20else 23else
21 MY_P=qt-x11-opensource-src-${MY_PV} 24 MY_P=qt-x11-opensource-src-${MY_PV}
22fi 25fi
23 26
24HOMEPAGE="http://qt.nokia.com/" 27HOMEPAGE="http://qt.nokia.com/"
25SRC_URI="http://get.qt.nokia.com/qt/source/${MY_P}.tar.gz" 28SRC_URI="http://get.qt.nokia.com/qt/source/${MY_P}.tar.gz"
26 29
27LICENSE="|| ( LGPL-2.1 GPL-3 )" 30LICENSE="|| ( LGPL-2.1 GPL-3 )"
28IUSE="debug pch aqua" 31IUSE+=" debug pch aqua"
29 32
30RDEPEND=" 33RDEPEND="
31 !<x11-libs/qt-assistant-${PV} 34 !<x11-libs/qt-assistant-${PV}
32 !>x11-libs/qt-assistant-${PV}-r9999 35 !>x11-libs/qt-assistant-${PV}-r9999
33 !<x11-libs/qt-core-${PV} 36 !<x11-libs/qt-core-${PV}
36 !>x11-libs/qt-dbus-${PV}-r9999 39 !>x11-libs/qt-dbus-${PV}-r9999
37 !<x11-libs/qt-demo-${PV} 40 !<x11-libs/qt-demo-${PV}
38 !>x11-libs/qt-demo-${PV}-r9999 41 !>x11-libs/qt-demo-${PV}-r9999
39 !<x11-libs/qt-gui-${PV} 42 !<x11-libs/qt-gui-${PV}
40 !>x11-libs/qt-gui-${PV}-r9999 43 !>x11-libs/qt-gui-${PV}-r9999
44 !<x11-libs/qt-multimedia-${PV}
45 !>x11-libs/qt-multimedia-${PV}-r9999
41 !<x11-libs/qt-opengl-${PV} 46 !<x11-libs/qt-opengl-${PV}
42 !>x11-libs/qt-opengl-${PV}-r9999 47 !>x11-libs/qt-opengl-${PV}-r9999
43 !<x11-libs/qt-phonon-${PV} 48 !<x11-libs/qt-phonon-${PV}
44 !>x11-libs/qt-phonon-${PV}-r9999 49 !>x11-libs/qt-phonon-${PV}-r9999
45 !<x11-libs/qt-qt3support-${PV} 50 !<x11-libs/qt-qt3support-${PV}
64# @DESCRIPTION: 69# @DESCRIPTION:
65# Sets up S, MY_P, PATH, and LD_LIBRARY_PATH 70# Sets up S, MY_P, PATH, and LD_LIBRARY_PATH
66qt4-build_pkg_setup() { 71qt4-build_pkg_setup() {
67 [[ ${EAPI} == 2 ]] && use !prefix && EPREFIX= 72 [[ ${EAPI} == 2 ]] && use !prefix && EPREFIX=
68 73
74 # Protect users by not allowing downgrades between releases
75 # Downgrading revisions within the same release should be allowed
76 if has_version '>'${CATEGORY}/${P}-r9999 ; then
77 if [[ -z $I_KNOW_WHAT_I_AM_DOING ]] ; then
78 eerror "Sanity check to keep you from breaking your system:"
79 eerror " Downgrading Qt is completely unsupported and will break your system!"
80 die "aborting to save your system"
81 else
82 ewarn "Downgrading Qt is completely unsupported and will break your system!"
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
97 fi
69 98
70 PATH="${S}/bin${PATH:+:}${PATH}" 99 PATH="${S}/bin${PATH:+:}${PATH}"
71 if [[ ${CHOST} != *-darwin* ]]; then 100 if [[ ${CHOST} != *-darwin* ]]; then
72 LD_LIBRARY_PATH="${S}/lib${LD_LIBRARY_PATH:+:}${LD_LIBRARY_PATH}" 101 LD_LIBRARY_PATH="${S}/lib${LD_LIBRARY_PATH:+:}${LD_LIBRARY_PATH}"
73 else 102 else
74 DYLD_LIBRARY_PATH="${S}/lib${DYLD_LIBRARY_PATH:+:}${DYLD_LIBRARY_PATH}" 103 DYLD_LIBRARY_PATH="${S}/lib${DYLD_LIBRARY_PATH:+:}${DYLD_LIBRARY_PATH}"
75 # On MacOS we *need* at least src/gui/kernel/qapplication_mac.mm for 104 # On MacOS we *need* at least src/gui/kernel/qapplication_mac.mm for
76 # platform detection. Note: needs to come before any directories to 105 # platform detection. Note: needs to come before any directories to
77 # avoid extract failure. 106 # avoid extract failure.
78 [[ ${CHOST} == *-apple-darwin* ]] && \ 107 [[ ${CHOST} == *-apple-darwin* ]] && \
79 QT4_EXTRACT_DIRECTORIES="src/gui/kernel/qapplication_mac.mm ${QT4_EXTRACT_DIRECTORIES}" 108 QT4_EXTRACT_DIRECTORIES="src/gui/kernel/qapplication_mac.mm
109 ${QT4_EXTRACT_DIRECTORIES}"
80 fi 110 fi
81 111
82 # Make sure ebuilds use the required EAPI 112 # Make sure ebuilds use the required EAPI
83 if [[ ${EAPI} != [23] ]]; then 113 if [[ ${EAPI} != [23] ]]; then
84 eerror "The qt4-build eclass requires EAPI=2 or EAPI=3, but this ebuild is using" 114 eerror "The qt4-build eclass requires EAPI=2 or EAPI=3, but this ebuild is using"
87 die "qt4-build eclass requires EAPI=2 or EAPI=3" 117 die "qt4-build eclass requires EAPI=2 or EAPI=3"
88 fi 118 fi
89 119
90 if ! version_is_at_least 4.1 $(gcc-version); then 120 if ! version_is_at_least 4.1 $(gcc-version); then
91 ewarn "Using a GCC version lower than 4.1 is not supported!" 121 ewarn "Using a GCC version lower than 4.1 is not supported!"
92 echo
93 ebeep 3
94 fi 122 fi
95} 123}
96 124
97# @ECLASS-VARIABLE: QT4_TARGET_DIRECTORIES 125# @ECLASS-VARIABLE: QT4_TARGET_DIRECTORIES
98# @DESCRIPTION: 126# @DESCRIPTION:
114 src/{qbase,qt_targets,qt_install}.pri bin config.tests mkspecs qmake \ 142 src/{qbase,qt_targets,qt_install}.pri bin config.tests mkspecs qmake \
115 ${QT4_EXTRACT_DIRECTORIES}; do 143 ${QT4_EXTRACT_DIRECTORIES}; do
116 targets+=" ${MY_P}/${target}" 144 targets+=" ${MY_P}/${target}"
117 done 145 done
118 146
119 echo tar xzpf "${DISTDIR}"/${MY_P}.tar.gz ${targets} 147 echo tar xzf "${DISTDIR}"/${MY_P}.tar.gz ${targets}
120 tar xzpf "${DISTDIR}"/${MY_P}.tar.gz ${targets} || die 148 tar xzf "${DISTDIR}"/${MY_P}.tar.gz ${targets} || die
121} 149}
122 150
123# @ECLASS-VARIABLE: PATCHES 151# @ECLASS-VARIABLE: PATCHES
124# @DESCRIPTION: 152# @DESCRIPTION:
125# In case you have patches to apply, specify them in PATCHES variable. Make sure 153# In case you have patches to apply, specify them in PATCHES variable. Make sure
134# Prepare the sources before the configure phase. Strip CFLAGS if necessary, and fix 162# Prepare the sources before the configure phase. Strip CFLAGS if necessary, and fix
135# source files in order to respect CFLAGS/CXXFLAGS/LDFLAGS specified on /etc/make.conf. 163# source files in order to respect CFLAGS/CXXFLAGS/LDFLAGS specified on /etc/make.conf.
136qt4-build_src_prepare() { 164qt4-build_src_prepare() {
137 setqtenv 165 setqtenv
138 cd "${S}" 166 cd "${S}"
167
168 # fix qt 4.7 regression that skips -fvisibility=hidden
169 if version_is_at_least "4.7.0_beta1"; then
170 sed -e "s/^gcc|g++)/*gcc|*g++)/" \
171 -i config.tests/unix/fvisibility.test ||
172 die "visibility fixing sed failed"
173 fi
174 # fix libx11 dependency on non X packages
175 if version_is_at_least "4.7.0_beta2"; then
176 local NOLIBX11PKG="qt-core qt-dbus qt-script qt-sql qt-test qt-xmlpatterns"
177 hasq ${PN} ${NOLIBX11PKG} && qt_nolibx11
178 [[ ${PN} == "qt-assistant" ]] && qt_assistant_cleanup
179 fi
139 180
140 if use aqua; then 181 if use aqua; then
141 # provide a proper macx-g++-64 182 # provide a proper macx-g++-64
142 use x64-macos && ln -s macx-g++ mkspecs/$(qt_mkspecs_dir) 183 use x64-macos && ln -s macx-g++ mkspecs/$(qt_mkspecs_dir)
143 184
154 195
155 if [[ ${CHOST} == *86*-apple-darwin* ]] ; then 196 if [[ ${CHOST} == *86*-apple-darwin* ]] ; then
156 # qmake bus errors with -O2 but -O3 works 197 # qmake bus errors with -O2 but -O3 works
157 replace-flags -O2 -O3 198 replace-flags -O2 -O3
158 fi 199 fi
159
160 # Bug 282984 && Bug 295530
161 sed -e "s:\(^SYSTEM_VARIABLES\):CC=$(tc-getCC)\nCXX=$(tc-getCXX)\n\1:" \
162 -i configure || die "sed qmake compilers failed"
163 sed -e "s:\(\$MAKE\):\1 CC=$(tc-getCC) CXX=$(tc-getCXX) LD=$(tc-getCXX):" \
164 -i config.tests/unix/compile.test || die "sed test compilers failed"
165 200
166 # Bug 178652 201 # Bug 178652
167 if [[ $(gcc-major-version) == 3 ]] && use amd64; then 202 if [[ $(gcc-major-version) == 3 ]] && use amd64; then
168 ewarn "Appending -fno-gcse to CFLAGS/CXXFLAGS" 203 ewarn "Appending -fno-gcse to CFLAGS/CXXFLAGS"
169 append-flags -fno-gcse 204 append-flags -fno-gcse
182 if use ppc64; then 217 if use ppc64; then
183 ewarn "Appending -mminimal-toc to CFLAGS/CXXFLAGS" 218 ewarn "Appending -mminimal-toc to CFLAGS/CXXFLAGS"
184 append-flags -mminimal-toc 219 append-flags -mminimal-toc
185 fi 220 fi
186 221
222 # Bug 282984 && Bug 295530
223 sed -e "s:\(^SYSTEM_VARIABLES\):CC=\"$(tc-getCC)\"\nCXX=\"$(tc-getCXX)\"\nCFLAGS=\"${CFLAGS}\"\nCXXFLAGS=\"${CXXFLAGS}\"\nLDFLAGS=\"${LDFLAGS}\"\n\1:" \
224 -i configure || die "sed qmake compilers failed"
225 # bug 321335
226 if version_is_at_least 4.6; then
227 find ./config.tests/unix -name "*.test" -type f -exec grep -lZ \$MAKE '{}' \; | \
228 xargs -0 \
229 sed -e "s:\(\$MAKE\):\1 CC=\"$(tc-getCC)\" CXX=\"$(tc-getCXX)\" LD=\"$(tc-getCXX)\" LINK=\"$(tc-getCXX)\":g" \
230 -i || die "sed test compilers failed"
231 fi
232
187 # Bug 172219 233 # Bug 172219
188 sed -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \
189 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \
190 -e "s:QMAKE_LFLAGS_RELEASE.*=.*:QMAKE_LFLAGS_RELEASE=${LDFLAGS}:" \
191 -e "s:X11R6/::" \ 234 sed -e "s:X11R6/::" \
192 -i "${S}"/mkspecs/$(qt_mkspecs_dir)/qmake.conf || die "sed ${S}/mkspecs/$(qt_mkspecs_dir)/qmake.conf failed" 235 -i "${S}"/mkspecs/$(qt_mkspecs_dir)/qmake.conf || die "sed ${S}/mkspecs/$(qt_mkspecs_dir)/qmake.conf failed"
193 236
194 if [[ ${CHOST} != *-darwin* ]]; then 237 if [[ ${CHOST} == *-darwin* ]]; then
195 sed -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \
196 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \
197 -e "s:QMAKE_LFLAGS_RELEASE.*=.*:QMAKE_LFLAGS_RELEASE=${LDFLAGS}:" \
198 -i mkspecs/common/g++.conf || die "sed mkspecs/common/g++.conf failed"
199 else
200 # Set FLAGS *and* remove -arch, since our gcc-apple is multilib 238 # Set FLAGS *and* remove -arch, since our gcc-apple is multilib
201 # crippled (by design) :/ 239 # crippled (by design) :/
202 sed -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \ 240 sed -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \
203 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \ 241 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \
204 -e "s:QMAKE_LFLAGS_RELEASE.*=.*:QMAKE_LFLAGS_RELEASE=-headerpad_max_install_names ${LDFLAGS}:" \ 242 -e "s:QMAKE_LFLAGS_RELEASE.*=.*:QMAKE_LFLAGS_RELEASE=-headerpad_max_install_names ${LDFLAGS}:" \
244 # use GCC over SunStudio 282 # use GCC over SunStudio
245 sed -i -e '/PLATFORM=solaris-cc/s/cc/g++/' configure || die 283 sed -i -e '/PLATFORM=solaris-cc/s/cc/g++/' configure || die
246 # don't flirt with non-Prefix stuff, we're quite possessive 284 # don't flirt with non-Prefix stuff, we're quite possessive
247 sed -i -e '/^QMAKE_\(LIB\|INC\)DIR\(_X11\|_OPENGL\|\)\t/s/=.*$/=/' \ 285 sed -i -e '/^QMAKE_\(LIB\|INC\)DIR\(_X11\|_OPENGL\|\)\t/s/=.*$/=/' \
248 mkspecs/$(qt_mkspecs_dir)/qmake.conf || die 286 mkspecs/$(qt_mkspecs_dir)/qmake.conf || die
287 # strip predefined CFLAGS from qmake ( bug #312689 )
288 sed -i '/^QMAKE_CFLAGS_RELEASE/s:+=.*:+=:' mkspecs/common/g++.conf
249 289
250 base_src_prepare 290 base_src_prepare
251} 291}
252 292
253# @FUNCTION: qt4-build_src_configure 293# @FUNCTION: qt4-build_src_configure
291 # freetype2 include dir is non-standard, thus include it on configure 331 # freetype2 include dir is non-standard, thus include it on configure
292 # use -I from configure 332 # use -I from configure
293 myconf+=" $(pkg-config --cflags freetype2)" 333 myconf+=" $(pkg-config --cflags freetype2)"
294 fi 334 fi
295 335
336 # Disable SSE4.x, since auto-detection is currently broken
337 # Upstream bug http://bugreports.qt.nokia.com/browse/QTBUG-13623
338 if version_is_at_least 4.7.1; then
339 myconf+=" -no-sse4.1 -no-sse4.2"
340 fi
341
296 echo ./configure ${myconf} 342 echo ./configure ${myconf}
297 ./configure ${myconf} || die "./configure failed" 343 ./configure ${myconf} || die "./configure failed"
298 myconf="" 344 myconf=""
299} 345}
300 346
302# @DESCRIPTION: Actual compile phase 348# @DESCRIPTION: Actual compile phase
303qt4-build_src_compile() { 349qt4-build_src_compile() {
304 setqtenv 350 setqtenv
305 351
306 build_directories ${QT4_TARGET_DIRECTORIES} 352 build_directories ${QT4_TARGET_DIRECTORIES}
353}
354
355# @FUNCTION: qt4-build_src_test
356# @DESCRIPTION:
357# Runs tests only in target directories.
358qt4-build_src_test() {
359 for dir in ${QT4_TARGET_DIRECTORIES}; do
360 emake -j1 check -C ${dir}
361 done
307} 362}
308 363
309# @FUNCTION: fix_includes 364# @FUNCTION: fix_includes
310# @DESCRIPTION: 365# @DESCRIPTION:
311# For MacOSX we need to add some symlinks when frameworks are 366# For MacOSX we need to add some symlinks when frameworks are
340 setqtenv 395 setqtenv
341 install_directories ${QT4_TARGET_DIRECTORIES} 396 install_directories ${QT4_TARGET_DIRECTORIES}
342 install_qconfigs 397 install_qconfigs
343 fix_library_files 398 fix_library_files
344 fix_includes 399 fix_includes
400 # remove .la files since we are building only shared Qt libraries
401 find "${D}"${QTLIBDIR} -name "*.la" -print0 | xargs -0 rm
345} 402}
346 403
347# @FUNCTION: setqtenv 404# @FUNCTION: setqtenv
348setqtenv() { 405setqtenv() {
349 # Set up installation directories 406 # Set up installation directories
405 alpha|arm|ia64|mips|s390|sparc) myconf+=" -arch $(tc-arch)" ;; 462 alpha|arm|ia64|mips|s390|sparc) myconf+=" -arch $(tc-arch)" ;;
406 hppa|sh) myconf+=" -arch generic" ;; 463 hppa|sh) myconf+=" -arch generic" ;;
407 *) die "$(tc-arch) is unsupported by this eclass. Please file a bug." ;; 464 *) die "$(tc-arch) is unsupported by this eclass. Please file a bug." ;;
408 esac 465 esac
409 466
410 # 4.6: build qt-core with exceptions or qt-xmlpatterns won't build 467 # 4.5: build everything but qt-xmlpatterns w/o exceptions
411 local exceptions= 468 # 4.6: exceptions USE flag
469 local exceptions="-exceptions"
412 case "${PV}" in 470 case "${PV}" in
413 4.6.*) 471 4.5.*)
414 if [[ ${PN} != "qt-core" ]] && [[ ${PN} != "qt-xmlpatterns" ]]; then 472 [[ ${PN} == "qt-xmlpatterns" ]] || exceptions="-no-exceptions"
415 case "${PV}:${CHOST}" in
416 4.6.0*:*-darwin*)
417 : # http://bugreports.qt.nokia.com/browse/QTBUG-5909
418 # workaround for compilation error on OSX (qt-gui)
419 ;;
420 *)
421 exceptions="-no-exceptions"
422 ;;
423 esac
424 fi
425 ;; 473 ;;
426 *) 474 *)
427 [[ ${PN} == "qt-xmlpatterns" ]] || exceptions="-no-exceptions" 475 has exceptions "${IUSE//+}" && exceptions="$(qt_use exceptions)"
428 ;; 476 ;;
429 esac 477 esac
430 478
431 # note about -reduce-relocations: 479 # note about -reduce-relocations:
432 # That flag seems to introduce major breakage to applications, 480 # That flag seems to introduce major breakage to applications,
458 { 506 {
459 echo "${S}"/mkspecs/common/*.conf 507 echo "${S}"/mkspecs/common/*.conf
460 find "${S}" -name '*.pr[io]' 508 find "${S}" -name '*.pr[io]'
461 } | xargs sed -i -e "s:\$\$\[QT_INSTALL_LIBS\]:${EPREFIX}/usr/$(get_libdir)/qt4:g" || die 509 } | xargs sed -i -e "s:\$\$\[QT_INSTALL_LIBS\]:${EPREFIX}/usr/$(get_libdir)/qt4:g" || die
462 "${S}"/bin/qmake "LIBS+=-L${QTLIBDIR}" "CONFIG+=nostrip" || die "qmake failed" 510 "${S}"/bin/qmake "LIBS+=-L${QTLIBDIR}" "CONFIG+=nostrip" || die "qmake failed"
463 emake CC="@echo compiling \$< && $(tc-getCC)" \ 511 emake CC="$(tc-getCC)" \
464 CXX="@echo compiling \$< && $(tc-getCXX)" \ 512 CXX="$(tc-getCXX)" \
465 LINK="@echo linking \$@ && $(tc-getCXX)" || die "emake failed" 513 LINK="$(tc-getCXX)" || die "emake failed"
466 popd >/dev/null 514 popd >/dev/null
467 done 515 done
468} 516}
469 517
470# @FUNCTION: install_directories 518# @FUNCTION: install_directories
582# @FUNCTION: qt4-build_pkg_postinst 630# @FUNCTION: qt4-build_pkg_postinst
583# @DESCRIPTION: Generate configuration, plus throws a message about possible 631# @DESCRIPTION: Generate configuration, plus throws a message about possible
584# breakages and proposed solutions. 632# breakages and proposed solutions.
585qt4-build_pkg_postinst() { 633qt4-build_pkg_postinst() {
586 generate_qconfigs 634 generate_qconfigs
587
588 if [[ "${PN}" == "qt-core" ]]; then
589 echo
590 ewarn "After a rebuild or upgrade of Qt, it can happen that Qt plugins (such as Qt"
591 ewarn "and KDE styles and widgets) can no longer be loaded. In this situation you"
592 ewarn "should recompile the packages providing these plugins. Also, make sure you"
593 ewarn "compile the Qt packages, and the packages that depend on it, with the same"
594 ewarn "GCC version and the same USE flag settings (especially the debug flag)."
595 ewarn
596 ewarn "Packages that typically need to be recompiled are kdelibs from KDE4, any"
597 ewarn "additional KDE4/Qt4 styles, qscintilla and PyQt4. Before filing a bug report,"
598 ewarn "make sure all your Qt4 packages are up-to-date and built with the same"
599 ewarn "configuration."
600 ewarn
601 ewarn "For more information, see http://doc.trolltech.com/${PV%.*}/plugins-howto.html"
602 echo
603 fi
604} 635}
605 636
606# @FUNCTION: skip_qmake_build_patch 637# @FUNCTION: skip_qmake_build_patch
607# @DESCRIPTION: 638# @DESCRIPTION:
608# Don't need to build qmake, as it's already installed from qt-core 639# Don't need to build qmake, as it's already installed from qt-core
734 fi 765 fi
735 766
736 echo "${spec}" 767 echo "${spec}"
737} 768}
738 769
770# @FUNCTION: qt_assistant_cleanup
771# @RETURN: nothing
772# @DESCRIPTION:
773# Tries to clean up tools.pro for qt-assistant ebuilds
774# Meant to be called in src_prepare
775qt_assistant_cleanup() {
776 # different versions (and branches...) may need different handling,
777 # add a case if you need special handling
778 case "${MY_PV_EXTRA}" in
779 *kde-qt*)
780 sed -e "/^[ \t]*porting/,/^[ \t]*win32.*activeqt$/d" \
781 -e "/mac/,/^embedded.*makeqpf$/d" \
782 -i tools/tools.pro || die "patching tools.pro failed"
783 ;;
784 *)
785 sed -e "/^[ \t]*porting/,/^[ \t]*win32.*activeqt$/d" \
786 -e "/mac/,/^embedded.*makeqpf$/d" \
787 -e "s/^\([ \t]*pixeltool\) /\1 qdoc3 /" \
788 -i tools/tools.pro || die "patching tools.pro failed"
789 ;;
790 esac
791}
792
793# @FUNCTION: qt_nolibx11
794# @RETURN: nothing
795# @DESCRIPTION:
796# Ignore X11 tests for packages that don't need X libraries installed
797qt_nolibx11() {
798 einfo "removing X11 check to allow X-less compilation"
799 sed -i "/unixtests\/compile.test.*config.tests\/x11\/xlib/,/fi$/d" "${S}"/configure ||
800 die "x11 check sed failed"
801}
802
739EXPORT_FUNCTIONS pkg_setup src_unpack src_prepare src_configure src_compile src_install pkg_postrm pkg_postinst 803EXPORT_FUNCTIONS pkg_setup src_unpack src_prepare src_configure src_compile src_install src_test pkg_postrm pkg_postinst

Legend:
Removed from v.1.63  
changed lines
  Added in v.1.88

  ViewVC Help
Powered by ViewVC 1.1.20