wireshark/gtk/main_packet_list.h

181 lines
5.4 KiB
C

/* main_packet_list.h
* Declarations of GTK+-specific routines for managing the packet list.
*
* $Id$
*
* Wireshark - Network traffic analyzer
* By Gerald Combs <gerald@wireshark.org>
* 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.
*/
#ifndef __MAIN_PACKET_LIST_H__
#define __MAIN_PACKET_LIST_H__
#ifndef NEW_PACKET_LIST
#define RECENT_KEY_COL_WIDTH "column.width"
/** @file
* Packet list pane.
* @ingroup main_window_group
*/
typedef enum {
COLUMN_SELECTED_SORT_ASCENDING,
COLUMN_SELECTED_SORT_DESCENDING,
COLUMN_SELECTED_SORT_NONE,
COLUMN_SELECTED_ALIGN_LEFT,
COLUMN_SELECTED_ALIGN_CENTER,
COLUMN_SELECTED_ALIGN_RIGHT,
COLUMN_SELECTED_RESIZE,
COLUMN_SELECTED_RENAME,
COLUMN_SELECTED_REMOVE
} COLUMN_SELECTED_E;
/** Create a new packet list.
*
* @param prefs current preferences
* @return the new packet list
*/
extern GtkWidget *packet_list_new(e_prefs *prefs);
/** Recreate the packet list (for use after columns are changed) */
extern void packet_list_recreate(void);
/** Fill in column titles. This must be done after the top level window
* is displayed.
*
* @todo is that still true, with fixed-width columns?
*/
extern void packet_list_set_column_titles(void);
extern void packet_list_column_menu_cb (GtkWidget *w, gpointer data, COLUMN_SELECTED_E action);
/** Resize columns
*
* @param widget parent widget (unused)
* @param data unused
*/
extern void packet_list_resize_columns_cb(GtkWidget *widget, gpointer data);
/** Mark the currently selected packet.
*
* @param widget parent widget (unused)
* @param data unused
*/
extern void packet_list_mark_frame_cb(GtkWidget *widget, gpointer data);
/** Mark all packets in the list.
*
* @param widget parent widget (unused)
* @param data unused
*/
extern void packet_list_mark_all_frames_cb(GtkWidget *widget, gpointer data);
/** Unmark all packets in the list.
*
* @param widget parent widget (unused)
* @param data unused
*/
extern void packet_list_unmark_all_frames_cb(GtkWidget *widget, gpointer data);
/** Update packet marks. */
extern void packet_list_update_marked_frames(void);
/** Ignore the currently selected packet.
*
* @param w parent widget (unused)
* @param data unused
*/
extern void packet_list_ignore_frame_cb(GtkWidget *w _U_, gpointer data _U_);
/** Ignore all packets in the list.
*
* @param w parent widget (unused)
* @param data unused
*/
extern void packet_list_ignore_all_frames_cb(GtkWidget *w _U_, gpointer data _U_);
/** Un-ignore all packets in the list.
*
* @param w parent widget (unused)
* @param data unused
*/
extern void packet_list_unignore_all_frames_cb(GtkWidget *w _U_, gpointer data _U_);
/** Update ignored packages. */
extern void packet_list_update_ignored_frames(void);
/** Gdk button click appeared, get row and column number in packet list from that position.
*
* @param widget the packet list widget from packet_list_new()
* @param event_button the button event clicked
* @param row the row in the packet list
* @param column the column in the packet list
* @return TRUE if row/column is returned and in range
*/
extern gboolean packet_list_get_event_row_column(GtkWidget *widget,
GdkEventButton *event_button, gint *row, gint *column);
/** Set the font of the packet list.
*
* @param font the new font
*/
extern void packet_list_set_font(PangoFontDescription *font);
/** Set the default column sizes. */
extern void packet_list_set_default_column_sizes(void);
/** Set the selection mode of the packet list window.
*
* @param val TRUE for GTK_SELECTION_SINGLE, FALSE for GTK_SELECTION_BROWSE
* @param force_set TRUE to force setting of the selection mode even if it
* was already set (used within packet_list_recreate).
*/
extern void packet_list_set_sel_browse(gboolean val, gboolean force_set);
/** Check to see if the packet list is at its end. Toggles automatic
* scrolling if needed.
*
* @return TRUE if packet list is scrolled to greater than 90% of its total length.
*/
extern gboolean packet_list_check_end(void);
/* Different modes of copying summary data */
typedef enum {
CS_TEXT, /* Packet summary data (tab separated) */
CS_CSV /* Packet summary data (comma separated) */
} copy_summary_type;
/** Called when user clicks on menu item to copy summary data.
*
* @param w Not used.
* @param data Not used.
* @param copy_type Mode in which to copy data (e.g. tab-separated, CSV)
*/
extern void packet_list_copy_summary_cb(GtkWidget * w _U_, gpointer data _U_, copy_summary_type copy_type);
/** Write all packet list geometry values to the recent file.
*
* @param rf recent file handle from caller
*/
extern void packet_list_recent_write_all(FILE *rf);
#endif /* NEW_PACKET_LIST */
#endif /* __MAIN_PACKET_LIST_H__ */