aboutsummaryrefslogtreecommitdiffstats
path: root/file.h
diff options
context:
space:
mode:
authorGuy Harris <guy@alum.mit.edu>1999-08-10 07:16:47 +0000
committerGuy Harris <guy@alum.mit.edu>1999-08-10 07:16:47 +0000
commit8eb998e3600cbb1bcf76e64d42baca1eb9d66d46 (patch)
tree2a160810c80b8a18d317238edf220c323ae0ef1c /file.h
parent7ec128ccb261ed3c1b59bd4866c0f69d3e19117d (diff)
downloadwireshark-8eb998e3600cbb1bcf76e64d42baca1eb9d66d46.tar.gz
wireshark-8eb998e3600cbb1bcf76e64d42baca1eb9d66d46.tar.bz2
wireshark-8eb998e3600cbb1bcf76e64d42baca1eb9d66d46.zip
Add the ability to specify a filter to be used when reading the file to
the "Open File" dialog box (the "Open File" dialog box equivalent of the "-R" flag). Have "load_cap_file()" take the filter expression as an argument, and make the global "rfilter" into a member of a "capture_file" structure. When reading a temporary capture file after a live capture, don't apply any filter. Move the code that pops up error boxes on file opens when reading a capture file back to "load_cap_file()"; it also pops up error boxes if the filter expression can't be parsed. Don't enable "File/Save" or "File/Save As..." if an attempt to read a capture file fails - if there was already an open capture file, it was closed by "load_cap_file()", so we no longer have an open file to save. svn path=/trunk/; revision=460
Diffstat (limited to 'file.h')
-rw-r--r--file.h59
1 files changed, 30 insertions, 29 deletions
diff --git a/file.h b/file.h
index 857e1eecfa..893709c5cd 100644
--- a/file.h
+++ b/file.h
@@ -1,7 +1,7 @@
/* file.h
* Definitions for file structures and routines
*
- * $Id: file.h,v 1.27 1999/08/10 04:13:37 guy Exp $
+ * $Id: file.h,v 1.28 1999/08/10 07:12:52 guy Exp $
*
* Ethereal - Network traffic analyzer
* By Gerald Combs <gerald@zing.org>
@@ -47,27 +47,28 @@
typedef struct bpf_program bpf_prog;
typedef struct _capture_file {
- FILE *fh; /* Capture file */
- gchar *filename; /* filename */
- long f_len; /* File length */
- guint16 cd_t; /* Capture data type */
+ FILE *fh; /* Capture file */
+ gchar *filename; /* filename */
+ long f_len; /* File length */
+ guint16 cd_t; /* Capture data type */
const gchar *cd_t_desc;/* Description of that data type */
- guint32 vers; /* Version. For tcpdump minor is appended to major */
- guint32 count; /* Packet count */
- gfloat unfiltered_count; /* used for dfilter progress bar */
- guint32 drops; /* Dropped packets */
- guint32 esec; /* Elapsed seconds */
- guint32 eusec; /* Elapsed microseconds */
- guint32 snap; /* Captured packet length */
- gchar *iface; /* Interface */
- gchar *save_file; /* File that user saved capture to */
- gint user_saved;/* Was capture file saved by user yet? */
- wtap *wth; /* Wiretap session */
- gchar *dfilter; /* Display filter string */
- GNode *dfcode; /* Compiled display filter program */
+ guint32 vers; /* Version. For tcpdump minor is appended to major */
+ guint32 count; /* Packet count */
+ gfloat unfiltered_count; /* used for dfilter progress bar */
+ guint32 drops; /* Dropped packets */
+ guint32 esec; /* Elapsed seconds */
+ guint32 eusec; /* Elapsed microseconds */
+ guint32 snap; /* Captured packet length */
+ gchar *iface; /* Interface */
+ gchar *save_file; /* File that user saved capture to */
+ gint user_saved;/* Was capture file saved by user yet? */
+ wtap *wth; /* Wiretap session */
+ gchar *rfilter; /* Read filter string */
+ gchar *dfilter; /* Display filter string */
+ GNode *dfcode; /* Compiled display filter program */
#ifdef HAVE_LIBPCAP
- gchar *cfilter; /* Capture filter string */
- bpf_prog fcode; /* Compiled capture filter program */
+ gchar *cfilter; /* Capture filter string */
+ bpf_prog fcode; /* Compiled capture filter program */
#endif
/* XXX - I'm cheating for now. I'll hardcode 65536 here until I re-arrange
* more header files so that ethereal.h is split up into two files, a
@@ -75,15 +76,15 @@ typedef struct _capture_file {
* moved to different header files) --gilbert
*/
/*guint8 pd[MAX_PACKET_SIZE];*/ /* Packet data */
- guint8 pd[65536]; /* Packet data */
- frame_data *plist; /* Packet list */
- frame_data *plist_end; /* Last packet in list */
+ guint8 pd[65536]; /* Packet data */
+ frame_data *plist; /* Packet list */
+ frame_data *plist_end; /* Last packet in list */
column_info cinfo; /* Column formatting information */
- int selected_packet; /* Index in packet list of currently selected packet, if any */
- int selected_row; /* Row in packet display of currently selected packet, if any */
- frame_data *fd; /* Frame data for currently selected packet */
- proto_tree *protocol_tree; /* Protocol tree for currently selected packet */
- FILE *print_fh; /* File we're printing to */
+ int selected_packet; /* Index in packet list of currently selected packet, if any */
+ int selected_row; /* Row in packet display of currently selected packet, if any */
+ frame_data *fd; /* Frame data for currently selected packet */
+ proto_tree *protocol_tree; /* Protocol tree for currently selected packet */
+ FILE *print_fh; /* File we're printing to */
} capture_file;
@@ -101,7 +102,7 @@ typedef struct _capture_file {
int open_cap_file(char *, capture_file *);
void close_cap_file(capture_file *, void *, guint);
-int load_cap_file(char *, capture_file *);
+int load_cap_file(char *, char *, capture_file *);
int tail_cap_file(char *, capture_file *);
/* size_t read_frame_header(capture_file *); */