U
    
W[6%                     @   sZ   d Z ddlmZ ddlmZ ddlmZ ddlmZmZ G dd de	Z
e
 Zd	d
 ZdS )z
Logger class.
    )time)currentframe)Failure   )InvalidLogLevelErrorLogLevelc                   @   s   e Zd ZdZedd ZdddZdddZd	d
 ZdddZ	de
jfddZdddZdddZdddZdddZd ddZdS )!Loggera  
    A L{Logger} emits log messages to an observer.  You should instantiate it
    as a class or module attribute, as documented in L{this module's
    documentation <twisted.logger>}.

    @type namespace: L{str}
    @ivar namespace: the namespace for this logger

    @type source: L{object}
    @ivar source: The object which is emitting events via this logger

    @type: L{ILogObserver}
    @ivar observer: The observer that this logger will send events to.
    c                   C   s,   zt djd W S  tk
r&   Y dS X dS )z
        Derive a namespace from the module containing the caller's caller.

        @return: the fully qualified python name of a module.
        @rtype: L{str} (native string)
           __name__z	<unknown>N)r   	f_globalsKeyError r   r   8/usr/lib/python3/dist-packages/twisted/logger/_logger.py_namespaceFromCallingContext!   s    z#Logger._namespaceFromCallingContextNc                 C   sB   |dkr|   }|| _|| _|dkr8ddlm} || _n|| _dS )a  
        @param namespace: The namespace for this logger.  Uses a dotted
            notation, as used by python modules.  If not L{None}, then the name
            of the module of the caller is used.
        @type namespace: L{str} (native string)

        @param source: The object which is emitting events via this
            logger; this is automatically set on instances of a class
            if this L{Logger} is an attribute of that class.
        @type source: L{object}

        @param observer: The observer that this logger will send events to.
            If L{None}, use the L{global log publisher <globalLogPublisher>}.
        @type observer: L{ILogObserver}
        Nr   )globalLogPublisher)r   	namespacesourceZ_globalr   observer)selfr   r   r   r   r   r   r   __init__/   s    zLogger.__init__c                 C   s2   |dkr|}n|}| j d|j|jg|| jdS )a  
        When used as a descriptor, i.e.::

            # File: athing.py
            class Something(object):
                log = Logger()
                def hello(self):
                    self.log.info("Hello")

        a L{Logger}'s namespace will be set to the name of the class it is
        declared on.  In the above example, the namespace would be
        C{athing.Something}.

        Additionally, its source will be set to the actual object referring to
        the L{Logger}.  In the above example, C{Something.log.source} would be
        C{Something}, and C{Something().log.source} would be an instance of
        C{Something}.
        N.)r   )	__class__join
__module__r
   r   )r   Zoselftyper   r   r   r   __get__L   s    zLogger.__get__c                 C   s   d| j j| jf S )Nz<%s %r>)r   r
   r   )r   r   r   r   __repr__k   s    zLogger.__repr__c                 K   st   |t  kr*| jdtt||| d dS |}|j| || j| j|t d d|krf|d 	| | j
f | 
| dS )a  
        Emit a log event to all log observers at the given level.

        @param level: a L{LogLevel}

        @param format: a message format using new-style (PEP 3101)
            formatting.  The logging event (which is a L{dict}) is
            used to render this format string.

        @param kwargs: additional key/value pairs to include in the event.
            Note that values which are later mutated may result in
            non-deterministic behavior from observers that schedule work for
            later execution.
        z:Got invalid log level {invalidLevel!r} in {logger}.emit().)ZinvalidLevelZloggerN)Z
