| \section{\module{pipes} --- |
| Interface to shell pipelines} |
| |
| \declaremodule{standard}{pipes} |
| \platform{Unix} |
| \sectionauthor{Moshe Zadka}{moshez@zadka.site.co.il} |
| \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{classdesc} |
| |
| 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.) |
| |
| Similarly, 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} |