/[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.57 Revision 1.104
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.57 2009/12/24 21:40:23 abcd Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/qt4-build.eclass,v 1.104 2011/12/16 20:02:48 abcd 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
14MY_PV=${PV/_/-}
15MY_P=qt-everywhere-opensource-src-${MY_PV}
16
17HOMEPAGE="http://qt.nokia.com/ http://qt-project.org/"
18SRC_URI="http://get.qt.nokia.com/qt/source/${MY_P}.tar.gz"
19LICENSE="|| ( LGPL-2.1 GPL-3 )"
20
17IUSE="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
31DEPEND="dev-util/pkgconfig"
18RDEPEND=" 32RDEPEND="
19 !<x11-libs/qt-assistant-${PV} 33 !<x11-libs/qt-assistant-${PV}
20 !>x11-libs/qt-assistant-${PV}-r9999 34 !>x11-libs/qt-assistant-${PV}-r9999
21 !<x11-libs/qt-core-${PV} 35 !<x11-libs/qt-core-${PV}
22 !>x11-libs/qt-core-${PV}-r9999 36 !>x11-libs/qt-core-${PV}-r9999
23 !<x11-libs/qt-dbus-${PV} 37 !<x11-libs/qt-dbus-${PV}
24 !>x11-libs/qt-dbus-${PV}-r9999 38 !>x11-libs/qt-dbus-${PV}-r9999
39 !<x11-libs/qt-declarative-${PV}
40 !>x11-libs/qt-declarative-${PV}-r9999
25 !<x11-libs/qt-demo-${PV} 41 !<x11-libs/qt-demo-${PV}
26 !>x11-libs/qt-demo-${PV}-r9999 42 !>x11-libs/qt-demo-${PV}-r9999
27 !<x11-libs/qt-gui-${PV} 43 !<x11-libs/qt-gui-${PV}
28 !>x11-libs/qt-gui-${PV}-r9999 44 !>x11-libs/qt-gui-${PV}-r9999
45 !<x11-libs/qt-multimedia-${PV}
46 !>x11-libs/qt-multimedia-${PV}-r9999
29 !<x11-libs/qt-opengl-${PV} 47 !<x11-libs/qt-opengl-${PV}
30 !>x11-libs/qt-opengl-${PV}-r9999 48 !>x11-libs/qt-opengl-${PV}-r9999
31 !<x11-libs/qt-phonon-${PV} 49 !<x11-libs/qt-phonon-${PV}
32 !>x11-libs/qt-phonon-${PV}-r9999 50 !>x11-libs/qt-phonon-${PV}-r9999
33 !<x11-libs/qt-qt3support-${PV} 51 !<x11-libs/qt-qt3support-${PV}
44 !>x11-libs/qt-webkit-${PV}-r9999 62 !>x11-libs/qt-webkit-${PV}-r9999
45 !<x11-libs/qt-xmlpatterns-${PV} 63 !<x11-libs/qt-xmlpatterns-${PV}
46 !>x11-libs/qt-xmlpatterns-${PV}-r9999 64 !>x11-libs/qt-xmlpatterns-${PV}-r9999
47" 65"
48 66
49MY_PV=${PV/_/-} 67S=${WORKDIR}/${MY_P}
50
51HOMEPAGE="http://qt.nokia.com/"
52if version_is_at_least 4.5.99999999 ${PV} ; then
53 SRC_URI="http://get.qt.nokia.com/qt/source/qt-everywhere-opensource-src-${MY_PV}.tar.gz"
54else
55 SRC_URI="aqua? ( http://get.qt.nokia.com/qt/source/qt-mac-opensource-src-${MY_PV}.tar.gz )
56 !aqua? ( http://get.qt.nokia.com/qt/source/qt-x11-opensource-src-${MY_PV}.tar.gz )"
57fi
58
59LICENSE="|| ( LGPL-2.1 GPL-3 )"
60 68
61# @FUNCTION: qt4-build_pkg_setup 69# @FUNCTION: qt4-build_pkg_setup
62# @DESCRIPTION: 70# @DESCRIPTION:
63# Sets up S, MY_P, PATH, and LD_LIBRARY_PATH 71# Sets up S, MY_P, PATH, and LD_LIBRARY_PATH
64qt4-build_pkg_setup() { 72qt4-build_pkg_setup() {
65 [[ ${EAPI} == 2 ]] && use !prefix && EPREFIX= 73 [[ ${EAPI} == 2 ]] && use !prefix && EPREFIX=
66 74
67 local MY_GE 75 # Protect users by not allowing downgrades between releases
68 if version_is_at_least 4.5.99999999 ${PV} ; then 76 # Downgrading revisions within the same release should be allowed
69 MY_P=qt-everywhere-opensource-src-${MY_PV} 77 if has_version '>'${CATEGORY}/${P}-r9999; then
78 if [[ -z ${I_KNOW_WHAT_I_AM_DOING} ]]; then
79 eerror "Sanity check to keep you from breaking your system:"
80 eerror " Downgrading Qt is completely unsupported and will break your system!"
81 die "aborting to save your system"
70 else 82 else
71 use aqua \ 83 ewarn "Downgrading Qt is completely unsupported and will break your system!"
72 && MY_GE=mac \
73 || MY_GE=x11
74 MY_P=qt-${MY_GE}-opensource-src-${MY_PV}
75 fi 84 fi
76 S=${WORKDIR}/${MY_P} 85 fi
86
87 if [[ ${PN} == "qt-webkit" ]]; then
88 eshopts_push -s extglob
89 if is-flagq '-g?(gdb)?([1-9])'; then
90 echo
91 ewarn "You have enabled debug info (probably have -g or -ggdb in your \$C{,XX}FLAGS)."
92 ewarn "You may experience really long compilation times and/or increased memory usage."
93 ewarn "If compilation fails, please try removing -g{,gdb} before reporting a bug."
94 ewarn "For more info check out bug #307861"
95 echo
96 fi
97 eshopts_pop
98 fi
77 99
78 PATH="${S}/bin${PATH:+:}${PATH}" 100 PATH="${S}/bin${PATH:+:}${PATH}"
79 if [[ ${CHOST} != *-darwin* ]]; then 101 if [[ ${CHOST} != *-darwin* ]]; then
80 LD_LIBRARY_PATH="${S}/lib${LD_LIBRARY_PATH:+:}${LD_LIBRARY_PATH}" 102 LD_LIBRARY_PATH="${S}/lib${LD_LIBRARY_PATH:+:}${LD_LIBRARY_PATH}"
81 else 103 else
82 DYLD_LIBRARY_PATH="${S}/lib${DYLD_LIBRARY_PATH:+:}${DYLD_LIBRARY_PATH}" 104 DYLD_LIBRARY_PATH="${S}/lib${DYLD_LIBRARY_PATH:+:}${DYLD_LIBRARY_PATH}"
83 # on mac we *need* src/gui/kernel/qapplication_mac.cpp for platfrom 105 # On MacOS we *need* at least src/gui/kernel/qapplication_mac.mm for
84 # detection since the x11-headers package b0rkens the header 106 # platform detection. Note: needs to come before any directories to
85 # installation, we have to extract src/ and include/ completely on mac 107 # avoid extract failure.
86 # tools is needed for qt-demo and some others 108 [[ ${CHOST} == *-apple-darwin* ]] && \
87 QT4_EXTRACT_DIRECTORIES+=" src include" 109 QT4_EXTRACT_DIRECTORIES="src/gui/kernel/qapplication_mac.mm
88
89 if [[ ${PN} == qt-demo || ${PN} == qt-qt3support || ${PN} == qt-webkit ]]; then
90 QT4_EXTRACT_DIRECTORIES+=" tools" 110 ${QT4_EXTRACT_DIRECTORIES}"
91 fi
92 fi 111 fi
93 112
94 # Make sure ebuilds use the required EAPI 113 # Make sure ebuilds use the required EAPI
95 if [[ ${EAPI} != [23] ]]; then 114 if [[ ${EAPI} != [23] ]]; then
96 eerror "The qt4-build eclass requires EAPI=2 or EAPI=3, but this ebuild is using" 115 eerror "The qt4-build eclass requires EAPI=2 or EAPI=3, but this ebuild is using"
99 die "qt4-build eclass requires EAPI=2 or EAPI=3" 118 die "qt4-build eclass requires EAPI=2 or EAPI=3"
100 fi 119 fi
101 120
102 if ! version_is_at_least 4.1 $(gcc-version); then 121 if ! version_is_at_least 4.1 $(gcc-version); then
103 ewarn "Using a GCC version lower than 4.1 is not supported!" 122 ewarn "Using a GCC version lower than 4.1 is not supported!"
104 echo
105 ebeep 3
106 fi 123 fi
107
108 if [[ ${P} == qt-core-4.6.0_rc1 ]]; then
109 ewarn
110 ewarn "Binary compatibility broke between 4.6.0_beta1 and 4.6.0_rc1."
111 ewarn "If you are upgrading from 4.6.0_beta1, you'll have to"
112 ewarn "re-emerge everything that depends on Qt."
113 ewarn "Use the following command:"
114 ewarn
115 ewarn " emerge -av1 \$(for i in \$(qlist -IC x11-libs/qt-);"
116 ewarn " do equery -q d \$i | grep -v 'x11-libs/qt-' |"
117 ewarn " sed \"s/^/=/\"; done)"
118 ewarn
119 ewarn "YOU'VE BEEN WARNED"
120 ewarn
121 ebeep 3
122 fi
123
124} 124}
125 125
126# @ECLASS-VARIABLE: QT4_TARGET_DIRECTORIES 126# @ECLASS-VARIABLE: QT4_TARGET_DIRECTORIES
127# @DESCRIPTION: 127# @DESCRIPTION:
128# Arguments for build_target_directories. Takes the directories, in which the 128# Arguments for build_target_directories. Takes the directories, in which the
136# @FUNCTION: qt4-build_src_unpack 136# @FUNCTION: qt4-build_src_unpack
137# @DESCRIPTION: 137# @DESCRIPTION:
138# Unpacks the sources 138# Unpacks the sources
139qt4-build_src_unpack() { 139qt4-build_src_unpack() {
140 setqtenv 140 setqtenv
141 local unpack_p="${MY_P}"
142 case "${PV}" in
143 4.8.0_*)
144 unpack_p="qt-everywhere-opensource-src-${PV/_*}"
145 ;;
146 esac
141 local target targets= 147 local target targets=
142 for target in configure LICENSE.GPL3 LICENSE.LGPL projects.pro \ 148 for target in configure LICENSE.GPL3 LICENSE.LGPL projects.pro \
143 src/{qbase,qt_targets,qt_install}.pri bin config.tests mkspecs qmake \ 149 src/{qbase,qt_targets,qt_install}.pri bin config.tests mkspecs qmake \
144 ${QT4_EXTRACT_DIRECTORIES}; do 150 ${QT4_EXTRACT_DIRECTORIES}; do
145 targets+=" ${MY_P}/${target}" 151 targets+=" ${unpack_p}/${target}"
146 done 152 done
147 153
148 echo tar xzpf "${DISTDIR}"/${MY_P}.tar.gz ${targets} 154 echo tar xzf "${DISTDIR}"/${MY_P}.tar.gz ${targets}
149 tar xzpf "${DISTDIR}"/${MY_P}.tar.gz ${targets} 155 tar xzf "${DISTDIR}"/${MY_P}.tar.gz ${targets} || die
156 case "${PV}" in
157 4.8.0_*)
158 mv ${WORKDIR}/qt-everywhere-opensource-src-${PV/_*} \
159 ${WORKDIR}/qt-everywhere-opensource-src-${MY_PV}
160 ;;
161 esac
150} 162}
151 163
152# @ECLASS-VARIABLE: PATCHES 164# @ECLASS-VARIABLE: PATCHES
153# @DESCRIPTION: 165# @DESCRIPTION:
154# In case you have patches to apply, specify them in PATCHES variable. Make sure 166# In case you have patches to apply, specify them in PATCHES variable. Make sure
164# source files in order to respect CFLAGS/CXXFLAGS/LDFLAGS specified on /etc/make.conf. 176# source files in order to respect CFLAGS/CXXFLAGS/LDFLAGS specified on /etc/make.conf.
165qt4-build_src_prepare() { 177qt4-build_src_prepare() {
166 setqtenv 178 setqtenv
167 cd "${S}" 179 cd "${S}"
168 180
181 # fix qt 4.7 regression that skips -fvisibility=hidden
182 if version_is_at_least "4.7.0_beta1"; then
183 sed -e "s/^gcc|g++)/*gcc|*g++)/" \
184 -i config.tests/unix/fvisibility.test ||
185 die "visibility fixing sed failed"
186 fi
187
188 if version_is_at_least "4.7"; then
189 # fix libX11 dependency on non X packages
190 local nolibx11_pkgs="qt-core qt-dbus qt-script qt-sql qt-test qt-xmlpatterns"
191 has ${PN} ${nolibx11_pkgs} && qt_nolibx11
192
193 qt_assistant_cleanup
194 fi
195
169 if use aqua; then 196 if use aqua; then
170 # provide a proper macx-g++-64 197 # provide a proper macx-g++-64
171 use x64-macos && ln -s macx-g++ mkspecs/$(qt_mkspecs_dir) 198 use x64-macos && ln -s macx-g++ mkspecs/$(qt_mkspecs_dir)
172 199
173 sed -e '/^CONFIG/s:app_bundle::' \ 200 sed -e '/^CONFIG/s:app_bundle::' \
174 -e '/^CONFIG/s:plugin_no_soname:plugin_with_soname absolute_library_soname:' \ 201 -e '/^CONFIG/s:plugin_no_soname:plugin_with_soname absolute_library_soname:' \
175 -i mkspecs/$(qt_mkspecs_dir)/qmake.conf || die "sed failed" 202 -i mkspecs/$(qt_mkspecs_dir)/qmake.conf || die "sed failed"
176 fi 203 fi
177 204
178 if [[ ${PN} != qt-core ]]; then 205 if [[ ${PN} != qt-core ]]; then
179 skip_qmake_build_patch 206 skip_qmake_build
180 skip_project_generation_patch 207 skip_project_generation
181 symlink_binaries_to_buildtree 208 symlink_binaries_to_buildtree
182 fi 209 fi
183 210
184 if [[ ${CHOST} == *86*-apple-darwin* ]] ; then 211 if [[ ${CHOST} == *86*-apple-darwin* ]] ; then
185 # qmake bus errors with -O2 but -O3 works 212 # qmake bus errors with -O2 but -O3 works
186 replace-flags -O2 -O3 213 replace-flags -O2 -O3
187 fi 214 fi
188
189 # Bug 282984 && Bug 295530
190 sed -e "s:\(^SYSTEM_VARIABLES\):CC=$(tc-getCC)\nCXX=$(tc-getCXX)\n\1:" \
191 -i configure || die "sed qmake compilers failed"
192 sed -e "s:\(\$MAKE\):\1 CC=$(tc-getCC) CXX=$(tc-getCXX) LD=$(tc-getCXX):" \
193 -i config.tests/unix/compile.test || die "sed test compilers failed"
194 215
195 # Bug 178652 216 # Bug 178652
196 if [[ $(gcc-major-version) == 3 ]] && use amd64; then 217 if [[ $(gcc-major-version) == 3 ]] && use amd64; then
197 ewarn "Appending -fno-gcse to CFLAGS/CXXFLAGS" 218 ewarn "Appending -fno-gcse to CFLAGS/CXXFLAGS"
198 append-flags -fno-gcse 219 append-flags -fno-gcse
220 fi
221
222 if use_if_iuse c++0x; then
223 ewarn "You are about to build Qt4 using the C++11 standard. Even though"
224 ewarn "this is an official standard, some of the reverse dependencies"
225 ewarn "may fail to compile or link againt the Qt4 libraries. Before"
226 ewarn "reporting a bug, make sure your bug is reproducible with c++0x"
227 ewarn "disabled."
228 append-flags -std=c++0x
199 fi 229 fi
200 230
201 # Unsupported old gcc versions - hardened needs this :( 231 # Unsupported old gcc versions - hardened needs this :(
202 if [[ $(gcc-major-version) -lt 4 ]] ; then 232 if [[ $(gcc-major-version) -lt 4 ]] ; then
203 ewarn "Appending -fno-stack-protector to CXXFLAGS" 233 ewarn "Appending -fno-stack-protector to CXXFLAGS"
211 if use ppc64; then 241 if use ppc64; then
212 ewarn "Appending -mminimal-toc to CFLAGS/CXXFLAGS" 242 ewarn "Appending -mminimal-toc to CFLAGS/CXXFLAGS"
213 append-flags -mminimal-toc 243 append-flags -mminimal-toc
214 fi 244 fi
215 245
246 # Bug 282984 && Bug 295530
247 sed -e "s:\(^SYSTEM_VARIABLES\):CC=\"$(tc-getCC)\"\nCXX=\"$(tc-getCXX)\"\nCFLAGS=\"${CFLAGS}\"\nCXXFLAGS=\"${CXXFLAGS}\"\nLDFLAGS=\"${LDFLAGS}\"\n\1:" \
248 -i configure || die "sed qmake compilers failed"
249
250 # Bug 321335
251 if version_is_at_least 4.6; then
252 find ./config.tests/unix -name "*.test" -type f -exec grep -lZ \$MAKE '{}' \; | \
253 xargs -0 \
254 sed -e "s:\(\$MAKE\):\1 CC=\"$(tc-getCC)\" CXX=\"$(tc-getCXX)\" LD=\"$(tc-getCXX)\" LINK=\"$(tc-getCXX)\":g" \
255 -i || die "sed test compilers failed"
256 fi
257
216 # Bug 172219 258 # Bug 172219
217 sed -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \
218 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \
219 -e "s:QMAKE_LFLAGS_RELEASE.*=.*:QMAKE_LFLAGS_RELEASE=${LDFLAGS}:" \
220 -e "s:X11R6/::" \ 259 sed -e "s:X11R6/::" \
221 -i "${S}"/mkspecs/$(qt_mkspecs_dir)/qmake.conf || die "sed ${S}/mkspecs/$(qt_mkspecs_dir)/qmake.conf failed" 260 -i "${S}"/mkspecs/$(qt_mkspecs_dir)/qmake.conf || die "sed ${S}/mkspecs/$(qt_mkspecs_dir)/qmake.conf failed"
222 261
223 if [[ ${CHOST} != *-darwin* ]]; then 262 if [[ ${CHOST} == *-darwin* ]]; then
224 sed -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \
225 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \
226 -e "s:QMAKE_LFLAGS_RELEASE.*=.*:QMAKE_LFLAGS_RELEASE=${LDFLAGS}:" \
227 -i mkspecs/common/g++.conf || die "sed mkspecs/common/g++.conf failed"
228 else
229 # Set FLAGS *and* remove -arch, since our gcc-apple is multilib 263 # Set FLAGS *and* remove -arch, since our gcc-apple is multilib
230 # crippled (by design) :/ 264 # crippled (by design) :/
231 sed -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \ 265 sed -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \
232 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \ 266 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \
233 -e "s:QMAKE_LFLAGS_RELEASE.*=.*:QMAKE_LFLAGS_RELEASE=-headerpad_max_install_names ${LDFLAGS}:" \ 267 -e "s:QMAKE_LFLAGS_RELEASE.*=.*:QMAKE_LFLAGS_RELEASE=-headerpad_max_install_names ${LDFLAGS}:" \
273 # use GCC over SunStudio 307 # use GCC over SunStudio
274 sed -i -e '/PLATFORM=solaris-cc/s/cc/g++/' configure || die 308 sed -i -e '/PLATFORM=solaris-cc/s/cc/g++/' configure || die
275 # don't flirt with non-Prefix stuff, we're quite possessive 309 # don't flirt with non-Prefix stuff, we're quite possessive
276 sed -i -e '/^QMAKE_\(LIB\|INC\)DIR\(_X11\|_OPENGL\|\)\t/s/=.*$/=/' \ 310 sed -i -e '/^QMAKE_\(LIB\|INC\)DIR\(_X11\|_OPENGL\|\)\t/s/=.*$/=/' \
277 mkspecs/$(qt_mkspecs_dir)/qmake.conf || die 311 mkspecs/$(qt_mkspecs_dir)/qmake.conf || die
312 # strip predefined CFLAGS from qmake ( bug #312689 )
313 sed -i '/^QMAKE_CFLAGS_RELEASE/s:+=.*:+=:' mkspecs/common/g++.conf
278 314
279 base_src_prepare 315 base_src_prepare
280} 316}
281 317
282# @FUNCTION: qt4-build_src_configure 318# @FUNCTION: qt4-build_src_configure
289 # this one is needed for all systems with a separate -liconv, apart from 325 # this one is needed for all systems with a separate -liconv, apart from
290 # Darwin, for which the sources already cater for -liconv 326 # Darwin, for which the sources already cater for -liconv
291 use !elibc_glibc && [[ ${CHOST} != *-darwin* ]] && \ 327 use !elibc_glibc && [[ ${CHOST} != *-darwin* ]] && \
292 myconf+=" -liconv" 328 myconf+=" -liconv"
293 329
294 if has glib ${IUSE//+} && use glib; then 330 if use_if_iuse glib; then
295 # use -I, -L and -l from configure 331 # use -I, -L and -l from configure
296 local glibflags="$(pkg-config --cflags --libs glib-2.0 gthread-2.0)" 332 local glibflags="$(pkg-config --cflags --libs glib-2.0 gthread-2.0)"
297 # avoid the -pthread argument 333 # avoid the -pthread argument
298 myconf+=" ${glibflags//-pthread}" 334 myconf+=" ${glibflags//-pthread}"
299 unset glibflags 335 unset glibflags
300 fi 336 fi
301 337
338 if use_if_iuse qpa; then
339 ewarn
340 ewarn "The qpa useflag enables the Qt Platform Abstraction, formely"
341 ewarn "known as Qt Lighthouse. If you are not sure what that is, then"
342 ewarn "disable it before reporting any bugs related to this useflag."
343 ewarn
344 myconf+=" -qpa"
345 fi
346
302 if use aqua ; then 347 if use aqua ; then
303 # On (snow) leopard use the new (frameworked) cocoa code. 348 # On (snow) leopard use the new (frameworked) cocoa code.
304 if [[ $(uname -r | cut -d . -f 1) -ge 9 ]] ; then 349 if [[ ${CHOST##*-darwin} -ge 9 ]] ; then
305 myconf+=" -cocoa -framework" 350 myconf+=" -cocoa -framework"
306 351
307 # We are crazy and build cocoa + qt3support :-) 352 # We are crazy and build cocoa + qt3support :-)
308 if use qt3support; then 353 if use qt3support; then
309 sed -e "/case \"\$PLATFORM,\$CFG_MAC_COCOA\" in/,/;;/ s|CFG_QT3SUPPORT=\"no\"|CFG_QT3SUPPORT=\"yes\"|" \ 354 sed -e "/case \"\$PLATFORM,\$CFG_MAC_COCOA\" in/,/;;/ s|CFG_QT3SUPPORT=\"no\"|CFG_QT3SUPPORT=\"yes\"|" \
320 # freetype2 include dir is non-standard, thus include it on configure 365 # freetype2 include dir is non-standard, thus include it on configure
321 # use -I from configure 366 # use -I from configure
322 myconf+=" $(pkg-config --cflags freetype2)" 367 myconf+=" $(pkg-config --cflags freetype2)"
323 fi 368 fi
324 369
370 # Disable SSE4.x, since auto-detection is currently broken
371 # Upstream bug http://bugreports.qt.nokia.com/browse/QTBUG-13623
372 [[ ${PV} == "4.7.1" ]] && myconf+=" -no-sse4.1 -no-sse4.2"
373
325 echo ./configure ${myconf} 374 echo ./configure ${myconf}
326 ./configure ${myconf} || die "./configure failed" 375 ./configure ${myconf} || die "./configure failed"
327 myconf="" 376 myconf=""
377
378 prepare_directories ${QT4_TARGET_DIRECTORIES}
328} 379}
329 380
330# @FUNCTION: qt4-build_src_compile 381# @FUNCTION: qt4-build_src_compile
382# @DESCRIPTION:
331# @DESCRIPTION: Actual compile phase 383# Actual compile phase
332qt4-build_src_compile() { 384qt4-build_src_compile() {
333 setqtenv 385 setqtenv
334 386
335 build_directories ${QT4_TARGET_DIRECTORIES} 387 build_directories ${QT4_TARGET_DIRECTORIES}
388}
389
390# @FUNCTION: qt4-build_src_test
391# @DESCRIPTION:
392# Runs tests only in target directories.
393qt4-build_src_test() {
394 for dir in ${QT4_TARGET_DIRECTORIES}; do
395 emake -j1 check -C ${dir}
396 done
336} 397}
337 398
338# @FUNCTION: fix_includes 399# @FUNCTION: fix_includes
339# @DESCRIPTION: 400# @DESCRIPTION:
340# For MacOSX we need to add some symlinks when frameworks are 401# For MacOSX we need to add some symlinks when frameworks are
341# being used, to avoid complications with some more or less stupid packages. 402# being used, to avoid complications with some more or less stupid packages.
342fix_includes() { 403fix_includes() {
343 if use aqua && [[ $(uname -r | cut -d . -f 1) -ge 9 ]] ; then 404 if use aqua && [[ ${CHOST##*-darwin} -ge 9 ]] ; then
344 # Some packages tend to include <Qt/...> 405 # Some packages tend to include <Qt/...>
345 dodir "${QTHEADERDIR#${EPREFIX}}"/Qt 406 dodir "${QTHEADERDIR#${EPREFIX}}"/Qt
346 407
347 # Fake normal headers when frameworks are installed... eases life later on 408 # Fake normal headers when frameworks are installed... eases life later on
348 local dest f 409 local dest f
365# @DESCRIPTION: 426# @DESCRIPTION:
366# Perform the actual installation including some library fixes. 427# Perform the actual installation including some library fixes.
367qt4-build_src_install() { 428qt4-build_src_install() {
368 [[ ${EAPI} == 2 ]] && use !prefix && ED=${D} 429 [[ ${EAPI} == 2 ]] && use !prefix && ED=${D}
369 setqtenv 430 setqtenv
431
370 install_directories ${QT4_TARGET_DIRECTORIES} 432 install_directories ${QT4_TARGET_DIRECTORIES}
371 install_qconfigs 433 install_qconfigs
372 fix_library_files 434 fix_library_files
373 fix_includes 435 fix_includes
436
437 # remove .la files since we are building only shared Qt libraries
438 find "${D}"${QTLIBDIR} -name "*.la" -print0 | xargs -0 rm
374} 439}
375 440
376# @FUNCTION: setqtenv 441# @FUNCTION: setqtenv
377setqtenv() { 442setqtenv() {
378 # Set up installation directories 443 # Set up installation directories
384 QTPCDIR=${EPREFIX}/usr/$(get_libdir)/pkgconfig 449 QTPCDIR=${EPREFIX}/usr/$(get_libdir)/pkgconfig
385 QTDATADIR=${EPREFIX}/usr/share/qt4 450 QTDATADIR=${EPREFIX}/usr/share/qt4
386 QTDOCDIR=${EPREFIX}/usr/share/doc/qt-${PV} 451 QTDOCDIR=${EPREFIX}/usr/share/doc/qt-${PV}
387 QTHEADERDIR=${EPREFIX}/usr/include/qt4 452 QTHEADERDIR=${EPREFIX}/usr/include/qt4
388 QTPLUGINDIR=${QTLIBDIR}/plugins 453 QTPLUGINDIR=${QTLIBDIR}/plugins
454 QTIMPORTDIR=${QTLIBDIR}/imports
389 QTSYSCONFDIR=${EPREFIX}/etc/qt4 455 QTSYSCONFDIR=${EPREFIX}/etc/qt4
390 QTTRANSDIR=${QTDATADIR}/translations 456 QTTRANSDIR=${QTDATADIR}/translations
391 QTEXAMPLESDIR=${QTDATADIR}/examples 457 QTEXAMPLESDIR=${QTDATADIR}/examples
392 QTDEMOSDIR=${QTDATADIR}/demos 458 QTDEMOSDIR=${QTDATADIR}/demos
393 QT_INSTALL_PREFIX=${EPREFIX}/usr/$(get_libdir)/qt4 459 QT_INSTALL_PREFIX=${EPREFIX}/usr/$(get_libdir)/qt4
401# Sets up some standard configure options, like libdir (if necessary), whether 467# Sets up some standard configure options, like libdir (if necessary), whether
402# debug info is wanted or not. 468# debug info is wanted or not.
403standard_configure_options() { 469standard_configure_options() {
404 local myconf= 470 local myconf=
405 471
406 # Doesn't need ${EPREFIX} because get_libdir() is *always* lib on prefix
407 [[ $(get_libdir) != lib ]] && myconf+=" -L/usr/$(get_libdir)" 472 [[ $(get_libdir) != lib ]] && myconf+=" -L${EPREFIX}/usr/$(get_libdir)"
408 473
409 # Disable visibility explicitly if gcc version isn't 4 474 # Disable visibility explicitly if gcc version isn't 4
410 if [[ $(gcc-major-version) -lt 4 ]]; then 475 if [[ $(gcc-major-version) -lt 4 ]]; then
411 myconf+=" -no-reduce-exports" 476 myconf+=" -no-reduce-exports"
412 fi 477 fi
424 use aqua && myconf+=" -no-framework" 489 use aqua && myconf+=" -no-framework"
425 490
426 # ARCH is set on Gentoo. Qt now falls back to generic on an unsupported 491 # ARCH is set on Gentoo. Qt now falls back to generic on an unsupported
427 # $(tc-arch). Therefore we convert it to supported values. 492 # $(tc-arch). Therefore we convert it to supported values.
428 case "$(tc-arch)" in 493 case "$(tc-arch)" in
429 amd64|x64-*) myconf+=" -arch x86_64" ;; 494 amd64|x64-*) myconf+=" -arch x86_64" ;;
430 ppc-macos) myconf+=" -arch ppc" ;; 495 ppc-macos) myconf+=" -arch ppc" ;;
431 ppc|ppc64|ppc-*) myconf+=" -arch powerpc" ;; 496 ppc|ppc64|ppc-*) myconf+=" -arch powerpc" ;;
432 sparc|sparc-*) myconf+=" -arch sparc" ;; 497 sparc|sparc-*|sparc64-*) myconf+=" -arch sparc" ;;
433 x86-macos) myconf+=" -arch x86" ;; 498 x86-macos) myconf+=" -arch x86" ;;
434 x86|x86-*) myconf+=" -arch i386" ;; 499 x86|x86-*) myconf+=" -arch i386" ;;
435 alpha|arm|ia64|mips|s390|sparc) myconf+=" -arch $(tc-arch)" ;; 500 alpha|arm|ia64|mips|s390) myconf+=" -arch $(tc-arch)" ;;
436 hppa|sh) myconf+=" -arch generic" ;; 501 hppa|sh) myconf+=" -arch generic" ;;
437 *) die "$(tc-arch) is unsupported by this eclass. Please file a bug." ;; 502 *) die "$(tc-arch) is unsupported by this eclass. Please file a bug." ;;
438 esac 503 esac
439 504
440 # 4.6: build qt-core with exceptions or qt-xmlpatterns won't build 505 # exceptions USE flag
441 local exceptions=
442 case "${PV}" in
443 4.6.*)
444 if [[ ${PN} != "qt-core" ]] && [[ ${PN} != "qt-xmlpatterns" ]]; then
445 case "${PV}:${CHOST}" in
446 4.6.0*:*-darwin*)
447 : # http://bugreports.qt.nokia.com/browse/QTBUG-5909
448 # workaround for compilation error on OSX (qt-gui)
449 ;;
450 *)
451 exceptions="-no-exceptions" 506 local exceptions="-exceptions"
452 ;; 507 in_iuse exceptions && exceptions="$(qt_use exceptions)"
453 esac
454 fi
455 ;;
456 *)
457 [[ ${PN} == "qt-xmlpatterns" ]] || exceptions="-no-exceptions"
458 ;;
459 esac
460 508
461 # note about -reduce-relocations: 509 # note about -reduce-relocations:
462 # That flag seems to introduce major breakage to applications, 510 # That flag seems to introduce major breakage to applications,
463 # mostly to be seen as a core dump with the message "QPixmap: Must 511 # mostly to be seen as a core dump with the message "QPixmap: Must
464 # construct a QApplication before a QPaintDevice" on Solaris 512 # construct a QApplication before a QPaintDevice" on Solaris
468 myconf+=" -platform $(qt_mkspecs_dir) -stl -verbose -largefile -confirm-license 516 myconf+=" -platform $(qt_mkspecs_dir) -stl -verbose -largefile -confirm-license
469 -prefix ${QTPREFIXDIR} -bindir ${QTBINDIR} -libdir ${QTLIBDIR} 517 -prefix ${QTPREFIXDIR} -bindir ${QTBINDIR} -libdir ${QTLIBDIR}
470 -datadir ${QTDATADIR} -docdir ${QTDOCDIR} -headerdir ${QTHEADERDIR} 518 -datadir ${QTDATADIR} -docdir ${QTDOCDIR} -headerdir ${QTHEADERDIR}
471 -plugindir ${QTPLUGINDIR} -sysconfdir ${QTSYSCONFDIR} 519 -plugindir ${QTPLUGINDIR} -sysconfdir ${QTSYSCONFDIR}
472 -translationdir ${QTTRANSDIR} -examplesdir ${QTEXAMPLESDIR} 520 -translationdir ${QTTRANSDIR} -examplesdir ${QTEXAMPLESDIR}
473 -demosdir ${QTDEMOSDIR} -silent -fast -opensource 521 -demosdir ${QTDEMOSDIR} -importdir ${QTIMPORTDIR} -silent -fast -opensource
474 ${exceptions} 522 ${exceptions}
475 -nomake examples -nomake demos" 523 -nomake examples -nomake demos"
476 524
477 echo "${myconf}" 525 echo "${myconf}"
478} 526}
527
528# @FUNCTION: prepare_directories
529# @USAGE: < directories >
530# @DESCRIPTION:
531# Generates makefiles for the directories set in $QT4_TARGET_DIRECTORIES
532prepare_directories() {
533 for x in "$@"; do
534 pushd "${S}"/${x} >/dev/null
535 einfo "Running qmake in: ${x}"
536 # avoid running over the maximum argument number, bug #299810
537 {
538 echo "${S}"/mkspecs/common/*.conf
539 find "${S}" -name '*.pr[io]'
540 } | xargs sed -i \
541 -e "s:\$\$\[QT_INSTALL_LIBS\]:${QTLIBDIR}:g" \
542 -e "s:\$\$\[QT_INSTALL_PLUGINS\]:${QTPLUGINDIR}:g" \
543 || die
544 "${S}"/bin/qmake "LIBS+=-L${QTLIBDIR}" "CONFIG+=nostrip" || die "qmake failed"
545 popd >/dev/null
546 done
547}
548
479 549
480# @FUNCTION: build_directories 550# @FUNCTION: build_directories
481# @USAGE: < directories > 551# @USAGE: < directories >
482# @DESCRIPTION: 552# @DESCRIPTION:
483# Compiles the code in $QT4_TARGET_DIRECTORIES 553# Compiles the code in $QT4_TARGET_DIRECTORIES
484build_directories() { 554build_directories() {
485 for x in "$@"; do 555 for x in "$@"; do
486 pushd "${S}"/${x} >/dev/null 556 pushd "${S}"/${x} >/dev/null
487 sed -i -e "s:\$\$\[QT_INSTALL_LIBS\]:${EPREFIX}/usr/$(get_libdir)/qt4:g" $(find "${S}" -name '*.pr[io]') "${S}"/mkspecs/common/*.conf || die 557 emake CC="$(tc-getCC)" \
488 "${S}"/bin/qmake "LIBS+=-L${QTLIBDIR}" "CONFIG+=nostrip" || die "qmake failed" 558 CXX="$(tc-getCXX)" \
489 emake CC="@echo compiling \$< && $(tc-getCC)" \
490 CXX="@echo compiling \$< && $(tc-getCXX)" \
491 LINK="@echo linking \$@ && $(tc-getCXX)" || die "emake failed" 559 LINK="$(tc-getCXX)" || die "emake failed"
492 popd >/dev/null 560 popd >/dev/null
493 done 561 done
494} 562}
495 563
496# @FUNCTION: install_directories 564# @FUNCTION: install_directories
519# @DESCRIPTION: 587# @DESCRIPTION:
520# List variables that should be defined at the top of QtCore/qconfig.h 588# List variables that should be defined at the top of QtCore/qconfig.h
521: ${QCONFIG_DEFINE:=} 589: ${QCONFIG_DEFINE:=}
522 590
523# @FUNCTION: install_qconfigs 591# @FUNCTION: install_qconfigs
592# @DESCRIPTION:
524# @DESCRIPTION: Install gentoo-specific mkspecs configurations 593# Install gentoo-specific mkspecs configurations
525install_qconfigs() { 594install_qconfigs() {
526 local x 595 local x
527 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} ]]; then 596 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} ]]; then
528 for x in QCONFIG_ADD QCONFIG_REMOVE; do 597 for x in QCONFIG_ADD QCONFIG_REMOVE; do
529 [[ -n ${!x} ]] && echo ${x}=${!x} >> "${T}"/${PN}-qconfig.pri 598 [[ -n ${!x} ]] && echo ${x}=${!x} >> "${T}"/${PN}-qconfig.pri
540 doins "${T}"/gentoo-${PN}-qconfig.h || die "installing ${PN}-qconfig.h failed" 609 doins "${T}"/gentoo-${PN}-qconfig.h || die "installing ${PN}-qconfig.h failed"
541 fi 610 fi
542} 611}
543 612
544# @FUNCTION: generate_qconfigs 613# @FUNCTION: generate_qconfigs
614# @DESCRIPTION:
545# @DESCRIPTION: Generates gentoo-specific configurations 615# Generates gentoo-specific configurations
546generate_qconfigs() { 616generate_qconfigs() {
547 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} || -n ${QCONFIG_DEFINE} || ${CATEGORY}/${PN} == x11-libs/qt-core ]]; then 617 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} || -n ${QCONFIG_DEFINE} || ${CATEGORY}/${PN} == x11-libs/qt-core ]]; then
548 local x qconfig_add qconfig_remove qconfig_new 618 local x qconfig_add qconfig_remove qconfig_new
549 for x in "${ROOT}${QTDATADIR}"/mkspecs/gentoo/*-qconfig.pri; do 619 for x in "${ROOT}${QTDATADIR}"/mkspecs/gentoo/*-qconfig.pri; do
550 [[ -f ${x} ]] || continue 620 [[ -f ${x} ]] || continue
564 634
565 # generate list of QT_CONFIG entries from the existing list 635 # generate list of QT_CONFIG entries from the existing list
566 # including qconfig_add and excluding qconfig_remove 636 # including qconfig_add and excluding qconfig_remove
567 for x in $(sed -n 's/^QT_CONFIG +=//p' \ 637 for x in $(sed -n 's/^QT_CONFIG +=//p' \
568 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri) ${qconfig_add}; do 638 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri) ${qconfig_add}; do
569 hasq ${x} ${qconfig_remove} || qconfig_new+=" ${x}" 639 has ${x} ${qconfig_remove} || qconfig_new+=" ${x}"
570 done 640 done
571 641
572 # replace the existing QT_CONFIG list with qconfig_new 642 # replace the existing QT_CONFIG list with qconfig_new
573 if ! sed -i -e "s/QT_CONFIG +=.*/QT_CONFIG += ${qconfig_new}/" \ 643 if ! sed -i -e "s/QT_CONFIG +=.*/QT_CONFIG += ${qconfig_new}/" \
574 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri; then 644 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri; then
598 fi 668 fi
599 fi 669 fi
600} 670}
601 671
602# @FUNCTION: qt4-build_pkg_postrm 672# @FUNCTION: qt4-build_pkg_postrm
673# @DESCRIPTION:
603# @DESCRIPTION: Generate configurations when the package is completely removed 674# Generate configurations when the package is completely removed
604qt4-build_pkg_postrm() { 675qt4-build_pkg_postrm() {
605 generate_qconfigs 676 generate_qconfigs
606} 677}
607 678
608# @FUNCTION: qt4-build_pkg_postinst 679# @FUNCTION: qt4-build_pkg_postinst
680# @DESCRIPTION:
609# @DESCRIPTION: Generate configuration, plus throws a message about possible 681# Generate configuration, plus throws a message about possible
610# breakages and proposed solutions. 682# breakages and proposed solutions.
611qt4-build_pkg_postinst() { 683qt4-build_pkg_postinst() {
612 generate_qconfigs 684 generate_qconfigs
613
614 if [[ "${PN}" == "qt-core" ]]; then
615 echo
616 ewarn "After a rebuild or upgrade of Qt, it can happen that Qt plugins (such as Qt"
617 ewarn "and KDE styles and widgets) can no longer be loaded. In this situation you"
618 ewarn "should recompile the packages providing these plugins. Also, make sure you"
619 ewarn "compile the Qt packages, and the packages that depend on it, with the same"
620 ewarn "GCC version and the same USE flag settings (especially the debug flag)."
621 ewarn
622 ewarn "Packages that typically need to be recompiled are kdelibs from KDE4, any"
623 ewarn "additional KDE4/Qt4 styles, qscintilla and PyQt4. Before filing a bug report,"
624 ewarn "make sure all your Qt4 packages are up-to-date and built with the same"
625 ewarn "configuration."
626 ewarn
627 ewarn "For more information, see http://doc.trolltech.com/${PV%.*}/plugins-howto.html"
628 echo
629 fi
630} 685}
631 686
632# @FUNCTION: skip_qmake_build_patch 687# @FUNCTION: skip_qmake_build
633# @DESCRIPTION: 688# @DESCRIPTION:
634# Don't need to build qmake, as it's already installed from qt-core 689# Don't need to build qmake, as it's already installed from qt-core
635skip_qmake_build_patch() { 690skip_qmake_build() {
636 # Don't need to build qmake, as it's already installed from qt-core 691 # Don't need to build qmake, as it's already installed from qt-core
637 sed -i -e "s:if true:if false:g" "${S}"/configure || die "Sed failed" 692 sed -i -e "s:if true:if false:g" "${S}"/configure || die "sed failed"
638} 693}
639 694
640# @FUNCTION: skip_project_generation_patch 695# @FUNCTION: skip_project_generation
641# @DESCRIPTION: 696# @DESCRIPTION:
642# Exit the script early by throwing in an exit before all of the .pro files are scanned 697# Exit the script early by throwing in an exit before all of the .pro files are scanned
643skip_project_generation_patch() { 698skip_project_generation() {
644 # Exit the script early by throwing in an exit before all of the .pro files are scanned 699 # Exit the script early by throwing in an exit before all of the .pro files are scanned
645 sed -e "s:echo \"Finding:exit 0\n\necho \"Finding:g" \ 700 sed -e "s:echo \"Finding:exit 0\n\necho \"Finding:g" \
646 -i "${S}"/configure || die "Sed failed" 701 -i "${S}"/configure || die "sed failed"
647} 702}
648 703
649# @FUNCTION: symlink_binaries_to_buildtree 704# @FUNCTION: symlink_binaries_to_buildtree
650# @DESCRIPTION: 705# @DESCRIPTION:
651# Symlink generated binaries to buildtree so they can be used during compilation 706# Symlink generated binaries to buildtree so they can be used during compilation
652# time 707# time
653symlink_binaries_to_buildtree() { 708symlink_binaries_to_buildtree() {
654 for bin in qmake moc uic rcc; do 709 for bin in qmake moc uic rcc; do
655 ln -s ${QTBINDIR}/${bin} "${S}"/bin/ || die "Symlinking ${bin} to ${S}/bin failed." 710 ln -s "${QTBINDIR}"/${bin} "${S}"/bin/ || die "symlinking ${bin} to ${S}/bin failed"
656 done 711 done
657} 712}
658 713
659# @FUNCTION: fix_library_files 714# @FUNCTION: fix_library_files
660# @DESCRIPTION: 715# @DESCRIPTION:
661# Fixes the pathes in *.la, *.prl, *.pc, as they are wrong due to sandbox and 716# Fixes the pathes in *.la, *.prl, *.pc, as they are wrong due to sandbox and
662# moves the *.pc-files into the pkgconfig directory 717# moves the *.pc-files into the pkgconfig directory
663fix_library_files() { 718fix_library_files() {
664 for libfile in "${D}"/${QTLIBDIR}/{*.la,*.prl,pkgconfig/*.pc}; do 719 for libfile in "${D}"/${QTLIBDIR}/{*.la,*.prl,pkgconfig/*.pc}; do
665 if [[ -e ${libfile} ]]; then 720 if [[ -e ${libfile} ]]; then
666 sed -i -e "s:${S}/lib:${QTLIBDIR}:g" ${libfile} || die "Sed on ${libfile} failed." 721 sed -i -e "s:${S}/lib:${QTLIBDIR}:g" ${libfile} || die "sed on ${libfile} failed"
667 fi 722 fi
668 done 723 done
669 724
670 # pkgconfig files refer to WORKDIR/bin as the moc and uic locations. Fix: 725 # pkgconfig files refer to WORKDIR/bin as the moc and uic locations. Fix:
671 for libfile in "${D}"/${QTLIBDIR}/pkgconfig/*.pc; do 726 for libfile in "${D}"/${QTLIBDIR}/pkgconfig/*.pc; do
672 if [[ -e ${libfile} ]]; then 727 if [[ -e ${libfile} ]]; then
673 sed -i -e "s:${S}/bin:${QTBINDIR}:g" ${libfile} || die "Sed failed" 728 sed -i -e "s:${S}/bin:${QTBINDIR}:g" ${libfile} || die "sed failed"
674 729
675 # Move .pc files into the pkgconfig directory 730 # Move .pc files into the pkgconfig directory
676 dodir ${QTPCDIR#${EPREFIX}} 731 dodir ${QTPCDIR#${EPREFIX}}
677 mv ${libfile} "${D}"/${QTPCDIR}/ \ 732 mv ${libfile} "${D}"/${QTPCDIR}/ \
678 || die "Moving ${libfile} to ${D}/${QTPCDIR}/ failed." 733 || die "moving ${libfile} to ${D}/${QTPCDIR}/ failed"
679 fi 734 fi
680 done 735 done
681 736
682 # Don't install an empty directory 737 # Don't install an empty directory
683 rmdir "${D}"/${QTLIBDIR}/pkgconfig 738 rmdir "${D}"/${QTLIBDIR}/pkgconfig
732 *-solaris*) 787 *-solaris*)
733 spec=solaris ;; 788 spec=solaris ;;
734 *-linux-*|*-linux) 789 *-linux-*|*-linux)
735 spec=linux ;; 790 spec=linux ;;
736 *) 791 *)
737 die "Unknown CHOST, no platform choosen." 792 die "Unknown CHOST, no platform chosen"
738 esac 793 esac
739 794
740 CXX=$(tc-getCXX) 795 CXX=$(tc-getCXX)
741 if [[ ${CXX} == *g++* ]]; then 796 if [[ ${CXX} == *g++* ]]; then
742 spec+=-g++ 797 spec+=-g++
743 elif [[ ${CXX} == *icpc* ]]; then 798 elif [[ ${CXX} == *icpc* ]]; then
744 spec+=-icc 799 spec+=-icc
745 else 800 else
746 die "Unknown compiler ${CXX}." 801 die "Unknown compiler '${CXX}'"
747 fi 802 fi
748 if [[ -n ${LIBDIR/lib} ]]; then 803 if [[ -n ${LIBDIR/lib} ]]; then
749 spec+=-${LIBDIR/lib} 804 spec+=-${LIBDIR/lib}
750 fi 805 fi
751 806
760 fi 815 fi
761 816
762 echo "${spec}" 817 echo "${spec}"
763} 818}
764 819
820# @FUNCTION: qt_assistant_cleanup
821# @RETURN: nothing
822# @DESCRIPTION:
823# Tries to clean up tools.pro for qt-assistant ebuilds.
824# Meant to be called in src_prepare().
825# Since Qt 4.7.4 this function is a no-op.
826qt_assistant_cleanup() {
827 # apply patching to qt-assistant ebuilds only
828 [[ ${PN} != "qt-assistant" ]] && return
829
830 # no longer needed for 4.7.4 and later
831 version_is_at_least "4.7.4" && return
832
833 # different versions (and branches...) may need different handling,
834 # add a case if you need special handling
835 case "${MY_PV_EXTRA}" in
836 *kde-qt*)
837 sed -e "/^[ \t]*porting/,/^[ \t]*win32.*activeqt$/d" \
838 -e "/mac/,/^embedded.*makeqpf$/d" \
839 -i tools/tools.pro || die "patching tools.pro failed"
840 ;;
841 *)
842 sed -e "/^[ \t]*porting/,/^[ \t]*win32.*activeqt$/d" \
843 -e "/mac/,/^embedded.*makeqpf$/d" \
844 -e "s/^\([ \t]*pixeltool\) /\1 qdoc3 /" \
845 -i tools/tools.pro || die "patching tools.pro failed"
846 ;;
847 esac
848}
849
850# @FUNCTION: qt_nolibx11
851# @RETURN: nothing
852# @DESCRIPTION:
853# Ignore X11 tests for packages that don't need X libraries installed
854qt_nolibx11() {
855 einfo "Removing X11 check to allow X-less compilation"
856 sed -i "/unixtests\/compile.test.*config.tests\/x11\/xlib/,/fi$/d" "${S}"/configure ||
857 die "x11 check sed failed"
858}
859
765EXPORT_FUNCTIONS pkg_setup src_unpack src_prepare src_configure src_compile src_install pkg_postrm pkg_postinst 860EXPORT_FUNCTIONS pkg_setup src_unpack src_prepare src_configure src_compile src_install src_test pkg_postrm pkg_postinst

Legend:
Removed from v.1.57  
changed lines
  Added in v.1.104

  ViewVC Help
Powered by ViewVC 1.1.20