/[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.64 Revision 1.159
1# Copyright 1999-2009 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.64 2010/02/15 16:34:00 spatz 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# Ben de Groot <yngwin@gentoo.org>, 7# Qt herd <qt@gentoo.org>
8# Markos Chandras <hwoarang@gentoo.org>,
9# Caleb Tennis <caleb@gentoo.org>
10# Alex Alexander <wired@gentoo.org>
11# @BLURB: Eclass for Qt4 split ebuilds. 8# @BLURB: Eclass for Qt4 split ebuilds.
12# @DESCRIPTION: 9# @DESCRIPTION:
13# This eclass contains various functions that are used when building Qt4 10# This eclass contains various functions that are used when building Qt4.
14 11
15inherit base eutils multilib toolchain-funcs flag-o-matic versionator 12case ${EAPI} in
13 4|5) : ;;
14 *) die "qt4-build.eclass: unsupported EAPI=${EAPI:-0}" ;;
15esac
16 16
17MY_PV=${PV/_/-} 17inherit eutils flag-o-matic multilib toolchain-funcs
18if version_is_at_least 4.5.99999999; then 18
19HOMEPAGE="https://www.qt.io/ https://qt-project.org/"
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"
19 MY_P=qt-everywhere-opensource-src-${MY_PV} 35 MY_P=qt-everywhere-opensource-src-${PV/_/-}
20else 36 SRC_URI="http://download.qt.io/archive/qt/${PV%.*}/${PV}/${MY_P}.tar.gz"
21 MY_P=qt-x11-opensource-src-${MY_PV} 37 S=${WORKDIR}/${MY_P}
38 ;;
39esac
40
41IUSE="aqua debug pch"
42[[ ${PN} != qtxmlpatterns ]] && IUSE+=" +exceptions"
43
44DEPEND="virtual/pkgconfig"
45if [[ ${QT4_BUILD_TYPE} == live ]]; then
46 DEPEND+=" dev-lang/perl"
22fi 47fi
23 48
24HOMEPAGE="http://qt.nokia.com/"
25SRC_URI="http://get.qt.nokia.com/qt/source/${MY_P}.tar.gz"
26
27LICENSE="|| ( LGPL-2.1 GPL-3 )"
28IUSE="debug pch aqua"
29
30RDEPEND="
31 !<x11-libs/qt-assistant-${PV}
32 !>x11-libs/qt-assistant-${PV}-r9999
33 !<x11-libs/qt-core-${PV}
34 !>x11-libs/qt-core-${PV}-r9999
35 !<x11-libs/qt-dbus-${PV}
36 !>x11-libs/qt-dbus-${PV}-r9999
37 !<x11-libs/qt-demo-${PV}
38 !>x11-libs/qt-demo-${PV}-r9999
39 !<x11-libs/qt-gui-${PV}
40 !>x11-libs/qt-gui-${PV}-r9999
41 !<x11-libs/qt-opengl-${PV}
42 !>x11-libs/qt-opengl-${PV}-r9999
43 !<x11-libs/qt-phonon-${PV}
44 !>x11-libs/qt-phonon-${PV}-r9999
45 !<x11-libs/qt-qt3support-${PV}
46 !>x11-libs/qt-qt3support-${PV}-r9999
47 !<x11-libs/qt-script-${PV}
48 !>x11-libs/qt-script-${PV}-r9999
49 !<x11-libs/qt-sql-${PV}
50 !>x11-libs/qt-sql-${PV}-r9999
51 !<x11-libs/qt-svg-${PV}
52 !>x11-libs/qt-svg-${PV}-r9999
53 !<x11-libs/qt-test-${PV}
54 !>x11-libs/qt-test-${PV}-r9999
55 !<x11-libs/qt-webkit-${PV}
56 !>x11-libs/qt-webkit-${PV}-r9999
57 !<x11-libs/qt-xmlpatterns-${PV}
58 !>x11-libs/qt-xmlpatterns-${PV}-r9999
59"
60
61S=${WORKDIR}/${MY_P}
62
63# @FUNCTION: qt4-build_pkg_setup 49# @FUNCTION: qt4-build_pkg_setup
64# @DESCRIPTION: 50# @DESCRIPTION:
65# Sets up S, MY_P, PATH, and LD_LIBRARY_PATH 51# Sets up PATH and LD_LIBRARY_PATH.
66qt4-build_pkg_setup() { 52qt4-build_pkg_setup() {
67 [[ ${EAPI} == 2 ]] && use !prefix && EPREFIX= 53 # Warn users of possible breakage when downgrading to a previous release.
68 54 # Downgrading revisions within the same release is safe.
55 if has_version ">${CATEGORY}/${P}-r9999:4"; then
56 ewarn
57 ewarn "Downgrading Qt is completely unsupported and can break your system!"
58 ewarn
59 fi
69 60
70 PATH="${S}/bin${PATH:+:}${PATH}" 61 PATH="${S}/bin${PATH:+:}${PATH}"
71 if [[ ${CHOST} != *-darwin* ]]; then 62 if [[ ${CHOST} != *-darwin* ]]; then
72 LD_LIBRARY_PATH="${S}/lib${LD_LIBRARY_PATH:+:}${LD_LIBRARY_PATH}" 63 LD_LIBRARY_PATH="${S}/lib${LD_LIBRARY_PATH:+:}${LD_LIBRARY_PATH}"
73 else 64 else
74 DYLD_LIBRARY_PATH="${S}/lib${DYLD_LIBRARY_PATH:+:}${DYLD_LIBRARY_PATH}" 65 DYLD_LIBRARY_PATH="${S}/lib${DYLD_LIBRARY_PATH:+:}${DYLD_LIBRARY_PATH}"
75 # On MacOS we *need* at least src/gui/kernel/qapplication_mac.mm for 66 # On MacOS we *need* at least src/gui/kernel/qapplication_mac.mm for
76 # platform detection. Note: needs to come before any directories to 67 # platform detection. Note: needs to come before any directories to
77 # avoid extract failure. 68 # avoid extract failure.
78 [[ ${CHOST} == *-apple-darwin* ]] && \ 69 [[ ${CHOST} == *-apple-darwin* ]] && \
79 QT4_EXTRACT_DIRECTORIES="src/gui/kernel/qapplication_mac.mm ${QT4_EXTRACT_DIRECTORIES}" 70 QT4_EXTRACT_DIRECTORIES="src/gui/kernel/qapplication_mac.mm
71 ${QT4_EXTRACT_DIRECTORIES}"
80 fi 72 fi
81
82 # Make sure ebuilds use the required EAPI
83 if [[ ${EAPI} != [23] ]]; then
84 eerror "The qt4-build eclass requires EAPI=2 or EAPI=3, but this ebuild is using"
85 eerror "EAPI=${EAPI:-0}. The ebuild author or editor failed. This ebuild needs to be"
86 eerror "fixed. Using qt4-build eclass without EAPI=2 or EAPI=3 will fail."
87 die "qt4-build eclass requires EAPI=2 or EAPI=3"
88 fi
89
90 if ! version_is_at_least 4.1 $(gcc-version); then
91 ewarn "Using a GCC version lower than 4.1 is not supported!"
92 echo
93 ebeep 3
94 fi
95} 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.
96 95
97# @ECLASS-VARIABLE: QT4_TARGET_DIRECTORIES 96# @ECLASS-VARIABLE: QT4_TARGET_DIRECTORIES
97# @DEFAULT_UNSET
98# @DESCRIPTION: 98# @DESCRIPTION:
99# Arguments for build_target_directories. Takes the directories, in which the 99# Space-separated list of directories that will be configured,
100# code should be compiled. This is a space-separated list 100# compiled, and installed. All paths must be relative to ${S}.
101
102# @ECLASS-VARIABLE: QT4_EXTRACT_DIRECTORIES
103# @DESCRIPTION:
104# Space separated list including the directories that will be extracted from Qt
105# tarball
106 101
107# @FUNCTION: qt4-build_src_unpack 102# @FUNCTION: qt4-build_src_unpack
108# @DESCRIPTION: 103# @DESCRIPTION:
109# Unpacks the sources 104# Unpacks the sources.
110qt4-build_src_unpack() { 105qt4-build_src_unpack() {
111 setqtenv 106 setqtenv
112 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=
113 for target in configure LICENSE.GPL3 LICENSE.LGPL projects.pro \ 133 for target in configure LICENSE.GPL3 LICENSE.LGPL projects.pro \
114 src/{qbase,qt_targets,qt_install}.pri bin config.tests mkspecs qmake \ 134 src/{qbase,qt_targets,qt_install}.pri bin config.tests \
115 ${QT4_EXTRACT_DIRECTORIES}; do 135 mkspecs qmake ${QT4_EXTRACT_DIRECTORIES}
136 do
116 targets+=" ${MY_P}/${target}" 137 targets+="${MY_P}/${target} "
117 done 138 done
118 139
119 echo tar xzpf "${DISTDIR}"/${MY_P}.tar.gz ${targets} 140 ebegin "Unpacking parts of ${tarball}:" ${targets//${MY_P}\/}
120 tar xzpf "${DISTDIR}"/${MY_P}.tar.gz ${targets} || die 141 tar -xzf "${DISTDIR}/${tarball}" ${targets}
142 eend $? || die "failed to unpack"
143 ;;
144 esac
121} 145}
122
123# @ECLASS-VARIABLE: PATCHES
124# @DESCRIPTION:
125# In case you have patches to apply, specify them in PATCHES variable. Make sure
126# to specify the full path. This variable is necessary for src_prepare phase.
127# example:
128# PATCHES="${FILESDIR}"/mypatch.patch
129# ${FILESDIR}"/mypatch2.patch"
130#
131 146
132# @FUNCTION: qt4-build_src_prepare 147# @FUNCTION: qt4-build_src_prepare
133# @DESCRIPTION: 148# @DESCRIPTION:
134# 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
135# source files in order to respect CFLAGS/CXXFLAGS/LDFLAGS specified on /etc/make.conf. 150# the build system in order to respect CFLAGS/CXXFLAGS/LDFLAGS specified in make.conf.
136qt4-build_src_prepare() { 151qt4-build_src_prepare() {
137 setqtenv 152 setqtenv
138 cd "${S}" 153
154 if [[ ${QT4_BUILD_TYPE} == live ]]; then
155 QTDIR="." ./bin/syncqt || die "syncqt failed"
156 fi
157
158 # avoid X11 dependency in non-gui packages
159 local nolibx11_pkgs="qtbearer qtcore qtdbus qtscript qtsql qttest qtxmlpatterns"
160 has ${PN} ${nolibx11_pkgs} && qt_nolibx11
139 161
140 if use aqua; then 162 if use aqua; then
141 # provide a proper macx-g++-64 163 # provide a proper macx-g++-64
142 use x64-macos && ln -s macx-g++ mkspecs/$(qt_mkspecs_dir) 164 use x64-macos && ln -s macx-g++ mkspecs/$(qt_mkspecs_dir)
143 165
144 sed -e '/^CONFIG/s:app_bundle::' \ 166 sed -e '/^CONFIG/s:app_bundle::' \
145 -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:' \
146 -i mkspecs/$(qt_mkspecs_dir)/qmake.conf || die "sed failed" 168 -i mkspecs/$(qt_mkspecs_dir)/qmake.conf || die
147 fi 169 fi
148 170
149 if [[ ${PN} != qt-core ]]; then 171 if [[ ${CATEGORY}/${PN} != dev-qt/qtcore ]]; then
150 skip_qmake_build_patch 172 skip_qmake_build
151 skip_project_generation_patch 173 skip_project_generation
152 symlink_binaries_to_buildtree 174 symlink_binaries_to_buildtree
153 fi 175 fi
154 176
155 if [[ ${CHOST} == *86*-apple-darwin* ]] ; then 177 if use_if_iuse c++0x; then
156 # qmake bus errors with -O2 but -O3 works 178 append-cxxflags -std=c++0x
157 replace-flags -O2 -O3
158 fi
159
160 # Bug 282984 && Bug 295530
161 sed -e "s:\(^SYSTEM_VARIABLES\):CC=$(tc-getCC)\nCXX=$(tc-getCXX)\n\1:" \
162 -i configure || die "sed qmake compilers failed"
163 sed -e "s:\(\$MAKE\):\1 CC=$(tc-getCC) CXX=$(tc-getCXX) LD=$(tc-getCXX):" \
164 -i config.tests/unix/compile.test || die "sed test compilers failed"
165
166 # Bug 178652
167 if [[ $(gcc-major-version) == 3 ]] && use amd64; then
168 ewarn "Appending -fno-gcse to CFLAGS/CXXFLAGS"
169 append-flags -fno-gcse
170 fi
171
172 # Unsupported old gcc versions - hardened needs this :(
173 if [[ $(gcc-major-version) -lt 4 ]] ; then
174 ewarn "Appending -fno-stack-protector to CXXFLAGS"
175 append-cxxflags -fno-stack-protector
176 # Bug 253127
177 sed -e "/^QMAKE_CFLAGS\t/ s:$: -fno-stack-protector-all:" \
178 -i "${S}"/mkspecs/common/g++.conf || die "sed ${S}/mkspecs/common/g++.conf failed"
179 fi 179 fi
180 180
181 # Bug 261632 181 # Bug 261632
182 if use ppc64; then 182 if use ppc64; then
183 ewarn "Appending -mminimal-toc to CFLAGS/CXXFLAGS"
184 append-flags -mminimal-toc 183 append-flags -mminimal-toc
185 fi 184 fi
186 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
196 fi
197
198 # Respect CC, CXX, {C,CXX,LD}FLAGS in .qmake.cache
199 sed -e "/^SYSTEM_VARIABLES=/i \
200 CC='$(tc-getCC)'\n\
201 CXX='$(tc-getCXX)'\n\
202 CFLAGS='${CFLAGS}'\n\
203 CXXFLAGS='${CXXFLAGS}'\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 \
212 || die "sed SYSTEM_VARIABLES failed"
213
214 # Respect CC, CXX, LINK and *FLAGS in config.tests
215 find config.tests/unix -name '*.test' -type f -print0 | xargs -0 \
216 sed -i -e "/bin\/qmake/ s: \"\$SRCDIR/: \
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"
220
187 # Bug 172219 221 # Bug 172219
188 sed -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \ 222 sed -e 's:/X11R6/:/:' -i mkspecs/$(qt_mkspecs_dir)/qmake.conf || die
189 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \
190 -e "s:QMAKE_LFLAGS_RELEASE.*=.*:QMAKE_LFLAGS_RELEASE=${LDFLAGS}:" \
191 -e "s:X11R6/::" \
192 -i "${S}"/mkspecs/$(qt_mkspecs_dir)/qmake.conf || die "sed ${S}/mkspecs/$(qt_mkspecs_dir)/qmake.conf failed"
193 223
194 if [[ ${CHOST} != *-darwin* ]]; then 224 if [[ ${CHOST} == *-darwin* ]]; then
195 sed -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \
196 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \
197 -e "s:QMAKE_LFLAGS_RELEASE.*=.*:QMAKE_LFLAGS_RELEASE=${LDFLAGS}:" \
198 -i mkspecs/common/g++.conf || die "sed mkspecs/common/g++.conf failed"
199 else
200 # Set FLAGS *and* remove -arch, since our gcc-apple is multilib 225 # Set FLAGS *and* remove -arch, since our gcc-apple is multilib
201 # 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 \
202 sed -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \ 238 -e "s:QMAKE_CFLAGS_RELEASE.*=.*:QMAKE_CFLAGS_RELEASE=${CFLAGS}:" \
203 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \ 239 -e "s:QMAKE_CXXFLAGS_RELEASE.*=.*:QMAKE_CXXFLAGS_RELEASE=${CXXFLAGS}:" \
204 -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}:" \
205 -e "s:-arch\s\w*::g" \ 241 -e "s:-arch\s\w*::g" \
206 -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"
207 244
208 # 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
209 # fix arch handling (automagically duplicates our -arch arg and breaks 246 # fix arch handling (automagically duplicates our -arch arg and breaks
210 # 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
211 sed \ 252 sed \
212 -e "s:-arch i386::" \ 253 -e "s:-arch i386::" \
213 -e "s:-arch ppc::" \ 254 -e "s:-arch ppc::" \
214 -e "s:-arch x86_64::" \ 255 -e "s:-arch x86_64::" \
215 -e "s:-arch ppc64::" \ 256 -e "s:-arch ppc64::" \
216 -e "s:-arch \$i::" \ 257 -e "s:-arch \$i::" \
217 -e "/if \[ ! -z \"\$NATIVE_64_ARCH\" \]; then/,/fi/ d" \ 258 -e "/if \[ ! -z \"\$NATIVE_64_ARCH\" \]; then/,/fi/ d" \
218 -e "s:CFG_MAC_XARCH=yes:CFG_MAC_XARCH=no:g" \ 259 -e "s:CFG_MAC_XARCH=yes:CFG_MAC_XARCH=no:g" \
219 -e "s:-Xarch_x86_64::g" \ 260 -e "s:-Xarch_x86_64::g" \
220 -e "s:-Xarch_ppc64::g" \ 261 -e "s:-Xarch_ppc64::g" \
221 -i configure mkspecs/common/mac-g++.conf || die "sed configure failed" 262 -i configure ${mac_gcc_confs} \
263 || die "sed -arch/-Xarch failed"
222 264
223 # 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.
224 if [[ ${CHOST} == *-apple-darwin10 ]] ; then 266 if [[ ${CHOST} == *-apple-darwin10 ]]; then
225 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" \
226 -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" \
227 -i configure mkspecs/common/mac-g++.conf || die "sed configure failed" 269 -i configure ${mac_gpp_conf} \
270 || die "sed deployment target failed"
228 fi 271 fi
229 fi 272 fi
230 273
231 # 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
232 # Darwin, for which the sources already cater for -liconv 275 # Darwin, for which the sources already cater for -liconv
233 if use !elibc_glibc && [[ ${CHOST} != *-darwin* ]] ; then 276 if use !elibc_glibc && [[ ${CHOST} != *-darwin* ]]; then
234 sed \ 277 sed -e 's|mac:\(LIBS += -liconv\)|\1|g' \
235 -e "s|mac:LIBS += -liconv|LIBS += -liconv|g" \
236 -i config.tests/unix/iconv/iconv.pro \ 278 -i config.tests/unix/iconv/iconv.pro \
237 || die "sed on iconv.pro failed" 279 || die "sed iconv.pro failed"
238 fi 280 fi
239 281
240 # we need some patches for Solaris 282 # we need some patches for Solaris
241 sed -i \
242 -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,' \
243 mkspecs/$(qt_mkspecs_dir)/qmake.conf || die 284 mkspecs/$(qt_mkspecs_dir)/qmake.conf || die
244 # use GCC over SunStudio 285 # use GCC over SunStudio
245 sed -i -e '/PLATFORM=solaris-cc/s/cc/g++/' configure || die 286 sed -i -e '/PLATFORM=solaris-cc/s/cc/g++/' configure || die
246 # don't flirt with non-Prefix stuff, we're quite possessive 287 # do not flirt with non-Prefix stuff, we're quite possessive
247 sed -i -e '/^QMAKE_\(LIB\|INC\)DIR\(_X11\|_OPENGL\|\)\t/s/=.*$/=/' \ 288 sed -i -e '/^QMAKE_\(LIB\|INC\)DIR\(_X11\|_OPENGL\|\)\t/s/=.*$/=/' \
248 mkspecs/$(qt_mkspecs_dir)/qmake.conf || die 289 mkspecs/$(qt_mkspecs_dir)/qmake.conf || die
249 290
250 base_src_prepare 291 # apply patches
292 [[ -n ${PATCHES[@]} ]] && epatch "${PATCHES[@]}"
293 epatch_user
251} 294}
252 295
253# @FUNCTION: qt4-build_src_configure 296# @FUNCTION: qt4-build_src_configure
254# @DESCRIPTION: 297# @DESCRIPTION:
255# Default configure phase 298# Default configure phase
256qt4-build_src_configure() { 299qt4-build_src_configure() {
257 setqtenv 300 setqtenv
258 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"
259 360
260 # 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
261 # Darwin, for which the sources already cater for -liconv 362 # Darwin, for which the sources already cater for -liconv
262 use !elibc_glibc && [[ ${CHOST} != *-darwin* ]] && \ 363 if use !elibc_glibc && [[ ${CHOST} != *-darwin* ]]; then
263 myconf+=" -liconv" 364 conf+=" -liconv"
365 fi
264 366
265 if has glib ${IUSE//+} && use glib; then 367 if use_if_iuse glib; then
266 # use -I, -L and -l from configure
267 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)"
268 # avoid the -pthread argument 369 # avoid the -pthread argument
269 myconf+=" ${glibflags//-pthread}" 370 conf+=" ${glibflags//-pthread}"
270 unset glibflags 371 unset glibflags
271 fi 372 fi
272 373
273 if use aqua ; then 374 if use aqua; then
274 # On (snow) leopard use the new (frameworked) cocoa code. 375 # On (snow) leopard use the new (frameworked) cocoa code.
275 if [[ ${CHOST##*-darwin} -ge 9 ]] ; then 376 if [[ ${CHOST##*-darwin} -ge 9 ]]; then
276 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}"
277 382
278 # We are crazy and build cocoa + qt3support :-) 383 # We are crazy and build cocoa + qt3support :-)
279 if use qt3support; then 384 if use qt3support; then
280 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\"|" \
281 -i configure 386 -i configure || die
282 fi 387 fi
283 388 else
284 # We need the source's headers, not the installed ones. 389 conf+=" -no-framework"
285 myconf+=" -I${S}/include"
286
287 # Add hint for the framework location.
288 myconf+=" -F${QTLIBDIR}"
289 fi 390 fi
290 else 391 else
291 # freetype2 include dir is non-standard, thus include it on configure 392 # freetype2 include dir is non-standard, thus pass it to configure
292 # use -I from configure
293 myconf+=" $(pkg-config --cflags freetype2)" 393 conf+=" $(pkg-config --cflags-only-I freetype2)"
294 fi 394 fi
295 395
396 conf+=" ${myconf}"
397 myconf=
398
296 echo ./configure ${myconf} 399 echo ./configure ${conf}
297 ./configure ${myconf} || die "./configure failed" 400 ./configure ${conf} || die "./configure failed"
298 myconf="" 401
402 prepare_directories ${QT4_TARGET_DIRECTORIES}
299} 403}
300 404
301# @FUNCTION: qt4-build_src_compile 405# @FUNCTION: qt4-build_src_compile
406# @DESCRIPTION:
302# @DESCRIPTION: Actual compile phase 407# Actual compile phase
303qt4-build_src_compile() { 408qt4-build_src_compile() {
304 setqtenv 409 setqtenv
305 410
306 build_directories ${QT4_TARGET_DIRECTORIES} 411 build_directories ${QT4_TARGET_DIRECTORIES}
307} 412}
308 413
414# @FUNCTION: qt4-build_src_test
415# @DESCRIPTION:
416# Runs tests only in target directories.
417qt4-build_src_test() {
418 # QtMultimedia does not have any test suite (bug #332299)
419 [[ ${CATEGORY}/${PN} == dev-qt/qtmultimedia ]] && return
420
421 for dir in ${QT4_TARGET_DIRECTORIES}; do
422 emake -j1 check -C ${dir}
423 done
424}
425
309# @FUNCTION: fix_includes 426# @FUNCTION: fix_includes
310# @DESCRIPTION: 427# @DESCRIPTION:
311# For MacOSX we need to add some symlinks when frameworks are 428# For MacOS X we need to add some symlinks when frameworks are
312# 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.
313fix_includes() { 430fix_includes() {
314 if use aqua && [[ ${CHOST##*-darwin} -ge 9 ]] ; then 431 if use aqua && [[ ${CHOST##*-darwin} -ge 9 ]]; then
432 local frw dest f h rdir
315 # Some packages tend to include <Qt/...> 433 # Some packages tend to include <Qt/...>
316 dodir "${QTHEADERDIR#${EPREFIX}}"/Qt 434 dodir "${QTHEADERDIR#${EPREFIX}}"/Qt
317 435
318 # Fake normal headers when frameworks are installed... eases life later on 436 # Fake normal headers when frameworks are installed... eases life later
319 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
320 for frw in "${D}${QTLIBDIR}"/*.framework; do 453 for frw in "${D}${QTLIBDIR}"/*.framework; do
321 [[ -e "${frw}"/Headers ]] || continue 454 [[ -e "${frw}"/Headers ]] || continue
322 f=$(basename ${frw}) 455 f=$(basename ${frw})
323 dest="${QTHEADERDIR#${EPREFIX}}"/${f%.framework} 456 dest="${QTHEADERDIR#${EPREFIX}}"/${f%.framework}
324 dosym "${QTLIBDIR#${EPREFIX}}"/${f}/Headers "${dest}" 457 dosym "${rdir}"/${f}/Headers "${dest}"
325 458
326 # Link normal headers as well. 459 # Link normal headers as well.
327 for hdr in "${D}/${QTLIBDIR}/${f}"/Headers/*; do 460 for hdr in "${D}/${QTLIBDIR}/${f}"/Headers/*; do
328 h=$(basename ${hdr}) 461 h=$(basename ${hdr})
329 dosym "${QTLIBDIR#${EPREFIX}}"/${f}/Headers/${h} "${QTHEADERDIR#${EPREFIX}}"/Qt/${h} 462 dosym "../${rdir}"/${f}/Headers/${h} \
463 "${QTHEADERDIR#${EPREFIX}}"/Qt/${h}
330 done 464 done
331 done 465 done
332 fi 466 fi
333} 467}
334 468
335# @FUNCTION: qt4-build_src_install 469# @FUNCTION: qt4-build_src_install
336# @DESCRIPTION: 470# @DESCRIPTION:
337# Perform the actual installation including some library fixes. 471# Perform the actual installation including some library fixes.
338qt4-build_src_install() { 472qt4-build_src_install() {
339 [[ ${EAPI} == 2 ]] && use !prefix && ED=${D}
340 setqtenv 473 setqtenv
474
341 install_directories ${QT4_TARGET_DIRECTORIES} 475 install_directories ${QT4_TARGET_DIRECTORIES}
342 install_qconfigs 476 install_qconfigs
343 fix_library_files 477 fix_library_files
344 fix_includes 478 fix_includes
479
480 # remove .la files since we are building only shared libraries
481 prune_libtool_files
345} 482}
346 483
347# @FUNCTION: setqtenv 484# @FUNCTION: setqtenv
485# @INTERNAL
348setqtenv() { 486setqtenv() {
349 # Set up installation directories 487 # Set up installation directories
350 QTBASEDIR=${EPREFIX}/usr/$(get_libdir)/qt4
351 QTPREFIXDIR=${EPREFIX}/usr 488 QTPREFIXDIR=${EPREFIX}/usr
352 QTBINDIR=${EPREFIX}/usr/bin 489 QTBINDIR=${QTPREFIXDIR}/bin
353 QTLIBDIR=${EPREFIX}/usr/$(get_libdir)/qt4 490 QTLIBDIR=${QTPREFIXDIR}/$(get_libdir)/qt4
354 QMAKE_LIBDIR_QT=${QTLIBDIR}
355 QTPCDIR=${EPREFIX}/usr/$(get_libdir)/pkgconfig 491 QTPCDIR=${QTPREFIXDIR}/$(get_libdir)/pkgconfig
356 QTDATADIR=${EPREFIX}/usr/share/qt4
357 QTDOCDIR=${EPREFIX}/usr/share/doc/qt-${PV} 492 QTDOCDIR=${QTPREFIXDIR}/share/doc/qt-${PV}
358 QTHEADERDIR=${EPREFIX}/usr/include/qt4 493 QTHEADERDIR=${QTPREFIXDIR}/include/qt4
359 QTPLUGINDIR=${QTLIBDIR}/plugins 494 QTPLUGINDIR=${QTLIBDIR}/plugins
495 QTIMPORTDIR=${QTLIBDIR}/imports
496 QTDATADIR=${QTPREFIXDIR}/share/qt4
497 QTTRANSDIR=${QTDATADIR}/translations
360 QTSYSCONFDIR=${EPREFIX}/etc/qt4 498 QTSYSCONFDIR=${EPREFIX}/etc/qt4
361 QTTRANSDIR=${QTDATADIR}/translations
362 QTEXAMPLESDIR=${QTDATADIR}/examples 499 QTEXAMPLESDIR=${QTDATADIR}/examples
363 QTDEMOSDIR=${QTDATADIR}/demos 500 QTDEMOSDIR=${QTDATADIR}/demos
364 QT_INSTALL_PREFIX=${EPREFIX}/usr/$(get_libdir)/qt4 501 QMAKE_LIBDIR_QT=${QTLIBDIR}
502
365 PLATFORM=$(qt_mkspecs_dir) 503 PLATFORM=$(qt_mkspecs_dir)
366
367 unset QMAKESPEC 504 unset QMAKESPEC
368}
369 505
370# @FUNCTION: standard_configure_options 506 export XDG_CONFIG_HOME="${T}"
371# @DESCRIPTION: 507}
372# Sets up some standard configure options, like libdir (if necessary), whether
373# debug info is wanted or not.
374standard_configure_options() {
375 local myconf=
376 508
377 [[ $(get_libdir) != lib ]] && myconf+=" -L${EPREFIX}/usr/$(get_libdir)" 509# @FUNCTION: prepare_directories
378 510# @USAGE: < directories >
379 # Disable visibility explicitly if gcc version isn't 4 511# @INTERNAL
380 if [[ $(gcc-major-version) -lt 4 ]]; then 512# @DESCRIPTION:
381 myconf+=" -no-reduce-exports" 513# Generates Makefiles for the given list of directories.
382 fi 514prepare_directories() {
383 515 for x in "$@"; do
384 # precompiled headers doesn't work on hardened, where the flag is masked. 516 pushd "${S}"/${x} >/dev/null || die
385 myconf+=" $(qt_use pch)" 517 einfo "Running qmake in: ${x}"
386 518 "${S}"/bin/qmake \
387 if use debug; then 519 "LIBS+=-L${QTLIBDIR}" \
388 myconf+=" -debug" 520 "CONFIG+=nostrip" \
389 else 521 || die "qmake failed"
390 myconf+=" -release" 522 popd >/dev/null || die
391 fi 523 done
392 myconf+=" -no-separate-debug-info"
393
394 use aqua && myconf+=" -no-framework"
395
396 # ARCH is set on Gentoo. Qt now falls back to generic on an unsupported
397 # $(tc-arch). Therefore we convert it to supported values.
398 case "$(tc-arch)" in
399 amd64|x64-*) myconf+=" -arch x86_64" ;;
400 ppc-macos) myconf+=" -arch ppc" ;;
401 ppc|ppc64|ppc-*) myconf+=" -arch powerpc" ;;
402 sparc|sparc-*) myconf+=" -arch sparc" ;;
403 x86-macos) myconf+=" -arch x86" ;;
404 x86|x86-*) myconf+=" -arch i386" ;;
405 alpha|arm|ia64|mips|s390|sparc) myconf+=" -arch $(tc-arch)" ;;
406 hppa|sh) myconf+=" -arch generic" ;;
407 *) die "$(tc-arch) is unsupported by this eclass. Please file a bug." ;;
408 esac
409
410 # 4.6: build qt-core with exceptions or qt-xmlpatterns won't build
411 local exceptions=
412 case "${PV}" in
413 4.6.*)
414 if [[ ${PN} != "qt-core" ]] && [[ ${PN} != "qt-xmlpatterns" ]]; then
415 case "${PV}:${CHOST}" in
416 4.6.0*:*-darwin*)
417 : # http://bugreports.qt.nokia.com/browse/QTBUG-5909
418 # workaround for compilation error on OSX (qt-gui)
419 ;;
420 *)
421 exceptions="-no-exceptions"
422 ;;
423 esac
424 fi
425 ;;
426 *)
427 [[ ${PN} == "qt-xmlpatterns" ]] || exceptions="-no-exceptions"
428 ;;
429 esac
430
431 # note about -reduce-relocations:
432 # That flag seems to introduce major breakage to applications,
433 # mostly to be seen as a core dump with the message "QPixmap: Must
434 # construct a QApplication before a QPaintDevice" on Solaris
435 # -- Daniel Vergien
436 [[ ${CHOST} != *-solaris* ]] && myconf+=" -reduce-relocations"
437
438 myconf+=" -platform $(qt_mkspecs_dir) -stl -verbose -largefile -confirm-license
439 -prefix ${QTPREFIXDIR} -bindir ${QTBINDIR} -libdir ${QTLIBDIR}
440 -datadir ${QTDATADIR} -docdir ${QTDOCDIR} -headerdir ${QTHEADERDIR}
441 -plugindir ${QTPLUGINDIR} -sysconfdir ${QTSYSCONFDIR}
442 -translationdir ${QTTRANSDIR} -examplesdir ${QTEXAMPLESDIR}
443 -demosdir ${QTDEMOSDIR} -silent -fast -opensource
444 ${exceptions}
445 -nomake examples -nomake demos"
446
447 echo "${myconf}"
448} 524}
449 525
450# @FUNCTION: build_directories 526# @FUNCTION: build_directories
451# @USAGE: < directories > 527# @USAGE: < directories >
528# @INTERNAL
452# @DESCRIPTION: 529# @DESCRIPTION:
453# Compiles the code in $QT4_TARGET_DIRECTORIES 530# Compiles the code in the given list of directories.
454build_directories() { 531build_directories() {
455 for x in "$@"; do 532 for x in "$@"; do
456 pushd "${S}"/${x} >/dev/null 533 pushd "${S}"/${x} >/dev/null || die
457 # avoid running over the maximum argument number, bug #299810 534 emake \
458 { 535 AR="$(tc-getAR) cqs" \
459 echo "${S}"/mkspecs/common/*.conf 536 CC="$(tc-getCC)" \
460 find "${S}" -name '*.pr[io]' 537 CXX="$(tc-getCXX)" \
461 } | xargs sed -i -e "s:\$\$\[QT_INSTALL_LIBS\]:${EPREFIX}/usr/$(get_libdir)/qt4:g" || die 538 LINK="$(tc-getCXX)" \
462 "${S}"/bin/qmake "LIBS+=-L${QTLIBDIR}" "CONFIG+=nostrip" || die "qmake failed" 539 RANLIB=":" \
463 emake CC="@echo compiling \$< && $(tc-getCC)" \ 540 STRIP=":"
464 CXX="@echo compiling \$< && $(tc-getCXX)" \
465 LINK="@echo linking \$@ && $(tc-getCXX)" || die "emake failed"
466 popd >/dev/null 541 popd >/dev/null || die
467 done 542 done
468} 543}
469 544
470# @FUNCTION: install_directories 545# @FUNCTION: install_directories
471# @USAGE: < directories > 546# @USAGE: < directories >
547# @INTERNAL
472# @DESCRIPTION: 548# @DESCRIPTION:
473# run emake install in the given directories, which are separated by spaces 549# Runs emake install in the given directories, which are separated by spaces.
474install_directories() { 550install_directories() {
475 for x in "$@"; do 551 for x in "$@"; do
476 pushd "${S}"/${x} >/dev/null || die "Can't pushd ${S}/${x}" 552 pushd "${S}"/${x} >/dev/null || die
477 emake INSTALL_ROOT="${D}" install || die "emake install failed" 553 emake INSTALL_ROOT="${D}" install
478 popd >/dev/null || die "Can't popd from ${S}/${x}" 554 popd >/dev/null || die
479 done 555 done
480} 556}
481 557
482# @ECLASS-VARIABLE: QCONFIG_ADD 558# @ECLASS-VARIABLE: QCONFIG_ADD
483# @DESCRIPTION: 559# @DESCRIPTION:
493# @DESCRIPTION: 569# @DESCRIPTION:
494# List variables that should be defined at the top of QtCore/qconfig.h 570# List variables that should be defined at the top of QtCore/qconfig.h
495: ${QCONFIG_DEFINE:=} 571: ${QCONFIG_DEFINE:=}
496 572
497# @FUNCTION: install_qconfigs 573# @FUNCTION: install_qconfigs
574# @INTERNAL
575# @DESCRIPTION:
498# @DESCRIPTION: Install gentoo-specific mkspecs configurations 576# Install gentoo-specific mkspecs configurations.
499install_qconfigs() { 577install_qconfigs() {
500 local x 578 local x
501 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} ]]; then 579 if [[ -n ${QCONFIG_ADD} || -n ${QCONFIG_REMOVE} ]]; then
502 for x in QCONFIG_ADD QCONFIG_REMOVE; do 580 for x in QCONFIG_ADD QCONFIG_REMOVE; do
503 [[ -n ${!x} ]] && echo ${x}=${!x} >> "${T}"/${PN}-qconfig.pri 581 [[ -n ${!x} ]] && echo ${x}=${!x} >> "${T}"/${PN}-qconfig.pri
504 done 582 done
505 insinto ${QTDATADIR#${EPREFIX}}/mkspecs/gentoo 583 insinto ${QTDATADIR#${EPREFIX}}/mkspecs/gentoo
506 doins "${T}"/${PN}-qconfig.pri || die "installing ${PN}-qconfig.pri failed" 584 doins "${T}"/${PN}-qconfig.pri
507 fi 585 fi
508 586
509 if [[ -n ${QCONFIG_DEFINE} ]]; then 587 if [[ -n ${QCONFIG_DEFINE} ]]; then
510 for x in ${QCONFIG_DEFINE}; do 588 for x in ${QCONFIG_DEFINE}; do
511 echo "#define ${x}" >> "${T}"/gentoo-${PN}-qconfig.h 589 echo "#define ${x}" >> "${T}"/gentoo-${PN}-qconfig.h
512 done 590 done
513 insinto ${QTHEADERDIR#${EPREFIX}}/Gentoo 591 insinto ${QTHEADERDIR#${EPREFIX}}/Gentoo
514 doins "${T}"/gentoo-${PN}-qconfig.h || die "installing ${PN}-qconfig.h failed" 592 doins "${T}"/gentoo-${PN}-qconfig.h
515 fi 593 fi
516} 594}
517 595
518# @FUNCTION: generate_qconfigs 596# @FUNCTION: generate_qconfigs
519# @DESCRIPTION: Generates gentoo-specific configurations 597# @INTERNAL
598# @DESCRIPTION:
599# Generates gentoo-specific qconfig.{h,pri}.
520generate_qconfigs() { 600generate_qconfigs() {
521 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
522 local x qconfig_add qconfig_remove qconfig_new 602 local x qconfig_add qconfig_remove qconfig_new
523 for x in "${ROOT}${QTDATADIR}"/mkspecs/gentoo/*-qconfig.pri; do 603 for x in "${ROOT}${QTDATADIR}"/mkspecs/gentoo/*-qconfig.pri; do
524 [[ -f ${x} ]] || continue 604 [[ -f ${x} ]] || continue
525 qconfig_add+=" $(sed -n 's/^QCONFIG_ADD=//p' "${x}")" 605 qconfig_add+=" $(sed -n 's/^QCONFIG_ADD=//p' "${x}")"
526 qconfig_remove+=" $(sed -n 's/^QCONFIG_REMOVE=//p' "${x}")" 606 qconfig_remove+=" $(sed -n 's/^QCONFIG_REMOVE=//p' "${x}")"
527 done 607 done
528 608
529 # 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}
530 # just makes things worse. 610 # just makes things worse.
531 if [[ -e "${ROOT}${QTDATADIR}"/mkspecs/gentoo/qconfig.pri ]]; then 611 if [[ -e "${ROOT}${QTDATADIR}"/mkspecs/gentoo/qconfig.pri ]]; then
532 # start with the qconfig.pri that qt-core installed 612 # start with the qconfig.pri that qtcore installed
533 if ! cp "${ROOT}${QTDATADIR}"/mkspecs/gentoo/qconfig.pri \ 613 if ! cp "${ROOT}${QTDATADIR}"/mkspecs/gentoo/qconfig.pri \
534 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri; then 614 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri; then
535 eerror "cp qconfig failed." 615 eerror "cp qconfig failed."
536 return 1 616 return 1
537 fi 617 fi
538 618
539 # generate list of QT_CONFIG entries from the existing list 619 # generate list of QT_CONFIG entries from the existing list
540 # including qconfig_add and excluding qconfig_remove 620 # including qconfig_add and excluding qconfig_remove
541 for x in $(sed -n 's/^QT_CONFIG +=//p' \ 621 for x in $(sed -n 's/^QT_CONFIG +=//p' \
542 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri) ${qconfig_add}; do 622 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri) ${qconfig_add}; do
543 hasq ${x} ${qconfig_remove} || qconfig_new+=" ${x}" 623 has ${x} ${qconfig_remove} || qconfig_new+=" ${x}"
544 done 624 done
545 625
546 # replace the existing QT_CONFIG list with qconfig_new 626 # replace the existing QT_CONFIG list with qconfig_new
547 if ! sed -i -e "s/QT_CONFIG +=.*/QT_CONFIG += ${qconfig_new}/" \ 627 if ! sed -i -e "s/QT_CONFIG +=.*/QT_CONFIG += ${qconfig_new}/" \
548 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri; then 628 "${ROOT}${QTDATADIR}"/mkspecs/qconfig.pri; then
572 fi 652 fi
573 fi 653 fi
574} 654}
575 655
576# @FUNCTION: qt4-build_pkg_postrm 656# @FUNCTION: qt4-build_pkg_postrm
657# @DESCRIPTION:
577# @DESCRIPTION: Generate configurations when the package is completely removed 658# Regenerate configuration when the package is completely removed.
578qt4-build_pkg_postrm() { 659qt4-build_pkg_postrm() {
579 generate_qconfigs 660 generate_qconfigs
580} 661}
581 662
582# @FUNCTION: qt4-build_pkg_postinst 663# @FUNCTION: qt4-build_pkg_postinst
664# @DESCRIPTION:
583# @DESCRIPTION: Generate configuration, plus throws a message about possible 665# Regenerate configuration, plus throw a message about possible
584# breakages and proposed solutions. 666# breakages and proposed solutions.
585qt4-build_pkg_postinst() { 667qt4-build_pkg_postinst() {
586 generate_qconfigs 668 generate_qconfigs
587} 669}
588 670
589# @FUNCTION: skip_qmake_build_patch 671# @FUNCTION: skip_qmake_build
672# @INTERNAL
590# @DESCRIPTION: 673# @DESCRIPTION:
591# Don't need to build qmake, as it's already installed from qt-core 674# Patches configure to skip qmake compilation, as it's already installed by qtcore.
592skip_qmake_build_patch() { 675skip_qmake_build() {
593 # Don't need to build qmake, as it's already installed from qt-core
594 sed -i -e "s:if true:if false:g" "${S}"/configure || die "Sed failed" 676 sed -i -e "s:if true:if false:g" "${S}"/configure || die
595} 677}
596 678
597# @FUNCTION: skip_project_generation_patch 679# @FUNCTION: skip_project_generation
680# @INTERNAL
598# @DESCRIPTION: 681# @DESCRIPTION:
599# Exit the script early by throwing in an exit before all of the .pro files are scanned 682# Exit the script early by throwing in an exit before all of the .pro files are scanned.
600skip_project_generation_patch() { 683skip_project_generation() {
601 # Exit the script early by throwing in an exit before all of the .pro files are scanned
602 sed -e "s:echo \"Finding:exit 0\n\necho \"Finding:g" \ 684 sed -i -e "s:echo \"Finding:exit 0\n\necho \"Finding:g" "${S}"/configure || die
603 -i "${S}"/configure || die "Sed failed"
604} 685}
605 686
606# @FUNCTION: symlink_binaries_to_buildtree 687# @FUNCTION: symlink_binaries_to_buildtree
688# @INTERNAL
607# @DESCRIPTION: 689# @DESCRIPTION:
608# Symlink generated binaries to buildtree so they can be used during compilation 690# Symlinks generated binaries to buildtree, so they can be used during compilation time.
609# time
610symlink_binaries_to_buildtree() { 691symlink_binaries_to_buildtree() {
611 for bin in qmake moc uic rcc; do 692 for bin in qmake moc uic rcc; do
612 ln -s ${QTBINDIR}/${bin} "${S}"/bin/ || die "Symlinking ${bin} to ${S}/bin failed." 693 ln -s "${QTBINDIR}"/${bin} "${S}"/bin/ || die "symlinking ${bin} to ${S}/bin failed"
613 done 694 done
614} 695}
615 696
616# @FUNCTION: fix_library_files 697# @FUNCTION: fix_library_files
698# @INTERNAL
617# @DESCRIPTION: 699# @DESCRIPTION:
618# Fixes the pathes in *.la, *.prl, *.pc, as they are wrong due to sandbox and 700# Fixes the paths in *.la, *.prl, *.pc, as they are wrong due to sandbox and
619# moves the *.pc-files into the pkgconfig directory 701# moves the *.pc files into the pkgconfig directory.
620fix_library_files() { 702fix_library_files() {
703 local libfile
621 for libfile in "${D}"/${QTLIBDIR}/{*.la,*.prl,pkgconfig/*.pc}; do 704 for libfile in "${D}"/${QTLIBDIR}/{*.la,*.prl,pkgconfig/*.pc}; do
622 if [[ -e ${libfile} ]]; then 705 if [[ -e ${libfile} ]]; then
623 sed -i -e "s:${S}/lib:${QTLIBDIR}:g" ${libfile} || die "Sed on ${libfile} failed." 706 sed -i -e "s:${S}/lib:${QTLIBDIR}:g" ${libfile} || die "sed on ${libfile} failed"
624 fi 707 fi
625 done 708 done
626 709
627 # pkgconfig files refer to WORKDIR/bin as the moc and uic locations. Fix: 710 # pkgconfig files refer to WORKDIR/bin as the moc and uic locations
628 for libfile in "${D}"/${QTLIBDIR}/pkgconfig/*.pc; do 711 for libfile in "${D}"/${QTLIBDIR}/pkgconfig/*.pc; do
629 if [[ -e ${libfile} ]]; then 712 if [[ -e ${libfile} ]]; then
630 sed -i -e "s:${S}/bin:${QTBINDIR}:g" ${libfile} || die "Sed failed" 713 sed -i -e "s:${S}/bin:${QTBINDIR}:g" ${libfile} || die "sed on ${libfile} failed"
631 714
632 # Move .pc files into the pkgconfig directory 715 # Move .pc files into the pkgconfig directory
633 dodir ${QTPCDIR#${EPREFIX}} 716 dodir ${QTPCDIR#${EPREFIX}}
634 mv ${libfile} "${D}"/${QTPCDIR}/ \ 717 mv ${libfile} "${D}"/${QTPCDIR}/ || die "moving ${libfile} to ${D}/${QTPCDIR}/ failed"
635 || die "Moving ${libfile} to ${D}/${QTPCDIR}/ failed."
636 fi 718 fi
637 done 719 done
638 720
639 # Don't install an empty directory 721 # Don't install an empty directory
640 rmdir "${D}"/${QTLIBDIR}/pkgconfig 722 rmdir "${D}"/${QTLIBDIR}/pkgconfig
641} 723}
642 724
643# @FUNCTION: qt_use 725# @FUNCTION: qt_use
644# @USAGE: < flag > [ feature ] [ enableval ] 726# @USAGE: < flag > [ feature ] [ enableval ]
645# @DESCRIPTION: 727# @DESCRIPTION:
646# This will echo "${enableval}-${feature}" if <flag> is enabled, or 728# This will echo "-${enableval}-${feature}" if <flag> is enabled, or
647# "-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>
648# 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
649# assignment-part 731# "-${enableval}" part.
650qt_use() { 732qt_use() {
651 local flag=$1 733 use "$1" && echo "${3:+-$3}-${2:-$1}" || echo "-no-${2:-$1}"
652 local feature=$1
653 local enableval=
654
655 [[ -n $2 ]] && feature=$2
656 [[ -n $3 ]] && enableval=-$3
657
658 if use ${flag}; then
659 echo "${enableval}-${feature}"
660 else
661 echo "-no-${feature}"
662 fi
663} 734}
664 735
665# @FUNCTION: qt_mkspecs_dir 736# @FUNCTION: qt_mkspecs_dir
666# @RETURN: the specs-directory w/o path 737# @RETURN: the specs-directory w/o path
667# @DESCRIPTION: 738# @DESCRIPTION:
668# Allows us to define which mkspecs dir we want to use. 739# Allows us to define which mkspecs dir we want to use.
669qt_mkspecs_dir() { 740qt_mkspecs_dir() {
670 # Allows us to define which mkspecs dir we want to use.
671 local spec 741 local spec=
672 742
673 case ${CHOST} in 743 case "${CHOST}" in
674 *-freebsd*|*-dragonfly*) 744 *-freebsd*|*-dragonfly*)
675 spec=freebsd ;; 745 spec=freebsd ;;
676 *-openbsd*) 746 *-openbsd*)
677 spec=openbsd ;; 747 spec=openbsd ;;
678 *-netbsd*) 748 *-netbsd*)
689 *-solaris*) 759 *-solaris*)
690 spec=solaris ;; 760 spec=solaris ;;
691 *-linux-*|*-linux) 761 *-linux-*|*-linux)
692 spec=linux ;; 762 spec=linux ;;
693 *) 763 *)
694 die "Unknown CHOST, no platform choosen." 764 die "${FUNCNAME}(): Unknown CHOST '${CHOST}'" ;;
695 esac 765 esac
696 766
697 CXX=$(tc-getCXX) 767 case "$(tc-getCXX)" in
698 if [[ ${CXX} == *g++* ]]; then 768 *g++*)
699 spec+=-g++ 769 spec+=-g++ ;;
700 elif [[ ${CXX} == *icpc* ]]; then 770 *icpc*)
701 spec+=-icc 771 spec+=-icc ;;
702 else 772 *)
703 die "Unknown compiler ${CXX}." 773 die "${FUNCNAME}(): Unknown compiler '$(tc-getCXX)'" ;;
704 fi 774 esac
705 if [[ -n ${LIBDIR/lib} ]]; then
706 spec+=-${LIBDIR/lib}
707 fi
708 775
709 # Add -64 for 64bit profiles 776 # Add -64 for 64bit profiles
710 if use x64-freebsd || 777 if use x64-freebsd ||
711 use amd64-linux || 778 use amd64-linux ||
712 use x64-macos || 779 use x64-macos ||
717 fi 784 fi
718 785
719 echo "${spec}" 786 echo "${spec}"
720} 787}
721 788
789# @FUNCTION: qt_nolibx11
790# @INTERNAL
791# @DESCRIPTION:
792# Skip X11 tests for packages that don't need X libraries installed.
793qt_nolibx11() {
794 sed -i -e '/^if.*PLATFORM_X11.*CFG_GUI/,/^fi$/d' "${S}"/configure || die
795}
796
722EXPORT_FUNCTIONS pkg_setup src_unpack src_prepare src_configure src_compile src_install 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.64  
changed lines
  Added in v.1.159

  ViewVC Help
Powered by ViewVC 1.1.20