Kaydet (Commit) 4755e7d5 authored tarafından Fred Drake's avatar Fred Drake

Three more modules documented by Moshe!

üst 1de2a927
......@@ -131,6 +131,7 @@ add new extensions to Python and how to embed it in other applications.
\input{libdircache}
\input{libstat}
\input{libstatcache}
\input{libstatvfs}
\input{libcmp}
\input{libcmpcache}
\input{libtime}
......@@ -156,6 +157,7 @@ add new extensions to Python and how to embed it in other applications.
\input{libbsddb}
\input{libzlib}
\input{libgzip}
\input{librlcompleter}
\input{libunix} % UNIX Specific Services
\input{libposix}
......@@ -166,6 +168,7 @@ add new extensions to Python and how to embed it in other applications.
\input{libgdbm}
\input{libtermios}
\input{libfcntl}
\input{libpipes}
\input{libposixfile}
\input{libresource}
\input{libsyslog}
......
\section{\module{pipes} ---
Interface to shell pipelines}
\declaremodule{standard}{pipes}
\platform{Unix}
\sectionauthor{Moshe Zadka}{mzadka@geocities.com}
\modulesynopsis{A Python interface to \UNIX{} shell pipelines.}
The \module{pipes} module defines a class to abstract the concept of
a \emph{pipeline} --- a sequence of convertors from one file to
another.
Because the module uses \program{/bin/sh} command lines, a \POSIX{} or
compatible shell for \function{os.system()} and \function{os.popen()}
is required.
The \module{pipes} module defines the following class:
\begin{classdesc}{Template}{}
An abstraction of a pipeline.
\end{funcdesc}
Example:
\begin{verbatim}
>>> import pipes
>>> t=pipes.Template()
>>> t.append('tr a-z A-Z', '--')
>>> f=t.open('/tmp/1', 'w')
>>> f.write('hello world')
>>> f.close()
>>> open('/tmp/1').read()
'HELLO WORLD'
\end{verbatim}
\subsection{Template Objects \label{template-objects}}
Template objects following methods:
\begin{methoddesc}{reset}{}
Restore a pipeline template to its initial state.
\end{methoddesc}
\begin{methoddesc}{clone}{}
Return a new, equivalent, pipeline template.
\end{methoddesc}
\begin{methoddesc}{debug}{flag}
If \var{flag} is true, turn debugging on. Otherwise, turn debugging
off. When debugging is on, commands to be executed are printed, and
the shell is given \code{set -x} command to be more verbose.
\end{methoddesc}
\begin{methoddesc}{append}{cmd, kind}
Append a new action at the end. The \var{cmd} variable must be a valid
bourne shell command. The \var{kind} variable consists of two letters.
The first letter can be either of \code{'-'} (which means the command
reads its standard input), \code{'f'} (which means the commands reads
a given file on the command line) or \code{'.'} (which means the commands
reads no input, and hence must be first.)
Similarily, the second letter can be either of \code{'-'} (which means
the command writes to standard output), \code{'f'} (which means the
command writes a file on the command line) or \code{'.'} (which means
the command does not write anything, and hence must be last.)
\end{methoddesc}
\begin{methoddesc}{prepend}{cmd, kind}
Add a new action at the beginning. See \method{append()} for explanations
of the arguments.
\end{methoddesc}
\begin{methoddesc}{open}{file, mode}
Return a file-like object, open to \var{file}, but read from or
written to by the pipeline. Note that only one of \code{'r'},
\code{'w'} may be given.
\end{methoddesc}
\begin{methoddesc}{copy}{infile, outfile}
Copy \var{infile} to \var{outfile} through the pipe.
\end{methoddesc}
\section{\module{rlcompleter} ---
Completion function for readline}
\declaremodule{standard}{rlcompleter}
\sectionauthor{Moshe Zadka}{mzadka@geocities.com}
\modulesynopsis{Python identifier completion in the readline library.}
The \module{rlcompleter} module defines a completion function for
the \module{readline} module by completing valid Python identifiers and
keyword.
The \module{rlcompleter} module defines the \class{Completer} class.
Example:
\begin{verbatim}
>>> import rlcompleter
>>> import readline
>>> readline.parse_and_bind("tab: complete")
>>> readline. <TAB PRESSED>
readline.__doc__ readline.get_line_buffer readline.read_init_file
readline.__file__ readline.insert_text readline.set_completer
readline.__name__ readline.parse_and_bind
>>> readline.
\end{verbatim}
The \module{rlcompleter} module is designed for use with Python's
interactive mode. A user can add the following lines to his or her
initialization file (identified by the \envvar{PYTHONSTARTUP}
environment variable) to get automatic \kbd{Tab} completion:
\begin{verbatim}
try:
import readline
except ImportError:
print "Module readline not available."
else:
import rlcompleter
readline.parse_and_bind("tab: complete")
\end{verbatim}
\subsection{Completer Objects \label{completer-objects}}
Completer objects have the following method:
\begin{methoddesc}[Completer]{complete}{text, state}
Return the \var{state}th completion for \var{text}.
If called for \var{text} that doesn't includea period character
(\character{.}), it will complete from names currently defined in
\refmodule{__main__}, \refmodule{__builtin__} and keywords (as defined
by the \refmodule{keyword} module).
If called for a dotted name, it will try to evaluate anything without
obvious side-effects (i.e., functions will not be evaluated, but it
can generate calls to \method{__getattr__()}) upto the last part, and
find matches for the rest via the \function{dir()} function.
\end{methoddesc}
\section{\module{statvfs} ---
Constants used with \function{os.statvfs()}}
\declaremodule{standard}{statvfs}
% LaTeX'ed from comments in module
\sectionauthor{Moshe Zadka}{mzadka@geocities.com}
\modulesynopsis{Constants for interpreting the result of
\function{os.statvfs()}.}
The \module{statvfs} module defines constants so interpreting the result
if \function{os.statvfs()}, which returns a tuple, can be made without
remembering ``magic numbers.'' Each of the constants defined in this
module is the \emph{index} of the entry in the tuple returned by
\function{os.statvfs()} that contains the specified information.
\begin{datadesc}{F_BSIZE}
Preferred file system block size.
\end{datadesc}
\begin{datadesc}{F_FRSIZE}
Fundamental file system block size.
\end{datadesc}
\begin{datadesc}{F_BFREE}
Total number of free blocks.
\end{datadesc}
\begin{datadesc}{F_BAVAIL}
Free blocks available to non-super user.
\end{datadesc}
\begin{datadesc}{F_FILES}
Total number of file nodes.
\end{datadesc}
\begin{datadesc}{F_FFREE}
Total number of free file nodes.
\end{datadesc}
\begin{datadesc}{F_FAVAIL}
Free nodes available to non-superuser.
\end{datadesc}
\begin{datadesc}{F_FLAG}
Flags. System dependant: see \cfunction{statvfs()} man page.
\end{datadesc}
\begin{datadesc}{F_NAMEMAX}
Maximum file name length.
\end{datadesc}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment