diff options
author | lego <lego@f5534014-38df-0310-8fa8-9805f1628bb7> | 2007-02-03 14:25:02 +0000 |
---|---|---|
committer | lego <lego@f5534014-38df-0310-8fa8-9805f1628bb7> | 2007-02-03 14:25:02 +0000 |
commit | a38ac2221a5a470ca9bbcdff0bb289d2fa870247 (patch) | |
tree | 683c63d63061635121c0893a08d8320a910299da /gtk/prefs_dlg.c | |
parent | 5304b157dc7a8d1e6e9481aed348bbf803d11ecc (diff) |
second iteration:
* fields of an uat table now are passed using an array of uat_filed_t
* field callbacks take two more userdata arguments
* add some macros to define uat field callbacks.
* uats can be registered as preferences for a specific protocol
- the preference widget is a button that opens the uat's window
* dfilter-macro => reflect changes to API
git-svn-id: http://anonsvn.wireshark.org/wireshark/trunk@20695 f5534014-38df-0310-8fa8-9805f1628bb7
Diffstat (limited to 'gtk/prefs_dlg.c')
-rw-r--r-- | gtk/prefs_dlg.c | 46 |
1 files changed, 45 insertions, 1 deletions
diff --git a/gtk/prefs_dlg.c b/gtk/prefs_dlg.c index 890462c08f..da16a45ed5 100644 --- a/gtk/prefs_dlg.c +++ b/gtk/prefs_dlg.c @@ -51,6 +51,7 @@ #include "compat_macros.h" #include "help_dlg.h" #include "keys.h" +#include "uat_gui.h" #include <epan/prefs-int.h> @@ -77,6 +78,8 @@ static void prefs_tree_select_cb(GtkCTree *, GtkCTreeNode *, gint, #else static void prefs_tree_select_cb(GtkTreeSelection *, gpointer); #endif +static GtkWidget* create_preference_uat(GtkWidget*, int, const gchar*, const gchar *, void*); + #define E_PREFSW_SCROLLW_KEY "prefsw_scrollw" #define E_PREFSW_TREE_KEY "prefsw_tree" @@ -237,6 +240,14 @@ pref_show(pref_t *pref, gpointer user_data) break; } + case PREF_UAT: + { + pref->control = create_preference_uat(main_tb, pref->ordinal, + label_string, pref->description, + pref->varp.uat); + break; + } + case PREF_OBSOLETE: g_assert_not_reached(); break; @@ -940,6 +951,35 @@ create_preference_static_text(GtkWidget *main_tb, int table_position, return label; } +static GtkWidget * +create_preference_uat(GtkWidget *main_tb, + int table_position, + const gchar *label_text, + const gchar *tooltip_text, + void* uat) +{ + GtkTooltips *tooltips; + GtkWidget *button = NULL; + + tooltips = OBJECT_GET_DATA(main_tb, E_TOOLTIPS_KEY); + + set_option_label(main_tb, table_position, label_text, tooltip_text, + tooltips); + + button = BUTTON_NEW_FROM_STOCK(WIRESHARK_STOCK_EDIT); + + SIGNAL_CONNECT(button, "clicked", uat_window_cb, uat); + + gtk_table_attach_defaults(GTK_TABLE(main_tb), button, 1, 2, + table_position, table_position+1); + if (tooltip_text != NULL && tooltips != NULL) + gtk_tooltips_set_tip(tooltips, button, tooltip_text, NULL); + gtk_widget_show(button); + + return button; +} + + static guint pref_check(pref_t *pref, gpointer user_data) { @@ -987,7 +1027,8 @@ pref_check(pref_t *pref, gpointer user_data) } break; - case PREF_STATIC_TEXT: + case PREF_STATIC_TEXT: + case PREF_UAT: /* Value can't be bad. */ break; @@ -1090,6 +1131,7 @@ pref_fetch(pref_t *pref, gpointer user_data) } case PREF_STATIC_TEXT: + case PREF_UAT: break; case PREF_OBSOLETE: @@ -1208,6 +1250,7 @@ pref_clean(pref_t *pref, gpointer user_data _U_) break; case PREF_STATIC_TEXT: + case PREF_UAT: break; case PREF_OBSOLETE: @@ -1541,6 +1584,7 @@ pref_revert(pref_t *pref, gpointer user_data) break; case PREF_STATIC_TEXT: + case PREF_UAT: break; case PREF_OBSOLETE: |