/[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.102 Revision 1.149
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.102 2011/12/08 17:21:45 pesa Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/qt4-build.eclass,v 1.149 2013/08/13 10:05:37 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/ http://qt-project.org/" 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 184 if [[ ${CHOST} == *86*-apple-darwin* ]]; then
212 # qmake bus errors with -O2 but -O3 works 185 # qmake bus errors with -O2 or -O3 but -O1 works
186 # Bug 373061
213 replace-flags -O2 -O3 187 replace-flags -O[23] -O1
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 188 fi
221 189
222 if use_if_iuse c++0x; then 190 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 191 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 192 fi
239 193
240 # Bug 261632 194 # Bug 261632
241 if use ppc64; then 195 if use ppc64; then
242 ewarn "Appending -mminimal-toc to CFLAGS/CXXFLAGS" 196 ewarn "Appending -mminimal-toc to CFLAGS/CXXFLAGS"
243 append-flags -mminimal-toc 197 append-flags -mminimal-toc
244 fi 198 fi
245 199
246 # Bug 282984 && Bug 295530 200 # Respect CC, CXX, {C,CXX,LD}FLAGS in .qmake.cache
247 sed -e "s:\(^SYSTEM_VARIABLES\):CC=\"$(tc-getCC)\"\nCXX=\"$(tc-getCXX)\"\nCFLAGS=\"${CFLAGS}\"\nCXXFLAGS=\"${CXXFLAGS}\"\nLDFLAGS=\"${LDFLAGS}\"\n\1:" \ 201 sed -e "/^SYSTEM_VARIABLES=/i \
248 -i configure || die "sed qmake compilers failed" 202 CC='$(tc-getCC)'\n\
203 CXX='$(tc-getCXX)'\n\
204 CFLAGS='${CFLAGS}'\n\
205 CXXFLAGS='${CXXFLAGS}'\n\
206 LDFLAGS='${LDFLAGS}'\n\
207 QMakeVar set QMAKE_CFLAGS_RELEASE\n\
208 QMakeVar set QMAKE_CFLAGS_DEBUG\n\
209 QMakeVar set QMAKE_CXXFLAGS_RELEASE\n\
210 QMakeVar set QMAKE_CXXFLAGS_DEBUG\n\
211 QMakeVar set QMAKE_LFLAGS_RELEASE\n\
212 QMakeVar set QMAKE_LFLAGS_DEBUG\n"\
213 -i configure \
214 || die "sed SYSTEM_VARIABLES failed"
249 215
250 # Bug 321335 216 # Respect CC, CXX, LINK and *FLAGS in config.tests
251 if version_is_at_least 4.6; then 217 find config.tests/unix -name '*.test' -type f -print0 | xargs -0 \
252 find ./config.tests/unix -name "*.test" -type f -exec grep -lZ \$MAKE '{}' \; | \ 218 sed -i -e "/bin\/qmake/ s: \"\$SRCDIR/: \
253 xargs -0 \ 219 'QMAKE_CC=$(tc-getCC)' 'QMAKE_CXX=$(tc-getCXX)' 'QMAKE_LINK=$(tc-getCXX)' \
254 sed -e "s:\(\$MAKE\):\1 CC=\"$(tc-getCC)\" CXX=\"$(tc-getCXX)\" LD=\"$(tc-getCXX)\" LINK=\"$(tc-getCXX)\":g" \ 220 'QMAKE_CFLAGS+=${CFLAGS}' 'QMAKE_CXXFLAGS+=${CXXFLAGS}' 'QMAKE_LFLAGS+=${LDFLAGS}'&:" \
255 -i || die "sed test compilers failed" 221 || die "sed config.tests failed"
256 fi
257 222
258 # Bug 172219 223 # Bug 172219
259 sed -e "s:X11R6/::" \ 224 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 225
262 if [[ ${CHOST} == *-darwin* ]]; then 226 if [[ ${CHOST} == *-darwin* ]]; then
263 # Set FLAGS *and* remove -arch, since our gcc-apple is multilib 227 # Set FLAGS *and* remove -arch, since our gcc-apple is multilib
264 # crippled (by design) :/ 228 # crippled (by design) :/
229 local mac_gpp_conf=
230 if [[ -f mkspecs/common/mac-g++.conf ]]; then
231 # qt < 4.8 has mac-g++.conf
232 mac_gpp_conf="mkspecs/common/mac-g++.conf"
233 elif [[ -f mkspecs/common/g++-macx.conf ]]; then
234 # qt >= 4.8 has g++-macx.conf
235 mac_gpp_conf="mkspecs/common/g++-macx.conf"
236 else
237 die "no known conf file for mac found"
238 fi
239 sed \
265 sed -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \ 240 -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \
266 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \ 241 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \
267 -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}:" \
268 -e "s:-arch\s\w*::g" \ 243 -e "s:-arch\s\w*::g" \
269 -i mkspecs/common/mac-g++.conf || die "sed mkspecs/common/mac-g++.conf failed" 244 -i ${mac_gpp_conf} \
245 || die "sed ${mac_gpp_conf} failed"
270 246
271 # Fix configure's -arch settings that appear in qmake/Makefile and also 247 # Fix configure's -arch settings that appear in qmake/Makefile and also
272 # fix arch handling (automagically duplicates our -arch arg and breaks 248 # fix arch handling (automagically duplicates our -arch arg and breaks
273 # pch). Additionally disable Xarch support. 249 # pch). Additionally disable Xarch support.
250 local mac_gcc_confs="${mac_gpp_conf}"
251 if [[ -f mkspecs/common/gcc-base-macx.conf ]]; then
252 mac_gcc_confs+=" mkspecs/common/gcc-base-macx.conf"
253 fi
274 sed \ 254 sed \
275 -e "s:-arch i386::" \ 255 -e "s:-arch i386::" \
276 -e "s:-arch ppc::" \ 256 -e "s:-arch ppc::" \
277 -e "s:-arch x86_64::" \ 257 -e "s:-arch x86_64::" \
278 -e "s:-arch ppc64::" \ 258 -e "s:-arch ppc64::" \
279 -e "s:-arch \$i::" \ 259 -e "s:-arch \$i::" \
280 -e "/if \[ ! -z \"\$NATIVE_64_ARCH\" \]; then/,/fi/ d" \ 260 -e "/if \[ ! -z \"\$NATIVE_64_ARCH\" \]; then/,/fi/ d" \
281 -e "s:CFG_MAC_XARCH=yes:CFG_MAC_XARCH=no:g" \ 261 -e "s:CFG_MAC_XARCH=yes:CFG_MAC_XARCH=no:g" \
282 -e "s:-Xarch_x86_64::g" \ 262 -e "s:-Xarch_x86_64::g" \
283 -e "s:-Xarch_ppc64::g" \ 263 -e "s:-Xarch_ppc64::g" \
284 -i configure mkspecs/common/mac-g++.conf || die "sed configure failed" 264 -i configure ${mac_gcc_confs} \
265 || die "sed -arch/-Xarch failed"
285 266
286 # On Snow Leopard don't fall back to 10.5 deployment target. 267 # On Snow Leopard don't fall back to 10.5 deployment target.
287 if [[ ${CHOST} == *-apple-darwin10 ]] ; then 268 if [[ ${CHOST} == *-apple-darwin10 ]]; then
288 sed -e "s:QMakeVar set QMAKE_MACOSX_DEPLOYMENT_TARGET.*:QMakeVar set QMAKE_MACOSX_DEPLOYMENT_TARGET 10.6:g" \ 269 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" \ 270 -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" 271 -i configure ${mac_gpp_conf} \
272 || die "sed deployment target failed"
291 fi 273 fi
292 fi 274 fi
293 275
294 # this one is needed for all systems with a separate -liconv, apart from 276 # this one is needed for all systems with a separate -liconv, apart from
295 # Darwin, for which the sources already cater for -liconv 277 # Darwin, for which the sources already cater for -liconv
296 if use !elibc_glibc && [[ ${CHOST} != *-darwin* ]] ; then 278 if use !elibc_glibc && [[ ${CHOST} != *-darwin* ]]; then
297 sed \ 279 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 \ 280 -i config.tests/unix/iconv/iconv.pro \
300 || die "sed on iconv.pro failed" 281 || die "sed iconv.pro failed"
301 fi 282 fi
302 283
303 # we need some patches for Solaris 284 # we need some patches for Solaris
304 sed -i \
305 -e '/^QMAKE_LFLAGS_THREAD/a\QMAKE_LFLAGS_DYNAMIC_LIST = -Wl,--dynamic-list,' \ 285 sed -i -e '/^QMAKE_LFLAGS_THREAD/a\QMAKE_LFLAGS_DYNAMIC_LIST = -Wl,--dynamic-list,' \
306 mkspecs/$(qt_mkspecs_dir)/qmake.conf || die 286 mkspecs/$(qt_mkspecs_dir)/qmake.conf || die
307 # use GCC over SunStudio 287 # use GCC over SunStudio
308 sed -i -e '/PLATFORM=solaris-cc/s/cc/g++/' configure || die 288 sed -i -e '/PLATFORM=solaris-cc/s/cc/g++/' configure || die
309 # don't flirt with non-Prefix stuff, we're quite possessive 289 # do not flirt with non-Prefix stuff, we're quite possessive
310 sed -i -e '/^QMAKE_\(LIB\|INC\)DIR\(_X11\|_OPENGL\|\)\t/s/=.*$/=/' \ 290 sed -i -e '/^QMAKE_\(LIB\|INC\)DIR\(_X11\|_OPENGL\|\)\t/s/=.*$/=/' \
311 mkspecs/$(qt_mkspecs_dir)/qmake.conf || die 291 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 292
315 base_src_prepare 293 # apply patches
294 [[ -n ${PATCHES[@]} ]] && epatch "${PATCHES[@]}"
295 epatch_user
316} 296}
317 297
318# @FUNCTION: qt4-build_src_configure 298# @FUNCTION: qt4-build_src_configure
319# @DESCRIPTION: 299# @DESCRIPTION:
320# Default configure phase 300# Default configure phase
321qt4-build_src_configure() { 301qt4-build_src_configure() {
322 setqtenv 302 setqtenv
323 myconf="$(standard_configure_options) ${myconf}" 303
304 local conf="
305 -prefix ${QTPREFIXDIR}
306 -bindir ${QTBINDIR}
307 -libdir ${QTLIBDIR}
308 -docdir ${QTDOCDIR}
309 -headerdir ${QTHEADERDIR}
310 -plugindir ${QTPLUGINDIR}
311 -importdir ${QTIMPORTDIR}
312 -datadir ${QTDATADIR}
313 -translationdir ${QTTRANSDIR}
314 -sysconfdir ${QTSYSCONFDIR}
315 -examplesdir ${QTEXAMPLESDIR}
316 -demosdir ${QTDEMOSDIR}
317 -opensource -confirm-license
318 -shared -fast -largefile -stl -verbose
319 -nomake examples -nomake demos"
320
321 # ARCH is set on Gentoo. Qt now falls back to generic on an unsupported
322 # $(tc-arch). Therefore we convert it to supported values.
323 case "$(tc-arch)" in
324 amd64|x64-*) conf+=" -arch x86_64" ;;
325 ppc-macos) conf+=" -arch ppc" ;;
326 ppc|ppc64|ppc-*) conf+=" -arch powerpc" ;;
327 sparc|sparc-*|sparc64-*) conf+=" -arch sparc" ;;
328 x86-macos) conf+=" -arch x86" ;;
329 x86|x86-*) conf+=" -arch i386" ;;
330 alpha|arm|ia64|mips|s390) conf+=" -arch $(tc-arch)" ;;
331 hppa|sh) conf+=" -arch generic" ;;
332 *) die "$(tc-arch) is unsupported by this eclass. Please file a bug." ;;
333 esac
334
335 conf+=" -platform $(qt_mkspecs_dir)"
336
337 [[ $(get_libdir) != lib ]] && conf+=" -L${EPREFIX}/usr/$(get_libdir)"
338
339 # debug/release
340 if use debug; then
341 conf+=" -debug"
342 else
343 conf+=" -release"
344 fi
345 conf+=" -no-separate-debug-info"
346
347 # exceptions USE flag
348 conf+=" $(in_iuse exceptions && qt_use exceptions || echo -exceptions)"
349
350 # disable rpath (bug 380415), except on prefix (bug 417169)
351 use prefix || conf+=" -no-rpath"
352
353 # precompiled headers don't work on hardened, where the flag is masked
354 conf+=" $(qt_use pch)"
355
356 # -reduce-relocations
357 # This flag seems to introduce major breakage to applications,
358 # mostly to be seen as a core dump with the message "QPixmap: Must
359 # construct a QApplication before a QPaintDevice" on Solaris.
360 # -- Daniel Vergien
361 [[ ${CHOST} != *-solaris* ]] && conf+=" -reduce-relocations"
324 362
325 # this one is needed for all systems with a separate -liconv, apart from 363 # this one is needed for all systems with a separate -liconv, apart from
326 # Darwin, for which the sources already cater for -liconv 364 # Darwin, for which the sources already cater for -liconv
327 use !elibc_glibc && [[ ${CHOST} != *-darwin* ]] && \ 365 if use !elibc_glibc && [[ ${CHOST} != *-darwin* ]]; then
328 myconf+=" -liconv" 366 conf+=" -liconv"
367 fi
329 368
330 if use_if_iuse glib; then 369 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)" 370 local glibflags="$(pkg-config --cflags --libs glib-2.0 gthread-2.0)"
333 # avoid the -pthread argument 371 # avoid the -pthread argument
334 myconf+=" ${glibflags//-pthread}" 372 conf+=" ${glibflags//-pthread}"
335 unset glibflags 373 unset glibflags
336 fi 374 fi
337 375
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 376 if use aqua; then
348 # On (snow) leopard use the new (frameworked) cocoa code. 377 # On (snow) leopard use the new (frameworked) cocoa code.
349 if [[ ${CHOST##*-darwin} -ge 9 ]] ; then 378 if [[ ${CHOST##*-darwin} -ge 9 ]]; then
350 myconf+=" -cocoa -framework" 379 conf+=" -cocoa -framework"
380 # We need the source's headers, not the installed ones.
381 conf+=" -I${S}/include"
382 # Add hint for the framework location.
383 conf+=" -F${QTLIBDIR}"
351 384
352 # We are crazy and build cocoa + qt3support :-) 385 # We are crazy and build cocoa + qt3support :-)
353 if use qt3support; then 386 if use qt3support; then
354 sed -e "/case \"\$PLATFORM,\$CFG_MAC_COCOA\" in/,/;;/ s|CFG_QT3SUPPORT=\"no\"|CFG_QT3SUPPORT=\"yes\"|" \ 387 sed -e "/case \"\$PLATFORM,\$CFG_MAC_COCOA\" in/,/;;/ s|CFG_QT3SUPPORT=\"no\"|CFG_QT3SUPPORT=\"yes\"|" \
355 -i configure 388 -i configure || die
356 fi 389 fi
357 390 else
358 # We need the source's headers, not the installed ones. 391 conf+=" -no-framework"
359 myconf+=" -I${S}/include"
360
361 # Add hint for the framework location.
362 myconf+=" -F${QTLIBDIR}"
363 fi 392 fi
364 else 393 else
365 # freetype2 include dir is non-standard, thus include it on configure 394 # freetype2 include dir is non-standard, thus pass it to configure
366 # use -I from configure
367 myconf+=" $(pkg-config --cflags freetype2)" 395 conf+=" $(pkg-config --cflags-only-I freetype2)"
368 fi 396 fi
369 397
370 # Disable SSE4.x, since auto-detection is currently broken 398 conf+=" ${myconf}"
371 # Upstream bug http://bugreports.qt.nokia.com/browse/QTBUG-13623 399 myconf=
372 [[ ${PV} == "4.7.1" ]] && myconf+=" -no-sse4.1 -no-sse4.2"
373 400
374 echo ./configure ${myconf} 401 echo ./configure ${conf}
375 ./configure ${myconf} || die "./configure failed" 402 ./configure ${conf} || die "./configure failed"
376 myconf=""
377 403
378 prepare_directories ${QT4_TARGET_DIRECTORIES} 404 prepare_directories ${QT4_TARGET_DIRECTORIES}
379} 405}
380 406
381# @FUNCTION: qt4-build_src_compile 407# @FUNCTION: qt4-build_src_compile
389 415
390# @FUNCTION: qt4-build_src_test 416# @FUNCTION: qt4-build_src_test
391# @DESCRIPTION: 417# @DESCRIPTION:
392# Runs tests only in target directories. 418# Runs tests only in target directories.
393qt4-build_src_test() { 419qt4-build_src_test() {
420 # QtMultimedia does not have any test suite (bug #332299)
421 [[ ${CATEGORY}/${PN} == dev-qt/qtmultimedia ]] && return
422
394 for dir in ${QT4_TARGET_DIRECTORIES}; do 423 for dir in ${QT4_TARGET_DIRECTORIES}; do
395 emake -j1 check -C ${dir} 424 emake -j1 check -C ${dir}
396 done 425 done
397} 426}
398 427
399# @FUNCTION: fix_includes 428# @FUNCTION: fix_includes
400# @DESCRIPTION: 429# @DESCRIPTION:
401# For MacOSX we need to add some symlinks when frameworks are 430# 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. 431# being used, to avoid complications with some more or less stupid packages.
403fix_includes() { 432fix_includes() {
404 if use aqua && [[ ${CHOST##*-darwin} -ge 9 ]] ; then 433 if use aqua && [[ ${CHOST##*-darwin} -ge 9 ]]; then
434 local frw dest f h rdir
405 # Some packages tend to include <Qt/...> 435 # Some packages tend to include <Qt/...>
406 dodir "${QTHEADERDIR#${EPREFIX}}"/Qt 436 dodir "${QTHEADERDIR#${EPREFIX}}"/Qt
407 437
408 # Fake normal headers when frameworks are installed... eases life later on 438 # Fake normal headers when frameworks are installed... eases life later
409 local dest f 439 # on, make sure we use relative links though, as some ebuilds assume
440 # these dirs exist in src_install to add additional files
441 f=${QTHEADERDIR}
442 h=${QTLIBDIR}
443 while [[ -n ${f} && ${f%%/*} == ${h%%/*} ]] ; do
444 f=${f#*/}
445 h=${h#*/}
446 done
447 rdir=${h}
448 f="../"
449 while [[ ${h} == */* ]] ; do
450 f="${f}../"
451 h=${h#*/}
452 done
453 rdir="${f}${rdir}"
454
410 for frw in "${D}${QTLIBDIR}"/*.framework; do 455 for frw in "${D}${QTLIBDIR}"/*.framework; do
411 [[ -e "${frw}"/Headers ]] || continue 456 [[ -e "${frw}"/Headers ]] || continue
412 f=$(basename ${frw}) 457 f=$(basename ${frw})
413 dest="${QTHEADERDIR#${EPREFIX}}"/${f%.framework} 458 dest="${QTHEADERDIR#${EPREFIX}}"/${f%.framework}
414 dosym "${QTLIBDIR#${EPREFIX}}"/${f}/Headers "${dest}" 459 dosym "${rdir}"/${f}/Headers "${dest}"
415 460
416 # Link normal headers as well. 461 # Link normal headers as well.
417 for hdr in "${D}/${QTLIBDIR}/${f}"/Headers/*; do 462 for hdr in "${D}/${QTLIBDIR}/${f}"/Headers/*; do
418 h=$(basename ${hdr}) 463 h=$(basename ${hdr})
419 dosym "${QTLIBDIR#${EPREFIX}}"/${f}/Headers/${h} "${QTHEADERDIR#${EPREFIX}}"/Qt/${h} 464 dosym "../${rdir}"/${f}/Headers/${h} \
465 "${QTHEADERDIR#${EPREFIX}}"/Qt/${h}
420 done 466 done
421 done 467 done
422 fi 468 fi
423} 469}
424 470
425# @FUNCTION: qt4-build_src_install 471# @FUNCTION: qt4-build_src_install
426# @DESCRIPTION: 472# @DESCRIPTION:
427# Perform the actual installation including some library fixes. 473# Perform the actual installation including some library fixes.
428qt4-build_src_install() { 474qt4-build_src_install() {
429 [[ ${EAPI} == 2 ]] && use !prefix && ED=${D}
430 setqtenv 475 setqtenv
431 476
432 install_directories ${QT4_TARGET_DIRECTORIES} 477 install_directories ${QT4_TARGET_DIRECTORIES}
433 install_qconfigs 478 install_qconfigs
434 fix_library_files 479 fix_library_files
435 fix_includes 480 fix_includes
436 481
437 # remove .la files since we are building only shared Qt libraries 482 # remove .la files since we are building only shared libraries
438 find "${D}"${QTLIBDIR} -name "*.la" -print0 | xargs -0 rm 483 prune_libtool_files
439} 484}
440 485
441# @FUNCTION: setqtenv 486# @FUNCTION: setqtenv
487# @INTERNAL
442setqtenv() { 488setqtenv() {
443 # Set up installation directories 489 # Set up installation directories
444 QTBASEDIR=${EPREFIX}/usr/$(get_libdir)/qt4
445 QTPREFIXDIR=${EPREFIX}/usr 490 QTPREFIXDIR=${EPREFIX}/usr
446 QTBINDIR=${EPREFIX}/usr/bin 491 QTBINDIR=${QTPREFIXDIR}/bin
447 QTLIBDIR=${EPREFIX}/usr/$(get_libdir)/qt4 492 QTLIBDIR=${QTPREFIXDIR}/$(get_libdir)/qt4
448 QMAKE_LIBDIR_QT=${QTLIBDIR}
449 QTPCDIR=${EPREFIX}/usr/$(get_libdir)/pkgconfig 493 QTPCDIR=${QTPREFIXDIR}/$(get_libdir)/pkgconfig
450 QTDATADIR=${EPREFIX}/usr/share/qt4
451 QTDOCDIR=${EPREFIX}/usr/share/doc/qt-${PV} 494 QTDOCDIR=${QTPREFIXDIR}/share/doc/qt-${PV}
452 QTHEADERDIR=${EPREFIX}/usr/include/qt4 495 QTHEADERDIR=${QTPREFIXDIR}/include/qt4
453 QTPLUGINDIR=${QTLIBDIR}/plugins 496 QTPLUGINDIR=${QTLIBDIR}/plugins
497 QTIMPORTDIR=${QTLIBDIR}/imports
498 QTDATADIR=${QTPREFIXDIR}/share/qt4
499 QTTRANSDIR=${QTDATADIR}/translations
454 QTSYSCONFDIR=${EPREFIX}/etc/qt4 500 QTSYSCONFDIR=${EPREFIX}/etc/qt4
455 QTTRANSDIR=${QTDATADIR}/translations
456 QTEXAMPLESDIR=${QTDATADIR}/examples 501 QTEXAMPLESDIR=${QTDATADIR}/examples
457 QTDEMOSDIR=${QTDATADIR}/demos 502 QTDEMOSDIR=${QTDATADIR}/demos
458 QT_INSTALL_PREFIX=${EPREFIX}/usr/$(get_libdir)/qt4 503 QMAKE_LIBDIR_QT=${QTLIBDIR}
504
459 PLATFORM=$(qt_mkspecs_dir) 505 PLATFORM=$(qt_mkspecs_dir)
460
461 unset QMAKESPEC 506 unset QMAKESPEC
462}
463 507
464# @FUNCTION: standard_configure_options 508 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} 509}
526 510
527# @FUNCTION: prepare_directories 511# @FUNCTION: prepare_directories
528# @USAGE: < directories > 512# @USAGE: < directories >
513# @INTERNAL
529# @DESCRIPTION: 514# @DESCRIPTION:
530# Generates makefiles for the directories set in $QT4_TARGET_DIRECTORIES 515# Generates Makefiles for the given list of directories.
531prepare_directories() { 516prepare_directories() {
532 for x in "$@"; do 517 for x in "$@"; do
533 pushd "${S}"/${x} >/dev/null 518 pushd "${S}"/${x} >/dev/null || die
534 einfo "Running qmake in: ${x}" 519 einfo "Running qmake in: ${x}"
535 # avoid running over the maximum argument number, bug #299810 520 "${S}"/bin/qmake \
536 { 521 "LIBS+=-L${QTLIBDIR}" \
537 echo "${S}"/mkspecs/common/*.conf 522 "CONFIG+=nostrip" \
538 find "${S}" -name '*.pr[io]' 523 || 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 524 popd >/dev/null || die
542 done 525 done
543} 526}
544
545 527
546# @FUNCTION: build_directories 528# @FUNCTION: build_directories
547# @USAGE: < directories > 529# @USAGE: < directories >
530# @INTERNAL
548# @DESCRIPTION: 531# @DESCRIPTION:
549# Compiles the code in $QT4_TARGET_DIRECTORIES 532# Compiles the code in the given list of directories.
550build_directories() { 533build_directories() {
551 for x in "$@"; do 534 for x in "$@"; do
552 pushd "${S}"/${x} >/dev/null 535 pushd "${S}"/${x} >/dev/null || die
536 emake \
537 AR="$(tc-getAR) cqs" \
553 emake CC="$(tc-getCC)" \ 538 CC="$(tc-getCC)" \
554 CXX="$(tc-getCXX)" \ 539 CXX="$(tc-getCXX)" \
555 LINK="$(tc-getCXX)" || die "emake failed" 540 LINK="$(tc-getCXX)" \
541 RANLIB=":" \
542 STRIP=":"
556 popd >/dev/null 543 popd >/dev/null || die
557 done 544 done
558} 545}
559 546
560# @FUNCTION: install_directories 547# @FUNCTION: install_directories
561# @USAGE: < directories > 548# @USAGE: < directories >
549# @INTERNAL
562# @DESCRIPTION: 550# @DESCRIPTION:
563# run emake install in the given directories, which are separated by spaces 551# Runs emake install in the given directories, which are separated by spaces.
564install_directories() { 552install_directories() {
565 for x in "$@"; do 553 for x in "$@"; do
566 pushd "${S}"/${x} >/dev/null || die "Can't pushd ${S}/${x}" 554 pushd "${S}"/${x} >/dev/null || die
567 emake INSTALL_ROOT="${D}" install || die "emake install failed" 555 emake INSTALL_ROOT="${D}" install
568 popd >/dev/null || die "Can't popd from ${S}/${x}" 556 popd >/dev/null || die
569 done 557 done
570} 558}
571 559
572# @ECLASS-VARIABLE: QCONFIG_ADD 560# @ECLASS-VARIABLE: QCONFIG_ADD
573# @DESCRIPTION: 561# @DESCRIPTION:
583# @DESCRIPTION: 571# @DESCRIPTION:
584# List variables that should be defined at the top of QtCore/qconfig.h 572# List variables that should be defined at the top of QtCore/qconfig.h
585: ${QCONFIG_DEFINE:=} 573: ${QCONFIG_DEFINE:=}
586 574
587# @FUNCTION: install_qconfigs 575# @FUNCTION: install_qconfigs
576# @INTERNAL
588# @DESCRIPTION: 577# @DESCRIPTION:
589# Install gentoo-specific mkspecs configurations 578# Install gentoo-specific mkspecs configurations.
590install_qconfigs() { 579install_qconfigs() {
591 local x 580 local x
592 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} ]]; then 581 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} ]]; then
593 for x in QCONFIG_ADD QCONFIG_REMOVE; do 582 for x in QCONFIG_ADD QCONFIG_REMOVE; do
594 [[ -n ${!x} ]] && echo ${x}=${!x} >> "${T}"/${PN}-qconfig.pri 583 [[ -n ${!x} ]] && echo ${x}=${!x} >> "${T}"/${PN}-qconfig.pri
595 done 584 done
596 insinto ${QTDATADIR#${EPREFIX}}/mkspecs/gentoo 585 insinto ${QTDATADIR#${EPREFIX}}/mkspecs/gentoo
597 doins "${T}"/${PN}-qconfig.pri || die "installing ${PN}-qconfig.pri failed" 586 doins "${T}"/${PN}-qconfig.pri
598 fi 587 fi
599 588
600 if [[ -n ${QCONFIG_DEFINE} ]]; then 589 if [[ -n ${QCONFIG_DEFINE} ]]; then
601 for x in ${QCONFIG_DEFINE}; do 590 for x in ${QCONFIG_DEFINE}; do
602 echo "#define ${x}" >> "${T}"/gentoo-${PN}-qconfig.h 591 echo "#define ${x}" >> "${T}"/gentoo-${PN}-qconfig.h
603 done 592 done
604 insinto ${QTHEADERDIR#${EPREFIX}}/Gentoo 593 insinto ${QTHEADERDIR#${EPREFIX}}/Gentoo
605 doins "${T}"/gentoo-${PN}-qconfig.h || die "installing ${PN}-qconfig.h failed" 594 doins "${T}"/gentoo-${PN}-qconfig.h
606 fi 595 fi
607} 596}
608 597
609# @FUNCTION: generate_qconfigs 598# @FUNCTION: generate_qconfigs
599# @INTERNAL
610# @DESCRIPTION: 600# @DESCRIPTION:
611# Generates gentoo-specific configurations 601# Generates gentoo-specific qconfig.{h,pri}.
612generate_qconfigs() { 602generate_qconfigs() {
613 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} || -n ${QCONFIG_DEFINE} || ${CATEGORY}/${PN} == x11-libs/qt-core ]]; then 603 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 604 local x qconfig_add qconfig_remove qconfig_new
615 for x in "${ROOT}${QTDATADIR}"/mkspecs/gentoo/*-qconfig.pri; do 605 for x in "${ROOT}${QTDATADIR}"/mkspecs/gentoo/*-qconfig.pri; do
616 [[ -f ${x} ]] || continue 606 [[ -f ${x} ]] || continue
617 qconfig_add+=" $(sed -n 's/^QCONFIG_ADD=//p' "${x}")" 607 qconfig_add+=" $(sed -n 's/^QCONFIG_ADD=//p' "${x}")"
618 qconfig_remove+=" $(sed -n 's/^QCONFIG_REMOVE=//p' "${x}")" 608 qconfig_remove+=" $(sed -n 's/^QCONFIG_REMOVE=//p' "${x}")"
619 done 609 done
620 610
621 # these error checks do not use die because dying in pkg_post{inst,rm} 611 # these error checks do not use die because dying in pkg_post{inst,rm}
622 # just makes things worse. 612 # just makes things worse.
623 if [[ -e "${ROOT}${QTDATADIR}"/mkspecs/gentoo/qconfig.pri ]]; then 613 if [[ -e "${ROOT}${QTDATADIR}"/mkspecs/gentoo/qconfig.pri ]]; then
624 # start with the qconfig.pri that qt-core installed 614 # start with the qconfig.pri that qtcore installed
625 if ! cp "${ROOT}${QTDATADIR}"/mkspecs/gentoo/qconfig.pri \ 615 if ! cp "${ROOT}${QTDATADIR}"/mkspecs/gentoo/qconfig.pri \
626 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri; then 616 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri; then
627 eerror "cp qconfig failed." 617 eerror "cp qconfig failed."
628 return 1 618 return 1
629 fi 619 fi
665 fi 655 fi
666} 656}
667 657
668# @FUNCTION: qt4-build_pkg_postrm 658# @FUNCTION: qt4-build_pkg_postrm
669# @DESCRIPTION: 659# @DESCRIPTION:
670# Generate configurations when the package is completely removed 660# Regenerate configuration when the package is completely removed.
671qt4-build_pkg_postrm() { 661qt4-build_pkg_postrm() {
672 generate_qconfigs 662 generate_qconfigs
673} 663}
674 664
675# @FUNCTION: qt4-build_pkg_postinst 665# @FUNCTION: qt4-build_pkg_postinst
676# @DESCRIPTION: 666# @DESCRIPTION:
677# Generate configuration, plus throws a message about possible 667# Regenerate configuration, plus throw a message about possible
678# breakages and proposed solutions. 668# breakages and proposed solutions.
679qt4-build_pkg_postinst() { 669qt4-build_pkg_postinst() {
680 generate_qconfigs 670 generate_qconfigs
681} 671}
682 672
683# @FUNCTION: skip_qmake_build 673# @FUNCTION: skip_qmake_build
674# @INTERNAL
684# @DESCRIPTION: 675# @DESCRIPTION:
685# Don't need to build qmake, as it's already installed from qt-core 676# Patches configure to skip qmake compilation, as it's already installed by qtcore.
686skip_qmake_build() { 677skip_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" 678 sed -i -e "s:if true:if false:g" "${S}"/configure || die
689} 679}
690 680
691# @FUNCTION: skip_project_generation 681# @FUNCTION: skip_project_generation
682# @INTERNAL
692# @DESCRIPTION: 683# @DESCRIPTION:
693# Exit the script early by throwing in an exit before all of the .pro files are scanned 684# Exit the script early by throwing in an exit before all of the .pro files are scanned.
694skip_project_generation() { 685skip_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" \ 686 sed -i -e "s:echo \"Finding:exit 0\n\necho \"Finding:g" "${S}"/configure || die
697 -i "${S}"/configure || die "sed failed"
698} 687}
699 688
700# @FUNCTION: symlink_binaries_to_buildtree 689# @FUNCTION: symlink_binaries_to_buildtree
690# @INTERNAL
701# @DESCRIPTION: 691# @DESCRIPTION:
702# Symlink generated binaries to buildtree so they can be used during compilation 692# Symlinks generated binaries to buildtree, so they can be used during compilation time.
703# time
704symlink_binaries_to_buildtree() { 693symlink_binaries_to_buildtree() {
705 for bin in qmake moc uic rcc; do 694 for bin in qmake moc uic rcc; do
706 ln -s "${QTBINDIR}"/${bin} "${S}"/bin/ || die "symlinking ${bin} to ${S}/bin failed" 695 ln -s "${QTBINDIR}"/${bin} "${S}"/bin/ || die "symlinking ${bin} to ${S}/bin failed"
707 done 696 done
708} 697}
709 698
710# @FUNCTION: fix_library_files 699# @FUNCTION: fix_library_files
700# @INTERNAL
711# @DESCRIPTION: 701# @DESCRIPTION:
712# Fixes the pathes in *.la, *.prl, *.pc, as they are wrong due to sandbox and 702# Fixes the paths in *.la, *.prl, *.pc, as they are wrong due to sandbox and
713# moves the *.pc-files into the pkgconfig directory 703# moves the *.pc files into the pkgconfig directory.
714fix_library_files() { 704fix_library_files() {
705 local libfile
715 for libfile in "${D}"/${QTLIBDIR}/{*.la,*.prl,pkgconfig/*.pc}; do 706 for libfile in "${D}"/${QTLIBDIR}/{*.la,*.prl,pkgconfig/*.pc}; do
716 if [[ -e ${libfile} ]]; then 707 if [[ -e ${libfile} ]]; then
717 sed -i -e "s:${S}/lib:${QTLIBDIR}:g" ${libfile} || die "sed on ${libfile} failed" 708 sed -i -e "s:${S}/lib:${QTLIBDIR}:g" ${libfile} || die "sed on ${libfile} failed"
718 fi 709 fi
719 done 710 done
720 711
721 # pkgconfig files refer to WORKDIR/bin as the moc and uic locations. Fix: 712 # pkgconfig files refer to WORKDIR/bin as the moc and uic locations
722 for libfile in "${D}"/${QTLIBDIR}/pkgconfig/*.pc; do 713 for libfile in "${D}"/${QTLIBDIR}/pkgconfig/*.pc; do
723 if [[ -e ${libfile} ]]; then 714 if [[ -e ${libfile} ]]; then
724 sed -i -e "s:${S}/bin:${QTBINDIR}:g" ${libfile} || die "sed failed" 715 sed -i -e "s:${S}/bin:${QTBINDIR}:g" ${libfile} || die "sed on ${libfile} failed"
725 716
726 # Move .pc files into the pkgconfig directory 717 # Move .pc files into the pkgconfig directory
727 dodir ${QTPCDIR#${EPREFIX}} 718 dodir ${QTPCDIR#${EPREFIX}}
728 mv ${libfile} "${D}"/${QTPCDIR}/ \ 719 mv ${libfile} "${D}"/${QTPCDIR}/ || die "moving ${libfile} to ${D}/${QTPCDIR}/ failed"
729 || die "moving ${libfile} to ${D}/${QTPCDIR}/ failed"
730 fi 720 fi
731 done 721 done
732 722
733 # Don't install an empty directory 723 # Don't install an empty directory
734 rmdir "${D}"/${QTLIBDIR}/pkgconfig 724 rmdir "${D}"/${QTLIBDIR}/pkgconfig
735} 725}
736 726
737# @FUNCTION: qt_use 727# @FUNCTION: qt_use
738# @USAGE: < flag > [ feature ] [ enableval ] 728# @USAGE: < flag > [ feature ] [ enableval ]
739# @DESCRIPTION: 729# @DESCRIPTION:
740# This will echo "${enableval}-${feature}" if <flag> is enabled, or 730# This will echo "-${enableval}-${feature}" if <flag> is enabled, or
741# "-no-${feature} if the flag is disabled. If [feature] is not specified <flag> 731# "-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 732# will be used for that. If [enableval] is not specified, it omits the
743# assignment-part 733# "-${enableval}" part.
744qt_use() { 734qt_use() {
745 local flag=$1 735 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} 736}
758 737
759# @FUNCTION: qt_mkspecs_dir 738# @FUNCTION: qt_mkspecs_dir
760# @RETURN: the specs-directory w/o path 739# @RETURN: the specs-directory w/o path
761# @DESCRIPTION: 740# @DESCRIPTION:
762# Allows us to define which mkspecs dir we want to use. 741# Allows us to define which mkspecs dir we want to use.
763qt_mkspecs_dir() { 742qt_mkspecs_dir() {
764 # Allows us to define which mkspecs dir we want to use.
765 local spec 743 local spec=
766 744
767 case ${CHOST} in 745 case "${CHOST}" in
768 *-freebsd*|*-dragonfly*) 746 *-freebsd*|*-dragonfly*)
769 spec=freebsd ;; 747 spec=freebsd ;;
770 *-openbsd*) 748 *-openbsd*)
771 spec=openbsd ;; 749 spec=openbsd ;;
772 *-netbsd*) 750 *-netbsd*)
783 *-solaris*) 761 *-solaris*)
784 spec=solaris ;; 762 spec=solaris ;;
785 *-linux-*|*-linux) 763 *-linux-*|*-linux)
786 spec=linux ;; 764 spec=linux ;;
787 *) 765 *)
788 die "Unknown CHOST, no platform chosen" 766 die "${FUNCNAME}(): Unknown CHOST '${CHOST}'" ;;
789 esac 767 esac
790 768
791 CXX=$(tc-getCXX) 769 case "$(tc-getCXX)" in
792 if [[ ${CXX} == *g++* ]]; then 770 *g++*)
793 spec+=-g++ 771 spec+=-g++ ;;
794 elif [[ ${CXX} == *icpc* ]]; then 772 *icpc*)
795 spec+=-icc 773 spec+=-icc ;;
796 else 774 *)
797 die "Unknown compiler '${CXX}'" 775 die "${FUNCNAME}(): Unknown compiler '$(tc-getCXX)'" ;;
798 fi 776 esac
799 if [[ -n ${LIBDIR/lib} ]]; then
800 spec+=-${LIBDIR/lib}
801 fi
802 777
803 # Add -64 for 64bit profiles 778 # Add -64 for 64bit profiles
804 if use x64-freebsd || 779 if use x64-freebsd ||
805 use amd64-linux || 780 use amd64-linux ||
806 use x64-macos || 781 use x64-macos ||
811 fi 786 fi
812 787
813 echo "${spec}" 788 echo "${spec}"
814} 789}
815 790
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 791# @FUNCTION: qt_nolibx11
847# @RETURN: nothing 792# @INTERNAL
848# @DESCRIPTION: 793# @DESCRIPTION:
849# Ignore X11 tests for packages that don't need X libraries installed 794# Skip X11 tests for packages that don't need X libraries installed.
850qt_nolibx11() { 795qt_nolibx11() {
851 einfo "Removing X11 check to allow X-less compilation" 796 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} 797}
855 798
856EXPORT_FUNCTIONS pkg_setup src_unpack src_prepare src_configure src_compile src_install src_test pkg_postrm pkg_postinst 799EXPORT_FUNCTIONS pkg_setup src_unpack src_prepare src_configure src_compile src_install src_test pkg_postrm pkg_postinst

Legend:
Removed from v.1.102  
changed lines
  Added in v.1.149

  ViewVC Help
Powered by ViewVC 1.1.20