aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorUlf Lamping <ulf.lamping@web.de>2004-04-17 11:50:14 +0000
committerUlf Lamping <ulf.lamping@web.de>2004-04-17 11:50:14 +0000
commitf4564cf6aa66ac7c2c5d12388b201fc67b40cfc7 (patch)
treef4a5368db13769a2d737d14e2abaa4393ce9a491
parent5c550c3788ffaaf57b8183162599f3e8dbcee74b (diff)
added PSML output to the printing dialog
svn path=/trunk/; revision=10628
-rw-r--r--gtk/print_dlg.c21
-rw-r--r--print.c54
-rw-r--r--print.h3
3 files changed, 68 insertions, 10 deletions
diff --git a/gtk/print_dlg.c b/gtk/print_dlg.c
index e64efd6b69..c8cd4ed48a 100644
--- a/gtk/print_dlg.c
+++ b/gtk/print_dlg.c
@@ -1,7 +1,7 @@
/* print_dlg.c
* Dialog boxes for printing
*
- * $Id: print_dlg.c,v 1.66 2004/04/16 18:17:48 ulfl Exp $
+ * $Id: print_dlg.c,v 1.67 2004/04/17 11:50:14 ulfl Exp $
*
* Ethereal - Network traffic analyzer
* By Gerald Combs <gerald@ethereal.com>
@@ -83,6 +83,7 @@ static gchar * print_cmd;
#define PRINT_PS_RB_KEY "printer_ps_radio_button"
#define PRINT_PDML_RB_KEY "printer_pdml_radio_button"
+#define PRINT_PSML_RB_KEY "printer_psml_radio_button"
#define PRINT_DEST_CB_KEY "printer_destination_check_button"
#define PRINT_SUMMARY_CB_KEY "printer_summary_check_button"
@@ -321,7 +322,7 @@ file_print_cmd_cb(GtkWidget *widget _U_, gpointer data _U_)
GtkWidget *main_vb;
GtkWidget *printer_fr, *printer_vb;
- GtkWidget *text_rb, *ps_rb, *pdml_rb;
+ GtkWidget *text_rb, *ps_rb, *pdml_rb, *psml_rb;
GtkWidget *printer_tb, *dest_cb;
#ifndef _WIN32
GtkWidget *cmd_lb, *cmd_te;
@@ -410,7 +411,7 @@ file_print_cmd_cb(GtkWidget *widget _U_, gpointer data _U_)
gtk_box_pack_start(GTK_BOX(printer_vb), ps_rb, FALSE, FALSE, 0);
gtk_widget_show(ps_rb);
- pdml_rb = RADIO_BUTTON_NEW_WITH_MNEMONIC(text_rb, "PDM_L (XML)", accel_group);
+ pdml_rb = RADIO_BUTTON_NEW_WITH_MNEMONIC(text_rb, "PDM_L (XML: Packet Details Markup Language)", accel_group);
if (print_format == PR_FMT_PDML)
gtk_toggle_button_set_state(GTK_TOGGLE_BUTTON(pdml_rb), TRUE);
gtk_tooltips_set_tip (tooltips, pdml_rb, (
@@ -420,6 +421,16 @@ file_print_cmd_cb(GtkWidget *widget _U_, gpointer data _U_)
gtk_box_pack_start(GTK_BOX(printer_vb), pdml_rb, FALSE, FALSE, 0);
gtk_widget_show(pdml_rb);
+ psml_rb = RADIO_BUTTON_NEW_WITH_MNEMONIC(text_rb, "PSML (XML: Packet Summary Markup Language)", accel_group);
+ if (print_format == PR_FMT_PSML)
+ gtk_toggle_button_set_state(GTK_TOGGLE_BUTTON(psml_rb), TRUE);
+ gtk_tooltips_set_tip (tooltips, psml_rb, (
+ "Print output in \"PSML\" (Packet Summary Markup Language), "
+ "an XML based packet summary interchange format. "
+ "Usually used in combination with the \"Output to file\" option to export packet data into an XML file."), NULL);
+ gtk_box_pack_start(GTK_BOX(printer_vb), psml_rb, FALSE, FALSE, 0);
+ gtk_widget_show(psml_rb);
+
/* printer table */
#ifndef _WIN32
printer_tb = gtk_table_new(2, 3, FALSE);
@@ -700,6 +711,7 @@ file_print_cmd_cb(GtkWidget *widget _U_, gpointer data _U_)
OBJECT_SET_DATA(ok_bt, PRINT_PS_RB_KEY, ps_rb);
OBJECT_SET_DATA(ok_bt, PRINT_PDML_RB_KEY, pdml_rb);
+ OBJECT_SET_DATA(ok_bt, PRINT_PSML_RB_KEY, psml_rb);
OBJECT_SET_DATA(ok_bt, PRINT_DEST_CB_KEY, dest_cb);
#ifndef _WIN32
OBJECT_SET_DATA(ok_bt, PRINT_CMD_TE_KEY, cmd_te);
@@ -868,6 +880,9 @@ print_ok_cb(GtkWidget *ok_bt, gpointer parent_w)
button = (GtkWidget *)OBJECT_GET_DATA(ok_bt, PRINT_PDML_RB_KEY);
if (gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON (button)))
print_format = PR_FMT_PDML;
+ button = (GtkWidget *)OBJECT_GET_DATA(ok_bt, PRINT_PSML_RB_KEY);
+ if (gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON (button)))
+ print_format = PR_FMT_PSML;
print_args.format = print_format;
button = (GtkWidget *)OBJECT_GET_DATA(ok_bt, PRINT_SUMMARY_CB_KEY);
diff --git a/print.c b/print.c
index 5d26810405..7a32ac8404 100644
--- a/print.c
+++ b/print.c
@@ -1,7 +1,7 @@
/* print.c
* Routines for printing packet analysis trees.
*
- * $Id: print.c,v 1.75 2004/04/17 09:02:32 ulfl Exp $
+ * $Id: print.c,v 1.76 2004/04/17 11:50:13 ulfl Exp $
*
* Gilbert Ramirez <gram@alumni.rice.edu>
*
@@ -44,6 +44,7 @@
#include "packet-frame.h"
#define PDML_VERSION "0"
+#define PSML_VERSION "0"
static void proto_tree_print_node(proto_node *node, gpointer data);
static void proto_tree_print_node_pdml(proto_node *node, gpointer data);
@@ -51,6 +52,7 @@ static void print_hex_data_buffer(FILE *fh, register const guchar *cp,
register guint length, char_enc encoding, gint format);
static void ps_clean_string(unsigned char *out, const unsigned char *in,
int outbuf_size);
+static void print_escaped_xml(FILE *fh, char *unescaped_string);
typedef struct {
int level;
@@ -93,6 +95,7 @@ proto_tree_print(print_args_t *print_args, epan_dissect_t *edt,
FILE *fh)
{
print_data data;
+ gint i;
/* Create the output */
data.level = 0;
@@ -106,8 +109,12 @@ proto_tree_print(print_args_t *print_args, epan_dissect_t *edt,
data.format = print_args->format;
data.edt = edt;
- if (data.format == PR_FMT_PDML) {
-
+ switch(data.format) {
+ case(PR_FMT_TEXT): /* fall through */
+ case(PR_FMT_PS):
+ proto_tree_children_foreach(edt->tree, proto_tree_print_node, &data);
+ break;
+ case(PR_FMT_PDML):
fprintf(fh, "<packet>\n");
/* Print a "geninfo" protocol as required by PDML */
@@ -116,9 +123,33 @@ proto_tree_print(print_args_t *print_args, epan_dissect_t *edt,
proto_tree_children_foreach(edt->tree, proto_tree_print_node_pdml, &data);
fprintf(fh, "</packet>\n\n");
- }
- else {
- proto_tree_children_foreach(edt->tree, proto_tree_print_node, &data);
+ break;
+ case(PR_FMT_PSML):
+ /* if this is the first packet, we have to create the PSML structure output */
+ if(edt->pi.fd->num == 1) {
+ fprintf(fh, "<structure>\n");
+
+ for(i=0; i < edt->pi.cinfo->num_cols; i++) {
+ fprintf(fh, "<section>");
+ print_escaped_xml(fh, edt->pi.cinfo->col_title[i]);
+ fprintf(fh, "</section>\n");
+ }
+
+ fprintf(fh, "</structure>\n\n");
+ }
+
+ fprintf(fh, "<packet>\n");
+
+ for(i=0; i < edt->pi.cinfo->num_cols; i++) {
+ fprintf(fh, "<section>");
+ print_escaped_xml(fh, edt->pi.cinfo->col_data[i]);
+ fprintf(fh, "</section>\n");
+ }
+
+ fprintf(fh, "</packet>\n\n");
+ break;
+ default:
+ g_assert_not_reached();
}
}
@@ -687,6 +718,11 @@ print_preamble(FILE *fh, gint format)
fputs("<pdml version=\"" PDML_VERSION "\" ", fh);
fprintf(fh, "creator=\"%s/%s\">\n", PACKAGE, VERSION);
break;
+ case(PR_FMT_PSML):
+ fputs("<?xml version=\"1.0\"?>\n", fh);
+ fputs("<psml version=\"" PSML_VERSION "\" ", fh);
+ fprintf(fh, "creator=\"%s/%s\">\n", PACKAGE, VERSION);
+ break;
default:
g_assert_not_reached();
}
@@ -706,6 +742,9 @@ print_finale(FILE *fh, gint format)
case(PR_FMT_PDML):
fputs("</pdml>\n", fh);
break;
+ case(PR_FMT_PSML):
+ fputs("</psml>\n", fh);
+ break;
default:
g_assert_not_reached();
}
@@ -743,6 +782,9 @@ print_line(FILE *fh, int indent, gint format, char *line)
case(PR_FMT_PDML):
/* do nothing */
break;
+ case(PR_FMT_PSML):
+ /* do nothing */
+ break;
default:
g_assert_not_reached();
}
diff --git a/print.h b/print.h
index d2b97bce3b..bb24342a2b 100644
--- a/print.h
+++ b/print.h
@@ -1,7 +1,7 @@
/* print.h
* Definitions for printing packet analysis trees.
*
- * $Id: print.h,v 1.38 2004/04/15 19:56:15 ulfl Exp $
+ * $Id: print.h,v 1.39 2004/04/17 11:50:14 ulfl Exp $
*
* Gilbert Ramirez <gram@alumni.rice.edu>
*
@@ -32,6 +32,7 @@
#define PR_FMT_TEXT 0
#define PR_FMT_PS 1
#define PR_FMT_PDML 2
+#define PR_FMT_PSML 3
/* print_range, enum which frames should be printed */
typedef enum {