| \section{Built-in Module \sectcode{ctb}} |
| \bimodindex{ctb} |
| \renewcommand{\indexsubitem}{(in module ctb)} |
| |
| This module provides a partial interface to the Macintosh |
| Communications Toolbox. Currently, only Connection Manager tools are |
| supported. It may not be available in all Mac Python versions. |
| |
| \begin{datadesc}{error} |
| The exception raised on errors. |
| \end{datadesc} |
| |
| \begin{datadesc}{cmData} |
| \dataline{cmCntl} |
| \dataline{cmAttn} |
| Flags for the \var{channel} argument of the \var{Read} and \var{Write} |
| methods. |
| \end{datadesc} |
| |
| \begin{datadesc}{cmFlagsEOM} |
| End-of-message flag for \var{Read} and \var{Write}. |
| \end{datadesc} |
| |
| \begin{datadesc}{choose*} |
| Values returned by \var{Choose}. |
| \end{datadesc} |
| |
| \begin{datadesc}{cmStatus*} |
| Bits in the status as returned by \var{Status}. |
| \end{datadesc} |
| |
| \begin{funcdesc}{available}{} |
| Return 1 if the communication toolbox is available, zero otherwise. |
| \end{funcdesc} |
| |
| \begin{funcdesc}{CMNew}{name\, sizes} |
| Create a connection object using the connection tool named |
| \var{name}. \var{sizes} is a 6-tuple given buffer sizes for data in, |
| data out, control in, control out, attention in and attention out. |
| Alternatively, passing \code{None} will result in default buffer sizes. |
| \end{funcdesc} |
| |
| \subsection{connection object} |
| For all connection methods that take a \var{timeout} argument, a value |
| of \code{-1} is indefinite, meaning that the command runs to completion. |
| |
| \renewcommand{\indexsubitem}{(connection object attribute)} |
| |
| \begin{datadesc}{callback} |
| If this member is set to a value other than \code{None} it should point |
| to a function accepting a single argument (the connection |
| object). This will make all connection object methods work |
| asynchronously, with the callback routine being called upon |
| completion. |
| |
| {\em Note:} for reasons beyond my understanding the callback routine |
| is currently never called. You are advised against using asynchronous |
| calls for the time being. |
| \end{datadesc} |
| |
| |
| \renewcommand{\indexsubitem}{(connection object method)} |
| |
| \begin{funcdesc}{Open}{timeout} |
| Open an outgoing connection, waiting at most \var{timeout} seconds for |
| the connection to be established. |
| \end{funcdesc} |
| |
| \begin{funcdesc}{Listen}{timeout} |
| Wait for an incoming connection. Stop waiting after \var{timeout} |
| seconds. This call is only meaningful to some tools. |
| \end{funcdesc} |
| |
| \begin{funcdesc}{accept}{yesno} |
| Accept (when \var{yesno} is non-zero) or reject an incoming call after |
| \var{Listen} returned. |
| \end{funcdesc} |
| |
| \begin{funcdesc}{Close}{timeout\, now} |
| Close a connection. When \var{now} is zero, the close is orderly |
| (i.e.\ outstanding output is flushed, etc.)\ with a timeout of |
| \var{timeout} seconds. When \var{now} is non-zero the close is |
| immediate, discarding output. |
| \end{funcdesc} |
| |
| \begin{funcdesc}{Read}{len\, chan\, timeout} |
| Read \var{len} bytes, or until \var{timeout} seconds have passed, from |
| the channel \var{chan} (which is one of \var{cmData}, \var{cmCntl} or |
| \var{cmAttn}). Return a 2-tuple:\ the data read and the end-of-message |
| flag. |
| \end{funcdesc} |
| |
| \begin{funcdesc}{Write}{buf\, chan\, timeout\, eom} |
| Write \var{buf} to channel \var{chan}, aborting after \var{timeout} |
| seconds. When \var{eom} has the value \var{cmFlagsEOM} an |
| end-of-message indicator will be written after the data (if this |
| concept has a meaning for this communication tool). The method returns |
| the number of bytes written. |
| \end{funcdesc} |
| |
| \begin{funcdesc}{Status}{} |
| Return connection status as the 2-tuple \code{(\var{sizes}, |
| \var{flags})}. \var{sizes} is a 6-tuple giving the actual buffer sizes used |
| (see \var{CMNew}), \var{flags} is a set of bits describing the state |
| of the connection. |
| \end{funcdesc} |
| |
| \begin{funcdesc}{GetConfig}{} |
| Return the configuration string of the communication tool. These |
| configuration strings are tool-dependent, but usually easily parsed |
| and modified. |
| \end{funcdesc} |
| |
| \begin{funcdesc}{SetConfig}{str} |
| Set the configuration string for the tool. The strings are parsed |
| left-to-right, with later values taking precedence. This means |
| individual configuration parameters can be modified by simply appending |
| something like \code{'baud 4800'} to the end of the string returned by |
| \var{GetConfig} and passing that to this method. The method returns |
| the number of characters actually parsed by the tool before it |
| encountered an error (or completed successfully). |
| \end{funcdesc} |
| |
| \begin{funcdesc}{Choose}{} |
| Present the user with a dialog to choose a communication tool and |
| configure it. If there is an outstanding connection some choices (like |
| selecting a different tool) may cause the connection to be |
| aborted. The return value (one of the \var{choose*} constants) will |
| indicate this. |
| \end{funcdesc} |
| |
| \begin{funcdesc}{Idle}{} |
| Give the tool a chance to use the processor. You should call this |
| method regularly. |
| \end{funcdesc} |
| |
| \begin{funcdesc}{Abort}{} |
| Abort an outstanding asynchronous \var{Open} or \var{Listen}. |
| \end{funcdesc} |
| |
| \begin{funcdesc}{Reset}{} |
| Reset a connection. Exact meaning depends on the tool. |
| \end{funcdesc} |
| |
| \begin{funcdesc}{Break}{length} |
| Send a break. Whether this means anything, what it means and |
| interpretation of the \var{length} parameter depend on the tool in |
| use. |
| \end{funcdesc} |