svn commit: samba r9104 - in branches/SAMBA_4_0/source/build/pidl: . Parse/Pidl/Ethereal

jelmer at samba.org jelmer at samba.org
Fri Aug 5 07:16:08 GMT 2005


Author: jelmer
Date: 2005-08-05 07:16:07 +0000 (Fri, 05 Aug 2005)
New Revision: 9104

WebSVN: http://websvn.samba.org/cgi-bin/viewcvs.cgi?view=rev&root=samba&rev=9104

Log:
Finish ethereal parser generator. Still a couple of minor issues 
remaining to get it to generate completely compilable code.

Modified:
   branches/SAMBA_4_0/source/build/pidl/Parse/Pidl/Ethereal/NDR.pm
   branches/SAMBA_4_0/source/build/pidl/pidl


Changeset:
Modified: branches/SAMBA_4_0/source/build/pidl/Parse/Pidl/Ethereal/NDR.pm
===================================================================
--- branches/SAMBA_4_0/source/build/pidl/Parse/Pidl/Ethereal/NDR.pm	2005-08-05 05:42:09 UTC (rev 9103)
+++ branches/SAMBA_4_0/source/build/pidl/Parse/Pidl/Ethereal/NDR.pm	2005-08-05 07:16:07 UTC (rev 9104)
@@ -6,7 +6,7 @@
 # Portions based on idl2eth.c by Ronnie Sahlberg
 # released under the GNU GPL
 
-package Parse::Pidl::Ethereal::NDR::Parser;
+package Parse::Pidl::Ethereal::NDR;
 
 use strict;
 use Parse::Pidl::Typelist;
@@ -20,6 +20,14 @@
 	"ptr" => "NDR_POINTER_PTR"
 );
 
+my %dissectors = (
+	"uint16" => "dissect_ndr_uint16",
+	"uint8" => "dissect_ndr_uint8",
+	"uint32" => "dissect_ndr_uint32",
+	"time_t" => "dissect_ndr_time_t",
+	"GUID" => "dissect_ndr_uuid_t"
+);
+
 sub type2ft($)
 {
     my($t) = shift;
@@ -29,9 +37,7 @@
     return "FT_UINT64", if $t eq "HYPER_T" or $t eq "NTTIME"
 	or $t eq "NTTIME_1sec" or $t eq "NTTIME_hyper" or $t eq "hyper";
    
-   # Type is an enum
-
-    return "FT_UINT16";
+    return "FT_NONE";
 }
 
 # Determine the display base for an element
@@ -144,7 +150,7 @@
 	pidl_code "return offset;";
 	pidl_code "}\n";
 
-	register_type($name, $dissectorname, enum_ft($e), "BASE_DEC", "0", "VALS($valsstring)", enum_size($e));
+	register_hf_field($name, $dissectorname, enum_ft($e), "BASE_DEC", "0", "VALS($valsstring)", enum_size($e));
 }
 
 sub Bitmap($$$)
@@ -215,7 +221,13 @@
 	my ($e,$l,$hf,$myname) = @_;
 
 	if ($l->{TYPE} eq "POINTER") {
-		pidl_code "offset=dissect_ndr_pointer(tvb,offset,pinfo,tree,drep,$myname\_,$ptrtype_mappings{$l->{POINTER_TYPE}},\"\",$hf);";
+		my $type;
+		if ($l->{LEVEL} eq "TOP") {
+			$type = "toplevel";
+		} elsif ($l->{LEVEL} eq "EMBEDDED") {
+			$type = "embedded";
+		}
+		pidl_code "offset=dissect_ndr_$type\_pointer(tvb,offset,pinfo,tree,drep,$myname\_,$ptrtype_mappings{$l->{POINTER_TYPE}},\"\",$hf);";
 	} elsif ($l->{TYPE} eq "ARRAY") {
 		my $af = "";
 
@@ -225,8 +237,9 @@
 
 		pidl_code "offset=dissect_ndr_$af(tvb,offset,pinfo,tree,drep,$myname\_);";
 	} elsif ($l->{TYPE} eq "DATA") {
-#		pidl_code "guint32 param="  . FindDissectorParam($dissectorname).";";
-#		pidl_code "offset=$type->{DISSECTOR}(tvb, offset, pinfo, tree, drep, $hf, param);";
+		pidl_code "guint32 param="  . FindDissectorParam($myname).";";
+		defined($dissectors{$l->{DATA_TYPE}}) or warn("Unknown data type $l->{DATA_TYPE}");
+		pidl_code "offset=".$dissectors{$l->{DATA_TYPE}}."(tvb, offset, pinfo, tree, drep, $hf, param);";
 	} elsif ($_->{TYPE} eq "SUBCONTEXT") {
 		die("subcontext() not supported")
 	}
