diff options
author | jmmv <jmmv@pkgsrc.org> | 2003-12-28 14:24:49 +0000 |
---|---|---|
committer | jmmv <jmmv@pkgsrc.org> | 2003-12-28 14:24:49 +0000 |
commit | 465bbfe921664a23e34f938271df7f1a27a1cec3 (patch) | |
tree | 553fa3fbe9fa4f9dc743e262cef83bedb3684d3e | |
parent | 808d1053a839c455510c692c6f9c962ae8b08e65 (diff) | |
download | pkgsrc-465bbfe921664a23e34f938271df7f1a27a1cec3.tar.gz |
Implement a framework to handle .entries files. If a package installs
one or more .entries files, it can set GCONF2_ENTRIES to the names of those
files and they will get (un)registered at (de)installation time.
Installation is handled after .schemas are installed, and uninstallation
before .schemas are deinstalled.
To achieve this, we need to implement an --unload flag in gconftool-2 to
allow clean removal of .entries from the database. This will be fed back
to authors.
Bump PKGREVISION to 1.
-rw-r--r-- | devel/GConf2/Makefile.common | 3 | ||||
-rw-r--r-- | devel/GConf2/distinfo | 3 | ||||
-rw-r--r-- | devel/GConf2/files/deinstall.tmpl | 7 | ||||
-rw-r--r-- | devel/GConf2/files/install.tmpl | 7 | ||||
-rw-r--r-- | devel/GConf2/patches/patch-ae | 116 | ||||
-rw-r--r-- | devel/GConf2/schemas.mk | 6 |
6 files changed, 136 insertions, 6 deletions
diff --git a/devel/GConf2/Makefile.common b/devel/GConf2/Makefile.common index 2096f892ad5..9274d07815b 100644 --- a/devel/GConf2/Makefile.common +++ b/devel/GConf2/Makefile.common @@ -1,7 +1,8 @@ -# $NetBSD: Makefile.common,v 1.8 2003/12/14 19:44:38 jmmv Exp $ +# $NetBSD: Makefile.common,v 1.9 2003/12/28 14:24:49 jmmv Exp $ # DISTNAME= GConf-2.4.0.1 +PKGREVISION= 1 CATEGORIES= devel gnome MASTER_SITES= ${MASTER_SITE_GNOME:=sources/GConf/2.4/} EXTRACT_SUFX= .tar.bz2 diff --git a/devel/GConf2/distinfo b/devel/GConf2/distinfo index efe3f0ec906..0cfeddbc2a8 100644 --- a/devel/GConf2/distinfo +++ b/devel/GConf2/distinfo @@ -1,4 +1,4 @@ -$NetBSD: distinfo,v 1.7 2003/12/14 19:44:38 jmmv Exp $ +$NetBSD: distinfo,v 1.8 2003/12/28 14:24:49 jmmv Exp $ SHA1 (GConf-2.4.0.1.tar.bz2) = 190ed06d34699976a9a425e9e14d4ccb26220ba8 Size (GConf-2.4.0.1.tar.bz2) = 1288876 bytes @@ -6,3 +6,4 @@ SHA1 (patch-aa) = 7bac8f0cc027a135b8bd1f55f5608a0691b13f51 SHA1 (patch-ab) = eb9ffa0ec87fe21b0f754aef019221d619b37b11 SHA1 (patch-ac) = de42b523072ff5eac020525c2ccb4ce93ed792c6 SHA1 (patch-ad) = 50b0d919768b179d0209c49aee25a7c64ca5b497 +SHA1 (patch-ae) = 292895b5a71e9b21963d258c6eeed976c9b01d30 diff --git a/devel/GConf2/files/deinstall.tmpl b/devel/GConf2/files/deinstall.tmpl index 693cb277dec..1e2421859d5 100644 --- a/devel/GConf2/files/deinstall.tmpl +++ b/devel/GConf2/files/deinstall.tmpl @@ -1,15 +1,20 @@ -# $NetBSD: deinstall.tmpl,v 1.4 2003/12/14 19:44:38 jmmv Exp $ +# $NetBSD: deinstall.tmpl,v 1.5 2003/12/28 14:24:49 jmmv Exp $ # # Unregister GConf2 schema files from GConf2's database at install time. # GCONFTOOL2="@GCONFTOOL2@" +GCONF2_ENTRIES="@GCONF2_ENTRIES@" GCONF2_SCHEMAS="@GCONF2_SCHEMAS@" GCONF2_SCHEMAS_DIR="@GCONF2_SCHEMAS_DIR@" GCONF2_CONFIG_SOURCE="@GCONF2_CONFIG_SOURCE@" case ${STAGE} in DEINSTALL) + for f in ${GCONF2_ENTRIES}; do + ${GCONFTOOL2} --config-source=${GCONF2_CONFIG_SOURCE} \ + --direct --unload ${GCONF2_SCHEMAS_DIR}/$f >/dev/null + done for f in ${GCONF2_SCHEMAS}; do GCONF_CONFIG_SOURCE="${GCONF2_CONFIG_SOURCE}" \ ${GCONFTOOL2} --makefile-uninstall-rule \ diff --git a/devel/GConf2/files/install.tmpl b/devel/GConf2/files/install.tmpl index 48f54b054fc..c8241477e9d 100644 --- a/devel/GConf2/files/install.tmpl +++ b/devel/GConf2/files/install.tmpl @@ -1,9 +1,10 @@ -# $NetBSD: install.tmpl,v 1.3 2003/06/20 10:49:18 jmmv Exp $ +# $NetBSD: install.tmpl,v 1.4 2003/12/28 14:24:49 jmmv Exp $ # # Register GConf2 schema files into GConf2's database at install time. # GCONFTOOL2="@GCONFTOOL2@" +GCONF2_ENTRIES="@GCONF2_ENTRIES@" GCONF2_SCHEMAS="@GCONF2_SCHEMAS@" GCONF2_SCHEMAS_DIR="@GCONF2_SCHEMAS_DIR@" GCONF2_CONFIG_SOURCE="@GCONF2_CONFIG_SOURCE@" @@ -15,6 +16,10 @@ POST-INSTALL) ${GCONFTOOL2} --makefile-install-rule \ ${GCONF2_SCHEMAS_DIR}/$f >/dev/null done + for f in ${GCONF2_ENTRIES}; do + ${GCONFTOOL2} --config-source=${GCONF2_CONFIG_SOURCE} \ + --direct --load ${GCONF2_SCHEMAS_DIR}/$f >/dev/null + done ;; *) ;; diff --git a/devel/GConf2/patches/patch-ae b/devel/GConf2/patches/patch-ae new file mode 100644 index 00000000000..2835685fa17 --- /dev/null +++ b/devel/GConf2/patches/patch-ae @@ -0,0 +1,116 @@ +$NetBSD: patch-ae,v 1.3 2003/12/28 14:24:49 jmmv Exp $ + +--- gconf/gconftool.c.orig 2003-08-18 20:13:20.000000000 +0200 ++++ gconf/gconftool.c +@@ -59,6 +59,7 @@ static char* long_desc = NULL; + static char* owner = NULL; + static char* schema_file = NULL; + static char* entry_file = NULL; ++static char* unload_entry_file = NULL; + static const char* config_source = NULL; + static int use_local_source = FALSE; + static int makefile_install_mode = FALSE; +@@ -167,6 +168,15 @@ struct poptOption options[] = { + NULL + }, + { ++ "unload", ++ '\0', ++ POPT_ARG_STRING, ++ &unload_entry_file, ++ 0, ++ N_("Unload a set of values described in an XML file."), ++ NULL ++ }, ++ { + "recursive-list", + 'R', + POPT_ARG_NONE, +@@ -838,6 +848,18 @@ main (int argc, char** argv) + return retval; + } + ++ if (unload_entry_file != NULL) ++ { ++ const gchar** args = poptGetArgs(ctx); ++ gint retval; ++ ++ retval = do_load_file(conf, LOAD_ENTRY_FILE, unload_entry_file, args); ++ ++ gconf_engine_unref(conf); ++ ++ return retval; ++ } ++ + if (spawn_gconfd) + { + do_spawn_daemon(conf); +@@ -2760,15 +2782,14 @@ set_values(GConfEngine* conf, const gcha + else + full_key = g_strdup(key); + +- if (schema_key) ++ full_schema_key = NULL; ++ if (unload_entry_file == NULL && schema_key) + { + if (base_dir && *schema_key != '/') + full_schema_key = gconf_concat_dir_and_key(base_dir, schema_key); + else + full_schema_key = g_strdup(schema_key); + } +- else +- full_schema_key = NULL; + + tmp = values; + while (tmp) +@@ -2776,21 +2797,21 @@ set_values(GConfEngine* conf, const gcha + GConfValue* value = tmp->data; + GError* error; + +- if (full_schema_key) ++ error = NULL; ++ if (!gconf_engine_associate_schema(conf, full_key, full_schema_key, &error)) + { +- error = NULL; +- if (!gconf_engine_associate_schema(conf, full_key, full_schema_key, &error)) +- { +- g_assert(error != NULL); +- +- g_printerr (_("WARNING: failed to associate schema `%s' with key `%s': %s\n"), +- full_schema_key, full_key, error->message); +- g_error_free(error); +- } ++ g_assert(error != NULL); ++ ++ g_printerr (_("WARNING: failed to associate schema `%s' with key `%s': %s\n"), ++ full_schema_key, full_key, error->message); ++ g_error_free(error); + } + + error = NULL; +- gconf_engine_set(conf, full_key, value, &error); ++ if (unload_entry_file != NULL) ++ gconf_engine_unset(conf, full_key, &error); ++ else ++ gconf_engine_set(conf, full_key, value, &error); + if (error != NULL) + { + g_printerr (_("Error setting value: %s\n"), error->message); +@@ -3307,7 +3328,7 @@ process_key_list(GConfEngine* conf, cons + GSList* tmp; + GError* error = NULL; + +- if (makefile_uninstall_mode) ++ if (makefile_uninstall_mode || unload_entry_file != NULL) + { + schema_name = NULL; + } +@@ -3504,7 +3525,7 @@ process_schema(GConfEngine* conf, xmlNod + + hash_foreach_info.conf = conf; + hash_foreach_info.key = schema_key; +- if (makefile_uninstall_mode) ++ if (makefile_uninstall_mode || unload_entry_file != NULL) + g_hash_table_foreach(schemas_hash, hash_uninstall_foreach, &hash_foreach_info); + else + g_hash_table_foreach(schemas_hash, hash_install_foreach, &hash_foreach_info); diff --git a/devel/GConf2/schemas.mk b/devel/GConf2/schemas.mk index c41a24c1b2c..e43aab371b4 100644 --- a/devel/GConf2/schemas.mk +++ b/devel/GConf2/schemas.mk @@ -1,4 +1,4 @@ -# $NetBSD: schemas.mk,v 1.3 2003/04/21 00:12:33 rh Exp $ +# $NetBSD: schemas.mk,v 1.4 2003/12/28 14:24:49 jmmv Exp $ # # This Makefile fragment is intended to be included by packages that install # GConf2 schema files. It takes care of registering them in the GConf2 @@ -37,9 +37,11 @@ CONFIGURE_ARGS+= --disable-schemas-install CONFIGURE_ARGS+= --with-gconf-schema-file-dir=${GCONF2_SCHEMAS_DIR} .endif -.if defined(GCONF2_SCHEMAS) && !empty(GCONF2_SCHEMAS) +.if (defined(GCONF2_SCHEMAS) && !empty(GCONF2_SCHEMAS)) || \ + (defined(GCONF2_ENTRIES) && !empty(GCONF2_ENTRIES)) FILES_SUBST+= GCONFTOOL2="${GCONFTOOL2}" FILES_SUBST+= GCONF2_CONFIG_SOURCE="${GCONF2_CONFIG_SOURCE}" +FILES_SUBST+= GCONF2_ENTRIES="${GCONF2_ENTRIES}" FILES_SUBST+= GCONF2_SCHEMAS="${GCONF2_SCHEMAS}" FILES_SUBST+= GCONF2_SCHEMAS_DIR="${GCONF2_SCHEMAS_DIR}" INSTALL_EXTRA_TMPL+= ${.CURDIR}/../../devel/GConf2/files/install.tmpl |