Suppress invalid or non-meaningful statistics - for example, without
[obnox/wireshark/wip.git] / ui / gtk / gsm_map_summary.c
1 /* gsm_map_summary.c
2  * Routines for GSM MAP Statictics summary window
3  *
4  * Copyright 2004, Michael Lum <mlum [AT] telostech.com>
5  * In association with Telos Technology Inc.
6  *
7  * Modified from summary_dlg.c
8  *
9  * $Id$
10  *
11  * Wireshark - Network traffic analyzer
12  * By Gerald Combs <gerald@wireshark.org>
13  * Copyright 1998 Gerald Combs
14  *
15  * This program is free software; you can redistribute it and/or
16  * modify it under the terms of the GNU General Public License
17  * as published by the Free Software Foundation; either version 2
18  * of the License, or (at your option) any later version.
19  *
20  * This program is distributed in the hope that it will be useful,
21  * but WITHOUT ANY WARRANTY; without even the implied warranty of
22  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
23  * GNU General Public License for more details.
24  *
25  * You should have received a copy of the GNU General Public License
26  * along with this program; if not, write to the Free Software
27  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
28  */
29
30 #ifdef HAVE_CONFIG_H
31 # include "config.h"
32 #endif
33
34 #ifdef HAVE_SYS_TYPES_H
35 #include <sys/types.h>
36 #endif
37
38 #include <gtk/gtk.h>
39
40 #include <wiretap/wtap.h>
41
42 #include <epan/epan.h>
43 #include <epan/packet.h>
44 #include <epan/packet_info.h>
45 #include <epan/value_string.h>
46 #include <epan/tap.h>
47 #include <epan/asn1.h>
48 #include <epan/dissectors/packet-gsm_map.h>
49
50 #include "../stat_menu.h"
51 #include "../globals.h"
52 #include "../file.h"
53 #include "../summary.h"
54
55 #include "ui/gtk/gui_stat_menu.h"
56 #include "ui/gtk/dlg_utils.h"
57 #include "ui/gtk/gui_utils.h"
58 #include "ui/gtk/gsm_map_stat.h"
59
60
61 #define SUM_STR_MAX 1024
62
63
64 static void
65 add_string_to_box(gchar *str, GtkWidget *box)
66 {
67   GtkWidget *lb;
68   lb = gtk_label_new(str);
69   gtk_misc_set_alignment(GTK_MISC(lb), 0.0f, 0.5f);
70   gtk_box_pack_start(GTK_BOX(box), lb,FALSE,FALSE, 0);
71   gtk_widget_show(lb);
72 }
73
74 void gsm_map_stat_gtk_sum_cb(GtkAction *action _U_, gpointer user_data _U_)
75 {
76   summary_tally summary;
77   GtkWidget     *sum_open_w,
78                 *main_vb, *file_fr, *data_fr, *file_box,
79                 *data_box, *bbox, *close_bt,
80                 *invoke_fr, *invoke_box,
81                 *rr_fr, *rr_box,
82                 *tot_fr, *tot_box;
83
84   gchar         string_buff[SUM_STR_MAX];
85   double        seconds;
86   int           i;
87   int           tot_invokes, tot_rr;
88   double        tot_invokes_size, tot_rr_size;
89
90   /* initialize the tally */
91   summary_fill_in(&cfile, &summary);
92
93   /* initial computations */
94   seconds = summary.stop_time - summary.start_time;
95
96   sum_open_w = dlg_window_new("GSM MAP Statistics: Summary");  /* transient_for top_level */
97   gtk_window_set_destroy_with_parent (GTK_WINDOW(sum_open_w), TRUE);
98
99   /* Container for each row of widgets */
100   main_vb = gtk_vbox_new(FALSE, 3);
101   gtk_container_set_border_width(GTK_CONTAINER(main_vb), 5);
102   gtk_container_add(GTK_CONTAINER(sum_open_w), main_vb);
103   gtk_widget_show(main_vb);
104
105   /* File frame */
106   file_fr = gtk_frame_new("File");
107   gtk_container_add(GTK_CONTAINER(main_vb), file_fr);
108   gtk_widget_show(file_fr);
109
110   file_box = gtk_vbox_new(FALSE, 3);
111   gtk_container_add(GTK_CONTAINER(file_fr), file_box);
112   gtk_widget_show(file_box);
113
114   /* filename */
115   g_snprintf(string_buff, SUM_STR_MAX, "Name: %s", ((summary.filename) ? summary.filename : "None"));
116   add_string_to_box(string_buff, file_box);
117
118   /* length */
119   g_snprintf(string_buff, SUM_STR_MAX, "Length: %" G_GINT64_MODIFIER "d", summary.file_length);
120   add_string_to_box(string_buff, file_box);
121
122   /* format */
123   g_snprintf(string_buff, SUM_STR_MAX, "Format: %s", wtap_file_type_string(summary.file_type));
124   add_string_to_box(string_buff, file_box);
125
126   if (summary.has_snap) {
127     /* snapshot length */
128     g_snprintf(string_buff, SUM_STR_MAX, "Snapshot length: %u", summary.snap);
129     add_string_to_box(string_buff, file_box);
130   }
131
132   /* Data frame */
133   data_fr = gtk_frame_new("Data");
134   gtk_container_add(GTK_CONTAINER(main_vb), data_fr);
135   gtk_widget_show(data_fr);
136
137   data_box = gtk_vbox_new(FALSE, 3);
138   gtk_container_add(GTK_CONTAINER(data_fr), data_box);
139   gtk_widget_show(data_box);
140
141   /*
142    * We must have no un-time-stamped packets (i.e., the number of
143    * time-stamped packets must be the same as the number of packets),
144    * and at least two time-stamped packets, in order for the elapsed
145    * time to be valid.
146    */
147   if (summary.packet_count_ts == summary.packet_count &&
148       summary.packet_count_ts >= 2) {
149     /* seconds */
150     g_snprintf(string_buff, SUM_STR_MAX, "Elapsed time: %.3f seconds", summary.elapsed_time);
151     add_string_to_box(string_buff, data_box);
152
153     g_snprintf(string_buff, SUM_STR_MAX, "Between first and last packet: %.3f seconds", seconds);
154     add_string_to_box(string_buff, data_box);
155   }
156
157   /* Packet count */
158   g_snprintf(string_buff, SUM_STR_MAX, "Packet count: %i", summary.packet_count);
159   add_string_to_box(string_buff, data_box);
160
161   tot_invokes = 0;
162   tot_invokes_size = 0;
163   for (i=0; i < GSM_MAP_MAX_NUM_OPR_CODES; i++)
164   {
165     tot_invokes += gsm_map_stat.opr_code[i];
166     tot_invokes_size += gsm_map_stat.size[i];
167   }
168
169   tot_rr = 0;
170   tot_rr_size = 0;
171   for (i=0; i < GSM_MAP_MAX_NUM_OPR_CODES; i++)
172   {
173     tot_rr += gsm_map_stat.opr_code_rr[i];
174     tot_rr_size += gsm_map_stat.size_rr[i];
175   }
176
177   /* Invoke frame */
178   invoke_fr = gtk_frame_new("Invokes");
179   gtk_container_add(GTK_CONTAINER(main_vb), invoke_fr);
180   gtk_widget_show(invoke_fr);
181
182   invoke_box = gtk_vbox_new(FALSE, 3);
183   gtk_container_add(GTK_CONTAINER(invoke_fr), invoke_box);
184   gtk_widget_show(invoke_box);
185
186   /* Total number of invokes */
187   g_snprintf(string_buff, SUM_STR_MAX, "Total number of Invokes: %u", tot_invokes);
188   add_string_to_box(string_buff, invoke_box);
189
190   /*
191    * We must have no un-time-stamped packets (i.e., the number of
192    * time-stamped packets must be the same as the number of packets),
193    * and at least two time-stamped packets, in order for the elapsed
194    * time to be valid.
195    */
196   if (summary.packet_count_ts == summary.packet_count &&
197       summary.packet_count_ts >= 2) {
198     /* Total number of invokes per second */
199     if (seconds)
200       g_snprintf(string_buff, SUM_STR_MAX, "Total number of Invokes per second: %.2f", tot_invokes/seconds);
201     else
202       g_snprintf(string_buff, SUM_STR_MAX, "Total number of Invokes per second: N/A");
203     add_string_to_box(string_buff, invoke_box);
204   }
205
206   /* Total size of invokes */
207   g_snprintf(string_buff, SUM_STR_MAX, "Total number of bytes for Invokes: %.0f", tot_invokes_size);
208   add_string_to_box(string_buff, invoke_box);
209
210   /* Average size of invokes */
211   if (tot_invokes)
212     g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes per Invoke: %.2f", tot_invokes_size/tot_invokes);
213   else
214     g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes per Invoke: N/A");
215   add_string_to_box(string_buff, invoke_box);
216
217   /*
218    * We must have no un-time-stamped packets (i.e., the number of
219    * time-stamped packets must be the same as the number of packets),
220    * and at least two time-stamped packets, in order for the elapsed
221    * time to be valid.
222    */
223   if (summary.packet_count_ts == summary.packet_count &&
224       summary.packet_count_ts >= 2) {
225     /* Average size of invokes per second */
226     if (seconds)
227       g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes per second: %.2f", tot_invokes_size/seconds);
228     else
229       g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes per second: N/A");
230     add_string_to_box(string_buff, invoke_box);
231   }
232
233   /* Return Results frame */
234   rr_fr = gtk_frame_new("Return Results");
235   gtk_container_add(GTK_CONTAINER(main_vb), rr_fr);
236   gtk_widget_show(rr_fr);
237
238   rr_box = gtk_vbox_new(FALSE, 3);
239   gtk_container_add(GTK_CONTAINER(rr_fr), rr_box);
240   gtk_widget_show(rr_box);
241
242   /* Total number of return results */
243   g_snprintf(string_buff, SUM_STR_MAX, "Total number of Return Results: %u", tot_rr);
244   add_string_to_box(string_buff, rr_box);
245
246   /*
247    * We must have no un-time-stamped packets (i.e., the number of
248    * time-stamped packets must be the same as the number of packets),
249    * and at least two time-stamped packets, in order for the elapsed
250    * time to be valid.
251    */
252   if (summary.packet_count_ts == summary.packet_count &&
253       summary.packet_count_ts >= 2) {
254     /* Total number of return results per second */
255     if (seconds)
256       g_snprintf(string_buff, SUM_STR_MAX, "Total number of Return Results per second: %.2f", tot_rr/seconds);
257     else
258       g_snprintf(string_buff, SUM_STR_MAX, "Total number of Return Results per second: N/A");
259     add_string_to_box(string_buff, rr_box);
260   }
261
262   /* Total size of return results */
263   g_snprintf(string_buff, SUM_STR_MAX, "Total number of bytes for Return Results: %.0f", tot_rr_size);
264   add_string_to_box(string_buff, rr_box);
265
266   /* Average size of return results */
267   if (tot_rr)
268     g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes per Return Result: %.2f", tot_rr_size/tot_rr);
269   else
270     g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes per Return Result: N/A");
271   add_string_to_box(string_buff, rr_box);
272
273   /*
274    * We must have no un-time-stamped packets (i.e., the number of
275    * time-stamped packets must be the same as the number of packets),
276    * and at least two time-stamped packets, in order for the elapsed
277    * time to be valid.
278    */
279   if (summary.packet_count_ts == summary.packet_count &&
280       summary.packet_count_ts >= 2) {
281     /* Average size of return results per second */
282     if (seconds)
283       g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes per second: %.2f", tot_rr_size/seconds);
284     else
285       g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes per second: N/A");
286     add_string_to_box(string_buff, rr_box);
287   }
288
289   /* Totals frame */
290   tot_fr = gtk_frame_new("Totals");
291   gtk_container_add(GTK_CONTAINER(main_vb), tot_fr);
292   gtk_widget_show(tot_fr);
293
294   tot_box = gtk_vbox_new(FALSE, 3);
295   gtk_container_add(GTK_CONTAINER(tot_fr), tot_box);
296   gtk_widget_show(tot_box);
297
298   /* Total number of return results */
299   g_snprintf(string_buff, SUM_STR_MAX, "Total number of GSM MAP messages: %u", tot_invokes + tot_rr);
300   add_string_to_box(string_buff, tot_box);
301
302   /*
303    * We must have no un-time-stamped packets (i.e., the number of
304    * time-stamped packets must be the same as the number of packets),
305    * and at least two time-stamped packets, in order for the elapsed
306    * time to be valid.
307    */
308   if (summary.packet_count_ts == summary.packet_count &&
309       summary.packet_count_ts >= 2) {
310     if (seconds)
311       g_snprintf(string_buff, SUM_STR_MAX, "Total number of GSM MAP messages per second: %.2f",
312                  (tot_invokes + tot_rr)/seconds);
313     else
314       g_snprintf(string_buff, SUM_STR_MAX, "Total number of GSM MAP messages per second: N/A");
315     add_string_to_box(string_buff, tot_box);
316   }
317
318   g_snprintf(string_buff, SUM_STR_MAX, "Total number of bytes for GSM MAP messages: %.0f", tot_invokes_size + tot_rr_size);
319   add_string_to_box(string_buff, tot_box);
320
321   if (tot_invokes + tot_rr)
322     g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes per GSM MAP messages: %.2f",
323                (tot_invokes_size + tot_rr_size)/(tot_invokes + tot_rr));
324   else
325     g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes per GSM MAP messages: N/A");
326   add_string_to_box(string_buff, tot_box);
327
328   /*
329    * We must have no un-time-stamped packets (i.e., the number of
330    * time-stamped packets must be the same as the number of packets),
331    * and at least two time-stamped packets, in order for the elapsed
332    * time to be valid.
333    */
334   if (summary.packet_count_ts == summary.packet_count &&
335       summary.packet_count_ts >= 2) {
336     if (seconds)
337       g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes second: %.2f",
338                  (tot_invokes_size + tot_rr_size)/seconds);
339     else
340       g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes second: N/A");
341     add_string_to_box(string_buff, tot_box);
342   }
343
344   /* Button row. */
345   bbox = dlg_button_row_new(GTK_STOCK_CLOSE, NULL);
346   gtk_container_add(GTK_CONTAINER(main_vb), bbox);
347   gtk_widget_show(bbox);
348
349   close_bt = g_object_get_data(G_OBJECT(bbox), GTK_STOCK_CLOSE);
350   window_set_cancel_button(sum_open_w, close_bt, window_cancel_button_cb);
351
352   g_signal_connect(sum_open_w, "delete_event", G_CALLBACK(window_delete_event_cb), NULL);
353
354   gtk_widget_show(sum_open_w);
355   window_present(sum_open_w);
356 }
357
358
359 void
360 register_tap_listener_gtkgsm_map_summary(void)
361 {
362 }