/[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.101 Revision 1.150
1# Copyright 1999-2011 Gentoo Foundation 1# Copyright 1999-2013 Gentoo Foundation
2# Distributed under the terms of the GNU General Public License v2 2# Distributed under the terms of the GNU General Public License v2
3# $Header: /var/cvsroot/gentoo-x86/eclass/qt4-build.eclass,v 1.101 2011/11/19 20:52:50 pesa Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/qt4-build.eclass,v 1.150 2013/08/13 10:17:54 pesa 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
13 4|5) : ;;
14 *) die "qt4-build.eclass: unsupported EAPI=${EAPI:-0}" ;;
15esac
16
12inherit base eutils multilib toolchain-funcs flag-o-matic versionator 17inherit eutils flag-o-matic multilib toolchain-funcs versionator
18
19if [[ ${PV} == *9999* ]]; then
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 )"
13 28
14MY_PV=${PV/_/-} 29MY_PV=${PV/_/-}
15MY_P=qt-everywhere-opensource-src-${MY_PV} 30MY_P=qt-everywhere-opensource-src-${MY_PV}
16 31
17HOMEPAGE="http://qt.nokia.com/" 32case ${QT4_BUILD_TYPE} in
18SRC_URI="http://get.qt.nokia.com/qt/source/${MY_P}.tar.gz" 33 live)
19LICENSE="|| ( LGPL-2.1 GPL-3 )" 34 EGIT_REPO_URI="git://gitorious.org/qt/qt.git
35 https://git.gitorious.org/qt/qt.git"
36 EGIT_BRANCH=${PV%.9999}
37 ;;
38 release)
39 SRC_URI="http://download.qt-project.org/official_releases/qt/${PV%.*}/${PV}/${MY_P}.tar.gz"
40 ;;
41esac
20 42
21IUSE="aqua debug pch" 43IUSE="aqua debug pch"
44[[ ${CATEGORY}/${PN} != dev-qt/qtwebkit ]] && IUSE+=" c++0x"
45[[ ${CATEGORY}/${PN} != dev-qt/qtxmlpatterns ]] && IUSE+=" +exceptions"
22 46
23[[ ${CATEGORY}/${PN} != x11-libs/qt-xmlpatterns ]] && 47DEPEND="virtual/pkgconfig"
24[[ ${CATEGORY}/${PN} != x11-themes/qgtkstyle ]] && 48if [[ ${QT4_BUILD_TYPE} == live ]]; then
25 IUSE+=" +exceptions" 49 DEPEND+=" dev-lang/perl"
26
27if version_is_at_least 4.7.99999999; then
28 IUSE+=" c++0x qpa"
29fi 50fi
30 51
31DEPEND="dev-util/pkgconfig"
32RDEPEND="
33 !<x11-libs/qt-assistant-${PV}
34 !>x11-libs/qt-assistant-${PV}-r9999
35 !<x11-libs/qt-core-${PV}
36 !>x11-libs/qt-core-${PV}-r9999
37 !<x11-libs/qt-dbus-${PV}
38 !>x11-libs/qt-dbus-${PV}-r9999
39 !<x11-libs/qt-declarative-${PV}
40 !>x11-libs/qt-declarative-${PV}-r9999
41 !<x11-libs/qt-demo-${PV}
42 !>x11-libs/qt-demo-${PV}-r9999
43 !<x11-libs/qt-gui-${PV}
44 !>x11-libs/qt-gui-${PV}-r9999
45 !<x11-libs/qt-multimedia-${PV}
46 !>x11-libs/qt-multimedia-${PV}-r9999
47 !<x11-libs/qt-opengl-${PV}
48 !>x11-libs/qt-opengl-${PV}-r9999
49 !<x11-libs/qt-phonon-${PV}
50 !>x11-libs/qt-phonon-${PV}-r9999
51 !<x11-libs/qt-qt3support-${PV}
52 !>x11-libs/qt-qt3support-${PV}-r9999
53 !<x11-libs/qt-script-${PV}
54 !>x11-libs/qt-script-${PV}-r9999
55 !<x11-libs/qt-sql-${PV}
56 !>x11-libs/qt-sql-${PV}-r9999
57 !<x11-libs/qt-svg-${PV}
58 !>x11-libs/qt-svg-${PV}-r9999
59 !<x11-libs/qt-test-${PV}
60 !>x11-libs/qt-test-${PV}-r9999
61 !<x11-libs/qt-webkit-${PV}
62 !>x11-libs/qt-webkit-${PV}-r9999
63 !<x11-libs/qt-xmlpatterns-${PV}
64 !>x11-libs/qt-xmlpatterns-${PV}-r9999
65"
66
67S=${WORKDIR}/${MY_P} 52S=${WORKDIR}/${MY_P}
68 53
69# @FUNCTION: qt4-build_pkg_setup 54# @FUNCTION: qt4-build_pkg_setup
70# @DESCRIPTION: 55# @DESCRIPTION:
71# Sets up S, MY_P, PATH, and LD_LIBRARY_PATH 56# Sets up PATH and LD_LIBRARY_PATH.
72qt4-build_pkg_setup() { 57qt4-build_pkg_setup() {
73 [[ ${EAPI} == 2 ]] && use !prefix && EPREFIX=
74
75 # Protect users by not allowing downgrades between releases 58 # Protect users by not allowing downgrades between releases.
76 # Downgrading revisions within the same release should be allowed 59 # Downgrading revisions within the same release should be allowed.
77 if has_version '>'${CATEGORY}/${P}-r9999; then 60 if has_version ">${CATEGORY}/${P}-r9999:4"; then
78 if [[ -z ${I_KNOW_WHAT_I_AM_DOING} ]]; then 61 if [[ -z ${I_KNOW_WHAT_I_AM_DOING} ]]; then
79 eerror "Sanity check to keep you from breaking your system:" 62 eerror " *** Sanity check to keep you from breaking your system ***"
80 eerror " Downgrading Qt is completely unsupported and will break your system!" 63 eerror "Downgrading Qt is completely unsupported and will break your system!"
81 die "aborting to save your system" 64 die "aborting to save your system"
82 else 65 else
83 ewarn "Downgrading Qt is completely unsupported and will break your system!" 66 ewarn "Downgrading Qt is completely unsupported and will break your system!"
84 fi 67 fi
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 68 fi
99 69
100 PATH="${S}/bin${PATH:+:}${PATH}" 70 PATH="${S}/bin${PATH:+:}${PATH}"
101 if [[ ${CHOST} != *-darwin* ]]; then 71 if [[ ${CHOST} != *-darwin* ]]; then
102 LD_LIBRARY_PATH="${S}/lib${LD_LIBRARY_PATH:+:}${LD_LIBRARY_PATH}" 72 LD_LIBRARY_PATH="${S}/lib${LD_LIBRARY_PATH:+:}${LD_LIBRARY_PATH}"
107 # avoid extract failure. 77 # avoid extract failure.
108 [[ ${CHOST} == *-apple-darwin* ]] && \ 78 [[ ${CHOST} == *-apple-darwin* ]] && \
109 QT4_EXTRACT_DIRECTORIES="src/gui/kernel/qapplication_mac.mm 79 QT4_EXTRACT_DIRECTORIES="src/gui/kernel/qapplication_mac.mm
110 ${QT4_EXTRACT_DIRECTORIES}" 80 ${QT4_EXTRACT_DIRECTORIES}"
111 fi 81 fi
112
113 # Make sure ebuilds use the required EAPI
114 if [[ ${EAPI} != [23] ]]; then
115 eerror "The qt4-build eclass requires EAPI=2 or EAPI=3, but this ebuild is using"
116 eerror "EAPI=${EAPI:-0}. The ebuild author or editor failed. This ebuild needs to be"
117 eerror "fixed. Using qt4-build eclass without EAPI=2 or EAPI=3 will fail."
118 die "qt4-build eclass requires EAPI=2 or EAPI=3"
119 fi
120
121 if ! version_is_at_least 4.1 $(gcc-version); then
122 ewarn "Using a GCC version lower than 4.1 is not supported!"
123 fi
124} 82}
83
84# @ECLASS-VARIABLE: QT4_EXTRACT_DIRECTORIES
85# @DEFAULT_UNSET
86# @DESCRIPTION:
87# Space-separated list including the directories that will be extracted from
88# Qt tarball.
125 89
126# @ECLASS-VARIABLE: QT4_TARGET_DIRECTORIES 90# @ECLASS-VARIABLE: QT4_TARGET_DIRECTORIES
91# @DEFAULT_UNSET
127# @DESCRIPTION: 92# @DESCRIPTION:
128# Arguments for build_target_directories. Takes the directories, in which the 93# Arguments for build_target_directories. Takes the directories in which the
129# code should be compiled. This is a space-separated list 94# code should be compiled. This is a space-separated list.
130
131# @ECLASS-VARIABLE: QT4_EXTRACT_DIRECTORIES
132# @DESCRIPTION:
133# Space separated list including the directories that will be extracted from Qt
134# tarball
135 95
136# @FUNCTION: qt4-build_src_unpack 96# @FUNCTION: qt4-build_src_unpack
137# @DESCRIPTION: 97# @DESCRIPTION:
138# Unpacks the sources 98# Unpacks the sources.
139qt4-build_src_unpack() { 99qt4-build_src_unpack() {
140 setqtenv 100 setqtenv
141 local unpack_p="${MY_P}" 101
142 case "${PV}" in 102 if ! version_is_at_least 4.1 $(gcc-version); then
143 4.8.0_*) 103 ewarn "Using a GCC version lower than 4.1 is not supported."
144 unpack_p="qt-everywhere-opensource-src-${PV/_*}" 104 elif use_if_iuse c++0x && ! version_is_at_least 4.4 $(gcc-version); then
105 ewarn "USE=c++0x requires GCC 4.4 or later."
106 fi
107
108 if [[ ${CATEGORY}/${PN} == dev-qt/qtwebkit ]]; then
109 eshopts_push -s extglob
110 if is-flagq '-g?(gdb)?([1-9])'; then
111 echo
112 ewarn "You have enabled debug info (probably have -g or -ggdb in your CFLAGS/CXXFLAGS)."
113 ewarn "You may experience really long compilation times and/or increased memory usage."
114 ewarn "If compilation fails, please try removing -g/-ggdb before reporting a bug."
115 ewarn "For more info check out https://bugs.gentoo.org/307861"
116 echo
117 fi
118 eshopts_pop
119 fi
120
121 case ${QT4_BUILD_TYPE} in
122 live)
123 git-2_src_unpack
145 ;; 124 ;;
125 release)
126 local tarball="${MY_P}.tar.gz" target= targets=
127 for target in configure LICENSE.GPL3 LICENSE.LGPL projects.pro \
128 src/{qbase,qt_targets,qt_install}.pri bin config.tests \
129 mkspecs qmake ${QT4_EXTRACT_DIRECTORIES}
130 do
131 targets+="${MY_P}/${target} "
132 done
133
134 ebegin "Unpacking parts of ${tarball}:" ${targets//${MY_P}\/}
135 tar -xzf "${DISTDIR}/${tarball}" ${targets}
136 eend $? || die "failed to unpack"
137 ;;
146 esac 138 esac
147 local target targets=
148 for target in configure LICENSE.GPL3 LICENSE.LGPL projects.pro \
149 src/{qbase,qt_targets,qt_install}.pri bin config.tests mkspecs qmake \
150 ${QT4_EXTRACT_DIRECTORIES}; do
151 targets+=" ${unpack_p}/${target}"
152 done
153
154 echo tar xzf "${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
162} 139}
163 140
164# @ECLASS-VARIABLE: PATCHES 141# @ECLASS-VARIABLE: PATCHES
142# @DEFAULT_UNSET
165# @DESCRIPTION: 143# @DESCRIPTION:
166# In case you have patches to apply, specify them in PATCHES variable. Make sure 144# PATCHES array variable containing all various patches to be applied.
167# to specify the full path. This variable is necessary for src_prepare phase. 145# This variable is expected to be defined in global scope of ebuild.
168# example: 146# Make sure to specify the full path. This variable is utilised in
169# PATCHES="${FILESDIR}"/mypatch.patch 147# src_prepare() phase.
170# ${FILESDIR}"/mypatch2.patch"
171# 148#
149# @CODE
150# PATCHES=( "${FILESDIR}/mypatch.patch"
151# "${FILESDIR}/patches_folder/" )
152# @CODE
172 153
173# @FUNCTION: qt4-build_src_prepare 154# @FUNCTION: qt4-build_src_prepare
174# @DESCRIPTION: 155# @DESCRIPTION:
175# Prepare the sources before the configure phase. Strip CFLAGS if necessary, and fix 156# Prepare the sources before the configure phase. Strip CFLAGS if necessary, and fix
176# source files in order to respect CFLAGS/CXXFLAGS/LDFLAGS specified on /etc/make.conf. 157# the build system in order to respect CFLAGS/CXXFLAGS/LDFLAGS specified in make.conf.
177qt4-build_src_prepare() { 158qt4-build_src_prepare() {
178 setqtenv 159 setqtenv
179 cd "${S}"
180 160
181 # fix qt 4.7 regression that skips -fvisibility=hidden 161 if [[ ${QT4_BUILD_TYPE} == live ]]; then
182 if version_is_at_least "4.7.0_beta1"; then 162 QTDIR="." ./bin/syncqt || die "syncqt failed"
183 sed -e "s/^gcc|g++)/*gcc|*g++)/" \
184 -i config.tests/unix/fvisibility.test ||
185 die "visibility fixing sed failed"
186 fi 163 fi
187 164
188 if version_is_at_least "4.7"; then
189 # fix libX11 dependency on non X packages 165 # avoid X11 dependency in non-gui packages
190 local nolibx11_pkgs="qt-core qt-dbus qt-script qt-sql qt-test qt-xmlpatterns" 166 local nolibx11_pkgs="qtcore qtdbus qtscript qtsql qttest qtxmlpatterns"
191 has ${PN} ${nolibx11_pkgs} && qt_nolibx11 167 has ${PN} ${nolibx11_pkgs} && qt_nolibx11
192
193 qt_assistant_cleanup
194 fi
195 168
196 if use aqua; then 169 if use aqua; then
197 # provide a proper macx-g++-64 170 # provide a proper macx-g++-64
198 use x64-macos && ln -s macx-g++ mkspecs/$(qt_mkspecs_dir) 171 use x64-macos && ln -s macx-g++ mkspecs/$(qt_mkspecs_dir)
199 172
200 sed -e '/^CONFIG/s:app_bundle::' \ 173 sed -e '/^CONFIG/s:app_bundle::' \
201 -e '/^CONFIG/s:plugin_no_soname:plugin_with_soname absolute_library_soname:' \ 174 -e '/^CONFIG/s:plugin_no_soname:plugin_with_soname absolute_library_soname:' \
202 -i mkspecs/$(qt_mkspecs_dir)/qmake.conf || die "sed failed" 175 -i mkspecs/$(qt_mkspecs_dir)/qmake.conf || die
203 fi 176 fi
204 177
205 if [[ ${PN} != qt-core ]]; then 178 if [[ ${CATEGORY}/${PN} != dev-qt/qtcore ]]; then
206 skip_qmake_build 179 skip_qmake_build
207 skip_project_generation 180 skip_project_generation
208 symlink_binaries_to_buildtree 181 symlink_binaries_to_buildtree
209 fi 182 fi
210 183
211 if [[ ${CHOST} == *86*-apple-darwin* ]] ; then
212 # qmake bus errors with -O2 but -O3 works
213 replace-flags -O2 -O3
214 fi
215
216 # Bug 178652
217 if [[ $(gcc-major-version) == 3 ]] && use amd64; then
218 ewarn "Appending -fno-gcse to CFLAGS/CXXFLAGS"
219 append-flags -fno-gcse
220 fi
221
222 if use_if_iuse c++0x; then 184 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 185 append-cxxflags -std=c++0x
229 fi
230
231 # Unsupported old gcc versions - hardened needs this :(
232 if [[ $(gcc-major-version) -lt 4 ]] ; then
233 ewarn "Appending -fno-stack-protector to CXXFLAGS"
234 append-cxxflags -fno-stack-protector
235 # Bug 253127
236 sed -e "/^QMAKE_CFLAGS\t/ s:$: -fno-stack-protector-all:" \
237 -i "${S}"/mkspecs/common/g++.conf || die "sed ${S}/mkspecs/common/g++.conf failed"
238 fi 186 fi
239 187
240 # Bug 261632 188 # Bug 261632
241 if use ppc64; then 189 if use ppc64; then
242 ewarn "Appending -mminimal-toc to CFLAGS/CXXFLAGS"
243 append-flags -mminimal-toc 190 append-flags -mminimal-toc
244 fi 191 fi
245 192
246 # Bug 282984 && Bug 295530 193 # Bug 373061
247 sed -e "s:\(^SYSTEM_VARIABLES\):CC=\"$(tc-getCC)\"\nCXX=\"$(tc-getCXX)\"\nCFLAGS=\"${CFLAGS}\"\nCXXFLAGS=\"${CXXFLAGS}\"\nLDFLAGS=\"${LDFLAGS}\"\n\1:" \ 194 # qmake bus errors with -O2 or -O3 but -O1 works
248 -i configure || die "sed qmake compilers failed" 195 if [[ ${CHOST} == *86*-apple-darwin* ]]; then
249 196 replace-flags -O[23] -O1
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 197 fi
198
199 # Bug 417105
200 # graphite on gcc 4.7 causes miscompilations
201 if [[ $(gcc-version) == "4.7" ]]; then
202 filter-flags -fgraphite-identity
203 fi
204
205 # Respect CC, CXX, {C,CXX,LD}FLAGS in .qmake.cache
206 sed -e "/^SYSTEM_VARIABLES=/i \
207 CC='$(tc-getCC)'\n\
208 CXX='$(tc-getCXX)'\n\
209 CFLAGS='${CFLAGS}'\n\
210 CXXFLAGS='${CXXFLAGS}'\n\
211 LDFLAGS='${LDFLAGS}'\n\
212 QMakeVar set QMAKE_CFLAGS_RELEASE\n\
213 QMakeVar set QMAKE_CFLAGS_DEBUG\n\
214 QMakeVar set QMAKE_CXXFLAGS_RELEASE\n\
215 QMakeVar set QMAKE_CXXFLAGS_DEBUG\n\
216 QMakeVar set QMAKE_LFLAGS_RELEASE\n\
217 QMakeVar set QMAKE_LFLAGS_DEBUG\n"\
218 -i configure \
219 || die "sed SYSTEM_VARIABLES failed"
220
221 # Respect CC, CXX, LINK and *FLAGS in config.tests
222 find config.tests/unix -name '*.test' -type f -print0 | xargs -0 \
223 sed -i -e "/bin\/qmake/ s: \"\$SRCDIR/: \
224 'QMAKE_CC=$(tc-getCC)' 'QMAKE_CXX=$(tc-getCXX)' 'QMAKE_LINK=$(tc-getCXX)' \
225 'QMAKE_CFLAGS+=${CFLAGS}' 'QMAKE_CXXFLAGS+=${CXXFLAGS}' 'QMAKE_LFLAGS+=${LDFLAGS}'&:" \
226 || die "sed config.tests failed"
257 227
258 # Bug 172219 228 # Bug 172219
259 sed -e "s:X11R6/::" \ 229 sed -e 's:/X11R6/:/:' -i mkspecs/$(qt_mkspecs_dir)/qmake.conf || die
260 -i "${S}"/mkspecs/$(qt_mkspecs_dir)/qmake.conf || die "sed ${S}/mkspecs/$(qt_mkspecs_dir)/qmake.conf failed"
261 230
262 if [[ ${CHOST} == *-darwin* ]]; then 231 if [[ ${CHOST} == *-darwin* ]]; then
263 # Set FLAGS *and* remove -arch, since our gcc-apple is multilib 232 # Set FLAGS *and* remove -arch, since our gcc-apple is multilib
264 # crippled (by design) :/ 233 # crippled (by design) :/
234 local mac_gpp_conf=
235 if [[ -f mkspecs/common/mac-g++.conf ]]; then
236 # qt < 4.8 has mac-g++.conf
237 mac_gpp_conf="mkspecs/common/mac-g++.conf"
238 elif [[ -f mkspecs/common/g++-macx.conf ]]; then
239 # qt >= 4.8 has g++-macx.conf
240 mac_gpp_conf="mkspecs/common/g++-macx.conf"
241 else
242 die "no known conf file for mac found"
243 fi
244 sed \
265 sed -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \ 245 -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \
266 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \ 246 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \
267 -e "s:QMAKE_LFLAGS_RELEASE.*=.*:QMAKE_LFLAGS_RELEASE=-headerpad_max_install_names ${LDFLAGS}:" \ 247 -e "s:QMAKE_LFLAGS_RELEASE.*=.*:QMAKE_LFLAGS_RELEASE=-headerpad_max_install_names ${LDFLAGS}:" \
268 -e "s:-arch\s\w*::g" \ 248 -e "s:-arch\s\w*::g" \
269 -i mkspecs/common/mac-g++.conf || die "sed mkspecs/common/mac-g++.conf failed" 249 -i ${mac_gpp_conf} \
250 || die "sed ${mac_gpp_conf} failed"
270 251
271 # Fix configure's -arch settings that appear in qmake/Makefile and also 252 # Fix configure's -arch settings that appear in qmake/Makefile and also
272 # fix arch handling (automagically duplicates our -arch arg and breaks 253 # fix arch handling (automagically duplicates our -arch arg and breaks
273 # pch). Additionally disable Xarch support. 254 # pch). Additionally disable Xarch support.
255 local mac_gcc_confs="${mac_gpp_conf}"
256 if [[ -f mkspecs/common/gcc-base-macx.conf ]]; then
257 mac_gcc_confs+=" mkspecs/common/gcc-base-macx.conf"
258 fi
274 sed \ 259 sed \
275 -e "s:-arch i386::" \ 260 -e "s:-arch i386::" \
276 -e "s:-arch ppc::" \ 261 -e "s:-arch ppc::" \
277 -e "s:-arch x86_64::" \ 262 -e "s:-arch x86_64::" \
278 -e "s:-arch ppc64::" \ 263 -e "s:-arch ppc64::" \
279 -e "s:-arch \$i::" \ 264 -e "s:-arch \$i::" \
280 -e "/if \[ ! -z \"\$NATIVE_64_ARCH\" \]; then/,/fi/ d" \ 265 -e "/if \[ ! -z \"\$NATIVE_64_ARCH\" \]; then/,/fi/ d" \
281 -e "s:CFG_MAC_XARCH=yes:CFG_MAC_XARCH=no:g" \ 266 -e "s:CFG_MAC_XARCH=yes:CFG_MAC_XARCH=no:g" \
282 -e "s:-Xarch_x86_64::g" \ 267 -e "s:-Xarch_x86_64::g" \
283 -e "s:-Xarch_ppc64::g" \ 268 -e "s:-Xarch_ppc64::g" \
284 -i configure mkspecs/common/mac-g++.conf || die "sed configure failed" 269 -i configure ${mac_gcc_confs} \
270 || die "sed -arch/-Xarch failed"
285 271
286 # On Snow Leopard don't fall back to 10.5 deployment target. 272 # On Snow Leopard don't fall back to 10.5 deployment target.
287 if [[ ${CHOST} == *-apple-darwin10 ]] ; then 273 if [[ ${CHOST} == *-apple-darwin10 ]]; then
288 sed -e "s:QMakeVar set QMAKE_MACOSX_DEPLOYMENT_TARGET.*:QMakeVar set QMAKE_MACOSX_DEPLOYMENT_TARGET 10.6:g" \ 274 sed -e "s:QMakeVar set QMAKE_MACOSX_DEPLOYMENT_TARGET.*:QMakeVar set QMAKE_MACOSX_DEPLOYMENT_TARGET 10.6:g" \
289 -e "s:-mmacosx-version-min=10.[0-9]:-mmacosx-version-min=10.6:g" \ 275 -e "s:-mmacosx-version-min=10.[0-9]:-mmacosx-version-min=10.6:g" \
290 -i configure mkspecs/common/mac-g++.conf || die "sed configure failed" 276 -i configure ${mac_gpp_conf} \
277 || die "sed deployment target failed"
291 fi 278 fi
292 fi 279 fi
293 280
294 # this one is needed for all systems with a separate -liconv, apart from 281 # this one is needed for all systems with a separate -liconv, apart from
295 # Darwin, for which the sources already cater for -liconv 282 # Darwin, for which the sources already cater for -liconv
296 if use !elibc_glibc && [[ ${CHOST} != *-darwin* ]] ; then 283 if use !elibc_glibc && [[ ${CHOST} != *-darwin* ]]; then
297 sed \ 284 sed -e 's|mac:\(LIBS += -liconv\)|\1|g' \
298 -e "s|mac:LIBS += -liconv|LIBS += -liconv|g" \
299 -i config.tests/unix/iconv/iconv.pro \ 285 -i config.tests/unix/iconv/iconv.pro \
300 || die "sed on iconv.pro failed" 286 || die "sed iconv.pro failed"
301 fi 287 fi
302 288
303 # we need some patches for Solaris 289 # we need some patches for Solaris
304 sed -i \
305 -e '/^QMAKE_LFLAGS_THREAD/a\QMAKE_LFLAGS_DYNAMIC_LIST = -Wl,--dynamic-list,' \ 290 sed -i -e '/^QMAKE_LFLAGS_THREAD/a\QMAKE_LFLAGS_DYNAMIC_LIST = -Wl,--dynamic-list,' \
306 mkspecs/$(qt_mkspecs_dir)/qmake.conf || die 291 mkspecs/$(qt_mkspecs_dir)/qmake.conf || die
307 # use GCC over SunStudio 292 # use GCC over SunStudio
308 sed -i -e '/PLATFORM=solaris-cc/s/cc/g++/' configure || die 293 sed -i -e '/PLATFORM=solaris-cc/s/cc/g++/' configure || die
309 # don't flirt with non-Prefix stuff, we're quite possessive 294 # do not flirt with non-Prefix stuff, we're quite possessive
310 sed -i -e '/^QMAKE_\(LIB\|INC\)DIR\(_X11\|_OPENGL\|\)\t/s/=.*$/=/' \ 295 sed -i -e '/^QMAKE_\(LIB\|INC\)DIR\(_X11\|_OPENGL\|\)\t/s/=.*$/=/' \
311 mkspecs/$(qt_mkspecs_dir)/qmake.conf || die 296 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
314 297
315 base_src_prepare 298 # apply patches
299 [[ -n ${PATCHES[@]} ]] && epatch "${PATCHES[@]}"
300 epatch_user
316} 301}
317 302
318# @FUNCTION: qt4-build_src_configure 303# @FUNCTION: qt4-build_src_configure
319# @DESCRIPTION: 304# @DESCRIPTION:
320# Default configure phase 305# Default configure phase
321qt4-build_src_configure() { 306qt4-build_src_configure() {
322 setqtenv 307 setqtenv
323 myconf="$(standard_configure_options) ${myconf}" 308
309 local conf="
310 -prefix ${QTPREFIXDIR}
311 -bindir ${QTBINDIR}
312 -libdir ${QTLIBDIR}
313 -docdir ${QTDOCDIR}
314 -headerdir ${QTHEADERDIR}
315 -plugindir ${QTPLUGINDIR}
316 -importdir ${QTIMPORTDIR}
317 -datadir ${QTDATADIR}
318 -translationdir ${QTTRANSDIR}
319 -sysconfdir ${QTSYSCONFDIR}
320 -examplesdir ${QTEXAMPLESDIR}
321 -demosdir ${QTDEMOSDIR}
322 -opensource -confirm-license
323 -shared -fast -largefile -stl -verbose
324 -nomake examples -nomake demos"
325
326 # ARCH is set on Gentoo. Qt now falls back to generic on an unsupported
327 # $(tc-arch). Therefore we convert it to supported values.
328 case "$(tc-arch)" in
329 amd64|x64-*) conf+=" -arch x86_64" ;;
330 ppc-macos) conf+=" -arch ppc" ;;
331 ppc|ppc64|ppc-*) conf+=" -arch powerpc" ;;
332 sparc|sparc-*|sparc64-*) conf+=" -arch sparc" ;;
333 x86-macos) conf+=" -arch x86" ;;
334 x86|x86-*) conf+=" -arch i386" ;;
335 alpha|arm|ia64|mips|s390) conf+=" -arch $(tc-arch)" ;;
336 hppa|sh) conf+=" -arch generic" ;;
337 *) die "$(tc-arch) is unsupported by this eclass. Please file a bug." ;;
338 esac
339
340 conf+=" -platform $(qt_mkspecs_dir)"
341
342 [[ $(get_libdir) != lib ]] && conf+=" -L${EPREFIX}/usr/$(get_libdir)"
343
344 # debug/release
345 if use debug; then
346 conf+=" -debug"
347 else
348 conf+=" -release"
349 fi
350 conf+=" -no-separate-debug-info"
351
352 # exceptions USE flag
353 conf+=" $(in_iuse exceptions && qt_use exceptions || echo -exceptions)"
354
355 # disable rpath (bug 380415), except on prefix (bug 417169)
356 use prefix || conf+=" -no-rpath"
357
358 # precompiled headers don't work on hardened, where the flag is masked
359 conf+=" $(qt_use pch)"
360
361 # -reduce-relocations
362 # This flag seems to introduce major breakage to applications,
363 # mostly to be seen as a core dump with the message "QPixmap: Must
364 # construct a QApplication before a QPaintDevice" on Solaris.
365 # -- Daniel Vergien
366 [[ ${CHOST} != *-solaris* ]] && conf+=" -reduce-relocations"
324 367
325 # this one is needed for all systems with a separate -liconv, apart from 368 # this one is needed for all systems with a separate -liconv, apart from
326 # Darwin, for which the sources already cater for -liconv 369 # Darwin, for which the sources already cater for -liconv
327 use !elibc_glibc && [[ ${CHOST} != *-darwin* ]] && \ 370 if use !elibc_glibc && [[ ${CHOST} != *-darwin* ]]; then
328 myconf+=" -liconv" 371 conf+=" -liconv"
372 fi
329 373
330 if use_if_iuse glib; then 374 if use_if_iuse glib; then
331 # use -I, -L and -l from configure
332 local glibflags="$(pkg-config --cflags --libs glib-2.0 gthread-2.0)" 375 local glibflags="$(pkg-config --cflags --libs glib-2.0 gthread-2.0)"
333 # avoid the -pthread argument 376 # avoid the -pthread argument
334 myconf+=" ${glibflags//-pthread}" 377 conf+=" ${glibflags//-pthread}"
335 unset glibflags 378 unset glibflags
336 fi 379 fi
337 380
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
347 if use aqua ; then 381 if use aqua; then
348 # On (snow) leopard use the new (frameworked) cocoa code. 382 # On (snow) leopard use the new (frameworked) cocoa code.
349 if [[ ${CHOST##*-darwin} -ge 9 ]] ; then 383 if [[ ${CHOST##*-darwin} -ge 9 ]]; then
350 myconf+=" -cocoa -framework" 384 conf+=" -cocoa -framework"
385 # We need the source's headers, not the installed ones.
386 conf+=" -I${S}/include"
387 # Add hint for the framework location.
388 conf+=" -F${QTLIBDIR}"
351 389
352 # We are crazy and build cocoa + qt3support :-) 390 # We are crazy and build cocoa + qt3support :-)
353 if use qt3support; then 391 if use qt3support; then
354 sed -e "/case \"\$PLATFORM,\$CFG_MAC_COCOA\" in/,/;;/ s|CFG_QT3SUPPORT=\"no\"|CFG_QT3SUPPORT=\"yes\"|" \ 392 sed -e "/case \"\$PLATFORM,\$CFG_MAC_COCOA\" in/,/;;/ s|CFG_QT3SUPPORT=\"no\"|CFG_QT3SUPPORT=\"yes\"|" \
355 -i configure 393 -i configure || die
356 fi 394 fi
357 395 else
358 # We need the source's headers, not the installed ones. 396 conf+=" -no-framework"
359 myconf+=" -I${S}/include"
360
361 # Add hint for the framework location.
362 myconf+=" -F${QTLIBDIR}"
363 fi 397 fi
364 else 398 else
365 # freetype2 include dir is non-standard, thus include it on configure 399 # freetype2 include dir is non-standard, thus pass it to configure
366 # use -I from configure
367 myconf+=" $(pkg-config --cflags freetype2)" 400 conf+=" $(pkg-config --cflags-only-I freetype2)"
368 fi 401 fi
369 402
370 # Disable SSE4.x, since auto-detection is currently broken 403 conf+=" ${myconf}"
371 # Upstream bug http://bugreports.qt.nokia.com/browse/QTBUG-13623 404 myconf=
372 [[ ${PV} == "4.7.1" ]] && myconf+=" -no-sse4.1 -no-sse4.2"
373 405
374 echo ./configure ${myconf} 406 echo ./configure ${conf}
375 ./configure ${myconf} || die "./configure failed" 407 ./configure ${conf} || die "./configure failed"
376 myconf=""
377 408
378 prepare_directories ${QT4_TARGET_DIRECTORIES} 409 prepare_directories ${QT4_TARGET_DIRECTORIES}
379} 410}
380 411
381# @FUNCTION: qt4-build_src_compile 412# @FUNCTION: qt4-build_src_compile
389 420
390# @FUNCTION: qt4-build_src_test 421# @FUNCTION: qt4-build_src_test
391# @DESCRIPTION: 422# @DESCRIPTION:
392# Runs tests only in target directories. 423# Runs tests only in target directories.
393qt4-build_src_test() { 424qt4-build_src_test() {
425 # QtMultimedia does not have any test suite (bug #332299)
426 [[ ${CATEGORY}/${PN} == dev-qt/qtmultimedia ]] && return
427
394 for dir in ${QT4_TARGET_DIRECTORIES}; do 428 for dir in ${QT4_TARGET_DIRECTORIES}; do
395 emake -j1 check -C ${dir} 429 emake -j1 check -C ${dir}
396 done 430 done
397} 431}
398 432
399# @FUNCTION: fix_includes 433# @FUNCTION: fix_includes
400# @DESCRIPTION: 434# @DESCRIPTION:
401# For MacOSX we need to add some symlinks when frameworks are 435# For MacOS X we need to add some symlinks when frameworks are
402# being used, to avoid complications with some more or less stupid packages. 436# being used, to avoid complications with some more or less stupid packages.
403fix_includes() { 437fix_includes() {
404 if use aqua && [[ ${CHOST##*-darwin} -ge 9 ]] ; then 438 if use aqua && [[ ${CHOST##*-darwin} -ge 9 ]]; then
439 local frw dest f h rdir
405 # Some packages tend to include <Qt/...> 440 # Some packages tend to include <Qt/...>
406 dodir "${QTHEADERDIR#${EPREFIX}}"/Qt 441 dodir "${QTHEADERDIR#${EPREFIX}}"/Qt
407 442
408 # Fake normal headers when frameworks are installed... eases life later on 443 # Fake normal headers when frameworks are installed... eases life later
409 local dest f 444 # on, make sure we use relative links though, as some ebuilds assume
445 # these dirs exist in src_install to add additional files
446 f=${QTHEADERDIR}
447 h=${QTLIBDIR}
448 while [[ -n ${f} && ${f%%/*} == ${h%%/*} ]] ; do
449 f=${f#*/}
450 h=${h#*/}
451 done
452 rdir=${h}
453 f="../"
454 while [[ ${h} == */* ]] ; do
455 f="${f}../"
456 h=${h#*/}
457 done
458 rdir="${f}${rdir}"
459
410 for frw in "${D}${QTLIBDIR}"/*.framework; do 460 for frw in "${D}${QTLIBDIR}"/*.framework; do
411 [[ -e "${frw}"/Headers ]] || continue 461 [[ -e "${frw}"/Headers ]] || continue
412 f=$(basename ${frw}) 462 f=$(basename ${frw})
413 dest="${QTHEADERDIR#${EPREFIX}}"/${f%.framework} 463 dest="${QTHEADERDIR#${EPREFIX}}"/${f%.framework}
414 dosym "${QTLIBDIR#${EPREFIX}}"/${f}/Headers "${dest}" 464 dosym "${rdir}"/${f}/Headers "${dest}"
415 465
416 # Link normal headers as well. 466 # Link normal headers as well.
417 for hdr in "${D}/${QTLIBDIR}/${f}"/Headers/*; do 467 for hdr in "${D}/${QTLIBDIR}/${f}"/Headers/*; do
418 h=$(basename ${hdr}) 468 h=$(basename ${hdr})
419 dosym "${QTLIBDIR#${EPREFIX}}"/${f}/Headers/${h} "${QTHEADERDIR#${EPREFIX}}"/Qt/${h} 469 dosym "../${rdir}"/${f}/Headers/${h} \
470 "${QTHEADERDIR#${EPREFIX}}"/Qt/${h}
420 done 471 done
421 done 472 done
422 fi 473 fi
423} 474}
424 475
425# @FUNCTION: qt4-build_src_install 476# @FUNCTION: qt4-build_src_install
426# @DESCRIPTION: 477# @DESCRIPTION:
427# Perform the actual installation including some library fixes. 478# Perform the actual installation including some library fixes.
428qt4-build_src_install() { 479qt4-build_src_install() {
429 [[ ${EAPI} == 2 ]] && use !prefix && ED=${D}
430 setqtenv 480 setqtenv
431 481
432 install_directories ${QT4_TARGET_DIRECTORIES} 482 install_directories ${QT4_TARGET_DIRECTORIES}
433 install_qconfigs 483 install_qconfigs
434 fix_library_files 484 fix_library_files
435 fix_includes 485 fix_includes
436 486
437 # remove .la files since we are building only shared Qt libraries 487 # remove .la files since we are building only shared libraries
438 find "${D}"${QTLIBDIR} -name "*.la" -print0 | xargs -0 rm 488 prune_libtool_files
439} 489}
440 490
441# @FUNCTION: setqtenv 491# @FUNCTION: setqtenv
492# @INTERNAL
442setqtenv() { 493setqtenv() {
443 # Set up installation directories 494 # Set up installation directories
444 QTBASEDIR=${EPREFIX}/usr/$(get_libdir)/qt4
445 QTPREFIXDIR=${EPREFIX}/usr 495 QTPREFIXDIR=${EPREFIX}/usr
446 QTBINDIR=${EPREFIX}/usr/bin 496 QTBINDIR=${QTPREFIXDIR}/bin
447 QTLIBDIR=${EPREFIX}/usr/$(get_libdir)/qt4 497 QTLIBDIR=${QTPREFIXDIR}/$(get_libdir)/qt4
448 QMAKE_LIBDIR_QT=${QTLIBDIR}
449 QTPCDIR=${EPREFIX}/usr/$(get_libdir)/pkgconfig 498 QTPCDIR=${QTPREFIXDIR}/$(get_libdir)/pkgconfig
450 QTDATADIR=${EPREFIX}/usr/share/qt4
451 QTDOCDIR=${EPREFIX}/usr/share/doc/qt-${PV} 499 QTDOCDIR=${QTPREFIXDIR}/share/doc/qt-${PV}
452 QTHEADERDIR=${EPREFIX}/usr/include/qt4 500 QTHEADERDIR=${QTPREFIXDIR}/include/qt4
453 QTPLUGINDIR=${QTLIBDIR}/plugins 501 QTPLUGINDIR=${QTLIBDIR}/plugins
502 QTIMPORTDIR=${QTLIBDIR}/imports
503 QTDATADIR=${QTPREFIXDIR}/share/qt4
504 QTTRANSDIR=${QTDATADIR}/translations
454 QTSYSCONFDIR=${EPREFIX}/etc/qt4 505 QTSYSCONFDIR=${EPREFIX}/etc/qt4
455 QTTRANSDIR=${QTDATADIR}/translations
456 QTEXAMPLESDIR=${QTDATADIR}/examples 506 QTEXAMPLESDIR=${QTDATADIR}/examples
457 QTDEMOSDIR=${QTDATADIR}/demos 507 QTDEMOSDIR=${QTDATADIR}/demos
458 QT_INSTALL_PREFIX=${EPREFIX}/usr/$(get_libdir)/qt4 508 QMAKE_LIBDIR_QT=${QTLIBDIR}
509
459 PLATFORM=$(qt_mkspecs_dir) 510 PLATFORM=$(qt_mkspecs_dir)
460
461 unset QMAKESPEC 511 unset QMAKESPEC
462}
463 512
464# @FUNCTION: standard_configure_options 513 export XDG_CONFIG_HOME="${T}"
465# @DESCRIPTION:
466# Sets up some standard configure options, like libdir (if necessary), whether
467# debug info is wanted or not.
468standard_configure_options() {
469 local myconf=
470
471 [[ $(get_libdir) != lib ]] && myconf+=" -L${EPREFIX}/usr/$(get_libdir)"
472
473 # Disable visibility explicitly if gcc version isn't 4
474 if [[ $(gcc-major-version) -lt 4 ]]; then
475 myconf+=" -no-reduce-exports"
476 fi
477
478 # precompiled headers doesn't work on hardened, where the flag is masked.
479 myconf+=" $(qt_use pch)"
480
481 if use debug; then
482 myconf+=" -debug"
483 else
484 myconf+=" -release"
485 fi
486 myconf+=" -no-separate-debug-info"
487
488 use aqua && myconf+=" -no-framework"
489
490 # ARCH is set on Gentoo. Qt now falls back to generic on an unsupported
491 # $(tc-arch). Therefore we convert it to supported values.
492 case "$(tc-arch)" in
493 amd64|x64-*) myconf+=" -arch x86_64" ;;
494 ppc-macos) myconf+=" -arch ppc" ;;
495 ppc|ppc64|ppc-*) myconf+=" -arch powerpc" ;;
496 sparc|sparc-*) myconf+=" -arch sparc" ;;
497 x86-macos) myconf+=" -arch x86" ;;
498 x86|x86-*) myconf+=" -arch i386" ;;
499 alpha|arm|ia64|mips|s390|sparc) myconf+=" -arch $(tc-arch)" ;;
500 hppa|sh) myconf+=" -arch generic" ;;
501 *) die "$(tc-arch) is unsupported by this eclass. Please file a bug." ;;
502 esac
503
504 # exceptions USE flag
505 local exceptions="-exceptions"
506 in_iuse exceptions && exceptions="$(qt_use exceptions)"
507
508 # note about -reduce-relocations:
509 # That flag seems to introduce major breakage to applications,
510 # mostly to be seen as a core dump with the message "QPixmap: Must
511 # construct a QApplication before a QPaintDevice" on Solaris
512 # -- Daniel Vergien
513 [[ ${CHOST} != *-solaris* ]] && myconf+=" -reduce-relocations"
514
515 myconf+=" -platform $(qt_mkspecs_dir) -stl -verbose -largefile -confirm-license
516 -prefix ${QTPREFIXDIR} -bindir ${QTBINDIR} -libdir ${QTLIBDIR}
517 -datadir ${QTDATADIR} -docdir ${QTDOCDIR} -headerdir ${QTHEADERDIR}
518 -plugindir ${QTPLUGINDIR} -sysconfdir ${QTSYSCONFDIR}
519 -translationdir ${QTTRANSDIR} -examplesdir ${QTEXAMPLESDIR}
520 -demosdir ${QTDEMOSDIR} -silent -fast -opensource
521 ${exceptions}
522 -nomake examples -nomake demos"
523
524 echo "${myconf}"
525} 514}
526 515
527# @FUNCTION: prepare_directories 516# @FUNCTION: prepare_directories
528# @USAGE: < directories > 517# @USAGE: < directories >
518# @INTERNAL
529# @DESCRIPTION: 519# @DESCRIPTION:
530# Generates makefiles for the directories set in $QT4_TARGET_DIRECTORIES 520# Generates Makefiles for the given list of directories.
531prepare_directories() { 521prepare_directories() {
532 for x in "$@"; do 522 for x in "$@"; do
533 pushd "${S}"/${x} >/dev/null 523 pushd "${S}"/${x} >/dev/null || die
534 einfo "Running qmake in: ${x}" 524 einfo "Running qmake in: ${x}"
535 # avoid running over the maximum argument number, bug #299810 525 "${S}"/bin/qmake \
536 { 526 "LIBS+=-L${QTLIBDIR}" \
537 echo "${S}"/mkspecs/common/*.conf 527 "CONFIG+=nostrip" \
538 find "${S}" -name '*.pr[io]' 528 || die "qmake failed"
539 } | xargs sed -i -e "s:\$\$\[QT_INSTALL_LIBS\]:${EPREFIX}/usr/$(get_libdir)/qt4:g" || die
540 "${S}"/bin/qmake "LIBS+=-L${QTLIBDIR}" "CONFIG+=nostrip" || die "qmake failed"
541 popd >/dev/null 529 popd >/dev/null || die
542 done 530 done
543} 531}
544
545 532
546# @FUNCTION: build_directories 533# @FUNCTION: build_directories
547# @USAGE: < directories > 534# @USAGE: < directories >
535# @INTERNAL
548# @DESCRIPTION: 536# @DESCRIPTION:
549# Compiles the code in $QT4_TARGET_DIRECTORIES 537# Compiles the code in the given list of directories.
550build_directories() { 538build_directories() {
551 for x in "$@"; do 539 for x in "$@"; do
552 pushd "${S}"/${x} >/dev/null 540 pushd "${S}"/${x} >/dev/null || die
541 emake \
542 AR="$(tc-getAR) cqs" \
553 emake CC="$(tc-getCC)" \ 543 CC="$(tc-getCC)" \
554 CXX="$(tc-getCXX)" \ 544 CXX="$(tc-getCXX)" \
555 LINK="$(tc-getCXX)" || die "emake failed" 545 LINK="$(tc-getCXX)" \
546 RANLIB=":" \
547 STRIP=":"
556 popd >/dev/null 548 popd >/dev/null || die
557 done 549 done
558} 550}
559 551
560# @FUNCTION: install_directories 552# @FUNCTION: install_directories
561# @USAGE: < directories > 553# @USAGE: < directories >
554# @INTERNAL
562# @DESCRIPTION: 555# @DESCRIPTION:
563# run emake install in the given directories, which are separated by spaces 556# Runs emake install in the given directories, which are separated by spaces.
564install_directories() { 557install_directories() {
565 for x in "$@"; do 558 for x in "$@"; do
566 pushd "${S}"/${x} >/dev/null || die "Can't pushd ${S}/${x}" 559 pushd "${S}"/${x} >/dev/null || die
567 emake INSTALL_ROOT="${D}" install || die "emake install failed" 560 emake INSTALL_ROOT="${D}" install
568 popd >/dev/null || die "Can't popd from ${S}/${x}" 561 popd >/dev/null || die
569 done 562 done
570} 563}
571 564
572# @ECLASS-VARIABLE: QCONFIG_ADD 565# @ECLASS-VARIABLE: QCONFIG_ADD
573# @DESCRIPTION: 566# @DESCRIPTION:
583# @DESCRIPTION: 576# @DESCRIPTION:
584# List variables that should be defined at the top of QtCore/qconfig.h 577# List variables that should be defined at the top of QtCore/qconfig.h
585: ${QCONFIG_DEFINE:=} 578: ${QCONFIG_DEFINE:=}
586 579
587# @FUNCTION: install_qconfigs 580# @FUNCTION: install_qconfigs
581# @INTERNAL
588# @DESCRIPTION: 582# @DESCRIPTION:
589# Install gentoo-specific mkspecs configurations 583# Install gentoo-specific mkspecs configurations.
590install_qconfigs() { 584install_qconfigs() {
591 local x 585 local x
592 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} ]]; then 586 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} ]]; then
593 for x in QCONFIG_ADD QCONFIG_REMOVE; do 587 for x in QCONFIG_ADD QCONFIG_REMOVE; do
594 [[ -n ${!x} ]] && echo ${x}=${!x} >> "${T}"/${PN}-qconfig.pri 588 [[ -n ${!x} ]] && echo ${x}=${!x} >> "${T}"/${PN}-qconfig.pri
595 done 589 done
596 insinto ${QTDATADIR#${EPREFIX}}/mkspecs/gentoo 590 insinto ${QTDATADIR#${EPREFIX}}/mkspecs/gentoo
597 doins "${T}"/${PN}-qconfig.pri || die "installing ${PN}-qconfig.pri failed" 591 doins "${T}"/${PN}-qconfig.pri
598 fi 592 fi
599 593
600 if [[ -n ${QCONFIG_DEFINE} ]]; then 594 if [[ -n ${QCONFIG_DEFINE} ]]; then
601 for x in ${QCONFIG_DEFINE}; do 595 for x in ${QCONFIG_DEFINE}; do
602 echo "#define ${x}" >> "${T}"/gentoo-${PN}-qconfig.h 596 echo "#define ${x}" >> "${T}"/gentoo-${PN}-qconfig.h
603 done 597 done
604 insinto ${QTHEADERDIR#${EPREFIX}}/Gentoo 598 insinto ${QTHEADERDIR#${EPREFIX}}/Gentoo
605 doins "${T}"/gentoo-${PN}-qconfig.h || die "installing ${PN}-qconfig.h failed" 599 doins "${T}"/gentoo-${PN}-qconfig.h
606 fi 600 fi
607} 601}
608 602
609# @FUNCTION: generate_qconfigs 603# @FUNCTION: generate_qconfigs
604# @INTERNAL
610# @DESCRIPTION: 605# @DESCRIPTION:
611# Generates gentoo-specific configurations 606# Generates gentoo-specific qconfig.{h,pri}.
612generate_qconfigs() { 607generate_qconfigs() {
613 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} || -n ${QCONFIG_DEFINE} || ${CATEGORY}/${PN} == x11-libs/qt-core ]]; then 608 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} || -n ${QCONFIG_DEFINE} || ${CATEGORY}/${PN} == dev-qt/qtcore ]]; then
614 local x qconfig_add qconfig_remove qconfig_new 609 local x qconfig_add qconfig_remove qconfig_new
615 for x in "${ROOT}${QTDATADIR}"/mkspecs/gentoo/*-qconfig.pri; do 610 for x in "${ROOT}${QTDATADIR}"/mkspecs/gentoo/*-qconfig.pri; do
616 [[ -f ${x} ]] || continue 611 [[ -f ${x} ]] || continue
617 qconfig_add+=" $(sed -n 's/^QCONFIG_ADD=//p' "${x}")" 612 qconfig_add+=" $(sed -n 's/^QCONFIG_ADD=//p' "${x}")"
618 qconfig_remove+=" $(sed -n 's/^QCONFIG_REMOVE=//p' "${x}")" 613 qconfig_remove+=" $(sed -n 's/^QCONFIG_REMOVE=//p' "${x}")"
619 done 614 done
620 615
621 # these error checks do not use die because dying in pkg_post{inst,rm} 616 # these error checks do not use die because dying in pkg_post{inst,rm}
622 # just makes things worse. 617 # just makes things worse.
623 if [[ -e "${ROOT}${QTDATADIR}"/mkspecs/gentoo/qconfig.pri ]]; then 618 if [[ -e "${ROOT}${QTDATADIR}"/mkspecs/gentoo/qconfig.pri ]]; then
624 # start with the qconfig.pri that qt-core installed 619 # start with the qconfig.pri that qtcore installed
625 if ! cp "${ROOT}${QTDATADIR}"/mkspecs/gentoo/qconfig.pri \ 620 if ! cp "${ROOT}${QTDATADIR}"/mkspecs/gentoo/qconfig.pri \
626 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri; then 621 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri; then
627 eerror "cp qconfig failed." 622 eerror "cp qconfig failed."
628 return 1 623 return 1
629 fi 624 fi
665 fi 660 fi
666} 661}
667 662
668# @FUNCTION: qt4-build_pkg_postrm 663# @FUNCTION: qt4-build_pkg_postrm
669# @DESCRIPTION: 664# @DESCRIPTION:
670# Generate configurations when the package is completely removed 665# Regenerate configuration when the package is completely removed.
671qt4-build_pkg_postrm() { 666qt4-build_pkg_postrm() {
672 generate_qconfigs 667 generate_qconfigs
673} 668}
674 669
675# @FUNCTION: qt4-build_pkg_postinst 670# @FUNCTION: qt4-build_pkg_postinst
676# @DESCRIPTION: 671# @DESCRIPTION:
677# Generate configuration, plus throws a message about possible 672# Regenerate configuration, plus throw a message about possible
678# breakages and proposed solutions. 673# breakages and proposed solutions.
679qt4-build_pkg_postinst() { 674qt4-build_pkg_postinst() {
680 generate_qconfigs 675 generate_qconfigs
681} 676}
682 677
683# @FUNCTION: skip_qmake_build 678# @FUNCTION: skip_qmake_build
679# @INTERNAL
684# @DESCRIPTION: 680# @DESCRIPTION:
685# Don't need to build qmake, as it's already installed from qt-core 681# Patches configure to skip qmake compilation, as it's already installed by qtcore.
686skip_qmake_build() { 682skip_qmake_build() {
687 # Don't need to build qmake, as it's already installed from qt-core
688 sed -i -e "s:if true:if false:g" "${S}"/configure || die "sed failed" 683 sed -i -e "s:if true:if false:g" "${S}"/configure || die
689} 684}
690 685
691# @FUNCTION: skip_project_generation 686# @FUNCTION: skip_project_generation
687# @INTERNAL
692# @DESCRIPTION: 688# @DESCRIPTION:
693# Exit the script early by throwing in an exit before all of the .pro files are scanned 689# Exit the script early by throwing in an exit before all of the .pro files are scanned.
694skip_project_generation() { 690skip_project_generation() {
695 # Exit the script early by throwing in an exit before all of the .pro files are scanned
696 sed -e "s:echo \"Finding:exit 0\n\necho \"Finding:g" \ 691 sed -i -e "s:echo \"Finding:exit 0\n\necho \"Finding:g" "${S}"/configure || die
697 -i "${S}"/configure || die "sed failed"
698} 692}
699 693
700# @FUNCTION: symlink_binaries_to_buildtree 694# @FUNCTION: symlink_binaries_to_buildtree
695# @INTERNAL
701# @DESCRIPTION: 696# @DESCRIPTION:
702# Symlink generated binaries to buildtree so they can be used during compilation 697# Symlinks generated binaries to buildtree, so they can be used during compilation time.
703# time
704symlink_binaries_to_buildtree() { 698symlink_binaries_to_buildtree() {
705 for bin in qmake moc uic rcc; do 699 for bin in qmake moc uic rcc; do
706 ln -s "${QTBINDIR}"/${bin} "${S}"/bin/ || die "symlinking ${bin} to ${S}/bin failed" 700 ln -s "${QTBINDIR}"/${bin} "${S}"/bin/ || die "symlinking ${bin} to ${S}/bin failed"
707 done 701 done
708} 702}
709 703
710# @FUNCTION: fix_library_files 704# @FUNCTION: fix_library_files
705# @INTERNAL
711# @DESCRIPTION: 706# @DESCRIPTION:
712# Fixes the pathes in *.la, *.prl, *.pc, as they are wrong due to sandbox and 707# Fixes the paths in *.la, *.prl, *.pc, as they are wrong due to sandbox and
713# moves the *.pc-files into the pkgconfig directory 708# moves the *.pc files into the pkgconfig directory.
714fix_library_files() { 709fix_library_files() {
710 local libfile
715 for libfile in "${D}"/${QTLIBDIR}/{*.la,*.prl,pkgconfig/*.pc}; do 711 for libfile in "${D}"/${QTLIBDIR}/{*.la,*.prl,pkgconfig/*.pc}; do
716 if [[ -e ${libfile} ]]; then 712 if [[ -e ${libfile} ]]; then
717 sed -i -e "s:${S}/lib:${QTLIBDIR}:g" ${libfile} || die "sed on ${libfile} failed" 713 sed -i -e "s:${S}/lib:${QTLIBDIR}:g" ${libfile} || die "sed on ${libfile} failed"
718 fi 714 fi
719 done 715 done
720 716
721 # pkgconfig files refer to WORKDIR/bin as the moc and uic locations. Fix: 717 # pkgconfig files refer to WORKDIR/bin as the moc and uic locations
722 for libfile in "${D}"/${QTLIBDIR}/pkgconfig/*.pc; do 718 for libfile in "${D}"/${QTLIBDIR}/pkgconfig/*.pc; do
723 if [[ -e ${libfile} ]]; then 719 if [[ -e ${libfile} ]]; then
724 sed -i -e "s:${S}/bin:${QTBINDIR}:g" ${libfile} || die "sed failed" 720 sed -i -e "s:${S}/bin:${QTBINDIR}:g" ${libfile} || die "sed on ${libfile} failed"
725 721
726 # Move .pc files into the pkgconfig directory 722 # Move .pc files into the pkgconfig directory
727 dodir ${QTPCDIR#${EPREFIX}} 723 dodir ${QTPCDIR#${EPREFIX}}
728 mv ${libfile} "${D}"/${QTPCDIR}/ \ 724 mv ${libfile} "${D}"/${QTPCDIR}/ || die "moving ${libfile} to ${D}/${QTPCDIR}/ failed"
729 || die "moving ${libfile} to ${D}/${QTPCDIR}/ failed"
730 fi 725 fi
731 done 726 done
732 727
733 # Don't install an empty directory 728 # Don't install an empty directory
734 rmdir "${D}"/${QTLIBDIR}/pkgconfig 729 rmdir "${D}"/${QTLIBDIR}/pkgconfig
735} 730}
736 731
737# @FUNCTION: qt_use 732# @FUNCTION: qt_use
738# @USAGE: < flag > [ feature ] [ enableval ] 733# @USAGE: < flag > [ feature ] [ enableval ]
739# @DESCRIPTION: 734# @DESCRIPTION:
740# This will echo "${enableval}-${feature}" if <flag> is enabled, or 735# This will echo "-${enableval}-${feature}" if <flag> is enabled, or
741# "-no-${feature} if the flag is disabled. If [feature] is not specified <flag> 736# "-no-${feature}" if it's disabled. If [feature] is not specified, <flag>
742# will be used for that. If [enableval] is not specified, it omits the 737# will be used for that. If [enableval] is not specified, it omits the
743# assignment-part 738# "-${enableval}" part.
744qt_use() { 739qt_use() {
745 local flag=$1 740 use "$1" && echo "${3:+-$3}-${2:-$1}" || echo "-no-${2:-$1}"
746 local feature=$1
747 local enableval=
748
749 [[ -n $2 ]] && feature=$2
750 [[ -n $3 ]] && enableval=-$3
751
752 if use ${flag}; then
753 echo "${enableval}-${feature}"
754 else
755 echo "-no-${feature}"
756 fi
757} 741}
758 742
759# @FUNCTION: qt_mkspecs_dir 743# @FUNCTION: qt_mkspecs_dir
760# @RETURN: the specs-directory w/o path 744# @RETURN: the specs-directory w/o path
761# @DESCRIPTION: 745# @DESCRIPTION:
762# Allows us to define which mkspecs dir we want to use. 746# Allows us to define which mkspecs dir we want to use.
763qt_mkspecs_dir() { 747qt_mkspecs_dir() {
764 # Allows us to define which mkspecs dir we want to use.
765 local spec 748 local spec=
766 749
767 case ${CHOST} in 750 case "${CHOST}" in
768 *-freebsd*|*-dragonfly*) 751 *-freebsd*|*-dragonfly*)
769 spec=freebsd ;; 752 spec=freebsd ;;
770 *-openbsd*) 753 *-openbsd*)
771 spec=openbsd ;; 754 spec=openbsd ;;
772 *-netbsd*) 755 *-netbsd*)
783 *-solaris*) 766 *-solaris*)
784 spec=solaris ;; 767 spec=solaris ;;
785 *-linux-*|*-linux) 768 *-linux-*|*-linux)
786 spec=linux ;; 769 spec=linux ;;
787 *) 770 *)
788 die "Unknown CHOST, no platform chosen" 771 die "${FUNCNAME}(): Unknown CHOST '${CHOST}'" ;;
789 esac 772 esac
790 773
791 CXX=$(tc-getCXX) 774 case "$(tc-getCXX)" in
792 if [[ ${CXX} == *g++* ]]; then 775 *g++*)
793 spec+=-g++ 776 spec+=-g++ ;;
794 elif [[ ${CXX} == *icpc* ]]; then 777 *icpc*)
795 spec+=-icc 778 spec+=-icc ;;
796 else 779 *)
797 die "Unknown compiler '${CXX}'" 780 die "${FUNCNAME}(): Unknown compiler '$(tc-getCXX)'" ;;
798 fi 781 esac
799 if [[ -n ${LIBDIR/lib} ]]; then
800 spec+=-${LIBDIR/lib}
801 fi
802 782
803 # Add -64 for 64bit profiles 783 # Add -64 for 64bit profiles
804 if use x64-freebsd || 784 if use x64-freebsd ||
805 use amd64-linux || 785 use amd64-linux ||
806 use x64-macos || 786 use x64-macos ||
811 fi 791 fi
812 792
813 echo "${spec}" 793 echo "${spec}"
814} 794}
815 795
816# @FUNCTION: qt_assistant_cleanup
817# @RETURN: nothing
818# @DESCRIPTION:
819# Tries to clean up tools.pro for qt-assistant ebuilds.
820# Meant to be called in src_prepare().
821# Since Qt 4.7.4 this function is a no-op.
822qt_assistant_cleanup() {
823 # apply patching to qt-assistant ebuilds only
824 [[ ${PN} != "qt-assistant" ]] && return
825
826 # no longer needed for 4.7.4 and later
827 version_is_at_least "4.7.4" && return
828
829 # different versions (and branches...) may need different handling,
830 # add a case if you need special handling
831 case "${MY_PV_EXTRA}" in
832 *kde-qt*)
833 sed -e "/^[ \t]*porting/,/^[ \t]*win32.*activeqt$/d" \
834 -e "/mac/,/^embedded.*makeqpf$/d" \
835 -i tools/tools.pro || die "patching tools.pro failed"
836 ;;
837 *)
838 sed -e "/^[ \t]*porting/,/^[ \t]*win32.*activeqt$/d" \
839 -e "/mac/,/^embedded.*makeqpf$/d" \
840 -e "s/^\([ \t]*pixeltool\) /\1 qdoc3 /" \
841 -i tools/tools.pro || die "patching tools.pro failed"
842 ;;
843 esac
844}
845
846# @FUNCTION: qt_nolibx11 796# @FUNCTION: qt_nolibx11
847# @RETURN: nothing 797# @INTERNAL
848# @DESCRIPTION: 798# @DESCRIPTION:
849# Ignore X11 tests for packages that don't need X libraries installed 799# Skip X11 tests for packages that don't need X libraries installed.
850qt_nolibx11() { 800qt_nolibx11() {
851 einfo "Removing X11 check to allow X-less compilation" 801 sed -i -e '/^if.*PLATFORM_X11.*CFG_GUI/,/^fi$/d' "${S}"/configure || die
852 sed -i "/unixtests\/compile.test.*config.tests\/x11\/xlib/,/fi$/d" "${S}"/configure ||
853 die "x11 check sed failed"
854} 802}
855 803
856EXPORT_FUNCTIONS pkg_setup src_unpack src_prepare src_configure src_compile src_install src_test pkg_postrm pkg_postinst 804EXPORT_FUNCTIONS pkg_setup src_unpack src_prepare src_configure src_compile src_install src_test pkg_postrm pkg_postinst

Legend:
Removed from v.1.101  
changed lines
  Added in v.1.150

  ViewVC Help
Powered by ViewVC 1.1.20