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-09 14:58:14 +0000 |
commit | 6ead00eba265211eae5a2423c155403c8c6d54d0 (patch) | |
tree | 17e8b83b928aafeb5250c2588fd6fee815b75d5b /meta/classes/mime.bbclass | |
parent | 07ee2d7e6b2f571fe405464838e376cf03e5e8e6 (diff) | |
download | openembedded-core-6ead00eba265211eae5a2423c155403c8c6d54d0.tar.gz openembedded-core-6ead00eba265211eae5a2423c155403c8c6d54d0.tar.bz2 openembedded-core-6ead00eba265211eae5a2423c155403c8c6d54d0.tar.xz openembedded-core-6ead00eba265211eae5a2423c155403c8c6d54d0.zip |
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>
Signed-off-by: Joshua Lock <josh@linux.intel.com>
Diffstat (limited to 'meta/classes/mime.bbclass')
-rw-r--r-- | meta/classes/mime.bbclass | 58 |
1 files changed, 58 insertions, 0 deletions
diff --git a/meta/classes/mime.bbclass b/meta/classes/mime.bbclass new file mode 100644 index 000000000..2d17d9cd0 --- /dev/null +++ b/meta/classes/mime.bbclass @@ -0,0 +1,58 @@ +DEPENDS += "shared-mime-info-native shared-mime-info" + +mime_postinst() { +if [ "$1" = configure ]; then + UPDATEMIMEDB=`which update-mime-database` + if [ -x "$UPDATEMIMEDB" ] ; then + echo "Updating MIME database... this may take a while." + $UPDATEMIMEDB $D${datadir}/mime + else + echo "Missing update-mime-database, update of mime database failed!" + exit 1 + fi +fi +} + +mime_postrm() { +if [ "$1" = remove ] || [ "$1" = upgrade ]; then + UPDATEMIMEDB=`which update-mime-database` + if [ -x "$UPDATEMIMEDB" ] ; then + echo "Updating MIME database... this may take a while." + $UPDATEMIMEDB $D${datadir}/mime + else + echo "Missing update-mime-database, update of mime database failed!" + exit 1 + fi +fi +} + +python populate_packages_append () { + import os.path, re + packages = d.getVar('PACKAGES', True).split() + pkgdest = d.getVar('PKGDEST', True) + + for pkg in packages: + mime_dir = '%s/%s/usr/share/mime/packages' % (pkgdest, pkg) + mimes = [] + mime_re = re.compile(".*\.xml$") + if os.path.exists(mime_dir): + for f in os.listdir(mime_dir): + if mime_re.match(f): + mimes.append(f) + if mimes: + bb.note("adding mime postinst and postrm scripts to %s" % pkg) + postinst = d.getVar('pkg_postinst_%s' % pkg, True) or d.getVar('pkg_postinst', True) + if not postinst: + postinst = '#!/bin/sh\n' + postinst += d.getVar('mime_postinst', True) + d.setVar('pkg_postinst_%s' % pkg, postinst) + postrm = d.getVar('pkg_postrm_%s' % pkg, True) or d.getVar('pkg_postrm', True) + if not postrm: + postrm = '#!/bin/sh\n' + postrm += d.getVar('mime_postrm', True) + d.setVar('pkg_postrm_%s' % pkg, postrm) + bb.note("adding shared-mime-info-data dependency to %s" % pkg) + rdepends = explode_deps(dgetVar('RDEPENDS_' + pkg, False) or d.getVar('RDEPENDS', False)) or "" + rdepends.append("shared-mime-info-data") + d.setVar('RDEPENDS_' + pkg, " " + " ".join(rdepends)) +} |