forked from osmocom/wireshark
d936d457c3
svn path=/trunk/; revision=33929
181 lines
5.4 KiB
C
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__ */
|