diff options
author | Jörg Mayer <jmayer@loplof.de> | 2004-08-06 21:06:27 +0000 |
---|---|---|
committer | Jörg Mayer <jmayer@loplof.de> | 2004-08-06 21:06:27 +0000 |
commit | 9ab5bc571356a08115f361a8f2bfd48d208ef820 (patch) | |
tree | 65f863822af7bf3093f1a1ba02f2085c33f25e39 /docbook/dfilter2xml.pl | |
parent | ca1d8cf41936253b9ede2f9b5c7ff1c305341c52 (diff) |
Svn stuff:
- Add eol-style native to all text files
- Add Id attributes
Add $Id: $ to all text files
Makefile:
- add several files and directories to make clean
- Add comments for values on Suse 9.1
catalog.xml:
- Add comments for values on Suse 9.1
svn path=/trunk/; revision=11618
Diffstat (limited to 'docbook/dfilter2xml.pl')
-rw-r--r-- | docbook/dfilter2xml.pl | 306 |
1 files changed, 153 insertions, 153 deletions
diff --git a/docbook/dfilter2xml.pl b/docbook/dfilter2xml.pl index e150820613..a2e6971215 100644 --- a/docbook/dfilter2xml.pl +++ b/docbook/dfilter2xml.pl @@ -1,153 +1,153 @@ -#!/usr/bin/perl
-#
-# Reads the display filter keyword dump produced by 'ethereal -G' and
-# formats it for a pod document. The pod document is then used to
-# make a manpage
-#
-# STDIN is the ethereal glossary
-# arg1 is the pod template file. The =insert_dfilter_table token
-# will be replaced by the pod-formatted glossary
-# STDOUT is the output
-#
-# $Id: dfilter2sgml,v 1.5 2002/09/10 15:49:57 sharpe Exp $
-
-%ftenum_names = (
- 'FT_NONE', 'No value',
- 'FT_PROTOCOL', 'Protocol',
- 'FT_BOOLEAN', 'Boolean',
- 'FT_UINT8', 'Unsigned 8-bit integer',
- 'FT_UINT16', 'Unsigned 16-bit integer',
- 'FT_UINT24', 'Unsigned 24-bit integer',
- 'FT_UINT32', 'Unsigned 32-bit integer',
- 'FT_UINT64', 'Unsigned 64-bit integer',
- 'FT_INT8', 'Signed 8-bit integer',
- 'FT_INT16', 'Signed 16-bit integer',
- 'FT_INT24', 'Signed 24-bit integer',
- 'FT_INT32', 'Signed 32-bit integer',
- 'FT_INT64', 'Signed 64-bit integer',
- 'FT_DOUBLE', 'Double-precision floating point',
- 'FT_ABSOLUTE_TIME', 'Date/Time stamp',
- 'FT_RELATIVE_TIME', 'Time duration',
- 'FT_STRING', 'String',
- 'FT_STRINGZ', 'String',
- 'FT_UINT_STRING', 'String',
- 'FT_ETHER', '6-byte Hardware (MAC) Address',
- 'FT_BYTES', 'Byte array',
- 'FT_IPv4', 'IPv4 address',
- 'FT_IPv6', 'IPv6 address',
- 'FT_IPXNET', 'IPX network or server name',
-);
-
-# Read all the data into memory
-while (<STDIN>) {
- next unless (/^([PF])/);
-
- $record_type = $1;
- chomp($_);
- $_ =~ s/\&/\&\;/g;
- $_ =~ s/\>/\>/g;
- $_ =~ s/\</\<\;/g;
-
- # Store protocol information
- if ($record_type eq 'P') {
- ($junk, $name, $abbrev) = split(/\t+/, $_);
- $proto_abbrev{$name} = $abbrev;
- }
- # Store header field information
- else {
- ($junk, $name, $abbrev, $type, $parent, $blurb) =
- split(/\t+/, $_);
- push(@{$field_abbrev{$parent}}, $abbrev);
- $field_info{$abbrev} = [ $name, $type, $blurb ];
- }
-}
-
-# if there was no input on stdin, bail out
-if ($record_type ne 'P' and $record_type ne 'F') {
- exit;
-}
-
-$template = shift(@ARGV);
-
-open(TEMPLATE, $template) || die "Can't open $template for reading: $!\n";
-
-while (<TEMPLATE>) {
- if (/=insert_dfilter_table/) {
- &create_dfilter_table;
- }
- else {
- print;
- }
-}
-
-close(TEMPLATE) || die "Can't close $template: $!\n";
-
-sub create_dfilter_table {
-
- print "<appendix id=\"AppFiltFields\"><title>Ethereal Display Filter Fields</title>\n";
- $pn_counter = 1;
-
- # Print each protocol
- for $proto_name (sort keys %proto_abbrev) {
-
- $ns_proto_name = $proto_name;
- $ns_proto_name =~ s/\s//g;
- $ns_proto_name =~ s/\)//g;
- $ns_proto_name =~ s/\(//g;
- $ns_proto_name =~ s/_//g;
- $ns_proto_name =~ s/\+/plus/g;
- $ns_proto_name =~ s/\//slash/g;
- $ns_proto_name =~ s/,/comma/g;
- $ns_proto_name =~ s/:/colon/g;
- $ns_proto_name =~ s/'/apos/g;
-
- # The maximum token name length is apparently 44 characters.
- # That's what NAMELEN is defined as in docbook 4.1, at least.
-
- if (length ($ns_proto_name) > 41) { # "SID" and "TID" are prepended below
- $ns_proto_name = sprintf ("%s%04d", substr($ns_proto_name, 0,
- 37), $pn_counter);
- $pn_counter++;
- }
-
- print "<section id=\"SID$ns_proto_name\"><title>$proto_name ($proto_abbrev{$proto_name})</title>\n\n";
-
- print "<table id=\"TID$ns_proto_name\"><title>$proto_name ($proto_abbrev{$proto_name})</title>\n";
- print "<tgroup cols=\"4\">\n";
-# print "<colspec colnum=\"1\" colwidth=\"80pt\">\n";
-# print "<colspec colnum=\"2\" colwidth=\"80pt\"\n>";
- print "<thead>\n <row>\n ";
- print "<entry>Field</>\n <entry>Field Name</>\n <entry>Type</>\n <entry>Description</>\n\n";
-
- print " </row>\n</thead>\n<tbody>\n";
-
- # If this proto has children fields, print those
- if ($field_abbrev{$proto_abbrev{$proto_name}}) {
-
- for $field_abbrev (sort @{$field_abbrev{$proto_abbrev{$proto_name}}}) {
-
- print " <row>\n";
- print " <entry>$field_abbrev</entry>\n";
- print " <entry>", $field_info{$field_abbrev}[0], "</entry>\n";
- print " <entry>", $ftenum_names{$field_info{$field_abbrev}[1]}, "</entry>\n";
- print " <entry>", $field_info{$field_abbrev}[2], "</>\n";
- print " </row>\n\n";
-
- }
-
- }
- else {
-
- print " <row>\n <entry></entry>\n <entry></entry>\n <entry></entry><entry></entry>\n";
- print " </row>\n";
-
- }
-
- print "</tbody></tgroup></table>\n";
- print "</section>\n\n";
-
- }
-
- print "</appendix>\n";
-
-}
+#!/usr/bin/perl +# +# Reads the display filter keyword dump produced by 'ethereal -G' and +# formats it for a pod document. The pod document is then used to +# make a manpage +# +# STDIN is the ethereal glossary +# arg1 is the pod template file. The =insert_dfilter_table token +# will be replaced by the pod-formatted glossary +# STDOUT is the output +# +# $Id$ + +%ftenum_names = ( + 'FT_NONE', 'No value', + 'FT_PROTOCOL', 'Protocol', + 'FT_BOOLEAN', 'Boolean', + 'FT_UINT8', 'Unsigned 8-bit integer', + 'FT_UINT16', 'Unsigned 16-bit integer', + 'FT_UINT24', 'Unsigned 24-bit integer', + 'FT_UINT32', 'Unsigned 32-bit integer', + 'FT_UINT64', 'Unsigned 64-bit integer', + 'FT_INT8', 'Signed 8-bit integer', + 'FT_INT16', 'Signed 16-bit integer', + 'FT_INT24', 'Signed 24-bit integer', + 'FT_INT32', 'Signed 32-bit integer', + 'FT_INT64', 'Signed 64-bit integer', + 'FT_DOUBLE', 'Double-precision floating point', + 'FT_ABSOLUTE_TIME', 'Date/Time stamp', + 'FT_RELATIVE_TIME', 'Time duration', + 'FT_STRING', 'String', + 'FT_STRINGZ', 'String', + 'FT_UINT_STRING', 'String', + 'FT_ETHER', '6-byte Hardware (MAC) Address', + 'FT_BYTES', 'Byte array', + 'FT_IPv4', 'IPv4 address', + 'FT_IPv6', 'IPv6 address', + 'FT_IPXNET', 'IPX network or server name', +); + +# Read all the data into memory +while (<STDIN>) { + next unless (/^([PF])/); + + $record_type = $1; + chomp($_); + $_ =~ s/\&/\&\;/g; + $_ =~ s/\>/\>/g; + $_ =~ s/\</\<\;/g; + + # Store protocol information + if ($record_type eq 'P') { + ($junk, $name, $abbrev) = split(/\t+/, $_); + $proto_abbrev{$name} = $abbrev; + } + # Store header field information + else { + ($junk, $name, $abbrev, $type, $parent, $blurb) = + split(/\t+/, $_); + push(@{$field_abbrev{$parent}}, $abbrev); + $field_info{$abbrev} = [ $name, $type, $blurb ]; + } +} + +# if there was no input on stdin, bail out +if ($record_type ne 'P' and $record_type ne 'F') { + exit; +} + +$template = shift(@ARGV); + +open(TEMPLATE, $template) || die "Can't open $template for reading: $!\n"; + +while (<TEMPLATE>) { + if (/=insert_dfilter_table/) { + &create_dfilter_table; + } + else { + print; + } +} + +close(TEMPLATE) || die "Can't close $template: $!\n"; + +sub create_dfilter_table { + + print "<appendix id=\"AppFiltFields\"><title>Ethereal Display Filter Fields</title>\n"; + $pn_counter = 1; + + # Print each protocol + for $proto_name (sort keys %proto_abbrev) { + + $ns_proto_name = $proto_name; + $ns_proto_name =~ s/\s//g; + $ns_proto_name =~ s/\)//g; + $ns_proto_name =~ s/\(//g; + $ns_proto_name =~ s/_//g; + $ns_proto_name =~ s/\+/plus/g; + $ns_proto_name =~ s/\//slash/g; + $ns_proto_name =~ s/,/comma/g; + $ns_proto_name =~ s/:/colon/g; + $ns_proto_name =~ s/'/apos/g; + + # The maximum token name length is apparently 44 characters. + # That's what NAMELEN is defined as in docbook 4.1, at least. + + if (length ($ns_proto_name) > 41) { # "SID" and "TID" are prepended below + $ns_proto_name = sprintf ("%s%04d", substr($ns_proto_name, 0, + 37), $pn_counter); + $pn_counter++; + } + + print "<section id=\"SID$ns_proto_name\"><title>$proto_name ($proto_abbrev{$proto_name})</title>\n\n"; + + print "<table id=\"TID$ns_proto_name\"><title>$proto_name ($proto_abbrev{$proto_name})</title>\n"; + print "<tgroup cols=\"4\">\n"; +# print "<colspec colnum=\"1\" colwidth=\"80pt\">\n"; +# print "<colspec colnum=\"2\" colwidth=\"80pt\"\n>"; + print "<thead>\n <row>\n "; + print "<entry>Field</>\n <entry>Field Name</>\n <entry>Type</>\n <entry>Description</>\n\n"; + + print " </row>\n</thead>\n<tbody>\n"; + + # If this proto has children fields, print those + if ($field_abbrev{$proto_abbrev{$proto_name}}) { + + for $field_abbrev (sort @{$field_abbrev{$proto_abbrev{$proto_name}}}) { + + print " <row>\n"; + print " <entry>$field_abbrev</entry>\n"; + print " <entry>", $field_info{$field_abbrev}[0], "</entry>\n"; + print " <entry>", $ftenum_names{$field_info{$field_abbrev}[1]}, "</entry>\n"; + print " <entry>", $field_info{$field_abbrev}[2], "</>\n"; + print " </row>\n\n"; + + } + + } + else { + + print " <row>\n <entry></entry>\n <entry></entry>\n <entry></entry><entry></entry>\n"; + print " </row>\n"; + + } + + print "</tbody></tgroup></table>\n"; + print "</section>\n\n"; + + } + + print "</appendix>\n"; + +} |