Add a new "prefs_register_protocol()" routine, which is like
[obnox/wireshark/wip.git] / file.h
diff --git a/file.h b/file.h
index 29113cda453e639e43553a1d54270e0df259d876..21e6af2689f666c8cffeac75794fa1b4cc0ee758 100644 (file)
--- a/file.h
+++ b/file.h
@@ -1,7 +1,7 @@
 /* file.h
  * Definitions for file structures and routines
  *
- * $Id: file.h,v 1.55 1999/11/29 01:54:01 guy Exp $
+ * $Id: file.h,v 1.78 2000/10/20 04:26:38 gram Exp $
  *
  * Ethereal - Network traffic analyzer
  * By Gerald Combs <gerald@zing.org>
 #include <sys/types.h>
 #endif
 
-#ifndef __WTAP_H__
 #include "wiretap/wtap.h"
-#endif
 
 #ifdef HAVE_LIBPCAP
-#ifndef lib_pcap_h
 #include <pcap.h>
 #endif
-#endif
 
-#ifndef __DFILTER_H__
 #include "dfilter.h"
-#endif
-
-#ifndef __COLORS_H__
-#include "colors.h"
-#endif
+#include "print.h"
 
 #include <errno.h>
 
+#include <epan.h>
+
 #ifdef HAVE_LIBZ
 #include "zlib.h"
-
 #define FILE_T gzFile
 #define file_open gzopen
 #define filed_open gzdopen
-#define file_seek gzseek
-#define file_read(buf, bsize, count, file) gzread((file),(buf),((count)*(bsize)))
-#define file_write(buf, bsize, count, file) gzwrite((file),(buf),((count)*(bsize)))
 #define file_close gzclose
-
 #else /* No zLib */
 #define FILE_T FILE *
 #define file_open fopen
 #define filed_open fdopen
-#define file_seek fseek
-#define file_read fread
-#define file_write fwrite
 #define file_close fclose
 #endif /* HAVE_LIBZ */
 
 typedef struct bpf_program bpf_prog;
 
+/* Current state of file. */
+typedef enum {
+       FILE_CLOSED,            /* No file open */
+       FILE_READ_IN_PROGRESS,  /* Reading a file we've opened */
+       FILE_READ_ABORTED,      /* Read aborted by user */
+       FILE_READ_DONE          /* Read completed */
+} file_state;
+
 typedef struct _capture_file {
-  FILE_T       fh;        /* Capture file */
-  int          filed;     /* Filedes of 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 */
+  file_state   state;     /* Current state of capture file */
+  int          filed;     /* File descriptor of capture file */
+  gchar       *filename;  /* Name of capture file */
+  gboolean     is_tempfile; /* Is capture file a temporary file? */
+  gboolean     user_saved;/* If capture file is temporary, has it been saved by user yet? */
+  long         f_len;     /* Length of capture file */
+  guint16      cd_t;      /* File type of capture file */
+  int          lnk_t;     /* Link-layer type with which to save capture */
   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 */
-  gboolean     update_progbar; /* TRUE if we should update the progress bar */
   long         progbar_quantum; /* Number of bytes read per progress bar update */
   long         progbar_nextstep; /* Next point at which to update progress bar */
   gchar       *iface;     /* Interface */
   gchar       *save_file; /* File that user saved capture to */
   int          save_file_fd; /* File descriptor for saved file */
-  gint         user_saved;/* Was capture file saved by user yet? */
   wtap        *wth;       /* Wiretap session */
   dfilter     *rfcode;    /* Compiled read filter program */ 
   gchar       *dfilter;   /* Display filter string */
-  colfilter   *colors;   /* Colors for colorizing packet window */
+  struct _colfilter   *colors;   /* Colors for colorizing packet window */
   dfilter     *dfcode;    /* Compiled display filter program */ 
 #ifdef HAVE_LIBPCAP
   gchar       *cfilter;   /* Capture filter string */
@@ -105,33 +97,51 @@ typedef struct _capture_file {
 #endif
   gchar       *sfilter;   /* Search filter string */
   gboolean     sbackward;  /* TRUE if search is backward, FALSE if forward */
+  union wtap_pseudo_header pseudo_header;      /* Packet pseudo_header */
   guint8       pd[WTAP_MAX_PACKET_SIZE];  /* Packet data */
+  GMemChunk   *plist_chunk; /* Memory chunk for frame_data structures */
   frame_data  *plist;     /* Packet list */
   frame_data  *plist_end; /* Last packet in list */
   frame_data  *first_displayed; /* First frame displayed */
   frame_data  *last_displayed;  /* Last frame displayed */
   column_info  cinfo;    /* Column formatting information */
   frame_data  *current_frame;  /* Frame data for current frame */
-  int          current_row;    /* Row in packet display of current frame */
-  gboolean     current_frame_is_selected; /* TRUE if that frame is selected */
   proto_tree  *protocol_tree; /* Protocol tree for currently selected packet */
+  epan_dissect_t *edt; /* Protocol dissection fo rcurrently selected packet */
   FILE        *print_fh;  /* File we're printing to */
 } capture_file;
 
-int  open_cap_file(char *, capture_file *);
-void close_cap_file(capture_file *, void *, guint);
-int  read_cap_file(capture_file *);
-int  start_tail_cap_file(char *, capture_file *);
-int  continue_tail_cap_file(capture_file *, int);
-int  finish_tail_cap_file(capture_file *);
+/* Return values from "read_cap_file()", "continue_tail_cap_file()",
+   and "finish_tail_cap_file()". */
+typedef enum {
+       READ_SUCCESS,   /* read succeeded */
+       READ_ERROR,     /* read got an error */
+       READ_ABORTED    /* read aborted by user */
+} read_status_t;
+
+int  open_cap_file(char *, gboolean, capture_file *);
+void close_cap_file(capture_file *, void *);
+read_status_t read_cap_file(capture_file *, int *);
+int  start_tail_cap_file(char *, gboolean, capture_file *);
+read_status_t continue_tail_cap_file(capture_file *, int, int *);
+read_status_t finish_tail_cap_file(capture_file *, int *);
 /* size_t read_frame_header(capture_file *); */
+int  save_cap_file(char *, capture_file *, gboolean, gboolean, guint);
 
 int filter_packets(capture_file *cf, gchar *dfilter);
 void colorize_packets(capture_file *);
+void redissect_packets(capture_file *cf);
 int print_packets(capture_file *cf, print_args_t *print_args);
 void change_time_formats(capture_file *);
 gboolean find_packet(capture_file *cf, dfilter *sfcode);
-gboolean goto_frame(capture_file *cf, guint fnumber);
+
+typedef enum {
+  FOUND_FRAME,         /* found the frame */
+  NO_SUCH_FRAME,       /* no frame with that number */
+  FRAME_NOT_DISPLAYED  /* frame with that number isn't displayed */
+} goto_result_t;
+goto_result_t goto_frame(capture_file *cf, guint fnumber);
+
 void select_packet(capture_file *, int);
 void unselect_packet(capture_file *);
 
@@ -141,7 +151,7 @@ int file_mv(char *from, char *to);
 /* Copies a file. Returns 0 on failure, 1 on success */
 int file_cp(char *from, char *to);
 
-char *file_open_error_message(int, int);
+char *file_open_error_message(int, gboolean);
 char *file_read_error_message(int);
 char *file_write_error_message(int);