From 15dda9bb029c9b9fd5125a13e2a0a69af4d85dac Mon Sep 17 00:00:00 2001 From: Phil Blundell Date: Mon, 2 Aug 2004 11:34:40 +0000 Subject: append, don't prepend, to populate_packages() BKrev: 410e26d0fFpnIoET6TdN4zK3LYzqYA --- classes/gconf.oeclass | 54 +++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 54 insertions(+) (limited to 'classes') diff --git a/classes/gconf.oeclass b/classes/gconf.oeclass index e69de29bb2..06697a71ea 100644 --- a/classes/gconf.oeclass +++ b/classes/gconf.oeclass @@ -0,0 +1,54 @@ +gconf_postinst() { +if [ "$1" = configure ]; then + SCHEMA_LOCATION=/etc/gconf/schemas + for SCHEMA in ${SCHEMA_FILES}; do + if [ -e $SCHEMA_LOCATION/$SCHEMA ]; then + HOME=/root GCONF_CONFIG_SOURCE=`gconftool-2 --get-default-source` \ + gconftool-2 \ + --makefile-install-rule $SCHEMA_LOCATION/$SCHEMA > /dev/null + fi + done +fi +} + +gconf_prerm() { +if [ "$1" = remove ] || [ "$1" = upgrade ]; then + SCHEMA_LOCATION=/etc/gconf/schemas + for SCHEMA in ${SCHEMA_FILES}; do + if [ -e $SCHEMA_LOCATION/$SCHEMA ]; then + HOME=/root GCONF_CONFIG_SOURCE=`gconftool-2 --get-default-source` \ + gconftool-2 \ + --makefile-uninstall-rule $SCHEMA_LOCATION/$SCHEMA > /dev/null + fi + done +fi +} + +python populate_packages_append () { + import os.path, re + packages = oe.data.getVar('PACKAGES', d, 1).split() + workdir = oe.data.getVar('WORKDIR', d, 1) + + for pkg in packages: + schema_dir = '%s/install/%s/etc/gconf/schemas' % (workdir, pkg) + schemas = [] + schema_re = re.compile(".*\.schemas$") + if os.path.exists(schema_dir): + for f in os.listdir(schema_dir): + if schema_re.match(f): + schemas.append(f) + if schemas != []: + oe.note("adding gconf postinst and prerm scripts to %s" % pkg) + oe.data.setVar('SCHEMA_FILES', " ".join(schemas), d) + postinst = oe.data.getVar('pkg_postinst_%s' % pkg, d, 1) or oe.data.getVar('pkg_postinst', d, 1) + if not postinst: + postinst = '#!/bin/sh\n' + postinst += oe.data.getVar('gconf_postinst', d, 1) + oe.data.setVar('pkg_postinst_%s' % pkg, postinst, d) + prerm = oe.data.getVar('pkg_prerm_%s' % pkg, d, 1) or oe.data.getVar('pkg_prerm', d, 1) + if not prerm: + prerm = '#!/bin/sh\n' + prerm += oe.data.getVar('gconf_prerm', d, 1) + oe.data.setVar('pkg_prerm_%s' % pkg, prerm, d) + +} -- cgit v1.2.3