gnome-control-center r9193 - trunk/capplets/keyboard
- From: svu svn gnome org
- To: svn-commits-list gnome org
- Subject: gnome-control-center r9193 - trunk/capplets/keyboard
- Date: Sat, 10 Jan 2009 01:57:31 +0000 (UTC)
Author: svu
Date: Sat Jan 10 01:57:31 2009
New Revision: 9193
URL: http://svn.gnome.org/viewvc/gnome-control-center?rev=9193&view=rev
Log:
sort options by description
Modified:
trunk/capplets/keyboard/ChangeLog
trunk/capplets/keyboard/gnome-keyboard-properties-xkbot.c
Modified: trunk/capplets/keyboard/gnome-keyboard-properties-xkbot.c
==============================================================================
--- trunk/capplets/keyboard/gnome-keyboard-properties-xkbot.c (original)
+++ trunk/capplets/keyboard/gnome-keyboard-properties-xkbot.c Sat Jan 10 01:57:31 2009
@@ -37,8 +37,9 @@
static GladeXML *chooser_dialog = NULL;
static const char *current1st_level_id = NULL;
-static GtkWidget *current_vbox = NULL;
+static GSList *option_checks_list = NULL;
static GtkWidget *current_none_radio = NULL;
+static GtkWidget *current_expander = NULL;
static gboolean current_multi_select = FALSE;
static GSList *current_radio_group = NULL;
@@ -70,51 +71,49 @@
return retval;
}
-static GtkWidget *
-xkb_options_get_expander (GtkWidget * option_button)
-{
- return
- gtk_widget_get_parent (gtk_widget_get_parent
- (gtk_widget_get_parent
- (option_button)));
-}
-
+/* Returns the selection counter of the expander (static current_expander) */
static int
-xkb_options_expander_selcounter_get (GtkWidget * expander)
+xkb_options_expander_selcounter_get (void)
{
return
GPOINTER_TO_INT (g_object_get_data
- (G_OBJECT (expander), SELCOUNTER_PROP));
+ (G_OBJECT (current_expander),
+ SELCOUNTER_PROP));
}
+/* Increments the selection counter in the expander (static current_expander)
+ using the value (can be 0)*/
static void
-xkb_options_expander_selcounter_add (GtkWidget * expander, int value)
+xkb_options_expander_selcounter_add (int value)
{
- g_object_set_data (G_OBJECT (expander), SELCOUNTER_PROP,
+ g_object_set_data (G_OBJECT (current_expander), SELCOUNTER_PROP,
GINT_TO_POINTER
- (xkb_options_expander_selcounter_get (expander)
+ (xkb_options_expander_selcounter_get ()
+ value));
}
+/* Resets the seletion counter in the expander (static current_expander) */
static void
-xkb_options_expander_selcounter_reset (GtkWidget * expander)
+xkb_options_expander_selcounter_reset (void)
{
- g_object_set_data (G_OBJECT (expander), SELCOUNTER_PROP,
+ g_object_set_data (G_OBJECT (current_expander), SELCOUNTER_PROP,
GINT_TO_POINTER (0));
}
+/* Formats the expander (static current_expander), based on the selection counter */
static void
-xkb_options_expander_highlight (GtkWidget * expander)
+xkb_options_expander_highlight (void)
{
char *utf_group_name =
- g_object_get_data (G_OBJECT (expander), "utfGroupName");
- int counter = xkb_options_expander_selcounter_get (expander);
+ g_object_get_data (G_OBJECT (current_expander),
+ "utfGroupName");
+ int counter = xkb_options_expander_selcounter_get ();
if (utf_group_name != NULL) {
gchar *titlemarkup =
g_strconcat (counter >
0 ? "<span weight=\"bold\">" : "<span>",
utf_group_name, "</span>", NULL);
- gtk_expander_set_label (GTK_EXPANDER (expander),
+ gtk_expander_set_label (GTK_EXPANDER (current_expander),
titlemarkup);
g_free (titlemarkup);
}
@@ -181,14 +180,16 @@
/* Make sure selected options stay visible when navigating with the keyboard */
static gboolean
-option_focused_cb (GtkWidget *widget, GdkEventFocus *event, gpointer data)
+option_focused_cb (GtkWidget * widget, GdkEventFocus * event,
+ gpointer data)
{
GtkScrolledWindow *win = GTK_SCROLLED_WINDOW (data);
GtkAllocation *alloc = &widget->allocation;
GtkAdjustment *adj;
adj = gtk_scrolled_window_get_vadjustment (win);
- gtk_adjustment_clamp_page (adj, alloc->y, alloc->y + alloc->height);
+ gtk_adjustment_clamp_page (adj, alloc->y,
+ alloc->y + alloc->height);
return FALSE;
}
@@ -235,9 +236,14 @@
gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON
(option_check),
TRUE);
- gtk_box_pack_start_defaults (GTK_BOX
- (current_vbox),
- option_check);
+ /* Make option name underscore -
+ to enforce its first position in the list */
+ g_object_set_data_full (G_OBJECT (option_check),
+ "utfOptionName",
+ g_strdup ("_"), g_free);
+ option_checks_list =
+ g_slist_append (option_checks_list,
+ option_check);
current_radio_group =
gtk_radio_button_get_group (GTK_RADIO_BUTTON
(option_check));
@@ -256,7 +262,6 @@
g_object_set_data (G_OBJECT (option_check), "NoneRadio",
current_none_radio);
}
- g_free (utf_option_name);
initial_state = xkb_options_is_selected (full_option_name);
@@ -265,30 +270,41 @@
g_object_set_data_full (G_OBJECT (option_check), OPTION_ID_PROP,
full_option_name, g_free);
+ g_object_set_data_full (G_OBJECT (option_check), "utfOptionName",
+ utf_option_name, g_free);
g_signal_connect (option_check, "toggled",
G_CALLBACK (option_toggled_cb), NULL);
+ option_checks_list =
+ g_slist_append (option_checks_list, option_check);
+
g_signal_connect (option_check, "focus-in-event",
G_CALLBACK (option_focused_cb),
WID ("options_scroll"));
- gtk_box_pack_start_defaults (GTK_BOX (current_vbox), option_check);
-
- xkb_options_expander_selcounter_add (xkb_options_get_expander
- (option_check),
- initial_state);
+ xkb_options_expander_selcounter_add (initial_state);
g_object_set_data (G_OBJECT (option_check), GCONFSTATE_PROP,
GINT_TO_POINTER (initial_state));
}
+static gint
+xkb_option_checks_compare (GtkWidget * chk1, GtkWidget * chk2)
+{
+ const gchar *t1 =
+ g_object_get_data (G_OBJECT (chk1), "utfOptionName");
+ const gchar *t2 =
+ g_object_get_data (G_OBJECT (chk2), "utfOptionName");
+ return g_utf8_collate (t1, t2);
+}
+
/* Add a group of options: create title and layout widgets and then
add widgets for all the options in the group. */
static void
xkb_options_add_group (XklConfigRegistry * config_registry,
XklConfigItem * config_item, GladeXML * dialog)
{
- GtkWidget *expander, *align, *vbox;
+ GtkWidget *align, *vbox, *option_check;
gboolean allow_multiple_selection =
GPOINTER_TO_INT (g_object_get_data (G_OBJECT (config_item),
XCI_PROP_ALLOW_MULTIPLE_SELECTION));
@@ -300,11 +316,12 @@
gchar *titlemarkup =
g_strconcat ("<span>", utf_group_name, "</span>", NULL);
- expander = gtk_expander_new (titlemarkup);
- gtk_expander_set_use_markup (GTK_EXPANDER (expander), TRUE);
- g_object_set_data_full (G_OBJECT (expander), "utfGroupName",
- utf_group_name, g_free);
- g_object_set_data_full (G_OBJECT (expander), "groupId",
+ current_expander = gtk_expander_new (titlemarkup);
+ gtk_expander_set_use_markup (GTK_EXPANDER (current_expander),
+ TRUE);
+ g_object_set_data_full (G_OBJECT (current_expander),
+ "utfGroupName", utf_group_name, g_free);
+ g_object_set_data_full (G_OBJECT (current_expander), "groupId",
g_strdup (config_item->name), g_free);
g_free (titlemarkup);
@@ -312,26 +329,36 @@
gtk_alignment_set_padding (GTK_ALIGNMENT (align), 6, 12, 12, 0);
vbox = gtk_vbox_new (TRUE, 6);
gtk_container_add (GTK_CONTAINER (align), vbox);
- gtk_container_add (GTK_CONTAINER (expander), align);
- current_vbox = vbox;
+ gtk_container_add (GTK_CONTAINER (current_expander), align);
current_multi_select = (gboolean) allow_multiple_selection;
current_radio_group = NULL;
-
current1st_level_id = config_item->name;
+
+ option_checks_list = NULL;
+
xkl_config_registry_foreach_option (config_registry,
config_item->name,
(ConfigItemProcessFunc)
xkb_options_add_option,
dialog);
+ /* sort it */
+ option_checks_list =
+ g_slist_sort (option_checks_list,
+ (GCompareFunc) xkb_option_checks_compare);
+ while (option_checks_list) {
+ option_check = GTK_WIDGET (option_checks_list->data);
+ gtk_box_pack_start_defaults (GTK_BOX (vbox), option_check);
+ option_checks_list = option_checks_list->next;
+ }
- xkb_options_expander_highlight (expander);
+ xkb_options_expander_highlight ();
- expanders_list = g_slist_append (expanders_list, expander);
+ expanders_list = g_slist_append (expanders_list, current_expander);
g_object_set_data (G_OBJECT (dialog), EXPANDERS_PROP,
expanders_list);
- g_signal_connect (expander, "focus-in-event",
+ g_signal_connect (current_expander, "focus-in-event",
G_CALLBACK (option_focused_cb),
WID ("options_scroll"));
}
@@ -356,7 +383,6 @@
GtkWidget *expander;
current1st_level_id = NULL;
- current_vbox = NULL;
current_none_radio = NULL;
current_multi_select = FALSE;
current_radio_group = NULL;
@@ -426,15 +452,14 @@
/* Update selected option counters for a group-bound expander */
static void
xkb_options_update_option_counters (XklConfigRegistry * config_registry,
- XklConfigItem * config_item,
- GtkWidget * expander)
+ XklConfigItem * config_item)
{
gchar *full_option_name =
g_strdup (gkbd_keyboard_config_merge_items
(current1st_level_id, config_item->name));
gboolean current_state =
xkb_options_is_selected (full_option_name);
- xkb_options_expander_selcounter_add (expander, current_state);
+ xkb_options_expander_selcounter_add (current_state);
}
/* Respond to a change in the xkb gconf settings */
@@ -452,18 +477,19 @@
g_object_get_data (G_OBJECT (chooser_dialog),
EXPANDERS_PROP);
while (expanders_list) {
- GtkWidget *expander =
+ current_expander =
GTK_WIDGET (expanders_list->data);
gchar *group_id =
- g_object_get_data (G_OBJECT (expander),
+ g_object_get_data (G_OBJECT (current_expander),
"groupId");
current1st_level_id = group_id;
- xkb_options_expander_selcounter_reset (expander);
+ xkb_options_expander_selcounter_reset ();
xkl_config_registry_foreach_option
(config_registry, group_id,
(ConfigItemProcessFunc)
- xkb_options_update_option_counters, expander);
- xkb_options_expander_highlight (expander);
+ xkb_options_update_option_counters,
+ current_expander);
+ xkb_options_expander_highlight ();
expanders_list = expanders_list->next;
}
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]