2 * Routines for capture file summary window
4 * $Id: summary_dlg.c,v 1.21 2003/12/21 22:32:07 guy Exp $
6 * Ethereal - Network traffic analyzer
7 * By Gerald Combs <gerald@ethereal.com>
8 * Copyright 1998 Gerald Combs
10 * This program is free software; you can redistribute it and/or
11 * modify it under the terms of the GNU General Public License
12 * as published by the Free Software Foundation; either version 2
13 * of the License, or (at your option) any later version.
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
20 * You should have received a copy of the GNU General Public License
21 * along with this program; if not, write to the Free Software
22 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
33 #ifdef NEED_SNPRINTF_H
34 # include "snprintf.h"
38 #include "summary_dlg.h"
39 #include "dlg_utils.h"
41 #include "compat_macros.h"
43 #define SUM_STR_MAX 1024
47 add_string_to_box(gchar *str, GtkWidget *box)
50 lb = gtk_label_new(str);
51 gtk_misc_set_alignment(GTK_MISC(lb), 0.0, 0.5);
52 gtk_box_pack_start(GTK_BOX(box), lb,FALSE,FALSE, 0);
58 summary_open_cb(GtkWidget *w _U_, gpointer d _U_)
60 summary_tally summary;
61 GtkWidget *sum_open_w,
62 *main_vb, *file_fr, *data_fr, *capture_fr, *file_box,
63 *filter_box, *filter_fr,
64 *data_box, *capture_box, *bbox, *close_bt;
66 gchar string_buff[SUM_STR_MAX];
70 /* initialize the tally */
71 summary_fill_in(&summary);
73 /* initial compututations */
74 seconds = summary.stop_time - summary.start_time;
75 sum_open_w = gtk_window_new(GTK_WINDOW_TOPLEVEL);
76 gtk_window_set_title(GTK_WINDOW(sum_open_w), "Ethereal: Summary");
77 SIGNAL_CONNECT(sum_open_w, "realize", window_icon_realize_cb, NULL);
79 /* Container for each row of widgets */
80 main_vb = gtk_vbox_new(FALSE, 3);
81 gtk_container_border_width(GTK_CONTAINER(main_vb), 5);
82 gtk_container_add(GTK_CONTAINER(sum_open_w), main_vb);
83 gtk_widget_show(main_vb);
86 file_fr = gtk_frame_new("File");
87 gtk_container_add(GTK_CONTAINER(main_vb), file_fr);
88 gtk_widget_show(file_fr);
90 file_box = gtk_vbox_new(FALSE, 3);
91 gtk_container_add(GTK_CONTAINER(file_fr), file_box);
92 gtk_widget_show(file_box);
95 snprintf(string_buff, SUM_STR_MAX, "Name: %s", summary.filename);
96 add_string_to_box(string_buff, file_box);
99 snprintf(string_buff, SUM_STR_MAX, "Length: %lu", summary.file_length);
100 add_string_to_box(string_buff, file_box);
103 snprintf(string_buff, SUM_STR_MAX, "Format: %s", wtap_file_type_string(summary.encap_type));
104 add_string_to_box(string_buff, file_box);
106 if (summary.has_snap) {
107 /* snapshot length */
108 snprintf(string_buff, SUM_STR_MAX, "Snapshot length: %u", summary.snap);
109 add_string_to_box(string_buff, file_box);
113 data_fr = gtk_frame_new("Data");
114 gtk_container_add(GTK_CONTAINER(main_vb), data_fr);
115 gtk_widget_show(data_fr);
117 data_box = gtk_vbox_new(FALSE, 3);
118 gtk_container_add(GTK_CONTAINER(data_fr), data_box);
119 gtk_widget_show(data_box);
122 snprintf(string_buff, SUM_STR_MAX, "Elapsed time: %.3f seconds", summary.elapsed_time);
123 add_string_to_box(string_buff, data_box);
125 snprintf(string_buff, SUM_STR_MAX, "Between first and last packet: %.3f seconds", seconds);
126 add_string_to_box(string_buff, data_box);
129 snprintf(string_buff, SUM_STR_MAX, "Packet count: %i", summary.packet_count);
130 add_string_to_box(string_buff, data_box);
132 /* Filtered Packet count */
133 /* Unless there is none filter, we move informations about filtered packets in a separate frame */
134 if (!summary.dfilter)
135 add_string_to_box("Filtered packet count: 0", data_box);
137 /* Marked Packet count */
138 snprintf(string_buff, SUM_STR_MAX, "Marked packet count: %i", summary.marked_count);
139 add_string_to_box(string_buff, data_box);
141 /* Packets per second */
143 snprintf(string_buff, SUM_STR_MAX, "Avg. packets/sec: %.3f", summary.packet_count/seconds);
144 add_string_to_box(string_buff, data_box);
148 if (summary.packet_count > 0){
149 snprintf(string_buff, SUM_STR_MAX, "Avg. packet size: %.3f bytes",
150 (float)summary.bytes/summary.packet_count);
151 add_string_to_box(string_buff, data_box);
155 if (summary.drops_known) {
156 snprintf(string_buff, SUM_STR_MAX, "Dropped packets: %u", summary.drops);
157 add_string_to_box(string_buff, data_box);
161 snprintf(string_buff, SUM_STR_MAX, "Bytes of traffic: %d", summary.bytes);
162 add_string_to_box(string_buff, data_box);
164 /* Bytes per second */
166 snprintf(string_buff, SUM_STR_MAX, "Avg. bytes/sec: %.3f", summary.bytes/seconds);
167 add_string_to_box(string_buff, data_box);
169 /* MBit per second */
170 snprintf(string_buff, SUM_STR_MAX, "Avg. Mbit/sec: %.3f",
171 summary.bytes * 8.0 / (seconds * 1000.0 * 1000.0));
172 add_string_to_box(string_buff, data_box);
175 /* Filtered packets frame */
176 filter_fr = gtk_frame_new("Data in filtered packets");
177 gtk_container_add(GTK_CONTAINER(main_vb), filter_fr);
178 gtk_widget_show(filter_fr);
180 filter_box = gtk_vbox_new( FALSE, 3);
181 gtk_container_add(GTK_CONTAINER(filter_fr), filter_box);
182 gtk_widget_show(filter_box);
184 if (summary.dfilter) {
188 snprintf(string_buff, SUM_STR_MAX, "Display filter: %s", summary.dfilter);
189 add_string_to_box(string_buff, filter_box);
192 seconds = (summary.filtered_stop - summary.filtered_start);
193 snprintf(string_buff, SUM_STR_MAX, "Between first and last packet: %.3f seconds", seconds);
194 add_string_to_box(string_buff, filter_box);
197 snprintf(string_buff, SUM_STR_MAX, "Packet count: %i", summary.filtered_count);
198 add_string_to_box(string_buff, filter_box);
200 /* Packets per second */
202 snprintf(string_buff, SUM_STR_MAX, "Avg. packets/sec: %.3f", summary.filtered_count/seconds);
203 add_string_to_box(string_buff, filter_box);
207 if (summary.filtered_count > 0){
208 snprintf(string_buff, SUM_STR_MAX, "Avg. packet size: %.3f bytes",
209 (float) summary.filtered_bytes/summary.filtered_count);
210 add_string_to_box(string_buff, filter_box);
214 snprintf(string_buff, SUM_STR_MAX, "Bytes of traffic: %d", summary.filtered_bytes);
215 add_string_to_box(string_buff, filter_box);
217 /* Bytes per second */
219 snprintf(string_buff, SUM_STR_MAX, "Avg. bytes/sec: %.3f", summary.filtered_bytes/seconds);
220 add_string_to_box(string_buff, filter_box);
222 /* MBit per second */
223 snprintf(string_buff, SUM_STR_MAX, "Avg. Mbit/sec: %.3f",
224 summary.filtered_bytes * 8.0 / (seconds * 1000.0 * 1000.0));
225 add_string_to_box(string_buff, filter_box);
229 snprintf(string_buff, SUM_STR_MAX, "Display filter: none");
230 add_string_to_box(string_buff, filter_box);
234 capture_fr = gtk_frame_new("Capture");
235 gtk_container_add(GTK_CONTAINER(main_vb), capture_fr);
236 gtk_widget_show(capture_fr);
238 capture_box = gtk_vbox_new(FALSE, 3);
239 gtk_container_add(GTK_CONTAINER(capture_fr), capture_box);
240 gtk_widget_show(capture_box);
244 snprintf(string_buff, SUM_STR_MAX, "Interface: %s", summary.iface);
246 sprintf(string_buff, "Interface: unknown");
248 add_string_to_box(string_buff, capture_box);
252 if (summary.cfilter && summary.cfilter[0] != '\0') {
253 snprintf(string_buff, SUM_STR_MAX, "Capture filter: %s", summary.cfilter);
255 sprintf(string_buff, "Capture filter: none");
257 add_string_to_box(string_buff, capture_box);
260 /* Button row: close button.
261 (We put it in an HButtonBox, even though there's only one of them,
262 so that it doesn't expand to the width of the window. */
263 bbox = gtk_hbutton_box_new();
264 gtk_button_box_set_spacing(GTK_BUTTON_BOX(bbox), 5);
265 gtk_container_add(GTK_CONTAINER(main_vb), bbox);
266 gtk_widget_show(bbox);
268 /* Create Close Button */
269 #if GTK_MAJOR_VERSION < 2
270 close_bt = gtk_button_new_with_label("Close");
272 close_bt = gtk_button_new_from_stock(GTK_STOCK_CLOSE);
274 SIGNAL_CONNECT_OBJECT(close_bt, "clicked", gtk_widget_destroy, sum_open_w);
275 GTK_WIDGET_SET_FLAGS(close_bt, GTK_CAN_DEFAULT);
276 gtk_box_pack_start(GTK_BOX(bbox), close_bt, FALSE,FALSE, 0);
277 gtk_widget_grab_default(close_bt);
278 gtk_widget_show(close_bt);
280 /* Catch the "key_press_event" signal in the window, so that we can catch
281 the ESC key being pressed and act as if the "Close" button had
283 dlg_set_cancel(sum_open_w, close_bt);
285 gtk_window_set_position(GTK_WINDOW(sum_open_w), GTK_WIN_POS_MOUSE);
286 gtk_widget_show(sum_open_w);