HEX
Server: Apache
System: Linux pdx1-shared-a1-38 6.6.104-grsec-jammy+ #3 SMP Tue Sep 16 00:28:11 UTC 2025 x86_64
User: mmickelson (3396398)
PHP: 8.1.31
Disabled: NONE
Upload Files
File: //lib/python3/dist-packages/ptyprocess/__pycache__/ptyprocess.cpython-310.pyc
o

5��_�{�@shddlZddlZddlZddlZddlZddlZddlZddlZddlZddl	Z	ddl
Z
ddlZzddlZWn
e
yCddlZYnwddlmZmZddlmZmZe	j��Ze�d�pbe�d�ZerndZddlmZnd	Ze	jdd
kZer~dd�Znd
d�ZGdd�de�Z Gdd�de�Z!d\a"a#dd�Z$dd�Z%dd�Z&Gdd�de'�Z(Gdd�de(�Z)dS)�N)�STDIN_FILENO�CHILD�)�which�PtyProcessError�solaris�sunosF)�	_fork_ptyT�cCs
t|g�S�N)�bytes��i�r�7/usr/lib/python3/dist-packages/ptyprocess/ptyprocess.py�_byte(s
rcCst|�Sr)�chrr
rrrr+sc@�eZdZdS)�FileNotFoundErrorN��__name__�
__module__�__qualname__rrrrr.�rc@r)�TimeoutErrorNrrrrrr/rr)NNc	Cs"tdur
tdur
dSzPddlm}m}d}dD]#}ttd|d�}|dus*t|d�s+qz|��}Wqt	y:Yqw|durCt	d��t
t�|�d|�}t
t�|�d|�}Wn,tt
tt	tjfy�zdd	lm}m}||}}Wn
ty�d
\}}YnwYnwt|�at|�adS)zkSet constants _EOF and _INTR.
    
    This avoids doing potentially costly operations on module load.
    Nr)�VEOF�VINTR)�stdin�stdoutz__%s__�filenozNo stream has a fileno�)�CEOF�CINTR)r
�)�_EOF�_INTR�termiosrr�getattr�sys�hasattrr�
ValueError�ord�	tcgetattr�ImportError�OSError�IOError�errorr!r"r)	rr�fd�name�stream�intr�eofr!r"rrr�_make_eof_intr3s:����r6c
Cs�d}zt�|�}Wn%tjy.}z|jdtjkr)t|jdd|jd|f���d}~ww|r;|dtjB|d<n
|dtj@|d<zt�|tj	|�WdStyt}z|jdtjkrot|jdd|jd|f���d}~ww)Nz~setecho() may not be called on this platform (it may still be possible to enable/disable echo when spawning the child process)r�%s: %s.rr
)
r&r,r0�args�errno�EINVALr/�ECHO�	tcsetattr�TCSANOW)r1�state�errmsg�attr�errrrr�_setecho^s(����rBcCs0ttdd�}t�d||dd�}t�|||�dS)N�
TIOCSWINSZigt��HHHHr)r'r&�struct�pack�fcntl�ioctl)r1�rows�colsrC�srrr�_setwinsizevsrLc@sTeZdZdZeZerej�	d�Zd�	d�Z
edd��Zn	ejZdZ
e
jjZdZdZdZdZdd�Ze		dBdd
��Zdd�Zedd��Zedd��Zdd�Zdd�ZdCdd�Zdd�Zdd�ZdDdd�Zd d!�Z d"d#�Z!dEd%d&�Z"d'd(�Z#dCd)d*�Z$dCd+d,�Zd-d.�Z%d/d0�Z&d1d2�Z'd3d4�Z(dFd6d7�Z)d8d9�Z*d:d;�Z+d<d=�Z,d>d?�Z-d@dA�Z.dS)G�
PtyProcessz�This class represents a process running in a pseudoterminal.
    
    The main constructor is the :meth:`spawn` classmethod.
    �asciiz
