mirror of https://github.com/python/cpython.git
- 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:
parent
0585d41198
commit
c46f56e35f
|
@ -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['----']
|
||||||
|
|
Loading…
Reference in New Issue