region: Use WID() macro

This commit is contained in:
Bastien Nocera 2011-09-29 14:41:11 +01:00
parent 01895fc933
commit 2749876e1f

View file

@ -40,28 +40,28 @@ static GDBusProxy *localed_proxy;
static GPermission *localed_permission; static GPermission *localed_permission;
static void static void
update_copy_button (GtkBuilder *builder) update_copy_button (GtkBuilder *dialog)
{ {
GtkWidget *label; GtkWidget *label;
GtkWidget *button; GtkWidget *button;
const gchar *user_lang, *system_lang; const gchar *user_lang, *system_lang;
const gchar *user_region, *system_region; const gchar *user_region, *system_region;
label = (GtkWidget *)gtk_builder_get_object (builder, "user_display_language"); label = WID ("user_display_language");
user_lang = g_object_get_data (G_OBJECT (label), "language"); user_lang = g_object_get_data (G_OBJECT (label), "language");
label = (GtkWidget*)gtk_builder_get_object (builder, "system_display_language"); label = WID ("system_display_language");
system_lang = g_object_get_data (G_OBJECT (label), "language"); system_lang = g_object_get_data (G_OBJECT (label), "language");
label = (GtkWidget *)gtk_builder_get_object (builder, "user_format"); label = WID ("user_format");
user_region = g_object_get_data (G_OBJECT (label), "region"); user_region = g_object_get_data (G_OBJECT (label), "region");
label = (GtkWidget*)gtk_builder_get_object (builder, "system_format"); label = WID ("system_format");
system_region = g_object_get_data (G_OBJECT (label), "region"); system_region = g_object_get_data (G_OBJECT (label), "region");
/* FIXME: compare layouts */ /* FIXME: compare layouts */
button = (GtkWidget *)gtk_builder_get_object (builder, "copy_settings_button"); button = WID ("copy_settings_button");
if (g_strcmp0 (user_lang, system_lang) == 0 && if (g_strcmp0 (user_lang, system_lang) == 0 &&
g_strcmp0 (user_region, system_region) == 0) { g_strcmp0 (user_region, system_region) == 0) {
@ -74,53 +74,51 @@ update_copy_button (GtkBuilder *builder)
static void static void
locale_settings_changed (GSettings *settings, locale_settings_changed (GSettings *settings,
const gchar *key, const gchar *key,
gpointer user_data) GtkBuilder *dialog)
{ {
GtkBuilder *builder = GTK_BUILDER (user_data);
GtkWidget *label; GtkWidget *label;
gchar *region, *display_region; gchar *region, *display_region;
region = g_settings_get_string (locale_settings, "region"); region = g_settings_get_string (locale_settings, "region");
if (!region || !region[0]) { if (!region || !region[0]) {
label = GTK_WIDGET (gtk_builder_get_object (builder, "user_display_language")); label = WID ("user_display_language");
region = g_strdup ((gchar*)g_object_get_data (G_OBJECT (label), "language")); region = g_strdup ((gchar*)g_object_get_data (G_OBJECT (label), "language"));
} }
display_region = gdm_get_region_from_name (region, NULL); display_region = gdm_get_region_from_name (region, NULL);
label = GTK_WIDGET (gtk_builder_get_object (builder, "user_format")); label = WID ("user_format");
gtk_label_set_text (GTK_LABEL (label), display_region); gtk_label_set_text (GTK_LABEL (label), display_region);
g_object_set_data_full (G_OBJECT (label), "region", g_strdup (region), g_free); g_object_set_data_full (G_OBJECT (label), "region", g_strdup (region), g_free);
g_free (region); g_free (region);
g_free (display_region); g_free (display_region);
update_copy_button (builder); update_copy_button (dialog);
} }
void void
system_update_language (GtkBuilder *builder, const gchar *language) system_update_language (GtkBuilder *dialog, const gchar *language)
{ {
gchar *display_language; gchar *display_language;
GtkWidget *label; GtkWidget *label;
display_language = gdm_get_language_from_name (language, NULL); display_language = gdm_get_language_from_name (language, NULL);
label = (GtkWidget *)gtk_builder_get_object (builder, "user_display_language"); label = WID ("user_display_language");
gtk_label_set_text (GTK_LABEL (label), display_language); gtk_label_set_text (GTK_LABEL (label), display_language);
g_object_set_data_full (G_OBJECT (label), "language", g_strdup (language), g_free); g_object_set_data_full (G_OBJECT (label), "language", g_strdup (language), g_free);
g_free (display_language); g_free (display_language);
/* need to update the region display in case the setting is '' */ /* need to update the region display in case the setting is '' */
locale_settings_changed (locale_settings, "region", builder); locale_settings_changed (locale_settings, "region", dialog);
update_copy_button (builder); update_copy_button (dialog);
} }
static void static void
xkb_settings_changed (GSettings *settings, xkb_settings_changed (GSettings *settings,
const gchar *key, const gchar *key,
gpointer user_data) GtkBuilder *dialog)
{ {
GtkBuilder *builder = GTK_BUILDER (user_data);
gint i; gint i;
GString *str = g_string_new (""); GString *str = g_string_new ("");
gchar **layouts = g_settings_get_strv (settings, "layouts"); gchar **layouts = g_settings_get_strv (settings, "layouts");
@ -139,7 +137,7 @@ xkb_settings_changed (GSettings *settings,
g_strfreev (layouts); g_strfreev (layouts);
gtk_label_set_text (GTK_LABEL (gtk_builder_get_object (builder, "user_input_source")), str->str); gtk_label_set_text (GTK_LABEL (WID ("user_input_source")), str->str);
g_string_free (str, TRUE); g_string_free (str, TRUE);
} }
@ -147,7 +145,7 @@ static void
on_localed_properties_changed (GDBusProxy *proxy, on_localed_properties_changed (GDBusProxy *proxy,
GVariant *changed_properties, GVariant *changed_properties,
const gchar **invalidated_properties, const gchar **invalidated_properties,
GtkBuilder *builder) GtkBuilder *dialog)
{ {
GVariant *res; GVariant *res;
GVariant *v; GVariant *v;
@ -204,7 +202,7 @@ on_localed_properties_changed (GDBusProxy *proxy,
if (messages) { if (messages) {
name = gdm_get_language_from_name (messages, NULL); name = gdm_get_language_from_name (messages, NULL);
label = (GtkWidget*)gtk_builder_get_object (builder, "system_display_language"); label = WID ("system_display_language");
gtk_label_set_text (GTK_LABEL (label), name); gtk_label_set_text (GTK_LABEL (label), name);
g_free (name); g_free (name);
g_object_set_data_full (G_OBJECT (label), "language", g_strdup (lang), g_free); g_object_set_data_full (G_OBJECT (label), "language", g_strdup (lang), g_free);
@ -212,7 +210,7 @@ on_localed_properties_changed (GDBusProxy *proxy,
if (time) { if (time) {
name = gdm_get_region_from_name (time, NULL); name = gdm_get_region_from_name (time, NULL);
label = (GtkWidget*)gtk_builder_get_object (builder, "system_format"); label = WID ("system_format");
gtk_label_set_text (GTK_LABEL (label), name); gtk_label_set_text (GTK_LABEL (label), name);
g_free (name); g_free (name);
g_object_set_data_full (G_OBJECT (label), "region", g_strdup (time), g_free); g_object_set_data_full (G_OBJECT (label), "region", g_strdup (time), g_free);
@ -221,15 +219,14 @@ on_localed_properties_changed (GDBusProxy *proxy,
} }
g_variant_unref (res); g_variant_unref (res);
update_copy_button (builder); update_copy_button (dialog);
} }
static void static void
localed_proxy_ready (GObject *source, localed_proxy_ready (GObject *source,
GAsyncResult *res, GAsyncResult *res,
gpointer user_data) GtkBuilder *dialog)
{ {
GtkBuilder *builder = user_data;
GError *error = NULL; GError *error = NULL;
localed_proxy = g_dbus_proxy_new_finish (res, &error); localed_proxy = g_dbus_proxy_new_finish (res, &error);
@ -240,16 +237,16 @@ localed_proxy_ready (GObject *source,
return; return;
} }
g_object_weak_ref (G_OBJECT (builder), (GWeakNotify) g_object_unref, localed_proxy); g_object_weak_ref (G_OBJECT (dialog), (GWeakNotify) g_object_unref, localed_proxy);
g_signal_connect (localed_proxy, "g-properties-changed", g_signal_connect (localed_proxy, "g-properties-changed",
G_CALLBACK (on_localed_properties_changed), builder); G_CALLBACK (on_localed_properties_changed), dialog);
on_localed_properties_changed (localed_proxy, NULL, NULL, builder); on_localed_properties_changed (localed_proxy, NULL, NULL, dialog);
} }
static void static void
copy_settings (GtkButton *button, GtkBuilder *builder) copy_settings (GtkButton *button, GtkBuilder *dialog)
{ {
const gchar *language; const gchar *language;
const gchar *region; const gchar *region;
@ -257,9 +254,9 @@ copy_settings (GtkButton *button, GtkBuilder *builder)
GVariantBuilder *b; GVariantBuilder *b;
gchar *s; gchar *s;
label = GTK_WIDGET (gtk_builder_get_object (builder, "user_display_language")); label = WID ("user_display_language");
language = g_object_get_data (G_OBJECT (label), "language"); language = g_object_get_data (G_OBJECT (label), "language");
label = GTK_WIDGET (gtk_builder_get_object (builder, "user_format")); label = WID ("user_format");
region = g_object_get_data (G_OBJECT (label), "region"); region = g_object_get_data (G_OBJECT (label), "region");
b = g_variant_builder_new (G_VARIANT_TYPE ("as")); b = g_variant_builder_new (G_VARIANT_TYPE ("as"));
@ -292,7 +289,7 @@ copy_settings (GtkButton *button, GtkBuilder *builder)
static void static void
on_permission_changed (GPermission *permission, on_permission_changed (GPermission *permission,
GParamSpec *pspec, GParamSpec *pspec,
GtkBuilder *builder) GtkBuilder *dialog)
{ {
GtkWidget *button; GtkWidget *button;
GtkWidget *label; GtkWidget *label;
@ -308,8 +305,8 @@ on_permission_changed (GPermission *permission,
allowed = FALSE; allowed = FALSE;
} }
button = (GtkWidget *)gtk_builder_get_object (builder, "copy_settings_button"); button = WID ("copy_settings_button");
label = (GtkWidget *)gtk_builder_get_object (builder, "system-title"); label = WID ("system-title");
if (!allowed && !can_acquire) { if (!allowed && !can_acquire) {
gtk_label_set_text (GTK_LABEL (label), gtk_label_set_text (GTK_LABEL (label),
@ -330,43 +327,45 @@ on_permission_changed (GPermission *permission,
} }
void void
setup_system (GtkBuilder *builder) setup_system (GtkBuilder *dialog)
{ {
gchar *language; gchar *language;
GDBusConnection *bus; GDBusConnection *bus;
GtkWidget *button; GtkWidget *button;
button = (GtkWidget *)gtk_builder_get_object (builder, "copy_settings_button");
g_signal_connect (button, "clicked",
G_CALLBACK (copy_settings), builder);
localed_permission = polkit_permission_new_sync ("org.freedesktop.locale1.set-locale", NULL, NULL, NULL); localed_permission = polkit_permission_new_sync ("org.freedesktop.locale1.set-locale", NULL, NULL, NULL);
if (localed_permission != NULL) { if (localed_permission != NULL) {
g_object_weak_ref (G_OBJECT (builder), (GWeakNotify) g_object_unref, localed_permission); g_object_weak_ref (G_OBJECT (dialog), (GWeakNotify) g_object_unref, localed_permission);
g_signal_connect (localed_permission, "notify", g_signal_connect (localed_permission, "notify",
G_CALLBACK (on_permission_changed), builder); G_CALLBACK (on_permission_changed), dialog);
} }
on_permission_changed (localed_permission, NULL, builder); on_permission_changed (localed_permission, NULL, dialog);
locale_settings = g_settings_new ("org.gnome.system.locale");
g_signal_connect (locale_settings, "changed::region", button = WID ("copy_settings_button");
G_CALLBACK (locale_settings_changed), builder); g_signal_connect (button, "clicked",
g_object_weak_ref (G_OBJECT (builder), (GWeakNotify) g_object_unref, locale_settings); G_CALLBACK (copy_settings), dialog);
locale_settings = g_settings_new ("org.gnome.system.locale");
g_signal_connect (locale_settings, "changed::region",
G_CALLBACK (locale_settings_changed), dialog);
g_object_weak_ref (G_OBJECT (dialog), (GWeakNotify) g_object_unref, locale_settings);
xkb_settings = g_settings_new (GKBD_KEYBOARD_SCHEMA); xkb_settings = g_settings_new (GKBD_KEYBOARD_SCHEMA);
g_signal_connect (xkb_settings, "changed::layouts", g_signal_connect (xkb_settings, "changed::layouts",
G_CALLBACK (xkb_settings_changed), builder); G_CALLBACK (xkb_settings_changed), dialog);
g_object_weak_ref (G_OBJECT (builder), (GWeakNotify) g_object_unref, xkb_settings); g_object_weak_ref (G_OBJECT (dialog), (GWeakNotify) g_object_unref, xkb_settings);
/* Display user settings */ /* Display user settings */
language = cc_common_language_get_current_language (); language = cc_common_language_get_current_language ();
system_update_language (builder, language); system_update_language (dialog, language);
g_free (language); g_free (language);
locale_settings_changed (locale_settings, "region", builder); locale_settings_changed (locale_settings, "region", dialog);
xkb_settings_changed (xkb_settings, "layouts", builder); xkb_settings_changed (xkb_settings, "layouts", dialog);
bus = g_bus_get_sync (G_BUS_TYPE_SYSTEM, NULL, NULL); bus = g_bus_get_sync (G_BUS_TYPE_SYSTEM, NULL, NULL);
g_dbus_proxy_new (bus, g_dbus_proxy_new (bus,
@ -376,7 +375,7 @@ setup_system (GtkBuilder *builder)
"/org/freedesktop/locale1", "/org/freedesktop/locale1",
"org.freedesktop.locale1", "org.freedesktop.locale1",
NULL, NULL,
localed_proxy_ready, (GAsyncReadyCallback) localed_proxy_ready,
builder); dialog);
g_object_unref (bus); g_object_unref (bus);
} }