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 | |
| 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>
| -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 | } | ||
