Plan 9 from Bell Labs’s /usr/web/sources/contrib/jas/root/sys/lib/python2.7/logging/config.pyo

Copyright © 2021 Plan 9 Foundation.
Distributed under the MIT License.
Download the Plan 9 distribution.


��Qc@s�dZddlZddlZddlZddlZddlZddlZddlZddlZddl	Z	ddl
Z
yddlZddlZWne
k
r�eZnXddlmZmZdZejdkr�ZndZeaeed�Zd	�Zd
�Zd�Zd�Zd
�Zd�Zejdej�Z d�Z!de"fd��YZ#de$fd��YZ%de&fd��YZ'de(fd��YZ)de)fd��YZ*e*Z+d�Z,ed�Z-d�Z.dS(s
Configuration functions for the logging package for Python. The core package
is based on PEP 282 and comments thereto in comp.lang.python, and influenced
by Apache's log4j system.

Copyright (C) 2001-2013 Vinay Sajip. All Rights Reserved.

To use, simply 'import logging' and log away!
i�N(tThreadingTCPServertStreamRequestHandleriF#twin32iF'ihcCs�ddl}|j|�}t|d�r:|j|�n
|j|�t|�}tj�z7tjj�tj	2t
||�}t|||�Wdtj�XdS(sD
    Read the logging configuration from a ConfigParser-format file.

    This can be called several times from an application, allowing an end user
    the ability to select from various pre-canned configurations (if the
    developer provides a mechanism to present the choices and load the chosen
    configuration).
    i�Ntreadline(
tConfigParserthasattrtreadfptreadt_create_formatterstloggingt_acquireLockt	_handlerstcleart_handlerListt_install_handlerst_install_loggerst_releaseLock(tfnametdefaultstdisable_existing_loggersRtcpt
formattersthandlers((s$/sys/lib/python2.7/logging/config.pyt
fileConfig5s	


cCs�|jd�}|jd�}t|�}x\|D]T}|d|}yt||�}Wq1tk
r�t|�t||�}q1Xq1W|S(s)Resolve a dotted name to a global object.t.i(tsplittpopt
__import__tgetattrtAttributeError(tnametusedtfoundtn((s$/sys/lib/python2.7/logging/config.pyt_resolveTs


cCstd�|�S(NcSs
|j�S(N(tstrip(tx((s$/sys/lib/python2.7/logging/config.pyt<lambda>cs(tmap(talist((s$/sys/lib/python2.7/logging/config.pyt
_strip_spacesbscCs t|t�r|S|jd�S(Nsutf-8(t
isinstancetstrtencode(ts((s$/sys/lib/python2.7/logging/config.pyt_encodedescCs|jdd�}t|�s"iS|jd�}t|�}i}x�|D]�}d|}|j|�}d|kr�|j|dd�}nd	}d|kr�|j|dd�}nd	}tj}d|kr�j|d�}	|	r�|	�}q�|||�}
|
||<qJW|S(
sCreate and return formattersRtkeyst,sformatter_%stformatitdatefmttclassN(	tgettlenRR(toptionstNoneR	t	FormatterR"(RtflistRtformtsectnametoptstfstdfstct
class_nametf((s$/sys/lib/python2.7/logging/config.pyRhs.

	cCs
|jdd�}t|�s"iS|jd�}t|�}i}g}x�|D]�}d|}|j|d�}|j|�}d|kr�|j|d�}	nd}	yt|tt��}Wn#tt	fk
r�t
|�}nX|j|d�}
t|
tt��}
||
�}d	|krO|j|d	�}|jtj|�nt|	�ro|j
||	�nt|tjj�r�d
|kr�|j|d
�}
nd}
t|
�r�|j||
f�q�n|||<qPWx%|D]\}}|j||�q�|S(sInstall and return handlersRR.R/s
handler_%sR2t	formatterttargstlevelttarget(R3R4RR(R5tevaltvarsR	Rt	NameErrorR"tsetLevelt_levelNamestsetFormattert
issubclassRt
MemoryHandlertappendt	setTarget(RRthlistRtfixupsthandR:tklassR;tfmtRCthRDREtt((s$/sys/lib/python2.7/logging/config.pyR�sH

cCsq|jdd�}|jd�}ttd�|��}|jd�d}tj}|}|j|�}d|kr�|j|d�}|jtj	|�nx|j
D]}	|j|	�q�W|j|d�}
t|
�r|
jd�}
t
|
�}
x"|
D]}|j||�qWnt|jjj��}|j�g}
x�|D]�}d	|}|j|d
�}|j|�}d|kr�|j|d�}nd}tj|�}||krK|j|�d}|d
}t|�}t|�}xB||kr:||| |kr-|
j||�n|d7}q�j|�nd|kr�|j|d�}|jtj	|�nx|j
D]}	|j|	�q�W||_d|_|j|d�}
t|
�rN|
jd�}
t
|
�}
x"|
D]}|j||�q�NqNWxT|D]L}|jj|}||
kr`tj|_g|_
d|_q||_qWdS(sCreate and install loggerstloggersR.R/cSs
|j�S(N(R#(R$((s$/sys/lib/python2.7/logging/config.pyR%�stroottlogger_rootRDRs	logger_%stqualnamet	propagateiRiN(R3RtlistR&tremoveR	RXR5RIRJRt
removeHandlerR4R(t
addHandlertmanagert
loggerDictR.tsorttgetintt	getLoggertindexRNR[tdisabledtNOTSETRD(RRRtllistR:RXtlogR;RDRURPRRtexistingt
child_loggerstqnR[tloggertitprefixedtpflentnum_existing((s$/sys/lib/python2.7/logging/config.pyR�sx
	




		

	s^[a-z_][a-z0-9_]*$cCs,tj|�}|s(td|��ntS(Ns!Not a valid Python identifier: %r(t
IDENTIFIERtmatcht
ValueErrortTrue(R,tm((s$/sys/lib/python2.7/logging/config.pytvalid_identstConvertingDictcBs/eZdZd�Zdd�Zdd�ZRS(s A converting dictionary wrapper.cCsqtj||�}|jj|�}||k	rm|||<t|�tttfkrm||_||_	qmn|S(N(
tdictt__getitem__tconfiguratortconvertttypeRxtConvertingListtConvertingTupletparenttkey(tselfR�tvaluetresult((s$/sys/lib/python2.7/logging/config.pyRz"s
	cCsttj|||�}|jj|�}||k	rp|||<t|�tttfkrp||_||_	qpn|S(N(
RyR3R{R|R}RxR~RR�R�(R�R�tdefaultR�R�((s$/sys/lib/python2.7/logging/config.pyR3.s
	cCsjtj|||�}|jj|�}||k	rft|�tttfkrf||_||_	qfn|S(N(
RyRR{R|R}RxR~RR�R�(R�R�R�R�R�((s$/sys/lib/python2.7/logging/config.pyR:s	N(t__name__t
__module__t__doc__RzR6R3R(((s$/sys/lib/python2.7/logging/config.pyRxs	R~cBs#eZdZd�Zdd�ZRS(sA converting list wrapper.cCsqtj||�}|jj|�}||k	rm|||<t|�tttfkrm||_||_	qmn|S(N(
R\RzR{R|R}RxR~RR�R�(R�R�R�R�((s$/sys/lib/python2.7/logging/config.pyRzFs
	i�cCs^tj||�}|jj|�}||k	rZt|�tttfkrZ||_qZn|S(N(	R\RR{R|R}RxR~RR�(R�tidxR�R�((s$/sys/lib/python2.7/logging/config.pyRRs(R�R�R�RzR(((s$/sys/lib/python2.7/logging/config.pyR~Ds	RcBseZdZd�ZRS(sA converting tuple wrapper.cCsgtj||�}|jj|�}||k	rct|�tttfkrc||_||_	qcn|S(N(
ttupleRzR{R|R}RxR~RR�R�(R�R�R�R�((s$/sys/lib/python2.7/logging/config.pyRz]s	(R�R�R�Rz(((s$/sys/lib/python2.7/logging/config.pyR[stBaseConfiguratorcBs�eZdZejd�Zejd�Zejd�Zejd�Zejd�Z	idd6dd	6Z
eZd
�Z
d�Zd�Zd
�Zd�Zd�Zd�ZRS(sI
    The configurator base class which defines some useful defaults.
    s%^(?P<prefix>[a-z]+)://(?P<suffix>.*)$s^\s*(\w+)\s*s^\.\s*(\w+)\s*s^\[\s*(\w+)\s*\]\s*s^\d+$text_converttexttcfg_converttcfgcCs@t|�|_||j_tt�tjkr<t|_ndS(N(RxtconfigR{R}RttypestFunctionTypetimporter(R�R�((s$/sys/lib/python2.7/logging/config.pyt__init__{sc	Cs�|jd�}|jd�}yy|j|�}x_|D]W}|d|7}yt||�}Wq7tk
r�|j|�t||�}q7Xq7W|SWnVtk
r�tj�d\}}td||f�}|||_	|_
|�nXdS(s`
        Resolve strings to objects using standard import and attribute
        syntax.
        RiisCannot resolve %r: %sN(RRR�RRtImportErrortsystexc_infoRtt	__cause__t
__traceback__(	R�R,RRR tfragtettbtv((s$/sys/lib/python2.7/logging/config.pytresolve�s"



cCs
|j|�S(s*Default converter for the ext:// protocol.(R�(R�R�((s$/sys/lib/python2.7/logging/config.pyR��scCsO|}|jj|�}|dkr7td|��n||j�}|j|j�d}x�rJ|jj|�}|r�||j�d}n�|jj|�}|r|j�d}|j	j|�s�||}qyt
|�}||}Wqtk
r||}qXn|r1||j�}qatd||f��qaW|S(s*Default converter for the cfg:// protocol.sUnable to convert %risUnable to convert %r at %rN(tWORD_PATTERNRsR6RttendR�tgroupstDOT_PATTERNt
INDEX_PATTERNt
DIGIT_PATTERNtintt	TypeError(R�R�trestRvtdR�R!((s$/sys/lib/python2.7/logging/config.pyR��s2	

cCs/t|t�r7t|t�r7t|�}||_n�|t�rnt|t�rnt|�}||_n�t|t�r�t|t�r�t|�}||_n�t|t�r+|j	j
|�}|r+|j�}|d}|jj
|d�}|r(|d}t||�}||�}q(q+n|S(s�
        Convert values to an appropriate type. dicts, lists and tuples are
        replaced by their converting alternatives. Strings are checked to
        see if they have a conversion format and are converted if they do.
        tprefixtsuffixN(R)RxRyR{R~R\RR�t
basestringtCONVERT_PATTERNRst	groupdicttvalue_convertersR3R6R(R�R�RvR�R�t	converterR�((s$/sys/lib/python2.7/logging/config.pyR|�s*

c	Cs�|jd�}t|d�rUttd�rUt|�tjkrU|j|�}n|jdd�}tg|D]"}t|�rq|||f^qq�}||�}|r�x-|j	�D]\}}t
|||�q�Wn|S(s1Configure an object with a user-supplied factory.s()t__call__t	ClassTypeRN(RRR�R}R�R�R6RyRwtitemstsetattr(	R�R�R>tpropstktkwargsR�RR�((s$/sys/lib/python2.7/logging/config.pytconfigure_custom�s45cCs"t|t�rt|�}n|S(s0Utility function which converts lists to tuples.(R)R\R�(R�R�((s$/sys/lib/python2.7/logging/config.pytas_tuple�s(R�R�R�tretcompileR�R�R�R�R�R�RR�R�R�R�R�R|R�R�(((s$/sys/lib/python2.7/logging/config.pyR�gs"
	
			"		tDictConfiguratorcBsheZdZd�Zd�Zd�Zd�Zd�Zd�Ze	d�Z
e	d�Ze	d	�ZRS(
s]
    Configure logging using a dictionary-like object to describe the
    configuration.
    cCs�|j}d|kr$td��n|ddkrKtd|d��n|jdt�}i}tj�zz|r�jd|�}x�|D]�}|tjkr�td|��q�yLtj|}||}|jdd�}|r|j	tj