c	Cs8ztjj�|�WStytj�|�dd��YSw)NrN�replace)r(r�buffer�write�AttributeError�decode)�brrr�write_to_stdout�s
�zPtyProcess.write_to_stdoutNcCsvt�||_||_tj|ddd�}tj|dddd�}t�||�|_d|_d|_d|_	d|_
d|_d|_d|_
d|_dS)N�rbr)�	buffering�wbF)rW�closefd皙�����?)r6�pidr1�io�open�BufferedRWPair�fileobj�
terminated�closed�
exitstatus�signalstatus�status�flag_eof�delayafterclose�delayafterterminate)�selfr[r1�readf�writefrrr�__init__�s
zPtyProcess.__init__T���Prc
Cs�t|ttf�s
td|��|dd�}|d}t|�}	|	dur'tdd|��|	}||d<t��\}
}tr<t	�
�\}}
nt��\}}
|t
k�rnz
ttg|�R�Wntyo}z|jdtjtjfvre�WYd}~nd}~ww|s�zttd�Wn!ttjfy�}z|jdtjtjfvr��WYd}~nd}~wwt�|
�t�|tjtj�tdt�tj�d�}t t!|�|hB�}t"dg|||g�D]}t�#|dd	|d	�q�|dur�t�$|�|du�r#z|�Wn8t%�y"}z+t&|�j'}d
�(|t)|��}t*�r|�+d�}t�,||�t�|�t�-d	�WYd}~nd}~wwz|du�r0t�.||�nt�/|||�Wn5t0�ym}z(d�(|jt)|��}t*�rR|�+d�}t�,||�t�|�t�-tj1�WYd}~nd}~ww|||
�}||_2|du�r~||_3|du�r�||_4t�|�t�5|
d
�}t�|
�t6|�dk�r�z*|�7dd�\}}}t8t9|�:d�t%�}||�:dd��}|t0u�r�t;|�|_W|�W|�t%d|��z|j<|�W|St�y�}z|jdtjtjtj=fv�r�WYd}~|Sd}~ww)a�Start the given command in a child process in a pseudo terminal.

        This does all the fork/exec type of stuff for a pty, and returns an
        instance of PtyProcess.

        If preexec_fn is supplied, it will be called with no arguments in the
        child process before exec-ing the specified command.
        It may, for instance, set signal handlers to SIG_DFL or SIG_IGN.

        Dimensions of the psuedoterminal used for the subprocess can be
        specified as a tuple (rows, cols), or the default (24, 80) will be used.

        By default, all file descriptors except 0, 1 and 2 are closed. This
        behavior can be overridden with pass_fds, a list of file descriptors to
        keep open between the parent and the child.
        z)Expected a list or tuple for argv, got %rNrz%The command was not found or was not zexecutable: %s.Fi�rz{}:0:{}�utf-8z
OSError:{}:{}i�:rNrOz)Subprocess failed, got bad error data: %r)>�
isinstance�list�tuple�	TypeErrorrr�os�pipe�use_native_pty_fork�pty�forkr	�fork_ptyrrLrr/r8r9r:�ENOTTYrBr&r0�closerG�F_SETFD�
FD_CLOEXEC�min�resource�	getrlimit�
RLIMIT_NOFILE�sorted�set�zip�
closerange�chdir�	Exception�typer�format�str�PY3�encoderQ�_exit�execv�execvper.�EX_OSERR�argv�env�
launch_dir�read�len�splitr'�builtinsrS�int�
setwinsize�ENXIO)�clsr��cwdr��echo�
preexec_fn�
dimensions�pass_fds�command�command_with_path�exec_err_pipe_read�exec_err_pipe_writer[r1rA�max_fd�	spass_fds�pair�e�ename�tosend�inst�
exec_err_data�errclass�errno_sr?�exctype�	exceptionrrr�spawn�s��	
������






��

�

��





����
���zPtyProcess.spawncCsxt|�j}|jdur3t|j�g}|jdur|�d|j�|jdur*|�d|j�d�|d�|��Sd�||j	|j
�S)Nzenv=%rzcwd=%rz{}.spawn({})z, z{}(pid={}, fd={}))r�rr��reprr��appendr�r��joinr[r1)rh�clsnamer8rrr�__repr__Zs



zPtyProcess.__repr__cCst|t�s
|�d�S|S)Nrp)rrrr��rKrrr�_coerce_send_stringhs

