/[gentoo-x86]/eclass/x-modular.eclass
Gentoo

Diff of /eclass/x-modular.eclass

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

Revision 1.56 Revision 1.92
1# Copyright 1999-2005 Gentoo Foundation 1# Copyright 1999-2005 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/x-modular.eclass,v 1.56 2006/05/14 19:17:09 spyderous Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/x-modular.eclass,v 1.92 2008/02/22 05:10:03 dberkholz Exp $
4# 4#
5# Author: Donnie Berkholz <spyderous@gentoo.org> 5# @ECLASS: x-modular.eclass
6# @MAINTAINER:
7# Donnie Berkholz <dberkholz@gentoo.org>, x11@gentoo.org
8# @BLURB: Reduces code duplication in the modularized X11 ebuilds.
9# @DESCRIPTION:
10# This eclass makes trivial X ebuilds possible for apps, fonts, drivers,
11# and more. Many things that would normally be done in various functions
12# can be accessed by setting variables instead, such as patching,
13# running eautoreconf, passing options to configure and installing docs.
6# 14#
7# This eclass is designed to reduce code duplication in the modularized X11 15# All you need to do in a basic ebuild is inherit this eclass and set
8# ebuilds. 16# DESCRIPTION, KEYWORDS and RDEPEND/DEPEND. If your package is hosted
9# 17# with the other X packages, you don't need to set SRC_URI. Pretty much
10# Using this eclass:
11#
12# Inherit it. If you need to run autoreconf for any reason (e.g., your patches
13# apply to the autotools files rather than configure), set SNAPSHOT="yes". Set
14# CONFIGURE_OPTIONS to everything you want to pass to the configure script.
15#
16# If you have any patches to apply, set PATCHES to their locations and epatch
17# will apply them. It also handles epatch-style bulk patches, if you know how to
18# use them and set the correct variables. If you don't, read eutils.eclass.
19#
20# If you're creating a font package and the suffix of PN is not equal to the
21# subdirectory of /usr/share/fonts/ it should install into, set FONT_DIR to that
22# directory or directories.
23#
24# IMPORTANT: Both SNAPSHOT and FONT_DIR must be set _before_ the inherit.
25#
26# Pretty much everything else should be automatic. 18# everything else should be automatic.
27 19
28EXPORT_FUNCTIONS src_unpack src_compile src_install pkg_preinst pkg_postinst pkg_postrm 20# @ECLASS-VARIABLE: XDIR
29 21# @DESCRIPTION:
30inherit eutils libtool toolchain-funcs flag-o-matic autotools 22# Directory prefix to use for everything. If you want to install to a
31 23# non-default prefix (e.g., /opt/xorg), change XDIR. This has not been
32# Directory prefix to use for everything 24# recently tested. You may need to uncomment the setting of datadir and
25# mandir in x-modular_src_install() or add it back in if it's no longer
26# there. You may also want to change the SLOT.
33XDIR="/usr" 27XDIR="/usr"
34 28
35# Set up default patchset version(s) if necessary
36# x11-driver-patches
37if [[ -z "${XDPVER}" ]]; then 29if [[ -z "${XDPVER}" ]]; then
30# @ECLASS-VARIABLE: XDPVER
31# @DESCRIPTION:
32# Set up default patchset version(s) if necessary for driver patches. If
33# you want to change the auto-application of the driver patchset or
34# prevent it from applying, edit XDPVER in the ebuild. Set it to -1 to
35# prevent patch application or positive integers for that patch version.
36# Set before inheriting this eclass.
38 XDPVER="1" 37 XDPVER="1"
39fi 38fi
40 39
41IUSE="" 40IUSE=""
42HOMEPAGE="http://xorg.freedesktop.org/" 41HOMEPAGE="http://xorg.freedesktop.org/"
43 42
43# @ECLASS-VARIABLE: SNAPSHOT
44# @DESCRIPTION:
45# If set to 'yes' and configure.ac exists, eautoreconf will run. Set
46# before inheriting this eclass.
47SNAPSHOT="no"
48
49if [[ ${PV} = 9999* ]]; then
50 GIT_ECLASS="git"
51 SNAPSHOT="yes"
52 SRC_URI=""
53fi
54
44# Set up SRC_URI for individual modular releases 55# Set up SRC_URI for individual modular releases
45BASE_INDIVIDUAL_URI="http://xorg.freedesktop.org/releases/individual" 56BASE_INDIVIDUAL_URI="http://xorg.freedesktop.org/releases/individual"
46if [[ ${CATEGORY} = x11-apps ]]; then 57if [[ ${CATEGORY} = x11-apps ]] || [[ ${CATEGORY} = x11-wm ]]; then
47 SRC_URI="${SRC_URI} 58 MODULE="app"
48 ${BASE_INDIVIDUAL_URI}/app/${P}.tar.bz2"
49elif [[ ${CATEGORY} = app-doc ]]; then 59elif [[ ${CATEGORY} = app-doc ]]; then
50 SRC_URI="${SRC_URI} 60 MODULE="doc"
51 ${BASE_INDIVIDUAL_URI}/doc/${P}.tar.bz2"
52# x11-misc contains data and util, x11-themes contains data 61# x11-misc contains data and util, x11-themes contains data
53elif [[ ${CATEGORY} = x11-misc ]] || [[ ${CATEGORY} = x11-themes ]]; then 62elif [[ ${CATEGORY} = x11-misc ]] || [[ ${CATEGORY} = x11-themes ]]; then
54 SRC_URI="${SRC_URI} 63 if [[ ${PN} == xbitmaps || ${PN} == xcursor-themes || ${PN} == xkbdata ]]; then
55 ${BASE_INDIVIDUAL_URI}/data/${P}.tar.bz2 64 MODULE="data"
56 ${BASE_INDIVIDUAL_URI}/util/${P}.tar.bz2" 65 else
66 MODULE="data"
67 fi
57elif [[ ${CATEGORY} = x11-drivers ]]; then 68elif [[ ${CATEGORY} = x11-drivers ]]; then
58 SRC_URI="${SRC_URI} 69 MODULE="driver"
59 ${BASE_INDIVIDUAL_URI}/driver/${P}.tar.bz2"
60elif [[ ${CATEGORY} = media-fonts ]]; then 70elif [[ ${CATEGORY} = media-fonts ]]; then
61 SRC_URI="${SRC_URI} 71 MODULE="font"
62 ${BASE_INDIVIDUAL_URI}/font/${P}.tar.bz2"
63elif [[ ${CATEGORY} = x11-libs ]]; then 72elif [[ ${CATEGORY} = x11-libs ]]; then
64 SRC_URI="${SRC_URI} 73 MODULE="lib"
65 ${BASE_INDIVIDUAL_URI}/lib/${P}.tar.bz2"
66elif [[ ${CATEGORY} = x11-proto ]]; then 74elif [[ ${CATEGORY} = x11-proto ]]; then
67 SRC_URI="${SRC_URI} 75 MODULE="proto"
68 ${BASE_INDIVIDUAL_URI}/proto/${P}.tar.bz2"
69elif [[ ${CATEGORY} = x11-base ]]; then 76elif [[ ${CATEGORY} = x11-base ]]; then
70 SRC_URI="${SRC_URI} 77 MODULE="xserver"
71 ${BASE_INDIVIDUAL_URI}/xserver/${P}.tar.bz2"
72fi 78fi
73 79
74# SRC_URI for full releases 80if [[ -n ${GIT_ECLASS} ]]; then
75SRC_URI="${SRC_URI} 81 EGIT_REPO_URI="git://anongit.freedesktop.org/git/xorg/${MODULE}/${PN}"
76 http://xorg.freedesktop.org/releases/X11R7.0/src/everything/${P}.tar.bz2" 82else
83 SRC_URI="${SRC_URI} ${BASE_INDIVIDUAL_URI}/${MODULE}/${P}.tar.bz2"
84fi
77 85
78SLOT="0" 86SLOT="0"
79 87
80# Set the license for the package. This can be overridden by setting 88# Set the license for the package. This can be overridden by setting
81# LICENSE after the inherit. 89# LICENSE after the inherit.
83 91
84# Set up shared dependencies 92# Set up shared dependencies
85if [[ -n "${SNAPSHOT}" ]]; then 93if [[ -n "${SNAPSHOT}" ]]; then
86# FIXME: What's the minimal libtool version supporting arbitrary versioning? 94# FIXME: What's the minimal libtool version supporting arbitrary versioning?
87 DEPEND="${DEPEND} 95 DEPEND="${DEPEND}
88 >=sys-devel/autoconf-2.57
89 >=sys-devel/automake-1.7
90 >=sys-devel/libtool-1.5 96 >=sys-devel/libtool-1.5
91 >=sys-devel/m4-1.4" 97 >=sys-devel/m4-1.4"
98 WANT_AUTOCONF="latest"
99 WANT_AUTOMAKE="latest"
92fi 100fi
93 101
94# If we're a font package, but not the font.alias one 102# If we're a font package, but not the font.alias one
103FONT_ECLASS=""
95if [[ "${PN/#font-}" != "${PN}" ]] \ 104if [[ "${PN/#font-}" != "${PN}" ]] \
96 && [[ "${CATEGORY}" = "media-fonts" ]] \ 105 && [[ "${CATEGORY}" = "media-fonts" ]] \
97 && [[ "${PN}" != "font-alias" ]] \ 106 && [[ "${PN}" != "font-alias" ]] \
98 && [[ "${PN}" != "font-util" ]]; then 107 && [[ "${PN}" != "font-util" ]]; then
99 # Activate font code in the rest of the eclass 108 # Activate font code in the rest of the eclass
100 FONT="yes" 109 FONT="yes"
101 110
111 # Whether to inherit the font eclass
112 FONT_ECLASS="font"
113
102 RDEPEND="${RDEPEND} 114 RDEPEND="${RDEPEND}
103 media-fonts/encodings 115 media-fonts/encodings
104 x11-apps/mkfontscale 116 x11-apps/mkfontscale
105 x11-apps/mkfontdir" 117 x11-apps/mkfontdir"
106 PDEPEND="${PDEPEND} 118 PDEPEND="${PDEPEND}
109 # Starting with 7.0RC3, we can specify the font directory 121 # Starting with 7.0RC3, we can specify the font directory
110 # But oddly, we can't do the same for encodings or font-alias 122 # But oddly, we can't do the same for encodings or font-alias
111 123
112 # Wrap in `if` so ebuilds can set it too 124 # Wrap in `if` so ebuilds can set it too
113 if [[ -z ${FONT_DIR} ]]; then 125 if [[ -z ${FONT_DIR} ]]; then
126# @ECLASS-VARIABLE: FONT_DIR
127# @DESCRIPTION:
128# If you're creating a font package and the suffix of PN is not equal to
129# the subdirectory of /usr/share/fonts/ it should install into, set
130# FONT_DIR to that directory or directories. Set before inheriting this
131# eclass.
114 FONT_DIR=${PN##*-} 132 FONT_DIR=${PN##*-}
115 133
116 fi 134 fi
117 135
118 # Fix case of font directories 136 # Fix case of font directories
134# If we're a driver package 152# If we're a driver package
135if [[ "${PN/#xf86-video}" != "${PN}" ]] || [[ "${PN/#xf86-input}" != "${PN}" ]]; then 153if [[ "${PN/#xf86-video}" != "${PN}" ]] || [[ "${PN/#xf86-input}" != "${PN}" ]]; then
136 # Enable driver code in the rest of the eclass 154 # Enable driver code in the rest of the eclass
137 DRIVER="yes" 155 DRIVER="yes"
138 156
157 if [[ ${XDPVER} != -1 ]]; then
139 # Add driver patchset to SRC_URI 158 # Add driver patchset to SRC_URI
140 SRC_URI="${SRC_URI} 159 SRC_URI="${SRC_URI}
141 http://dev.gentoo.org/~joshuabaergen/distfiles/x11-driver-patches-${XDPVER}.tar.bz2" 160 mirror://gentoo/x11-driver-patches-${XDPVER}.tar.bz2"
161 fi
142fi 162fi
143 163
144# Debugging -- ignore packages that can't be built with debugging 164# Debugging -- ignore packages that can't be built with debugging
145if [[ -z "${FONT}" ]] \ 165if [[ -z "${FONT}" ]] \
146 || [[ "${PN/app-doc}" != "${PN}" ]] \ 166 && [[ "${CATEGORY/app-doc}" = "${CATEGORY}" ]] \
147 || [[ "${PN/x11-proto}" != "${PN}" ]] \ 167 && [[ "${CATEGORY/x11-proto}" = "${CATEGORY}" ]] \
148 || [[ "${PN/util-macros}" != "${PN}" ]] \ 168 && [[ "${PN/util-macros}" = "${PN}" ]] \
149 || [[ "${PN/xbitmaps}" != "${PN}" ]] \ 169 && [[ "${PN/xbitmaps}" = "${PN}" ]] \
150 || [[ "${PN/xkbdata}" != "${PN}" ]] \ 170 && [[ "${PN/xkbdata}" = "${PN}" ]] \
151 || [[ "${PN/xorg-cf-files}" != "${PN}" ]] \ 171 && [[ "${PN/xorg-cf-files}" = "${PN}" ]] \
152 || [[ "${PN/xcursor}" != "${PN}" ]] \ 172 && [[ "${PN/xcursor}" = "${PN}" ]] \
153 ; then 173 ; then
154 DEBUGGABLE="yes" 174 DEBUGGABLE="yes"
155 IUSE="${IUSE} debug" 175 IUSE="${IUSE} debug"
156 if use debug; then
157 if ! has splitdebug ${FEATURES}; then
158 RESTRICT="${RESTRICT} nostrip"
159 fi
160 fi
161fi 176fi
162 177
163DEPEND="${DEPEND} 178DEPEND="${DEPEND}
164 >=dev-util/pkgconfig-0.18" 179 >=dev-util/pkgconfig-0.18"
165 180
166if [[ "${PN/util-macros}" = "${PN}" ]]; then 181if [[ "${PN/util-macros}" = "${PN}" ]]; then
167 DEPEND="${DEPEND} 182 DEPEND="${DEPEND}
168 >=x11-misc/util-macros-0.99.2" 183 >=x11-misc/util-macros-0.99.2
184 >=sys-devel/binutils-2.16.1-r3"
169fi 185fi
170 186
171# >=sys-apps/man-1.6b-r2 required to look in [0-8]x/ directories
172RDEPEND="${RDEPEND} 187RDEPEND="${RDEPEND}
173 !<=x11-base/xorg-x11-6.9 188 !<=x11-base/xorg-x11-6.9"
174 >=sys-apps/man-1.6b-r2"
175# Provides virtual/x11 for temporary use until packages are ported 189# Provides virtual/x11 for temporary use until packages are ported
176# x11-base/x11-env" 190# x11-base/x11-env"
177 191
192inherit eutils libtool multilib toolchain-funcs flag-o-matic autotools \
193 ${FONT_ECLASS} ${GIT_ECLASS}
194
195# @FUNCTION: x-modular_specs_check
196# @USAGE:
197# @DESCRIPTION:
198# Make any necessary changes related to gcc specs (generally hardened)
178x-modular_specs_check() { 199x-modular_specs_check() {
179 if [[ ${PN:0:11} = "xorg-server" ]] || [[ -n "${DRIVER}" ]]; then 200 if [[ ${PN:0:11} = "xorg-server" ]] || [[ -n "${DRIVER}" ]]; then
180 if gcc-specs-now; then 201 append-ldflags -Wl,-z,lazy
181 msg="${PN} does not work with hardened gcc specs. Switch to vanilla gcc specs to emerge ${PN}."
182 eerror "$msg"
183 die "$msg"
184 fi
185
186 # (#116698) breaks loading 202 # (#116698) breaks loading
187 filter-ldflags -Wl,-z,now 203 filter-ldflags -Wl,-z,now
188 fi 204 fi
189} 205}
190 206
207# @FUNCTION: x-modular_dri_check
208# @USAGE:
209# @DESCRIPTION:
210# Ensures the server supports DRI if building a driver with DRI support
191x-modular_dri_check() { 211x-modular_dri_check() {
192 # (#120057) Enabling DRI in drivers requires that the server was built with 212 # (#120057) Enabling DRI in drivers requires that the server was built with
193 # support for it 213 # support for it
194 if [[ -n "${DRIVER}" ]]; then 214 if [[ -n "${DRIVER}" ]]; then
195 if has dri ${IUSE} && use dri; then 215 if has dri ${IUSE} && use dri; then
199 fi 219 fi
200 fi 220 fi
201 fi 221 fi
202} 222}
203 223
224# @FUNCTION: x-modular_server_supports_drivers_check
225# @USAGE:
226# @DESCRIPTION:
227# Ensures the server SDK is installed if a driver is being built
228x-modular_server_supports_drivers_check() {
229 # (#135873) Only certain servers will actually use or be capable of
230 # building external drivers, including binary drivers.
231 if [[ -n "${DRIVER}" ]]; then
232 if has_version '>=x11-base/xorg-server-1.1'; then
233 if ! built_with_use x11-base/xorg-server xorg; then
234 eerror "x11-base/xorg-server is not built with support for external drivers."
235 die "You must build x11-base/xorg-server with USE=xorg."
236 fi
237 fi
238 fi
239}
240
241# @FUNCTION: x-modular_unpack_source
242# @USAGE:
243# @DESCRIPTION:
244# Simply unpack source code. Nothing else.
204x-modular_unpack_source() { 245x-modular_unpack_source() {
246 if [[ -n ${GIT_ECLASS} ]]; then
247 git_src_unpack
248 else
205 unpack ${A} 249 unpack ${A}
250 fi
206 cd ${S} 251 cd ${S}
207 252
208 if [[ -n ${FONT_OPTIONS} ]]; then 253 if [[ -n ${FONT_OPTIONS} ]]; then
209 einfo "Detected font directory: ${FONT_DIR}" 254 einfo "Detected font directory: ${FONT_DIR}"
210 fi 255 fi
211} 256}
212 257
258# @FUNCTION: x-modular_patch_source
259# @USAGE:
260# @DESCRIPTION:
261# Apply all patches
213x-modular_patch_source() { 262x-modular_patch_source() {
214 # Use standardized names and locations with bulk patching 263 # Use standardized names and locations with bulk patching
215 # Patch directory is ${WORKDIR}/patch 264 # Patch directory is ${WORKDIR}/patch
216 # See epatch() in eutils.eclass for more documentation 265 # See epatch() in eutils.eclass for more documentation
217 if [[ -z "${EPATCH_SUFFIX}" ]] ; then 266 if [[ -z "${EPATCH_SUFFIX}" ]] ; then
219 fi 268 fi
220 269
221 # If this is a driver package we need to fix man page install location. 270 # If this is a driver package we need to fix man page install location.
222 # Running autoreconf will use the patched util-macros to make the 271 # Running autoreconf will use the patched util-macros to make the
223 # change for us, so we only need to patch if it is not going to run. 272 # change for us, so we only need to patch if it is not going to run.
224 if [[ -n "${DRIVER}" ]] && [[ "${SNAPSHOT}" != "yes" ]]; then 273 if [[ -n "${DRIVER}" ]] && [[ "${SNAPSHOT}" != "yes" ]]\
274 && [[ ${XDPVER} != -1 ]]; then
225 PATCHES="${PATCHES} ${DISTDIR}/x11-driver-patches-${XDPVER}.tar.bz2" 275 PATCHES="${PATCHES} ${DISTDIR}/x11-driver-patches-${XDPVER}.tar.bz2"
226 fi 276 fi
227 277
228 # For specific list of patches 278# @VARIABLE: PATCHES
279# @DESCRIPTION:
280# If you have any patches to apply, set PATCHES to their locations and epatch
281# will apply them. It also handles epatch-style bulk patches, if you know how to
282# use them and set the correct variables. If you don't, read eutils.eclass.
229 if [[ -n "${PATCHES}" ]] ; then 283 if [[ -n "${PATCHES}" ]] ; then
230 for PATCH in ${PATCHES} 284 for PATCH in ${PATCHES}
231 do 285 do
232 epatch ${PATCH} 286 epatch ${PATCH}
233 done 287 done
238 elif [[ -d "${EPATCH_SOURCE}" ]] ; then 292 elif [[ -d "${EPATCH_SOURCE}" ]] ; then
239 epatch 293 epatch
240 fi 294 fi
241} 295}
242 296
297# @FUNCTION: x-modular_reconf_source
298# @USAGE:
299# @DESCRIPTION:
300# Run eautoreconf if necessary, and run elibtoolize.
243x-modular_reconf_source() { 301x-modular_reconf_source() {
244 # Run autoreconf for CVS snapshots only
245 if [[ "${SNAPSHOT}" = "yes" ]] 302 if [[ "${SNAPSHOT}" = "yes" ]]
246 then 303 then
247 # If possible, generate configure if it doesn't exist 304 # If possible, generate configure if it doesn't exist
248 if [ -f "${S}/configure.ac" ] 305 if [ -f "./configure.ac" ]
249 then 306 then
250 eautoreconf 307 eautoreconf
251 fi 308 fi
252 fi 309 fi
253 310
254 # Joshua Baergen - October 23, 2005 311 # Joshua Baergen - October 23, 2005
255 # Fix shared lib issues on MIPS, FBSD, etc etc 312 # Fix shared lib issues on MIPS, FBSD, etc etc
256 elibtoolize 313 elibtoolize
257} 314}
258 315
316# @FUNCTION: x-modular_src_unpack
317# @USAGE:
318# @DESCRIPTION:
319# Unpack a package, performing all X-related tasks.
259x-modular_src_unpack() { 320x-modular_src_unpack() {
260 x-modular_specs_check 321 x-modular_specs_check
322 x-modular_server_supports_drivers_check
261 x-modular_dri_check 323 x-modular_dri_check
262 x-modular_unpack_source 324 x-modular_unpack_source
263 x-modular_patch_source 325 x-modular_patch_source
264 x-modular_reconf_source 326 x-modular_reconf_source
265} 327}
266 328
329# @FUNCTION: x-modular_font_configure
330# @USAGE:
331# @DESCRIPTION:
332# If a font package, perform any necessary configuration steps
267x-modular_font_configure() { 333x-modular_font_configure() {
268 if [[ -n "${FONT}" ]]; then 334 if [[ -n "${FONT}" ]]; then
269 # Might be worth adding an option to configure your desired font 335 # Might be worth adding an option to configure your desired font
270 # and exclude all others. Also, should this USE be nls or minimal? 336 # and exclude all others. Also, should this USE be nls or minimal?
271 if ! use nls; then 337 if ! use nls; then
289 --disable-koi8-r" 355 --disable-koi8-r"
290 fi 356 fi
291 fi 357 fi
292} 358}
293 359
360# @FUNCTION: x-modular_debug_setup
361# @USAGE:
362# @DESCRIPTION:
363# Set up CFLAGS for a debug build
294x-modular_debug_setup() { 364x-modular_debug_setup() {
295 if [[ -n "${DEBUGGABLE}" ]]; then 365 if [[ -n "${DEBUGGABLE}" ]]; then
296 if use debug; then 366 if use debug; then
297 strip-flags 367 strip-flags
298 append-flags -g 368 append-flags -g
299 fi 369 fi
300 fi 370 fi
301} 371}
302 372
373# @FUNCTION: x-modular_src_configure
374# @USAGE:
375# @DESCRIPTION:
376# Perform any necessary pre-configuration steps, then run configure
303x-modular_src_configure() { 377x-modular_src_configure() {
304 x-modular_font_configure 378 x-modular_font_configure
305 x-modular_debug_setup 379 x-modular_debug_setup
306 380
381# @VARIABLE: CONFIGURE_OPTIONS
382# @DESCRIPTION:
383# Any options to pass to configure
384[[ -n ${CONFIGURE_OPTIONTS} ]]
385
307 # If prefix isn't set here, .pc files cause problems 386 # If prefix isn't set here, .pc files cause problems
308 if [[ -x ./configure ]]; then 387 if [[ -x ${ECONF_SOURCE:-.}/configure ]]; then
309 econf --prefix=${XDIR} \ 388 econf --prefix=${XDIR} \
310 --datadir=${XDIR}/share \ 389 --datadir=${XDIR}/share \
311 ${FONT_OPTIONS} \ 390 ${FONT_OPTIONS} \
312 ${DRIVER_OPTIONS} \ 391 ${DRIVER_OPTIONS} \
313 ${CONFIGURE_OPTIONS} 392 ${CONFIGURE_OPTIONS}
314 fi 393 fi
315} 394}
316 395
396# @FUNCTION: x-modular_src_make
397# @USAGE:
398# @DESCRIPTION:
399# Run make.
317x-modular_src_make() { 400x-modular_src_make() {
318 emake || die "emake failed" 401 emake || die "emake failed"
319} 402}
320 403
404# @FUNCTION: x-modular_src_configure
405# @USAGE:
406# @DESCRIPTION:
407# Compile a package, performing all X-related tasks.
321x-modular_src_compile() { 408x-modular_src_compile() {
322 x-modular_src_configure 409 x-modular_src_configure
323 x-modular_src_make 410 x-modular_src_make
324} 411}
325 412
413# @FUNCTION: x-modular_src_install
414# @USAGE:
415# @DESCRIPTION:
416# Install a built package to ${D}, performing any necessary steps.
417# Creates a ChangeLog from git if using live ebuilds.
326x-modular_src_install() { 418x-modular_src_install() {
327 # Install everything to ${XDIR} 419 # Install everything to ${XDIR}
328 make \ 420 make \
329 DESTDIR="${D}" \ 421 DESTDIR="${D}" \
330 install 422 install
331# Shouldn't be necessary in XDIR=/usr 423# Shouldn't be necessary in XDIR=/usr
332# einstall forces datadir, so we need to re-force it 424# einstall forces datadir, so we need to re-force it
333# datadir=${XDIR}/share \ 425# datadir=${XDIR}/share \
334# mandir=${XDIR}/share/man \ 426# mandir=${XDIR}/share/man \
335 427
428 if [[ -n ${GIT_ECLASS} ]]; then
429 pushd "${EGIT_STORE_DIR}/${EGIT_CLONE_DIR}"
430 git log ${GIT_TREE} > "${S}"/ChangeLog
431 popd
432 fi
433
434 if [[ -e ${S}/ChangeLog ]]; then
435 dodoc ${S}/ChangeLog
436 fi
437# @VARIABLE: DOCS
438# @DESCRIPTION:
439# Any documentation to install
440 [[ -n ${DOCS} ]] && dodoc ${DOCS}
441
336 # Make sure docs get compressed 442 # Make sure docs get compressed
337 prepalldocs 443 prepalldocs
338 444
339 # Don't install libtool archives for server modules 445 # Don't install libtool archives for server modules
340 if [[ -e ${D}/usr/lib/xorg/modules ]]; then 446 if [[ -e ${D}/usr/$(get_libdir)/xorg/modules ]]; then
341 find ${D}/usr/lib/xorg/modules -name '*.la' \ 447 find ${D}/usr/$(get_libdir)/xorg/modules -name '*.la' \
342 | xargs rm -f 448 | xargs rm -f
343 fi 449 fi
344 450
345 # Don't install overlapping fonts.* files
346 # Generate them instead when possible
347 if [[ -n "${FONT}" ]]; then 451 if [[ -n "${FONT}" ]]; then
348 remove_font_metadata 452 remove_font_metadata
349 fi 453 fi
350}
351 454
455 if [[ -n "${DRIVER}" ]]; then
456 install_driver_hwdata
457 fi
458}
459
460# @FUNCTION: x-modular_pkg_preinst
461# @USAGE:
462# @DESCRIPTION:
463# This function doesn't do anything right now, but it may in the future.
352x-modular_pkg_preinst() { 464x-modular_pkg_preinst() {
353 if [[ -n "${FONT}" ]]; then 465 # We no longer do anything here, but we can't remove it from the API
354 discover_font_dirs 466 :
355 fi
356} 467}
357 468
469# @FUNCTION: x-modular_pkg_postinst
470# @USAGE:
471# @DESCRIPTION:
472# Run X-specific post-installation tasks on the live filesystem. The
473# only task right now is some setup for font packages.
358x-modular_pkg_postinst() { 474x-modular_pkg_postinst() {
359 if [[ -n "${FONT}" ]]; then 475 if [[ -n "${FONT}" ]]; then
360 setup_fonts 476 setup_fonts
361 fi 477 fi
362} 478}
363 479
480# @FUNCTION: x-modular_pkg_postrm
481# @USAGE:
482# @DESCRIPTION:
483# Run X-specific post-removal tasks on the live filesystem. The only
484# task right now is some cleanup for font packages.
364x-modular_pkg_postrm() { 485x-modular_pkg_postrm() {
365 if [[ -n "${FONT}" ]]; then 486 if [[ -n "${FONT}" ]]; then
366 cleanup_fonts 487 cleanup_fonts
488 font_pkg_postrm
367 fi 489 fi
368} 490}
369 491
492# @FUNCTION: cleanup_fonts
493# @USAGE:
494# @DESCRIPTION:
495# Get rid of font directories that only contain generated files
370cleanup_fonts() { 496cleanup_fonts() {
371 local ALLOWED_FILES="encodings.dir fonts.cache-1 fonts.dir fonts.scale" 497 local ALLOWED_FILES="encodings.dir fonts.cache-1 fonts.dir fonts.scale"
372 for DIR in ${FONT_DIR}; do 498 for DIR in ${FONT_DIR}; do
373 unset KEEP_FONTDIR 499 unset KEEP_FONTDIR
374 REAL_DIR=${ROOT}usr/share/fonts/${DIR} 500 REAL_DIR=${ROOT}usr/share/fonts/${DIR}
400 fi 526 fi
401 eend 0 527 eend 0
402 done 528 done
403} 529}
404 530
531# @FUNCTION: setup_fonts
532# @USAGE:
533# @DESCRIPTION:
534# Generates needed files for fonts and fixes font permissions
405setup_fonts() { 535setup_fonts() {
406 if [[ ! -n "${FONT_DIRS}" ]]; then 536 if [[ ! -n "${FONT_DIR}" ]]; then
407 msg="FONT_DIRS is empty. The ebuild should set it to at least one subdir of /usr/share/fonts." 537 msg="FONT_DIR is empty. The ebuild should set it to at least one subdir of /usr/share/fonts."
408 eerror "${msg}" 538 eerror "${msg}"
409 die "${msg}" 539 die "${msg}"
410 fi 540 fi
411 541
412 create_fonts_scale 542 create_fonts_scale
413 create_fonts_dir 543 create_fonts_dir
414 fix_font_permissions 544 fix_font_permissions
415 create_font_cache 545 create_font_cache
416} 546}
417 547
548# @FUNCTION: remove_font_metadata
549# @USAGE:
550# @DESCRIPTION:
551# Don't let the package install generated font files that may overlap
552# with other packages. Instead, they're generated in pkg_postinst().
418remove_font_metadata() { 553remove_font_metadata() {
419 local DIR 554 local DIR
420 for DIR in ${FONT_DIR}; do 555 for DIR in ${FONT_DIR}; do
421 if [[ "${DIR}" != "Speedo" ]] && \ 556 if [[ "${DIR}" != "Speedo" ]] && \
422 [[ "${DIR}" != "CID" ]] ; then 557 [[ "${DIR}" != "CID" ]] ; then
425 rm -f ${D}/usr/share/fonts/${DIR}/fonts.{scale,dir,cache-1} 560 rm -f ${D}/usr/share/fonts/${DIR}/fonts.{scale,dir,cache-1}
426 fi 561 fi
427 done 562 done
428} 563}
429 564
565# @FUNCTION: install_driver_hwdata
566# @USAGE:
567# @DESCRIPTION:
568# Installs device-to-driver mappings for system-config-display and
569# anything else that uses hwdata.
570install_driver_hwdata() {
571 insinto /usr/share/hwdata/videoaliases
572 for i in "${FILESDIR}"/*.xinf; do
573 # We need this for the case when none exist,
574 # so *.xinf doesn't expand
575 if [[ -e $i ]]; then
576 doins $i
577 fi
578 done
579}
580
581# @FUNCTION: discover_font_dirs
582# @USAGE:
583# @DESCRIPTION:
584# Deprecated. Sets up the now-unused FONT_DIRS variable.
430discover_font_dirs() { 585discover_font_dirs() {
431 pushd ${IMAGE}/usr/share/fonts 586 FONT_DIRS="${FONT_DIR}"
432 FONT_DIRS="$(find . -maxdepth 1 -mindepth 1 -type d)"
433 FONT_DIRS="$(echo ${FONT_DIRS} | sed -e 's:./::g')"
434 popd
435} 587}
436 588
589# @FUNCTION: create_fonts_scale
590# @USAGE:
591# @DESCRIPTION:
592# Create fonts.scale file, used by the old server-side fonts subsystem.
437create_fonts_scale() { 593create_fonts_scale() {
438 ebegin "Creating fonts.scale files" 594 ebegin "Creating fonts.scale files"
439 local x 595 local x
440 for FONT_DIR in ${FONT_DIRS}; do 596 for DIR in ${FONT_DIR}; do
441 x=${ROOT}/usr/share/fonts/${FONT_DIR} 597 x=${ROOT}/usr/share/fonts/${DIR}
442 [[ -z "$(ls ${x}/)" ]] && continue 598 [[ -z "$(ls ${x}/)" ]] && continue
443 [[ "$(ls ${x}/)" = "fonts.cache-1" ]] && continue 599 [[ "$(ls ${x}/)" = "fonts.cache-1" ]] && continue
444 600
445 # Only generate .scale files if truetype, opentype or type1 601 # Only generate .scale files if truetype, opentype or type1
446 # fonts are present ... 602 # fonts are present ...
447 603
448 # First truetype (ttf,ttc)
449 # NOTE: ttmkfdir does NOT work on type1 fonts (#53753)
450 # Also, there is no way to regenerate Speedo/CID fonts.scale 604 # NOTE: There is no way to regenerate Speedo/CID fonts.scale
451 # <spyderous@gentoo.org> 2 August 2004 605 # <dberkholz@gentoo.org> 2 August 2004
452 if [[ "${x/encodings}" = "${x}" ]] \ 606 if [[ "${x/encodings}" = "${x}" ]] \
453 && [[ -n "$(find ${x} -iname '*.tt[cf]' -print)" ]]; then
454 if [[ -x ${ROOT}/usr/bin/ttmkfdir ]]; then
455 LD_LIBRARY_PATH="${LD_LIBRARY_PATH}:${ROOT}/usr/$(get_libdir)" \
456 ${ROOT}/usr/bin/ttmkfdir -x 2 \
457 -e ${ROOT}/usr/share/fonts/encodings/encodings.dir \
458 -o ${x}/fonts.scale -d ${x}
459 # ttmkfdir fails on some stuff, so try mkfontscale if it does
460 local ttmkfdir_return=$?
461 else
462 # We didn't use ttmkfdir at all
463 local ttmkfdir_return=2
464 fi
465 if [[ ${ttmkfdir_return} -ne 0 ]]; then
466 LD_LIBRARY_PATH="${LD_LIBRARY_PATH}:${ROOT}/usr/$(get_libdir)" \
467 ${ROOT}/usr/bin/mkfontscale \
468 -a /usr/share/fonts/encodings/encodings.dir \
469 -- ${x}
470 fi
471 # Next type1 and opentype (pfa,pfb,otf,otc)
472 elif [[ "${x/encodings}" = "${x}" ]] \
473 && [[ -n "$(find ${x} -iname '*.[po][ft][abcf]' -print)" ]]; then 607 && [[ -n "$(find ${x} -iname '*.[pot][ft][abcf]' -print)" ]]; then
474 LD_LIBRARY_PATH="${LD_LIBRARY_PATH}:${ROOT}/usr/$(get_libdir)" \ 608 mkfontscale \
475 ${ROOT}/usr/bin/mkfontscale \
476 -a ${ROOT}/usr/share/fonts/encodings/encodings.dir \ 609 -a ${ROOT}/usr/share/fonts/encodings/encodings.dir \
477 -- ${x} 610 -- ${x}
478 fi 611 fi
479 done 612 done
480 eend 0 613 eend 0
481} 614}
482 615
616# @FUNCTION: create_fonts_dir
617# @USAGE:
618# @DESCRIPTION:
619# Create fonts.dir file, used by the old server-side fonts subsystem.
483create_fonts_dir() { 620create_fonts_dir() {
484 ebegin "Generating fonts.dir files" 621 ebegin "Generating fonts.dir files"
485 for FONT_DIR in ${FONT_DIRS}; do 622 for DIR in ${FONT_DIR}; do
486 x=${ROOT}/usr/share/fonts/${FONT_DIR} 623 x=${ROOT}/usr/share/fonts/${DIR}
487 [[ -z "$(ls ${x}/)" ]] && continue 624 [[ -z "$(ls ${x}/)" ]] && continue
488 [[ "$(ls ${x}/)" = "fonts.cache-1" ]] && continue 625 [[ "$(ls ${x}/)" = "fonts.cache-1" ]] && continue
489 626
490 if [[ "${x/encodings}" = "${x}" ]]; then 627 if [[ "${x/encodings}" = "${x}" ]]; then
491 LD_LIBRARY_PATH="${LD_LIBRARY_PATH}:${ROOT}/usr/$(get_libdir)" \ 628 mkfontdir \
492 ${ROOT}/usr/bin/mkfontdir \
493 -e ${ROOT}/usr/share/fonts/encodings \ 629 -e ${ROOT}/usr/share/fonts/encodings \
494 -e ${ROOT}/usr/share/fonts/encodings/large \ 630 -e ${ROOT}/usr/share/fonts/encodings/large \
495 -- ${x} 631 -- ${x}
496 fi 632 fi
497 done 633 done
498 eend 0 634 eend 0
499} 635}
500 636
637# @FUNCTION: fix_font_permissions
638# @USAGE:
639# @DESCRIPTION:
640# Font files should have 644 permissions. Ensure this is the case.
501fix_font_permissions() { 641fix_font_permissions() {
502 ebegin "Fixing permissions" 642 ebegin "Fixing permissions"
503 for FONT_DIR in ${FONT_DIRS}; do 643 for DIR in ${FONT_DIR}; do
504 find ${ROOT}/usr/share/fonts/${FONT_DIR} -type f -name 'font.*' \ 644 find ${ROOT}/usr/share/fonts/${DIR} -type f -name 'font.*' \
505 -exec chmod 0644 {} \; 645 -exec chmod 0644 {} \;
506 done 646 done
507 eend 0 647 eend 0
508} 648}
509 649
650# @FUNCTION: create_font_cache
651# @USAGE:
652# @DESCRIPTION:
653# Create fonts.cache-1 files, used by the new client-side fonts
654# subsystem.
510create_font_cache() { 655create_font_cache() {
511 # danarmak found out that fc-cache should be run AFTER all the above 656 font_pkg_postinst
512 # stuff, as otherwise the cache is invalid, and has to be run again
513 # as root anyway
514 if [[ -x ${ROOT}/usr/bin/fc-cache ]]; then
515 ebegin "Creating FC font cache"
516 HOME="/root" ${ROOT}/usr/bin/fc-cache
517 eend 0
518 fi
519} 657}
658
659EXPORT_FUNCTIONS src_unpack src_compile src_install pkg_preinst pkg_postinst pkg_postrm

Legend:
Removed from v.1.56  
changed lines
  Added in v.1.92

  ViewVC Help
Powered by ViewVC 1.1.20