diff options
author | teravest@chromium.org <teravest@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-11-07 00:13:55 +0000 |
---|---|---|
committer | teravest@chromium.org <teravest@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-11-07 00:13:55 +0000 |
commit | 5f5286d6d8f13591c707e575f165c862ae600234 (patch) | |
tree | 490c0a6067ab6770fcbb2954965e703366241272 /ppapi | |
parent | 9691607ef3e6a36e07db4820426bda0a74a23036 (diff) | |
download | chromium_src-5f5286d6d8f13591c707e575f165c862ae600234.zip chromium_src-5f5286d6d8f13591c707e575f165c862ae600234.tar.gz chromium_src-5f5286d6d8f13591c707e575f165c862ae600234.tar.bz2 |
Update comments for the GeneratorByFile interface.
It would appear that the comments here are stale; I've updated them to
reflect the method that derived classes must implement.
BUG=
Review URL: https://chromiumcodereview.appspot.com/11359071
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@166314 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'ppapi')
-rwxr-xr-x | ppapi/generators/idl_generator.py | 56 |
1 files changed, 27 insertions, 29 deletions
diff --git a/ppapi/generators/idl_generator.py b/ppapi/generators/idl_generator.py index bd30217..218b6b4 100755 --- a/ppapi/generators/idl_generator.py +++ b/ppapi/generators/idl_generator.py @@ -14,24 +14,22 @@ GeneratorList = [] Option('release', 'Which release to generate.', default='') Option('range', 'Which ranges in the form of MIN,MAX.', default='start,end') +class Generator(object): + """Base class for generators. -# -# Generator -# -# Base class for generators. This class provides a mechanism for -# adding new generator objects to the IDL driver. To use this class -# override the GenerateRelease and GenerateRange members, and -# instantiate one copy of the class in the same module which defines it to -# register the generator. After the AST is generated, call the static Run -# member which will check every registered generator to see which ones have -# been enabled through command-line options. To enable a generator use the -# switches: -# --<sname> : To enable with defaults -# --<sname>_opt=<XXX,YYY=y> : To enable with generator specific options. -# -# NOTE: Generators still have access to global options + This class provides a mechanism for adding new generator objects to the IDL + driver. To use this class override the GenerateRelease and GenerateRange + members, and instantiate one copy of the class in the same module which + defines it to register the generator. After the AST is generated, call the + static Run member which will check every registered generator to see which + ones have been enabled through command-line options. To enable a generator + use the switches: + --<sname> : To enable with defaults + --<sname>_opt=<XXX,YYY=y> : To enable with generator specific options. + + NOTE: Generators still have access to global options + """ -class Generator(object): def __init__(self, name, sname, desc): self.name = name self.run_switch = Option(sname, desc) @@ -152,20 +150,21 @@ class Generator(object): return fail_count -# -# GeneratorByFile -# -# A subclass of Generator for use of generators which have a one to one -# mapping between IDL sources and output files. To use, derive a new class -# which defines: -# -# GetOutFile - Returns an IDLOutFile based on filenode (name) and options -# GenerateHead - Writes the first part of the file (includes, etc...) -# GenerateBody - Writes the body of the file (definitions) -# GenerateTail - Writes the end of the file (closing include guard, etc...) -# class GeneratorByFile(Generator): + """A simplified generator that generates one output file per IDL source file. + + A subclass of Generator for use of generators which have a one to one + mapping between IDL sources and output files. + + Derived classes should define GenerateFile. + """ + def GenerateFile(self, filenode, releases, options): + """Generates an output file from the IDL source. + + Returns true if the generated file is different than the previously + generated file. + """ __pychecker__ = 'unusednames=filenode,releases,options' self.Error("Undefined release generator.") return 0 @@ -275,4 +274,3 @@ def Main(args): if __name__ == '__main__': GeneratorReleaseTest('Test Gen', 'testgen', 'Generator Class Test.') sys.exit(Main(sys.argv[1:])) - |