�`^c
@s�dZyddlmZWnek
r3eZnXddlZdddddd d
ddd
dddg
ZdZdZ de
fd��YZdefd��YZdefd��YZ
defd��YZdefd��YZdefd��YZd efd��YZdefd��YZd
efd��YZdefd��YZdfd��YZddlZd ejfd!��YZdefd"��YZd
efd#��YZdS($sConfiguration file parser.
A setup file consists of sections, lead by a "[section]" header,
and followed by "name: value" entries, with continuations and such in
the style of RFC 822.
The option values can contain format strings which refer to other values in
the same section, or values in a special [DEFAULT] section.
For example:
something: %(dir)s/whatever
would resolve the "%(dir)s" to the value of dir. All reference
expansions are done late, on demand.
Intrinsic defaults can be specified by passing them into the
ConfigParser constructor as a dictionary.
class:
ConfigParser -- responsible for parsing a list of
configuration files, and managing the parsed database.
methods:
__init__(defaults=None)
create the parser and specify a dictionary of intrinsic defaults. The
keys must be strings, the values must be appropriate for %()s string
interpolation. Note that `__name__' is always an intrinsic default;
its value is the section's name.
sections()
return all the configuration section names, sans DEFAULT
has_section(section)
return whether the given section exists
has_option(section, option)
return whether the given option exists in the given section
options(section)
return list of configuration options for the named section
read(filenames)
read and parse the list of named configuration files, given by
name. A single filename is also allowed. Non-existing files
are ignored. Return list of successfully read files.
readfp(fp, filename=None)
read and parse one configuration file, given as a file object.
The filename defaults to fp.name; it is only used in error
messages (if fp has no `name' attribute, the string `<???>' is used).
get(section, option, raw=False, vars=None)
return a string value for the named option. All % interpolations are
expanded in the return values, based on the defaults passed into the
constructor and the DEFAULT section. Additional substitutions may be
provided using the `vars' argument, which must be a dictionary whose
contents override any pre-existing defaults.
getint(section, options)
like get(), but convert value to an integer
getfloat(section, options)
like get(), but convert value to a float
getboolean(section, options)
like get(), but convert value to a boolean (currently case
insensitively defined as 0, false, no, off for False, and 1, true,
yes, on for True). Returns False or True.
items(section, raw=False, vars=None)
return a list of tuples with (name, value) for each option
in the section.
remove_section(section)
remove the given file section and all its options
remove_option(section, option)
remove the given option from the given section
set(section, option, value)
set the given option
write(fp)
write the configuration state in .ini format
i�(tOrderedDictNtNoSectionErrortDuplicateSectionErrort
NoOptionErrortInterpolationErrortInterpolationDepthErrortInterpolationSyntaxErrortParsingErrortMissingSectionHeaderErrortConfigParsertSafeConfigParsertRawConfigParsertDEFAULTSECTtMAX_INTERPOLATION_DEPTHtDEFAULTi
tErrorcBsJeZdZd�Zd�Zeee�Zdd�Zd�ZeZ RS(s'Base class for ConfigParser exceptions.cCs|jS(sSGetter for 'message'; needed only to override deprecation in
BaseException.(t_Error__message(tself((s"/sys/lib/python2.7/ConfigParser.pyt_get_messagesscCs
||_dS(sSSetter for 'message'; needed only to override deprecation in
BaseException.N(R(Rtvalue((s"/sys/lib/python2.7/ConfigParser.pyt_set_messagexstcCs||_tj||�dS(N(tmessaget Exceptiont__init__(Rtmsg((s"/sys/lib/python2.7/ConfigParser.pyR�s cCs|jS(N(R(R((s"/sys/lib/python2.7/ConfigParser.pyt__repr__�s(
t__name__t
__module__t__doc__RRtpropertyRRRt__str__(((s"/sys/lib/python2.7/ConfigParser.pyRps cBseZdZd�ZRS(s2Raised when no section matches a requested option.cCs0tj|d|f�||_|f|_dS(NsNo section: %r(RRtsectiontargs(RR ((s"/sys/lib/python2.7/ConfigParser.pyR�s (RRRR(((s"/sys/lib/python2.7/ConfigParser.pyR�scBseZdZd�ZRS(s*Raised when a section is multiply-created.cCs-tj|d|�||_|f|_dS(NsSection %r already exists(RRR R!(RR ((s"/sys/lib/python2.7/ConfigParser.pyR�s (RRRR(((s"/sys/lib/python2.7/ConfigParser.pyR�scBseZdZd�ZRS(s!A requested option was not found.cCs?tj|d||f�||_||_||f|_dS(NsNo option %r in section: %r(RRtoptionR R!(RR"R ((s"/sys/lib/python2.7/ConfigParser.pyR�s
(RRRR(((s"/sys/lib/python2.7/ConfigParser.pyR�scBseZdZd�ZRS(s0Base class for interpolation-related exceptions.cCs8tj||�||_||_|||f|_dS(N(RRR"R R!(RR"R R((s"/sys/lib/python2.7/ConfigParser.pyR�s (RRRR(((s"/sys/lib/python2.7/ConfigParser.pyR�stInterpolationMissingOptionErrorcBseZdZd�ZRS(sAA string substitution required a setting which was not available.cCsNd||||f}tj||||�||_||||f|_dS(NsNBad value substitution:
section: [%s]
option : %s
key : %s
rawval : %s
(RRt referenceR!(RR"R trawvalR$R((s"/sys/lib/python2.7/ConfigParser.pyR�s
(RRRR(((s"/sys/lib/python2.7/ConfigParser.pyR#�scBseZdZRS(sjRaised when the source text into which substitutions are made
does not conform to the required syntax.(RRR(((s"/sys/lib/python2.7/ConfigParser.pyR�scBseZdZd�ZRS(s0Raised when substitutions are nested too deeply.cCs?d|||f}tj||||�|||f|_dS(NsSValue interpolation too deeply recursive:
section: [%s]
option : %s
rawval : %s
(RRR!(RR"R R%R((s"/sys/lib/python2.7/ConfigParser.pyR�s(RRRR(((s"/sys/lib/python2.7/ConfigParser.pyR�scBs eZdZd�Zd�ZRS(s>Raised when a configuration file does not follow legal syntax.cCs6tj|d|�||_g|_|f|_dS(Ns File contains parsing errors: %s(RRtfilenameterrorsR!(RR&((s"/sys/lib/python2.7/ConfigParser.pyR�s cCs3|jj||f�|jd||f7_dS(Ns
[line %2d]: %s(R'tappendR(Rtlinenotline((s"/sys/lib/python2.7/ConfigParser.pyR(�s(RRRRR((((s"/sys/lib/python2.7/ConfigParser.pyR�s cBseZdZd�ZRS(s@Raised when a key-value pair is found before any section header.cCsNtj|d|||f�||_||_||_|||f|_dS(Ns7File contains no section headers.
file: %s, line: %d
%r(RRR&R)R*R!(RR&R)R*((s"/sys/lib/python2.7/ConfigParser.pyR�s (RRRR(((s"/sys/lib/python2.7/ConfigParser.pyR�scBs?eZd eed�Zd�Zd�Zd�Zd�Z d�Z
d�Zd d�Zd�Z
d �Zd
�Zd�Zd�Zied
6ed6ed6ed6ed6ed6ed6ed6Zd�Zd�Zd�Zd d�Zd�Zd�Zd�Zejd�Zejd�Zejd�Zd�Z RS(!cCs�||_|j�|_|j�|_|r<|j|_n|j|_|r�x3|j�D]"\}}||j|j|�<q[WndS(N(t_dictt _sectionst _defaultst OPTCRE_NVt_optcretOPTCREtitemstoptionxform(Rtdefaultst dict_typetallow_no_valuetkeyR((s"/sys/lib/python2.7/ConfigParser.pyR�s cCs|jS(N(R-(R((s"/sys/lib/python2.7/ConfigParser.pyR3�scCs
|jj�S(s3Return a list of section names, excluding [DEFAULT](R,tkeys(R((s"/sys/lib/python2.7/ConfigParser.pytsections�scCsW|j�dkr"td|�n||jkr@t|��n|j�|j|<dS(s�Create a new section in the configuration.
Raise DuplicateSectionError if a section by the specified name
already exists. Raise ValueError if name is DEFAULT or any of it's
case-insensitive variants.
tdefaultsInvalid section name: %sN(tlowert
ValueErrorR,RR+(RR ((s"/sys/lib/python2.7/ConfigParser.pytadd_section�s
cCs
||jkS(s~Indicate whether the named section is present in the configuration.
The DEFAULT section is not acknowledged.
(R,(RR ((s"/sys/lib/python2.7/ConfigParser.pythas_sectionscCsgy|j|j�}Wntk
r6t|��nX|j|j�d|kr]|d=n|j�S(s9Return a list of option names for the given section name.R(R,tcopytKeyErrorRtupdateR-R7(RR topts((s"/sys/lib/python2.7/ConfigParser.pytoptionss
cCs�t|t�r|g}ng}x\|D]T}yt|�}Wntk
rTq(nX|j||�|j�|j|�q(W|S(s�Read and parse a filename or a list of filenames.
Files that cannot be opened are silently ignored; this is
designed so that you can specify a list of potential
configuration file locations (e.g. current directory, user's
home directory, systemwide directory), and all existing
configuration files in the list will be read. A single
filename may also be given.
Return list of successfully read files.
(t
isinstancet
basestringtopentIOErrort_readtcloseR((Rt filenamestread_okR&tfp((s"/sys/lib/python2.7/ConfigParser.pytreads
cCsJ|dkr6y
|j}Wq6tk
r2d}q6Xn|j||�dS(sLike read() but the argument must be a file-like object.
The `fp' argument must have a `readline' method. Optional
second argument is the `filename', which if not given, is
taken from fp.name. If fp has no `name' attribute, `<???>' is
used.
s<???>N(tNonetnametAttributeErrorRG(RRKR&((s"/sys/lib/python2.7/ConfigParser.pytreadfp6s
cCs�|j|�}||jkre|tkr9t|��n||jkrS|j|St||��nK||j|kr�|j||S||jkr�|j|St||��dS(N(R2R,RRR-R(RR R"topt((s"/sys/lib/python2.7/ConfigParser.pytgetFscCs�y|j|}Wn8tk
rK|tkr<t|��n|j�}nX|jj�}|j|�d|kr~|d=n|j�S(NR( R,R?RRR+R-R>R@R1(RR td2td((s"/sys/lib/python2.7/ConfigParser.pyR1Vs
cCs||j||��S(N(RR(RR tconvR"((s"/sys/lib/python2.7/ConfigParser.pyt_getcscCs|j|t|�S(N(RVtint(RR R"((s"/sys/lib/python2.7/ConfigParser.pytgetintfscCs|j|t|�S(N(RVtfloat(RR R"((s"/sys/lib/python2.7/ConfigParser.pytgetfloatist1tyesttruetont0tnotfalsetoffcCsH|j||�}|j�|jkr7td|�n|j|j�S(NsNot a boolean: %s(RRR:t_boolean_statesR;(RR R"tv((s"/sys/lib/python2.7/ConfigParser.pyt
getbooleanoscCs
|j�S(N(R:(Rt optionstr((s"/sys/lib/python2.7/ConfigParser.pyR2uscCsu|s|tkr/|j|�}||jkS||jkrBtS|j|�}||j|kpp||jkSdS(s=Check for the existence of a given option in a given section.N(RR2R-R,tFalse(RR R"((s"/sys/lib/python2.7/ConfigParser.pyt
has_optionxs
cCsg|s|tkr|j}n1y|j|}Wntk
rOt|��nX|||j|�<dS(sSet an option.N(RR-R,R?RR2(RR R"Rtsectdict((s"/sys/lib/python2.7/ConfigParser.pytset�s
cCs8|jrs|jdt�xF|jj�D]5\}}|jd|t|�jdd�f�q*W|jd�nx�|jD]�}|jd|�x�|j|j�D]w\}}|dkr�q�n|dk s�j|j krdj
|t|�jdd�f�}n|jd|�q�W|jd�q}WdS( s?Write an .ini-format representation of the configuration state.s[%s]
s%s = %s
s
s
Rs = s%s
N(R-twriteRR1tstrtreplaceR,RMR/R0tjoin(RRKR6RR ((s"/sys/lib/python2.7/ConfigParser.pyRk�s - *cCs|s|tkr|j}n1y|j|}Wntk
rOt|��nX|j|�}||k}|r{||=n|S(sRemove an option.(RR-R,R?RR2(RR R"Ritexisted((s"/sys/lib/python2.7/ConfigParser.pyt
remove_option�s
cCs&||jk}|r"|j|=n|S(sRemove a file section.(R,(RR Ro((s"/sys/lib/python2.7/ConfigParser.pytremove_section�s
s\[(?P<header>[^]]+)\]s9(?P<option>[^:=\s][^:=]*)\s*(?P<vi>[:=])\s*(?P<value>.*)$s>(?P<option>[^:=\s][^:=]*)\s*(?:(?P<vi>[:=])\s*(?P<value>.*))?$cCs:d}d}d}d}x�tr�|j�}|s7Pn|d}|j�dks|ddkriqn|jdd�dj�dkr�|ddkr�qn|dj�r�dk r�r�j�}|r�||j|�q�q|jj |�} | rv| j
d�}
|
|jkr2|j|
}n;|
tkrJ|j
}n#|j�}|
|d<||j|
<d}q|dkr�t|||��q|jj |�} | r�| j
d d
d�\}}}|j|j��}|dk rv|dkrEd|krE|jd�}
|
dkrE||
dj�rE||
}qEn|j�}|dkrfd}n|g||<q�|||<q|s�t|�}n|j|t|��qW|r�|�n|j
g}|j|jj��xP|D]H}x?|j�D]1\}}t|t�r�j|�||<q�Wq�dS(s�Parse a sectioned setup file.
The sections in setup file contains a title line at the top,
indicated by a name in square brackets (`[]'), plus key/value
options lines, indicated by `name: value' format lines.
Continuations are represented by an embedded newline then
leading whitespace. Blank lines, lines beginning with a '#',
and just about everything else are ignored.
iiRs#;tremtrRtheaderRR"tviRt=t:t;i�s""s
N(RvRw(RMtTruetreadlinetstriptsplitR:tisspaceR(tSECTCREtmatchtgroupR,RR-R+RR/R2trstriptfindRtreprtextendtvaluesR1RCtlistRn(RRKtfpnametcursecttoptnameR)teR*RtmotsectnameRutoptvaltpostall_sectionsRBRNtval((s"/sys/lib/python2.7/ConfigParser.pyRG�sn
"2"
N(!RRRMt
_default_dictRgRR3R8R<R=RBRLRPRRR1RVRXRZRyRcReR2RhRjRkRpRqtretcompileR~R0R.RG(((s"/sys/lib/python2.7/ConfigParser.pyR�s<
t _ChainmapcBs)eZdZd�Zd�Zd�ZRS(s�Combine multiple mappings for successive lookups.
For example, to emulate Python's normal lookup sequence:
import __builtin__
pylookup = _Chainmap(locals(), globals(), vars(__builtin__))
cGs
||_dS(N(t_maps(Rtmaps((s"/sys/lib/python2.7/ConfigParser.pyR7scCsDx1|jD]&}y||SWq
tk
r/q
Xq
Wt|��dS(N(R�R?(RR6tmapping((s"/sys/lib/python2.7/ConfigParser.pyt__getitem__:s
cCsag}t�}xK|jD]@}x7|D]/}||kr&|j|�|j|�q&q&WqW|S(N(RjR�R(tadd(RtresulttseenR�R6((s"/sys/lib/python2.7/ConfigParser.pyR7Bs
(RRRRR�R7(((s"/sys/lib/python2.7/ConfigParser.pyR�.s cBsGeZedd�Zedd�Zd�Zejd�Z d�Z
RS(c
Cs
i}y|j|}Wn,tk
rE|tkrFt|��qFnXi}|r�x0|j�D]\}}|||j|�<q_Wnt|||j�} |j|�}y| |}Wn tk
r�t||��nX|s�dkr�S|j
|||| �SdS(s�Get an option value for a given section.
If `vars' is provided, it must be a dictionary. The option is looked up
in `vars' (if provided), `section', and in `defaults' in that order.
All % interpolations are expanded in the return values, unless the
optional argument `raw' is true. Values for interpolation keys are
looked up in the same manner as the option.
The section DEFAULT is special.
N(R,R?RRR1R2R�R-RRMt_interpolate(
RR R"trawtvarstsectiondicttvardictR6RRT((s"/sys/lib/python2.7/ConfigParser.pyRRNs&
c Cs|jj�}y|j|j|�Wn,tk
rU|tkrVt|��qVnX|r�x0|j�D]\}}|||j|�<qiWn|j �}d|kr�|j
d�n|r�g|D]}|||f^q�Sg|D](}||j|||||�f^q�dS(s�Return a list of tuples with (name, value) for each option
in the section.
All % interpolations are expanded in the return values, based on the
defaults passed into the constructor, unless the optional argument
`raw' is true. Additional substitutions may be provided using the
`vars' argument, which must be a dictionary whose contents overrides
any pre-existing defaults.
The section DEFAULT is special.
RN(R-R>R@R,R?RRR1R2R7tremoveR�( RR R�R�RTR6RRBR"((s"/sys/lib/python2.7/ConfigParser.pyR1qs"
cCs�|}t}x�|r�|d8}|r�d|kr�|jj|j|�}y||}Wq�tk
r�}t||||jd��q�XqPqW|r�d|kr�t|||��n|S(Nis%(i(R
t_KEYCREtsubt_interpolation_replaceR?R#R!R(RR R"R%R�RtdepthR�((s"/sys/lib/python2.7/ConfigParser.pyR��s
s%\(([^)]*)\)s|.cCs:|jd�}|dkr%|j�Sd|j|�SdS(Nis%%(%s)s(R�RMR2(RRts((s"/sys/lib/python2.7/ConfigParser.pyR��s
N(RRRgRMRRR1R�R�R�R�R�(((s"/sys/lib/python2.7/ConfigParser.pyR Ls
# cBs5eZd�Zejd�Zd�Zdd�ZRS(cCs/g}|j|||||d�dj|�S(NiR(t_interpolate_someRn(RR R"R%R�tL((s"/sys/lib/python2.7/ConfigParser.pyR��ss
%\(([^)]+)\)scCs�|tkr!t|||��nx�|r�|jd�}|dkrV|j|�dS|dkr�|j|| �||}n|dd!}|dkr�|jd�|d}q$|dkr�|jj|�} | dkr�||d|��n|j| j d��}
|| j
�}y||
}Wn&tk
rTt||||
��nXd|kr�|j
||||||d�q�|j|�q$t||d|f��q$WdS(Nt%iiit(s'bad interpolation variable reference %rs/'%%' must be followed by '%%' or '(', found: %r(R
RR�R(t
_interpvar_reRRMRR2R�tendR?R#R�(RR"taccumtrestR tmapR�tptctmtvarRd((s"/sys/lib/python2.7/ConfigParser.pyR��sB
cCs�|j|jks|r9t|t�s9td��q9n|dk r�|jdd�}|jjd|�}d|kr�t d||j
d�f��q�ntj||||�dS(sASet an option. Extend ConfigParser.set: check for string values.soption values must be stringss%%RR�s1invalid interpolation syntax in %r at position %dN(
R/R0RCRDt TypeErrorRMRmR�R�R;R�R Rj(RR R"Rt tmp_value((s"/sys/lib/python2.7/ConfigParser.pyRj�sN( RRR�R�R�R�R�RMRj(((s"/sys/lib/python2.7/ConfigParser.pyR
�s &(RtcollectionsRR�tImportErrortdictR�t__all__RR
RRRRRRR#RRRRRtUserDictt _UserDictt DictMixinR�R R
(((s"/sys/lib/python2.7/ConfigParser.pyt<module>Xs:
�b
|