wmem: allow wmem_destroy_list to ignore a NULL list.
[metze/wireshark/wip.git] / ringbuffer.h
index c905b4b89303b072f5b5fb5903d7bfe74fc4aaf4..b56fa056fa4377e5ec15ee9d4632dac17661e748 100644 (file)
@@ -1,50 +1,48 @@
-/* capture.h
- * Definitions for packet capture windows
+/* ringbuffer.h
+ * Definitions for capture ringbuffer files
  *
- * $Id: ringbuffer.h,v 1.3 2003/06/22 16:06:03 deniel Exp $
- *
- * Ethereal - Network traffic analyzer
- * By Gerald Combs <gerald@ethereal.com>
+ * Wireshark - Network traffic analyzer
+ * By Gerald Combs <gerald@wireshark.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.
+ * SPDX-License-Identifier: GPL-2.0-or-later
  */
 
 #ifndef __RINGBUFFER_H__
 #define __RINGBUFFER_H__
 
-#ifdef HAVE_LIBPCAP
-
 #include <stdio.h>
-#include "file.h"
 #include "wiretap/wtap.h"
 
 #define RINGBUFFER_UNLIMITED_FILES 0
-/* minimum number of ringbuffer files */
+/* Minimum number of ringbuffer files */
 #define RINGBUFFER_MIN_NUM_FILES 0
-/* maximum number of ringbuffer files */
-#define RINGBUFFER_MAX_NUM_FILES 1024
+/* Maximum number of ringbuffer files */
+/* Avoid crashes on very large numbers. Should be a power of 10 */
+#define RINGBUFFER_MAX_NUM_FILES 100000
+/* Maximum number for FAT filesystems */
+#define RINGBUFFER_WARN_NUM_FILES 65535
 
-int ringbuf_init(const char *capture_name, guint num_files);
-wtap_dumper* ringbuf_init_wtap_dump_fdopen(int filetype, int linktype,
-  int snaplen, int *err);
-gboolean ringbuf_switch_file(capture_file *cf, wtap_dumper **pdh, int *err);
-gboolean ringbuf_wtap_dump_close(capture_file *cf, int *err);
+int ringbuf_init(const char *capture_name, guint num_files, gboolean group_read_access);
+const gchar *ringbuf_current_filename(void);
+FILE *ringbuf_init_libpcap_fdopen(int *err);
+gboolean ringbuf_switch_file(FILE **pdh, gchar **save_file, int *save_file_fd,
+                             int *err);
+gboolean ringbuf_libpcap_dump_close(gchar **save_file, int *err);
 void ringbuf_free(void);
 void ringbuf_error_cleanup(void);
 
-#endif /* HAVE_LIBPCAP */
-
 #endif /* ringbuffer.h */
+
+/*
+ * Editor modelines  -  http://www.wireshark.org/tools/modelines.html
+ *
+ * Local Variables:
+ * c-basic-offset: 2
+ * tab-width: 8
+ * indent-tabs-mode: nil
+ * End:
+ *
+ * vi: set shiftwidth=2 tabstop=8 expandtab:
+ * :indentSize=2:tabSize=8:noTabs=true:
+ */