mirror of
				https://github.com/python/cpython.git
				synced 2025-11-04 03:44:55 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			149 lines
		
	
	
	
		
			5 KiB
		
	
	
	
		
			TeX
		
	
	
	
	
	
			
		
		
	
	
			149 lines
		
	
	
	
		
			5 KiB
		
	
	
	
		
			TeX
		
	
	
	
	
	
\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}
 |