- Added optional "start" argument to TalkTo initialializer, which

starts the app (if needed).
- Added aetools.Error, which is returned in case of server-generated
  errors (better than MacOS.Error, which was raised previously)
This commit is contained in:
Jack Jansen 1996-09-20 15:28:28 +00:00
parent 0585d41198
commit c46f56e35f
1 changed files with 20 additions and 4 deletions

View File

@ -29,6 +29,8 @@
from aetypes import * from aetypes import *
from aepack import pack, unpack, coerce, AEDescType from aepack import pack, unpack, coerce, AEDescType
Error = 'aetools.Error'
# Special code to unpack an AppleEvent (which is *not* a disguised record!) # Special code to unpack an AppleEvent (which is *not* a disguised record!)
# Note by Jack: No??!? If I read the docs correctly it *is*.... # Note by Jack: No??!? If I read the docs correctly it *is*....
@ -105,35 +107,49 @@ def enumsubst(arguments, key, edict):
def decodeerror(arguments): def decodeerror(arguments):
"""Create the 'best' argument for a raise MacOS.Error""" """Create the 'best' argument for a raise MacOS.Error"""
errn = arguments['errn'] errn = arguments['errn']
errarg = (errn, MacOS.GetErrorString(errn)) errarg = (errn, )
if arguments.has_key('errs'): if arguments.has_key('errs'):
errarg = errarg + (arguments['errs'],) errarg = errarg + (arguments['errs'],)
if arguments.has_key('erob'): if arguments.has_key('erob'):
errarg = errarg + (arguments['erob'],) errarg = errarg + (arguments['erob'],)
if len(errarg) == 1:
errarg = errarg + ('Server returned error code %d'%errn, )
return errarg return errarg
class TalkTo: class TalkTo:
"""An AE connection to an application""" """An AE connection to an application"""
def __init__(self, signature): def __init__(self, signature, start=0):
"""Create a communication channel with a particular application. """Create a communication channel with a particular application.
Addressing the application is done by specifying either a Addressing the application is done by specifying either a
4-byte signature, an AEDesc or an object that will __aepack__ 4-byte signature, an AEDesc or an object that will __aepack__
to an AEDesc. to an AEDesc.
""" """
self.target_signature = None
if type(signature) == AEDescType: if type(signature) == AEDescType:
self.target = signature self.target = signature
elif type(signature) == InstanceType and hasattr(signature, '__aepack__'): elif type(signature) == InstanceType and hasattr(signature, '__aepack__'):
self.target = signature.__aepack__() self.target = signature.__aepack__()
elif type(signature) == StringType and len(signature) == 4: elif type(signature) == StringType and len(signature) == 4:
self.target = AE.AECreateDesc(AppleEvents.typeApplSignature, signature) self.target = AE.AECreateDesc(AppleEvents.typeApplSignature, signature)
self.target_signature = signature
else: else:
raise TypeError, "signature should be 4-char string or AEDesc" raise TypeError, "signature should be 4-char string or AEDesc"
self.send_flags = AppleEvents.kAEWaitReply self.send_flags = AppleEvents.kAEWaitReply
self.send_priority = AppleEvents.kAENormalPriority self.send_priority = AppleEvents.kAENormalPriority
self.send_timeout = AppleEvents.kAEDefaultTimeout self.send_timeout = AppleEvents.kAEDefaultTimeout
if start:
self.start()
def start(self):
"""Start the application, if it is not running yet"""
import findertools
import macfs
fss = macfs.FindApplication(self.target_signature)
findertools.launch(fss)
def newevent(self, code, subcode, parameters = {}, attributes = {}): def newevent(self, code, subcode, parameters = {}, attributes = {}):
"""Create a complete structure for an apple event""" """Create a complete structure for an apple event"""
@ -177,7 +193,7 @@ def get(self, _object, _attributes={}):
_reply, _arguments, _attributes = self.send(_code, _subcode, _reply, _arguments, _attributes = self.send(_code, _subcode,
_arguments, _attributes) _arguments, _attributes)
if _arguments.has_key('errn'): if _arguments.has_key('errn'):
raise MacOS.Error, decodeerror(_arguments) raise Error, decodeerror(_arguments)
if _arguments.has_key('----'): if _arguments.has_key('----'):
return _arguments['----'] return _arguments['----']