
    )h,/                        d dl Z d dlZd dlZd dlZd dlZd dlZd dlZd dlmZ d dl	m
Z
 d dlmZ d dlmZmZmZmZmZmZ d dlmZmZmZmZmZmZ d dlmZ d dlmZ d d	lmZ d d
l m!Z! d dl"m#Z#m$Z$ d dl%m&Z& d dl'm(Z( d dl)m*Z*  ejV                         Z,da-dZ. e$d      Z/ G d de0      Z1dee2   de2de3fdZ4e jj                  d0de6ded   fd       Z7de6fdZ8 G d dejr                        Z:e G d d             Z; G d de      Z<d d!d"e3defd#Z= G d$ d%e      Z> G d& d'ej~                  j                        ZA G d( d)e      ZB G d* d+e      ZCd,e6d-e3d.eeD   de6fd/ZEy)1    N)	dataclass)TextIOWrapper)Filter)AnyClassVar	GeneratorListOptionalType)ConsoleConsoleOptionsConsoleRenderableRenderableTypeRenderResultRichCast)NullHighlighter)RichHandler)Segment)Style)VERBOSE	getLogger)WINDOWS)DEPRECATION_MSG_PREFIX)
ensure_dirzpip.subprocessorc                       e Zd ZdZy)BrokenStdoutLoggingErrorzO
    Raised if BrokenPipeError occurs for the stdout stream while logging.
    N)__name__
__module____qualname____doc__     N/var/www/html/venv/lib/python3.12/site-packages/pip/_internal/utils/logging.pyr   r   %   s    r"   r   	exc_classexcreturnc                     | t         u ryt        syt        |t              xr, |j                  t        j
                  t        j                  fv S )NTF)BrokenPipeErrorr   
isinstanceOSErrorerrnoEINVALEPIPE)r$   r%   s     r#   _is_broken_pipe_errorr.   +   s=    O#
 c7#P		ellEKK5P(PPr"   num)NNNc              #      K   t               t        _        t        xj                  | z  c_        	 d t        xj                  | z  c_        y# t        xj                  | z  c_        w xY ww)zv
    A context manager which will cause the log output to be indented for any
    log messages emitted inside it.
    N)get_indentation
_log_stateindentation)r/   s    r#   
indent_logr4   8   sN      -.Jc!&#%
#%s   -A,A A,A))A,c                  $    t        t        dd      S )Nr3   r   )getattrr2   r!   r"   r#   r1   r1   G   s    :}a00r"   c            	       v     e Zd ZdZdddedededdf fd	Zd
ededefdZ	de
j                  def fdZ xZS )IndentingFormatterz%Y-%m-%dT%H:%M:%SF)add_timestampargsr9   kwargsr&   Nc                2    || _         t        |   |i | y)z
        A logging.Formatter that obeys the indent_log() context manager.

        :param add_timestamp: A bool indicating output lines should be prefixed
            with their record's timestamp.
        N)r9   super__init__)selfr9   r:   r;   	__class__s       r#   r>   zIndentingFormatter.__init__N   s     +$)&)r"   	formattedlevelnoc                     |t         j                  k  ry|j                  t              ry|t         j                  k  ryy)zv
        Return the start of the formatted log message (not counting the
        prefix to add to each line).
         z	WARNING: zERROR: )loggingWARNING
startswithr   ERROR)r?   rA   rB   s      r#   get_message_startz$IndentingFormatter.get_message_start]   s9    
 W__$ 67 W]]"r"   recordc                 8   t         |   |      }| j                  ||j                        }||z   }d}| j                  r| j                  |       d}|dt               z  z  }dj                  |j                  d      D cg c]  }||z   	 c}      }|S c c}w )z
        Calls the standard formatter, but will indent all of the log message
        lines by our current indentation level.
        rD    T)	r=   formatrI   rB   r9   
formatTimer1   join
splitlines)r?   rJ   rA   message_startprefixliner@   s         r#   rM   zIndentingFormatter.formatm   s    
 GN6*	..y&..I!I-	/02F#)))GGy7K7KD7QRtVd]RS	 Ss   B)r   r   r   default_time_formatr   boolr>   strintrI   rE   	LogRecordrM   __classcell__r@   s   @r#   r8   r8   K   sq    -
 $** * 	*
 
