Accepting request 81494 from GNOME:Factory

Pushing most of G:F

OBS-URL: https://build.opensuse.org/request/show/81494
OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/gnome-settings-daemon?expand=0&rev=68
This commit is contained in:
Sascha Peilicke 2011-09-09 09:20:07 +00:00 committed by Git OBS Bridge
commit e0bdc32a47
8 changed files with 543 additions and 385 deletions

View File

@ -1,29 +1,68 @@
Index: gnome-packagekit-2.91.4/src/gpk-update-icon.c diff --git a/data/gnome-settings-daemon.convert b/data/gnome-settings-daemon.convert
=================================================================== index 9ecc65f..5a6efbc 100644
--- gnome-packagekit-2.91.4.orig/src/gpk-update-icon.c --- a/data/gnome-settings-daemon.convert
+++ gnome-packagekit-2.91.4/src/gpk-update-icon.c +++ b/data/gnome-settings-daemon.convert
@@ -48,6 +48,78 @@ static GpkFirmware *firmware = NULL; @@ -93,6 +93,9 @@ priority = /apps/gnome_settings_daemon/plugins/smartcard/priority
static GpkHardware *hardware = NULL; active = /apps/gnome_settings_daemon/plugins/sound/active
static guint timer_id = 0; priority = /apps/gnome_settings_daemon/plugins/sound/priority
static gboolean timed_exit = FALSE;
+static GSettings *settings = NULL; +[org.gnome.settings-daemon.plugins.updates]
+asked-to-collect-hardware-info = /apps/gnome-packagekit/updater_asked_to_collect_hardware_information
+ +
+#define GPK_UPDATE_HARDWARE_SEND_ACTION "gpk-update-icon hardware info - send " [org.gnome.settings-daemon.plugins.xrandr]
+#define GPK_UPDATE_HARDWARE_DONT_PROMPT_ACTION "gpk-update-icon hardware info - don't ask again" active = /apps/gnome_settings_daemon/plugins/xrandr/active
default-configuration-file = /apps/gnome_settings_daemon/xrandr/default_configuration_file
diff --git a/data/org.gnome.settings-daemon.plugins.updates.gschema.xml.in.in b/data/org.gnome.settings-daemon.plugins.updates.gschema.xml.in.in
index c09096a..67081e2 100644
--- a/data/org.gnome.settings-daemon.plugins.updates.gschema.xml.in.in
+++ b/data/org.gnome.settings-daemon.plugins.updates.gschema.xml.in.in
@@ -120,5 +120,10 @@
<_summary>The filenames on removable media that designate it a software source.</_summary>
<_description>When removable media is inserted, it is checked to see if it contains any important filenames in the root directory. If the filename matches, then an updates check is performed. This allows post-install disks to be used to update running systems.</_description>
</key>
+ <key name="asked-to-collect-hardware-info" type="b">
+ <default>false</default>
+ <_summary>Whether the hardware information collection is asked</_summary>
+ <_description>Whether the hardware information collection is asked</_description>
+ </key>
</schema>
</schemalist>
diff --git a/plugins/updates/gsd-updates-manager.c b/plugins/updates/gsd-updates-manager.c
index 5c193e9..b1abcc5 100644
--- a/plugins/updates/gsd-updates-manager.c
+++ b/plugins/updates/gsd-updates-manager.c
@@ -35,6 +35,10 @@
#include "gsd-updates-common.h"
#include "gnome-settings-profile.h"
+#define GSD_UPDATES_HARDWARE_SEND_ACTION "gsd-updates hardware info - send "
+#define GSD_UPDATES_HARDWARE_DONT_PROMPT_ACTION "gsd-updates hardware info - don't ask again"
+#define GSD_SETTINGS_HARDWARE_ASKED_TO_COLLECT "asked-to-collect-hardware-info"
+ +
#define GSD_UPDATES_MANAGER_GET_PRIVATE(o) (G_TYPE_INSTANCE_GET_PRIVATE ((o), GSD_TYPE_UPDATES_MANAGER, GsdUpdatesManagerPrivate))
#define MAX_FAILED_GET_UPDATES 10 /* the maximum number of tries */
@@ -1308,6 +1312,79 @@ on_bus_gotten (GObject *source_object,
NULL);
}
+static void +static void
+gpk_update_libnotify_cb (NotifyNotification *notification, gchar *action, gpointer data) +gsd_updates_libnotify_cb (NotifyNotification *notification,
+ gchar *action,
+ gpointer data)
+{ +{
+ if (g_strcmp0 (action, GPK_UPDATE_HARDWARE_SEND_ACTION ) == 0) { + GsdUpdatesManager *manager = GSD_UPDATES_MANAGER (data);
+
+ if (g_strcmp0 (action, GSD_UPDATES_HARDWARE_SEND_ACTION ) == 0) {
+ gboolean retval = g_spawn_command_line_async ("/usr/bin/smoltGui", NULL); + gboolean retval = g_spawn_command_line_async ("/usr/bin/smoltGui", NULL);
+ if (!retval) { + if (!retval) {
+ g_debug ("Failure launching smoltGui"); + g_debug ("Failure launching smoltGui");
+ } + }
+ g_debug ("set %s to TRUE because done", GPK_SETTINGS_HARDWARE_ASKED_TO_COLLECT); + g_debug ("set %s to TRUE because done", GSD_SETTINGS_HARDWARE_ASKED_TO_COLLECT);
+ g_settings_set_boolean (settings, GPK_SETTINGS_HARDWARE_ASKED_TO_COLLECT, TRUE); + g_settings_set_boolean (manager->priv->settings_gsd, GSD_SETTINGS_HARDWARE_ASKED_TO_COLLECT, TRUE);
+ } else if (g_strcmp0 (action, GPK_UPDATE_HARDWARE_DONT_PROMPT_ACTION) == 0) { + } else if (g_strcmp0 (action, GSD_UPDATES_HARDWARE_DONT_PROMPT_ACTION) == 0) {
+ g_debug ("set %s to TRUE because user said no", GPK_SETTINGS_HARDWARE_ASKED_TO_COLLECT); + g_debug ("set %s to TRUE because user said no", GSD_SETTINGS_HARDWARE_ASKED_TO_COLLECT);
+ g_settings_set_boolean (settings, GPK_SETTINGS_HARDWARE_ASKED_TO_COLLECT, TRUE); + g_settings_set_boolean (manager->priv->settings_gsd, GSD_SETTINGS_HARDWARE_ASKED_TO_COLLECT, TRUE);
+ } else { + } else {
+ g_warning ("unknown action id: %s", action); + g_warning ("unknown action id: %s", action);
+ } + }
@ -31,8 +70,9 @@ Index: gnome-packagekit-2.91.4/src/gpk-update-icon.c
+} +}
+ +
+static gboolean +static gboolean
+check_for_collect_hardware_information (gpointer data) +check_for_collect_hardware_information (gpointer *data)
+{ +{
+ GsdUpdatesManager *manager = GSD_UPDATES_MANAGER (data);
+ gboolean asked_to_collect = FALSE; + gboolean asked_to_collect = FALSE;
+ +
+ NotifyNotification *notification; + NotifyNotification *notification;
@ -41,7 +81,7 @@ Index: gnome-packagekit-2.91.4/src/gpk-update-icon.c
+ //gchar *body2; + //gchar *body2;
+ gboolean ret; + gboolean ret;
+ +
+ asked_to_collect = g_settings_get_boolean (settings, GPK_SETTINGS_HARDWARE_ASKED_TO_COLLECT); + asked_to_collect = g_settings_get_boolean (manager->priv->settings_gsd, GSD_SETTINGS_HARDWARE_ASKED_TO_COLLECT);
+ +
+ if (asked_to_collect) { + if (asked_to_collect) {
+ g_debug ("don't collect hardware info because already done"); + g_debug ("don't collect hardware info because already done");
@ -64,10 +104,10 @@ Index: gnome-packagekit-2.91.4/src/gpk-update-icon.c
+ notification = notify_notification_new (summary, body, "help-browser"); + notification = notify_notification_new (summary, body, "help-browser");
+ notify_notification_set_timeout (notification, NOTIFY_EXPIRES_NEVER); + notify_notification_set_timeout (notification, NOTIFY_EXPIRES_NEVER);
+ notify_notification_set_urgency (notification, NOTIFY_URGENCY_LOW); + notify_notification_set_urgency (notification, NOTIFY_URGENCY_LOW);
+ notify_notification_add_action (notification, GPK_UPDATE_HARDWARE_SEND_ACTION, + notify_notification_add_action (notification, GSD_UPDATES_HARDWARE_SEND_ACTION,
+ _("Send now"), gpk_update_libnotify_cb, NULL, NULL); + _("Send now"), gsd_updates_libnotify_cb, (gpointer)manager, NULL);
+ notify_notification_add_action (notification, GPK_UPDATE_HARDWARE_DONT_PROMPT_ACTION, + notify_notification_add_action (notification, GSD_UPDATES_HARDWARE_DONT_PROMPT_ACTION,
+ _("Do not show this again"), gpk_update_libnotify_cb, NULL, NULL); + _("Do not show this again"), gsd_updates_libnotify_cb, (gpointer)manager, NULL);
+ ret = notify_notification_show (notification, &error); + ret = notify_notification_show (notification, &error);
+ if (!ret) { + if (!ret) {
+ g_warning ("error: %s", error->message); + g_warning ("error: %s", error->message);
@ -78,43 +118,16 @@ Index: gnome-packagekit-2.91.4/src/gpk-update-icon.c
+ g_free (body); + g_free (body);
+ return FALSE; + return FALSE;
+} +}
+
gboolean
gsd_updates_manager_start (GsdUpdatesManager *manager,
GError **error)
@@ -1406,6 +1483,8 @@ gsd_updates_manager_start (GsdUpdatesManager *manager,
(GAsyncReadyCallback) on_bus_gotten,
manager);
/** + g_timeout_add_seconds (5 * 60, check_for_collect_hardware_information, manager);
* gpk_icon_timed_exit_cb: +
@@ -70,11 +142,14 @@ gpk_icon_startup_cb (GtkApplication *app /* success */
watch = gpk_watch_new (); ret = TRUE;
firmware = gpk_firmware_new (); g_debug ("Started updates manager");
hardware = gpk_hardware_new ();
+ settings = g_settings_new (GPK_SETTINGS_SCHEMA);
/* Only timeout if we have specified iton the command line */
if (timed_exit) {
timer_id = g_timeout_add_seconds (120, (GSourceFunc) gpk_icon_timed_exit_cb, application);
g_source_set_name_by_id (timer_id, "[GpkUpdateIcon] timed exit");
+ } else {
+ g_timeout_add_seconds (5 * 60, check_for_collect_hardware_information, NULL);
}
}
Index: gnome-packagekit-2.91.4/data/org.gnome.packagekit.gschema.migrate
===================================================================
--- gnome-packagekit-2.91.4.orig/data/org.gnome.packagekit.gschema.migrate
+++ gnome-packagekit-2.91.4/data/org.gnome.packagekit.gschema.migrate
@@ -45,4 +45,4 @@ dbus-default-interaction = /apps/gnome-p
dbus-enforced-interaction = /apps/gnome-packagekit/dbus_enforced_interaction
install-root = /apps/gnome-packagekit/install_root
media-repo-filenames = /apps/gnome-packagekit/media_repo_filenames
-
+updater-asked-to-collect-hardware-information = /apps/gnome-packagekit/updater_asked_to_collect_hardware_information
Index: gnome-packagekit-2.91.4/src/gpk-common.h
===================================================================
--- gnome-packagekit-2.91.4.orig/src/gpk-common.h
+++ gnome-packagekit-2.91.4/src/gpk-common.h
@@ -53,6 +53,7 @@ G_BEGIN_DECLS
#define GPK_SETTINGS_FREQUENCY_GET_UPDATES "frequency-get-updates"
#define GPK_SETTINGS_FREQUENCY_GET_UPGRADES "frequency-get-upgrades"
#define GPK_SETTINGS_FREQUENCY_REFRESH_CACHE "frequency-refresh-cache"
+#define GPK_SETTINGS_HARDWARE_ASKED_TO_COLLECT "updater-asked-to-collect-hardware-information"
#define GPK_SETTINGS_IGNORED_DBUS_REQUESTS "ignored-dbus-requests"
#define GPK_SETTINGS_IGNORED_DEVICES "ignored-devices"
#define GPK_SETTINGS_IGNORED_MESSAGES "ignored-messages"

View File

@ -1,3 +0,0 @@
version https://git-lfs.github.com/spec/v1
oid sha256:cba471aa232688b87bf536c0982e816011c62a6d98bba9c949dd2bafc27f02cb
size 1683404

View File

@ -0,0 +1,3 @@
version https://git-lfs.github.com/spec/v1
oid sha256:b0e73a652a315d4288f123f4dd34cfcb982bf5595529167f6b894934723020ec
size 1736576

View File

@ -1,61 +1,52 @@
Index: data/apps_gnome_settings_daemon_keybindings.schemas.in
===================================================================
--- data/apps_gnome_settings_daemon_keybindings.schemas.in.orig
+++ data/apps_gnome_settings_daemon_keybindings.schemas.in
@@ -25,6 +25,17 @@
</schema>
<schema>
+ <key>/schemas/apps/gnome_settings_daemon/toggle_mute</key>
+ <applyto>/apps/gnome_settings_daemon/toggle_mute</applyto>
+ <type>bool</type>
+ <default>TRUE</default>
+ <locale name="C">
+ <short>Toggle Mute</short>
+ <long>Toggle the sound mixer's mute status when then mute button is pressed.</long>
+ </locale>
+ </schema>
+
+ <schema>
<key>/schemas/apps/gnome_settings_daemon/keybindings/volume_mute</key>
<applyto>/apps/gnome_settings_daemon/keybindings/volume_mute</applyto>
<type>string</type>
Index: plugins/media-keys/gsd-media-keys-manager.c Index: plugins/media-keys/gsd-media-keys-manager.c
=================================================================== ===================================================================
--- plugins/media-keys/gsd-media-keys-manager.c.orig --- plugins/media-keys/gsd-media-keys-manager.c.orig
+++ plugins/media-keys/gsd-media-keys-manager.c +++ plugins/media-keys/gsd-media-keys-manager.c
@@ -681,9 +681,11 @@ do_sound_action (GsdMediaKeysManager *ma @@ -637,6 +637,7 @@ do_sound_action (GsdMediaKeysManager *ma
int type) gboolean quiet)
{ {
gboolean muted; gboolean old_muted, new_muted;
+ gboolean toggle_mute; + gboolean toggle_mute;
guint vol, norm_vol_step; guint old_vol, new_vol, norm_vol_step;
int vol_step;
gboolean sound_changed; gboolean sound_changed;
+ GError *error;
if (manager->priv->stream == NULL) @@ -653,7 +654,11 @@ do_sound_action (GsdMediaKeysManager *ma
return;
@@ -704,7 +706,21 @@ do_sound_action (GsdMediaKeysManager *ma
switch (type) { switch (type) {
case MUTE_KEY: case MUTE_KEY:
- muted = !muted; - new_muted = !old_muted;
+ error = NULL; + toggle_mute = g_settings_get_boolean (manager->priv->settings, "toggle-mute");
+ toggle_mute = gconf_client_get_bool (manager->priv->conf_client,
+ GCONF_MISC_DIR "/toggle_mute",
+ &error);
+
+ if (error) {
+ toggle_mute = TRUE;
+ g_error_free (error);
+ }
+
+ if (toggle_mute) + if (toggle_mute)
+ muted = !muted; + new_muted = !old_muted;
+ else + else
+ muted = TRUE; + new_muted = TRUE;
+
gvc_mixer_stream_change_is_muted (manager->priv->stream, muted);
sound_changed = TRUE;
break; break;
case VOLUME_DOWN_KEY:
if (old_vol <= norm_vol_step) {
Index: data/gnome-settings-daemon.convert
===================================================================
--- data/gnome-settings-daemon.convert.orig
+++ data/gnome-settings-daemon.convert
@@ -66,6 +66,7 @@ volume-down = /apps/gnome_settings_daemo
volume-mute = /apps/gnome_settings_daemon/keybindings/volume_mute
volume-up = /apps/gnome_settings_daemon/keybindings/volume_up
www = /apps/gnome_settings_daemon/keybindings/www
+toggle-mute = /apps/gnome_settings_daemon/toggle_mute
[org.gnome.settings-daemon.plugins.mouse]
active = /apps/gnome_settings_daemon/plugins/mouse/active
Index: data/org.gnome.settings-daemon.plugins.media-keys.gschema.xml.in.in
===================================================================
--- data/org.gnome.settings-daemon.plugins.media-keys.gschema.xml.in.in.orig
+++ data/org.gnome.settings-daemon.plugins.media-keys.gschema.xml.in.in
@@ -145,5 +145,10 @@
<_summary>Magnifier zoom out</_summary>
<_description>Binding for the magnifier to zoom out</_description>
</key>
+ <key name="toggle-mute" type="b">
+ <default>true</default>
+ <_summary>Toggle Mute</_summary>
+ <_description>Toggle the sound mixer's mute status when then mute button is pressed.</_description>
+ </key>
</schema>
</schemalist>

View File

@ -0,0 +1,20 @@
diff --git a/plugins/updates/gsd-updates-manager.c b/plugins/updates/gsd-updates-manager.c
index a81aa1f..5c193e9 100644
--- a/plugins/updates/gsd-updates-manager.c
+++ b/plugins/updates/gsd-updates-manager.c
@@ -995,6 +995,7 @@ set_proxy_cb (GObject *object, GAsyncResult *res, gpointer user_data)
static void
reload_proxy_settings (GsdUpdatesManager *manager)
{
+#if 0
gchar *proxy_http;
gchar *proxy_ftp;
@@ -1011,6 +1012,7 @@ reload_proxy_settings (GsdUpdatesManager *manager)
g_free (proxy_http);
g_free (proxy_ftp);
+#endif
}
static void

View File

@ -24,8 +24,8 @@ GNOME's GConf keys.
Index: plugins/proxy/Makefile.am Index: plugins/proxy/Makefile.am
=================================================================== ===================================================================
--- /dev/null 1970-01-01 00:00:00.000000000 +0000 --- /dev/null
+++ plugins/proxy/Makefile.am 2010-01-13 16:44:52.000000000 +1100 +++ plugins/proxy/Makefile.am
@@ -0,0 +1,57 @@ @@ -0,0 +1,57 @@
+NULL = +NULL =
+ +
@ -86,9 +86,9 @@ Index: plugins/proxy/Makefile.am
+@GSD_INTLTOOL_PLUGIN_RULE@ +@GSD_INTLTOOL_PLUGIN_RULE@
Index: plugins/proxy/gsd-proxy-manager.c Index: plugins/proxy/gsd-proxy-manager.c
=================================================================== ===================================================================
--- /dev/null 1970-01-01 00:00:00.000000000 +0000 --- /dev/null
+++ plugins/proxy/gsd-proxy-manager.c 2010-01-13 16:44:52.000000000 +1100 +++ plugins/proxy/gsd-proxy-manager.c
@@ -0,0 +1,731 @@ @@ -0,0 +1,733 @@
+/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- +/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*-
+ * + *
+ * Copyright (C) 2008 Rodrigo Moya <rodrigo@gnome-db.org> + * Copyright (C) 2008 Rodrigo Moya <rodrigo@gnome-db.org>
@ -127,7 +127,6 @@ Index: plugins/proxy/gsd-proxy-manager.c
+#include <gdk/gdk.h> +#include <gdk/gdk.h>
+#include <gdk/gdkx.h> +#include <gdk/gdkx.h>
+#include <gtk/gtk.h> +#include <gtk/gtk.h>
+#include <gconf/gconf-client.h>
+ +
+#include "gnome-settings-profile.h" +#include "gnome-settings-profile.h"
+#include "gsd-proxy-manager.h" +#include "gsd-proxy-manager.h"
@ -135,7 +134,8 @@ Index: plugins/proxy/gsd-proxy-manager.c
+#define GSD_PROXY_MANAGER_GET_PRIVATE(o) (G_TYPE_INSTANCE_GET_PRIVATE ((o), GSD_TYPE_PROXY_MANAGER, GsdProxyManagerPrivate)) +#define GSD_PROXY_MANAGER_GET_PRIVATE(o) (G_TYPE_INSTANCE_GET_PRIVATE ((o), GSD_TYPE_PROXY_MANAGER, GsdProxyManagerPrivate))
+ +
+/* Novell extension */ +/* Novell extension */
+#define KEY_USE_SYSTEM_SETTINGS "/system/proxy/use_system_settings" /* string */ +#define GSD_SETTINGS_PROXY_SCHEMA "org.gnome.settings-daemon.plugins.proxy"
+#define KEY_USE_SYSTEM_SETTINGS "use-system-settings" /* string */
+#define VAL_USE_SYSTEM_SETTINGS_ONLY_IF_NOT_SET "only_if_mode_not_set" +#define VAL_USE_SYSTEM_SETTINGS_ONLY_IF_NOT_SET "only_if_mode_not_set"
+#define VAL_USE_SYSTEM_SETTINGS_SYSTEM_VALUES "system_values" +#define VAL_USE_SYSTEM_SETTINGS_SYSTEM_VALUES "system_values"
+#define VAL_USE_SYSTEM_SETTINGS_USER_VALUES "user_values" +#define VAL_USE_SYSTEM_SETTINGS_USER_VALUES "user_values"
@ -143,30 +143,24 @@ Index: plugins/proxy/gsd-proxy-manager.c
+#define ETC_SYSCONFIG_PROXY_URI "file:///etc/sysconfig/proxy" +#define ETC_SYSCONFIG_PROXY_URI "file:///etc/sysconfig/proxy"
+ +
+/* Gnome keys */ +/* Gnome keys */
+#define DIR_PROXY "/system/proxy" +#define GNOME_SETTINGS_PROXY_SCHEMA "org.gnome.system.proxy"
+#define KEY_USE_HTTP_PROXY "/system/http_proxy/use_http_proxy" /* bool */ +#define KEY_PROXY_AUTOCONFIG_URL "autoconfig-url" /* string */
+#define KEY_HTTP_HOST "/system/http_proxy/host" /* string */ +#define KEY_PROXY_HTTP_IGNORE_HOSTS "ignore-hosts" /* list-of-string */
+#define KEY_HTTP_PORT "/system/http_proxy/port" /* int */ +#define KEY_PROXY_MODE "mode" /* string */
+#define KEY_HTTP_USE_AUTHENTICATION "/system/http_proxy/use_authentication" /* bool */ +#define KEY_HTTP_AUTHENTICATION_USER "authentication-user" /* string */
+#define KEY_HTTP_AUTHENTICATION_USER "/system/http_proxy/authentication_user" /* string */ +#define KEY_HTTP_AUTHENTICATION_PASSWORD "authentication-password" /* string */
+#define KEY_HTTP_AUTHENTICATION_PASSWORD "/system/http_proxy/authentication_password" /* string */ +#define KEY_HTTP_PROXY_ENABLED "enabled" /* bool */
+#define KEY_HTTP_IGNORE_HOSTS "/system/http_proxy/ignore_hosts" /* list-of-string */ +#define KEY_HTTP_USE_AUTHENTICATION "use-authentication" /* bool */
+#define KEY_MODE "/system/proxy/mode" /* string */ +#define KEY_HOST "host" /* string */
+#define KEY_SECURE_HOST "/system/proxy/secure_host" /* string */ +#define KEY_PORT "port" /* bool */
+#define KEY_SECURE_PORT "/system/proxy/secure_port" /* int */
+#define KEY_FTP_HOST "/system/proxy/ftp_host" /* string */
+#define KEY_FTP_PORT "/system/proxy/ftp_port" /* int */
+#define KEY_SOCKS_HOST "/system/proxy/socks_host" /* string */
+#define KEY_SOCKS_PORT "/system/proxy/socks_port" /* int */
+#define KEY_AUTOCONFIG_URL "/system/proxy/autoconfig_url" /* string */
+ +
+struct GsdProxyManagerPrivate +struct GsdProxyManagerPrivate
+{ +{
+ /* This is to avoid "sizeof (GsdProxyManagerPrivate) == 0" when adding + GSettings *settings;
+ * the private struct with g_type_class_add_private(). Feel free to + GSettings *settings_sys;
+ * remove this dummy field if you add real fields here. + GSettings *settings_ftp;
+ */ + GSettings *settings_http;
+ int dummy; + GSettings *settings_https;
+}; +};
+ +
+typedef struct { +typedef struct {
@ -191,20 +185,22 @@ Index: plugins/proxy/gsd-proxy-manager.c
+ +
+static gpointer manager_object = NULL; +static gpointer manager_object = NULL;
+ +
+/* Returns whether the /system/proxy/mode key has ever been set by the user */ +/* Returns whether the org.gnome.system.proxy.mode key has ever been set by the user */
+static gboolean +static gboolean
+user_mode_is_set (GConfClient *config_client) +user_mode_is_set (GsdProxyManager *manager)
+{ +{
+ GConfValue *value; + char *value;
+ +
+ value = gconf_client_get_without_default (config_client, KEY_MODE, NULL); + value = g_settings_get_string (manager->priv->settings_sys, KEY_PROXY_MODE);
+ +
+ if (value) + /* FIXME Poke the default value */
+ if (value && strcmp (value, "none") != 0)
+ { + {
+ gconf_value_free (value); + g_free (value);
+ return TRUE; + return TRUE;
+ } + }
+ else +
+ g_free (value);
+ return FALSE; + return FALSE;
+} +}
+ +
@ -301,10 +297,10 @@ Index: plugins/proxy/gsd-proxy-manager.c
+ +
+/* Disables the proxy in the user's settings */ +/* Disables the proxy in the user's settings */
+static void +static void
+copy_proxy_disabled (GConfClient *config_client) +copy_proxy_disabled (GsdProxyManager *manager)
+{ +{
+ gconf_client_set_bool (config_client, KEY_USE_HTTP_PROXY, FALSE, NULL); + g_settings_set_boolean (manager->priv->settings_http, KEY_HTTP_PROXY_ENABLED, FALSE);
+ gconf_client_set_string (config_client, KEY_MODE, "none", NULL); + g_settings_set_string (manager->priv->settings_sys, KEY_PROXY_MODE, "none");
+} +}
+ +
+ +
@ -485,65 +481,67 @@ Index: plugins/proxy/gsd-proxy-manager.c
+ +
+/* Copies the (enabled) system proxy settings in the user's settings */ +/* Copies the (enabled) system proxy settings in the user's settings */
+static void +static void
+copy_proxy_enabled (GConfClient *config_client, SystemSettings *settings) +copy_proxy_enabled (GsdProxyManager *manager, SystemSettings *settings)
+{ +{
+ GsdProxyManagerPrivate *priv;
+ gchar *host; + gchar *host;
+ guint port; + guint port;
+ +
+ gconf_client_set_string (config_client, KEY_MODE, "manual", NULL); + priv = manager->priv;
+ g_settings_set_string (priv->settings_sys, KEY_PROXY_MODE, "manual");
+ +
+ /* 1. HTTP proxy */ + /* 1. HTTP proxy */
+ +
+ /* Yast2 currently doesn't support a public username/password */ + /* Yast2 currently doesn't support a public username/password */
+ gconf_client_set_bool (config_client, KEY_HTTP_USE_AUTHENTICATION, FALSE, NULL); + g_settings_set_boolean (priv->settings_http, KEY_HTTP_USE_AUTHENTICATION, FALSE);
+ gconf_client_set_string (config_client, KEY_HTTP_AUTHENTICATION_USER, "", NULL); + g_settings_set_string (priv->settings_http, KEY_HTTP_AUTHENTICATION_USER, "");
+ gconf_client_set_string (config_client, KEY_HTTP_AUTHENTICATION_PASSWORD, "", NULL); + g_settings_set_string (priv->settings_http, KEY_HTTP_AUTHENTICATION_PASSWORD, "");
+ +
+ if (parse_uri (settings->http_proxy, &host, &port)) + if (parse_uri (settings->http_proxy, &host, &port))
+ { + {
+ gconf_client_set_bool (config_client, KEY_USE_HTTP_PROXY, TRUE, NULL); + g_settings_set_boolean (priv->settings_http, KEY_HTTP_PROXY_ENABLED, TRUE);
+ +
+ gconf_client_set_string (config_client, KEY_HTTP_HOST, host, NULL); + g_settings_set_string (priv->settings_http, KEY_HOST, host);
+ gconf_client_set_int (config_client, KEY_HTTP_PORT, (int) port, NULL); + g_settings_set_int (priv->settings_http, KEY_PORT, (int) port);
+ +
+ g_free (host); + g_free (host);
+ } + }
+ else + else
+ { + {
+ gconf_client_set_bool (config_client, KEY_USE_HTTP_PROXY, FALSE, NULL); + g_settings_set_boolean (priv->settings_http, KEY_HTTP_PROXY_ENABLED, FALSE);
+ gconf_client_set_string (config_client, KEY_HTTP_HOST, "", NULL); + g_settings_set_string (priv->settings_http, KEY_HOST, "");
+ gconf_client_set_int (config_client, KEY_HTTP_PORT, 0, NULL); + g_settings_set_int (priv->settings_http, KEY_PORT, 0);
+ gconf_client_set_list (config_client, KEY_HTTP_IGNORE_HOSTS, GCONF_VALUE_STRING, NULL, NULL); + g_settings_set_strv (priv->settings_sys, KEY_PROXY_HTTP_IGNORE_HOSTS, NULL);
+ } + }
+ +
+ /* 2. HTTPS proxy */ + /* 2. HTTPS proxy */
+ +
+ if (parse_uri (settings->https_proxy, &host, &port)) + if (parse_uri (settings->https_proxy, &host, &port))
+ { + {
+ gconf_client_set_string (config_client, KEY_SECURE_HOST, host, NULL); + g_settings_set_string (priv->settings_https, KEY_HOST, host);
+ gconf_client_set_int (config_client, KEY_SECURE_PORT, (int) port, NULL); + g_settings_set_int (priv->settings_https, KEY_PORT, (int) port);
+ +
+ g_free (host); + g_free (host);
+ } + }
+ else + else
+ { + {
+ gconf_client_set_string (config_client, KEY_SECURE_HOST, "", NULL); + g_settings_set_string (priv->settings_https, KEY_HOST, "");
+ gconf_client_set_int (config_client, KEY_SECURE_PORT, 0, NULL); + g_settings_set_int (priv->settings_https, KEY_PORT, 0);
+ } + }
+ +
+ /* 3. FTP proxy */ + /* 3. FTP proxy */
+ +
+ if (parse_uri (settings->ftp_proxy, &host, &port)) + if (parse_uri (settings->ftp_proxy, &host, &port))
+ { + {
+ gconf_client_set_string (config_client, KEY_FTP_HOST, host, NULL); + g_settings_set_string (priv->settings_ftp, KEY_HOST, host);
+ gconf_client_set_int (config_client, KEY_FTP_PORT, (int) port, NULL); + g_settings_set_int (priv->settings_ftp, KEY_PORT, (int) port);
+ +
+ g_free (host); + g_free (host);
+ } + }
+ else + else
+ { + {
+ gconf_client_set_string (config_client, KEY_FTP_HOST, "", NULL); + g_settings_set_string (priv->settings_ftp, KEY_HOST, "");
+ gconf_client_set_int (config_client, KEY_FTP_PORT, 0, NULL); + g_settings_set_int (priv->settings_ftp, KEY_PORT, 0);
+ } + }
+ +
+ /* 4. No-proxy hosts */ + /* 4. No-proxy hosts */
@ -551,60 +549,42 @@ Index: plugins/proxy/gsd-proxy-manager.c
+ if (settings->no_proxy != NULL) + if (settings->no_proxy != NULL)
+ { + {
+ char **tokens; + char **tokens;
+ int i;
+ GSList *list;
+ +
+ tokens = g_strsplit_set (settings->no_proxy, ", ", 0); + tokens = g_strsplit_set (settings->no_proxy, ", ", 0);
+ + g_settings_set_strv (priv->settings_sys, KEY_PROXY_HTTP_IGNORE_HOSTS, (const gchar * const*)tokens);
+ list = NULL;
+
+ for (i = 0; tokens[i] != NULL; i++)
+ {
+ char *s;
+
+ s = tokens[i];
+ if (strlen (s) != 0)
+ list = g_slist_prepend (list, s);
+ }
+
+ list = g_slist_reverse (list);
+
+ gconf_client_set_list (config_client, KEY_HTTP_IGNORE_HOSTS, GCONF_VALUE_STRING, list, NULL);
+
+ g_slist_free (list);
+ g_strfreev (tokens); + g_strfreev (tokens);
+ } + }
+ else + else
+ gconf_client_set_list (config_client, KEY_HTTP_IGNORE_HOSTS, GCONF_VALUE_STRING, NULL, NULL); + g_settings_set_strv (priv->settings_sys, KEY_PROXY_HTTP_IGNORE_HOSTS, NULL);
+} +}
+ +
+/* Copies the system's proxy settings to the user's settings */ +/* Copies the system's proxy settings to the user's settings */
+static void +static void
+copy_system_to_user (GConfClient *config_client) +copy_system_to_user (GsdProxyManager *manager)
+{ +{
+ SystemSettings settings; + SystemSettings settings;
+ +
+ read_system_settings (&settings); + read_system_settings (&settings);
+ +
+ if (settings.proxy_enabled == NULL) + if (settings.proxy_enabled == NULL)
+ copy_proxy_disabled (config_client); + copy_proxy_disabled (manager);
+ else + else
+ { + {
+ if (strcmp (settings.proxy_enabled, "no") == 0) + if (strcmp (settings.proxy_enabled, "no") == 0)
+ copy_proxy_disabled (config_client); + copy_proxy_disabled (manager);
+ else if (strcmp (settings.proxy_enabled, "yes") == 0) + else if (strcmp (settings.proxy_enabled, "yes") == 0)
+ copy_proxy_enabled (config_client, &settings); + copy_proxy_enabled (manager, &settings);
+ } + }
+ +
+ system_settings_free (&settings); + system_settings_free (&settings);
+} +}
+ +
+static void +static void
+use_system_settings_change (GConfClient *config_client, const char *value) +use_system_settings_change (GsdProxyManager *manager, const char *value)
+{ +{
+ if (strcmp (value, VAL_USE_SYSTEM_SETTINGS_SYSTEM_VALUES) == 0) + if (strcmp (value, VAL_USE_SYSTEM_SETTINGS_SYSTEM_VALUES) == 0)
+ { + {
+ copy_system_to_user (config_client); + copy_system_to_user (manager);
+ } + }
+ else if (strcmp (value, VAL_USE_SYSTEM_SETTINGS_USER_VALUES) == 0) + else if (strcmp (value, VAL_USE_SYSTEM_SETTINGS_USER_VALUES) == 0)
+ { + {
@ -613,26 +593,27 @@ Index: plugins/proxy/gsd-proxy-manager.c
+} +}
+ +
+static void +static void
+dir_proxy_key_changed_cb (GConfEntry *entry) +settings_key_changed_cb (GSettings *gsettings, char *key, GsdProxyManager *manager)
+{
+ GConfClient *client = gconf_client_get_default ();
+
+ if (strcmp (entry->key, KEY_USE_SYSTEM_SETTINGS) == 0)
+ use_system_settings_change (client, gconf_value_get_string (entry->value));
+
+ g_object_unref (client);
+}
+
+static void
+copy_system_values_if_needed (GConfClient *client)
+{ +{
+ char *value; + char *value;
+ +
+ value = gconf_client_get_string (client, KEY_USE_SYSTEM_SETTINGS, NULL); + if (strcmp (key, KEY_USE_SYSTEM_SETTINGS) == 0) {
+ value = g_settings_get_string (gsettings, key);
+ use_system_settings_change (manager, value);
+ g_free (value);
+ }
+}
+
+static void
+copy_system_values_if_needed (GsdProxyManager *manager)
+{
+ char *value;
+
+ value = g_settings_get_string (manager->priv->settings, KEY_USE_SYSTEM_SETTINGS);
+ if (!value) + if (!value)
+ return; + return;
+ +
+ use_system_settings_change (client, value); + use_system_settings_change (manager, value);
+ g_free (value); + g_free (value);
+} +}
+ +
@ -642,63 +623,56 @@ Index: plugins/proxy/gsd-proxy-manager.c
+ GFile *file, + GFile *file,
+ GFile *other_file, + GFile *other_file,
+ GFileMonitorEvent event_type, + GFileMonitorEvent event_type,
+ gpointer data) + GsdProxyManager *manager)
+{ +{
+ GConfClient *client;
+
+ if (event_type != G_FILE_MONITOR_EVENT_CHANGED) + if (event_type != G_FILE_MONITOR_EVENT_CHANGED)
+ return; + return;
+ +
+ client = gconf_client_get_default (); + copy_system_values_if_needed (manager);
+ copy_system_values_if_needed (client);
+ g_object_unref (G_OBJECT (client));
+} +}
+ +
+gboolean +gboolean
+gsd_proxy_manager_start (GsdProxyManager *manager, +gsd_proxy_manager_start (GsdProxyManager *manager,
+ GError **error) + GError **error)
+{ +{
+ GConfClient *config_client; + GsdProxyManagerPrivate *priv;
+ GFile *sysconfig_proxy; + GFile *sysconfig_proxy;
+ GFileMonitor *monitor; + GFileMonitor *monitor;
+ char *use_system_settings; + char *use_system_settings;
+ +
+ priv = manager->priv;
+
+ g_debug ("Starting proxy manager"); + g_debug ("Starting proxy manager");
+ gnome_settings_profile_start (NULL); + gnome_settings_profile_start (NULL);
+ +
+ config_client = gconf_client_get_default ();
+
+ /* The very first time g-s-d is run, we change the user's keys if the new + /* The very first time g-s-d is run, we change the user's keys if the new
+ * use_system_settings key is not set at all or is set to the default. + * use_system_settings key is not set at all or is set to the default.
+ * Afterwards, that key will be set to reflect what the user had previously + * Afterwards, that key will be set to reflect what the user had previously
+ * configured. + * configured.
+ */ + */
+ +
+ use_system_settings = gconf_client_get_string (config_client, KEY_USE_SYSTEM_SETTINGS, NULL); + use_system_settings = g_settings_get_string (priv->settings, KEY_USE_SYSTEM_SETTINGS);
+ if (!use_system_settings || strcmp (use_system_settings, VAL_USE_SYSTEM_SETTINGS_ONLY_IF_NOT_SET) == 0) + if (!use_system_settings || strcmp (use_system_settings, VAL_USE_SYSTEM_SETTINGS_ONLY_IF_NOT_SET) == 0)
+ { + {
+ if (user_mode_is_set (config_client)) + if (user_mode_is_set (manager))
+ gconf_client_set_string (config_client, KEY_USE_SYSTEM_SETTINGS, VAL_USE_SYSTEM_SETTINGS_USER_VALUES, NULL); + g_settings_set_string (priv->settings, KEY_USE_SYSTEM_SETTINGS, VAL_USE_SYSTEM_SETTINGS_USER_VALUES);
+ else + else
+ { + {
+ copy_system_to_user (config_client); + copy_system_to_user (manager);
+ gconf_client_set_string (config_client, KEY_USE_SYSTEM_SETTINGS, VAL_USE_SYSTEM_SETTINGS_SYSTEM_VALUES, NULL); + g_settings_set_string (priv->settings, KEY_USE_SYSTEM_SETTINGS, VAL_USE_SYSTEM_SETTINGS_SYSTEM_VALUES);
+ } + }
+ } + }
+ +
+ if (use_system_settings) + if (use_system_settings)
+ g_free (use_system_settings); + g_free (use_system_settings);
+ +
+ gconf_client_add_dir (config_client, DIR_PROXY, GCONF_CLIENT_PRELOAD_NONE, NULL); + g_signal_connect (priv->settings, "changed", G_CALLBACK (settings_key_changed_cb), manager);
+ gconf_client_notify_add (config_client, DIR_PROXY, dir_proxy_key_changed_cb, NULL, NULL, NULL);
+ +
+ sysconfig_proxy = g_file_new_for_uri (ETC_SYSCONFIG_PROXY_URI); + sysconfig_proxy = g_file_new_for_uri (ETC_SYSCONFIG_PROXY_URI);
+ monitor = g_file_monitor_file (sysconfig_proxy, 0, NULL, NULL); + monitor = g_file_monitor_file (sysconfig_proxy, 0, NULL, NULL);
+ g_signal_connect (monitor, "changed", G_CALLBACK (monitor_cb), NULL); + g_signal_connect (monitor, "changed", G_CALLBACK (monitor_cb), manager);
+ +
+ copy_system_values_if_needed (config_client); + copy_system_values_if_needed (manager);
+
+ g_object_unref (config_client);
+ +
+ gnome_settings_profile_end (NULL); + gnome_settings_profile_end (NULL);
+ +
@ -766,8 +740,31 @@ Index: plugins/proxy/gsd-proxy-manager.c
+gsd_proxy_manager_dispose (GObject *object) +gsd_proxy_manager_dispose (GObject *object)
+{ +{
+ GsdProxyManager *proxy_manager; + GsdProxyManager *proxy_manager;
+ GsdProxyManagerPrivate *priv;
+ +
+ proxy_manager = GSD_PROXY_MANAGER (object); + proxy_manager = GSD_PROXY_MANAGER (object);
+ priv = proxy_manager->priv;
+
+ if (priv->settings) {
+ g_object_unref (priv->settings);
+ priv->settings = NULL;
+ }
+ if (priv->settings_sys) {
+ g_object_unref (priv->settings_sys);
+ priv->settings_sys = NULL;
+ }
+ if (priv->settings_ftp) {
+ g_object_unref (priv->settings_ftp);
+ priv->settings_ftp = NULL;
+ }
+ if (priv->settings_http) {
+ g_object_unref (priv->settings_http);
+ priv->settings_http = NULL;
+ }
+ if (priv->settings_https) {
+ g_object_unref (priv->settings_https);
+ priv->settings_https = NULL;
+ }
+ +
+ G_OBJECT_CLASS (gsd_proxy_manager_parent_class)->dispose (object); + G_OBJECT_CLASS (gsd_proxy_manager_parent_class)->dispose (object);
+} +}
@ -790,6 +787,11 @@ Index: plugins/proxy/gsd-proxy-manager.c
+gsd_proxy_manager_init (GsdProxyManager *manager) +gsd_proxy_manager_init (GsdProxyManager *manager)
+{ +{
+ manager->priv = GSD_PROXY_MANAGER_GET_PRIVATE (manager); + manager->priv = GSD_PROXY_MANAGER_GET_PRIVATE (manager);
+ manager->priv->settings = g_settings_new (GSD_SETTINGS_PROXY_SCHEMA);
+ manager->priv->settings_sys = g_settings_new (GNOME_SETTINGS_PROXY_SCHEMA);
+ manager->priv->settings_ftp = g_settings_get_child (manager->priv->settings_sys, "ftp");
+ manager->priv->settings_http = g_settings_get_child (manager->priv->settings_sys, "http");
+ manager->priv->settings_https = g_settings_get_child (manager->priv->settings_sys, "https");
+} +}
+ +
+static void +static void
@ -822,8 +824,8 @@ Index: plugins/proxy/gsd-proxy-manager.c
+} +}
Index: plugins/proxy/gsd-proxy-manager.h Index: plugins/proxy/gsd-proxy-manager.h
=================================================================== ===================================================================
--- /dev/null 1970-01-01 00:00:00.000000000 +0000 --- /dev/null
+++ plugins/proxy/gsd-proxy-manager.h 2010-01-13 16:44:52.000000000 +1100 +++ plugins/proxy/gsd-proxy-manager.h
@@ -0,0 +1,57 @@ @@ -0,0 +1,57 @@
+/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- +/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*-
+ * + *
@ -884,9 +886,9 @@ Index: plugins/proxy/gsd-proxy-manager.h
+#endif /* __GSD_PROXY_MANAGER_H */ +#endif /* __GSD_PROXY_MANAGER_H */
Index: plugins/proxy/gsd-proxy-plugin.c Index: plugins/proxy/gsd-proxy-plugin.c
=================================================================== ===================================================================
--- /dev/null 1970-01-01 00:00:00.000000000 +0000 --- /dev/null
+++ plugins/proxy/gsd-proxy-plugin.c 2010-01-13 16:44:52.000000000 +1100 +++ plugins/proxy/gsd-proxy-plugin.c
@@ -0,0 +1,103 @@ @@ -0,0 +1,109 @@
+/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- +/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*-
+ * + *
+ * Copyright (C) 2008 Rodrigo Moya <rodrigo@gnome-db.org> + * Copyright (C) 2008 Rodrigo Moya <rodrigo@gnome-db.org>
@ -975,6 +977,7 @@ Index: plugins/proxy/gsd-proxy-plugin.c
+impl_deactivate (GnomeSettingsPlugin *plugin) +impl_deactivate (GnomeSettingsPlugin *plugin)
+{ +{
+ g_debug ("Deactivating proxy plugin"); + g_debug ("Deactivating proxy plugin");
+ gsd_proxy_manager_stop (GSD_PROXY_PLUGIN (plugin)->priv->manager);
+} +}
+ +
+static void +static void
@ -990,10 +993,15 @@ Index: plugins/proxy/gsd-proxy-plugin.c
+ +
+ g_type_class_add_private (klass, sizeof (GsdProxyPluginPrivate)); + g_type_class_add_private (klass, sizeof (GsdProxyPluginPrivate));
+} +}
+
+static void
+gsd_proxy_plugin_class_finalize (GsdProxyPluginClass *klass)
+{
+}
Index: plugins/proxy/gsd-proxy-plugin.h Index: plugins/proxy/gsd-proxy-plugin.h
=================================================================== ===================================================================
--- /dev/null 1970-01-01 00:00:00.000000000 +0000 --- /dev/null
+++ plugins/proxy/gsd-proxy-plugin.h 2010-01-13 16:44:52.000000000 +1100 +++ plugins/proxy/gsd-proxy-plugin.h
@@ -0,0 +1,59 @@ @@ -0,0 +1,59 @@
+/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- +/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*-
+ * + *
@ -1056,8 +1064,8 @@ Index: plugins/proxy/gsd-proxy-plugin.h
+#endif /* __GSD_PROXY_PLUGIN_H__ */ +#endif /* __GSD_PROXY_PLUGIN_H__ */
Index: plugins/proxy/novell-sysconfig-proxy-helper Index: plugins/proxy/novell-sysconfig-proxy-helper
=================================================================== ===================================================================
--- /dev/null 1970-01-01 00:00:00.000000000 +0000 --- /dev/null
+++ plugins/proxy/novell-sysconfig-proxy-helper 2010-01-13 16:44:52.000000000 +1100 +++ plugins/proxy/novell-sysconfig-proxy-helper
@@ -0,0 +1,19 @@ @@ -0,0 +1,19 @@
+#!/bin/sh +#!/bin/sh
+ +
@ -1080,8 +1088,8 @@ Index: plugins/proxy/novell-sysconfig-proxy-helper
+echo "NO_PROXY $NO_PROXY" +echo "NO_PROXY $NO_PROXY"
Index: plugins/proxy/proxy.gnome-settings-plugin.in Index: plugins/proxy/proxy.gnome-settings-plugin.in
=================================================================== ===================================================================
--- /dev/null 1970-01-01 00:00:00.000000000 +0000 --- /dev/null
+++ plugins/proxy/proxy.gnome-settings-plugin.in 2010-01-13 16:44:52.000000000 +1100 +++ plugins/proxy/proxy.gnome-settings-plugin.in
@@ -0,0 +1,8 @@ @@ -0,0 +1,8 @@
+[GNOME Settings Plugin] +[GNOME Settings Plugin]
+Module=proxy +Module=proxy
@ -1091,105 +1099,87 @@ Index: plugins/proxy/proxy.gnome-settings-plugin.in
+Authors=Rodrigo Moya <rodrigo@gnome-db.org> +Authors=Rodrigo Moya <rodrigo@gnome-db.org>
+Copyright= +Copyright=
+Website= +Website=
Index: data/system_proxy.schemas.in
===================================================================
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
+++ data/system_proxy.schemas.in 2010-01-13 16:44:52.000000000 +1100
@@ -0,0 +1,26 @@
+<?xml version="1.0"?>
+<gconfschemafile>
+ <schemalist>
+ <schema>
+ <key>/schemas/system/proxy/use_system_settings</key>
+ <applyto>/system/proxy/use_system_settings</applyto>
+ <type>string</type>
+ <default>only_if_mode_not_set</default>
+ <locale name="C">
+ <short>Use the system's proxy settings</short>
+ <long>Whether to use the system's proxy settings.
+ Possible values are "only_if_mode_not_set", "system_values", and
+ "user_values". The first one is the default value; in
+ it, the system's proxy settings will be used if and
+ only if the user has never set his /system/proxy/mode
+ key. Once the user sets that key, use_system_settings
+ will switch to "system_values", which indicates that
+ the system's proxy settings should be used, or
+ "user_values", which indicates that the user's
+ settings should be used. The key will alternate
+ between these last two values in the future and will
+ not go back to the default value.</long>
+ </locale>
+ </schema>
+ </schemalist>
+</gconfschemafile>
Index: plugins/Makefile.am Index: plugins/Makefile.am
=================================================================== ===================================================================
--- plugins/Makefile.am.orig 2009-06-16 20:17:13.000000000 +1000 --- plugins/Makefile.am.orig
+++ plugins/Makefile.am 2010-01-13 16:44:52.000000000 +1100 +++ plugins/Makefile.am
@@ -12,6 +12,7 @@ SUBDIRS = \ @@ -15,6 +15,7 @@ enabled_plugins = \
keyboard \ keyboard \
media-keys \ media-keys \
mouse \ mouse \
+ proxy \ + proxy \
sound \ sound \
typing-break \ wacom \
xrandr \ xrandr \
Index: configure.ac Index: configure.ac
=================================================================== ===================================================================
--- configure.ac.orig 2010-01-13 02:52:55.000000000 +1100 --- configure.ac.orig
+++ configure.ac 2010-01-13 16:44:52.000000000 +1100 +++ configure.ac
@@ -359,6 +359,7 @@ plugins/keyboard/Makefile @@ -575,6 +575,7 @@ plugins/media-keys/cut-n-paste/Makefile
plugins/media-keys/Makefile
plugins/media-keys/cut-n-paste/Makefile
plugins/mouse/Makefile plugins/mouse/Makefile
plugins/orientation/Makefile
plugins/print-notifications/Makefile
+plugins/proxy/Makefile +plugins/proxy/Makefile
plugins/smartcard/Makefile plugins/smartcard/Makefile
plugins/sound/Makefile plugins/sound/Makefile
plugins/typing-break/Makefile plugins/updates/Makefile
@@ -598,6 +599,7 @@ data/org.gnome.settings-daemon.plugins.u
data/org.gnome.settings-daemon.plugins.xrandr.gschema.xml.in
data/org.gnome.settings-daemon.peripherals.wacom.gschema.xml.in
data/org.gnome.settings-daemon.plugins.print-notifications.gschema.xml.in
+data/org.gnome.settings-daemon.plugins.proxy.gschema.xml.in
po/Makefile.in
])
Index: data/Makefile.am Index: data/Makefile.am
=================================================================== ===================================================================
--- data/Makefile.am.orig 2009-07-28 07:37:28.000000000 +1000 --- data/Makefile.am.orig
+++ data/Makefile.am 2010-01-13 16:44:52.000000000 +1100 +++ data/Makefile.am
@@ -11,6 +11,7 @@ schemas_in_files = \ @@ -16,6 +16,7 @@ gsettings_SCHEMAS = \
apps_gnome_settings_daemon_xrandr.schemas.in \ org.gnome.settings-daemon.plugins.xsettings.gschema.xml \
desktop_gnome_peripherals_touchpad.schemas.in \ org.gnome.settings-daemon.plugins.housekeeping.gschema.xml \
desktop_gnome_peripherals_smartcard.schemas.in \ org.gnome.settings-daemon.plugins.print-notifications.gschema.xml \
+ system_proxy.schemas.in \ + org.gnome.settings-daemon.plugins.proxy.gschema.xml \
$(NULL) org.gnome.settings-daemon.peripherals.wacom.gschema.xml \
org.gnome.settings-daemon.plugins.xrandr.gschema.xml
schemas_DATA = $(schemas_in_files:.schemas.in=.schemas) Index: data/gnome-settings-daemon.convert
Index: data/gnome-settings-daemon.schemas.in
=================================================================== ===================================================================
--- data/gnome-settings-daemon.schemas.in.orig 2009-06-16 20:17:13.000000000 +1000 --- data/gnome-settings-daemon.convert.orig
+++ data/gnome-settings-daemon.schemas.in 2010-01-13 16:44:52.000000000 +1100 +++ data/gnome-settings-daemon.convert
@@ -210,6 +210,30 @@ @@ -79,6 +79,11 @@ left-handed = /desktop/gnome/peripherals
</schema> motion-acceleration = /desktop/gnome/peripherals/mouse/motion_acceleration
motion-threshold = /desktop/gnome/peripherals/mouse/motion_threshold
<schema> +[org.gnome.settings-daemon.plugins.proxy]
+ <key>/schemas/apps/gnome_settings_daemon/plugins/proxy/active</key> +active = /apps/gnome_settings_daemon/plugins/proxy/active
+ <applyto>/apps/gnome_settings_daemon/plugins/proxy/active</applyto> +priority = /apps/gnome_settings_daemon/plugins/proxy/priority
+ <owner>gnome-settings-daemon</owner> +use-system-settings = /system/proxy/use_system_settings
+ <type>bool</type>
+ <default>TRUE</default>
+ <locale name="C">
+ <short>Enable system-proxy plugin</short>
+ <long>Set to True to enable the plugin to manage the system
+ proxy settings.</long>
+ </locale>
+ </schema>
+ <schema>
+ <key>/schemas/apps/gnome_settings_daemon/plugins/proxy/priority</key>
+ <applyto>/apps/gnome_settings_daemon/plugins/proxy/priority</applyto>
+ <owner>gnome-settings-daemon</owner>
+ <type>int</type>
+ <default>7</default>
+ <locale name="C">
+ <short></short>
+ <long></long>
+ </locale>
+ </schema>
+ +
+ <schema> [org.gnome.settings-daemon.plugins.smartcard]
<key>/schemas/apps/gnome_settings_daemon/plugins/sound/active</key> active = /apps/gnome_settings_daemon/plugins/smartcard/active
<applyto>/apps/gnome_settings_daemon/plugins/sound/active</applyto> priority = /apps/gnome_settings_daemon/plugins/smartcard/priority
<owner>gnome-settings-daemon</owner> Index: data/org.gnome.settings-daemon.plugins.proxy.gschema.xml.in.in
===================================================================
--- /dev/null
+++ data/org.gnome.settings-daemon.plugins.proxy.gschema.xml.in.in
@@ -0,0 +1,19 @@
+<schemalist>
+ <schema gettext-domain="@GETTEXT_PACKAGE@" id="org.gnome.settings-daemon.plugins.proxy" path="/org/gnome/settings-daemon/plugins/proxy/">
+ <key name="active" type="b">
+ <default>true</default>
+ <_summary>Activation of this plugin</_summary>
+ <_description>Whether this plugin would be activated by gnome-settings-daemon or not</_description>
+ </key>
+ <key name="priority" type="i">
+ <default>7</default>
+ <_summary>Priority to use for this plugin</_summary>
+ <_description>Priority to use for this plugin in gnome-settings-daemon startup queue</_description>
+ </key>
+ <key name="use-system-settings" type="s">
+ <default>'only_if_mode_not_set'</default>
+ <summary>Use the system's proxy settings</summary>
+ <description>Whether to use the system's proxy settings. Possible values are "only_if_mode_not_set", "system_values", and "user_values". The first one is the default value; in it, the system's proxy settings will be used if and only if the user has never set his org.gnome.system.proxy.mode key. Once the user sets that key, use-system-settings will switch to "system_values", which indicates that the system's proxy settings should be used, or "user_values", which indicates that the user's settings should be used. The key will alternate between these last two values in the future and will not go back to the default value.</description>
+ </key>
+ </schema>
+</schemalist>

View File

@ -1,3 +1,137 @@
-------------------------------------------------------------------
Thu Sep 8 06:59:13 UTC 2011 - vuntz@opensuse.org
- Disable gnome-settings-daemon-system-proxy-configuration.diff for
now: we really need to fix it the proper way, which likely
involves libproxy, as mentioned in
http://code.google.com/p/libproxy/issues/detail?id=165 (tracked
in bnc#690493).
- Also note that gnome-packagekit-fate302445.patch is not enabled
right now (tracked in bnc#689592).
-------------------------------------------------------------------
Mon Sep 5 15:51:46 UTC 2011 - vuntz@opensuse.org
- Update to version 3.1.91:
+ Common:
- Don't list XINPUT_LIBS twice, move X11_LIBS from LDFLAGS to
LIBADD
+ Color:
- Ensure the 'Recalibration required' notification has a custom
app name
- Fix a critical warning on startup
- Do not notify to recalibrate on every startup
+ Daemon:
- Fix possible double-free outside gnome-session
+ Gconf:
- Double check stuff we add to the hash table (bgo#658055)
+ Housekeeping:
- NULL-terminate the ignore-paths array (bgo#657849)
+ Power:
- Do not exit gnome-settings-daemon if upower fails to load
- Fix impossible to hit error paths (bgo#657364)
- Fix BRIGHTESS_STEP_AMOUNT calculation macro
- Do most of the work in _start () (bgo#657924)
- Never idle-dim the display to a higher brightness level
(bgo#658144)
+ Printers:
- Remove redundant code
+ Xsettings:
- Handle rgba-order key (bgo#657525)
- Don't poke at an empty hashtable (bgo#657464)
- Fix a stray brace
+ Updated translations.
-------------------------------------------------------------------
Thu Sep 1 14:28:30 UTC 2011 - vuntz@opensuse.org
- Update to version 3.1.90:
+ A11Y-keyboard:
- Use GIO's DBus API instead of dbus-glib's
+ Color:
- Don't use uninitialized GErrors
- Do not set an age for display and printer profiles
- Remove the ability to disable notifications
- Do not search user-icc directories if they do not exist
(bgo#657484)
+ Daemon:
- Add Unity to OnlyShowIn value for autostart desktop file
(bgo#654919)
+ Media keys:
- Don't go up to 11 (bgo#649411)
+ Mouse:
- Be more careful to avoid segfaults (bgo#657462)
+ Power:
- Ensure the critical battery beep is stopped when the AC is
inserted
- Ensure we lock the screen before suspending on lid close
(bgo#655924)
- Add mention of bgo#652183
+ Smartcard:
- Use GIO's DBus API instead of dbus-glib's
+ Updates:
- Do not log a warning if the firmware-missing file does not
exist
- Do not log a warning at startup if getting the upgrade list
is not supported (bgo#657483)
+ Updated translations.
- Rebase gnome-settings-daemon-bnc462640-mute-action.patch.
- Add polkit Requires: the power plugin uses pkexec.
-------------------------------------------------------------------
Thu Aug 18 08:58:07 CEST 2011 - dimstar@opensuse.org
- Update to version 3.1.5:
+ A11y-keyboard:
- Enable plugin by default (bgo#656287)
+ Automount:
- Link against the private profiler library
- Add some missing includes
- Don't ship the .in file, just the .in.in one
- Silence two trivial -Wformat-security warnings
+ Color:
- Do not show multiple warnings if colord is not available at
runtime
- Fix a potential crash when unloading the color plugin
- Fix a potential crash if creating the per-user ICC directory
fails
- Make lcms2 a hard dependency
+ Housekeeping:
- Use g_format_size() instead of g_format_size_for_display()
+ Media keys:
- Don't preserve the path after filling
- Remove the half pixel offset from the progressbar fill
- Always round the render coordinates for media icons
+ Power:
- Add the idle actions
- Show a status icon when in fallback mode
- Respect the idle-dim-ac and idle-dim-battery configuration
keys
- Add a backlight helper, as xbacklight isn't always present
- Fall back to the backlight helper if xbacklight is not
available
- Fix a potential crash when unloading the power plugin
- Ensure we return the new percentage when changing the
brightness
+ Updates:
- Do not use deprecated PackageKit #defines
+ Wacom:
- Invert TPCButton setting (bgo#656372)
+ Updated translations.
-------------------------------------------------------------------
Fri Jul 29 04:19:01 UTC 2011 - glin@suse.com
- Rebase gnome-settings-daemon-system-proxy-configuration.diff and
gnome-settings-daemon-bnc462640-mute-action.patch, and re-enable
the the call to autoreconf.
- Add gnome-settings-daemon-stop-reload-proxy-settings.patch to
stop the g-s-d packagekit plugin from popping up an
authentication window when reloading the proxy settings
(bnc#689592#c1 for bnc#538353)
- Port gnome-packagekit-fate302445.patch to gnome-settings-daemon
and GSettings.
------------------------------------------------------------------- -------------------------------------------------------------------
Mon Jul 25 12:54:49 CEST 2011 - vuntz@opensuse.org Mon Jul 25 12:54:49 CEST 2011 - vuntz@opensuse.org

View File

@ -18,18 +18,18 @@
Name: gnome-settings-daemon Name: gnome-settings-daemon
Version: 3.1.4 Version: 3.1.91
Release: 1 Release: 1
License: GPLv2+ License: GPLv2+
Summary: Settings daemon for the GNOME desktop Summary: Settings daemon for the GNOME desktop
Url: http://www.gnome.org Url: http://www.gnome.org
Group: System/GUI/GNOME Group: System/GUI/GNOME
Source: http://download.gnome.org/sources/gnome-settings-daemon/3.1/%{name}-%{version}.tar.bz2 Source: http://download.gnome.org/sources/gnome-settings-daemon/3.1/%{name}-%{version}.tar.bz2
# PATCH-NEEDS-REBASE gnome-settings-daemon-system-proxy-configuration.diff (was PATCH-FEATURE-OPENSUSE) # PATCH-NEEDS-REBASE gnome-settings-daemon-system-proxy-configuration.diff
Patch2: gnome-settings-daemon-system-proxy-configuration.diff Patch2: gnome-settings-daemon-system-proxy-configuration.diff
# PATCH-NEEDS-REBASE gnome-settings-daemon-apport-monitor.patch bnc439203 jblunck@novell.com -- Add apport monitoring plugin. (was PATCH-FEATURE-UPSTREAM) # PATCH-NEEDS-REBASE gnome-settings-daemon-apport-monitor.patch bnc439203 jblunck@novell.com -- Add apport monitoring plugin. (was PATCH-FEATURE-UPSTREAM)
Patch8: gnome-settings-daemon-apport-monitor.patch Patch8: gnome-settings-daemon-apport-monitor.patch
# PATCH-NEEDS-REBASE gnome-settings-daemon-bnc462640-mute-action.patch bnc462640 bgo572365 vuntz@novell.com -- Mute button should always mute sound instead of toggling mute status (was PATCH-FEATURE-UPSTREAM) # PATCH-FEATURE-UPSTREAM gnome-settings-daemon-bnc462640-mute-action.patch bnc462640 bgo572365 vuntz@novell.com -- Mute button should always mute sound instead of toggling mute status
Patch10: gnome-settings-daemon-bnc462640-mute-action.patch Patch10: gnome-settings-daemon-bnc462640-mute-action.patch
# PATCH-NEEDS-REBASE gnome-settings-daemon-bnc461755-randr-rotate-wacom.diff bnc461755 federico@novell.com - Add the option of rotating a Wacom tablet when rotating the monitor with RANDR (was PATCH-FEATURE-OPENSUSE) # PATCH-NEEDS-REBASE gnome-settings-daemon-bnc461755-randr-rotate-wacom.diff bnc461755 federico@novell.com - Add the option of rotating a Wacom tablet when rotating the monitor with RANDR (was PATCH-FEATURE-OPENSUSE)
Patch11: gnome-settings-daemon-bnc461755-randr-rotate-wacom.diff Patch11: gnome-settings-daemon-bnc461755-randr-rotate-wacom.diff
@ -41,6 +41,8 @@ Patch14: gnome-packagekit-fate302445.patch
Patch15: gnome-packagekit-BNC383261.patch Patch15: gnome-packagekit-BNC383261.patch
# PATCH-FIX-UPSTREAM bgo#654970 bnc#675969 gnome-settings-daemon-ntp-support.patch vuntz@opensuse.org -- Add SUSE support for datetime polkit helper # PATCH-FIX-UPSTREAM bgo#654970 bnc#675969 gnome-settings-daemon-ntp-support.patch vuntz@opensuse.org -- Add SUSE support for datetime polkit helper
Patch16: gnome-settings-daemon-ntp-support.patch Patch16: gnome-settings-daemon-ntp-support.patch
# PATCH-FIX-OPENSUSE gnome-settings-daemon-stop-reload-proxy-settings.patch bnc689592#c1, bnc#538353 glin@suse.com -- Stop g-s-d poping up the authentication dialog for reloading the proxy settings
Patch17: gnome-settings-daemon-stop-reload-proxy-settings.patch
BuildRequires: fdupes BuildRequires: fdupes
BuildRequires: gnome-common BuildRequires: gnome-common
# Disabled because of the non-rebased patches # Disabled because of the non-rebased patches
@ -50,31 +52,33 @@ BuildRequires: translation-update-upstream
BuildRequires: update-desktop-files BuildRequires: update-desktop-files
BuildRequires: cups-devel BuildRequires: cups-devel
BuildRequires: pkgconfig(colord) BuildRequires: pkgconfig(colord)
BuildRequires: pkgconfig(dbus-glib-1) BuildRequires: pkgconfig(dbus-glib-1) >= 0.7.4
BuildRequires: pkgconfig(fontconfig) BuildRequires: pkgconfig(fontconfig)
BuildRequires: pkgconfig(gconf-2.0) BuildRequires: pkgconfig(gconf-2.0) >= 2.6.1
BuildRequires: pkgconfig(glib-2.0) BuildRequires: pkgconfig(glib-2.0) >= 2.29.14
%if 0%{?BUILD_FROM_VCS} %if 0%{?BUILD_FROM_VCS}
BuildRequires: gnome-common BuildRequires: gnome-common
%endif %endif
BuildRequires: pkgconfig(gnome-desktop-3.0) BuildRequires: pkgconfig(gnome-desktop-3.0) >= 3.1.5
BuildRequires: pkgconfig(gsettings-desktop-schemas) BuildRequires: pkgconfig(gsettings-desktop-schemas)
BuildRequires: pkgconfig(gtk+-3.0) BuildRequires: pkgconfig(gtk+-3.0) >= 2.99.3
BuildRequires: pkgconfig(gudev-1.0) BuildRequires: pkgconfig(gudev-1.0)
BuildRequires: pkgconfig(lcms2) BuildRequires: pkgconfig(lcms2)
BuildRequires: pkgconfig(libcanberra-gtk3) BuildRequires: pkgconfig(libcanberra-gtk3)
BuildRequires: pkgconfig(libgnomekbd) BuildRequires: pkgconfig(libgnomekbd)
BuildRequires: pkgconfig(libgnomekbdui) BuildRequires: pkgconfig(libgnomekbdui)
BuildRequires: pkgconfig(libnotify) BuildRequires: pkgconfig(libnotify) >= 0.7.3
BuildRequires: pkgconfig(libpulse) BuildRequires: pkgconfig(libpulse)
BuildRequires: pkgconfig(libxklavier) BuildRequires: pkgconfig(libxklavier)
BuildRequires: pkgconfig(nss) BuildRequires: pkgconfig(nss)
BuildRequires: pkgconfig(packagekit-glib2) BuildRequires: pkgconfig(packagekit-glib2) >= 0.6.12
BuildRequires: pkgconfig(polkit-gobject-1) BuildRequires: pkgconfig(polkit-gobject-1)
BuildRequires: pkgconfig(upower-glib) BuildRequires: pkgconfig(upower-glib)
BuildRequires: pkgconfig(xfixes) BuildRequires: pkgconfig(xfixes)
BuildRequires: pkgconfig(xi) BuildRequires: pkgconfig(xi)
Requires: gsettings-desktop-schemas Requires: gsettings-desktop-schemas
# g-s-d uses the pkexec binary
Requires: polkit
Recommends: %{name}-lang Recommends: %{name}-lang
# For housekeeping plugin, that uses the nautilus dbus service # For housekeeping plugin, that uses the nautilus dbus service
Recommends: nautilus Recommends: nautilus
@ -125,18 +129,19 @@ translation-update-upstream
%if !0%{?BUILD_FROM_VCS} %if !0%{?BUILD_FROM_VCS}
# Disabled because of the non-rebased patches # Disabled because of the non-rebased patches
#gnome-patch-translation-prepare #gnome-patch-translation-prepare
#%patch2 -p0 #%%patch2 -p0
#%patch8 -p0 #%%patch8 -p0
#%patch10 -p0 %patch10 -p0
# PATCH-NEEDS-REBASE # PATCH-NEEDS-REBASE
#%patch11 -p1 #%%patch11 -p1
# PATCH-NEEDS-REBASE # PATCH-NEEDS-REBASE
#%patch13 -p0 #%%patch13 -p0
# PATCH-NEEDS-REBASE # PATCH-NEEDS-REBASE
#%patch14 -p0 #%%patch14 -p0
# PATCH-NEEDS-REBASE # PATCH-NEEDS-REBASE
#%patch15 -p0 #%%patch15 -p0
%patch16 -p1 %patch16 -p1
%patch17 -p1
%endif %endif
%if 0%{?BUILD_FROM_VCS} %if 0%{?BUILD_FROM_VCS}
@ -144,8 +149,7 @@ NOCONFIGURE=1 /usr/bin/gnome-autogen.sh
%endif %endif
%build %build
# Disabled because of the non-rebased patches autoreconf -f -i
#autoreconf -f -i
%configure\ %configure\
--libexecdir=%{_libexecdir}/gnome-settings-daemon-3.0 \ --libexecdir=%{_libexecdir}/gnome-settings-daemon-3.0 \
--enable-gconf-bridge \ --enable-gconf-bridge \
@ -185,8 +189,11 @@ rm -rf %{buildroot}
%dir %{_libexecdir}/gnome-settings-daemon-3.0 %dir %{_libexecdir}/gnome-settings-daemon-3.0
%{_libexecdir}/gnome-settings-daemon-3.0/gnome-fallback-mount-helper %{_libexecdir}/gnome-settings-daemon-3.0/gnome-fallback-mount-helper
%{_libexecdir}/gnome-settings-daemon-3.0/gnome-settings-daemon %{_libexecdir}/gnome-settings-daemon-3.0/gnome-settings-daemon
%{_libexecdir}/gnome-settings-daemon-3.0/gsd-backlight-helper
%{_libexecdir}/gnome-settings-daemon-3.0/gsd-locate-pointer %{_libexecdir}/gnome-settings-daemon-3.0/gsd-locate-pointer
%{_libexecdir}/gnome-settings-daemon-3.0/gsd-printer %{_libexecdir}/gnome-settings-daemon-3.0/gsd-printer
# From patch2
#%{_libexecdir}/gnome-settings-daemon-3.0/novell-sysconfig-proxy-helper
%if "%{_libdir}" != "%{_libexecdir}" %if "%{_libdir}" != "%{_libexecdir}"
%dir %{_libdir}/gnome-settings-daemon-3.0/ %dir %{_libdir}/gnome-settings-daemon-3.0/
%endif %endif
@ -204,10 +211,13 @@ rm -rf %{buildroot}
%{_datadir}/glib-2.0/schemas/org.gnome.settings-daemon.plugins.orientation.gschema.xml %{_datadir}/glib-2.0/schemas/org.gnome.settings-daemon.plugins.orientation.gschema.xml
%{_datadir}/glib-2.0/schemas/org.gnome.settings-daemon.plugins.power.gschema.xml %{_datadir}/glib-2.0/schemas/org.gnome.settings-daemon.plugins.power.gschema.xml
%{_datadir}/glib-2.0/schemas/org.gnome.settings-daemon.plugins.print-notifications.gschema.xml %{_datadir}/glib-2.0/schemas/org.gnome.settings-daemon.plugins.print-notifications.gschema.xml
# From patch2
#%{_datadir}/glib-2.0/schemas/org.gnome.settings-daemon.plugins.proxy.gschema.xml
%{_datadir}/glib-2.0/schemas/org.gnome.settings-daemon.plugins.updates.gschema.xml %{_datadir}/glib-2.0/schemas/org.gnome.settings-daemon.plugins.updates.gschema.xml
%{_datadir}/glib-2.0/schemas/org.gnome.settings-daemon.plugins.xrandr.gschema.xml %{_datadir}/glib-2.0/schemas/org.gnome.settings-daemon.plugins.xrandr.gschema.xml
%{_datadir}/glib-2.0/schemas/org.gnome.settings-daemon.plugins.xsettings.gschema.xml %{_datadir}/glib-2.0/schemas/org.gnome.settings-daemon.plugins.xsettings.gschema.xml
%{_datadir}/icons/*/*/* %{_datadir}/icons/*/*/*
%{_datadir}/polkit-1/actions/org.gnome.settings-daemon.plugins.power.policy
%{_mandir}/man1/gnome-settings-daemon.1* %{_mandir}/man1/gnome-settings-daemon.1*
# Own the directory since we can't depend on gconf providing them # Own the directory since we can't depend on gconf providing them
%dir %{_datadir}/GConf %dir %{_datadir}/GConf