|��nWq�tk
r.}	td	||	f��q�Xq�W|jd
|�}
xU|
D]M}y|j||
|t
�WqLtk
r�}	td||	f��qLXqLW|jdd�}|r�|j|t
�Wq�k
r�}	td
|	��q���jdt
�}tjj�tj2|jd|�}
xU|
D]M}y|j|
|�|
|<Wq4tk
r�}	td||	f��q4Xq4W|jd|�}xU|D]M}y|j||�||<Wq�tk
r�}	td||	f��q�Xq�W|jd|�}g}x�t|�D]~}y*|j||�}||_|||<Wqtk
r�}	dt|	�krx|j|�q�td	||	f��qXqWxd|D]\}y*|j||�}||_|||<Wq�tk
r�	td	||	f��q�Xq�Wtj}|jjj�}|j�g}|jd
|�}
x�D]�t|�}||kr�j|�}|d}t|�}t|�}|d}x?||kr�||| |kr�|j||�|d}q�W|j |�ny|j||
|�WqAtk
r/}	td||	f��qAXqAWx]|D]U}|jj|}||kr~tj!|_"g|_#t
|_$q;|r;t
|_%q;q;W|jdd�}|r�|j|�Wq�tk
r�}	td
|	��q�nWdtj&�XdS(sDo the configuration.tversions$dictionary doesn't specify a versionisUnsupported version: %stincrementalRsNo handler found with name %rRDs"Unable to configure handler %r: %sRWs!Unable to configure logger %r: %sRXs#Unable to configure root logger: %sRRs$Unable to configure formatter %r: %stfilterss!Unable to configure filter %r: %sstarget not configured yetRN('R�RtRtFalseR	R
R3RR6RIt_checkLevelt
StandardErrortconfigure_loggerRutconfigure_rootRR
tconfigure_formattertconfigure_filtertsortedtconfigure_handlerRR*RNRXR`RaR.RbR-ReR4R]RgRDRR[RfR(R�R�R�t
EMPTY_DICTRRthandlerthandler_configRDR�RWRXtdisable_existingRR�tdeferredRjRkRnRoRpRqRiRm((s$/sys/lib/python2.7/logging/config.pyt	configure�s�	








	
		




	cCs�d|kr�|d}y|j|�}Wq�tk
r�}dt|�krS�n|jd�|d<||d<|j|�}q�Xn6|jdd�}|jdd�}tj||�}|S(s(Configure a formatter from a dictionary.s()s'format'R0RTR1N(R�R�R*RR3R6R	R7(R�R�tfactoryR�tteRTtdfmt((s$/sys/lib/python2.7/logging/config.pyR��s

cCsCd|kr|j|�}n!|jdd�}tj|�}|S(s%Configure a filter from a dictionary.s()RRB(R�R3R	tFilter(R�R�R�R((s$/sys/lib/python2.7/logging/config.pyR��s
cCs]xV|D]N}y|j|jd|�Wqtk
rT}td||f��qXqWdS(s/Add filters to a filterer from a list of names.R�sUnable to add filter %r: %sN(t	addFilterR�R�Rt(R�tfiltererR�R@R�((s$/sys/lib/python2.7/logging/config.pytadd_filters�s

c	Cs|jdd�}|r\y|jd|}Wq\tk
rX}td||f��q\Xn|jdd�}|jdd�}d|kr�jd�}t|d�r�td�r�|�tjkr�j	|�}n|}n<|jd	�}|j	|�}	t
|	tjj
�r�d
|kr�yN|jd|d
}
t|
tj�sl||d	<td��n|
|d
<Wq tk
r�}td
|d
|f��q Xnvt
|	tjj�r�|kr�j|d�|d<n;t
|	tjj�r d|kr |j|d�|d<n|	}tg|D]"}t|�r0|||f^q0�}y||�}
WnJtk
r�}dt|�kr��n|jd�|d<||�}
nX|r�|
j|�n|dk	r�jtj|��n|r|j|
|�n|
S(s&Configure a handler from a dictionary.RARsUnable to set formatter %r: %sRDR�s()R�R�R2RERstarget not configured yets#Unable to set target handler %r: %stmailhosttaddresss'stream'tstreamtstrmN(RR6R�R�RtRR�R}R�R�RLR	RRMR)tHandlertSMTPHandlerR�t
SysLogHandlerRyRwR�R*RKRIR�R�(R�R�RAR�RDR�R>R�tcnameRStthR�R�R�R�((s$/sys/lib/python2.7/logging/config.pyR��sb4	
5cCs]xV|D]N}y|j|jd|�Wqtk
rT}td||f��qXqWdS(s.Add handlers to a logger from a list of names.RsUnable to add handler %r: %sN(R_R�R�Rt(R�RmRRUR�((s$/sys/lib/python2.7/logging/config.pytadd_handlers�s

cCs�|jdd�}|dk	r7|jtj|��n|s�x|jD]}|j|�qHW|jdd�}|r�|j||�n|jdd�}|r�|j||�q�ndS(sU
        Perform configuration which is common to root and non-root loggers.
        RDRR�N(	R3R6RIR	R�RR^R�R�(R�RmR�R�RDRURR�((s$/sys/lib/python2.7/logging/config.pytcommon_logger_configscCsPtj|�}|j|||�|jdd�}|dk	rL||_ndS(s.Configure a non-root logger from a dictionary.R[N(R	RdR�R3R6R[(R�RR�R�RmR[((s$/sys/lib/python2.7/logging/config.pyR�s
cCs#tj�}|j|||�dS(s*Configure a root logger from a dictionary.N(R	RdR�(R�R�R�RX((s$/sys/lib/python2.7/logging/config.pyR�s(
R�R�R�R�R�R�R�R�R�R�R�R�R�(((s$/sys/lib/python2.7/logging/config.pyR��s	�				:	cCst|�j�dS(s%Configure logging using a dictionary.N(tdictConfigClassR�(R�((s$/sys/lib/python2.7/logging/config.pyt
dictConfig!scsptstd��ndtfd��Y}dtfd��Y}dtjf�fd��Y��|||�S(sW
    Start up a socket server on the specified port, and listen for new
    configurations.

    These will be sent as a file suitable for processing by fileConfig().
    Returns a Thread object on which you can call start() to start the server,
    and which you can join() when appropriate. To stop the server, call
    stopListening().
    s listen() needs threading to worktConfigStreamHandlercBseZdZd�ZRS(s�
        Handler for a logging configuration request.

        It expects a completely new logging configuration and uses fileConfig
        to install it.
        c
Ss�ddl}y+|j}|jd�}t|�dkr6tjd|�d}|jj|�}x3t|�|kr�||j|t|��}qdWy)ddl}|j|�}t|�WnQt	j
|�}yt|�Wqtt
fk
r��qtj�qXnX|jjr6|jjj�q6nWnMtjk
r�}t|jt�sd�q�|jd}	|	tkr��q�nXdS(s�
            Handle a request.

            Each request is expected to be a 4-byte length, packed using
            struct.pack(">L", n), followed by the config file.
            Uses fileConfig() to do the grunt work.
            i�Nis>Li(ttempfilet
connectiontrecvR4tstructtunpacktjsontloadsR�t	cStringIOtStringIORtKeyboardInterruptt
SystemExitt	tracebackt	print_exctservertreadytsettsocketterrorR)RCR�tRESET_ERROR(
R�R�tconntchunktslenR�R�tfileR�terrcode((s$/sys/lib/python2.7/logging/config.pythandle:s:	!
(R�R�R�R�(((s$/sys/lib/python2.7/logging/config.pyR�3stConfigSocketReceivercBs2eZdZdZdeddd�Zd�ZRS(sD
        A simple TCP socket-based logging config receiver.
        it	localhostcSsLtj|||f|�tj�d|_tj�d|_||_dS(Nii(RR�R	R
tabortRttimeoutR�(R�thosttportR�R�((s$/sys/lib/python2.7/logging/config.pyR�ks
	
	cSs�ddl}d}xj|s~|j|jj�ggg|j�\}}}|r^|j�ntj�|j}tj�qW|jj	�dS(Ni�i(
tselectR�tfilenoR�thandle_requestR	R
R�Rtclose(R�RR�trdtwrtex((s$/sys/lib/python2.7/logging/config.pytserve_until_stoppedts	

	N(R�R�R�tallow_reuse_addresstDEFAULT_LOGGING_CONFIG_PORTR6R�R	(((s$/sys/lib/python2.7/logging/config.pyR�ds
tServercs eZ�fd�Zd�ZRS(csAt�|�j�||_||_||_tj�|_dS(N(tsuperR�trcvrthdlrRt	threadingtEventR�(R�RRR(R(s$/sys/lib/python2.7/logging/config.pyR��s
			cSs~|jd|jd|jd|j�}|jdkrI|jd|_n|jj�tj�|atj	�|j
�dS(NRR�R�ii(RRRR�tserver_addressR�R	R
t	_listenerRR	(R�R�((s$/sys/lib/python2.7/logging/config.pytrun�s


(R�R�R�R((R(s$/sys/lib/python2.7/logging/config.pyR�s(tthreadtNotImplementedErrorRRRtThread(RR�R�((Rs$/sys/lib/python2.7/logging/config.pytlisten&s
1cCs8tj�ztr%dt_danWdtj�XdS(sN
    Stop the listening server which was created with a call to listen().
    iN(R	R
RR�R6R(((s$/sys/lib/python2.7/logging/config.pyt
stopListening�s
	
(/R�R�R	tlogging.handlersR�R�tosR�R�R�R�RRR�R6tSocketServerRRRtplatformR�RRuRR"R(R-RRRR�tIRrRwRyRxR\R~R�RtobjectR�R�R�R�RR(((s$/sys/lib/python2.7/logging/config.pyt<module>s@`

						+	\	%��	s

Bell Labs OSI certified Powered by Plan 9

(Return to Plan 9 Home Page)

Copyright © 2021 Plan 9 Foundation. All Rights Reserved.
Comments to [email protected].