diff options
author | Joshua Lock <josh@linux.intel.com> | 2011-11-01 17:11:04 -0700 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2011-11-10 11:37:11 +0000 |
commit | f6998758283a029cc10c767e1b6d7ea7cd3f6714 (patch) | |
tree | eaa89e98b5b3902ed0586117adb0b5b9930a407b /meta/classes | |
parent | cb1bc7668eef0804250561309e8669ba0ed9c338 (diff) | |
download | poky-f6998758283a029cc10c767e1b6d7ea7cd3f6714.tar.gz |
classes/[gnome|gnomebase|mime]: enhance gnome related classes
This patch pulls in the gnome related classes from oe-core which
adds extra packaging rules and functionality whilst modularising things
so that one can get a subset of gnome functionality without adding a lot
of extra dependencies.
These aren't an exact copy of the classes from meta-openembedded, notable
differences are:
* gnome.bbclass - I dropped the BBCLASSEXTEND
* mime.bbclass:
- updated coding style
- use which to find update-mime-database program rather than hard coded
- fix typo in populate_packges_append such that it's actually called
CC: Koen Kooi <koen@dominion.thruhere.net>
CC: Richard Purdie <richard.purdie@linuxfoundation.org>
(From OE-Core rev: 6ead00eba265211eae5a2423c155403c8c6d54d0)
Signed-off-by: Joshua Lock <josh@linux.intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta/classes')
-rw-r--r-- | meta/classes/gnome.bbclass | 18 | ||||
-rw-r--r-- | meta/classes/gnomebase.bbclass | 30 | ||||
-rw-r--r-- | meta/classes/mime.bbclass | 58 |
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 @@ | |||
1 | def gnome_verdir(v): | 1 | inherit 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 | ||
6 | SECTION ?= "x11/gnome" | 3 | EXTRA_OECONF += "--enable-introspection=no" |
7 | SRC_URI = "${GNOME_MIRROR}/${BPN}/${@gnome_verdir("${PV}")}/${BPN}-${PV}.tar.bz2;name=archive" | ||
8 | |||
9 | DEPENDS += "gnome-common" | ||
10 | |||
11 | FILES_${PN} += "${datadir}/application-registry \ | ||
12 | ${datadir}/mime-info \ | ||
13 | ${datadir}/gnome-2.0" | ||
14 | |||
15 | inherit autotools pkgconfig gconf | ||
16 | |||
17 | EXTRA_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 @@ | |||
1 | def 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 | |||
6 | SECTION ?= "x11/gnome" | ||
7 | SRC_URI = "${GNOME_MIRROR}/${BPN}/${@gnome_verdir("${PV}")}/${BPN}-${PV}.tar.bz2;name=archive" | ||
8 | |||
9 | DEPENDS += "gnome-common" | ||
10 | |||
11 | FILES_${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 | |||
21 | FILES_${PN}-doc += "${datadir}/devhelp" | ||
22 | |||
23 | inherit autotools pkgconfig | ||
24 | |||
25 | do_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 @@ | |||
1 | DEPENDS += "shared-mime-info-native shared-mime-info" | ||
2 | |||
3 | mime_postinst() { | ||
4 | if [ "$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 | ||
13 | fi | ||
14 | } | ||
15 | |||
16 | mime_postrm() { | ||
17 | if [ "$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 | ||
26 | fi | ||
27 | } | ||
28 | |||
29 | python 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 | } | ||