0
0
mirror of https://github.com/python/cpython.git synced 2024-11-29 00:56:12 +01:00
cpython/Doc/mac/libminiae.tex

66 lines
2.5 KiB
TeX
Raw Normal View History

1998-08-10 20:40:22 +02:00
\section{\module{MiniAEFrame} ---
1999-03-02 17:37:17 +01:00
Open Scripting Architecture server support}
1999-03-02 17:37:17 +01:00
\declaremodule{standard}{MiniAEFrame}
\platform{Mac}
\modulesynopsis{Support to act as an Open Scripting Architecture (OSA) server
(``Apple Events'').}
1998-04-04 08:23:02 +02:00
The module \module{MiniAEFrame} provides a framework for an application
that can function as an Open Scripting Architecture
\index{Open Scripting Architecture}
(OSA) server, i.e. receive and process
AppleEvents\index{AppleEvents}. It can be used in conjunction with
\refmodule{FrameWork}\refstmodindex{FrameWork} or standalone. As an
example, it is used in \program{PythonCGISlave}.
1998-04-04 08:23:02 +02:00
The \module{MiniAEFrame} module defines the following classes:
1998-04-04 08:23:02 +02:00
\begin{classdesc}{AEServer}{}
A class that handles AppleEvent dispatch. Your application should
subclass this class together with either
1998-04-04 08:23:02 +02:00
\class{MiniApplication} or
\class{FrameWork.Application}. Your \method{__init__()} method should
call the \method{__init__()} method for both classes.
\end{classdesc}
1998-04-04 08:23:02 +02:00
\begin{classdesc}{MiniApplication}{}
A class that is more or less compatible with
1998-04-04 08:23:02 +02:00
\class{FrameWork.Application} but with less functionality. Its
event loop supports the apple menu, command-dot and AppleEvents; other
events are passed on to the Python interpreter and/or Sioux.
1998-04-04 08:23:02 +02:00
Useful if your application wants to use \class{AEServer} but does not
provide its own windows, etc.
1998-04-04 08:23:02 +02:00
\end{classdesc}
1999-03-02 17:37:17 +01:00
\subsection{AEServer Objects \label{aeserver-objects}}
1998-04-04 08:23:02 +02:00
\begin{methoddesc}[AEServer]{installaehandler}{classe, type, callback}
Installs an AppleEvent handler. \var{classe} and \var{type} are the
four-character OSA Class and Type designators, \code{'****'} wildcards
are allowed. When a matching AppleEvent is received the parameters are
decoded and your callback is invoked.
1998-04-04 08:23:02 +02:00
\end{methoddesc}
1998-04-04 08:23:02 +02:00
\begin{methoddesc}[AEServer]{callback}{_object, **kwargs}
Your callback is called with the OSA Direct Object as first positional
parameter. The other parameters are passed as keyword arguments, with
1998-04-04 08:23:02 +02:00
the 4-character designator as name. Three extra keyword parameters are
passed: \code{_class} and \code{_type} are the Class and Type
designators and \code{_attributes} is a dictionary with the AppleEvent
attributes.
The return value of your method is packed with
1998-04-04 08:23:02 +02:00
\function{aetools.packevent()} and sent as reply.
\end{methoddesc}
Note that there are some serious problems with the current
1998-04-04 08:23:02 +02:00
design. AppleEvents which have non-identifier 4-character designators
for arguments are not implementable, and it is not possible to return
an error to the originator. This will be addressed in a future
release.