diff options
author | Gerald Combs <gerald@wireshark.org> | 1998-10-12 01:40:57 +0000 |
---|---|---|
committer | Gerald Combs <gerald@wireshark.org> | 1998-10-12 01:40:57 +0000 |
commit | 0758da11466778cbd377fade6142bbe7c19ceecd (patch) | |
tree | f57ee7de708d072038153022c1ccbd9afa448651 /prefs.c | |
parent | 73e19611fdb5a6b70951c140c0831c72f04beb5c (diff) |
- Added match_strval function to packet.c
- Separated display and capture filters; rearranged some of the look and feel
- Lots of other miscellaneous fixes and updates
svn path=/trunk/; revision=38
Diffstat (limited to 'prefs.c')
-rw-r--r-- | prefs.c | 48 |
1 files changed, 28 insertions, 20 deletions
@@ -1,7 +1,7 @@ /* prefs.c * Routines for handling preferences * - * $Id: prefs.c,v 1.4 1998/10/10 03:32:18 gerald Exp $ + * $Id: prefs.c,v 1.5 1998/10/12 01:40:55 gerald Exp $ * * Ethereal - Network traffic analyzer * By Gerald Combs <gerald@zing.org> @@ -42,22 +42,20 @@ extern capture_file cf; -const gchar *print_page_key = "printer_options_page"; -const gchar *filter_page_key = "filter_options_page"; - void -prefs_cb() { +prefs_cb(GtkWidget *w, gpointer sp) { GtkWidget *prefs_w, *main_vb, *top_hb, *bbox, *prefs_nb, *ok_bt, *save_bt, *cancel_bt; GtkWidget *print_pg, *filter_pg; GtkWidget *nlabel, *label; + gint start_page = (gint) sp; prefs_w = gtk_window_new(GTK_WINDOW_TOPLEVEL); gtk_window_set_title(GTK_WINDOW(prefs_w), "Ethereal: Preferences"); /* Container for each row of widgets */ - main_vb = gtk_vbox_new(FALSE, 3); -/* gtk_container_border_width(GTK_CONTAINER(main_vb), 5); */ + main_vb = gtk_vbox_new(FALSE, 5); + gtk_container_border_width(GTK_CONTAINER(main_vb), 5); gtk_container_add(GTK_CONTAINER(prefs_w), main_vb); gtk_widget_show(main_vb); @@ -71,71 +69,81 @@ prefs_cb() { gtk_widget_show(prefs_nb); /* General prefs */ - nlabel = gtk_label_new("Nothing here yet..."); +/* nlabel = gtk_label_new("Nothing here yet..."); gtk_widget_show (nlabel); label = gtk_label_new ("General"); gtk_notebook_append_page (GTK_NOTEBOOK(prefs_nb), nlabel, label); - + */ /* Printing prefs */ print_pg = printer_prefs_show(); - gtk_object_set_data(GTK_OBJECT(prefs_w), print_page_key, print_pg); + gtk_object_set_data(GTK_OBJECT(prefs_w), E_PRINT_PAGE_KEY, print_pg); label = gtk_label_new ("Printing"); gtk_notebook_append_page (GTK_NOTEBOOK(prefs_nb), print_pg, label); /* Filter prefs */ filter_pg = filter_prefs_show(); - gtk_object_set_data(GTK_OBJECT(prefs_w), filter_page_key, filter_pg); + /* Pass along the entry widget pointer from the calling widget */ + gtk_object_set_data(GTK_OBJECT(filter_pg), E_FILT_TE_PTR_KEY, + gtk_object_get_data(GTK_OBJECT(w), E_FILT_TE_PTR_KEY)); + gtk_object_set_data(GTK_OBJECT(prefs_w), E_FILTER_PAGE_KEY, filter_pg); label = gtk_label_new ("Filters"); gtk_notebook_append_page (GTK_NOTEBOOK(prefs_nb), filter_pg, label); + + /* Jump to the specified page, if it was supplied */ + if (start_page > E_PR_PG_NONE) + gtk_notebook_set_page(GTK_NOTEBOOK(prefs_nb), start_page); /* Button row: OK and cancel buttons */ bbox = gtk_hbutton_box_new(); gtk_button_box_set_layout (GTK_BUTTON_BOX (bbox), GTK_BUTTONBOX_END); + gtk_button_box_set_spacing(GTK_BUTTON_BOX(bbox), 5); gtk_container_add(GTK_CONTAINER(main_vb), bbox); gtk_widget_show(bbox); ok_bt = gtk_button_new_with_label ("OK"); gtk_signal_connect_object(GTK_OBJECT(ok_bt), "clicked", GTK_SIGNAL_FUNC(prefs_main_ok_cb), GTK_OBJECT(prefs_w)); - gtk_container_add(GTK_CONTAINER(bbox), ok_bt); GTK_WIDGET_SET_FLAGS(ok_bt, GTK_CAN_DEFAULT); + gtk_box_pack_start (GTK_BOX (bbox), ok_bt, TRUE, TRUE, 0); gtk_widget_grab_default(ok_bt); gtk_widget_show(ok_bt); save_bt = gtk_button_new_with_label ("Save"); gtk_signal_connect_object(GTK_OBJECT(save_bt), "clicked", GTK_SIGNAL_FUNC(prefs_main_save_cb), GTK_OBJECT(prefs_w)); - gtk_container_add(GTK_CONTAINER(bbox), save_bt); + GTK_WIDGET_SET_FLAGS(save_bt, GTK_CAN_DEFAULT); + gtk_box_pack_start (GTK_BOX (bbox), save_bt, TRUE, TRUE, 0); gtk_widget_show(save_bt); cancel_bt = gtk_button_new_with_label ("Cancel"); gtk_signal_connect_object(GTK_OBJECT(cancel_bt), "clicked", GTK_SIGNAL_FUNC(prefs_main_cancel_cb), GTK_OBJECT(prefs_w)); - gtk_container_add(GTK_CONTAINER(bbox), cancel_bt); + GTK_WIDGET_SET_FLAGS(cancel_bt, GTK_CAN_DEFAULT); + gtk_box_pack_start (GTK_BOX (bbox), cancel_bt, TRUE, TRUE, 0); gtk_widget_show(cancel_bt); - + gtk_widget_show(prefs_w); } void prefs_main_ok_cb(GtkWidget *w, gpointer win) { - printer_prefs_ok(gtk_object_get_data(GTK_OBJECT(win), print_page_key)); - filter_prefs_ok(gtk_object_get_data(GTK_OBJECT(win), filter_page_key)); + printer_prefs_ok(gtk_object_get_data(GTK_OBJECT(win), E_PRINT_PAGE_KEY)); + filter_prefs_ok(gtk_object_get_data(GTK_OBJECT(win), E_FILTER_PAGE_KEY)); gtk_widget_destroy(GTK_WIDGET(win)); } void prefs_main_save_cb(GtkWidget *w, gpointer win) { - filter_prefs_save(gtk_object_get_data(GTK_OBJECT(win), filter_page_key)); + filter_prefs_save(gtk_object_get_data(GTK_OBJECT(win), E_FILTER_PAGE_KEY)); } void prefs_main_cancel_cb(GtkWidget *w, gpointer win) { - printer_prefs_cancel(gtk_object_get_data(GTK_OBJECT(win), print_page_key)); - filter_prefs_cancel(gtk_object_get_data(GTK_OBJECT(win), filter_page_key)); + printer_prefs_cancel(gtk_object_get_data(GTK_OBJECT(win), E_PRINT_PAGE_KEY)); + filter_prefs_cancel(gtk_object_get_data(GTK_OBJECT(win), E_FILTER_PAGE_KEY)); gtk_widget_destroy(GTK_WIDGET(win)); } |