aboutsummaryrefslogtreecommitdiffstats
path: root/e-util
diff options
context:
space:
mode:
Diffstat (limited to 'e-util')
-rw-r--r--e-util/ChangeLog18
-rw-r--r--e-util/e-dialog-widgets.c113
2 files changed, 43 insertions, 88 deletions
diff --git a/e-util/ChangeLog b/e-util/ChangeLog
index 519b62cb7b..9c0a9deb65 100644
--- a/e-util/ChangeLog
+++ b/e-util/ChangeLog
@@ -1,3 +1,21 @@
+2000-05-30 Federico Mena Quintero <federico@helixcode.com>
+
+ * e-dialog-widgets.c (hook_radio): Use the exported function to
+ set the value.
+ (get_radio_value): Likewise.
+ (hook_option_menu): Likewise.
+ (get_option_menu_value): Likewise.
+ (hook_toggle): Likewise.
+ (get_toggle_value): Likewise.
+ (hook_spin_button): Likewise.
+ (get_spin_button_value): Likewise.
+ (hook_editable): Likewise.
+ (get_editable_value): Likewise.
+ (e_dialog_radio_set): Radio buttons are prepended to their parent
+ group's list, so we need to flip the index around when
+ getting/setting the value.
+ (e_dialog_radio_get): Likewise.
+
2000-05-27 Federico Mena Quintero <federico@helixcode.com>
* e-dialog-widgets.c (e_dialog_editable_set): Moved over from
diff --git a/e-util/e-dialog-widgets.c b/e-util/e-dialog-widgets.c
index 98099a1891..d4a50e0cd7 100644
--- a/e-util/e-dialog-widgets.c
+++ b/e-util/e-dialog-widgets.c
@@ -136,10 +136,9 @@ static void
hook_radio (GtkWidget *dialog, GtkRadioButton *radio, gpointer value_var, gpointer info)
{
GSList *group;
+ GSList *l;
int *value;
- int i;
const int *value_map;
- GSList *l;
group = gtk_radio_button_group (radio);
@@ -148,15 +147,7 @@ hook_radio (GtkWidget *dialog, GtkRadioButton *radio, gpointer value_var, gpoint
value = (int *) value_var;
value_map = (const int *) info;
- i = value_to_index (value_map, *value);
- if (i != -1) {
- l = g_slist_nth (group, i);
- if (!l)
- g_message ("hook_radio(): could not find index %d in radio group!", i);
-
- gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (l->data), TRUE);
- } else
- g_message ("hook_radio(): could not find value %d in value map!", *value);
+ e_dialog_radio_set (GTK_WIDGET (radio), *value, value_map);
/* Hook to changed */
@@ -170,35 +161,13 @@ hook_radio (GtkWidget *dialog, GtkRadioButton *radio, gpointer value_var, gpoint
static void
get_radio_value (GtkRadioButton *radio, gpointer value_var, gpointer info)
{
- GSList *group;
- GSList *l;
- int i;
int *value;
const int *value_map;
- int v;
-
- group = gtk_radio_button_group (radio);
-
- for (i = 0, l = group; l; l = l->next) {
- radio = GTK_RADIO_BUTTON (l->data);
-
- if (GTK_TOGGLE_BUTTON (radio)->active)
- break;
- }
-
- if (!l)
- g_assert_not_reached ();
value = (int *) value_var;
value_map = (const int *) info;
- v = index_to_value (value_map, i);
- if (v == -1) {
- g_message ("get_radio_value(): could not find index %d in value map!", i);
- return;
- }
-
- *value = v;
+ *value = e_dialog_radio_get (GTK_WIDGET (radio), value_map);
}
/* Callback for the "activate" signal of menu items */
@@ -216,7 +185,6 @@ static void
hook_option_menu (GtkWidget *dialog, GtkOptionMenu *omenu, gpointer value_var, gpointer info)
{
int *value;
- int i;
const int *value_map;
/* Set the value */
@@ -224,11 +192,7 @@ hook_option_menu (GtkWidget *dialog, GtkOptionMenu *omenu, gpointer value_var, g
value = (int *) value_var;
value_map = (const int *) info;
- i = value_to_index (value_map, *value);
- if (i != -1)
- gtk_option_menu_set_history (omenu, i);
- else
- g_message ("hook_option_menu(): could not find value %d in value map!", *value);
+ e_dialog_option_menu_set (GTK_WIDGET (omenu), *value, value_map);
/* Hook to changed */
@@ -248,40 +212,13 @@ hook_option_menu (GtkWidget *dialog, GtkOptionMenu *omenu, gpointer value_var, g
static void
get_option_menu_value (GtkOptionMenu *omenu, gpointer value_var, gpointer info)
{
- GtkMenu *menu;
- GtkWidget *active;
- GList *children;
- GList *l;
- int i;
int *value;
const int *value_map;
- int v;
-
- menu = GTK_MENU (gtk_option_menu_get_menu (omenu));
-
- active = gtk_menu_get_active (menu);
- g_assert (active != NULL);
-
- children = GTK_MENU_SHELL (menu)->children;
-
- for (i = 0, l = children; l; l = l->next) {
- if (GTK_WIDGET (l->data) == active)
- break;
- }
-
- if (!l)
- g_assert_not_reached ();
value = (int *) value_var;
value_map = (const int *) info;
- v = index_to_value (value_map, i);
- if (v == -1) {
- g_message ("get_option_menu_value(): could not find index %d in value map!", i);
- return;
- }
-
- *value = v;
+ *value = e_dialog_option_menu_get (GTK_WIDGET (omenu), value_map);
}
/* Hooks a toggle button */
@@ -293,7 +230,7 @@ hook_toggle (GtkWidget *dialog, GtkToggleButton *toggle, gpointer value_var, gpo
/* Set the value */
value = (gboolean *) value_var;
- gtk_toggle_button_set_active (toggle, *value);
+ e_dialog_toggle_set (GTK_WIDGET (toggle), *value);
/* Hook to changed */
@@ -309,7 +246,7 @@ get_toggle_value (GtkToggleButton *toggle, gpointer value_var, gpointer info)
gboolean *value;
value = (gboolean *) value;
- *value = toggle->active ? TRUE : FALSE;
+ *value = e_dialog_toggle_get (GTK_WIDGET (toggle));
}
/* Callback for the "value_changed" signal of the adjustment of a spin button */
@@ -332,13 +269,12 @@ hook_spin_button (GtkWidget *dialog, GtkSpinButton *spin, gpointer value_var, gp
/* Set the value */
value = (double *) value_var;
- adj = gtk_spin_button_get_adjustment (spin);
-
- adj->value = *value;
- gtk_signal_emit_by_name (GTK_OBJECT (adj), "value_changed");
+ e_dialog_spin_set (GTK_WIDGET (spin), *value);
/* Hook to changed */
+ adj = gtk_spin_button_get_adjustment (spin);
+
if (GNOME_IS_PROPERTY_BOX (dialog))
gtk_signal_connect (GTK_OBJECT (adj), "value_changed",
GTK_SIGNAL_FUNC (value_changed_cb), dialog);
@@ -349,12 +285,9 @@ static void
get_spin_button_value (GtkSpinButton *spin, gpointer value_var, gpointer info)
{
double *value;
- GtkAdjustment *adj;
value = (double *) value_var;
-
- adj = gtk_spin_button_get_adjustment (spin);
- *value = adj->value;
+ *value = e_dialog_spin_get_double (GTK_WIDGET (spin));
}
/* Callback for the "changed" signal of a GtkEditable widget */
@@ -372,18 +305,12 @@ static void
hook_editable (GtkWidget *dialog, GtkEditable *editable, gpointer value_var, gpointer info)
{
char **value;
- gint pos;
/* Set the value */
value = (char **) value_var;
- pos = 0;
- gtk_editable_delete_text (editable, 0, -1);
-
- /* Take NULL as empty string */
- if (*value)
- gtk_editable_insert_text (editable, *value, strlen (*value), &pos);
+ e_dialog_editable_set (GTK_WIDGET (editable), *value);
/* Hook to changed */
@@ -402,7 +329,7 @@ get_editable_value (GtkEditable *editable, gpointer value_var, gpointer data)
if (*value)
g_free (*value);
- *value = gtk_editable_get_chars (editable, 0, -1);
+ *value = e_dialog_editable_get (GTK_WIDGET (editable));
}
void
@@ -445,6 +372,11 @@ e_dialog_radio_set (GtkWidget *widget, int value, const int *value_map)
i = value_to_index (value_map, value);
if (i != -1) {
+ /* Groups are built by prepending items, so the list ends up in reverse
+ * order; we need to flip the index around.
+ */
+ i = g_slist_length (group) - i - 1;
+
l = g_slist_nth (group, i);
if (!l)
g_message ("e_dialog_radio_set(): could not find index %d in radio group!",
@@ -470,7 +402,7 @@ e_dialog_radio_get (GtkWidget *widget, const int *value_map)
group = gtk_radio_button_group (GTK_RADIO_BUTTON (widget));
- for (i = 0, l = group; l; l = l->next) {
+ for (i = 0, l = group; l; l = l->next, i++) {
widget = GTK_WIDGET (l->data);
if (GTK_TOGGLE_BUTTON (widget)->active)
@@ -480,6 +412,11 @@ e_dialog_radio_get (GtkWidget *widget, const int *value_map)
if (!l)
g_assert_not_reached ();
+ /* Groups are built by prepending items, so the list ends up in reverse
+ * order; we need to flip the index around.
+ */
+ i = g_slist_length (group) - i - 1;
+
v = index_to_value (value_map, i);
if (v == -1) {
g_message ("e_dialog_radio_get(): could not find index %d in value map!", i);
@@ -584,7 +521,7 @@ e_dialog_option_menu_get (GtkWidget *widget, const int *value_map)
children = GTK_MENU_SHELL (menu)->children;
- for (i = 0, l = children; l; l = l->next) {
+ for (i = 0, l = children; l; l = l->next, i++) {
if (GTK_WIDGET (l->data) == active)
break;
}