source: trunk/essentials/dev-lang/python/Doc/lib/libtelnetlib.tex@ 3368

Last change on this file since 3368 was 3225, checked in by bird, 19 years ago

Python 2.5

File size: 7.0 KB
Line 
1\section{\module{telnetlib} ---
2 Telnet client}
3
4\declaremodule{standard}{telnetlib}
5\modulesynopsis{Telnet client class.}
6\sectionauthor{Skip Montanaro}{[email protected]}
7
8\index{protocol!Telnet}
9
10The \module{telnetlib} module provides a \class{Telnet} class that
11implements the Telnet protocol. See \rfc{854} for details about the
12protocol. In addition, it provides symbolic constants for the protocol
13characters (see below), and for the telnet options. The
14symbolic names of the telnet options follow the definitions in
15\code{arpa/telnet.h}, with the leading \code{TELOPT_} removed. For
16symbolic names of options which are traditionally not included in
17\code{arpa/telnet.h}, see the module source itself.
18
19The symbolic constants for the telnet commands are: IAC, DONT, DO,
20WONT, WILL, SE (Subnegotiation End), NOP (No Operation), DM (Data
21Mark), BRK (Break), IP (Interrupt process), AO (Abort output), AYT
22(Are You There), EC (Erase Character), EL (Erase Line), GA (Go Ahead),
23SB (Subnegotiation Begin).
24
25
26\begin{classdesc}{Telnet}{\optional{host\optional{, port}}}
27\class{Telnet} represents a connection to a Telnet server. The
28instance is initially not connected by default; the \method{open()}
29method must be used to establish a connection. Alternatively, the
30host name and optional port number can be passed to the constructor,
31to, in which case the connection to the server will be established
32before the constructor returns.
33
34Do not reopen an already connected instance.
35
36This class has many \method{read_*()} methods. Note that some of them
37raise \exception{EOFError} when the end of the connection is read,
38because they can return an empty string for other reasons. See the
39individual descriptions below.
40\end{classdesc}
41
42
43\begin{seealso}
44 \seerfc{854}{Telnet Protocol Specification}{
45 Definition of the Telnet protocol.}
46\end{seealso}
47
48
49
50\subsection{Telnet Objects \label{telnet-objects}}
51
52\class{Telnet} instances have the following methods:
53
54
55\begin{methoddesc}{read_until}{expected\optional{, timeout}}
56Read until a given string, \var{expected}, is encountered or until
57\var{timeout} seconds have passed.
58
59When no match is found, return whatever is available instead,
60possibly the empty string. Raise \exception{EOFError} if the connection
61is closed and no cooked data is available.
62\end{methoddesc}
63
64\begin{methoddesc}{read_all}{}
65Read all data until \EOF; block until connection closed.
66\end{methoddesc}
67
68\begin{methoddesc}{read_some}{}
69Read at least one byte of cooked data unless \EOF{} is hit.
70Return \code{''} if \EOF{} is hit. Block if no data is immediately
71available.
72\end{methoddesc}
73
74\begin{methoddesc}{read_very_eager}{}
75Read everything that can be without blocking in I/O (eager).
76
77Raise \exception{EOFError} if connection closed and no cooked data
78available. Return \code{''} if no cooked data available otherwise.
79Do not block unless in the midst of an IAC sequence.
80\end{methoddesc}
81
82\begin{methoddesc}{read_eager}{}
83Read readily available data.
84
85Raise \exception{EOFError} if connection closed and no cooked data
86available. Return \code{''} if no cooked data available otherwise.
87Do not block unless in the midst of an IAC sequence.
88\end{methoddesc}
89
90\begin{methoddesc}{read_lazy}{}
91Process and return data already in the queues (lazy).
92
93Raise \exception{EOFError} if connection closed and no data available.
94Return \code{''} if no cooked data available otherwise. Do not block
95unless in the midst of an IAC sequence.
96\end{methoddesc}
97
98\begin{methoddesc}{read_very_lazy}{}
99Return any data available in the cooked queue (very lazy).
100
101Raise \exception{EOFError} if connection closed and no data available.
102Return \code{''} if no cooked data available otherwise. This method
103never blocks.
104\end{methoddesc}
105
106\begin{methoddesc}{read_sb_data}{}
107Return the data collected between a SB/SE pair (suboption begin/end).
108The callback should access these data when it was invoked with a
109\code{SE} command. This method never blocks.
110
111\versionadded{2.3}
112\end{methoddesc}
113
114\begin{methoddesc}{open}{host\optional{, port}}
115Connect to a host.
116The optional second argument is the port number, which
117defaults to the standard Telnet port (23).
118
119Do not try to reopen an already connected instance.
120\end{methoddesc}
121
122\begin{methoddesc}{msg}{msg\optional{, *args}}
123Print a debug message when the debug level is \code{>} 0.
124If extra arguments are present, they are substituted in the
125message using the standard string formatting operator.
126\end{methoddesc}
127
128\begin{methoddesc}{set_debuglevel}{debuglevel}
129Set the debug level. The higher the value of \var{debuglevel}, the
130more debug output you get (on \code{sys.stdout}).
131\end{methoddesc}
132
133\begin{methoddesc}{close}{}
134Close the connection.
135\end{methoddesc}
136
137\begin{methoddesc}{get_socket}{}
138Return the socket object used internally.
139\end{methoddesc}
140
141\begin{methoddesc}{fileno}{}
142Return the file descriptor of the socket object used internally.
143\end{methoddesc}
144