Re-generate a number of ASN.1-based dissectors with the most recent
[obnox/wireshark/wip.git] / capinfo.c
old mode 100755 (executable)
new mode 100644 (file)
index 6c368c8..c39cccd
--- a/capinfo.c
+++ b/capinfo.c
-/* capinfo.c\r
- * Reports capture file information including # of packets, duration, others\r
- *\r
- * Copyright 2004 Ian Schorr\r
- *\r
- * $Id: $\r
- *\r
- * Ethereal - Network traffic analyzer\r
- * By Gerald Combs <gerald@ethereal.com>\r
- * Copyright 1998 Gerald Combs\r
- *\r
- * This program is free software; you can redistribute it and/or\r
- * modify it under the terms of the GNU General Public License\r
- * as published by the Free Software Foundation; either version 2\r
- * of the License, or (at your option) any later version.\r
- *\r
- * This program is distributed in the hope that it will be useful,\r
- * but WITHOUT ANY WARRANTY; without even the implied warranty of\r
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\r
- * GNU General Public License for more details.\r
- *\r
- * You should have received a copy of the GNU General Public License\r
- * along with this program; if not, write to the Free Software\r
- * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.\r
- */\r
-\r
-#ifdef HAVE_CONFIG_H\r
-#include "config.h"\r
-#endif\r
-\r
-#include <stdio.h>\r
-#include <stdlib.h>\r
-#include <glib.h>\r
-#include <string.h>\r
-\r
-#ifdef HAVE_UNISTD_H\r
-#include <unistd.h>\r
-#endif\r
-\r
-#ifdef HAVE_SYS_TIME_H\r
-#include <sys/time.h>\r
-#endif\r
-\r
-#include <string.h>\r
-#include <epan/packet.h>\r
-#include "wtap.h"\r
-\r
-#ifdef NEED_GETOPT_H\r
-#include "getopt.h"\r
-#endif\r
-\r
-#ifdef HAVE_SYS_STAT_H\r
-#include <sys/stat.h>\r
-#endif\r
-\r
-\r
-static gboolean cap_file_type = FALSE;      /* Do not report capture type     */\r
-static gboolean cap_packet_count = FALSE;   /* Do not produce packet count    */\r
-static gboolean cap_file_size = FALSE;      /* Do not report file size        */\r
-static gboolean cap_data_size = FALSE;      /* Do not report packet byte size */\r
-static gboolean cap_duration = FALSE;       /* Do not report capture duration */\r
-static gboolean cap_start_time = FALSE;\r
-static gboolean cap_end_time = FALSE;\r
-\r
-static gboolean cap_data_rate_byte = FALSE;\r
-static gboolean cap_data_rate_bit = FALSE;\r
-static gboolean cap_packet_size = FALSE;\r
-\r
-\r
-typedef struct _capture_info {\r
-       const char              *filename;\r
-       guint16                 file_type;\r
-       guint64                 filesize;\r
-       guint64                 packet_bytes;\r
-       double                  start_time;\r
-       double                  stop_time;\r
-       guint32                 packet_count;\r
-       gboolean                snap_set;\r
-       guint32                 snaplen;\r
-       gboolean                drops_known;\r
-       guint32                 drop_count;\r
-       \r
-       double                  duration;\r
-       double                  packet_rate;\r
-       double                  packet_size;\r
-       double                  data_rate;              /* in bytes */\r
-} capture_info;\r
-\r
-static double\r
-secs_usecs(guint32 s, guint32 us)\r
-{\r
-  return (us / 1000000.0) + (double)s;\r
-}\r
-\r
-static void\r
-print_stats(capture_info *cf_info)\r
-{\r
-  gchar                        *file_type_string;\r
-  time_t               start_time_t;\r
-  struct tm            *start_time_tm;\r
-  time_t               stop_time_t;\r
-  struct tm            *stop_time_tm;\r
-\r
-  /* Build printable strings for various stats */\r
-  file_type_string = wtap_file_type_string(cf_info->file_type);\r
-  start_time_t = (long)cf_info->start_time;\r
-  stop_time_t = (long)cf_info->stop_time;\r
-  start_time_tm = localtime (&start_time_t);\r
-  stop_time_tm = localtime (&stop_time_t);\r
-\r
-  if (cap_file_type) printf("File Type: %s\n", file_type_string);\r
-  if (cap_packet_count) printf("Number of packets: %u \n", cf_info->packet_count);\r
-  if (cap_file_size) printf("File Size: %" PRIu64 " bytes\n", cf_info->filesize);\r
-  if (cap_data_size) printf("Data Size: %" PRIu64 " bytes\n", cf_info->packet_bytes);\r
-  if (cap_duration) printf("Capture duration: %f seconds\n", cf_info->duration);\r
-  if (cap_start_time) printf("Start time: %s", asctime (start_time_tm));\r
-  if (cap_end_time) printf("End time: %s", asctime (stop_time_tm));\r
-  if (cap_data_rate_byte) printf("Data rate: %.2f bytes/s\n", cf_info->data_rate);\r
-  if (cap_data_rate_bit) printf("Data rate: %.2f bits/s\n", cf_info->data_rate*8);\r
-  if (cap_packet_size) printf("Average packet size: %.2f bytes\n", cf_info->packet_size);\r
-\r
-}\r
-\r
-static int \r
-process_cap_file(wtap *wth)\r
-{\r
-  int                  err;\r
-  gchar                        *err_info;\r
-  struct stat   cf_stat;\r
-  long                 data_offset;\r
-  \r
-  guint32              packet = 0;\r
-  gint64               bytes = 0;\r
-  const struct wtap_pkthdr *phdr;\r
-  capture_info  cf_info;\r
-  double               start_time = 0;\r
-  double               stop_time = 0;\r
-  double               cur_time = 0;\r
-  \r
-  /* Tally up data that we need to parse through the file to find */\r
-  while (wtap_read(wth, &err, &err_info, &data_offset))  {\r
-    phdr = wtap_phdr(wth);\r
-       cur_time = secs_usecs(phdr->ts.tv_sec, phdr->ts.tv_usec);\r
-       if(packet==0) {\r
-         start_time = cur_time;\r
-         stop_time = cur_time;\r
-       }\r
-       if (cur_time < start_time) {\r
-         start_time = cur_time;\r
-       }\r
-       if (cur_time > stop_time) {\r
-         stop_time = cur_time;\r
-       }\r
-       bytes+=phdr->len;\r
-    packet++;\r
-  }\r
-  \r
-  if (err != 0) {\r
-    fprintf(stderr, "Error after reading %i packets\n", packet);\r
-       exit(1);\r
-  }\r
-\r
-  /* File size */\r
-  if (fstat(wtap_fd(wth), &cf_stat) < 0) {\r
-    wtap_close(wth);\r
-       return 1;\r
-  }\r
-  \r
-  cf_info.filesize = cf_stat.st_size;\r
-  \r
-  /* File Type */\r
-  cf_info.file_type = wtap_file_type(wth);\r
-  \r
-  /* # of packets */\r
-  cf_info.packet_count = packet;\r
-  \r
-  /* File Times */\r
-  cf_info.start_time = start_time;\r
-  cf_info.stop_time = stop_time;\r
-  cf_info.duration = stop_time-start_time;\r
-       \r
-  /* Number of packet bytes */\r
-  cf_info.packet_bytes = bytes;\r
-  \r
-  /* Data rate per second */\r
-  cf_info.data_rate = (double)bytes / (stop_time-start_time);\r
-  \r
-  /* Avg packet size */\r
-  cf_info.packet_size = (double)bytes/packet;\r
-  \r
-  print_stats(&cf_info);\r
-\r
-return 0;\r
-}\r
-\r
-static void usage(gboolean is_error)\r
-{\r
-  FILE *output;\r
-  \r
-  if (!is_error) {\r
-    output = stdout;\r
-       /* XXX - add capinfo header info here */\r
-  }\r
-  else {\r
-    output = stderr;\r
-  }\r
-\r
-\r
-  fprintf(output, "Usage: capinfo [-t] [-c] [-s] [-d] [-u] [-a] [-e] [-y]\n");\r
-  fprintf(output, "               [-i] [-z] [-h] <capfile>\n");\r
-  fprintf(output, "  where\t-t display the capture type of <capfile>\n");\r
-  fprintf(output, "       \t-c count the number of packets\n");\r
-  fprintf(output, "       \t-s display the size of the file \n");\r
-  fprintf(output, "       \t-d display the total length of all packets in the file\n");\r
-  fprintf(output, "       \t   (in bytes)\n");\r
-  fprintf(output, "       \t-u display the capture duration (in seconds) \n");\r
-  fprintf(output, "       \t-a display the capture start time\n");\r
-  fprintf(output, "       \t-e display the capture end time\n");\r
-  fprintf(output, "       \t-y display average data rate (in bytes)\n");\r
-  fprintf(output, "       \t-i display average data rate (in bits)\n");\r
-  fprintf(output, "       \t-z display average packet size (in bytes)\n");\r
-  fprintf(output, "       \t-h produces this help listing.\n");\r
-  fprintf(output, "\n      \t    If no data flags are given, default is to display all statistics\n");\r
-}\r
-\r
-int main(int argc, char *argv[])\r
-{\r
-  wtap *wth;\r
-  int err;\r
-  gchar *err_info;\r
-  extern char *optarg;\r
-  extern int optind;\r
-  int opt;\r
-  int status = 0;\r
-\r
-  /* Process the options first */\r
-\r
-  while ((opt = getopt(argc, argv, "tcsduaeyizvh")) !=-1) {\r
-\r
-    switch (opt) {\r
-\r
-       case 't':\r
-         cap_file_type = TRUE;\r
-         break;\r
-\r
-       case 'c':\r
-         cap_packet_count = TRUE;\r
-         break;\r
-\r
-       case 's':\r
-         cap_file_size = TRUE;\r
-         break;\r
-\r
-       case 'd':\r
-         cap_data_size = TRUE;\r
-         break;\r
-\r
-       case 'u':\r
-         cap_duration = TRUE;\r
-         break;\r
-\r
-       case 'a':\r
-         cap_start_time = TRUE;\r
-         break;\r
-\r
-       case 'e':\r
-         cap_end_time = TRUE;\r
-         break;\r
-\r
-       case 'y':\r
-         cap_data_rate_byte = TRUE;\r
-         break;\r
-\r
-       case 'i':\r
-         cap_data_rate_bit = TRUE;\r
-         break;\r
-\r
-       case 'z':\r
-         cap_packet_size = TRUE;\r
-         break;\r
-\r
-    case 'h':\r
-      usage(FALSE);\r
-      exit(1);\r
-      break;\r
-\r
-    case '?':              /* Bad flag - print usage message */\r
-      usage(TRUE);\r
-      exit(1);\r
-      break;\r
-\r
-    }\r
-\r
-  }\r
-\r
-  if (optind < 2) {\r
-\r
-    /* If no arguments were given, by default display all statistics */\r
-    cap_file_type = TRUE;      \r
-    cap_packet_count = TRUE;   \r
-    cap_file_size = TRUE;      \r
-    cap_data_size = TRUE;      \r
-    cap_duration = TRUE;       \r
-    cap_start_time = TRUE;\r
-    cap_end_time = TRUE;\r
-\r
-    cap_data_rate_byte = TRUE;\r
-    cap_data_rate_bit = TRUE;\r
-    cap_packet_size = TRUE;\r
-\r
-  }\r
-  \r
-  if ((argc - optind) < 1) {\r
-    usage(TRUE);\r
-       exit(1);\r
-  }\r
-  \r
-  wth = wtap_open_offline(argv[optind], &err, &err_info, FALSE);\r
-\r
-  if (!wth) {\r
-    fprintf(stderr, "editcap: Can't open %s: %s\n", argv[optind],\r
-        wtap_strerror(err));\r
-    switch (err) {\r
-\r
-    case WTAP_ERR_UNSUPPORTED:\r
-    case WTAP_ERR_UNSUPPORTED_ENCAP:\r
-    case WTAP_ERR_BAD_RECORD:\r
-      fprintf(stderr, "(%s)\n", err_info);\r
-      g_free(err_info);\r
-      break;\r
-    }\r
-    exit(1);\r
-\r
-  }\r
-\r
-  status = process_cap_file(wth);\r
-  \r
-  wtap_close(wth);\r
-  return status;\r
-}\r
-\r
+/* capinfo.c
+ * Reports capture file information including # of packets, duration, others
+ *
+ * Copyright 2004 Ian Schorr
+ *
+ * $Id$
+ *
+ * Ethereal - Network traffic analyzer
+ * By Gerald Combs <gerald@ethereal.com>
+ * 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.
+ */
+
+#ifdef HAVE_CONFIG_H
+#include "config.h"
+#endif
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <glib.h>
+#include <string.h>
+
+#ifdef HAVE_UNISTD_H
+#include <unistd.h>
+#endif
+
+#ifdef HAVE_SYS_TIME_H
+#include <sys/time.h>
+#endif
+
+#include <string.h>
+#include <epan/packet.h>
+#include "wtap.h"
+
+#ifdef NEED_GETOPT_H
+#include "getopt.h"
+#endif
+
+#ifdef HAVE_SYS_STAT_H
+#include <sys/stat.h>
+#endif
+
+
+static gboolean cap_file_type = FALSE;      /* Do not report capture type     */
+static gboolean cap_packet_count = FALSE;   /* Do not produce packet count    */
+static gboolean cap_file_size = FALSE;      /* Do not report file size        */
+static gboolean cap_data_size = FALSE;      /* Do not report packet byte size */
+static gboolean cap_duration = FALSE;       /* Do not report capture duration */
+static gboolean cap_start_time = FALSE;
+static gboolean cap_end_time = FALSE;
+
+static gboolean cap_data_rate_byte = FALSE;
+static gboolean cap_data_rate_bit = FALSE;
+static gboolean cap_packet_size = FALSE;
+
+
+typedef struct _capture_info {
+       const char              *filename;
+       guint16                 file_type;
+       guint64                 filesize;
+       guint64                 packet_bytes;
+       double                  start_time;
+       double                  stop_time;
+       guint32                 packet_count;
+       gboolean                snap_set;
+       guint32                 snaplen;
+       gboolean                drops_known;
+       guint32                 drop_count;
+       
+       double                  duration;
+       double                  packet_rate;
+       double                  packet_size;
+       double                  data_rate;              /* in bytes */
+} capture_info;
+
+static double
+secs_usecs(guint32 s, guint32 us)
+{
+  return (us / 1000000.0) + (double)s;
+}
+
+static void
+print_stats(capture_info *cf_info)
+{
+  const gchar          *file_type_string;
+  time_t               start_time_t;
+  time_t               stop_time_t;
+
+  /* Build printable strings for various stats */
+  file_type_string = wtap_file_type_string(cf_info->file_type);
+  start_time_t = (time_t)cf_info->start_time;
+  stop_time_t = (time_t)cf_info->stop_time;
+
+  if (cap_file_type) printf("File Type: %s\n", file_type_string);
+  if (cap_packet_count) printf("Number of packets: %u \n", cf_info->packet_count);
+  if (cap_file_size) printf("File Size: %" PRIu64 " bytes\n", cf_info->filesize);
+  if (cap_data_size) printf("Data Size: %" PRIu64 " bytes\n", cf_info->packet_bytes);
+  if (cap_duration) printf("Capture duration: %f seconds\n", cf_info->duration);
+  if (cap_start_time) printf("Start time: %s", ctime (&start_time_t));
+  if (cap_end_time) printf("End time: %s", ctime (&stop_time_t));
+  if (cap_data_rate_byte) printf("Data rate: %.2f bytes/s\n", cf_info->data_rate);
+  if (cap_data_rate_bit) printf("Data rate: %.2f bits/s\n", cf_info->data_rate*8);
+  if (cap_packet_size) printf("Average packet size: %.2f bytes\n", cf_info->packet_size);
+
+}
+
+static int 
+process_cap_file(wtap *wth)
+{
+  int                  err;
+  gchar                        *err_info;
+  struct stat   cf_stat;
+  long                 data_offset;
+  
+  guint32              packet = 0;
+  gint64               bytes = 0;
+  const struct wtap_pkthdr *phdr;
+  capture_info  cf_info;
+  double               start_time = 0;
+  double               stop_time = 0;
+  double               cur_time = 0;
+  
+  /* Tally up data that we need to parse through the file to find */
+  while (wtap_read(wth, &err, &err_info, &data_offset))  {
+    phdr = wtap_phdr(wth);
+    cur_time = secs_usecs(phdr->ts.tv_sec, phdr->ts.tv_usec);
+    if(packet==0) {
+      start_time = cur_time;
+      stop_time = cur_time;
+    }
+    if (cur_time < start_time) {
+      start_time = cur_time;
+    }
+    if (cur_time > stop_time) {
+      stop_time = cur_time;
+    }
+    bytes+=phdr->len;
+    packet++;
+  }
+  
+  if (err != 0) {
+    fprintf(stderr, "Error after reading %i packets\n", packet);
+    exit(1);
+  }
+
+  /* File size */
+  if (fstat(wtap_fd(wth), &cf_stat) < 0) {
+    wtap_close(wth);
+    return 1;
+  }
+  
+  cf_info.filesize = cf_stat.st_size;
+  
+  /* File Type */
+  cf_info.file_type = wtap_file_type(wth);
+  
+  /* # of packets */
+  cf_info.packet_count = packet;
+  
+  /* File Times */
+  cf_info.start_time = start_time;
+  cf_info.stop_time = stop_time;
+  cf_info.duration = stop_time-start_time;
+
+  /* Number of packet bytes */
+  cf_info.packet_bytes = bytes;
+  
+  /* Data rate per second */
+  cf_info.data_rate = (double)bytes / (stop_time-start_time);
+  
+  /* Avg packet size */
+  cf_info.packet_size = (double)bytes/packet;
+  
+  print_stats(&cf_info);
+
+return 0;
+}
+
+static void usage(gboolean is_error)
+{
+  FILE *output;
+  
+  if (!is_error) {
+    output = stdout;
+    /* XXX - add capinfo header info here */
+  }
+  else {
+    output = stderr;
+  }
+
+
+  fprintf(output, "Usage: capinfo [-t] [-c] [-s] [-d] [-u] [-a] [-e] [-y]\n");
+  fprintf(output, "               [-i] [-z] [-h] <capfile>\n");
+  fprintf(output, "  where\t-t display the capture type of <capfile>\n");
+  fprintf(output, "       \t-c count the number of packets\n");
+  fprintf(output, "       \t-s display the size of the file \n");
+  fprintf(output, "       \t-d display the total length of all packets in the file\n");
+  fprintf(output, "       \t   (in bytes)\n");
+  fprintf(output, "       \t-u display the capture duration (in seconds) \n");
+  fprintf(output, "       \t-a display the capture start time\n");
+  fprintf(output, "       \t-e display the capture end time\n");
+  fprintf(output, "       \t-y display average data rate (in bytes)\n");
+  fprintf(output, "       \t-i display average data rate (in bits)\n");
+  fprintf(output, "       \t-z display average packet size (in bytes)\n");
+  fprintf(output, "       \t-h produces this help listing.\n");
+  fprintf(output, "\n      \t    If no data flags are given, default is to display all statistics\n");
+}
+
+int main(int argc, char *argv[])
+{
+  wtap *wth;
+  int err;
+  gchar *err_info;
+  extern char *optarg;
+  extern int optind;
+  int opt;
+  int status = 0;
+
+  /* Process the options first */
+
+  while ((opt = getopt(argc, argv, "tcsduaeyizvh")) !=-1) {
+
+    switch (opt) {
+
+    case 't':
+      cap_file_type = TRUE;
+      break;
+
+    case 'c':
+      cap_packet_count = TRUE;
+      break;
+
+    case 's':
+      cap_file_size = TRUE;
+      break;
+
+    case 'd':
+      cap_data_size = TRUE;
+      break;
+
+    case 'u':
+      cap_duration = TRUE;
+      break;
+
+    case 'a':
+      cap_start_time = TRUE;
+      break;
+
+    case 'e':
+      cap_end_time = TRUE;
+      break;
+
+    case 'y':
+      cap_data_rate_byte = TRUE;
+      break;
+
+    case 'i':
+      cap_data_rate_bit = TRUE;
+      break;
+
+    case 'z':
+      cap_packet_size = TRUE;
+      break;
+
+    case 'h':
+      usage(FALSE);
+      exit(1);
+      break;
+
+    case '?':              /* Bad flag - print usage message */
+      usage(TRUE);
+      exit(1);
+      break;
+    }
+  }
+
+  if (optind < 2) {
+
+    /* If no arguments were given, by default display all statistics */
+    cap_file_type = TRUE;      
+    cap_packet_count = TRUE;   
+    cap_file_size = TRUE;      
+    cap_data_size = TRUE;      
+    cap_duration = TRUE;       
+    cap_start_time = TRUE;
+    cap_end_time = TRUE;
+
+    cap_data_rate_byte = TRUE;
+    cap_data_rate_bit = TRUE;
+    cap_packet_size = TRUE;
+  }
+  
+  if ((argc - optind) < 1) {
+    usage(TRUE);
+    exit(1);
+  }
+  
+  wth = wtap_open_offline(argv[optind], &err, &err_info, FALSE);
+
+  if (!wth) {
+    fprintf(stderr, "editcap: Can't open %s: %s\n", argv[optind],
+        wtap_strerror(err));
+    switch (err) {
+
+    case WTAP_ERR_UNSUPPORTED:
+    case WTAP_ERR_UNSUPPORTED_ENCAP:
+    case WTAP_ERR_BAD_RECORD:
+      fprintf(stderr, "(%s)\n", err_info);
+      g_free(err_info);
+      break;
+    }
+    exit(1);
+  }
+
+  status = process_cap_file(wth);
+  
+  wtap_close(wth);
+  return status;
+}