diff options
author | Jack Jansen <jack.jansen@cwi.nl> | 2002-08-22 23:31:37 (GMT) |
---|---|---|
committer | Jack Jansen <jack.jansen@cwi.nl> | 2002-08-22 23:31:37 (GMT) |
commit | d59f8d0691aff6649c70bfc764f7edce8d5f105c (patch) | |
tree | 308b621325a5dd2793d80a95e728fb6b6f035676 /Mac/Modules/ah/ahsupport.py | |
parent | f34a8bced262ad63564336de128c32b72eefec44 (diff) | |
download | cpython-d59f8d0691aff6649c70bfc764f7edce8d5f105c.zip cpython-d59f8d0691aff6649c70bfc764f7edce8d5f105c.tar.gz cpython-d59f8d0691aff6649c70bfc764f7edce8d5f105c.tar.bz2 |
Interface to Apple Help Manager.
Diffstat (limited to 'Mac/Modules/ah/ahsupport.py')
-rw-r--r-- | Mac/Modules/ah/ahsupport.py | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/Mac/Modules/ah/ahsupport.py b/Mac/Modules/ah/ahsupport.py new file mode 100644 index 0000000..b07c779 --- /dev/null +++ b/Mac/Modules/ah/ahsupport.py @@ -0,0 +1,50 @@ +# This script generates a Python interface for an Apple Macintosh Manager. +# It uses the "bgen" package to generate C code. +# The function specifications are generated by scanning the mamager's header file, +# using the "scantools" package (customized for this particular manager). + +import string + +# Declarations that change for each manager +MACHEADERFILE = 'AppleHelp.h' # The Apple header file +MODNAME = '_AH' # The name of the module + +# The following is *usually* unchanged but may still require tuning +MODPREFIX = 'Ah' # The prefix for module-wide routines +INPUTFILE = string.lower(MODPREFIX) + 'gen.py' # The file generated by the scanner +OUTPUTFILE = MODNAME + "module.c" # The file generated by this program + +from macsupport import * + +# Create the type objects +AHTOCType = Type("AHTOCType", "s") + +includestuff = includestuff + """ +#ifdef WITHOUT_FRAMEWORKS +#include <AppleHelp.h> +#else +#include <Carbon/Carbon.h> +#endif + +""" + +# From here on it's basically all boiler plate... + +# Create the generator groups and link them +module = MacModule(MODNAME, MODPREFIX, includestuff, finalstuff, initstuff) + +# Create the generator classes used to populate the lists +Function = OSErrFunctionGenerator + +# Create and populate the lists +functions = [] +execfile(INPUTFILE) + +# add the populated lists to the generator groups +# (in a different wordl the scan program would generate this) +for f in functions: module.add(f) + +# generate output (open the output file as late as possible) +SetOutputFileName(OUTPUTFILE) +module.generate() + |