summaryrefslogtreecommitdiff
path: root/ui
diff options
context:
space:
mode:
authorGuy Harris <guy@alum.mit.edu>2017-04-23 16:48:17 -0700
committerGuy Harris <guy@alum.mit.edu>2017-04-24 03:38:21 +0000
commite52c95c6c8cdac34eccdba9b49d68a6982685f1a (patch)
treefc479aac517dbee8b5a6a82ea33ec40a482cc248 /ui
parent751e078d2bc6adf1179de164291eb743abd8732b (diff)
downloadwireshark-e52c95c6c8cdac34eccdba9b49d68a6982685f1a.tar.gz
Move UI-only stuff out of libwireshark.
Packet ranges are used only in the UI; move the packet range stuff into libui. Don't pass a print_args_t structure to libwireshark packet-printing routines, just pass the few parameters they need. Move the declaration of print_args_t into file.h. Change-Id: Icff5991eea7d7d56f33b4716105895263d275bcf Reviewed-on: https://code.wireshark.org/review/21308 Petri-Dish: Guy Harris <guy@alum.mit.edu> Tested-by: Petri Dish Buildbot <buildbot-no-reply@wireshark.org> Reviewed-by: Guy Harris <guy@alum.mit.edu>
Diffstat (limited to 'ui')
-rw-r--r--ui/CMakeLists.txt1
-rw-r--r--ui/Makefile.am2
-rw-r--r--ui/packet_range.c379
-rw-r--r--ui/packet_range.h117
-rw-r--r--ui/qt/capture_file_dialog.cpp2
-rw-r--r--ui/qt/export_dissection_dialog.cpp2
-rw-r--r--ui/qt/packet_range_group_box.h2
7 files changed, 502 insertions, 3 deletions
diff --git a/ui/CMakeLists.txt b/ui/CMakeLists.txt
index d1f778ee77..8a52ef9463 100644
--- a/ui/CMakeLists.txt
+++ b/ui/CMakeLists.txt
@@ -39,6 +39,7 @@ set(COMMON_UI_SRC
language.c
mcast_stream.c
packet_list_utils.c
+ packet_range.c
persfilepath_opt.c
preference_utils.c
profile.c
diff --git a/ui/Makefile.am b/ui/Makefile.am
index c7e984162e..776ad4230b 100644
--- a/ui/Makefile.am
+++ b/ui/Makefile.am
@@ -66,6 +66,7 @@ WIRESHARK_UI_SRC = \
help_url.c \
mcast_stream.c \
packet_list_utils.c \
+ packet_range.c \
persfilepath_opt.c \
preference_utils.c \
profile.c \
@@ -113,6 +114,7 @@ WIRESHARK_UI_INCLUDES = \
language.h \
mcast_stream.h \
main_statusbar.h \
+ packet_range.h \
persfilepath_opt.h \
preference_utils.h \
profile.h \
diff --git a/ui/packet_range.c b/ui/packet_range.c
new file mode 100644
index 0000000000..a6797e3110
--- /dev/null
+++ b/ui/packet_range.c
@@ -0,0 +1,379 @@
+/* packet_range.c
+ * Packet range routines (save, print, ...)
+ *
+ * Dick Gooris <gooris@lucent.com>
+ * Ulf Lamping <ulf.lamping@web.de>
+ *
+ * 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
+ */
+
+#include "config.h"
+
+#include <string.h>
+
+#include <glib.h>
+
+#include <epan/frame_data.h>
+
+#include "packet_range.h"
+
+/* (re-)calculate the packet counts (except the user specified range) */
+static void packet_range_calc(packet_range_t *range) {
+ guint32 framenum;
+ guint32 mark_low;
+ guint32 mark_high;
+ guint32 displayed_mark_low;
+ guint32 displayed_mark_high;
+ frame_data *packet;
+
+
+ range->selected_packet = 0;
+
+ mark_low = 0;
+ mark_high = 0;
+ range->mark_range_cnt = 0;
+ range->ignored_cnt = 0;
+ range->ignored_marked_cnt = 0;
+ range->ignored_mark_range_cnt = 0;
+ range->ignored_user_range_cnt = 0;
+
+ displayed_mark_low = 0;
+ displayed_mark_high = 0;
+
+ range->displayed_cnt = 0;
+ range->displayed_marked_cnt = 0;
+ range->displayed_mark_range_cnt = 0;
+ range->displayed_plus_dependents_cnt = 0;
+ range->displayed_ignored_cnt = 0;
+ range->displayed_ignored_marked_cnt = 0;
+ range->displayed_ignored_mark_range_cnt = 0;
+ range->displayed_ignored_user_range_cnt = 0;
+
+ g_assert(range->cf != NULL);
+
+ /* XXX - this doesn't work unless you have a full set of frame_data
+ * structures for all packets in the capture, which is not,
+ * for example, the case when TShark is doing a one-pass
+ * read of a file or a live capture.
+ *
+ * It's also horribly slow on large captures, causing it to
+ * take a long time for the Save As dialog to pop up, for
+ * example. We should really keep these statistics in
+ * the capture_file structure, updating them whenever we
+ * filter the display, etc..
+ */
+ if (range->cf->frames != NULL) {
+ /* The next for-loop is used to obtain the amount of packets
+ * to be processed and is used to present the information in
+ * the Save/Print As widget.
+ * We have different types of ranges: All the packets, the number
+ * of packets of a marked range, a single packet, and a user specified
+ * packet range. The last one is not calculated here since this
+ * data must be entered in the widget by the user.
+ */
+
+ for(framenum = 1; framenum <= range->cf->count; framenum++) {
+ packet = frame_data_sequence_find(range->cf->frames, framenum);
+
+ if (range->cf->current_frame == packet) {
+ range->selected_packet = framenum;
+ }
+ if (packet->flags.passed_dfilter) {
+ range->displayed_cnt++;
+ }
+ if (packet->flags.passed_dfilter ||
+ packet->flags.dependent_of_displayed) {
+ range->displayed_plus_dependents_cnt++;
+ }
+ if (packet->flags.marked) {
+ if (packet->flags.ignored) {
+ range->ignored_marked_cnt++;
+ }
+ if (packet->flags.passed_dfilter) {
+ range->displayed_marked_cnt++;
+ if (packet->flags.ignored) {
+ range->displayed_ignored_marked_cnt++;
+ }
+ if (displayed_mark_low == 0) {
+ displayed_mark_low = framenum;
+ }
+ if (framenum > displayed_mark_high) {
+ displayed_mark_high = framenum;
+ }
+ }
+
+ if (mark_low == 0) {
+ mark_low = framenum;
+ }
+ if (framenum > mark_high) {
+ mark_high = framenum;
+ }
+ }
+ if (packet->flags.ignored) {
+ range->ignored_cnt++;
+ if (packet->flags.passed_dfilter) {
+ range->displayed_ignored_cnt++;
+ }
+ }
+ }
+
+ for(framenum = 1; framenum <= range->cf->count; framenum++) {
+ packet = frame_data_sequence_find(range->cf->frames, framenum);
+
+ if (framenum >= mark_low &&
+ framenum <= mark_high)
+ {
+ range->mark_range_cnt++;
+ if (packet->flags.ignored) {
+ range->ignored_mark_range_cnt++;
+ }
+ }
+
+ if (framenum >= displayed_mark_low &&
+ framenum <= displayed_mark_high)
+ {
+ if (packet->flags.passed_dfilter) {
+ range->displayed_mark_range_cnt++;
+ if (packet->flags.ignored) {
+ range->displayed_ignored_mark_range_cnt++;
+ }
+ }
+ }
+ }
+
+#if 0
+ /* in case we marked just one packet, we add 1. */
+ if (range->cf->marked_count != 0) {
+ range->mark_range = mark_high - mark_low + 1;
+ }
+
+ /* in case we marked just one packet, we add 1. */
+ if (range->displayed_marked_cnt != 0) {
+ range->displayed_mark_range = displayed_mark_high - displayed_mark_low + 1;
+ }
+#endif
+ }
+}
+
+
+/* (re-)calculate the user specified packet range counts */
+static void packet_range_calc_user(packet_range_t *range) {
+ guint32 framenum;
+ frame_data *packet;
+
+ range->user_range_cnt = 0;
+ range->ignored_user_range_cnt = 0;
+ range->displayed_user_range_cnt = 0;
+ range->displayed_ignored_user_range_cnt = 0;
+
+ g_assert(range->cf != NULL);
+
+ /* XXX - this doesn't work unless you have a full set of frame_data
+ * structures for all packets in the capture, which is not,
+ * for example, the case when TShark is doing a one-pass
+ * read of a file or a live capture.
+ *
+ * It's also horribly slow on large captures, causing it to
+ * take a long time for the Save As dialog to pop up, for
+ * example. This obviously can't be kept in the capture_file
+ * structure and recalculated whenever we filter the display
+ * or mark frames as ignored, as the results of this depend
+ * on what the user specifies. In some cases, limiting the
+ * frame_data structures at which we look to the ones specified
+ * by the user might help, but if most of the frames are in
+ * the range, that won't help. In that case, if we could
+ * examine the *complement* of the range, and *subtract* them
+ * from the statistics for the capture as a whole, that might
+ * help, but if the user specified about *half* the packets in
+ * the range, that won't help, either.
+ */
+ if (range->cf->frames != NULL) {
+ for(framenum = 1; framenum <= range->cf->count; framenum++) {
+ packet = frame_data_sequence_find(range->cf->frames, framenum);
+
+ if (value_is_in_range(range->user_range, framenum)) {
+ range->user_range_cnt++;
+ if (packet->flags.ignored) {
+ range->ignored_user_range_cnt++;
+ }
+ if (packet->flags.passed_dfilter) {
+ range->displayed_user_range_cnt++;
+ if (packet->flags.ignored) {
+ range->displayed_ignored_user_range_cnt++;
+ }
+ }
+ }
+ }
+ }
+}
+
+
+/* init the range struct */
+void packet_range_init(packet_range_t *range, capture_file *cf) {
+
+ memset(range, 0, sizeof(packet_range_t));
+ range->process = range_process_all;
+ range->user_range = NULL;
+ range->cf = cf;
+
+ /* calculate all packet range counters */
+ packet_range_calc(range);
+ packet_range_calc_user(range);
+}
+
+/* check whether the packet range is OK */
+convert_ret_t packet_range_check(packet_range_t *range) {
+ if (range->process == range_process_user_range && range->user_range == NULL) {
+ /* Not valid - return the error. */
+ return range->user_range_status;
+ }
+ return CVT_NO_ERROR;
+}
+
+/* init the processing run */
+void packet_range_process_init(packet_range_t *range) {
+ /* Check that, if an explicit range was selected, it's valid. */
+ /* "enumeration" values */
+ range->marked_range_active = FALSE;
+ range->selected_done = FALSE;
+
+ if (range->process_filtered == FALSE) {
+ range->marked_range_left = range->mark_range_cnt;
+ } else {
+ range->marked_range_left = range->displayed_mark_range_cnt;
+ }
+}
+
+/* do we have to process all packets? */
+gboolean packet_range_process_all(packet_range_t *range) {
+ return range->process == range_process_all && !range->process_filtered && !range->remove_ignored;
+}
+
+/* do we have to process this packet? */
+range_process_e packet_range_process_packet(packet_range_t *range, frame_data *fdata) {
+
+ if (range->remove_ignored && fdata->flags.ignored) {
+ return range_process_next;
+ }
+
+ g_assert(range->cf != NULL);
+
+ switch(range->process) {
+ case(range_process_all):
+ break;
+ case(range_process_selected):
+ if (range->selected_done) {
+ return range_processing_finished;
+ }
+ if (fdata->num != range->cf->current_frame->num) {
+ return range_process_next;
+ }
+ range->selected_done = TRUE;
+ break;
+ case(range_process_marked):
+ if (fdata->flags.marked == FALSE) {
+ return range_process_next;
+ }
+ break;
+ case(range_process_marked_range):
+ if (range->marked_range_left == 0) {
+ return range_processing_finished;
+ }
+ if (fdata->flags.marked == TRUE) {
+ range->marked_range_active = TRUE;
+ }
+ if (range->marked_range_active == FALSE ) {
+ return range_process_next;
+ }
+ if (!range->process_filtered ||
+ (range->process_filtered && fdata->flags.passed_dfilter == TRUE))
+ {
+ range->marked_range_left--;
+ }
+ break;
+ case(range_process_user_range):
+ if (value_is_in_range(range->user_range, fdata->num) == FALSE) {
+ return range_process_next;
+ }
+ break;
+ default:
+ g_assert_not_reached();
+ }
+
+ /* This packet has to pass the display filter but didn't?
+ * Try next, but only if we're not including dependent packets and this
+ * packet happens to be a dependency on something that is displayed.
+ */
+ if ((range->process_filtered && fdata->flags.passed_dfilter == FALSE) &&
+ !(range->include_dependents && fdata->flags.dependent_of_displayed)) {
+ return range_process_next;
+ }
+
+ /* We fell through the conditions above, so we accept this packet */
+ return range_process_this;
+}
+
+
+/******************** Range Entry Parser *********************************/
+
+/* Converts a range string to a user range.
+ * The parameter 'es' points to the string to be converted, and is defined in
+ * the Save/Print-As widget.
+ */
+
+void packet_range_convert_str(packet_range_t *range, const gchar *es)
+{
+ range_t *new_range;
+ convert_ret_t ret;
+
+ if (range->user_range != NULL)
+ wmem_free(NULL, range->user_range);
+
+ g_assert(range->cf != NULL);
+
+ ret = range_convert_str(NULL, &new_range, es, range->cf->count);
+ if (ret != CVT_NO_ERROR) {
+ /* range isn't valid */
+ range->user_range = NULL;
+ range->user_range_status = ret;
+ range->user_range_cnt = 0;
+ range->ignored_user_range_cnt = 0;
+ range->displayed_user_range_cnt = 0;
+ range->displayed_ignored_user_range_cnt = 0;
+ return;
+ }
+ range->user_range = new_range;
+
+ /* calculate new user specified packet range counts */
+ packet_range_calc_user(range);
+} /* packet_range_convert_str */
+
+
+/*
+ * Editor modelines - http://www.wireshark.org/tools/modelines.html
+ *
+ * Local variables:
+ * c-basic-offset: 4
+ * tab-width: 8
+ * indent-tabs-mode: nil
+ * End:
+ *
+ * vi: set shiftwidth=4 tabstop=8 expandtab:
+ * :indentSize=4:tabSize=8:noTabs=true:
+ */
diff --git a/ui/packet_range.h b/ui/packet_range.h
new file mode 100644
index 0000000000..49e8cdbbd3
--- /dev/null
+++ b/ui/packet_range.h
@@ -0,0 +1,117 @@
+/* packet_range.h
+ * Packet range routines (save, print, ...)
+ *
+ * Dick Gooris <gooris@lucent.com>
+ * Ulf Lamping <ulf.lamping@web.de>
+ *
+ * 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
+ */
+
+#ifndef __PACKET_RANGE_H__
+#define __PACKET_RANGE_H__
+
+#ifdef __cplusplus
+extern "C" {
+#endif /* __cplusplus */
+
+#include <glib.h>
+
+#include <epan/range.h>
+
+#include "cfile.h"
+
+extern guint32 curr_selected_frame;
+
+typedef enum {
+ range_process_all,
+ range_process_selected,
+ range_process_marked,
+ range_process_marked_range,
+ range_process_user_range
+} packet_range_e;
+
+typedef struct packet_range_tag {
+ /* values coming from the UI */
+ packet_range_e process; /* which range to process */
+ gboolean process_filtered; /* captured or filtered packets */
+ gboolean remove_ignored; /* remove ignored packets */
+ gboolean include_dependents; /* True if packets which are dependents of others should be processed */
+
+ /* user specified range(s) and, if null, error status */
+ range_t *user_range;
+ convert_ret_t user_range_status;
+
+ /* calculated values */
+ guint32 selected_packet; /* the currently selected packet */
+
+ /* current packet counts (captured) */
+ capture_file *cf; /* Associated capture file. */
+ guint32 mark_range_cnt; /* packets in marked range */
+ guint32 user_range_cnt; /* packets in user specified range */
+ guint32 ignored_cnt; /* packets ignored */
+ guint32 ignored_marked_cnt; /* packets ignored and marked */
+ guint32 ignored_mark_range_cnt; /* packets ignored in marked range */
+ guint32 ignored_user_range_cnt; /* packets ignored in user specified range */
+
+ /* current packet counts (displayed) */
+ guint32 displayed_cnt;
+ guint32 displayed_plus_dependents_cnt;
+ guint32 displayed_marked_cnt;
+ guint32 displayed_mark_range_cnt;
+ guint32 displayed_user_range_cnt;
+ guint32 displayed_ignored_cnt;
+ guint32 displayed_ignored_marked_cnt;
+ guint32 displayed_ignored_mark_range_cnt;
+ guint32 displayed_ignored_user_range_cnt;
+
+ /* "enumeration" values */
+ gboolean marked_range_active; /* marked range is currently processed */
+ guint32 marked_range_left; /* marked range packets left to do */
+ gboolean selected_done; /* selected packet already processed */
+} packet_range_t;
+
+typedef enum {
+ range_process_this, /* process this packet */
+ range_process_next, /* skip this packet, process next */
+ range_processing_finished /* stop processing, required packets done */
+} range_process_e;
+
+/* init the range structure */
+extern void packet_range_init(packet_range_t *range, capture_file *cf);
+
+/* check whether the packet range is OK */
+extern convert_ret_t packet_range_check(packet_range_t *range);
+
+/* init the processing run */
+extern void packet_range_process_init(packet_range_t *range);
+
+/* do we have to process all packets? */
+extern gboolean packet_range_process_all(packet_range_t *range);
+
+/* do we have to process this packet? */
+extern range_process_e packet_range_process_packet(packet_range_t *range, frame_data *fdata);
+
+/* convert user given string to the internal user specified range representation */
+extern void packet_range_convert_str(packet_range_t *range, const gchar *es);
+
+#ifdef __cplusplus
+}
+#endif /* __cplusplus */
+
+#endif /* __PACKET_RANGE_H__ */
diff --git a/ui/qt/capture_file_dialog.cpp b/ui/qt/capture_file_dialog.cpp
index cb83f4c6a6..1d6bff7525 100644
--- a/ui/qt/capture_file_dialog.cpp
+++ b/ui/qt/capture_file_dialog.cpp
@@ -26,7 +26,7 @@
#ifdef Q_OS_WIN
#include <windows.h>
-#include "epan/packet_range.h"
+#include "ui/packet_range.h"
#include "ui/win32/file_dlg_win32.h"
#else // Q_OS_WIN
diff --git a/ui/qt/export_dissection_dialog.cpp b/ui/qt/export_dissection_dialog.cpp
index 24db5d4923..8dd70dd1c7 100644
--- a/ui/qt/export_dissection_dialog.cpp
+++ b/ui/qt/export_dissection_dialog.cpp
@@ -23,7 +23,7 @@
#ifdef Q_OS_WIN
#include <windows.h>
-#include "epan/packet_range.h"
+#include "ui/packet_range.h"
#include "ui/win32/file_dlg_win32.h"
#else // Q_OS_WIN
diff --git a/ui/qt/packet_range_group_box.h b/ui/qt/packet_range_group_box.h
index 769f75fc38..7a96e5862f 100644
--- a/ui/qt/packet_range_group_box.h
+++ b/ui/qt/packet_range_group_box.h
@@ -26,7 +26,7 @@
#include <glib.h>
-#include "epan/packet_range.h"
+#include "ui/packet_range.h"
#include "syntax_line_edit.h"
#include <QGroupBox>