diff options
author | Gerald Combs <gerald@wireshark.org> | 2002-04-22 02:03:53 +0000 |
---|---|---|
committer | Gerald Combs <gerald@wireshark.org> | 2002-04-22 02:03:53 +0000 |
commit | c64fb4b223f715d97eaf03c5862761913d840619 (patch) | |
tree | b01ef460a11e64835fc372fc74606b170fa724de /gtk/column_prefs.c | |
parent | 14caf2a9a558281fac7d4321e79e44aed17d0998 (diff) |
Polish the column prefs a bit. Make the column tile entry and format
menu modify the currently-selected item directly. Remove the "Change"
button since it's no longer needed. Make the column list a clist, and
add a column which shows the format. Make the format option menu not
fill the entire table cell. Update the man page accordingly.
svn path=/trunk/; revision=5214
Diffstat (limited to 'gtk/column_prefs.c')
-rw-r--r-- | gtk/column_prefs.c | 340 |
1 files changed, 179 insertions, 161 deletions
diff --git a/gtk/column_prefs.c b/gtk/column_prefs.c index bca6f9b0a2..fa11a4d3c3 100644 --- a/gtk/column_prefs.c +++ b/gtk/column_prefs.c @@ -1,7 +1,7 @@ /* column_prefs.c * Dialog box for column preferences * - * $Id: column_prefs.c,v 1.8 2002/03/05 11:55:58 guy Exp $ + * $Id: column_prefs.c,v 1.9 2002/04/22 02:03:53 gerald Exp $ * * Ethereal - Network traffic analyzer * By Gerald Combs <gerald@ethereal.com> @@ -38,17 +38,19 @@ static GtkWidget *column_l, *chg_bt, *del_bt, *title_te, *fmt_m, *up_bt, *dn_bt; -static gint cur_fmt; +static gint cur_fmt, cur_row; -static void column_sel_list_cb(GtkWidget *, gpointer); -static void column_sel_new_cb(GtkWidget *, gpointer); -static void column_sel_chg_cb(GtkWidget *, gpointer); -static void column_sel_del_cb(GtkWidget *, gpointer); -static void column_sel_arrow_cb(GtkWidget *, gpointer); -static void column_set_fmt_cb(GtkWidget *, gpointer); +static void column_list_select_cb(GtkCList *clist, gint row, gint column, + GdkEvent *event, gpointer user_data); +static void column_list_unselect_cb(GtkCList *clist, gint row, gint column, + GdkEvent *event, gpointer user_data); +static void column_list_new_cb(GtkWidget *, gpointer); +static void column_entry_changed_cb(GtkEditable *, gpointer); +static void column_menu_changed_cb(GtkWidget *, gpointer); +static void column_list_delete_cb(GtkWidget *, gpointer); +static void column_arrow_cb(GtkWidget *, gpointer); +void column_set_arrow_button_sensitivity(GList *); -#define E_COL_NAME_KEY "column_name" -#define E_COL_LBL_KEY "column_label" #define E_COL_CM_KEY "in_col_cancel_mode" /* Create and display the column selection widgets. */ @@ -59,7 +61,8 @@ column_prefs_show() { *nl_lb, *tb, *lb, *menu, *mitem, *arrow_hb; GList *clp = NULL; fmt_data *cfmt; - gint i; + gint i, row; + gchar *column_titles[] = {"Title", "Format"}, *col_ent[2]; /* Container for each row of widgets */ main_vb = gtk_vbox_new(FALSE, 5); @@ -77,23 +80,16 @@ column_prefs_show() { gtk_container_add(GTK_CONTAINER(top_hb), list_bb); gtk_widget_show(list_bb); - new_bt = gtk_button_new_with_label ("New"); + new_bt = gtk_button_new_with_label ("Add New"); gtk_signal_connect(GTK_OBJECT(new_bt), "clicked", - GTK_SIGNAL_FUNC(column_sel_new_cb), NULL); + GTK_SIGNAL_FUNC(column_list_new_cb), NULL); gtk_container_add(GTK_CONTAINER(list_bb), new_bt); gtk_widget_show(new_bt); - chg_bt = gtk_button_new_with_label ("Change"); - gtk_widget_set_sensitive(chg_bt, FALSE); - gtk_signal_connect(GTK_OBJECT(chg_bt), "clicked", - GTK_SIGNAL_FUNC(column_sel_chg_cb), NULL); - gtk_container_add(GTK_CONTAINER(list_bb), chg_bt); - gtk_widget_show(chg_bt); - del_bt = gtk_button_new_with_label ("Delete"); gtk_widget_set_sensitive(del_bt, FALSE); gtk_signal_connect(GTK_OBJECT(del_bt), "clicked", - GTK_SIGNAL_FUNC(column_sel_del_cb), NULL); + GTK_SIGNAL_FUNC(column_list_delete_cb), NULL); gtk_container_add(GTK_CONTAINER(list_bb), del_bt); gtk_widget_show(del_bt); @@ -104,14 +100,14 @@ column_prefs_show() { up_bt = gtk_button_new_with_label("Up"); gtk_widget_set_sensitive(up_bt, FALSE); gtk_signal_connect(GTK_OBJECT(up_bt), "clicked", - GTK_SIGNAL_FUNC(column_sel_arrow_cb), NULL); + GTK_SIGNAL_FUNC(column_arrow_cb), NULL); gtk_box_pack_start(GTK_BOX(arrow_hb), up_bt, TRUE, TRUE, 0); gtk_widget_show(up_bt); dn_bt = gtk_button_new_with_label("Down"); gtk_widget_set_sensitive(dn_bt, FALSE); gtk_signal_connect(GTK_OBJECT(dn_bt), "clicked", - GTK_SIGNAL_FUNC(column_sel_arrow_cb), NULL); + GTK_SIGNAL_FUNC(column_arrow_cb), NULL); gtk_box_pack_start(GTK_BOX(arrow_hb), dn_bt, TRUE, TRUE, 0); gtk_widget_show(dn_bt); @@ -122,26 +118,28 @@ column_prefs_show() { gtk_container_add(GTK_CONTAINER(top_hb), column_sc); gtk_widget_show(column_sc); - column_l = gtk_list_new(); - gtk_list_set_selection_mode(GTK_LIST(column_l), GTK_SELECTION_SINGLE); - gtk_signal_connect(GTK_OBJECT(column_l), "selection_changed", - GTK_SIGNAL_FUNC(column_sel_list_cb), main_vb); + column_l = gtk_clist_new_with_titles(2, column_titles); + /* XXX - make this match the packet list prefs? */ + gtk_clist_set_selection_mode(GTK_CLIST(column_l), GTK_SELECTION_SINGLE); + gtk_clist_column_titles_passive(GTK_CLIST(column_l)); + gtk_clist_column_titles_show(GTK_CLIST(column_l)); + gtk_clist_set_column_auto_resize(GTK_CLIST(column_l), 0, TRUE); + gtk_clist_set_column_auto_resize(GTK_CLIST(column_l), 1, TRUE); + + gtk_signal_connect(GTK_OBJECT(column_l), "select-row", + GTK_SIGNAL_FUNC(column_list_select_cb), NULL); + gtk_signal_connect(GTK_OBJECT(column_l), "unselect-row", + GTK_SIGNAL_FUNC(column_list_unselect_cb), NULL); gtk_scrolled_window_add_with_viewport(GTK_SCROLLED_WINDOW(column_sc), column_l); gtk_widget_show(column_l); clp = g_list_first(prefs.col_list); while (clp) { cfmt = (fmt_data *) clp->data; - nl_lb = gtk_label_new(cfmt->title); - nl_item = gtk_list_item_new(); - gtk_misc_set_alignment (GTK_MISC (nl_lb), 0.0, 0.5); - gtk_container_add(GTK_CONTAINER(nl_item), nl_lb); - gtk_widget_show(nl_lb); - gtk_container_add(GTK_CONTAINER(column_l), nl_item); - gtk_widget_show(nl_item); - gtk_object_set_data(GTK_OBJECT(nl_item), E_COL_LBL_KEY, nl_lb); - gtk_object_set_data(GTK_OBJECT(nl_item), E_COL_NAME_KEY, clp); - + col_ent[0] = cfmt->title; + col_ent[1] = col_format_desc(get_column_format_from_str(cfmt->fmt)); + row = gtk_clist_append(GTK_CLIST(column_l), col_ent); + gtk_clist_set_row_data(GTK_CLIST(column_l), row, clp); clp = clp->next; } @@ -159,6 +157,9 @@ column_prefs_show() { title_te = gtk_entry_new(); gtk_table_attach_defaults(GTK_TABLE(tb), title_te, 1, 2, 0, 1); + gtk_signal_connect(GTK_OBJECT(title_te), "changed", + GTK_SIGNAL_FUNC(column_entry_changed_cb), column_l); + gtk_widget_set_sensitive(title_te, FALSE); gtk_widget_show(title_te); lb = gtk_label_new("Column format:"); @@ -166,178 +167,195 @@ column_prefs_show() { gtk_table_attach_defaults(GTK_TABLE(tb), lb, 0, 1, 1, 2); gtk_widget_show(lb); + top_hb = gtk_hbox_new(FALSE, 5); + gtk_table_attach(GTK_TABLE(tb), top_hb, 1, 2, 1, 2, GTK_FILL, GTK_SHRINK, 0, 0); + gtk_widget_show(top_hb); + fmt_m = gtk_option_menu_new(); menu = gtk_menu_new(); for (i = 0; i < NUM_COL_FMTS; i++) { mitem = gtk_menu_item_new_with_label(col_format_desc(i)); gtk_menu_append(GTK_MENU(menu), mitem); gtk_signal_connect( GTK_OBJECT(mitem), "activate", - GTK_SIGNAL_FUNC(column_set_fmt_cb), (gpointer) i); + GTK_SIGNAL_FUNC(column_menu_changed_cb), (gpointer) i); gtk_widget_show(mitem); } gtk_option_menu_set_menu(GTK_OPTION_MENU(fmt_m), menu); cur_fmt = 0; gtk_option_menu_set_history(GTK_OPTION_MENU(fmt_m), cur_fmt); - gtk_table_attach_defaults(GTK_TABLE(tb), fmt_m, 1, 2, 1, 2); + gtk_widget_set_sensitive(fmt_m, FALSE); + gtk_box_pack_start(GTK_BOX(top_hb), fmt_m, FALSE, FALSE, 0); gtk_widget_show(fmt_m); - + return(main_vb); } +/* For each selection, set the entry and option menu widgets to match + the currently selected item. Set the up/down button sensitivity. + Draw focus to the entry widget. */ static void -column_sel_list_cb(GtkWidget *l, gpointer data) { +column_list_select_cb(GtkCList *clist, + gint row, + gint column _U_, + GdkEvent *event _U_, + gpointer user_data _U_) { fmt_data *cfmt; - gchar *title = ""; - GList *sl, *clp; - GtkObject *l_item; - gint sensitivity = FALSE, up_sens = FALSE, dn_sens = FALSE; - - sl = GTK_LIST(l)->selection; - - if (sl) { /* Something was selected */ - l_item = GTK_OBJECT(sl->data); - clp = (GList *) gtk_object_get_data(l_item, E_COL_NAME_KEY); - if (clp) { - cfmt = (fmt_data *) clp->data; - title = cfmt->title; - cur_fmt = get_column_format_from_str(cfmt->fmt); - g_assert(cur_fmt != -1); /* It should always be valid */ - gtk_option_menu_set_history(GTK_OPTION_MENU(fmt_m), cur_fmt); - sensitivity = TRUE; - if (clp != g_list_first(prefs.col_list)) - up_sens = TRUE; - if (clp != g_list_last(prefs.col_list)) - dn_sens = TRUE; - } - } + GList *clp; + + clp = gtk_clist_get_row_data(clist, row); + g_assert(clp != NULL); + cfmt = (fmt_data *) clp->data; + cur_fmt = get_column_format_from_str(cfmt->fmt); + g_assert(cur_fmt != -1); /* It should always be valid */ + cur_row = row; - /* Did you know that this function is called when the window is destroyed? */ - /* Funny, that. */ - if (!gtk_object_get_data(GTK_OBJECT(data), E_COL_CM_KEY)) { - gtk_entry_set_text(GTK_ENTRY(title_te), title); - gtk_widget_set_sensitive(chg_bt, sensitivity); - gtk_widget_set_sensitive(del_bt, sensitivity); - gtk_widget_set_sensitive(up_bt, up_sens); - gtk_widget_set_sensitive(dn_bt, dn_sens); - } + gtk_entry_set_text(GTK_ENTRY(title_te), cfmt->title); + gtk_editable_select_region(GTK_EDITABLE(title_te), 0, -1); + gtk_widget_grab_focus(title_te); + + gtk_option_menu_set_history(GTK_OPTION_MENU(fmt_m), cur_fmt); + + gtk_widget_set_sensitive(del_bt, TRUE); + gtk_widget_set_sensitive(title_te, TRUE); + gtk_widget_set_sensitive(fmt_m, TRUE); + column_set_arrow_button_sensitivity(clp); +} + +/* A row was deselected. Clear the text entry box and disable various widgets. */ +static void +column_list_unselect_cb(GtkCList *clist _U_, + gint row, + gint column _U_, + GdkEvent *event _U_, + gpointer user_data _U_) { + + cur_row = -1; + gtk_editable_delete_text(GTK_EDITABLE(title_te), 0, -1); + + gtk_widget_set_sensitive(del_bt, FALSE); + gtk_widget_set_sensitive(title_te, FALSE); + gtk_widget_set_sensitive(fmt_m, FALSE); + gtk_widget_set_sensitive(up_bt, FALSE); + gtk_widget_set_sensitive(dn_bt, FALSE); } /* To do: add input checking to each of these callbacks */ static void -column_sel_new_cb(GtkWidget *w _U_, gpointer data _U_) { +column_list_new_cb(GtkWidget *w _U_, gpointer data _U_) { fmt_data *cfmt; - gchar *title; - GtkWidget *nl_item, *nl_lb; + gchar *title = "New Column", *col_ent[2]; - title = gtk_entry_get_text(GTK_ENTRY(title_te)); - - if (strlen(title) > 0) { - cfmt = (fmt_data *) g_malloc(sizeof(fmt_data)); - cfmt->title = g_strdup(title); - cfmt->fmt = g_strdup(col_format_to_string(cur_fmt)); - prefs.col_list = g_list_append(prefs.col_list, cfmt); - nl_lb = gtk_label_new(cfmt->title); - nl_item = gtk_list_item_new(); - gtk_misc_set_alignment (GTK_MISC (nl_lb), 0.0, 0.5); - gtk_container_add(GTK_CONTAINER(nl_item), nl_lb); - gtk_widget_show(nl_lb); - gtk_container_add(GTK_CONTAINER(column_l), nl_item); - gtk_widget_show(nl_item); - gtk_object_set_data(GTK_OBJECT(nl_item), E_COL_LBL_KEY, nl_lb); - gtk_object_set_data(GTK_OBJECT(nl_item), E_COL_NAME_KEY, - g_list_last(prefs.col_list)); - gtk_list_select_child(GTK_LIST(column_l), nl_item); - } + cur_fmt = 0; + cfmt = (fmt_data *) g_malloc(sizeof(fmt_data)); + cfmt->title = g_strdup(title); + cfmt->fmt = g_strdup(col_format_to_string(cur_fmt)); + prefs.col_list = g_list_append(prefs.col_list, cfmt); + + col_ent[0] = title; + col_ent[1] = col_format_desc(cur_fmt); + cur_row = gtk_clist_append(GTK_CLIST(column_l), col_ent); + gtk_clist_set_row_data(GTK_CLIST(column_l), cur_row, g_list_last(prefs.col_list)); + + gtk_clist_select_row(GTK_CLIST(column_l), cur_row, 0); } static void -column_sel_chg_cb(GtkWidget *w _U_, gpointer data _U_) { - fmt_data *cfmt; - gchar *title = ""; +column_list_delete_cb(GtkWidget *w _U_, gpointer data _U_) { GList *sl, *clp; + fmt_data *cfmt; GtkObject *l_item; - GtkLabel *nl_lb; - - sl = GTK_LIST(column_l)->selection; - title = gtk_entry_get_text(GTK_ENTRY(title_te)); - - if (sl) { /* Something was selected */ - l_item = GTK_OBJECT(sl->data); - clp = (GList *) gtk_object_get_data(l_item, E_COL_NAME_KEY); - nl_lb = (GtkLabel *) gtk_object_get_data(l_item, E_COL_LBL_KEY); - if (clp && nl_lb) { - cfmt = (fmt_data *) clp->data; - - if (strlen(title) > 0 && cfmt) { - g_free(cfmt->title); - g_free(cfmt->fmt); - cfmt->title = g_strdup(title); - cfmt->fmt = g_strdup(col_format_to_string(cur_fmt)); - gtk_label_set(nl_lb, cfmt->title); - } - } + gint pos; + + g_assert(cur_row >= 0); + clp = gtk_clist_get_row_data(GTK_CLIST(column_l), cur_row); + + cfmt = (fmt_data *) clp->data; + g_free(cfmt->title); + g_free(cfmt->fmt); + g_free(cfmt); + prefs.col_list = g_list_remove_link(prefs.col_list, clp); + + gtk_clist_remove(GTK_CLIST(column_l), cur_row); +} + +/* The user changed the column title entry box. */ +static void +column_entry_changed_cb(GtkEditable *te, gpointer data) { + fmt_data *cfmt; + GList *clp; + GtkCList *cl = data; + gchar *title; + gint row; + + if (cur_row >= 0) { + title = gtk_editable_get_chars(te, 0, -1); + clp = gtk_clist_get_row_data(cl, cur_row); + cfmt = (fmt_data *) clp->data; + + gtk_clist_set_text(cl, cur_row, 0, title); + g_free(cfmt->title); + cfmt->title = title; } } +/* The user changed the format menu. */ static void -column_sel_del_cb(GtkWidget *w _U_, gpointer data _U_) { - GList *sl, *clp; +column_menu_changed_cb(GtkWidget *w _U_, gpointer data) { fmt_data *cfmt; - GtkObject *l_item; - gint pos; + GList *clp; + gint row; - sl = GTK_LIST(column_l)->selection; - if (sl) { /* Something was selected */ - l_item = GTK_OBJECT(sl->data); - pos = gtk_list_child_position(GTK_LIST(column_l), GTK_WIDGET(l_item)); - clp = (GList *) gtk_object_get_data(l_item, E_COL_NAME_KEY); - if (clp) { - cfmt = (fmt_data *) clp->data; - g_free(cfmt->title); - g_free(cfmt->fmt); - g_free(cfmt); - prefs.col_list = g_list_remove_link(prefs.col_list, clp); - gtk_list_clear_items(GTK_LIST(column_l), pos, pos + 1); - } + if (cur_row >= 0) { + cur_fmt = (gint) data; + clp = gtk_clist_get_row_data(GTK_CLIST(column_l), cur_row); + cfmt = (fmt_data *) clp->data; + + gtk_clist_set_text(GTK_CLIST(column_l), cur_row, 1, col_format_desc(cur_fmt)); + g_free(cfmt->fmt); + cfmt->fmt = g_strdup(col_format_to_string(cur_fmt)); } } static void -column_sel_arrow_cb(GtkWidget *w, gpointer data _U_) { - GList *sl, *clp, *il; +column_arrow_cb(GtkWidget *w, gpointer data _U_) { + GList *clp; fmt_data *cfmt; - GtkObject *l_item; - gint pos, inc = 1; + gint inc = 1; + g_assert(cur_row >= 0); + if (w == up_bt) inc = -1; - sl = GTK_LIST(column_l)->selection; - if (sl) { /* Something was selected */ - l_item = GTK_OBJECT(sl->data); - pos = gtk_list_child_position(GTK_LIST(column_l), GTK_WIDGET(l_item)); - clp = (GList *) gtk_object_get_data(l_item, E_COL_NAME_KEY); - if (clp) { - cfmt = (fmt_data *) clp->data; - prefs.col_list = g_list_remove(prefs.col_list, cfmt); - g_list_insert(prefs.col_list, cfmt, pos + inc); - il = (GList *) g_malloc(sizeof(GList)); - il->next = NULL; - il->prev = NULL; - il->data = l_item; - gtk_widget_ref(GTK_WIDGET(l_item)); - gtk_list_clear_items(GTK_LIST(column_l), pos, pos + 1); - gtk_list_insert_items(GTK_LIST(column_l), il, pos + inc); - gtk_widget_unref(GTK_WIDGET(l_item)); - gtk_list_select_item(GTK_LIST(column_l), pos + inc); - } - } + /* This would end up appending to the list. We shouldn't have to check for + appending past the end of the list. */ + g_assert((cur_row + inc) >= 0); + + clp = gtk_clist_get_row_data(GTK_CLIST(column_l), cur_row); + cfmt = (fmt_data *) clp->data; + prefs.col_list = g_list_remove(prefs.col_list, cfmt); + prefs.col_list = g_list_insert(prefs.col_list, cfmt, cur_row + inc); + + gtk_clist_row_move(GTK_CLIST(column_l), cur_row, cur_row + inc); + clp = g_list_find(prefs.col_list, cfmt); + cur_row += inc; + gtk_clist_set_row_data(GTK_CLIST(column_l), cur_row, clp); + + column_set_arrow_button_sensitivity(clp); } void -column_set_fmt_cb(GtkWidget *w _U_, gpointer data) { - cur_fmt = (gint) data; +column_set_arrow_button_sensitivity(GList *clp) { + gint up_sens = FALSE, dn_sens = FALSE; + + if (clp != g_list_first(prefs.col_list)) + up_sens = TRUE; + if (clp != g_list_last(prefs.col_list)) + dn_sens = TRUE; + + gtk_widget_set_sensitive(up_bt, up_sens); + gtk_widget_set_sensitive(dn_bt, dn_sens); } void |