*3    W.. 3  r"   r8   c                   6    e Zd ZU eed<   eed<   dededefdZ	y)IndentedRenderable
renderableindentconsoleoptionsr&   c              #      K   |j                  | j                  |      }t        j                  |      }|D ]3  }t        d| j                  z         |E d {    t        d       5 y 7 w)NrL   
)renderr]   r   split_linesr^   )r?   r_   r`   segmentslinesrS   s         r#   __rich_console__z#IndentedRenderable.__rich_console__   sc      >>$//7;##H- 	 D#+,,OO$-	 s   AA/A-A/N)
r   r   r   r   __annotations__rW   r   r   r   rg   r!   r"   r#   r\   r\   ~   s*    K  )7 	 r"   r\   c                       e Zd ZddZy)
PipConsoleNc                     t               d N)r(   )r?   s    r#   on_broken_pipezPipConsole.on_broken_pipe   s     T)r"   )r&   N)r   r   r   rm   r!   r"   r#   rj   rj      s    *r"   rj   Fstderrro   c                 R    | rt         J d       t         S t        J d       t        S )Nzstderr rich console is missing!zstdout rich console is missing!)_stderr_console_stdout_consolern   s    r#   get_consolers      s5    *M,MM**M,MM*r"   c                        e Zd ZU g Zeeee         ed<   de	ddf fdZ
dej                  ddfdZdej                  ddf fdZ xZS )	RichPipStreamHandlerKEYWORDSr_   r&   Nc                 >    t         |   |dddt                      y )NF)r_   	show_time
show_level	show_pathhighlighter)r=   r>   r   )r?   r_   r@   s     r#   r>   zRichPipStreamHandler.__init__   s'    ') 	 	
r"   rJ   c                 p   d }t        |dd      ret        |j                  t              sJ |j                  \  }t        |t        t
        t        f      s
J | d       t        |t                     }n| j                  |      }| j                  ||      }|j                  S|j                  t        j                  k\  rt        d      }n)|j                  t        j                  k\  rt        d      }	 | j                   j#                  |dd|	       y # t$        $ r | j'                  |       Y y w xY w)
NrichFz is not rich-console-renderable)r^   red)coloryellowignore)overflowcropstyle)r6   r)   r:   tupler   r   rV   r\   r1   rM   render_messagerB   rE   rH   r   rF   r_   print	ExceptionhandleError)r?   rJ   r   rich_renderabler]   messages         r#   emitzRichPipStreamHandler.emit   s   !% 665)fkk5111!'_"3Xs!C C!""ABC  *<(9*J kk&)G,,VW=J~~)>>W]]2!.E^^w6!1E	%LLzH5PUV 	%V$	%s   8D D54D5c                     t        j                         dd \  }}|r>|r<| j                  j                  t         j                  u rt        ||      r
t               t        | !  |      S )z1Called when logging is unable to log some output.N   )	sysexc_infor_   filestdoutr.   r   r=   r   )r?   rJ   r$   r%   r@   s       r#   r   z RichPipStreamHandler.handleError   s\     +	3 !!SZZ/%i5*,,w"6**r"   )r   r   r   rv   r   r
   r	   rV   rh   r   r>   rE   rX   r   r   rY   rZ   s   @r#   ru   ru      se    .0HhxS	*+0
 
D 
%7,, % %8+'"3"3 + + +r"   ru   c                   $     e Zd Zdef fdZ xZS )BetterRotatingFileHandlerr&   c                     t        t        j                  j                  | j                               t
        |          S rl   )r   ospathdirnamebaseFilenamer=   _open)r?   r@   s    r#   r   zBetterRotatingFileHandler._open   s*    277??4#4#456w}r"   )r   r   r   r   r   rY   rZ   s   @r#   r   r      s    }  r"   r   c                   @    e Zd ZdeddfdZdej                  defdZy)MaxLevelFilterlevelr&   Nc                     || _         y rl   )r   )r?   r   s     r#   r>   zMaxLevelFilter.__init__   s	    
r"   rJ   c                 4    |j                   | j                  k  S rl   )rB   r   )r?   rJ   s     r#   filterzMaxLevelFilter.filter   s    ~~

**r"   )	r   r   r   rW   r>   rE   rX   rU   r   r!   r"   r#   r   r      s.    c d +W.. +4 +r"   r   c                   @     e Zd ZdZdej
                  def fdZ xZS )ExcludeLoggerFilterzQ
    A logging Filter that excludes records from a logger (or its children).
    rJ   r&   c                 $    t         |   |       S rl   )r=   r   )r?   rJ   r@   s     r#   r   zExcludeLoggerFilter.filter   s     7>&)))r"   )	r   r   r   r    rE   rX   rU   r   rY   rZ   s   @r#   r   r      s&    *W.. *4 * *r"   r   	verbosityno_coloruser_log_filec                 *   | dk\  rt         j                  }n^| dk(  rt        }nR| dk(  rt         j                  }n<| dk(  rt         j                  }n&| dk  rt         j
                  }nt         j                  }t        j                  |      }|du}|r|}d}nd}|}|d	v rd
nd}ddd}	g d|rdgng z   }
t        t        j                  |d      at        t        j                  |d      }t         j                  j                  dddt         j                  ddt        j                   ddt        j                   ddt"        ddt"        dddd||	d   t        ddgd d!d
|	d   |dgd d!||	d   |d"gd d!d|	d#   |d$dd%d&d'||
d(d)d*|iid+       |S ),znConfigures and sets up all of the logging

    Returns the requested logging level, as its integer value.
    r      NDEBUGz	/dev/null)INFOrH   rF   z0pip._internal.utils.logging.RichPipStreamHandlerz5pip._internal.utils.logging.BetterRotatingFileHandler)streamr   )r_   console_errorsconsole_subprocessuser_logT)r   r   	soft_wrapFz*pip._internal.utils.logging.MaxLevelFilter)()r   zlogging.Filter)r   namez/pip._internal.utils.logging.ExcludeLoggerFilter)exclude_warningsrestrict_to_subprocessexclude_subprocessz%(message)s)r   rM   )r   rM   r9   )r^   indent_with_timestampr   r   r   r^   )r   classr_   filters	formatterr   r   zutf-8r   )r   r   filenameencodingdelayr   )r_   r   r   r   )r   handlerszpip._vendorr   )versiondisable_existing_loggersr   
formattersr   rootloggers)rE   r   r   rF   rH   CRITICALr   getLevelNamerj   r   r   rr   ro   config
dictConfigsubprocess_loggerr   r8   )r   r   r   level_numberr   include_user_logadditional_log_file
root_levelvendored_log_levelhandler_classesr   rq   s               r#   setup_loggingr      s    A~}}	a	b	b}}	b''||  .E %D0+
)
 ',/@&@g EGO C(bH !cjj8tTO cjj8tTONN(- G$__%
 +-22+
 L-22'  -+
 -+%)*
 #,X6. 46HI!) ',X6. 45!)# #,X6. 89!)' %,V4 3 '!!81 D $$ &1C'DECB	
DL r"   )r   )F
contextlibr+   rE   logging.handlersr   r   	threadingdataclassesr   ior   r   typingr   r   r   r	   r
   r   pip._vendor.rich.consoler   r   r   r   r   r   pip._vendor.rich.highlighterr   pip._vendor.rich.loggingr   pip._vendor.rich.segmentr   pip._vendor.rich.styler   pip._internal.utils._logr   r   pip._internal.utils.compatr   pip._internal.utils.deprecationr   pip._internal.utils.miscr   localr2   rr   rq   r   r   r   BaseExceptionrU   r.   contextmanagerrW   r4   r1   	Formatterr8   r\   rj   rs   ru   r   RotatingFileHandlerr   r   r   rV   r   r!   r"   r#   <module>r      s       	 
  !   A A  9 0 , ( 7 . B /Y__
01 y 
QT-%8 
Q} 
QQU 
Q &C &	*: ; & &1 10** 0f      * * #( 4 G 9+; 9+x 0 0 D D +V +*& *vS vD v# vSV vr"   