diff options
author | Jelmer Vernooij <jelmer@samba.org> | 2004-08-17 19:25:07 +0000 |
---|---|---|
committer | Gerald (Jerry) Carter <jerry@samba.org> | 2007-10-10 12:58:04 -0500 |
commit | 84da00004be647d92230fb97e2610daaed3dfd93 (patch) | |
tree | 72ee13511022dea22cc82374e71dfe40bcc32b89 | |
parent | ebd696bd8c73d39a3f72624e25bf85965bdf93ef (diff) | |
download | samba-84da00004be647d92230fb97e2610daaed3dfd93.tar.gz samba-84da00004be647d92230fb97e2610daaed3dfd93.tar.bz2 samba-84da00004be647d92230fb97e2610daaed3dfd93.zip |
r1867: Add README file in build/pidl/
(This used to be commit 189ed098408b52965ccdf652d78ec678bbe0462e)
-rw-r--r-- | source4/build/pidl/README | 35 |
1 files changed, 35 insertions, 0 deletions
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 |