From 84da00004be647d92230fb97e2610daaed3dfd93 Mon Sep 17 00:00:00 2001 From: Jelmer Vernooij Date: Tue, 17 Aug 2004 19:25:07 +0000 Subject: r1867: Add README file in build/pidl/ (This used to be commit 189ed098408b52965ccdf652d78ec678bbe0462e) --- source4/build/pidl/README | 35 +++++++++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) create mode 100644 source4/build/pidl/README diff --git a/source4/build/pidl/README b/source4/build/pidl/README new file mode 100644 index 0000000000..17a214cd58 --- /dev/null +++ b/source4/build/pidl/README @@ -0,0 +1,35 @@ +This directory contains the source code of the pidl (Perl IDL) +compiler. + +pidl.pl is the main file of pidl. + +Pidl works by building a parse tree from a .pidl file (a simple +dump of it's internal parse tree) or a .idl file +(a file format mostly like the IDL file format midl uses). +The IDL file parser is in idl.yp (a yacc file converted to +perl code by yapp) + +After a parse tree is present, pidl will call one of it's backends +(which one depends on the options given on the command-line). Here is +a list of current backends: + +client.pm - Generates client call functions in C +dump.pm - Converts the parse tree back to an IDL file +eparser.pm - Generates a parser for the ethereal network sniffer +header.pm - Generates a header file with structures +parser.pm - Generates pull/push functions for parsing +server.pm - Generates server side implementation in C +template.pm - Generates stubs in C for server implementation +validator.pm - Validates the parse tree + +Other files in this directory are: +tables.pl - Generates a table of available interfaces from a list of IDL files +util.pm - Misc utility functions used by *.pm and pidl.pl + +Tips for hacking on pidl: + - Look at the pidl's parse tree by using the --keep option and looking + at the generated .pidl file. + - The various backends have a lot in common, if you don't understand how one + implements something, look at the others + - See pidl(1) and the documentation on midl + - See 'info bison' and yapp(1) for information on the file format of idl.yp -- cgit