/[gentoo-x86]/eclass/kde4-functions.eclass
Gentoo

Diff of /eclass/kde4-functions.eclass

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

Revision 1.6 Revision 1.25
1# Copyright 1999-2008 Gentoo Foundation 1# Copyright 1999-2008 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/kde4-functions.eclass,v 1.6 2008/05/15 19:49:32 ingmar Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/kde4-functions.eclass,v 1.25 2009/10/06 18:02:12 alexxy Exp $
4
5inherit versionator
6
7# Prefix compat:
8: ${EROOT:=${ROOT}}
9# Append missing trailing slash character
10[[ ${EROOT} = */ ]] || EROOT+="/"
4 11
5# @ECLASS: kde4-functions.eclass 12# @ECLASS: kde4-functions.eclass
6# @MAINTAINER: 13# @MAINTAINER:
7# kde@gentoo.org 14# kde@gentoo.org
8# @BLURB: Common ebuild functions for monolithic and split KDE 4 packages 15# @BLURB: Common ebuild functions for KDE 4 packages
9# @DESCRIPTION: 16# @DESCRIPTION:
10# This eclass contains all functions shared by the different eclasses, 17# This eclass contains all functions shared by the different eclasses,
11# for KDE 4 monolithic and split ebuilds. 18# for KDE 4 ebuilds.
12# 19
13# NOTE: This eclass uses the SLOT dependencies from EAPI="1" or compatible, 20# @ECLASS-VARIABLE: EAPI
14# hence you must define EAPI="1" in the ebuild, before inheriting any eclasses. 21# @DESCRIPTION:
22# By default kde4 eclasses want EAPI 2 which might be redefinable to newer
23# versions.
24case ${EAPI:-0} in
25 2) : ;;
26 *) DEPEND="EAPI-TOO-OLD" ;;
27esac
15 28
16# @ECLASS-VARIABLE: KDEBASE 29# @ECLASS-VARIABLE: KDEBASE
17# @DESCRIPTION: 30# @DESCRIPTION:
18# This gets set to a non-zero value when a package is considered a kde or 31# This gets set to a non-zero value when a package is considered a kde or
19# koffice ebuild. 32# koffice ebuild.
20 33
21if [[ "${CATEGORY}" == "kde-base" ]]; then 34if [[ ${CATEGORY} = kde-base ]]; then
22 debug-print "${ECLASS}: KDEBASE ebuild recognized" 35 debug-print "${ECLASS}: KDEBASE ebuild recognized"
23 KDEBASE="kde-base" 36 KDEBASE=kde-base
24fi 37fi
25 38
26# is this a koffice ebuild? 39# is this a koffice ebuild?
27if [[ "${KMNAME}" == "koffice" || "${PN}" == "koffice" ]]; then 40if [[ ${KMNAME} = koffice || ${PN} = koffice ]]; then
28 debug-print "${ECLASS}: KOFFICE ebuild recognized" 41 debug-print "${ECLASS}: KOFFICE ebuild recognized"
29 KDEBASE="koffice" 42 KDEBASE=koffice
30fi 43fi
31 44
45# @ECLASS-VARIABLE: KDE_SLOTS
46# @DESCRIPTION:
47# The slots used by all KDE versions later than 4.0. The live KDE releases use
48# KDE_LIVE_SLOTS instead. Values should be ordered.
49KDE_SLOTS=( "4.1" "4.2" "4.3" "4.4" )
50
32# @ECLASS-VARIABLE: KDE_DERIVATION_MAP 51# @ECLASS-VARIABLE: KDE_LIVE_SLOTS
33# @DESCRIPTION: 52# @DESCRIPTION:
34# Map of the monolithic->split ebuild derivation. 53# The slots used by KDE live versions. Values should be ordered.
35# Used to build dependencies describing the relationships between them: 54KDE_LIVE_SLOTS=( "live" )
36# Monolithic ebuilds block their split counterparts in the same slot, and vice versa.
37#
38# Also see get-parent-package(), get-child-packages(), is-parent-package()
39KDE_DERIVATION_MAP='
40kde-base/kdeaccessibility kde-base/kdeaccessibility-colorschemes
41kde-base/kdeaccessibility kde-base/kdeaccessibility-iconthemes
42kde-base/kdeaccessibility kde-base/kmag
43kde-base/kdeaccessibility kde-base/kmousetool
44kde-base/kdeaccessibility kde-base/kmouth
45kde-base/kdeaccessibility kde-base/kttsd
46kde-base/kdeadmin kde-base/kcron
47kde-base/kdeadmin kde-base/kdat
48kde-base/kdeadmin kde-base/knetworkconf
49kde-base/kdeadmin kde-base/ksysv
50kde-base/kdeadmin kde-base/kuser
51kde-base/kdeadmin kde-base/lilo-config
52kde-base/kdeadmin kde-base/secpolicy
53kde-base/kdeartwork kde-base/kdeartwork-colorschemes
54kde-base/kdeartwork kde-base/kdeartwork-emoticons
55kde-base/kdeartwork kde-base/kdeartwork-icewm-themes
56kde-base/kdeartwork kde-base/kdeartwork-iconthemes
57kde-base/kdeartwork kde-base/kdeartwork-kscreensaver
58kde-base/kdeartwork kde-base/kdeartwork-kworldclock
59kde-base/kdeartwork kde-base/kdeartwork-sounds
60kde-base/kdeartwork kde-base/kdeartwork-styles
61kde-base/kdeartwork kde-base/kdeartwork-wallpapers
62kde-base/kdebase kde-base/dolphin
63kde-base/kdebase kde-base/kappfinder
64kde-base/kdebase kde-base/kdepasswd
65kde-base/kdebase kde-base/kdialog
66kde-base/kdebase kde-base/keditbookmarks
67kde-base/kdebase kde-base/kfind
68kde-base/kdebase kde-base/kinfocenter
69kde-base/kdebase kde-base/konqueror
70kde-base/kdebase kde-base/konsole
71kde-base/kdebase kde-base/kwrite
72kde-base/kdebase kde-base/libkonq
73kde-base/kdebase kde-base/nsplugins
74kde-base/kdebase kde-base/drkonqi
75kde-base/kdebase kde-base/kcmshell
76kde-base/kdebase kde-base/kcontrol
77kde-base/kdebase kde-base/kdebase-data
78kde-base/kdebase kde-base/kdebase-kioslaves
79kde-base/kdebase kde-base/kdebugdialog
80kde-base/kdebase kde-base/kde-menu
81kde-base/kdebase kde-base/kdesu
82kde-base/kdebase kde-base/kfile
83kde-base/kdebase kde-base/khelpcenter
84kde-base/kdebase kde-base/kiconfinder
85kde-base/kdebase kde-base/kioclient
86kde-base/kdebase kde-base/kmimetypefinder
87kde-base/kdebase kde-base/knetattach
88kde-base/kdebase kde-base/knewstuff
89kde-base/kdebase kde-base/knotify
90kde-base/kdebase kde-base/kpasswdserver
91kde-base/kdebase kde-base/kquitapp
92kde-base/kdebase kde-base/kreadconfig
93kde-base/kdebase kde-base/kstart
94kde-base/kdebase kde-base/kstyles
95kde-base/kdebase kde-base/ktimezoned
96kde-base/kdebase kde-base/ktraderclient
97kde-base/kdebase kde-base/kuiserver
98kde-base/kdebase kde-base/kurifilter-plugins
99kde-base/kdebase kde-base/nepomuk
100kde-base/kdebase kde-base/phonon
101kde-base/kdebase kde-base/solid-hardware
102kde-base/kdebase kde-base/soliduiserver
103kde-base/kdebase kde-base/kcheckpass
104kde-base/kdebase kde-base/kcminit
105kde-base/kdebase kde-base/kdebase-startkde
106kde-base/kdebase kde-base/kstartupconfig
107kde-base/kdebase kde-base/kde-menu-icons
108kde-base/kdebase kde-base/kde-wallpapers
109kde-base/kdebase kde-base/kdm
110kde-base/kdebase kde-base/khotkeys
111kde-base/kdebase kde-base/klipper
112kde-base/kdebase kde-base/kmenuedit
113kde-base/kdebase kde-base/krunner
114kde-base/kdebase kde-base/kscreensaver
115kde-base/kdebase kde-base/ksmserver
116kde-base/kdebase kde-base/ksplash
117kde-base/kdebase kde-base/ksysguard
118kde-base/kdebase kde-base/ksystraycmd
119kde-base/kdebase kde-base/ktip
120kde-base/kdebase kde-base/kwin
121kde-base/kdebase kde-base/libkworkspace
122kde-base/kdebase kde-base/libplasma
123kde-base/kdebase kde-base/libtaskmanager
124kde-base/kdebase kde-base/plasma
125kde-base/kdebase kde-base/solid
126kde-base/kdebase kde-base/systemsettings
127kde-base/kdebindings kde-base/kalyptus
128kde-base/kdebindings kde-base/kdejava
129kde-base/kdebindings kde-base/kimono
130kde-base/kdebindings kde-base/kjsembed
131kde-base/kdebindings kde-base/korundum
132kde-base/kdebindings kde-base/krosspython
133kde-base/kdebindings kde-base/krossruby
134kde-base/kdebindings kde-base/pykde4
135kde-base/kdebindings kde-base/qyoto
136kde-base/kdebindings kde-base/qtjava
137kde-base/kdebindings kde-base/qtruby
138kde-base/kdebindings kde-base/qtsharp
139kde-base/kdebindings kde-base/smoke
140kde-base/kdebindings kde-base/xparts
141kde-base/kdeedu kde-base/blinken
142kde-base/kdeedu kde-base/kalgebra
143kde-base/kdeedu kde-base/kalzium
144kde-base/kdeedu kde-base/kanagram
145kde-base/kdeedu kde-base/kbruch
146kde-base/kdeedu kde-base/kgeography
147kde-base/kdeedu kde-base/khangman
148kde-base/kdeedu kde-base/kig
149kde-base/kdeedu kde-base/kiten
150kde-base/kdeedu kde-base/klettres
151kde-base/kdeedu kde-base/kmplot
152kde-base/kdeedu kde-base/kpercentage
153kde-base/kdeedu kde-base/kstars
154kde-base/kdeedu kde-base/ktouch
155kde-base/kdeedu kde-base/kturtle
156kde-base/kdeedu kde-base/kwordquiz
157kde-base/kdeedu kde-base/libkdeedu
158kde-base/kdeedu kde-base/marble
159kde-base/kdeedu kde-base/parley
160kde-base/kdeedu kde-base/step
161kde-base/kdegames kde-base/bovo
162kde-base/kdegames kde-base/katomic
163kde-base/kdegames kde-base/kbattleship
164kde-base/kdegames kde-base/kblackbox
165kde-base/kdegames kde-base/kbounce
166kde-base/kdegames kde-base/kdiamond
167kde-base/kdegames kde-base/kfourinline
168kde-base/kdegames kde-base/kgoldrunner
169kde-base/kdegames kde-base/kiriki
170kde-base/kdegames kde-base/kjumpingcube
171kde-base/kdegames kde-base/klines
172kde-base/kdegames kde-base/kmahjongg
173kde-base/kdegames kde-base/kmines
174kde-base/kdegames kde-base/knetwalk
175kde-base/kdegames kde-base/kolf
176kde-base/kdegames kde-base/kollision
177kde-base/kdegames kde-base/konquest
178kde-base/kdegames kde-base/kpat
179kde-base/kdegames kde-base/kreversi
180kde-base/kdegames kde-base/ksame
181kde-base/kdegames kde-base/kshisen
182kde-base/kdegames kde-base/kspaceduel
183kde-base/kdegames kde-base/ksquares
184kde-base/kdegames kde-base/ksudoku
185kde-base/kdegames kde-base/ktuberling
186kde-base/kdegames kde-base/kubrick
187kde-base/kdegames kde-base/libkdegames
188kde-base/kdegames kde-base/libkmahjongg
189kde-base/kdegames kde-base/lskat
190kde-base/kdegraphics kde-base/gwenview
191kde-base/kdegraphics kde-base/kamera
192kde-base/kdegraphics kde-base/kcolorchooser
193kde-base/kdegraphics kde-base/kgamma
194kde-base/kdegraphics kde-base/kghostview
195kde-base/kdegraphics kde-base/kolourpaint
196kde-base/kdegraphics kde-base/kruler
197kde-base/kdegraphics kde-base/ksnapshot
198kde-base/kdegraphics kde-base/libkscan
199kde-base/kdegraphics kde-base/okular
200kde-base/kdegraphics kde-base/svgpart
201kde-base/kdemultimedia kde-base/dragonplayer
202kde-base/kdemultimedia kde-base/juk
203kde-base/kdemultimedia kde-base/kdemultimedia-kioslaves
204kde-base/kdemultimedia kde-base/kmix
205kde-base/kdemultimedia kde-base/kscd
206kde-base/kdemultimedia kde-base/libkcddb
207kde-base/kdemultimedia kde-base/libkcompactdisc
208kde-base/kdenetwork kde-base/kdenetwork-filesharing
209kde-base/kdenetwork kde-base/kdnssd
210kde-base/kdenetwork kde-base/kget
211kde-base/kdenetwork kde-base/knewsticker
212kde-base/kdenetwork kde-base/kopete
213kde-base/kdenetwork kde-base/kppp
214kde-base/kdenetwork kde-base/krdc
215kde-base/kdenetwork kde-base/krfb
216kde-base/kdepim kde-base/akonadi
217kde-base/kdepim kde-base/akregator
218kde-base/kdepim kde-base/certmanager
219kde-base/kdepim kde-base/kabc2mutt
220kde-base/kdepim kde-base/kabcclient
221kde-base/kdepim kde-base/kaddressbook
222kde-base/kdepim kde-base/kalarm
223kde-base/kdepim kde-base/kdemaildir
224kde-base/kdepim kde-base/kdepim-kioslaves
225kde-base/kdepim kde-base/kdepim-kresources
226kde-base/kdepim kde-base/kdepim-wizards
227kde-base/kdepim kde-base/kfeed
228kde-base/kdepim kde-base/kitchensync
229kde-base/kdepim kde-base/kleopatra
230kde-base/kdepim kde-base/kmail
231kde-base/kdepim kde-base/kmailcvt
232kde-base/kdepim kde-base/kmobiletools
233kde-base/kdepim kde-base/knode
234kde-base/kdepim kde-base/knotes
235kde-base/kdepim kde-base/kode
236kde-base/kdepim kde-base/konsolekalendar
237kde-base/kdepim kde-base/kontact
238kde-base/kdepim kde-base/kontact-specialdates
239kde-base/kdepim kde-base/korganizer
240kde-base/kdepim kde-base/korn
241kde-base/kdepim kde-base/kpilot
242kde-base/kdepim kde-base/ktimetracker
243kde-base/kdepim kde-base/ktnef
244kde-base/kdepim kde-base/libkdepim
245kde-base/kdepim kde-base/libkholidays
246kde-base/kdepim kde-base/libkleo
247kde-base/kdepim kde-base/libkpgp
248kde-base/kdepim kde-base/libksieve
249kde-base/kdepim kde-base/mailtransport
250kde-base/kdepim kde-base/mimelib
251kde-base/kdepim kde-base/networkstatus
252kde-base/kdesdk kde-base/cervisia
253kde-base/kdesdk kde-base/kdeaccounts-plugin
254kde-base/kdesdk kde-base/kapptemplate
255kde-base/kdesdk kde-base/kate
256kde-base/kdesdk kde-base/kbabel
257kde-base/kdesdk kde-base/kbugbuster
258kde-base/kdesdk kde-base/kcachegrind
259kde-base/kdesdk kde-base/kdesdk-kioslaves
260kde-base/kdesdk kde-base/kdesdk-misc
261kde-base/kdesdk kde-base/kdesdk-scripts
262kde-base/kdesdk kde-base/kmtrace
263kde-base/kdesdk kde-base/kompare
264kde-base/kdesdk kde-base/kspy
265kde-base/kdesdk kde-base/kstartperf
266kde-base/kdesdk kde-base/strigi-analyzer
267kde-base/kdesdk kde-base/kuiviewer
268kde-base/kdesdk kde-base/poxml
269kde-base/kdesdk kde-base/umbrello
270kde-base/kdetoys kde-base/amor
271kde-base/kdetoys kde-base/kteatime
272kde-base/kdetoys kde-base/ktux
273kde-base/kdetoys kde-base/kweather
274kde-base/kdetoys kde-base/kworldclock
275kde-base/kdeutils kde-base/ark
276kde-base/kdeutils kde-base/kcalc
277kde-base/kdeutils kde-base/kcharselect
278kde-base/kdeutils kde-base/kdessh
279kde-base/kdeutils kde-base/kdf
280kde-base/kdeutils kde-base/kfloppy
281kde-base/kdeutils kde-base/kgpg
282kde-base/kdeutils kde-base/kjots
283kde-base/kdeutils kde-base/kmilo
284kde-base/kdeutils kde-base/kregexpeditor
285kde-base/kdeutils kde-base/kdessh
286kde-base/kdeutils kde-base/ktimer
287kde-base/kdeutils kde-base/kwallet
288kde-base/kdeutils kde-base/superkaramba
289kde-base/kdeutils kde-base/sweeper
290kde-base/kdewebdev kde-base/kfilereplace
291kde-base/kdewebdev kde-base/kimagemapeditor
292kde-base/kdewebdev kde-base/klinkstatus
293kde-base/kdewebdev kde-base/kxsldbg
294kde-base/kdewebdev kde-base/quanta
295app-office/koffice app-office/karbon
296app-office/koffice app-office/kchart
297app-office/koffice app-office/kexi
298app-office/koffice app-office/kformula
299app-office/koffice app-office/kivio
300app-office/koffice app-office/koffice-data
301app-office/koffice app-office/koffice-libs
302app-office/koffice app-office/koshell
303app-office/koffice app-office/kplato
304app-office/koffice app-office/kpresenter
305app-office/koffice app-office/krita
306app-office/koffice app-office/kspread
307app-office/koffice app-office/kugar
308app-office/koffice app-office/kword
309'
310 55
311# @FUNCTION: get-parent-package 56# @FUNCTION: slot_is_at_least
312# @USAGE: <split ebuild> 57# @USAGE: <want> <have>
313# @DESCRIPTION: 58# @DESCRIPTION:
314# Echoes the name of the monolithic package that a given split ebuild was derived from. 59# Version aware slot comparator.
315get-parent-package() { 60# Current implementation relies on the fact, that slots can be compared like
316 local parent child 61# string literals (and let's keep it this way).
317 while read parent child; do 62slot_is_at_least() {
318 if [[ "${child}" == "$1" ]]; then 63 [[ "${2}" > "${1}" || "${2}" = "${1}" ]]
319 echo ${parent}
320 return 0
321 fi
322 done <<< "$KDE_DERIVATION_MAP"
323 die "Package $target not found in KDE_DERIVATION_MAP, please report bug"
324}
325
326# @FUNCTION: get-child-packages
327# @USAGE: <monolithic ebuild>
328# @DESCRIPTION:
329# Echoes the names of all (split) ebuilds derived from a given monolithic ebuild.
330get-child-packages() {
331 local parent child
332 while read parent child; do
333 [[ "${parent}" == "$1" ]] && echo -n "${child} "
334 done <<< "$KDE_DERIVATION_MAP"
335}
336
337# @FUNCTION: is-parent-package
338# @USAGE: <$CATEGORY/$PN>
339# @DESCRIPTION:
340# Returns zero exit-status if the given package is a parent (monolithic) ebuild.
341# Returns non-zero exit-status if it's not.
342is-parent-package() {
343 local parent child
344 while read parent child; do
345 [[ "${parent}" == "$1" ]] && return 0
346 done <<< "$KDE_DERIVATION_MAP"
347 return 1
348} 64}
349 65
350# @FUNCTION: buildsycoca 66# @FUNCTION: buildsycoca
351# @DESCRIPTION: 67# @DESCRIPTION:
352# Function to rebuild the KDE System Configuration Cache. 68# Function to rebuild the KDE System Configuration Cache.
353# All KDE ebuilds should run this in pkg_postinst and pkg_postrm. 69# All KDE ebuilds should run this in pkg_postinst and pkg_postrm.
354#
355# Note that kde4-base.eclass already does this.
356buildsycoca() { 70buildsycoca() {
357 debug-print-function ${FUNCNAME} "$@" 71 debug-print-function ${FUNCNAME} "$@"
358 72
359 if [[ -x ${KDEDIR}/bin/kbuildsycoca4 && -z "${ROOT%%/}" ]]; then 73 local KDE3DIR="${EROOT}usr/kde/3.5"
360 # First of all, make sure that the /usr/share/services directory exists 74 if [[ -z ${EROOT%%/} && -x "${KDE3DIR}"/bin/kbuildsycoca ]]; then
361 # and it has the right permissions 75 # Since KDE3 is aware of shortcuts in /usr, rebuild database
362 mkdir -p /usr/share/services 76 # for KDE3 as well.
363 chown root:0 /usr/share/services 77 touch "${KDE3DIR}"/share/services/ksycoca
364 chmod 0755 /usr/share/services 78 chmod 644 "${KDE3DIR}"/share/services/ksycoca
365 79
366 # kbuildsycoca4 needs a running dbus session to work correctly. 80 ebegin "Running kbuildsycoca to build global database"
367 # We have to start a new dbus session, because the DBUS_SESSION_BUS_ADDRESS in the environment 81 XDG_DATA_DIRS="${EROOT}usr/local/share:${KDE3DIR}/share:${EROOT}usr/share" \
368 # could from from the user's environment (through su [without '-']), causing kbuildsycoca4 to hang. 82 DISPLAY="" \
83 "${KDE3DIR}"/bin/kbuildsycoca --global --noincremental &> /dev/null
84 eend $?
85 fi
369 86
370 echo "Starting dbus session for kbuildsycoca4" 87 # We no longer need to run kbuildsycoca4, as kded does that automatically, as needed
371 local _i 88
372 for _i in $(dbus-launch); do 89 # fix permission for some directories
373 # We export both the ADDRESS _and_ the PID. We need the latter only to kill our session. 90 for x in share/{config,kde4}; do
374 debug-print "Exporting: ${_i}" 91 [[ ${KDEDIR} = ${EROOT}usr ]] && DIRS=${EROOT}usr || DIRS="${EROOT}usr ${KDEDIR}"
375 export "${_i}"; 92 for y in ${DIRS}; do
93 [[ -d "${y}/${x}" ]] || break # nothing to do if directory does not exist
94 if [[ $(stat --format=%a "${y}/${x}") != 755 ]]; then
95 ewarn "QA Notice:"
96 ewarn "Package ${PN} is breaking ${y}/${x} permissions."
97 ewarn "Please report this issue to gentoo bugzilla."
98 einfo "Permissions will get adjusted automatically now."
99 find "${y}/${x}" -type d -print0 | xargs -0 chmod 755
100 fi
376 done 101 done
377 debug-print "kbuildsycoca4 is using ${DBUS_SESSION_BUS_ADDRESS}" 102 done
378
379 ebegin "Running kbuildsycoca4 to build global database"
380 # This is needed because we support multiple kde versions installed together.
381 XDG_DATA_DIRS="/usr/share:${KDEDIRS//:/\/share:}/share:/usr/local/share" \
382 ${KDEDIR}/bin/kbuildsycoca4 --global --noincremental &> /dev/null
383 eend $?
384
385 echo "Killing dbus session for kbuildsycoca4"
386 debug-print "ADDRESS ${DBUS_SESSION_BUS_ADDRESS}"
387 debug-print "PID: ${DBUS_SESSION_BUS_PID}"
388 kill ${DBUS_SESSION_BUS_PID}
389 eend $?
390 unset DBUS_SESSION_BUS_ADDRESS DBUS_SESSION_BUS_PID
391
392 # For some reason this directory gets created with noone other than root
393 # being able to read it. Hence we chmod it.
394 chmod -R 0755 "${ROOT}"/usr/share/kde4
395 fi
396} 103}
397 104
398# @FUNCTION: comment_all_add_subdirectory 105# @FUNCTION: comment_all_add_subdirectory
399# @USAGE: [list of directory names] 106# @USAGE: [list of directory names]
400# @DESCRIPTION: 107# @DESCRIPTION:
401# recursively comment all add_subdirectory instructions in listed directories 108# Recursively comment all add_subdirectory instructions in listed directories,
402# except the ones in cmake/. 109# except those in cmake/.
403comment_all_add_subdirectory() { 110comment_all_add_subdirectory() {
404 find "$@" -name CMakeLists.txt -print0 | grep -vFzZ "./cmake" | \ 111 find "$@" -name CMakeLists.txt -print0 | grep -vFzZ "./cmake" | \
405 xargs -0 sed -i -e '/add_subdirectory/s/^/#DONOTCOMPILE /' -e '/ADD_SUBDIRECTORY/s/^/#DONOTCOMPILE /' || \ 112 xargs -0 sed -i \
113 -e '/^[[:space:]]*add_subdirectory/s/^/#DONOTCOMPILE /' \
114 -e '/^[[:space:]]*ADD_SUBDIRECTORY/s/^/#DONOTCOMPILE /' \
115 -e '/^[[:space:]]*macro_optional_add_subdirectory/s/^/#DONOTCOMPILE /' \
116 -e '/^[[:space:]]*MACRO_OPTIONAL_ADD_SUBDIRECTORY/s/^/#DONOTCOMPILE /' \
406 die "${LINENO}: Initial sed died" 117 || die "${LINENO}: Initial sed died"
407} 118}
408 119
409# @ECLASS-VARIABLE: KDE_LINGUAS 120# @ECLASS-VARIABLE: KDE_LINGUAS
410# @DESCRIPTION: 121# @DESCRIPTION:
411# This is a whitespace-separated list of translations that this ebuild supports. 122# This is a whitespace-separated list of translations this ebuild supports.
412# These translations automatically get added to IUSE. Therefore ebuilds must set 123# These translations are automatically added to IUSE. Therefore ebuilds must set
413# this variable before inheriting any eclasses. To only enable selected 124# this variable before inheriting any eclasses. To enable only selected
414# translations ebuilds must call enable_selected_linguas(). kde4-base.eclass does 125# translations, ebuilds must call enable_selected_linguas(). kde4-{base,meta}.eclass does
415# this for you. 126# this for you.
416# 127#
417# Example: KDE_LINGUAS="en_GB de nl" 128# Example: KDE_LINGUAS="en_GB de nl"
418for _lingua in ${KDE_LINGUAS}; do 129for _lingua in ${KDE_LINGUAS}; do
419 IUSE="${IUSE} linguas_${_lingua}" 130 IUSE="${IUSE} linguas_${_lingua}"
420done 131done
421 132
422# @FUNCTION: enable_selected_linguas 133# @FUNCTION: enable_selected_linguas
423# @DESCRIPTION: 134# @DESCRIPTION:
424# Enable translations based on LINGUAS settings and what translations are 135# Enable translations based on LINGUAS settings and translations supported by
425# supported (see KDE_LINGUAS). By default translations are found in "${S}"/po 136# the package (see KDE_LINGUAS). By default, translations are found in "${S}"/po
426# but this default can be overridden by defining KDE_LINGUAS_DIR. 137# but this default can be overridden by defining KDE_LINGUAS_DIR.
427enable_selected_linguas() { 138enable_selected_linguas() {
428 local lingua 139 debug-print-function ${FUNCNAME} "$@"
140
141 local lingua linguas sr_mess wp
142
143 # if there is no linguas defined we enable everything
144 if ! $(env | grep -q "^LINGUAS="); then
145 return 0
146 fi
147
148 # @ECLASS-VARIABLE: KDE_LINGUAS_DIR
149 # @DESCRIPTION:
150 # Specified folder where application translations are located.
151 KDE_LINGUAS_DIR=${KDE_LINGUAS_DIR:="po"}
152 [[ -d "${KDE_LINGUAS_DIR}" ]] || die "wrong linguas dir specified"
429 comment_all_add_subdirectory "${KDE_LINGUAS_DIR:-${S}/po}" 153 comment_all_add_subdirectory "${KDE_LINGUAS_DIR}"
154 pushd "${KDE_LINGUAS_DIR}" > /dev/null
155
156 # fix all various crazy sr@Latn variations
157 # this part is only ease for ebuilds, so there wont be any die when this
158 # fail at any point
159 sr_mess="sr@latn sr@latin sr@Latin"
160 for wp in ${sr_mess}; do
161 [[ -e "${wp}.po" ]] && mv "${wp}.po" "sr@Latn.po"
162 if [[ -d "${wp}" ]]; then
163 # move dir and fix cmakelists
164 mv "${wp}" "sr@Latn"
165 sed -i \
166 -e "s:${wp}:sr@Latin:g" \
167 CMakeLists.txt
168 fi
169 done
170
430 for lingua in ${KDE_LINGUAS}; do 171 for lingua in ${KDE_LINGUAS}; do
172 if [[ -e "${lingua}.po" ]]; then
173 mv "${lingua}.po" "${lingua}.po.old"
174 fi
175 done
176
177 for lingua in ${KDE_LINGUAS}; do
431 if use linguas_${lingua}; then 178 if use linguas_${lingua} ; then
179 if [[ -d "${lingua}" ]]; then
180 linguas="${linguas} ${lingua}"
432 sed -e "/add_subdirectory([[:space:]]*${lingua}[[:space:]]*)[[:space:]]*$/ s/^#DONOTCOMPILE //" \ 181 sed -e "/add_subdirectory([[:space:]]*${lingua}[[:space:]]*)[[:space:]]*$/ s/^#DONOTCOMPILE //" \
433 -e "/ADD_SUBDIRECTORY([[:space:]]*${lingua}[[:space:]]*)[[:space:]]*$/ s/^#DONOTCOMPILE //" \ 182 -e "/ADD_SUBDIRECTORY([[:space:]]*${lingua}[[:space:]]*)[[:space:]]*$/ s/^#DONOTCOMPILE //" \
434 -i "${KDE_LINGUAS_DIR:-${S}/po}"/CMakeLists.txt || die "Sed to uncomment linguas_${lingua} failed." 183 -i CMakeLists.txt || die "Sed to uncomment linguas_${lingua} failed."
435 fi 184 fi
185 if [[ -e "${lingua}.po.old" ]]; then
186 linguas="${linguas} ${lingua}"
187 mv "${lingua}.po.old" "${lingua}.po"
188 fi
189 fi
436 done 190 done
437} 191 [[ -n "${linguas}" ]] && einfo "Enabling languages: ${linguas}"
438 192
439# @ECLASS-VARIABLE: QT4_BUILT_WITH_USE_CHECK 193 popd > /dev/null
194}
195
196# @FUNCTION: enable_selected_doc_linguas
197# @DESCRIPTION:
198# Enable only selected linguas enabled doc folders.
199enable_selected_doc_linguas() {
200 debug-print-function ${FUNCNAME} "$@"
201
202 # if there is no linguas defined we enable everything
203 if ! $(env | grep -q "^LINGUAS="); then
204 return 0
205 fi
206
207 # @ECLASS-VARIABLE: KDE_DOC_DIRS
440# @DESCRIPTION: 208 # @DESCRIPTION:
441# A list of USE flags that x11-libs/qt:4 needs to be built with. 209 # Variable specifying whitespace separated patterns for documentation locations.
210 # Default is "doc/%lingua"
211 KDE_DOC_DIRS=${KDE_DOC_DIRS:='doc/%lingua'}
212 local linguas
213 for pattern in ${KDE_DOC_DIRS}; do
214
215 local handbookdir=`dirname ${pattern}`
216 local translationdir=`basename ${pattern}`
217 # Do filename pattern supplied, treat as directory
218 [[ "${handbookdir}" = '.' ]] && handbookdir=${translationdir} && translationdir=
219 [[ -d "${handbookdir}" ]] || die 'wrong doc dir specified'
220
221 if ! use handbook; then
222 # Disable whole directory
223 sed -e "/add_subdirectory[[:space:]]*([[:space:]]*${handbookdir}[[:space:]]*)/s/^/#DONOTCOMPILE /" \
224 -e "/ADD_SUBDIRECTORY[[:space:]]*([[:space:]]*${handbookdir}[[:space:]]*)/s/^/#DONOTCOMPILE /" \
225 -i CMakeLists.txt || die 'failed to comment out all handbooks'
226 else
227 # Disable subdirectories recursively
228 comment_all_add_subdirectory "${handbookdir}"
229 # Add requested translations
230 local lingua
231 for lingua in en ${KDE_LINGUAS}; do
232 if [[ ${lingua} = 'en' ]] || use linguas_${lingua}; then
233 if [[ -d "${handbookdir}/${translationdir//%lingua/${lingua}}" ]]; then
234 sed -e "/add_subdirectory[[:space:]]*([[:space:]]*${translationdir//%lingua/${lingua}}/s/^#DONOTCOMPILE //" \
235 -e "/ADD_SUBDIRECTORY[[:space:]]*([[:space:]]*${translationdir//%lingua/${lingua}}/s/^#DONOTCOMPILE //" \
236 -i "${handbookdir}"/CMakeLists.txt && ! has ${lingua} ${linguas} && linguas="${linguas} ${lingua}"
237 fi
238 fi
239 done
240 fi
241
242 done
243 [[ -n "${linguas}" ]] && einfo "Enabling handbook translations:${linguas}"
244}
245
246# @FUNCTION: get_build_type
247# @DESCRIPTION:
248# Determine whether we are using live ebuild or tbzs.
249get_build_type() {
250 if [[ ${SLOT} = live || ${PV} = *9999* ]]; then
251 BUILD_TYPE="live"
252 else
253 BUILD_TYPE="release"
254 fi
255 export BUILD_TYPE
256}
257
258# @FUNCTION: migrate_store_dir
259# @DESCRIPTION:
260# Universal store dir migration
261# * performs split of kdebase to kdebase-apps when needed
262# * moves playground/extragear kde4-base-style to toplevel dir
263migrate_store_dir() {
264 local cleandir="${ESVN_STORE_DIR}/KDE"
265 if [[ -d "${cleandir}" ]]; then
266 ewarn "'${cleandir}' has been found. Moving contents to new location."
267 addwrite "${ESVN_STORE_DIR}"
268 # Split kdebase
269 local module
270 if pushd "${cleandir}"/kdebase/kdebase > /dev/null; then
271 for module in `find . -maxdepth 1 -type d -name [a-z0-9]\*`; do
272 module="${module#./}"
273 mkdir -p "${ESVN_STORE_DIR}/kdebase-${module}" && mv -f "${module}" "${ESVN_STORE_DIR}/kdebase-${module}" || \
274 die "Failed to move to '${ESVN_STORE_DIR}/kdebase-${module}'."
275 done
276 popd > /dev/null
277 rm -fr "${cleandir}/kdebase" || \
278 die "Failed to remove ${cleandir}/kdebase. You need to remove it manually."
279 fi
280 # Move the rest
281 local pkg
282 for pkg in "${cleandir}"/*; do
283 mv -f "${pkg}" "${ESVN_STORE_DIR}"/ || eerror "Failed to move '${pkg}'"
284 done
285 rmdir "${cleandir}" || die "Could not move obsolete KDE store dir. Please move '${cleandir}' contents to appropriate location (possibly ${ESVN_STORE_DIR}) and manually remove '${cleandir}' in order to continue."
286 fi
287
288 if ! hasq kde4-meta ${INHERITED}; then
289 case ${KMNAME} in
290 extragear*|playground*)
291 local svnlocalpath="${ESVN_STORE_DIR}"/"${KMNAME}"/"${PN}"
292 if [[ -d "${svnlocalpath}" ]]; then
293 local destdir="${ESVN_STORE_DIR}"/"${ESVN_PROJECT}"/"`basename "${ESVN_REPO_URI}"`"
294 ewarn "'${svnlocalpath}' has been found."
295 ewarn "Moving contents to new location: ${destdir}"
296 addwrite "${ESVN_STORE_DIR}"
297 mkdir -p "${ESVN_STORE_DIR}"/"${ESVN_PROJECT}" && mv -f "${svnlocalpath}" "${destdir}" \
298 || die "Failed to move to '${svnlocalpath}'"
299 # Try cleaning empty directories
300 rmdir "`dirname "${svnlocalpath}"`" 2> /dev/null
301 fi
302 ;;
303 esac
304 fi
305}
306
307# Functions handling KMLOADLIBS and KMSAVELIBS
308
309# @FUNCTION: save_library_dependencies
310# @DESCRIPTION:
311# Add exporting CMake dependencies for current package
312save_library_dependencies() {
313 local depsfile="${T}/${PN}:${SLOT}"
314
315 ebegin "Saving library dependencies in ${depsfile##*/}"
316 echo "EXPORT_LIBRARY_DEPENDENCIES(\"${depsfile}\")" >> "${S}/CMakeLists.txt" || \
317 die "Failed to save the library dependencies."
318 eend $?
319}
320
321# @FUNCTION: install_library_dependencies
322# @DESCRIPTION:
323# Install generated CMake library dependencies to /var/lib/kde
324install_library_dependencies() {
325 local depsfile="${T}/${PN}:${SLOT}"
326
327 ebegin "Installing library dependencies as ${depsfile##*/}"
328 insinto ${EROOT}var/lib/kde
329 doins "${depsfile}" || die "Failed to install library dependencies."
330 eend $?
331}
332
333# @FUNCTION: load_library_dependencies
334# @DESCRIPTION:
335# Inject specified library dependencies in current package
336load_library_dependencies() {
337 local pn i depsfile
338 ebegin "Injecting library dependencies from '${KMLOADLIBS}'"
339
340 i=0
341 for pn in ${KMLOADLIBS} ; do
342 ((i++))
343 depsfile="${EROOT}var/lib/kde/${pn}:${SLOT}"
344 [[ -r "${depsfile}" ]] || die "Depsfile '${depsfile}' not accessible. You probably need to reinstall ${pn}."
345 sed -i -e "${i}iINCLUDE(\"${depsfile}\")" "${S}/CMakeLists.txt" || \
346 die "Failed to include library dependencies for ${pn}"
347 done
348 eend $?
349}
350
351# @FUNCTION: block_other_slots
352# @DESCRIPTION:
353# Create blocks for the current package in other slots when
354# installed with USE=-kdeprefix
355block_other_slots() {
356 debug-print-function ${FUNCNAME} "$@"
357
358 _do_blocker ${PN} 0:${SLOT}
359}
360
361# @FUNCTION: add_blocker
362# @DESCRIPTION:
363# Create correct RDEPEND value for blocking correct package.
364# Useful for file-collision blocks.
365# Parameters are package and version(s) to block.
366# add_blocker kdelibs 4.2.4
367# If no version is specified, then all versions will be blocked
368# If any arguments (from 2 on) contain a ":", then different versions
369# are blocked in different slots. (Unlisted slots get the version without
370# a ":", if none, then all versions are blocked). The parameter is then of
371# the form VERSION:SLOT. Any VERSION of 0 means that no blocker will be
372# added for that slot (or, if no slot, then for any unlisted slot).
373# A parameter of the form :SLOT means to block all versions from that slot.
374# If VERSION begins with "<", then "!<foo" will be used instead of "!<=foo".
375# As a special case, if a parameter with slot "3.5" is passed, then that slot
376# may also be blocked.
442# 377#
443# This list is automatically appended to KDE4_BUILT_WITH_USE_CHECK, 378# Versions that match "4.x.50" are equivalent to all slots up to (and including)
444# so don't call qt4_pkg_setup manually. 379# "4.x", but nothing following slot "4.x"
445
446# @ECLASS-VARIABLE: KDE4_BUILT_WITH_USE_CHECK
447# @DESCRIPTION:
448# The contents of $KDE4_BUILT_WITH_USE_CHECK gets fed to built_with_use
449# (eutils.eclass), line per line.
450# 380#
451# Example: 381# As an example, if SLOT=live, then
452# @CODE 382# add_blocker kdelibs 0 :4.3 '<4.3.96:4.4' 9999:live
453# pkg_setup() { 383# will add the following to RDEPEND:
454# KDE4_BUILT_WITH_USE_CHECK="--missing true sys-apps/dbus X" 384# !kdeprefix? ( !kde-base/kdelibs:4.3[-kdeprefix] )
455# use alsa && KDE4_BUILT_WITH_USE_CHECK="${KDE4_BUILT_WITH_USE_CHECK} 385# !kdeprefix? ( !<kde-base/kdelibs-4.3.96:4.4[-kdeprefix] )
456# --missing true media-libs/alsa-lib midi" 386# !kdeprefix? ( !<=kde-base/kdelibs-9999:live[-kdeprefix] )
457# kde4-base_pkg_setup 387# kdeprefix? ( !<=kde-base/kdelibs-9999:live[kdeprefix] )
458# } 388add_blocker() {
459# @CODE 389 debug-print-function ${FUNCNAME} "$@"
460 390
461# run built_with_use on each flag and print appropriate error messages if any 391 RDEPEND+=" $(_do_blocker "$@")"
462# flags are missing 392}
463_kde4-functions_built_with_use() {
464 local missing opt pkg flag flags
465 393
466 if [[ ${1} = "--missing" ]]; then 394# _greater_max_in_slot ver slot
467 missing="${1} ${2}" && shift 2 395# slot must be 4.x or live
396# returns true if ver is >= the maximum possibile version in slot
397_greater_max_in_slot() {
398 local ver=$1
399 local slot=$2
400 # If slot is live, then return false
401 # (nothing is greater than the maximum live version)
402 [[ $slot == live ]] && return 1
403 # Otherwise, for slot X.Y, test against X.Y.50
404 local test=${slot}.50
405 version_compare $1 ${test}
406 # 1 = '<', 2 = '=', 3 = '>'
407 [[ $? -ne 1 ]]
408}
409
410# _less_min_in_slot ver slot
411# slot must be 4.x or live
412# returns true if ver is <= the minimum possibile version in slot
413_less_min_in_slot() {
414 local ver=$1
415 local slot=$2
416 # If slot == live, then test with "9999_pre", so that 9999 tests false
417 local test=9999_pre
418 # If slot == X.Y, then test with X.(Y-1).50
419 [[ $slot == live ]] || test=${slot%.*}.$((${slot#*.} - 1)).50
420 version_compare $1 ${test}
421 # 1 = '<', 2 = '=', 3 = '>'
422 [[ $? -ne 3 ]]
423}
424
425# Internal function used for add_blocker and block_other_slots
426# This takes the same parameters as add_blocker, but echos to
427# stdout instead of updating a variable.
428_do_blocker() {
429 debug-print-function ${FUNCNAME} "$@"
430
431 [[ -z ${1} ]] && die "Missing parameter"
432 local pkg=kde-base/$1
433 shift
434 local param slot def="unset" var atom
435 # The following variables will hold parameters that contain ":"
436 # - block_3_5
437 # - block_4_1
438 # - block_4_2
439 # - block_4_3
440 # - block_4_4
441 # - block_live
442 for slot in 3.5 ${KDE_SLOTS[@]} ${KDE_LIVE_SLOTS[@]}; do
443 local block_${slot//./_}="unset"
444 done
445
446 # This construct goes through each parameter passed, and sets
447 # either def or block_* to the version passed
448 for param; do
449 # If the parameter does not have a ":" in it...
450 if [[ ${param/:} == ${param} ]]; then
451 def=${param}
452 else # the parameter *does* have a ":" in it
453 # so everythin after the : is the slot...
454 slot=${param#*:}
455 # ...and everything before the : is the version
456 local block_${slot//./_}=${param%:*}
468 fi 457 fi
458 done
459
460 for slot in ${KDE_SLOTS[@]} ${KDE_LIVE_SLOTS[@]}; do
461 # ${var} contains the name of the variable we care about for this slot
462 # ${!var} is it's value
463 var=block_${slot//./_}
464 # if we didn't pass *:${slot}, then use the unsloted value
465 [[ ${!var} == "unset" ]] && var=def
466
467 # If the no version was passed, or the version is greater than the
468 # maximum possible version in this slot, block all versions in this
469 # slot
470 if [[ ${!var} == "unset" ]] || _greater_max_in_slot ${!var#<} ${slot}; then
471 atom=${pkg}
472 # If the version is "0" or less than the minimum possible version in
473 # this slot, do nothing
474 elif [[ ${!var} == "0" ]] || _less_min_in_slot ${!var#<} ${slot}; then
475 continue
476 # If the version passed begins with a "<", then use "<" instead of "<="
469 if [[ ${1:0:1} = "-" ]]; then 477 elif [[ ${!var:0:1} == "<" ]]; then
470 opt=${1} && shift 478 # this also removes the first character of the version, which is a "<"
471 fi 479 atom="<${pkg}-${!var:1}"
472
473 pkg=${1} && shift
474
475 for flag in "${@}"; do
476 flags="${flags} ${flag}"
477 if ! built_with_use ${missing} ${opt} ${pkg} ${flag}; then
478 flags="${flags}*"
479 else 480 else
480 [[ ${opt} = "-o" ]] && return 0 481 atom="<=${pkg}-${!var}"
481 fi
482 done
483 if [[ "${flags# }" = "${@}" ]]; then
484 return 0
485 fi
486 if [[ ${opt} = "-o" ]]; then
487 eerror "This package requires '${pkg}' to be built with any of the following USE flags: '$*'."
488 else
489 eerror "This package requires '${pkg}' to be built with the following USE flags: '${flags# }'."
490 fi
491 return 1
492}
493
494# @FUNCTION: kde4-functions_check_use
495# @DESCRIPTION:
496# Check if the Qt4 libraries are built with the USE flags listed in
497# $QT4_BUILT_WITH_USE_CHECK.
498#
499# Check if a list of packages are built with certain USE flags, as listed in
500# $KDE4_BUILT_WITH_USE_CHECK.
501#
502# If any of the required USE flags are missing, an eerror will be printed for
503# each package with missing USE flags.
504kde4-functions_check_use() {
505 # I like to keep flags sorted
506 QT4_BUILT_WITH_USE_CHECK=$(echo "${QT4_BUILT_WITH_USE_CHECK}" | \
507 tr '[:space:]' '\n' | sort | xargs)
508
509 local line missing
510 if [[ -n ${KDE4_BUILT_WITH_USE_CHECK[@]} && $(declare -p KDE4_BUILT_WITH_USE_CHECK) = 'declare -a '* ]]; then
511 KDE4_BUILT_WITH_USE_CHECK=("x11-libs/qt:4 ${QT4_BUILT_WITH_USE_CHECK}"
512 "${KDE4_BUILT_WITH_USE_CHECK[@]}")
513
514 for line in "${KDE4_BUILT_WITH_USE_CHECK[@]}"; do
515 [[ -z ${line} ]] && continue
516 if ! _kde4-functions_built_with_use ${line}; then
517 missing=true
518 fi 482 fi
483 # on -kdeprefix we block every slot
484 echo " !kdeprefix? ( !${atom}:${slot}[-kdeprefix] )"
485 # on kdeprefix we block only our slot
486 if [[ ${SLOT} == ${slot} ]]; then
487 echo " kdeprefix? ( !${atom}:${SLOT}[kdeprefix] )"
488 fi
519 done 489 done
490
491 # This is a special case block for :3.5; it does not use the
492 # default version passed, and no blocker is output *unless* a version
493 # is passed, or ":3.5" is passed to explicitly request a block on all
494 # 3.5 versions.
495 if [[ ${block_3_5} != "unset" && ${block_3_5} != "0" ]]; then
496 if [[ -z ${block_3_5} ]]; then
497 atom=${pkg}
498 elif [[ ${block_3_5:0:1} == "<" ]]; then
499 atom="<${pkg}-${block_3_5:1}"
520 else 500 else
521 KDE4_BUILT_WITH_USE_CHECK="x11-libs/qt:4 ${QT4_BUILT_WITH_USE_CHECK} 501 atom="<=${pkg}-${block_3_5}"
522 ${KDE4_BUILT_WITH_USE_CHECK}"
523
524 while read line; do
525 [[ -z ${line} ]] && continue
526 if ! _kde4-functions_built_with_use ${line}; then
527 missing=true
528 fi 502 fi
529 done <<< "${KDE4_BUILT_WITH_USE_CHECK}" 503 echo " !${atom}:3.5"
530 fi 504 fi
531 if [[ -n ${missing} ]]; then
532 echo
533 eerror "Flags marked with an * are missing."
534 die "Missing USE flags found"
535 fi
536} 505}
506
507# @FUNCTION: add_kdebase_dep
508# @DESCRIPTION:
509# Create proper dependency for kde-base/ dependencies,
510# adding SLOT when needed (and *only* when needed).
511# This takes 1 or 2 arguments. The first being the package
512# name, the optional second, is additional USE flags to append.
513# The output of this should be added directly to DEPEND/RDEPEND, and
514# may be wrapped in a USE conditional (but not an || conditional
515# without an extra set of parentheses.
516add_kdebase_dep() {
517 debug-print-function ${FUNCNAME} "$@"
518
519 [[ -z ${1} ]] && die "Missing parameter"
520
521 local use=${2:+,${2}}
522
523 echo "!kdeprefix? ( >=kde-base/${1}-${PV}[-kdeprefix${use}] )"
524 echo "kdeprefix? ( >=kde-base/${1}-${PV}:${SLOT}[kdeprefix${use}] )"
525}

Legend:
Removed from v.1.6  
changed lines
  Added in v.1.25

  ViewVC Help
Powered by ViewVC 1.1.20