log_loggerZ	log_levelZlog_namespaceZ
log_sourceZ
log_formatZlog_timeZ	log_trace)r   Ziterconstantsfailurer   r   updater   r   r   appendr   )r   levelformatkwargsZeventr   r   r   emito   s(    
    zLogger.emitc                 K   s*   |dkrt  }| j||fd|i| dS )a  
        Log a failure and emit a traceback.

        For example::

            try:
                frob(knob)
            except Exception:
                log.failure("While frobbing {knob}", knob=knob)

        or::

            d = deferredFrob(knob)
            d.addErrback(lambda f: log.failure, "While frobbing {knob}",
                         f, knob=knob)

        This method is generally meant to capture unexpected exceptions in
        code; an exception that is caught and handled somehow should be logged,
        if appropriate, via L{Logger.error} instead.  If some unknown exception
        occurs and your code doesn't know how to handle it, as in the above
        example, then this method provides a means to describe the failure in
        nerd-speak.  This is done at L{LogLevel.critical} by default, since no
        corrective guidance can be offered to an user/administrator, and the
        impact of the condition is unknown.

        @param format: a message format using new-style (PEP 3101) formatting.
            The logging event (which is a L{dict}) is used to render this
            format string.

        @param failure: a L{Failure} to log.  If L{None}, a L{Failure} is
            created from the exception in flight.

        @param level: a L{LogLevel} to use.

        @param kwargs: additional key/value pairs to include in the event.
            Note that values which are later mutated may result in
            non-deterministic behavior from observers that schedule work for
            later execution.
        NZlog_failure)r   r#   )r   r!   r   r    r"   r   r   r   r      s    (zLogger.failurec                 K   s   | j tj|f| dS )a  
        Emit a log event at log level L{LogLevel.debug}.

        @param format: a message format using new-style (PEP 3101) formatting.
            The logging event (which is a L{dict}) is used to render this
            format string.

        @param kwargs: additional key/value pairs to include in the event.
            Note that values which are later mutated may result in
            non-deterministic behavior from observers that schedule work for
            later execution.
        N)r#   r   debugr   r!   r"   r   r   r   r$      s    zLogger.debugc                 K   s   | j tj|f| dS )a  
        Emit a log event at log level L{LogLevel.info}.

        @param format: a message format using new-style (PEP 3101) formatting.
            The logging event (which is a L{dict}) is used to render this
            format string.

        @param kwargs: additional key/value pairs to include in the event.
            Note that values which are later mutated may result in
            non-deterministic behavior from observers that schedule work for
            later execution.
        N)r#   r   infor%   r   r   r   r&      s    zLogger.infoc                 K   s   | j tj|f| dS )a  
        Emit a log event at log level L{LogLevel.warn}.

        @param format: a message format using new-style (PEP 3101) formatting.
            The logging event (which is a L{dict}) is used to render this
            format string.

        @param kwargs: additional key/value pairs to include in the event.
            Note that values which are later mutated may result in
            non-deterministic behavior from observers that schedule work for
            later execution.
        N)r#   r   warnr%   r   r   r   r'      s    zLogger.warnc                 K   s   | j tj|f| dS )a  
        Emit a log event at log level L{LogLevel.error}.

        @param format: a message format using new-style (PEP 3101) formatting.
            The logging event (which is a L{dict}) is used to render this
            format string.

        @param kwargs: additional key/value pairs to include in the event.
            Note that values which are later mutated may result in
            non-deterministic behavior from observers that schedule work for
            later execution.
        N)r#   r   errorr%   r   r   r   r(      s    zLogger.errorc                 K   s   | j tj|f| dS )a  
        Emit a log event at log level L{LogLevel.critical}.

        @param format: a message format using new-style (PEP 3101) formatting.
            The logging event (which is a L{dict}) is used to render this
            format string.

        @param kwargs: additional key/value pairs to include in the event.
            Note that values which are later mutated may result in
            non-deterministic behavior from observers that schedule work for
            later execution.
        N)r#   r   criticalr%   r   r   r   r)     s    zLogger.critical)NNN)N)N)N)N)N)N)N)r
   r   __qualname____doc__staticmethodr   r   r   r   r#   r   r)   r   r$   r&   r'   r(   r   r   r   r   r      s   



$.



r   c                 C   s   t | | jS )N)_logr   r   )objr   r   r   <lambda>      r/   N)r+   r   Ztwisted.python.compatr   Ztwisted.python.failurer   Z_levelsr   r   objectr   r-   Z
_loggerForr   r   r   r   <module>   s     