added PSML output to the printing dialog

svn path=/trunk/; revision=10628
This commit is contained in:
Ulf Lamping 2004-04-17 11:50:14 +00:00
parent 5c550c3788
commit f4564cf6aa
3 changed files with 68 additions and 10 deletions

View File

@ -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);

54
print.c
View File

@ -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();
}

View File

@ -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 {