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

Legend:
Removed from v.1.110  
changed lines
  Added in v.1.159

  ViewVC Help
Powered by ViewVC 1.1.20