zPtyProcess._coerce_send_stringcCs|Srrr�rrr�_coerce_read_stringnszPtyProcess._coerce_read_stringcCs&|jsz|��WdSYdSdS)aLThis makes sure that no system resources are left open. Python only
        garbage collects Python objects. OS file descriptors are not Python
        objects, so they must be handled explicitly. If the child file
        descriptor was opened outside of this class (passed to the constructor)
        then this does not close it. N)rar}�rhrrr�__del__rs�zPtyProcess.__del__cC�|jS)zCThis returns the file descriptor of the pty for the child.
        )r1r�rrrr�szPtyProcess.filenocCsR|js'|��|j��t�|j�|��r|�|�st	d��d|_
d|_dSdS)a?This closes the connection with the child application. Note that
        calling close() more than once is valid. This emulates standard Python
        behavior with files. Set force to True if you want to make sure that
        the child is terminated (SIGKILL is sent if the child ignores SIGHUP
        and SIGINT). zCould not terminate the child.���TN)ra�flushr_r}�time�sleeprf�isalive�	terminaterr1�rh�forcerrrr}�s


�zPtyProcess.closecCsdS)zWThis does nothing. It is here to support the interface for a
        File-like object. Nrr�rrrr��szPtyProcess.flushcCst�|j�S)a^This returns True if the file descriptor is open and connected to a
        tty(-like) device, else False.

        On SVR4-style platforms implementing streams, such as SunOS and HP-UX,
        the child pty may not appear as a terminal device.  This means
        methods such as setecho(), setwinsize(), getwinsize() may raise an
        IOError. )rv�isattyr1r�rrrr��s	zPtyProcess.isattycCsV|dur
t��|}	|��sdS|dkr|durdS|dur%|t��}t�d�q)a�This waits until the terminal ECHO flag is set False. This returns
        True if the echo mode is off. This returns False if the ECHO flag was
        not set False before the timeout. This can be used to detect when the
        child is waiting for a password. Usually a child application will turn
        off echo mode when it is waiting for the user to enter a password. For
        example, instead of expecting the "password:" prompt you can wait for
        the child to set ECHO off::

            p = pexpect.spawn('ssh user@example.com')
            p.waitnoecho()
            p.sendline(mypassword)

        If timeout==None then this method to block until ECHO flag is False.
        NTrFrZ)r��getechor�)rh�timeout�end_timerrr�
waitnoecho�s
�zPtyProcess.waitnoechoc
Cszzt�|j�}Wn'tjy/}zd}|jdtjkr*t|jdd|jd|f���d}~wwt|dtj	@�|_
|j
S)aThis returns the terminal echo mode. This returns True if echo is
        on or False if echo is off. Child applications that are expecting you
        to enter a password often set ECHO False. See waitnoecho().

        Not supported on platforms where ``isatty()`` returns False.  z,getecho() may not be called on this platformrr7rNr
)r&r,r1r0r8r9r:r/�boolr;r�)rhr@rAr?rrrr��s��zPtyProcess.getechocCst|j|�||_dS)aZThis sets the terminal echo mode on or off. Note that anything the
        child sent before the echo will be lost, so you should be sure that
        your input buffer is empty before you call setecho(). For example, the
        following will work as expected::

            p = pexpect.spawn('cat') # Echo is on by default.
            p.sendline('1234') # We expect see this twice from the child...
            p.expect(['1234']) # ... once from the tty echo...
            p.expect(['1234']) # ... and again from cat itself.
            p.setecho(False) # Turn off tty echo
            p.sendline('abcd') # We will set this only once (echoed by cat).
            p.sendline('wxyz') # We will set this only once (echoed by cat)
            p.expect(['abcd'])
            p.expect(['wxyz'])

        The following WILL NOT WORK because the lines sent before the setecho
        will be lost::

            p = pexpect.spawn('cat')
            p.sendline('1234')
            p.setecho(False) # Turn off tty echo
            p.sendline('abcd') # We will set this only once (echoed by cat).
            p.sendline('wxyz') # We will set this only once (echoed by cat)
            p.expect(['1234'])
            p.expect(['1234'])
            p.expect(['abcd'])
            p.expect(['wxyz'])


        Not supported on platforms where ``isatty()`` returns False.
        N)rBr1r�)rhr>rrr�setecho�s 
