mirror of
https://github.com/python/cpython.git
synced 2025-08-04 17:08:35 +00:00
Adding an interface to the high-level Open Scripting Architecture,
by request of Donovan Preston. In return, he promised to use this to create a Python OSA component, which would turn Python into a first-class OSA scripting language (like AppleScript itself).
This commit is contained in:
parent
8850c8785f
commit
fe3fe4adb5
6 changed files with 1595 additions and 0 deletions
1226
Mac/Modules/osa/_OSAmodule.c
Normal file
1226
Mac/Modules/osa/_OSAmodule.c
Normal file
File diff suppressed because it is too large
Load diff
61
Mac/Modules/osa/osascan.py
Normal file
61
Mac/Modules/osa/osascan.py
Normal file
|
@ -0,0 +1,61 @@
|
|||
# Scan an Apple header file, generating a Python file of generator calls.
|
||||
|
||||
import sys
|
||||
import os
|
||||
from bgenlocations import TOOLBOXDIR, BGENDIR
|
||||
sys.path.append(BGENDIR)
|
||||
from scantools import Scanner
|
||||
|
||||
LONG = "OSAconst"
|
||||
SHORT = "osa"
|
||||
|
||||
def main():
|
||||
input = "OSA.h"
|
||||
output = SHORT + "gen.py"
|
||||
defsoutput = TOOLBOXDIR + LONG + ".py"
|
||||
scanner = MyScanner(input, output, defsoutput)
|
||||
scanner.scan()
|
||||
scanner.close()
|
||||
scanner.gentypetest(SHORT+"typetest.py")
|
||||
print "=== Testing definitions output code ==="
|
||||
execfile(defsoutput, {}, {})
|
||||
print "=== Done scanning and generating, now importing the generated code... ==="
|
||||
exec "import " + SHORT + "support"
|
||||
print "=== Done. It's up to you to compile it now! ==="
|
||||
|
||||
class MyScanner(Scanner):
|
||||
|
||||
def destination(self, type, name, arglist):
|
||||
classname = "Function"
|
||||
listname = "functions"
|
||||
if arglist:
|
||||
t, n, m = arglist[0]
|
||||
if t == "ComponentInstance" and m == "InMode":
|
||||
classname = "Method"
|
||||
listname = "methods"
|
||||
return classname, listname
|
||||
|
||||
def writeinitialdefs(self):
|
||||
self.defsfile.write("def FOUR_CHAR_CODE(x): return x\n")
|
||||
self.defsfile.write("from Carbon.AppleEvents import *\n")
|
||||
self.defsfile.write("kAEUseStandardDispatch = -1\n")
|
||||
|
||||
def makeblacklistnames(self):
|
||||
return [
|
||||
"OSACopyScript",
|
||||
]
|
||||
|
||||
def makeblacklisttypes(self):
|
||||
return [
|
||||
"OSACreateAppleEventUPP",
|
||||
"OSAActiveUPP",
|
||||
"AEEventHandlerUPP",
|
||||
"OSASendUPP",
|
||||
]
|
||||
|
||||
def makerepairinstructions(self):
|
||||
return [
|
||||
]
|
||||
|
||||
if __name__ == "__main__":
|
||||
main()
|
94
Mac/Modules/osa/osasupport.py
Normal file
94
Mac/Modules/osa/osasupport.py
Normal file
|
@ -0,0 +1,94 @@
|
|||
# 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 = 'OSA.h' # The Apple header file
|
||||
MODNAME = '_OSA' # The name of the module
|
||||
|
||||
# The following is *usually* unchanged but may still require tuning
|
||||
MODPREFIX = 'OSA' # The prefix for module-wide routines
|
||||
OBJECTPREFIX = 'OSAObj' # The prefix for object methods
|
||||
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
|
||||
|
||||
includestuff = includestuff + """
|
||||
#include <Carbon/Carbon.h>
|
||||
|
||||
#ifdef USE_TOOLBOX_OBJECT_GLUE
|
||||
extern PyObject *_OSAObj_New(ComponentInstance);
|
||||
extern int _OSAObj_Convert(PyObject *, ComponentInstance *);
|
||||
|
||||
#define OSAObj_New _OSAObj_New
|
||||
#define OSAObj_Convert _OSAObj_Convert
|
||||
#endif
|
||||
"""
|
||||
|
||||
initstuff = initstuff + """
|
||||
/*
|
||||
PyMac_INIT_TOOLBOX_OBJECT_NEW(ComponentInstance, OSAObj_New);
|
||||
PyMac_INIT_TOOLBOX_OBJECT_CONVERT(ComponentInstance, OSAObj_Convert);
|
||||
*/
|
||||
"""
|
||||
|
||||
ComponentInstance = OpaqueByValueType('ComponentInstance', OBJECTPREFIX)
|
||||
OSAError = OSErrType("OSAError", "l")
|
||||
OSAID = Type("OSAID", "l")
|
||||
OSADebugCallFrameRef = Type("OSADebugCallFrameRef", "l")
|
||||
OSADebugSessionRef = Type("OSADebugSessionRef", "l")
|
||||
OSADebugStepKind = Type("OSADebugStepKind", "l")
|
||||
DescType = OSTypeType("DescType")
|
||||
AEDesc = OpaqueType('AEDesc')
|
||||
AEDesc_ptr = OpaqueType('AEDesc')
|
||||
AEAddressDesc = OpaqueType('AEAddressDesc', 'AEDesc')
|
||||
AEAddressDesc_ptr = OpaqueType('AEAddressDesc', 'AEDesc')
|
||||
AEDescList = OpaqueType('AEDescList', 'AEDesc')
|
||||
AEDescList_ptr = OpaqueType('AEDescList', 'AEDesc')
|
||||
AERecord = OpaqueType('AERecord', 'AEDesc')
|
||||
AERecord_ptr = OpaqueType('AERecord', 'AEDesc')
|
||||
AppleEvent = OpaqueType('AppleEvent', 'AEDesc')
|
||||
AppleEvent_ptr = OpaqueType('AppleEvent', 'AEDesc')
|
||||
|
||||
# NOTE: at the moment OSA.ComponentInstance is not a subclass
|
||||
# of Cm.ComponentInstance. If this is a problem it can be fixed.
|
||||
class MyObjectDefinition(PEP253Mixin, GlobalObjectDefinition):
|
||||
def outputCheckNewArg(self):
|
||||
Output("""if (itself == NULL) {
|
||||
PyErr_SetString(OSA_Error,"NULL ComponentInstance");
|
||||
return NULL;
|
||||
}""")
|
||||
|
||||
# Create the generator groups and link them
|
||||
module = MacModule(MODNAME, MODPREFIX, includestuff, finalstuff, initstuff)
|
||||
object = MyObjectDefinition('ComponentInstance', OBJECTPREFIX,
|
||||
'ComponentInstance')
|
||||
module.addobject(object)
|
||||
|
||||
# Create the generator classes used to populate the lists
|
||||
Function = OSErrWeakLinkFunctionGenerator
|
||||
Method = OSErrWeakLinkMethodGenerator
|
||||
|
||||
# Test which types we are still missing.
|
||||
execfile(string.lower(MODPREFIX) + 'typetest.py')
|
||||
|
||||
# Create and populate the lists
|
||||
functions = []
|
||||
methods = []
|
||||
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)
|
||||
for f in methods: object.add(f)
|
||||
|
||||
# generate output (open the output file as late as possible)
|
||||
SetOutputFileName(OUTPUTFILE)
|
||||
module.generate()
|
||||
|
Loading…
Add table
Add a link
Reference in a new issue