forked from osmocom/wireshark
791f5774d0
Put a hash-table of "interesting" fields in the per-proto-tree data. The dfilter code records which fields/protocols are "interesting" (by which I mean, their value or existence is checked). Thus, the proto_tree routines can create special arrays of field_info*'s that are ready for the dfilter engine to use during a filter operation. Also store the "proto_tree_is_visible" boolean, renamed "visible", in the per-proto-tree data. Move epan_dissect_t to its own header file to make #include dependencies easier to handle. Provide epan_dissect_fill_in_columns(), which accepts just the epan_dissect_t* as an argument. epan_dissect_new() needs to be followed by epan_dissect_run() for the dissection to actually take place. Between those two calls, epan_dissect_prime_dfilter() can be run 0, 1, or multiple times in order to prime the empty proto_tree with the "intersesting" fields from the dfilter_t. svn path=/trunk/; revision=4422
75 lines
2.3 KiB
C
75 lines
2.3 KiB
C
/* colors.h
|
|
* Definitions for color structures and routines
|
|
*
|
|
* $Id: colors.h,v 1.5 2001/12/18 19:09:07 gram Exp $
|
|
*
|
|
* Ethereal - Network traffic analyzer
|
|
* By Gerald Combs <gerald@zing.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 __COLORS_H__
|
|
#define __COLORS_H__
|
|
|
|
#include "proto.h"
|
|
#include "dfilter/dfilter.h"
|
|
#include <gtk/gtk.h>
|
|
#include "epan.h"
|
|
|
|
#define MAXCOLORS 255
|
|
#define MAX_COLOR_FILTER_NAME_LEN 33
|
|
#define MAX_COLOR_FILTER_STRING_LEN 256
|
|
|
|
#define CFILTERS_CONTAINS_FILTER(filter) \
|
|
((filter)->num_of_filters != 0)
|
|
|
|
extern GdkColor WHITE;
|
|
extern GdkColor BLACK;
|
|
|
|
/* Data for a color filter. */
|
|
typedef struct _color_filter {
|
|
gchar *filter_name; /* name of the filter */
|
|
gchar *filter_text; /* text of the filter expression */
|
|
GdkColor bg_color; /* background color for packets that match */
|
|
GdkColor fg_color; /* foreground color for packets that match */
|
|
dfilter_t *c_colorfilter; /* compiled filter expression */
|
|
GtkWidget *edit_dialog; /* if filter is being edited, dialog box for it */
|
|
} color_filter_t;
|
|
|
|
/* List of all color filters. */
|
|
extern GSList *filter_list;
|
|
|
|
typedef struct _colfilter {
|
|
gint num_of_filters; /* first num_of_filters rows filled */
|
|
gint row_selected; /* row in color_filters that is selected */
|
|
} colfilter;
|
|
|
|
colfilter *colfilter_new(void);
|
|
|
|
gboolean write_filters(colfilter *filter);
|
|
|
|
color_filter_t *new_color_filter(colfilter *filters, gchar *name,
|
|
gchar *filter_string);
|
|
void delete_color_filter(color_filter_t *colorf);
|
|
|
|
gboolean get_color (GdkColor *new_color);
|
|
|
|
void
|
|
filter_list_prime_edt(epan_dissect_t *edt);
|
|
|
|
#endif
|