@@ -240,8 +253,7 @@
 
 	return if (EmitProhibited($dissectorname));
 
-	my $hf = "";
-	#FIXME	my $hf = register_hf_field("hf_$ifname\_$pn\_$e->{NAME}", $e->{NAME}, "$ifname.$pn.$e->{NAME}", $type->{FT_TYPE}, $type->{BASE_TYPE}, $type->{VALS}, $type->{MASK}, "");
+	my $hf = register_hf_field("hf_$ifname\_$pn\_$e->{NAME}", $e->{NAME}, "$ifname.$pn.$e->{NAME}", type2ft($e->{TYPE}), "BASE_HEX", "NULL", 0, "");
 	my $add = "";
 
 	foreach (@{$e->{LEVELS}}) {
@@ -312,7 +324,7 @@
 	register_ett("ett_$ifname\_$name");
 
 	my $res = "";
-	($res.=Element($_, $name, $ifname)."\n") foreach (@{$e->{ELEMENTS}});
+	($res.="\t".Element($_, $name, $ifname)."\n") foreach (@{$e->{ELEMENTS}});
 
 	pidl_hdr "int $dissectorname(tvbuff_t *tvb, int offset, packet_info *pinfo, proto_tree *parent_tree, guint8 *drep, int hf_index, guint32 param _U_);";
 
@@ -337,7 +349,7 @@
 	deindent;
 	pidl_code "}";
 
-	pidl_code "$res";
+	pidl_code "\n$res";
 
 
 	pidl_code "";
@@ -351,7 +363,7 @@
 {
 	my ($e,$name,$ifname) = @_;
 
-	my $dissectorname = "$ifname\_dissect_union_$name";
+	my $dissectorname = "$ifname\_dissect_$name";
 	
 	register_ett("ett_$ifname\_$name");
 
@@ -466,6 +478,10 @@
 {
 	my $x = shift;
 
+	foreach (@{$x->{TYPEDEFS}}) {
+		$dissectors{$_->{NAME}} = "$x->{NAME}_dissect_$_->{NAME}";
+	}
+
 	if (defined($x->{UUID})) {
 		my $if_uuid = $x->{UUID};
 

Modified: branches/SAMBA_4_0/source/build/pidl/pidl
===================================================================
--- branches/SAMBA_4_0/source/build/pidl/pidl	2005-08-05 05:42:09 UTC (rev 9103)
+++ branches/SAMBA_4_0/source/build/pidl/pidl	2005-08-05 07:16:07 UTC (rev 9104)
@@ -319,7 +319,7 @@
 	  my $eheader = $eparser;
 	  $eheader =~ s/\.c$/\.h/;
 
-	  my ($dp, $dh) = Parse::Pidl::Ethereal::NDR::Parser::Parse($ndr, $basename, $eparser);
+	  my ($dp, $dh) = Parse::Pidl::Ethereal::NDR::Parse($ndr, $eheader, $eparser);
 	  FileSave($eparser, $dp);
 	  FileSave($eheader, $dh);
 	}



More information about the samba-cvs mailing list