uawdijnntqw1x1x1
IP : 18.191.189.164
Hostname : host45.registrar-servers.com
Kernel : Linux host45.registrar-servers.com 4.18.0-513.18.1.lve.2.el8.x86_64 #1 SMP Sat Mar 30 15:36:11 UTC 2024 x86_64
Disable Function : None :)
OS : Linux
PATH:
/
home
/
..
/
lib64
/
td-agent-bit
/
..
/
python3.8
/
collections
/
..
/
__pycache__
/
pipes.cpython-38.opt-1.pyc
/
/
U e5d�"�@spdZddlZddlZddlZddlmZdgZdZdZdZ dZ d Zd Zeee e eegZ Gdd�d�Zdd �ZdS)a�Conversion pipeline templates. The problem: ------------ Suppose you have some data that you want to convert to another format, such as from GIF image format to PPM image format. Maybe the conversion involves several steps (e.g. piping it through compress or uuencode). Some of the conversion steps may require that their input is a disk file, others may be able to read standard input; similar for their output. The input to the entire conversion may also be read from a disk file or from an open file, and similar for its output. The module lets you construct a pipeline template by sticking one or more conversion steps together. It will take care of creating and removing temporary files if they are necessary to hold intermediate data. You can then use the template to do conversions from many different sources to many different destinations. The temporary file names used are different each time the template is used. The templates are objects so you can create templates for many different conversion steps and store them in a dictionary, for instance. Directions: ----------- To create a template: t = Template() To add a conversion step to a template: t.append(command, kind) where kind is a string of two characters: the first is '-' if the command reads its standard input or 'f' if it requires a file; the second likewise for the output. The command must be valid /bin/sh syntax. If input or output files are required, they are passed as $IN and $OUT; otherwise, it must be possible to use the command in a pipeline. To add a conversion step at the beginning: t.prepend(command, kind) To convert a file to another file using a template: sts = t.copy(infile, outfile) If infile or outfile are the empty string, standard input is read or standard output is written, respectively. The return value is the exit status of the conversion pipeline. To open a file for reading or writing through a conversion pipeline: fp = t.open(file, mode) where mode is 'r' to read the file, or 'w' to write it -- just like for the built-in function open() or for os.popen(). To create a new template object initialized to a given one: t2 = t.clone() �N)�quote�TemplateZffz-fzf-�--z.-z-.c@speZdZdZdd�Zdd�Zdd�Zdd �Zd d�Zdd �Z dd�Z dd�Zdd�Zdd�Z dd�Zdd�ZdS)rz'Class representing a pipeline template.cCsd|_|��dS)z-Template() returns a fresh pipeline template.rN)� debugging�reset��self�r �/usr/lib64/python3.8/pipes.py�__init__UszTemplate.__init__cCsd|jfS)z t.__repr__() implements repr(t).z<Template instance, steps=%r>��stepsrr r r �__repr__ZszTemplate.__repr__cCs g|_dS)z<t.reset() restores a pipeline template to its initial state.Nrrr r r r^szTemplate.resetcCs"t�}|jdd�|_|j|_|S)zbt.clone() returns a new pipeline template with identical initial state as the current one.N)rr r)r�tr r r �clonebszTemplate.clonecCs ||_dS)z(t.debug(flag) turns debugging on or off.N)r)r�flagr r r �debugjszTemplate.debugcCs�t|�td�k rtd��|tkr.td|f��|tkr>td��|jr^|jddtkr^td��|dd kr~t�d |�s~td��|dd kr�t�d|�s�td ��|j� ||f�dS)z/t.append(cmd, kind) adds a new step at the end.�z%Template.append: cmd must be a stringzTemplate.append: bad kind %rz-Template.append: SOURCE can only be prepended����z'Template.append: already ends with SINKr�f�\$IN\bz#Template.append: missing $IN in cmd�\$OUT\bz$Template.append: missing $OUT in cmdN) �type� TypeError� stepkinds� ValueError�SOURCEr �SINK�re�search�append�r�cmd�kindr r r r!nszTemplate.appendcCs�t|�td�k rtd��|tkr.td|f��|tkr>td��|jr^|jddtkr^td��|ddkr~t�d |�s~td ��|ddkr�t�d|�s�td��|j� d||f�d S)z2t.prepend(cmd, kind) adds a new step at the front.rz&Template.prepend: cmd must be a stringzTemplate.prepend: bad kind %rz+Template.prepend: SINK can only be appendedrrz,Template.prepend: already begins with SOURCErrz$Template.prepend: missing $IN in cmdrz%Template.prepend: missing $OUT in cmdN) rrrrrr rrr �insertr"r r r �prepend~szTemplate.prependcCs6|dkr|�|�S|dkr$|�|�Std|f��dS)z~t.open(file, rw) returns a pipe or file object open for reading or writing; the file is the other end of the pipeline.�r�wz,Template.open: rw must be 'r' or 'w', not %rN)�open_r�open_wr)r�fileZrwr r r �open�s �z Template.opencCsB|jst|d�S|jddtkr*td��|�|d�}t�|d�S)zit.open_r(file) and t.open_w(file) implement t.open(file, 'r') and t.open(file, 'w') respectively.r'rrz)Template.open_r: pipeline ends width SINKr)r r,rr�makepipeline�os�popen�rr+r#r r r r)�s zTemplate.open_rcCsB|jst|d�S|jddtkr*td��|�d|�}t�|d�S)Nr(rrz,Template.open_w: pipeline begins with SOURCEr)r r,rrr-r.r/r0r r r r*�s zTemplate.open_wcCst�|�||��S)N)r.�systemr-)r�infile�outfiler r r �copy�sz Template.copycCs(t||j|�}|jr$t|�d|}|S)Nzset -x; )r-r r�print)rr2r3r#r r r r-�s zTemplate.makepipelineN)�__name__� __module__�__qualname__�__doc__rrrrrr!r&r,r)r*r4r-r r r r rRs cCs�g}|D]\}}|�d||dg�q|s:|�ddddg�|ddd�\}}|ddkrr|sr|�dddddg�||dd<|ddd�\}}|ddkr�|s�|�ddddg�||dd<g}tdt|��D]v}||dd }||d } |ddk�s| ddkr�t��\} }t�| �|�|�|||dd<||d<q�|D]�}|\} }}}|ddk�r�d t|�d|}|ddk�r�dt| �d|}|dd k�r�| �r�|dt| �}|dd k�r�|�r�|dt|�}||d<�qN|dd}|dd�D]T}|dd�\}}|ddk�rTd|k�rFd|d}|d|}n|d|}�q|�r�d}|D]}|dt|�}�qrdt|d�d}|d|d|}|S)Nr�catrrr�rr�zOUT=z; zIN=�-z <z >z{ z; }z | � zrm -f� ztrap z; exitz 1 2 3 13 14 15) r!r%�range�len�tempfileZmkstempr.�closer)r2r r3�listr#r$Zgarbage�iZlkindZrkind�fdZtemp�item�infZoutfZcmdlistZrmcmdr+Ztrapcmdr r r r-�s` r-)r9rr.rBZshlexr�__all__ZFILEIN_FILEOUTZ STDIN_FILEOUTZ FILEIN_STDOUTZSTDIN_STDOUTrrrrr-r r r r �<module>s";�c
/home/../lib64/td-agent-bit/../python3.8/collections/../__pycache__/pipes.cpython-38.opt-1.pyc