aboutsummaryrefslogtreecommitdiffstats
path: root/gtk/prefs_dlg.c
diff options
context:
space:
mode:
authorlego <lego@f5534014-38df-0310-8fa8-9805f1628bb7>2007-02-03 14:25:02 +0000
committerlego <lego@f5534014-38df-0310-8fa8-9805f1628bb7>2007-02-03 14:25:02 +0000
commita38ac2221a5a470ca9bbcdff0bb289d2fa870247 (patch)
tree683c63d63061635121c0893a08d8320a910299da /gtk/prefs_dlg.c
parent5304b157dc7a8d1e6e9481aed348bbf803d11ecc (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.c46
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: