o
    
j6ht*                  	   @   s  d dl Z d dlmZ d dl mZmZ d dlmZ d dlmZmZm	Z	m
Z
mZ ddlmZ ddlmZmZ dd	lmZmZ dd
lmZmZ ddlmZ ddlmZ G dd deZedkrd dlmZ dZe j dededddgd e !dZ"e"#d e"#d ed e"#d e"#d e"#d e"$d ed e"%ddd g d!d"gd#d$dddd#d% e"%d& e"&d' e"#d( e"#d) e"$d* d3d,d-Z'e'  ed e"(d. e"#d/ e"j#d0e)dd1d2 dS dS )4    N)datetime)Handler	LogRecord)Path)ClassVarListOptionalTypeUnion   )get_console)	LogRenderFormatTimeCallable)ConsoleConsoleRenderable)HighlighterReprHighlighter)Text)	Tracebackc                (       sD  e Zd ZU dZg dZeeee   e	d< e
Zeee  e	d< ejdfdddddddddddddd	d
dddeeef dee dedededededee dededee dedee dededededeeef ddf& fd d!Zd"edefd#d$Zd"eddfd%d&Zd"ed'edd(fd)d*Zd"ed+ee d,d(dd(fd-d.Z  ZS )/RichHandlera	  A logging handler that renders output with Rich. The time / level / message and file are displayed in columns.
    The level is color coded, and the message is syntax highlighted.

    Note:
        Be careful when enabling console markup in log messages if you have configured logging for libraries not
        under your control. If a dependency writes messages containing square brackets, it may not produce the intended output.

    Args:
        level (Union[int, str], optional): Log level. Defaults to logging.NOTSET.
        console (:class:`~rich.console.Console`, optional): Optional console instance to write logs.
            Default will use a global console instance writing to stdout.
        show_time (bool, optional): Show a column for the time. Defaults to True.
        omit_repeated_times (bool, optional): Omit repetition of the same time. Defaults to True.
        show_level (bool, optional): Show a column for the level. Defaults to True.
        show_path (bool, optional): Show the path to the original log call. Defaults to True.
        enable_link_path (bool, optional): Enable terminal link of path column to file. Defaults to True.
        highlighter (Highlighter, optional): Highlighter to style log messages, or None to use ReprHighlighter. Defaults to None.
        markup (bool, optional): Enable console markup in log messages. Defaults to False.
        rich_tracebacks (bool, optional): Enable rich tracebacks with syntax highlighting and formatting. Defaults to False.
        tracebacks_width (Optional[int], optional): Number of characters used to render tracebacks, or None for full width. Defaults to None.
        tracebacks_extra_lines (int, optional): Additional lines of code to render tracebacks, or None for full width. Defaults to None.
        tracebacks_theme (str, optional): Override pygments theme used in traceback.
        tracebacks_word_wrap (bool, optional): Enable word wrapping of long tracebacks lines. Defaults to True.
        tracebacks_show_locals (bool, optional): Enable display of locals in tracebacks. Defaults to False.
        locals_max_length (int, optional): Maximum length of containers before abbreviating, or None for no abbreviation.
            Defaults to 10.
        locals_max_string (int, optional): Maximum length of string before truncating, or None to disable. Defaults to 80.
        log_time_format (Union[str, TimeFormatterCallable], optional): If ``log_time`` is enabled, either string for strftime or callable that formats the time. Defaults to "[%x %X] ".
    )GETPOSTHEADPUTDELETEOPTIONSTRACEPATCHKEYWORDSHIGHLIGHTER_CLASSNTF   
   P   z[%x %X])	show_timeomit_repeated_times
show_level	show_pathenable_link_pathhighlightermarkuprich_tracebackstracebacks_widthtracebacks_extra_linestracebacks_themetracebacks_word_wraptracebacks_show_localslocals_max_lengthlocals_max_stringlog_time_formatlevelconsoler#   r$   r%   r&   r'   r(   r)   r*   r+   r,   r-   r.   r/   r0   r1   r2   returnc                   s~   t  j|d |pt | _|p|  | _t|||||d d| _|| _|	| _	|
| _
|| _|| _|| _|| _|| _|| _|| _d S )N)r3   )r#   r%   r&   time_formatr$   level_width)super__init__r   r4   r   r(   r   _log_renderr'   r)   r*   r+   r,   r-   r.   r/   r0   r1   )selfr3   r4   r#   r$   r%   r&   r'   r(   r)   r*   r+   r,   r-   r.   r/   r0   r1   r2   	__class__ g/var/www/html/chefvision.cloud.itp360.com/venv/lib/python3.10/site-packages/pip/_vendor/rich/logging.pyr9   :   s*   
zRichHandler.__init__recordc                 C   s&   |j }t|dd|  }|S )zGet the level name from the record.

        Args:
            record (LogRecord): LogRecord instance.

        Returns:
            Text: A tuple of the style and level name.
           zlogging.level.)	levelnamer   styledljustlower)r;   r@   
level_name
level_textr>   r>   r?   get_level_textf   s
   	zRichHandler.get_level_textc           
      C   s  |  |}d}| jr_|jr_|jdkr_|j\}}}|dusJ |dus$J tj|||| j| j| j| j| j	| j
| jd
}| }| jr_| |_| j}t|drZ| rZ|||j|_||}| ||}| j|||d}	z	| j|	 W dS  ty   | | Y dS w )zInvoked by logging.N)NNN)widthextra_linestheme	word_wrapshow_localsr0   r1   usesTime)r@   	tracebackmessage_renderable)formatr*   exc_infor   from_exceptionr+   r,   r-   r.   r/   r0   r1   
getMessage	formattermessagehasattrrN   
formatTimedatefmtasctimeformatMessagerender_messagerenderr4   print	ExceptionhandleError)
r;   r@   rV   rO   exc_type	exc_valueexc_tracebackrU   rP   log_renderabler>   r>   r?   emitu   sL   



zRichHandler.emitrV   r   c                 C   sV   t |d| j}|rt|nt|}t |d| j}|r||}| jr)|| jd |S )zRender message text in to Text.

        record (LogRecord): logging Record.
        message (str): String containing log message.

        Returns:
            ConsoleRenderable: Renderable to display log message.
        r)   r(   zlogging.keyword)getattrr)   r   from_markupr(   r   highlight_words)r;   r@   rV   
use_markupmessage_textr(   r>   r>   r?   r\      s   	zRichHandler.render_messagerO   rP   c          	   
   C   st   t |jj}| |}| jdu rdn| jj}t|j}| j	| j
|s%|gn||g|||||j| jr4|jndd}|S )av  Render log for display.

        Args:
            record (LogRecord): logging Record.
            traceback (Optional[Traceback]): Traceback instance or None for no Traceback.
            message_renderable (ConsoleRenderable): Renderable (typically Text) containing log message contents.

        Returns:
            ConsoleRenderable: Renderable to display log.
        N)log_timer6   r3   pathline_no	link_path)r   pathnamenamerH   rU   rY   r   fromtimestampcreatedr:   r4   linenor'   )	r;   r@   rO   rP   rl   r3   r6   rk   rd   r>   r>   r?   r]      s   

zRichHandler.render)__name__
__module____qualname____doc__r   r   r   r   str__annotations__r   r   r	   r   loggingNOTSETr
   intr   boolr   r9   r   r   rH   re   r\   r   r]   __classcell__r>   r>   r<   r?   r      s   
 

	

,)r   __main__)sleepz%(message)sr{   z[%X]T)r*   r/   )r3   rQ   rY   handlersrichzServer starting...z"Listening on http://127.0.0.1:8080zGET /index.html 200 1298z)GET /imgs/backgrounds/back1.jpg 200 54386zGET /css/styles.css 200 54386zGET /favicon.ico 404 242zJSONRPC request
--> %r
<-- %rz1.1confirmFruitPurchase)appleorangemangoespomelog+?	194521489)versionmethodparamsid)r   resulterrorr   zrLoading configuration file /adasd/asdasd/qeqwe/qwrqwrqwr/sdgsdgsdg/werwerwer/dfgerert/ertertert/ertetert/werwerwerz$Unable to find 'pomelo' in database!zPOST /jsonrpc/ 200 65532zPOST /admin/ 401 42234z%password was rejected for admin site.r5   c                  C   sB   d} d}dgd }t d z| |  W d S    t d Y d S )Nr   r   food   z	in dividezAn error of some kind occurred!)logdebug	exception)numberdivisorfoosr>   r>   r?   divide   s   

r   zOut of memory!zServer exited with code=-1z[bold]EXITING...[/bold])r)   )extra)r5   N)*rz   r   r   r   pathlibr   typingr   r   r   r	   r
    r   r:   r   r   r4   r   r   r(   r   r   textr   rO   r   r   rt   timer   FORMATbasicConfig	getLoggerr   infowarningr   r   r   criticaldictr>   r>   r>   r?   <module>   sl     G
















