gnome-build r634 - in trunk: . src/backends/libgbf_am src/gbf
- From: sgranjoux svn gnome org
- To: svn-commits-list gnome org
- Subject: gnome-build r634 - in trunk: . src/backends/libgbf_am src/gbf
- Date: Sun, 5 Oct 2008 14:36:33 +0000 (UTC)
Author: sgranjoux
Date: Sun Oct 5 14:36:32 2008
New Revision: 634
URL: http://svn.gnome.org/viewvc/gnome-build?rev=634&view=rev
Log:
* src/backends/libgbf_am/gbf-am-config.h,
src/backends/libgbf_am/gbf-am-config.c,
src/backends/libgbf_am/gbf-am-project.c,
src/backends/libgbf_am/gbf-am-parse.in:
Fix #541694 - new modules and packaged are not displayed in dialog
until the project is reloaded
* src/backends/libgbf_am/test.c,
src/gbf/test.c:
Avoid GCC warning: not enough variable arguments to fit a sentinel
Modified:
trunk/ChangeLog
trunk/src/backends/libgbf_am/gbf-am-config.c
trunk/src/backends/libgbf_am/gbf-am-config.h
trunk/src/backends/libgbf_am/gbf-am-parse.in
trunk/src/backends/libgbf_am/gbf-am-project.c
trunk/src/backends/libgbf_am/test.c
trunk/src/gbf/test.c
Modified: trunk/src/backends/libgbf_am/gbf-am-config.c
==============================================================================
--- trunk/src/backends/libgbf_am/gbf-am-config.c (original)
+++ trunk/src/backends/libgbf_am/gbf-am-config.c Sun Oct 5 14:36:32 2008
@@ -301,6 +301,44 @@
}
gboolean
+gbf_am_config_mapping_update (GbfAmConfigMapping *mapping,
+ const gchar *key,
+ GbfAmConfigValue *value)
+{
+ GbfAmConfigEntry *entry = NULL;
+ GList *lp;
+ gboolean update = TRUE;
+ gboolean insert = TRUE;
+
+ g_return_val_if_fail (mapping != NULL && key != NULL, FALSE);
+
+ for (lp = mapping->pairs; lp; lp = lp->next) {
+ entry = (GbfAmConfigEntry *) lp->data;
+ if (!strcmp (entry->key, key)) {
+ if (entry->value != value)
+ {
+ gbf_am_config_value_free (entry->value);
+ entry->value = value;
+ update = TRUE;
+ }
+ insert = FALSE;
+ break;
+ }
+ }
+
+ if (insert) {
+ GbfAmConfigEntry *new_entry;
+
+ new_entry = g_new0 (GbfAmConfigEntry, 1);
+ new_entry->key = g_strdup (key);
+ new_entry->value = value;
+ mapping->pairs = g_list_prepend (mapping->pairs, new_entry);
+ }
+
+ return update;
+}
+
+gboolean
gbf_am_config_mapping_remove (GbfAmConfigMapping *mapping,
const gchar *key)
{
Modified: trunk/src/backends/libgbf_am/gbf-am-config.h
==============================================================================
--- trunk/src/backends/libgbf_am/gbf-am-config.h (original)
+++ trunk/src/backends/libgbf_am/gbf-am-config.h Sun Oct 5 14:36:32 2008
@@ -74,6 +74,9 @@
gboolean gbf_am_config_mapping_insert (GbfAmConfigMapping *mapping,
const gchar *key,
GbfAmConfigValue *value);
+gboolean gbf_am_config_mapping_update (GbfAmConfigMapping *mapping,
+ const gchar *key,
+ GbfAmConfigValue *value);
gboolean gbf_am_config_mapping_remove (GbfAmConfigMapping *mapping,
const gchar *key);
void gbf_am_config_mapping_foreach (GbfAmConfigMapping *mapping,
Modified: trunk/src/backends/libgbf_am/gbf-am-parse.in
==============================================================================
--- trunk/src/backends/libgbf_am/gbf-am-parse.in (original)
+++ trunk/src/backends/libgbf_am/gbf-am-parse.in Sun Oct 5 14:36:32 2008
@@ -17,8 +17,8 @@
use GBF::AmFiles;
# I18n
-use Locale::gettext;
use POSIX;
+use Locale::gettext qw(textdomain);
setlocale(LC_MESSAGES, "");
textdomain("@PACKAGE@");
@@ -1413,10 +1413,12 @@
my ($project, $op, $operand) = @_;
my $configure_in = $project->{"configure_in"};
- print "Operation = $op\n";
- print "operand start\n";
- print Dumper $operand;
- print "operand end\n";
+ if ($verbose) {
+ print "Operation = $op\n";
+ print "operand start\n";
+ print Dumper $operand;
+ print "operand end\n";
+ }
# op is: "set_config"
# operand is full group name for add_group, and ignored for remove_group
@@ -1439,7 +1441,6 @@
}
}
} elsif ($key =~ /^pkg_check_modules_(.*)$/) {
- print "Updating pkg config modules\n";
my $module = $1;
foreach my $subkey (keys %$value) {
if ($subkey eq "packages") {
@@ -2196,7 +2197,7 @@
shift @$tree;
- while ($$tree[0] eq "param") {
+ while (@$tree && $$tree[0] eq "param") {
shift @$tree;
my $child = $$tree[0];
if (defined($$child[0]->{value})) {
@@ -2206,7 +2207,7 @@
my %items;
$params{$$child[0]->{name}} = \%items;
shift @$child;
- while ($$child[0] eq "item") {
+ while (@$child && $$child[0] eq "item") {
shift @$child;
my $str = $$child[0][0]->{value};
$items{$$child[0][0]->{name}} = xml_unescape ($str);
Modified: trunk/src/backends/libgbf_am/gbf-am-project.c
==============================================================================
--- trunk/src/backends/libgbf_am/gbf-am-project.c (original)
+++ trunk/src/backends/libgbf_am/gbf-am-project.c Sun Oct 5 14:36:32 2008
@@ -47,7 +47,10 @@
#include "gbf-am-config.h"
#include "gbf-am-properties.h"
-#define ENABLE_DEBUG
+/* With debugging enable, the perl script gbf-am-parse outputs
+ * debugging messages not in xml format and the parser
+ * return an error */
+/*#define ENABLE_DEBUG*/
#ifdef ENABLE_DEBUG
#define DEBUG(x) x
@@ -1375,7 +1378,7 @@
gbf_am_config_value_set_string (param, (char *) param_value);
/* try to save the parameter in the config mapping */
- if (!gbf_am_config_mapping_insert (data->config,
+ if (!gbf_am_config_mapping_update (data->config,
(char *) param_name, param)) {
gbf_am_config_value_free (param);
}
@@ -1442,7 +1445,7 @@
case GBF_AM_TYPE_MAPPING:
if (item_name == NULL ||
- !gbf_am_config_mapping_insert (param->mapping,
+ !gbf_am_config_mapping_update (param->mapping,
(char *) item_name,
item)) {
gbf_am_config_value_free (item);
Modified: trunk/src/backends/libgbf_am/test.c
==============================================================================
--- trunk/src/backends/libgbf_am/test.c (original)
+++ trunk/src/backends/libgbf_am/test.c Sun Oct 5 14:36:32 2008
@@ -105,7 +105,8 @@
/* Bootstrap */
gnome_program_init ("libgbf-am-test", VERSION, LIBGNOME_MODULE,
- argc, argv, NULL);
+ argc, argv, NULL,
+ NULL); /* Avoid GCC sentinel warning */
if (argc < 2) {
g_print ("! You need to specify a project path\n");
Modified: trunk/src/gbf/test.c
==============================================================================
--- trunk/src/gbf/test.c (original)
+++ trunk/src/gbf/test.c Sun Oct 5 14:36:32 2008
@@ -10,7 +10,8 @@
GSList *l;
gnome_program_init ("libgbf-test", VERSION, LIBGNOME_MODULE,
- argc, argv, NULL);
+ argc, argv, NULL,
+ NULL); /* Avoid GCC sentinel warning */
g_print ("initializing gbf backend...\n");
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]