Added an option to limit the list to match the current display filter.

svn path=/trunk/; revision=25281
This commit is contained in:
Stig Bjørlykke 2008-05-12 22:45:08 +00:00
parent 20186d4947
commit 355dfa770d
1 changed files with 47 additions and 4 deletions

View File

@ -98,6 +98,7 @@ typedef struct wlan_ep {
static GtkWidget *wlanstat_dlg_w = NULL;
static GtkWidget *wlanstat_pane = NULL;
static GtkWidget *wlanstat_name_lb = NULL;
/* used to keep track of the statistics for an entire program interface */
typedef struct _wlan_stat_t {
@ -109,6 +110,7 @@ typedef struct _wlan_stat_t {
guint32 num_entries;
guint32 num_details;
gboolean resolve_names;
gboolean use_dfilter;
gboolean show_only_existing;
address selected_bssid;
gboolean selected_bssid_valid;
@ -136,14 +138,38 @@ wlanstat_reset (void *phs)
wlanstat_t* wlan_stat = (wlanstat_t *)phs;
wlan_ep_t* list = wlan_stat->ep_list;
wlan_ep_t* tmp = NULL;
char title[256];
GString *error_string;
const char *filter = NULL;
if (wlanstat_dlg_w != NULL) {
char title[256];
g_snprintf (title, 255, "Wireshark: WLAN Traffic Statistics: %s",
cf_get_display_name(&cfile));
gtk_window_set_title(GTK_WINDOW(wlanstat_dlg_w), title);
}
if (wlan_stat->use_dfilter) {
filter = gtk_entry_get_text(GTK_ENTRY(main_display_filter_widget));
}
error_string = set_tap_dfilter (wlan_stat, filter);
if (error_string) {
simple_dialog(ESD_TYPE_ERROR, ESD_BTN_OK, error_string->str);
g_string_free(error_string, TRUE);
return;
}
if (wlan_stat->use_dfilter) {
if (filter && strlen(filter)) {
g_snprintf(title, 255, "WLAN Traffic Statistics - Filter: %s", filter);
} else {
g_snprintf(title, 255, "WLAN Traffic Statistics - No Filter");
}
} else {
g_snprintf(title, 255, "WLAN Traffic Statistics");
}
gtk_label_set_text(GTK_LABEL(wlanstat_name_lb), title);
/* remove all entries from the clist */
gtk_clist_clear (GTK_CLIST(wlan_stat->table));
gtk_clist_clear (GTK_CLIST(wlan_stat->details));
@ -710,6 +736,16 @@ wlan_resolve_toggle_dest(GtkWidget *widget, gpointer data)
wlanstat_draw(hs);
}
static void
wlan_filter_toggle_dest(GtkWidget *widget, gpointer data)
{
wlanstat_t *hs = (wlanstat_t *)data;
hs->use_dfilter = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON (widget));
cf_retap_packets(&cfile, FALSE);
}
static void
wlan_existing_toggle_dest(GtkWidget *widget, gpointer data)
{
@ -1099,12 +1135,12 @@ wlanstat_dlg_create (void)
{
wlanstat_t *hs;
GString *error_string;
GtkWidget *top_label;
GtkWidget *scrolled_window;
GtkWidget *bbox;
GtkWidget *vbox;
GtkWidget *hbox;
GtkWidget *resolv_cb;
GtkWidget *filter_cb;
GtkWidget *existing_cb;
GtkWidget *close_bt;
GtkWidget *help_bt;
@ -1120,6 +1156,7 @@ wlanstat_dlg_create (void)
hs->ep_list = NULL;
hs->number_of_packets = 0;
hs->resolve_names = TRUE;
hs->use_dfilter = FALSE;
hs->show_only_existing = FALSE;
g_snprintf (title, 255, "Wireshark: WLAN Traffic Statistics: %s",
@ -1131,8 +1168,8 @@ wlanstat_dlg_create (void)
gtk_container_add(GTK_CONTAINER(wlanstat_dlg_w), vbox);
gtk_container_set_border_width (GTK_CONTAINER(vbox), 12);
top_label = gtk_label_new ("WLAN Traffic Statistics");
gtk_box_pack_start (GTK_BOX (vbox), top_label, FALSE, FALSE, 0);
wlanstat_name_lb = gtk_label_new ("WLAN Traffic Statistics");
gtk_box_pack_start (GTK_BOX (vbox), wlanstat_name_lb, FALSE, FALSE, 0);
wlanstat_pane = gtk_vpaned_new();
gtk_box_pack_start (GTK_BOX (vbox), wlanstat_pane, TRUE, TRUE, 0);
@ -1257,6 +1294,12 @@ wlanstat_dlg_create (void)
g_signal_connect(resolv_cb, "toggled", G_CALLBACK(wlan_resolve_toggle_dest), hs);
filter_cb = gtk_check_button_new_with_mnemonic("Limit to display filter");
gtk_container_add(GTK_CONTAINER(hbox), filter_cb);
gtk_toggle_button_set_state(GTK_TOGGLE_BUTTON(filter_cb), FALSE);
gtk_tooltips_set_tip(tooltips, filter_cb, "Limit the list to entries matching the current display filter.", NULL);
g_signal_connect(filter_cb, "toggled", G_CALLBACK(wlan_filter_toggle_dest), hs);
existing_cb = gtk_check_button_new_with_mnemonic("Only show existing networks");
gtk_container_add(GTK_CONTAINER(hbox), existing_cb);
gtk_toggle_button_set_state(GTK_TOGGLE_BUTTON(existing_cb), FALSE);