"pipes" --- Interfaz para tuberías de shell
*******************************************

**Código fuente:** Lib/pipes.py

Obsoleto desde la versión 3.11: The "pipes" module is deprecated (see
**PEP 594** for details). Please use the "subprocess" module instead.

======================================================================

El módulo "pipes" define una clase para abstraer el concepto de una
*tubería* --- una secuencia de conversores de un archivo a otro.

Debido a que el módulo utiliza líneas de comando **/bin/sh**, se
requiere una interfaz POSIX o un shell compatible para ejecutar
"os.system()" y "os.popen()".

El módulo "pipes" define la siguiente clase:

class pipes.Template

   Una abstracción de una tubería.

Ejemplo:

   >>> import pipes
   >>> t = pipes.Template()
   >>> t.append('tr a-z A-Z', '--')
   >>> f = t.open('pipefile', 'w')
   >>> f.write('hello world')
   >>> f.close()
   >>> open('pipefile').read()
   'HELLO WORLD'


Objetos Template
================

Las instancias Template tienen los siguientes métodos:

Template.reset()

   Recupera el estado inicial del Template de una tubería.

Template.clone()

   Retorna una nueva y equivalente instancia del Template de una
   tubería.

Template.debug(flag)

   Si  *flag* es verdadero, activa la depuración. Si no, la depuración
   no se activa. Cuando la depuración está activada, los comandos a
   ejecutar son impresos, y se le añade el comando "set -x" a la shell
   para ser más verboso.

Template.append(cmd, kind)

   Añade una nueva acción al final. La variable *cmd* tiene que ser un
   comando válido de *Bourne Shell*. La variable *kind* está formada
   por dos letras.

   La primera letra puede ser tanto "'-'" (que significa que el
   comando lee su entrada de datos estándar), "'f'" (que significa que
   el comando lee un fichero desde línea de comandos) o "'.'" (que
   significa que el comando no lee ninguna entrada de datos, y por
   tanto tiene que ser el primero.)

   De manera parecida, la segunda letra puede ser tanto "'-'" (que
   significa que el comando escribe a la salida de datos estándar),
   "'f'" (que significa que el comando escribirá a un fichero de la
   línea de comandos) o "'.'" (que significa que el comando no escribe
   nada, por lo que debe ser el primero)

Template.prepend(cmd, kind)

   Añade una nueva acción al principio. Ver "append()" para la
   explicación de los argumentos.

Template.open(file, mode)

   Retorna un objeto similar a un fichero, abierto a *file*, pero
   leído o escrito por la tubería. Destacar que solo una de "'r'" o
   "'w'" puede ser añadida.

Template.copy(infile, outfile)

   Copia *infile* a *outfile* a través de la tubería.
