aboutsummaryrefslogtreecommitdiffstats
path: root/ui/gtk/gsm_map_summary.c
diff options
context:
space:
mode:
Diffstat (limited to 'ui/gtk/gsm_map_summary.c')
-rw-r--r--ui/gtk/gsm_map_summary.c429
1 files changed, 0 insertions, 429 deletions
diff --git a/ui/gtk/gsm_map_summary.c b/ui/gtk/gsm_map_summary.c
deleted file mode 100644
index e258889731..0000000000
--- a/ui/gtk/gsm_map_summary.c
+++ /dev/null
@@ -1,429 +0,0 @@
-/* gsm_map_summary.c
- * Routines for GSM MAP Statictics summary window
- *
- * Copyright 2004, Michael Lum <mlum [AT] telostech.com>
- * In association with Telos Technology Inc.
- *
- * Modified from summary_dlg.c
- *
- * 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 <stdlib.h>
-
-#include <gtk/gtk.h>
-
-#include <epan/packet.h>
-#include <epan/tap.h>
-#include <epan/asn1.h>
-#include <epan/dissectors/packet-gsm_map.h>
-
-#include "globals.h"
-
-#include "ui/simple_dialog.h"
-#include "ui/summary.h"
-
-#include <epan/stat_tap_ui.h>
-#include "ui/gtk/gui_stat_menu.h"
-
-#include "ui/gtk/dlg_utils.h"
-#include "ui/gtk/gui_utils.h"
-
-/** Gsm map statistic data */
-typedef struct _gsm_map_stat_t {
- int opr_code[GSM_MAP_MAX_NUM_OPR_CODES];
- int size[GSM_MAP_MAX_NUM_OPR_CODES];
-
- int opr_code_rr[GSM_MAP_MAX_NUM_OPR_CODES];
- int size_rr[GSM_MAP_MAX_NUM_OPR_CODES];
-} gsm_map_stat_t;
-
-gsm_map_stat_t gsm_map_stat;
-
-#define SUM_STR_MAX 1024
-
-void register_tap_listener_gtk_gsm_map_summary(void);
-
-static void
-add_string_to_box(gchar *str, GtkWidget *box)
-{
- GtkWidget *lb;
- lb = gtk_label_new(str);
- gtk_misc_set_alignment(GTK_MISC(lb), 0.0f, 0.5f);
- gtk_box_pack_start(GTK_BOX(box), lb,FALSE,FALSE, 0);
- gtk_widget_show(lb);
-}
-
-void gsm_map_stat_gtk_sum_cb(GtkAction *action _U_, gpointer user_data _U_)
-{
- summary_tally summary;
- GtkWidget *sum_open_w,
- *main_vb, *file_fr, *data_fr, *file_box,
- *data_box, *bbox, *close_bt,
- *invoke_fr, *invoke_box,
- *rr_fr, *rr_box,
- *tot_fr, *tot_box;
-
- gchar string_buff[SUM_STR_MAX];
- double seconds;
- int i;
- int tot_invokes, tot_rr;
- double tot_invokes_size, tot_rr_size;
-
- if (cfile.state == FILE_CLOSED) {
- return;
- }
-
- /* initialize the tally */
- summary_fill_in(&cfile, &summary);
-
- /* initial computations */
- seconds = summary.stop_time - summary.start_time;
-
- sum_open_w = dlg_window_new("GSM MAP Statistics: Summary"); /* transient_for top_level */
- gtk_window_set_destroy_with_parent (GTK_WINDOW(sum_open_w), TRUE);
-
- /* Container for each row of widgets */
- main_vb = ws_gtk_box_new(GTK_ORIENTATION_VERTICAL, 3, FALSE);
- gtk_container_set_border_width(GTK_CONTAINER(main_vb), 5);
- gtk_container_add(GTK_CONTAINER(sum_open_w), main_vb);
- gtk_widget_show(main_vb);
-
- /* File frame */
- file_fr = gtk_frame_new("File");
- gtk_box_pack_start(GTK_BOX (main_vb), file_fr, TRUE, TRUE, 0);
- gtk_widget_show(file_fr);
-
- file_box = ws_gtk_box_new(GTK_ORIENTATION_VERTICAL, 3, FALSE);
- gtk_container_add(GTK_CONTAINER(file_fr), file_box);
- gtk_widget_show(file_box);
-
- /* filename */
- g_snprintf(string_buff, SUM_STR_MAX, "Name: %s", ((summary.filename) ? summary.filename : "None"));
- add_string_to_box(string_buff, file_box);
-
- /* length */
- g_snprintf(string_buff, SUM_STR_MAX, "Length: %" G_GINT64_MODIFIER "d", summary.file_length);
- add_string_to_box(string_buff, file_box);
-
- /* format */
- g_snprintf(string_buff, SUM_STR_MAX, "Format: %s", wtap_file_type_subtype_string(summary.file_type));
- add_string_to_box(string_buff, file_box);
-
- if (summary.snap != 0) {
- /* snapshot length */
- g_snprintf(string_buff, SUM_STR_MAX, "Snapshot length: %u", summary.snap);
- add_string_to_box(string_buff, file_box);
- }
-
- /* Data frame */
- data_fr = gtk_frame_new("Data");
- gtk_box_pack_start(GTK_BOX (main_vb), data_fr, TRUE, TRUE, 0);
- gtk_widget_show(data_fr);
-
- data_box = ws_gtk_box_new(GTK_ORIENTATION_VERTICAL, 3, FALSE);
- gtk_container_add(GTK_CONTAINER(data_fr), data_box);
- gtk_widget_show(data_box);
-
- /*
- * We must have no un-time-stamped packets (i.e., the number of
- * time-stamped packets must be the same as the number of packets),
- * and at least two time-stamped packets, in order for the elapsed
- * time to be valid.
- */
- if (summary.packet_count_ts == summary.packet_count &&
- summary.packet_count_ts >= 2) {
- /* seconds */
- g_snprintf(string_buff, SUM_STR_MAX, "Elapsed time: %.3f seconds", summary.elapsed_time);
- add_string_to_box(string_buff, data_box);
-
- g_snprintf(string_buff, SUM_STR_MAX, "Between first and last packet: %.3f seconds", seconds);
- add_string_to_box(string_buff, data_box);
- }
-
- /* Packet count */
- g_snprintf(string_buff, SUM_STR_MAX, "Packet count: %i", summary.packet_count);
- add_string_to_box(string_buff, data_box);
-
- tot_invokes = 0;
- tot_invokes_size = 0;
- for (i=0; i < GSM_MAP_MAX_NUM_OPR_CODES; i++)
- {
- tot_invokes += gsm_map_stat.opr_code[i];
- tot_invokes_size += gsm_map_stat.size[i];
- }
-
- tot_rr = 0;
- tot_rr_size = 0;
- for (i=0; i < GSM_MAP_MAX_NUM_OPR_CODES; i++)
- {
- tot_rr += gsm_map_stat.opr_code_rr[i];
- tot_rr_size += gsm_map_stat.size_rr[i];
- }
-
- /* Invoke frame */
- invoke_fr = gtk_frame_new("Invokes");
- gtk_box_pack_start(GTK_BOX (main_vb), invoke_fr, TRUE, TRUE, 0);
- gtk_widget_show(invoke_fr);
-
- invoke_box = ws_gtk_box_new(GTK_ORIENTATION_VERTICAL, 3, FALSE);
- gtk_container_add(GTK_CONTAINER(invoke_fr), invoke_box);
- gtk_widget_show(invoke_box);
-
- /* Total number of invokes */
- g_snprintf(string_buff, SUM_STR_MAX, "Total number of Invokes: %u", tot_invokes);
- add_string_to_box(string_buff, invoke_box);
-
- /*
- * We must have no un-time-stamped packets (i.e., the number of
- * time-stamped packets must be the same as the number of packets),
- * and at least two time-stamped packets, in order for the elapsed
- * time to be valid.
- */
- if (summary.packet_count_ts == summary.packet_count &&
- summary.packet_count_ts >= 2) {
- /* Total number of invokes per second */
- if (seconds)
- g_snprintf(string_buff, SUM_STR_MAX, "Total number of Invokes per second: %.2f", tot_invokes/seconds);
- else
- g_snprintf(string_buff, SUM_STR_MAX, "Total number of Invokes per second: N/A");
- add_string_to_box(string_buff, invoke_box);
- }
-
- /* Total size of invokes */
- g_snprintf(string_buff, SUM_STR_MAX, "Total number of bytes for Invokes: %.0f", tot_invokes_size);
- add_string_to_box(string_buff, invoke_box);
-
- /* Average size of invokes */
- if (tot_invokes)
- g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes per Invoke: %.2f", tot_invokes_size/tot_invokes);
- else
- g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes per Invoke: N/A");
- add_string_to_box(string_buff, invoke_box);
-
- /*
- * We must have no un-time-stamped packets (i.e., the number of
- * time-stamped packets must be the same as the number of packets),
- * and at least two time-stamped packets, in order for the elapsed
- * time to be valid.
- */
- if (summary.packet_count_ts == summary.packet_count &&
- summary.packet_count_ts >= 2) {
- /* Average size of invokes per second */
- if (seconds)
- g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes per second: %.2f", tot_invokes_size/seconds);
- else
- g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes per second: N/A");
- add_string_to_box(string_buff, invoke_box);
- }
-
- /* Return Results frame */
- rr_fr = gtk_frame_new("Return Results");
- gtk_box_pack_start(GTK_BOX (main_vb), rr_fr, TRUE, TRUE, 0);
- gtk_widget_show(rr_fr);
-
- rr_box = ws_gtk_box_new(GTK_ORIENTATION_VERTICAL, 3, FALSE);
- gtk_container_add(GTK_CONTAINER(rr_fr), rr_box);
- gtk_widget_show(rr_box);
-
- /* Total number of return results */
- g_snprintf(string_buff, SUM_STR_MAX, "Total number of Return Results: %u", tot_rr);
- add_string_to_box(string_buff, rr_box);
-
- /*
- * We must have no un-time-stamped packets (i.e., the number of
- * time-stamped packets must be the same as the number of packets),
- * and at least two time-stamped packets, in order for the elapsed
- * time to be valid.
- */
- if (summary.packet_count_ts == summary.packet_count &&
- summary.packet_count_ts >= 2) {
- /* Total number of return results per second */
- if (seconds)
- g_snprintf(string_buff, SUM_STR_MAX, "Total number of Return Results per second: %.2f", tot_rr/seconds);
- else
- g_snprintf(string_buff, SUM_STR_MAX, "Total number of Return Results per second: N/A");
- add_string_to_box(string_buff, rr_box);
- }
-
- /* Total size of return results */
- g_snprintf(string_buff, SUM_STR_MAX, "Total number of bytes for Return Results: %.0f", tot_rr_size);
- add_string_to_box(string_buff, rr_box);
-
- /* Average size of return results */
- if (tot_rr)
- g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes per Return Result: %.2f", tot_rr_size/tot_rr);
- else
- g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes per Return Result: N/A");
- add_string_to_box(string_buff, rr_box);
-
- /*
- * We must have no un-time-stamped packets (i.e., the number of
- * time-stamped packets must be the same as the number of packets),
- * and at least two time-stamped packets, in order for the elapsed
- * time to be valid.
- */
- if (summary.packet_count_ts == summary.packet_count &&
- summary.packet_count_ts >= 2) {
- /* Average size of return results per second */
- if (seconds)
- g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes per second: %.2f", tot_rr_size/seconds);
- else
- g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes per second: N/A");
- add_string_to_box(string_buff, rr_box);
- }
-
- /* Totals frame */
- tot_fr = gtk_frame_new("Totals");
- gtk_box_pack_start(GTK_BOX (main_vb), tot_fr, TRUE, TRUE, 0);
- gtk_widget_show(tot_fr);
-
- tot_box = ws_gtk_box_new(GTK_ORIENTATION_VERTICAL, 3, FALSE);
- gtk_container_add(GTK_CONTAINER(tot_fr), tot_box);
- gtk_widget_show(tot_box);
-
- /* Total number of return results */
- g_snprintf(string_buff, SUM_STR_MAX, "Total number of GSM MAP messages: %u", tot_invokes + tot_rr);
- add_string_to_box(string_buff, tot_box);
-
- /*
- * We must have no un-time-stamped packets (i.e., the number of
- * time-stamped packets must be the same as the number of packets),
- * and at least two time-stamped packets, in order for the elapsed
- * time to be valid.
- */
- if (summary.packet_count_ts == summary.packet_count &&
- summary.packet_count_ts >= 2) {
- if (seconds)
- g_snprintf(string_buff, SUM_STR_MAX, "Total number of GSM MAP messages per second: %.2f",
- (tot_invokes + tot_rr)/seconds);
- else
- g_snprintf(string_buff, SUM_STR_MAX, "Total number of GSM MAP messages per second: N/A");
- add_string_to_box(string_buff, tot_box);
- }
-
- g_snprintf(string_buff, SUM_STR_MAX, "Total number of bytes for GSM MAP messages: %.0f", tot_invokes_size + tot_rr_size);
- add_string_to_box(string_buff, tot_box);
-
- if (tot_invokes + tot_rr)
- g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes per GSM MAP messages: %.2f",
- (tot_invokes_size + tot_rr_size)/(tot_invokes + tot_rr));
- else
- g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes per GSM MAP messages: N/A");
- add_string_to_box(string_buff, tot_box);
-
- /*
- * We must have no un-time-stamped packets (i.e., the number of
- * time-stamped packets must be the same as the number of packets),
- * and at least two time-stamped packets, in order for the elapsed
- * time to be valid.
- */
- if (summary.packet_count_ts == summary.packet_count &&
- summary.packet_count_ts >= 2) {
- if (seconds)
- g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes second: %.2f",
- (tot_invokes_size + tot_rr_size)/seconds);
- else
- g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes second: N/A");
- add_string_to_box(string_buff, tot_box);
- }
-
- /* Button row. */
- bbox = dlg_button_row_new(GTK_STOCK_CLOSE, NULL);
- gtk_box_pack_start(GTK_BOX(main_vb), bbox, TRUE, TRUE, 0);
- gtk_widget_show(bbox);
-
- close_bt = (GtkWidget *)g_object_get_data(G_OBJECT(bbox), GTK_STOCK_CLOSE);
- window_set_cancel_button(sum_open_w, close_bt, window_cancel_button_cb);
-
- g_signal_connect(sum_open_w, "delete_event", G_CALLBACK(window_delete_event_cb), NULL);
-
- gtk_widget_show(sum_open_w);
- window_present(sum_open_w);
-}
-
-static void
-gsm_map_summary_reset(void *tapdata)
-{
- gsm_map_stat_t *stat_p = (gsm_map_stat_t *)tapdata;
-
- memset(stat_p, 0, sizeof(gsm_map_stat_t));
-}
-
-
-static gboolean
-gsm_map_summary_packet(
- void *tapdata,
- packet_info *pinfo _U_,
- epan_dissect_t *edt _U_,
- const void *data)
-{
- gsm_map_stat_t *stat_p = (gsm_map_stat_t *)tapdata;
- const gsm_map_tap_rec_t *data_p = (const gsm_map_tap_rec_t *)data;
-
- if (data_p->invoke)
- {
- stat_p->opr_code[data_p->opcode]++;
- stat_p->size[data_p->opcode] += data_p->size;
- }
- else
- {
- stat_p->opr_code_rr[data_p->opcode]++;
- stat_p->size_rr[data_p->opcode] += data_p->size;
- }
-
- return(FALSE); /* We have no draw callback */
-}
-
-void
-register_tap_listener_gtk_gsm_map_summary(void)
-{
- GString *err_p;
-
- memset((void *) &gsm_map_stat, 0, sizeof(gsm_map_stat_t));
-
- err_p =
- register_tap_listener("gsm_map", &gsm_map_stat, NULL, 0,
- gsm_map_summary_reset,
- gsm_map_summary_packet,
- NULL);
-
- if (err_p != NULL)
- {
- simple_dialog(ESD_TYPE_ERROR, ESD_BTN_OK, "%s", err_p->str);
- g_string_free(err_p, TRUE);
-
- exit(1);
- }
-}
-
-/*
- * 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:
- */