zPtyProcess.setecho�c
Cshz|j�|�}Wnttfy&}z|jdtjkr!d|_td���d}~ww|dkr2d|_td��|S)aRead and return at most ``size`` bytes from the pty.

        Can block if there is nothing to read. Raises :exc:`EOFError` if the
        terminal was closed.
        
        Unlike Pexpect's ``read_nonblocking`` method, this doesn't try to deal
        with the vagaries of EOF on platforms that do strange things, like IRIX
        or older Solaris systems. It handles the errno=EIO pattern used on
        Linux, and the empty-string return used on BSD platforms and (seemingly)
        on recent Solaris.
        rT�,End Of File (EOF). Exception style platform.N��/End Of File (EOF). Empty string style platform.)	r_�read1r.r/r8r9�EIOre�EOFError)rh�sizerKrArrrr��s��zPtyProcess.readc
Csfz|j��}Wnttfy%}z|jdtjkr d|_td���d}~ww|dkr1d|_td��|S)��Read one line from the pseudoterminal, and return it as unicode.

        Can block if there is nothing to read. Raises :exc:`EOFError` if the
        terminal was closed.
        rTr�Nr�r�)	r_�readliner.r/r8r9r�rer�)rhrKrArrrr�s��zPtyProcess.readlinecCs|j�|�}|r
|j��|Sr)r_rQr�)rhrTr��nrrr�_writeb-s
zPtyProcess._writebcCs|j||d�S)zaWrite bytes to the pseudoterminal.
        
        Returns the number of bytes written.
        )r�)r�)rhrKr�rrrrQ3szPtyProcess.writec
Cs�|��}t|�}d|krdkr'nn|td�d}t|�}|�|�|fSddddddddd	d	d
dd�}||vr<d
St||�}|�|�|fS)aHelper method that wraps send() with mnemonic access for sending control
        character to the child (such as Ctrl-C or Ctrl-D).  For example, to send
        Ctrl-G (ASCII 7, bell, '')::

            child.sendcontrol('g')

        See also, sendintr() and sendeof().
        �a�z�arr������)�@�`�[�{�\�|�]�}�^�~�_�?)rr�)�lowerr+rr�)rh�charr��byte�drrr�sendcontrol:s$	�zPtyProcess.sendcontrolcC�|�t�tfS)a1This sends an EOF to the child. This sends a character which causes
        the pending parent output buffer to be sent to the waiting child
        program without waiting for end-of-line. If it is the first character
        of the line, the read() in the user program returns 0, which signifies
        end-of-file. This means to work as expected a sendeof() has to be
        called at the beginning of a line. This method does not send a newline.
        It is the responsibility of the caller to ensure the eof is sent at the
        beginning of a line. )r�r$r�rrr�sendeofVs
zPtyProcess.sendeofcCr�)znThis sends a SIGINT to the child. It does not require
        the SIGINT to be the first character on a line. )r�r%r�rrr�sendintrbszPtyProcess.sendintrcCr�)z@This returns True if the EOF exception was ever raised.
        )rer�rrrr5hszPtyProcess.eofFcCs�|��sdSzT|�tj�t�|j�|��sWdS|�tj�t�|j�|��s-WdS|�tj�t�|j�|��s@WdS|rX|�tj	�t�|j�|��sUWdSWdSWdSt
yqt�|j�|��snYdSYdSw)z�This forces a child process to terminate. It starts nicely with
        SIGHUP and SIGINT. If "force" is True then moves onto SIGKILL. This
        returns True if the child was terminated. This returns False if the
        child could not be terminated. TF)r��kill�signal�SIGHUPr�r�rg�SIGCONT�SIGINT�SIGKILLr.r�rrrr�ns8�zPtyProcess.terminatecCs�|��rt�|jd�\}}n|jSt�|�|_t�|�r.||_t�|�|_d|_d|_	|jSt�
|�rE||_d|_t�|�|_d|_	|jSt�|�rNt
d��|jS)amThis waits until the child exits. This is a blocking call. This will
        not read any data from the child, so this will block forever if the
        child has unread output and has terminated. In other words, the child
        may have printed output then called exit(), but, the child is
        technically still alive until its output is read by the parent. rNTz�Called wait() on a stopped child process. This is not supported. Is some other process attempting job control with our child pid?)r�rv�waitpidr[rb�WEXITSTATUS�	WIFEXITEDrdrcr`�WIFSIGNALED�WTERMSIG�
