2006-02-04 19:56:50 +00:00
|
|
|
/*
|
|
|
|
* funnel_stat.c
|
|
|
|
*
|
|
|
|
* EPAN's funneled GUI mini-API
|
|
|
|
*
|
|
|
|
* (c) 2006, Luis E. Garcia Ontanon <luis.ontanon@gmail.com>
|
2006-02-06 01:27:05 +00:00
|
|
|
*
|
2006-02-04 22:44:31 +00:00
|
|
|
* $Id$
|
2006-02-04 19:56:50 +00:00
|
|
|
*
|
2006-05-21 05:12:17 +00:00
|
|
|
* Wireshark - Network traffic analyzer
|
|
|
|
* By Gerald Combs <gerald@wireshark.org>
|
2006-02-04 19:56:50 +00:00
|
|
|
* Copyright 1998 Gerald Combs
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation; either version 2
|
|
|
|
* of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
|
|
*/
|
|
|
|
|
2006-02-06 01:27:05 +00:00
|
|
|
/*
|
2006-05-22 07:29:40 +00:00
|
|
|
* Most of the code here has been harvested from other Wireshark gtk modules.
|
2006-02-06 01:27:05 +00:00
|
|
|
* most from prefs_dlg.c and about_dlg.c
|
|
|
|
*/
|
|
|
|
|
2006-02-04 19:56:50 +00:00
|
|
|
#ifdef HAVE_CONFIG_H
|
|
|
|
# include "config.h"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef HAVE_SYS_TYPES_H
|
|
|
|
# include <sys/types.h>
|
|
|
|
#endif
|
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
#include <gtk/gtk.h>
|
|
|
|
|
2008-04-13 01:54:20 +00:00
|
|
|
#include <epan/prefs.h>
|
|
|
|
#include <epan/funnel.h>
|
|
|
|
|
2006-02-04 19:56:50 +00:00
|
|
|
#include "../register.h"
|
|
|
|
#include "../timestats.h"
|
|
|
|
#include "../simple_dialog.h"
|
|
|
|
#include "../file.h"
|
|
|
|
#include "../globals.h"
|
|
|
|
#include "../stat_menu.h"
|
2008-04-13 01:54:20 +00:00
|
|
|
#include "../file.h"
|
2006-02-04 19:56:50 +00:00
|
|
|
|
2008-04-13 01:54:20 +00:00
|
|
|
#include "gtk/gui_utils.h"
|
|
|
|
#include "gtk/dlg_utils.h"
|
|
|
|
#include "gtk/tap_dfilter_dlg.h"
|
|
|
|
#include "gtk/font_utils.h"
|
|
|
|
#include "gtk/gui_stat_menu.h"
|
|
|
|
#include "gtk/prefs_dlg.h"
|
|
|
|
#include "gtk/main.h"
|
|
|
|
#include "gtk/webbrowser.h"
|
|
|
|
#include "gtk/gtkglobals.h"
|
2006-02-04 19:56:50 +00:00
|
|
|
|
|
|
|
|
|
|
|
struct _funnel_text_window_t {
|
|
|
|
GtkWidget* win;
|
|
|
|
GtkWidget* txt;
|
2006-03-30 19:42:49 +00:00
|
|
|
GtkWidget* button_hbox;
|
2006-02-05 20:02:41 +00:00
|
|
|
GtkWidget* bt_close;
|
|
|
|
text_win_close_cb_t close_cb;
|
|
|
|
void* close_data;
|
2006-10-04 18:45:26 +00:00
|
|
|
GPtrArray* buttons;
|
2006-02-04 19:56:50 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
struct _funnel_tree_window_t {
|
|
|
|
GtkWidget *win;
|
|
|
|
|
|
|
|
};
|
2006-02-04 20:26:36 +00:00
|
|
|
|
|
|
|
struct _funnel_node_t {
|
|
|
|
void* dummy;
|
|
|
|
};
|
|
|
|
|
2006-02-04 19:56:50 +00:00
|
|
|
static void text_window_cancel_button_cb(GtkWidget *bt _U_, gpointer data) {
|
|
|
|
funnel_text_window_t* tw = data;
|
|
|
|
|
2006-02-05 20:02:41 +00:00
|
|
|
window_destroy(GTK_WIDGET(tw->win));
|
|
|
|
tw->win = NULL;
|
|
|
|
|
2006-02-06 01:27:05 +00:00
|
|
|
if (tw->close_cb)
|
|
|
|
tw->close_cb(tw->close_data);
|
2006-02-05 20:02:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void unref_text_win_cancel_bt_cb(GtkWidget *bt _U_, gpointer data) {
|
|
|
|
funnel_text_window_t* tw = data;
|
2006-10-04 18:45:26 +00:00
|
|
|
unsigned i;
|
|
|
|
|
2006-02-04 19:56:50 +00:00
|
|
|
window_destroy(GTK_WIDGET(tw->win));
|
|
|
|
tw->win = NULL;
|
|
|
|
|
2006-02-06 01:27:05 +00:00
|
|
|
if (tw->close_cb)
|
|
|
|
tw->close_cb(tw->close_data);
|
|
|
|
|
2006-10-04 18:45:26 +00:00
|
|
|
for (i = 0; i < tw->buttons->len; i++) {
|
|
|
|
funnel_bt_t* cbd = g_ptr_array_index(tw->buttons,i);
|
|
|
|
/* XXX a free cb should be passed somehow */
|
2006-10-05 16:25:13 +00:00
|
|
|
if (cbd->data && cbd->free_data) cbd->free_data(cbd->data);
|
|
|
|
if (cbd->free) cbd->free(cbd);
|
2006-10-04 18:45:26 +00:00
|
|
|
}
|
|
|
|
g_ptr_array_free(tw->buttons,TRUE);
|
2006-02-06 01:27:05 +00:00
|
|
|
g_free(tw);
|
|
|
|
}
|
|
|
|
|
2006-03-30 19:42:49 +00:00
|
|
|
|
2006-02-06 01:27:05 +00:00
|
|
|
static gboolean text_window_unref_del_event_cb(GtkWidget *win _U_, GdkEvent *event _U_, gpointer user_data) {
|
|
|
|
funnel_text_window_t* tw = user_data;
|
2006-10-04 18:45:26 +00:00
|
|
|
unsigned i;
|
2006-02-06 01:27:05 +00:00
|
|
|
|
|
|
|
window_destroy(GTK_WIDGET(tw->win));
|
|
|
|
tw->win = NULL;
|
|
|
|
|
|
|
|
if (tw->close_cb)
|
|
|
|
tw->close_cb(tw->close_data);
|
2006-02-05 20:02:41 +00:00
|
|
|
|
2006-10-04 18:45:26 +00:00
|
|
|
for (i = 0; i < tw->buttons->len; i++) {
|
|
|
|
funnel_bt_t* cbd = g_ptr_array_index(tw->buttons,i);
|
|
|
|
/* XXX a free cb should be passed somehow */
|
2006-10-05 16:25:13 +00:00
|
|
|
if (cbd->data && cbd->free_data) cbd->free_data(cbd->data);
|
|
|
|
if (cbd->free) cbd->free(cbd);
|
2006-10-04 18:45:26 +00:00
|
|
|
}
|
|
|
|
g_ptr_array_free(tw->buttons,TRUE);
|
2006-02-05 20:02:41 +00:00
|
|
|
g_free(tw);
|
|
|
|
|
2006-02-06 01:27:05 +00:00
|
|
|
return TRUE;
|
2006-02-05 20:02:41 +00:00
|
|
|
}
|
|
|
|
|
2006-02-06 01:27:05 +00:00
|
|
|
static gboolean text_window_delete_event_cb(GtkWidget *win _U_, GdkEvent *event _U_, gpointer user_data)
|
2006-02-05 20:02:41 +00:00
|
|
|
{
|
|
|
|
funnel_text_window_t* tw = user_data;
|
2006-02-06 01:27:05 +00:00
|
|
|
|
|
|
|
window_destroy(GTK_WIDGET(tw->win));
|
|
|
|
tw->win = NULL;
|
|
|
|
|
|
|
|
if (tw->close_cb)
|
|
|
|
tw->close_cb(tw->close_data);
|
|
|
|
|
2006-02-05 20:02:41 +00:00
|
|
|
return TRUE;
|
2006-02-04 19:56:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static funnel_text_window_t* new_text_window(const gchar* title) {
|
|
|
|
funnel_text_window_t* tw = g_malloc(sizeof(funnel_text_window_t));
|
2006-03-30 20:15:59 +00:00
|
|
|
GtkWidget *txt_scrollw, *main_vb, *hbox;
|
2006-02-04 19:56:50 +00:00
|
|
|
|
2006-02-06 01:27:05 +00:00
|
|
|
tw->close_cb = NULL;
|
|
|
|
tw->close_data = NULL;
|
2006-10-04 18:45:26 +00:00
|
|
|
tw->buttons = g_ptr_array_new();
|
|
|
|
|
2006-02-04 19:56:50 +00:00
|
|
|
tw->win = window_new(GTK_WINDOW_TOPLEVEL,title);
|
2008-04-11 22:10:36 +00:00
|
|
|
g_signal_connect(tw->win, "delete-event", G_CALLBACK(text_window_delete_event_cb), tw);
|
2006-02-05 20:02:41 +00:00
|
|
|
|
2006-02-04 19:56:50 +00:00
|
|
|
txt_scrollw = scrolled_window_new(NULL, NULL);
|
|
|
|
main_vb = gtk_vbox_new(FALSE, 3);
|
2006-02-06 01:27:05 +00:00
|
|
|
gtk_container_border_width(GTK_CONTAINER(main_vb), 6);
|
2006-02-04 19:56:50 +00:00
|
|
|
gtk_container_add(GTK_CONTAINER(tw->win), main_vb);
|
|
|
|
|
|
|
|
gtk_container_add(GTK_CONTAINER(main_vb), txt_scrollw);
|
|
|
|
|
|
|
|
gtk_scrolled_window_set_shadow_type(GTK_SCROLLED_WINDOW(txt_scrollw),
|
|
|
|
GTK_SHADOW_IN);
|
|
|
|
|
|
|
|
gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(txt_scrollw),
|
|
|
|
GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC);
|
|
|
|
tw->txt = gtk_text_view_new();
|
|
|
|
gtk_text_view_set_editable(GTK_TEXT_VIEW(tw->txt), FALSE);
|
|
|
|
gtk_text_view_set_wrap_mode(GTK_TEXT_VIEW(tw->txt), GTK_WRAP_WORD);
|
|
|
|
gtk_text_view_set_cursor_visible(GTK_TEXT_VIEW(tw->txt), FALSE);
|
2006-02-06 01:27:05 +00:00
|
|
|
|
|
|
|
gtk_text_view_set_left_margin(GTK_TEXT_VIEW(tw->txt), 4);
|
|
|
|
gtk_text_view_set_right_margin(GTK_TEXT_VIEW(tw->txt), 4);
|
2006-02-04 19:56:50 +00:00
|
|
|
|
2006-03-30 20:15:59 +00:00
|
|
|
hbox = gtk_hbox_new(FALSE, 0);
|
|
|
|
gtk_widget_show(hbox);
|
2006-03-30 19:42:49 +00:00
|
|
|
|
|
|
|
tw->button_hbox = gtk_hbutton_box_new();
|
|
|
|
gtk_button_box_set_layout(GTK_BUTTON_BOX(tw->button_hbox), GTK_BUTTONBOX_START);
|
|
|
|
|
2006-03-30 20:15:59 +00:00
|
|
|
gtk_box_pack_start(GTK_BOX(hbox), tw->button_hbox, TRUE, TRUE, 0);
|
2006-03-30 19:42:49 +00:00
|
|
|
gtk_widget_show(tw->button_hbox);
|
|
|
|
|
2006-03-30 20:15:59 +00:00
|
|
|
gtk_box_pack_start(GTK_BOX(main_vb), hbox, FALSE, FALSE, 0);
|
2006-03-30 19:42:49 +00:00
|
|
|
|
|
|
|
tw->bt_close = gtk_button_new_with_label("Close");
|
|
|
|
GTK_WIDGET_SET_FLAGS(tw->bt_close, GTK_CAN_DEFAULT);
|
2008-04-11 16:44:31 +00:00
|
|
|
g_object_set_data(G_OBJECT(hbox), "Close", tw->bt_close);
|
2006-03-30 19:42:49 +00:00
|
|
|
|
2006-03-30 20:15:59 +00:00
|
|
|
gtk_box_pack_end(GTK_BOX(hbox), tw->bt_close, FALSE, FALSE, 0);
|
2006-03-30 19:42:49 +00:00
|
|
|
gtk_widget_show(tw->bt_close);
|
|
|
|
|
2008-04-11 22:10:36 +00:00
|
|
|
g_signal_connect(tw->bt_close, "clicked", G_CALLBACK(text_window_cancel_button_cb), tw);
|
2006-02-05 20:02:41 +00:00
|
|
|
gtk_widget_grab_default(tw->bt_close);
|
2006-02-04 19:56:50 +00:00
|
|
|
|
2006-03-30 19:42:49 +00:00
|
|
|
gtk_container_add(GTK_CONTAINER(txt_scrollw), tw->txt);
|
2006-02-04 19:56:50 +00:00
|
|
|
gtk_window_resize(GTK_WINDOW(tw->win),400,300);
|
|
|
|
gtk_widget_show_all(tw->win);
|
|
|
|
|
|
|
|
return tw;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static void text_window_clear(funnel_text_window_t* tw)
|
|
|
|
{
|
2006-02-06 13:06:15 +00:00
|
|
|
GtkTextBuffer *buf;
|
|
|
|
|
2006-02-05 20:02:41 +00:00
|
|
|
if (! tw->win) return;
|
|
|
|
|
2006-02-06 13:06:15 +00:00
|
|
|
buf = gtk_text_view_get_buffer(GTK_TEXT_VIEW(tw->txt));
|
2006-02-04 19:56:50 +00:00
|
|
|
|
|
|
|
gtk_text_buffer_set_text(buf, "", 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static void text_window_append(funnel_text_window_t* tw, const char *str)
|
|
|
|
{
|
|
|
|
GtkWidget *txt;
|
|
|
|
int nchars = strlen(str);
|
2006-02-06 13:06:15 +00:00
|
|
|
GtkTextBuffer *buf;
|
|
|
|
GtkTextIter iter;
|
2006-02-04 19:56:50 +00:00
|
|
|
|
|
|
|
if (! tw->win) return;
|
|
|
|
|
|
|
|
txt = tw->txt;
|
|
|
|
nchars = strlen(str);
|
|
|
|
|
|
|
|
|
2006-02-06 13:06:15 +00:00
|
|
|
buf= gtk_text_view_get_buffer(GTK_TEXT_VIEW(txt));
|
2006-02-04 19:56:50 +00:00
|
|
|
|
|
|
|
gtk_text_buffer_get_end_iter(buf, &iter);
|
|
|
|
gtk_widget_modify_font(GTK_WIDGET(txt), user_font_get_regular());
|
|
|
|
|
|
|
|
if (!g_utf8_validate(str, -1, NULL))
|
|
|
|
printf("Invalid utf8 encoding: %s\n", str);
|
|
|
|
|
|
|
|
gtk_text_buffer_insert(buf, &iter, str, nchars);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static void text_window_set_text(funnel_text_window_t* tw, const gchar* text)
|
|
|
|
{
|
|
|
|
|
|
|
|
if (! tw->win) return;
|
|
|
|
|
|
|
|
text_window_clear(tw);
|
|
|
|
text_window_append(tw, text);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static void text_window_prepend(funnel_text_window_t* tw, const char *str _U_) {
|
2006-03-05 02:01:16 +00:00
|
|
|
GtkWidget *txt;
|
|
|
|
int nchars = strlen(str);
|
|
|
|
GtkTextBuffer *buf;
|
|
|
|
GtkTextIter iter;
|
|
|
|
|
2006-02-04 19:56:50 +00:00
|
|
|
if (! tw->win) return;
|
2006-03-05 02:01:16 +00:00
|
|
|
|
|
|
|
txt = tw->txt;
|
|
|
|
nchars = strlen(str);
|
|
|
|
|
|
|
|
|
|
|
|
buf= gtk_text_view_get_buffer(GTK_TEXT_VIEW(txt));
|
|
|
|
|
|
|
|
gtk_text_buffer_get_start_iter(buf, &iter);
|
|
|
|
gtk_widget_modify_font(GTK_WIDGET(txt), user_font_get_regular());
|
|
|
|
|
|
|
|
if (!g_utf8_validate(str, -1, NULL))
|
|
|
|
printf("Invalid utf8 encoding: %s\n", str);
|
|
|
|
|
|
|
|
gtk_text_buffer_insert(buf, &iter, str, nchars);
|
2006-02-04 19:56:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static const gchar* text_window_get_text(funnel_text_window_t* tw) {
|
2006-03-05 02:01:16 +00:00
|
|
|
GtkWidget *txt;
|
|
|
|
GtkTextBuffer *buf;
|
|
|
|
GtkTextIter start;
|
|
|
|
GtkTextIter end;
|
|
|
|
|
2006-02-04 19:56:50 +00:00
|
|
|
if (! tw->win) return "";
|
|
|
|
|
2006-03-05 02:01:16 +00:00
|
|
|
txt = tw->txt;
|
|
|
|
|
|
|
|
buf= gtk_text_view_get_buffer(GTK_TEXT_VIEW(txt));
|
|
|
|
gtk_text_buffer_get_start_iter(buf, &start);
|
|
|
|
gtk_text_buffer_get_end_iter(buf, &end);
|
|
|
|
|
|
|
|
return gtk_text_buffer_get_text(buf, &start, &end, FALSE);
|
2006-02-04 19:56:50 +00:00
|
|
|
}
|
|
|
|
|
2006-03-30 19:42:49 +00:00
|
|
|
|
|
|
|
|
2006-02-05 20:02:41 +00:00
|
|
|
static void text_window_set_close_cb(funnel_text_window_t* tw, text_win_close_cb_t cb, void* data) {
|
|
|
|
tw->close_cb = cb;
|
|
|
|
tw->close_data = data;
|
|
|
|
}
|
|
|
|
|
2006-02-04 19:56:50 +00:00
|
|
|
static void text_window_destroy(funnel_text_window_t* tw) {
|
|
|
|
if (tw->win) {
|
2006-02-05 20:02:41 +00:00
|
|
|
/*
|
|
|
|
* the window is still there and its callbacks refer to this data structure
|
|
|
|
* we need to change the callback so that they free tw.
|
|
|
|
*/
|
2008-04-11 22:10:36 +00:00
|
|
|
g_signal_connect(tw->bt_close, "clicked", G_CALLBACK(unref_text_win_cancel_bt_cb), tw);
|
|
|
|
g_signal_connect(tw->win, "delete-event", G_CALLBACK(text_window_unref_del_event_cb), tw);
|
2006-02-05 20:02:41 +00:00
|
|
|
} else {
|
2006-10-04 18:45:26 +00:00
|
|
|
unsigned i;
|
2006-02-05 20:02:41 +00:00
|
|
|
/*
|
|
|
|
* we have no window anymore a human user closed
|
|
|
|
* the window already just free the container
|
|
|
|
*/
|
2006-10-04 18:45:26 +00:00
|
|
|
for (i = 0; i < tw->buttons->len; i++) {
|
|
|
|
funnel_bt_t* cbd = g_ptr_array_index(tw->buttons,i);
|
|
|
|
/* XXX a free cb should be passed somehow */
|
2006-10-05 16:25:13 +00:00
|
|
|
if (cbd->data && cbd->free_data) cbd->free_data(cbd->data);
|
|
|
|
if (cbd->free) cbd->free(cbd);
|
2006-10-04 18:45:26 +00:00
|
|
|
}
|
|
|
|
g_ptr_array_free(tw->buttons,TRUE);
|
2006-02-05 20:02:41 +00:00
|
|
|
g_free(tw);
|
2006-02-04 19:56:50 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2006-03-30 19:42:49 +00:00
|
|
|
static void text_window_set_editable(funnel_text_window_t* tw, gboolean editable){
|
|
|
|
gtk_text_view_set_editable(GTK_TEXT_VIEW(tw->txt), editable);
|
|
|
|
gtk_text_view_set_cursor_visible(GTK_TEXT_VIEW(tw->txt), editable);
|
|
|
|
}
|
|
|
|
|
|
|
|
static gboolean text_window_button_cb(GtkWidget *bt _U_, gpointer user_data)
|
|
|
|
{
|
|
|
|
funnel_bt_t* cbd = user_data;
|
|
|
|
|
|
|
|
if (cbd->func) {
|
|
|
|
return cbd->func(cbd->tw,cbd->data);
|
|
|
|
} else {
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void text_window_add_button(funnel_text_window_t* tw, funnel_bt_t* cbd, const gchar* label) {
|
|
|
|
GtkWidget *button;
|
|
|
|
|
|
|
|
cbd->tw = tw;
|
2006-10-04 18:45:26 +00:00
|
|
|
g_ptr_array_add(tw->buttons,cbd);
|
2006-03-30 19:42:49 +00:00
|
|
|
|
|
|
|
button = gtk_button_new_with_label(label);
|
|
|
|
GTK_WIDGET_SET_FLAGS(button, GTK_CAN_DEFAULT);
|
|
|
|
|
|
|
|
gtk_box_pack_start(GTK_BOX(tw->button_hbox), button, FALSE, FALSE, 0);
|
|
|
|
|
|
|
|
gtk_widget_show(button);
|
2008-04-11 22:10:36 +00:00
|
|
|
g_signal_connect(button, "clicked", G_CALLBACK(text_window_button_cb), cbd);
|
2006-03-30 19:42:49 +00:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2006-02-06 01:27:05 +00:00
|
|
|
|
|
|
|
struct _funnel_dlg_data {
|
|
|
|
GtkWidget* win;
|
|
|
|
GPtrArray* entries;
|
|
|
|
funnel_dlg_cb_t dlg_cb;
|
|
|
|
void* data;
|
|
|
|
};
|
|
|
|
|
|
|
|
static gboolean funnel_dlg_cb(GtkWidget *win _U_, gpointer user_data)
|
|
|
|
{
|
|
|
|
struct _funnel_dlg_data* dd = user_data;
|
|
|
|
guint i;
|
|
|
|
guint len = dd->entries->len;
|
|
|
|
GPtrArray* returns = g_ptr_array_new();
|
|
|
|
|
|
|
|
for(i=0; i<len; i++) {
|
|
|
|
GtkEntry* entry = g_ptr_array_index(dd->entries,i);
|
|
|
|
g_ptr_array_add(returns,g_strdup(gtk_entry_get_text(entry)));
|
|
|
|
}
|
|
|
|
|
|
|
|
g_ptr_array_add(returns,NULL);
|
|
|
|
|
|
|
|
if (dd->dlg_cb)
|
|
|
|
dd->dlg_cb((gchar**)returns->pdata,dd->data);
|
|
|
|
|
|
|
|
window_destroy(GTK_WIDGET(dd->win));
|
|
|
|
|
2006-02-06 23:54:54 +00:00
|
|
|
g_ptr_array_free(returns,FALSE);
|
|
|
|
|
2006-02-06 01:27:05 +00:00
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void funnel_cancel_btn_cb(GtkWidget *bt _U_, gpointer data) {
|
|
|
|
GtkWidget* win = data;
|
|
|
|
|
|
|
|
window_destroy(GTK_WIDGET(win));
|
|
|
|
}
|
|
|
|
|
|
|
|
static void funnel_new_dialog(const gchar* title,
|
|
|
|
const gchar** fieldnames,
|
|
|
|
funnel_dlg_cb_t dlg_cb,
|
|
|
|
void* data) {
|
|
|
|
GtkWidget *win, *main_tb, *main_vb, *bbox, *bt_cancel, *bt_ok;
|
|
|
|
guint i;
|
|
|
|
const gchar* fieldname;
|
|
|
|
struct _funnel_dlg_data* dd = g_malloc(sizeof(struct _funnel_dlg_data));
|
|
|
|
|
|
|
|
dd->entries = g_ptr_array_new();
|
|
|
|
dd->dlg_cb = dlg_cb;
|
|
|
|
dd->data = data;
|
|
|
|
|
|
|
|
for (i=0;fieldnames[i];i++);
|
|
|
|
|
|
|
|
win = dlg_window_new(title);
|
|
|
|
|
|
|
|
dd->win = win;
|
|
|
|
|
|
|
|
gtk_window_resize(GTK_WINDOW(win),400,10*(i+2));
|
|
|
|
|
|
|
|
main_vb = gtk_vbox_new(TRUE,5);
|
|
|
|
gtk_container_add(GTK_CONTAINER(win), main_vb);
|
|
|
|
gtk_container_border_width(GTK_CONTAINER(main_vb), 6);
|
|
|
|
|
|
|
|
main_tb = gtk_table_new(i+1, 2, FALSE);
|
|
|
|
gtk_box_pack_start(GTK_BOX(main_vb), main_tb, FALSE, FALSE, 0);
|
|
|
|
gtk_table_set_row_spacings(GTK_TABLE(main_tb), 10);
|
|
|
|
gtk_table_set_col_spacings(GTK_TABLE(main_tb), 15);
|
|
|
|
|
|
|
|
for (i = 0; (fieldname = fieldnames[i]) ; i++) {
|
|
|
|
GtkWidget *entry, *label;
|
|
|
|
|
|
|
|
label = gtk_label_new(fieldname);
|
|
|
|
gtk_misc_set_alignment(GTK_MISC(label), 1.0, 0.5);
|
|
|
|
gtk_table_attach_defaults(GTK_TABLE(main_tb), label, 0, 1, i+1, i + 2);
|
|
|
|
gtk_widget_show(label);
|
|
|
|
|
|
|
|
entry = gtk_entry_new();
|
|
|
|
g_ptr_array_add(dd->entries,entry);
|
|
|
|
gtk_table_attach_defaults(GTK_TABLE(main_tb), entry, 1, 2, i+1, i + 2);
|
|
|
|
gtk_widget_show(entry);
|
|
|
|
}
|
|
|
|
|
|
|
|
bbox = dlg_button_row_new(GTK_STOCK_CANCEL,GTK_STOCK_OK, NULL);
|
2008-04-11 16:44:31 +00:00
|
|
|
gtk_box_pack_start(GTK_BOX(main_vb), bbox, FALSE, FALSE, 0);
|
2006-02-06 01:27:05 +00:00
|
|
|
|
2008-04-11 16:44:31 +00:00
|
|
|
bt_ok = g_object_get_data(G_OBJECT(bbox), GTK_STOCK_OK);
|
2008-04-11 22:10:36 +00:00
|
|
|
g_signal_connect(bt_ok, "clicked", G_CALLBACK(funnel_dlg_cb), dd);
|
2006-02-06 01:27:05 +00:00
|
|
|
gtk_widget_grab_default(bt_ok);
|
|
|
|
|
2008-04-11 16:44:31 +00:00
|
|
|
bt_cancel = g_object_get_data(G_OBJECT(bbox), GTK_STOCK_CANCEL);
|
2008-04-11 22:10:36 +00:00
|
|
|
g_signal_connect(bt_cancel, "clicked", G_CALLBACK(funnel_cancel_btn_cb), win);
|
2006-02-06 01:27:05 +00:00
|
|
|
gtk_widget_grab_default(bt_cancel);
|
|
|
|
|
|
|
|
gtk_widget_show(main_tb);
|
|
|
|
gtk_widget_show(main_vb);
|
|
|
|
gtk_widget_show(win);
|
|
|
|
}
|
|
|
|
|
2006-10-03 12:07:10 +00:00
|
|
|
static void funnel_set_filter(const char* filter_string) {
|
|
|
|
gtk_entry_set_text(GTK_ENTRY(main_display_filter_widget), filter_string);
|
|
|
|
}
|
2006-02-11 13:05:24 +00:00
|
|
|
|
2006-11-07 07:47:49 +00:00
|
|
|
static void funnel_apply_filter(void) {
|
2006-10-03 14:27:45 +00:00
|
|
|
const char* filter_string = gtk_entry_get_text(GTK_ENTRY(main_display_filter_widget));
|
|
|
|
main_filter_packets(&cfile, filter_string, FALSE);
|
|
|
|
}
|
|
|
|
|
2006-02-11 13:05:24 +00:00
|
|
|
/* XXX: finish this */
|
|
|
|
static void funnel_logger(const gchar *log_domain _U_,
|
|
|
|
GLogLevelFlags log_level _U_,
|
|
|
|
const gchar *message,
|
|
|
|
gpointer user_data _U_) {
|
|
|
|
fputs(message,stderr);
|
|
|
|
}
|
|
|
|
|
2006-03-05 02:47:00 +00:00
|
|
|
static void funnel_retap_packets(void) {
|
2006-03-05 02:01:16 +00:00
|
|
|
cf_retap_packets(&cfile, FALSE);
|
|
|
|
}
|
|
|
|
|
2007-04-23 10:59:26 +00:00
|
|
|
static gboolean funnel_open_file(const char* fname, const char* filter, const char** err_str) {
|
2006-10-03 12:07:10 +00:00
|
|
|
int err = 0;
|
|
|
|
dfilter_t *rfcode = NULL;
|
|
|
|
|
2006-10-04 18:45:26 +00:00
|
|
|
*err_str = "no error";
|
2006-10-03 12:07:10 +00:00
|
|
|
|
|
|
|
switch (cfile.state) {
|
|
|
|
case FILE_CLOSED:
|
|
|
|
case FILE_READ_DONE:
|
|
|
|
case FILE_READ_ABORTED:
|
|
|
|
break;
|
|
|
|
case FILE_READ_IN_PROGRESS:
|
2006-10-04 18:45:26 +00:00
|
|
|
*err_str = "file read in progress";
|
2006-10-03 12:07:10 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (filter) {
|
|
|
|
if (!dfilter_compile(filter, &rfcode)) {
|
2006-10-04 18:45:26 +00:00
|
|
|
*err_str = dfilter_error_msg ? dfilter_error_msg : "cannot compile filter";
|
2006-10-03 12:07:10 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (cf_open(&cfile, fname, FALSE, &err) != CF_OK) {
|
2006-10-04 18:45:26 +00:00
|
|
|
*err_str = strerror(err);
|
2006-10-03 12:07:10 +00:00
|
|
|
if (rfcode != NULL) dfilter_free(rfcode);
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
cfile.rfcode = rfcode;
|
|
|
|
|
|
|
|
switch (cf_read(&cfile)) {
|
|
|
|
case CF_READ_OK:
|
|
|
|
case CF_READ_ERROR:
|
|
|
|
break;
|
|
|
|
default:
|
2006-10-04 18:45:26 +00:00
|
|
|
*err_str = "problem while reading file";
|
2006-10-03 12:07:10 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
2006-11-15 23:43:16 +00:00
|
|
|
static void funnel_reload(void) {
|
2006-10-03 12:07:10 +00:00
|
|
|
if (cfile.state == FILE_READ_DONE) cf_reload(&cfile);
|
|
|
|
}
|
2006-02-11 13:05:24 +00:00
|
|
|
|
2006-02-06 23:54:54 +00:00
|
|
|
static const funnel_ops_t funnel_ops = {
|
2006-02-04 19:56:50 +00:00
|
|
|
new_text_window,
|
|
|
|
text_window_set_text,
|
|
|
|
text_window_append,
|
|
|
|
text_window_prepend,
|
|
|
|
text_window_clear,
|
|
|
|
text_window_get_text,
|
2006-02-05 20:02:41 +00:00
|
|
|
text_window_set_close_cb,
|
2006-03-30 19:42:49 +00:00
|
|
|
text_window_set_editable,
|
2006-02-06 01:27:05 +00:00
|
|
|
text_window_destroy,
|
2006-03-30 19:42:49 +00:00
|
|
|
text_window_add_button,
|
2006-02-06 01:27:05 +00:00
|
|
|
/*...,*/
|
2006-02-11 13:05:24 +00:00
|
|
|
funnel_new_dialog,
|
2006-03-05 02:01:16 +00:00
|
|
|
funnel_logger,
|
2006-10-03 12:07:10 +00:00
|
|
|
funnel_retap_packets,
|
|
|
|
copy_to_clipboard,
|
|
|
|
funnel_set_filter,
|
|
|
|
funnel_open_file,
|
2006-10-03 14:27:45 +00:00
|
|
|
funnel_reload,
|
2006-12-27 01:46:42 +00:00
|
|
|
funnel_apply_filter,
|
|
|
|
browser_open_url,
|
|
|
|
browser_open_data_file
|
2006-02-04 19:56:50 +00:00
|
|
|
};
|
|
|
|
|
2006-02-05 03:59:56 +00:00
|
|
|
|
|
|
|
typedef struct _menu_cb_t {
|
|
|
|
void (*callback)(gpointer);
|
|
|
|
void* callback_data;
|
2006-02-05 20:02:41 +00:00
|
|
|
gboolean retap;
|
2006-02-05 03:59:56 +00:00
|
|
|
} menu_cb_t;
|
|
|
|
|
|
|
|
static void our_menu_callback(void* unused _U_, gpointer data) {
|
|
|
|
menu_cb_t* mcb = data;
|
|
|
|
mcb->callback(mcb->callback_data);
|
2006-02-05 20:02:41 +00:00
|
|
|
if (mcb->retap) cf_retap_packets(&cfile, FALSE);
|
2006-02-05 03:59:56 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void register_menu_cb(const char *name,
|
2006-09-27 17:12:42 +00:00
|
|
|
register_stat_group_t group,
|
2006-02-05 03:59:56 +00:00
|
|
|
void (*callback)(gpointer),
|
2006-02-05 20:02:41 +00:00
|
|
|
gpointer callback_data,
|
|
|
|
gboolean retap) {
|
2006-02-05 03:59:56 +00:00
|
|
|
menu_cb_t* mcb = g_malloc(sizeof(menu_cb_t));
|
|
|
|
|
|
|
|
mcb->callback = callback;
|
|
|
|
mcb->callback_data = callback_data;
|
2006-02-05 20:02:41 +00:00
|
|
|
mcb->retap = retap;
|
2006-02-05 03:59:56 +00:00
|
|
|
|
|
|
|
register_stat_menu_item(name, group, our_menu_callback, NULL, NULL, mcb);
|
|
|
|
|
2006-02-04 19:56:50 +00:00
|
|
|
}
|
|
|
|
|
2006-02-06 23:54:54 +00:00
|
|
|
void initialize_funnel_ops(void) {
|
|
|
|
funnel_set_funnel_ops(&funnel_ops);
|
|
|
|
}
|
|
|
|
|
2006-02-04 19:56:50 +00:00
|
|
|
void
|
|
|
|
register_tap_listener_gtkfunnel(void)
|
|
|
|
{
|
2006-02-05 03:59:56 +00:00
|
|
|
funnel_register_all_menus(register_menu_cb);
|
2006-02-04 19:56:50 +00:00
|
|
|
}
|