summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--meta/classes/gnome.bbclass18
-rw-r--r--meta/classes/gnomebase.bbclass30
-rw-r--r--meta/classes/mime.bbclass58
3 files changed, 90 insertions, 16 deletions
diff --git a/meta/classes/gnome.bbclass b/meta/classes/gnome.bbclass
index 3d68b12e9e..a19dd1703a 100644
--- a/meta/classes/gnome.bbclass
+++ b/meta/classes/gnome.bbclass
@@ -1,17 +1,3 @@
1def gnome_verdir(v): 1inherit gnomebase gtk-icon-cache gconf mime
2 import re
3 m = re.match("^([0-9]+)\.([0-9]+)", v)
4 return "%s.%s" % (m.group(1), m.group(2))
5 2
6SECTION ?= "x11/gnome" 3EXTRA_OECONF += "--enable-introspection=no"
7SRC_URI = "${GNOME_MIRROR}/${BPN}/${@gnome_verdir("${PV}")}/${BPN}-${PV}.tar.bz2;name=archive"
8
9DEPENDS += "gnome-common"
10
11FILES_${PN} += "${datadir}/application-registry \
12 ${datadir}/mime-info \
13 ${datadir}/gnome-2.0"
14
15inherit autotools pkgconfig gconf
16
17EXTRA_OEMAKE += "GCONF_DISABLE_MAKEFILE_SCHEMA_INSTALL=1"
diff --git a/meta/classes/gnomebase.bbclass b/meta/classes/gnomebase.bbclass
new file mode 100644
index 0000000000..a4209a0289
--- /dev/null
+++ b/meta/classes/gnomebase.bbclass
@@ -0,0 +1,30 @@
1def gnome_verdir(v):
2 import re
3 m = re.match("^([0-9]+)\.([0-9]+)", v)
4 return "%s.%s" % (m.group(1), m.group(2))
5
6SECTION ?= "x11/gnome"
7SRC_URI = "${GNOME_MIRROR}/${BPN}/${@gnome_verdir("${PV}")}/${BPN}-${PV}.tar.bz2;name=archive"
8
9DEPENDS += "gnome-common"
10
11FILES_${PN} += "${datadir}/application-registry \
12 ${datadir}/mime-info \
13 ${datadir}/mime/packages \
14 ${datadir}/mime/application \
15 ${datadir}/gnome-2.0 \
16 ${datadir}/polkit* \
17 ${datadir}/GConf \
18 ${datadir}/glib-2.0/schemas \
19"
20
21FILES_${PN}-doc += "${datadir}/devhelp"
22
23inherit autotools pkgconfig
24
25do_install_append() {
26 rm -rf ${D}${localstatedir}/lib/scrollkeeper/*
27 rm -rf ${D}${localstatedir}/scrollkeeper/*
28 rm -f ${D}${datadir}/applications/*.cache
29}
30
diff --git a/meta/classes/mime.bbclass b/meta/classes/mime.bbclass
new file mode 100644
index 0000000000..2d17d9cd0d
--- /dev/null
+++ b/meta/classes/mime.bbclass
@@ -0,0 +1,58 @@
1DEPENDS += "shared-mime-info-native shared-mime-info"
2
3mime_postinst() {
4if [ "$1" = configure ]; then
5 UPDATEMIMEDB=`which update-mime-database`
6 if [ -x "$UPDATEMIMEDB" ] ; then
7 echo "Updating MIME database... this may take a while."
8 $UPDATEMIMEDB $D${datadir}/mime
9 else
10 echo "Missing update-mime-database, update of mime database failed!"
11 exit 1
12 fi
13fi
14}
15
16mime_postrm() {
17if [ "$1" = remove ] || [ "$1" = upgrade ]; then
18 UPDATEMIMEDB=`which update-mime-database`
19 if [ -x "$UPDATEMIMEDB" ] ; then
20 echo "Updating MIME database... this may take a while."
21 $UPDATEMIMEDB $D${datadir}/mime
22 else
23 echo "Missing update-mime-database, update of mime database failed!"
24 exit 1
25 fi
26fi
27}
28
29python populate_packages_append () {
30 import os.path, re
31 packages = d.getVar('PACKAGES', True).split()
32 pkgdest = d.getVar('PKGDEST', True)
33
34 for pkg in packages:
35 mime_dir = '%s/%s/usr/share/mime/packages' % (pkgdest, pkg)
36 mimes = []
37 mime_re = re.compile(".*\.xml$")
38 if os.path.exists(mime_dir):
39 for f in os.listdir(mime_dir):
40 if mime_re.match(f):
41 mimes.append(f)
42 if mimes:
43 bb.note("adding mime postinst and postrm scripts to %s" % pkg)
44 postinst = d.getVar('pkg_postinst_%s' % pkg, True) or d.getVar('pkg_postinst', True)
45 if not postinst:
46 postinst = '#!/bin/sh\n'
47 postinst += d.getVar('mime_postinst', True)
48 d.setVar('pkg_postinst_%s' % pkg, postinst)
49 postrm = d.getVar('pkg_postrm_%s' % pkg, True) or d.getVar('pkg_postrm', True)
50 if not postrm:
51 postrm = '#!/bin/sh\n'
52 postrm += d.getVar('mime_postrm', True)
53 d.setVar('pkg_postrm_%s' % pkg, postrm)
54 bb.note("adding shared-mime-info-data dependency to %s" % pkg)
55 rdepends = explode_deps(dgetVar('RDEPENDS_' + pkg, False) or d.getVar('RDEPENDS', False)) or ""
56 rdepends.append("shared-mime-info-data")
57 d.setVar('RDEPENDS_' + pkg, " " + " ".join(rdepends))
58}