WIFSTOPPEDr)rhr[rdrrr�wait�s&

�
�zPtyProcess.waitc
Cs6|jrdS|jrd}ntj}zt�|j|�\}}Wnty0}z|jtjkr+t	d���d}~ww|dkr^zt�|j|�\}}WntyW}z|jtjkrRt	d���d}~ww|dkr^dS|dkrddSt�
|�rz||_t�|�|_
d|_d|_dSt�|�r�||_d|_
t�|�|_d|_dSt�|�r�t	d��dS)aZThis tests if the child process is running or not. This is
        non-blocking. If the child was terminated then this will read the
        exitstatus or signalstatus of the child. This returns True if the child
        process appears to be running or False if not. It can take literally
        SECONDS for Solaris to return the right status. Frz�isalive() encountered condition where "terminated" is 0, but there was no child process. Did someone else call waitpid() on our process?Nz�isalive() encountered condition that should never happen. There was no child process. Did someone else call waitpid() on our process?Tz�isalive() encountered condition where child process is stopped. This is not supported. Is some other process attempting job control with our child pid?)r`rerv�WNOHANGr�r[r.r9�ECHILDrr�rdr�rbrcrrr)rh�waitpid_optionsr[rdr�rrrr��sR����

�
�zPtyProcess.isalivecCs|��r
t�|j|�dSdS)aSend the given signal to the child application.

        In keeping with UNIX tradition it has a misleading name. It does not
        necessarily kill the child unless you send the right signal. See the
        :mod:`signal` module for constants representing signal numbers.
        N)r�rvr�r[)rh�sigrrrr�s	�zPtyProcess.killcCsBttdd�}t�ddddd�}t�|j||�}t�d|�dd�S)zNReturn the window size of the pseudoterminal as a tuple (rows, cols).
        �
TIOCGWINSZiht@rDrro)r'r&rErFrGrHr1�unpack)rhrrK�xrrr�
getwinsizeszPtyProcess.getwinsizecCst|j||�S)a@Set the terminal window size of the child tty.

        This will cause a SIGWINCH signal to be sent to the child. This does not
        change the physical window size. It changes the size reported to
        TTY-aware applications like vi or curses -- applications that respond to
        the SIGWINCH signal.
        )rLr1)rhrIrJrrrr�szPtyProcess.setwinsize)NNTNrlr)Tr�r�)F)/rrr�__doc__r�string_typer�rv�linesepr��crlf�staticmethodrUr(rrQ�encodingr�r�r�rk�classmethodr�r�r�r�r�rr}r�r�r�r�r�r�r�r�r�r�r�r5r�rr�r�rr�rrrrrM�s`
�(




$


(MrMcsVeZdZdZereZneZd
�fdd�	Zd�fdd�	Z	�fd	d
�Z
�fdd�Z�ZS)�PtyProcessUnicodez�Unicode wrapper around a process running in a pseudoterminal.

    This class exposes a similar interface to :class:`PtyProcess`, but its read
    methods return unicode, and its :meth:`write` accepts unicode.
    rp�strictcs4tt|��||�||_||_t�|�|d�|_dS)N)�errors)�superrrkr�codec_errors�codecs�getincrementaldecoder�decoder)rhr[r1rr��	__class__rrrk*szPtyProcessUnicode.__init__r�cs tt|��|�}|jj|dd�S)aRead at most ``size`` bytes from the pty, return them as unicode.

        Can block if there is nothing to read. Raises :exc:`EOFError` if the
        terminal was closed.

        The size argument still refers to bytes, not unicode code points.
        F��final)rrr�rrS)rhr�rTrrrr�0szPtyProcessUnicode.readcstt|���}|jj|dd�S)r�Fr)rrr�rrS)rhrTrrrr�;szPtyProcessUnicode.readlinecs|�|j�}tt|��|�S)zlWrite the unicode string ``s`` to the pseudoterminal.

        Returns the number of bytes written.
        )r�rrrrQ)rhrKrTrrrrQDszPtyProcessUnicode.write)rprr)
rrrr
r�r�r�unicoderkr�r�rQ�
__classcell__rrrrrs	r)*rr9rGr\rvryr�r�rEr(r&r�r�r-�__builtin__rr�utilrr�platformr��	_platform�
startswith�_is_solarisrx�r	�version_infor�rr.rrr$r%r6rBrL�objectrMrrrrr�<module>sX�

�
+
$