Enable "Match Selected" only if there's a field selected *and* we can do
a "Match Selected" on it - we can't do a "Match Selected" if the field
has no value (e.g., FT_NULL) and has a length of 0.
If we unselect the current packet, we don't have a protocol tree, so we
don't have a currently selected field - clear the "Match Selected" menu
item and the display in the status line of information about the
currently selected field.
Move the low-level statusbar manipulation into "gtk/main.c", in routines
whose API doesn't expose anything GTK+-ish.
"close_cap_file()" calls one of those routines to clear out the status
bar, so it doesn't need to take a pointer to the statusbar widget as an
argument.
"clear_tree_and_hex_views()" is purely a display-manipulating routine;
move it to "gtk/proto_draw.c".
Extract from "tree_view_unselect_row_cb()" an "unselect_field()" routine
to do all the work that needs to be done if the currently selected
protocol tree row is unselected, and call it if the currently selected
packet list row is unselected (if it's unselected, there *is* no
protocol tree, so no row can be selected), as well as from
"tree_view_unselect_row_cb()".
Before pushing a new field-description message onto the statusbar, pop
the old one off.
Get rid of an unused variable (set, but not used).
svn path=/trunk/; revision=3513
2001-06-05 07:39:31 +00:00
|
|
|
/* proto_draw.h
|
1999-03-23 03:14:46 +00:00
|
|
|
* Definitions for GTK+ packet display structures and routines
|
|
|
|
*
|
2002-11-03 17:38:45 +00:00
|
|
|
* $Id: proto_draw.h,v 1.21 2002/11/03 17:38:34 oabad Exp $
|
1999-03-23 03:14:46 +00:00
|
|
|
*
|
|
|
|
* Ethereal - Network traffic analyzer
|
Enable "Match Selected" only if there's a field selected *and* we can do
a "Match Selected" on it - we can't do a "Match Selected" if the field
has no value (e.g., FT_NULL) and has a length of 0.
If we unselect the current packet, we don't have a protocol tree, so we
don't have a currently selected field - clear the "Match Selected" menu
item and the display in the status line of information about the
currently selected field.
Move the low-level statusbar manipulation into "gtk/main.c", in routines
whose API doesn't expose anything GTK+-ish.
"close_cap_file()" calls one of those routines to clear out the status
bar, so it doesn't need to take a pointer to the statusbar widget as an
argument.
"clear_tree_and_hex_views()" is purely a display-manipulating routine;
move it to "gtk/proto_draw.c".
Extract from "tree_view_unselect_row_cb()" an "unselect_field()" routine
to do all the work that needs to be done if the currently selected
protocol tree row is unselected, and call it if the currently selected
packet list row is unselected (if it's unselected, there *is* no
protocol tree, so no row can be selected), as well as from
"tree_view_unselect_row_cb()".
Before pushing a new field-description message onto the statusbar, pop
the old one off.
Get rid of an unused variable (set, but not used).
svn path=/trunk/; revision=3513
2001-06-05 07:39:31 +00:00
|
|
|
* By Gerald Combs <gerald@ethereal.com>
|
1999-03-23 03:14:46 +00:00
|
|
|
* Copyright 1998 Gerald Combs
|
2002-08-28 21:04:11 +00:00
|
|
|
*
|
1999-03-23 03:14:46 +00:00
|
|
|
* 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.
|
2002-08-28 21:04:11 +00:00
|
|
|
*
|
1999-03-23 03:14:46 +00:00
|
|
|
* 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.
|
2002-08-28 21:04:11 +00:00
|
|
|
*
|
1999-03-23 03:14:46 +00:00
|
|
|
* 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 __GTKPACKET_H__
|
|
|
|
#define __GTKPACKET_H__
|
2001-03-23 14:44:04 +00:00
|
|
|
|
2002-02-18 01:08:44 +00:00
|
|
|
/* Get the current text window for the notebook. */
|
|
|
|
extern GtkWidget *get_notebook_bv_ptr(GtkWidget *nb_ptr);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Get the data and length for a byte view, given the byte view page.
|
|
|
|
* Return the pointer, or NULL on error, and set "*data_len" to the length.
|
|
|
|
*/
|
|
|
|
extern const guint8 *get_byte_view_data_and_length(GtkWidget *byte_view,
|
|
|
|
guint *data_len);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Set the current text window for the notebook to the window that
|
|
|
|
* refers to a particular tvbuff.
|
|
|
|
*/
|
|
|
|
extern void set_notebook_page(GtkWidget *nb_ptr, tvbuff_t *tvb);
|
2001-03-23 14:44:04 +00:00
|
|
|
|
2002-02-18 01:08:44 +00:00
|
|
|
/* Redraw a given byte view window. */
|
|
|
|
extern void redraw_hex_dump(GtkWidget *nb, frame_data *fd, field_info *finfo);
|
2001-03-23 14:44:04 +00:00
|
|
|
|
2002-02-18 01:08:44 +00:00
|
|
|
/* Redraw all byte view windows. */
|
|
|
|
extern void redraw_hex_dump_all(void);
|
2001-03-23 14:44:04 +00:00
|
|
|
|
2002-03-31 23:11:04 +00:00
|
|
|
extern GtkWidget *create_byte_view(gint bv_size, GtkWidget *pane);
|
2001-03-23 14:44:04 +00:00
|
|
|
|
2002-06-04 07:03:57 +00:00
|
|
|
extern void add_byte_views(epan_dissect_t *edt, GtkWidget *tree_view,
|
2002-11-03 17:38:45 +00:00
|
|
|
GtkWidget *byte_nb_ptr);
|
1999-03-23 03:14:46 +00:00
|
|
|
|
2002-11-03 17:38:45 +00:00
|
|
|
#if GTK_MAJOR_VERSION < 2
|
2002-02-18 01:08:44 +00:00
|
|
|
void packet_hex_print(GtkText *, const guint8 *, frame_data *, field_info *,
|
|
|
|
guint);
|
2001-03-23 14:44:04 +00:00
|
|
|
void packet_hex_reprint(GtkText *);
|
2002-11-03 17:38:45 +00:00
|
|
|
void set_ptree_font_all(GdkFont *font);
|
|
|
|
#else
|
|
|
|
void packet_hex_print(GtkTextView *, const guint8 *, frame_data *, field_info *,
|
|
|
|
guint);
|
|
|
|
void packet_hex_reprint(GtkTextView *);
|
|
|
|
void set_ptree_font_all(PangoFontDescription *font);
|
|
|
|
#endif
|
1999-03-23 03:14:46 +00:00
|
|
|
|
2000-02-29 06:24:41 +00:00
|
|
|
void create_tree_view(gint tv_size, e_prefs *prefs, GtkWidget *pane,
|
2002-03-31 23:11:04 +00:00
|
|
|
GtkWidget **tv_scrollw_p, GtkWidget **tree_view_p);
|
1999-07-07 22:52:57 +00:00
|
|
|
void proto_tree_draw(proto_tree *protocol_tree, GtkWidget *tree_view);
|
1999-09-11 12:38:18 +00:00
|
|
|
void expand_all_tree(proto_tree *protocol_tree, GtkWidget *tree_view);
|
|
|
|
void collapse_all_tree(proto_tree *protocol_tree, GtkWidget *tree_view);
|
1999-07-07 22:52:57 +00:00
|
|
|
|
Instead of each set of built-in preferences having "ok", "save",
"cancel", and "delete" methods, give them:
"fetch" - fetch from the notebook tab any values not already
stored in "prefs", and store them there, but doesn't apply them;
"apply" - apply the settings in "prefs";
"destroy" - clean up any windows created from the tab.
As we no longer have "cancel" methods, we don't have per-preference code
to revert preference values; instead, we have the common preference
dialog box code make a copy of all the current preferences, and, when
the "Cancel" button is clicked, free the current preferences and copy
the saved preferences to it, and apply the preferences.
Add an "Apply" button to the preference dialog box, which applies the
current preferences without closing the dialog box.
Treat a request to delete the preferences dialog box as equivalent to
clicking "Cancel".
Have a "remember_ptree_widget()" routine to remember all protocol tree
widgets, and use the list of those widgets when we set GUI preferences
for the protocol tree widgets, rather than setting the main protocol
tree widget and then using the list of packet windows. Move that code
out of "main.c" to "proto_draw.c", as it's not used by anything in
"main.c", but is used by stuff in "proto_draw.c".
Make the font one of the preferences we can set on the fly for protocol
tree widgets. Also make it something we can set on the fly for the
packet list widget.
svn path=/trunk/; revision=2316
2000-08-21 08:09:17 +00:00
|
|
|
void set_ptree_sel_browse_all(gboolean);
|
|
|
|
|
1999-03-23 03:14:46 +00:00
|
|
|
#endif
|