
    6hf                        S SK Jr  SSKJr  SSKJrJr  SSKJr   " S S5      r	S r
S	 rS
 rS rS rS rS rS rS rSS jrS r " S S5      r " S S5      rg)    )annotations   )_)errorutil)
stringutilc                  V    \ rS rSrSS jrS rS rS rSS jrSS jr	S	 r
S
 rS rSrg)parser   Nc                *    Xl         X l        S U l        g N)	_elements_methodscurrent)selfelementsmethodss      2/usr/lib/python3/dist-packages/mercurial/parser.py__init__parser.__init__   s    !    c                T    U R                   n[        U R                  S5      U l         U$ )zadvance the tokenizerN)r   next_iter)r   ts     r   _advanceparser._advance#   s"    LLDJJ-r   c                R    [        U R                  U R                  S      SS 5      $ )z%True if next token may start new termr   r      )anyr   r   )r   s    r   _hasnewtermparser._hasnewterm)   s%    4>>$,,q/21Q788r   c                    U R                   S   U:w  a=  [        R                  " [        S5      U R                   S   -  U R                   S   5      eU R	                  5         g)z0make sure the tokenizer matches an end conditionr   s   unexpected token: %s   N)r   r   
ParseErrorr   r   )r   ms     r   _matchparser._match-   sP    <<?a"")*T\\!_<dll1o  	r   c                    U(       a  U R                   S   U:X  a  SnOU R                  U5      nU(       a  U R                  U5        U$ )zDgather right-hand-side operand until an end condition or binding
metr   N)r   _parser'   )r   bindr&   exprs       r   _parseoperandparser._parseoperand5   s<     aA%D;;t$DKKNr   c                   U R                  5       u  p#nU R                  U   SS u  pVU(       a   U(       a  U R                  5       (       d  XS4nOBU(       a  US   U R                  " USS  6 4nO#[        R
                  " [        S5      U-  U5      eXR                  U R                  S      S   :  a  U R                  5       u  p#nU R                  U   SS  u  pU	(       a   U(       a  U R                  5       (       d  X4nOBU(       a  US   XpR                  " USS  6 4nO#[        R
                  " [        S5      U-  U5      eXR                  U R                  S      S   :  a  M  U$ )Nr   r   r   s   not a prefix: %ss   not an infix: %s)r   r   r!   r-   r   r%   r   r   )
r   r+   tokenvalueposprimaryprefixr,   infixsuffixs
             r   r*   parser._parse@   sF    MMOc../!4Ft'7'7'9'9#D1It116!":>?D""1%8#9E#A3GG^^DLLO4Q77 $E# NN51!"5MEu)9)9););~a$(:(:E!"I(FG&&q)<'='EsKK ^^DLLO4Q77 r   c                r    Xl         U R                  5         U R                  5       nU R                  u  p4nX%4$ )z!generate a parse tree from tokens)r   r   r*   r   )r   	tokeniterresr0   r1   r2   s         r   parseparser.parseW   s0    
kkm LLcxr   c                    [        U[        5      (       d  U$ U R                  US      " USS  Vs/ s H  o R                  U5      PM     sn6 $ s  snf )z4recursively evaluate a parse tree using node methodsr   r   N)
isinstancetupler   eval)r   treer   s      r   r@   parser.eval_   sJ    $&&K}}T!W%d12h'Gh		!h'GHH'Gs   Ac                l    U R                  U5      nU R                  (       a  U R                  U5      $ U$ )z<parse tokens into a parse tree and evaluate if methods given)r;   r   r@   )r   r9   r   s      r   __call__parser.__call__e   s*    JJy!==99Q<r   )r   r   r   r   r   )r   )__name__
__module____qualname____firstlineno__r   r   r!   r'   r-   r*   r;   r@   rD   __static_attributes__ r   r   r
   r
      s0    
9	.Ir   r
   c                   SnU R                  S5      u  p#nU(       aW  UR                  5       nU(       d  [        R                  " S5      e[	        U5      S:  a  [        R                  " S5      eUS   nUR                  S5      u  p#nUR                  5       nUR                  5       nU(       a(  U(       d  [        R                  " S5      eXeS   USS U4$ / SXa4$ )	aZ  Parse spec of function arguments into (poskeys, varkey, keys, optkey)

>>> splitargspec(b'')
([], None, [], None)
>>> splitargspec(b'foo bar')
([], None, ['foo', 'bar'], None)
>>> splitargspec(b'foo *bar baz **qux')
(['foo'], 'bar', ['baz'], 'qux')
>>> splitargspec(b'*foo')
([], 'foo', [], None)
>>> splitargspec(b'**foo')
([], None, [], 'foo')
Ns   **s   no **optkey name providedr   s!   excessive **optkey names providedr      *s   no *varkey name provided)	partitionsplitr   ProgrammingErrorlen)specoptkeypreseppostpostspress          r   splitargspecrY   m   s     F^^E*NCd


(()EFFu:>(()MNNq]]4(NCd99;DJJLE
(()DEE1XuQRy&00tT!!r   c                  ^ Uu  pVpx[        U4S j[        U 5       5       [        U 5      5      n	U	[        U5      :  a.  [        R                  " [        S5      U[        U5      S.-  5      eU(       dU  U	[        U5      [        U5      -   :  a:  [        R                  " [        S5      U[        U5      [        U5      -   S.-  5      e[        R                  " 5       n
[        XPSU	 5       H	  u  pXU'   M     U(       a  U [        U
5      U	 X'   O$[        Xp[        U
5      U	 5       H	  u  pXU'   M     U(       a  [        R                  " 5       X'   X	S  H  nU(       a  US   T:w  d  US   S   U:w  a$  [        R                  " [        S5      S	U0-  5      eUS   S   nX;   a  U
nO/U(       d$  [        R                  " [        S
5      XS.-  5      eX   nX;   a$  [        R                  " [        S5      XS.-  5      eUS   X'   M     U
$ )ay  Build dict from list containing positional and keyword arguments

Arguments are specified by a tuple of ``(poskeys, varkey, keys, optkey)``
where

- ``poskeys``: list of names of positional arguments
- ``varkey``: optional argument name that takes up remainder
- ``keys``: list of names that can be either positional or keyword arguments
- ``optkey``: optional argument name that takes up excess keyword arguments

If ``varkey`` specified, all ``keys`` must be given as keyword arguments.

Invalid keywords, too few positional arguments, or too many positional
arguments are rejected, but missing keyword arguments are just omitted.
c              3  T   >#    U  H  u  pU(       d  M  US    T:X  d  M  Uv   M     g7fr   NrK   ).0ixkeyvaluenodes      r   	<genexpr> buildargsdict.<locals>.<genexpr>   s&     F'tq111E's   ((	(s6   %(func)s takes at least %(nargs)d positional arguments)   funcs   nargss5   %(func)s takes at most %(nargs)d positional argumentsNr   r   s    %(func)s got an invalid argumentrc   s5   %(func)s got an unexpected keyword argument '%(key)s')rc   s   keys;   %(func)s got multiple values for keyword argument '%(key)s'r$   )	r   	enumeraterQ   r   r%   r   r   sortdictzip)treesfuncnameargspecr`   keynodeposkeysvarkeykeysrS   kwstartargskr_   ds      `          r   buildargsdictrr      s     %,!GTFy'FE
G WGH CL9:
 	
 gGs4y 88FG CL3t9,DEF
 	
 ==?DG8G_-Q .SY1CI89DAG : }}8_AaDL(AaDGw,>""56'89LL  aDG9A""JK$01 
 A6""* %0	1  t/ 0 Kr   c                     [         R                  " U 5      $ ! [         a=  n[        R                  " [         R
                  " U5      R                  5       5      eS nAff = fr   )r   unescapestr
ValueErrorr   r%   forcebytestrlower)ses     r   rt   rt      sR    C%%a(( C
 z66q9??ABBCs    
A8AAc                   [        U [        5      (       d(  UR                  U[        R                  " U 5      45        g U S   U;   aH  [        [        R                  U SS  5      nUR                  USU S   SR                  U5      4-  45        g UR                  USU S   -  45        U SS   H  n[        XQUS-   U5        M     US   S   US   S   S-   4/USS & g )Nr   r   s   (%s %s)    s   (%s   ))r>   r?   appendr   pprintmapjoin_prettyformat)rA   	leafnodeslevellinesrsrx   s         r   r   r      s    dE""eZ..t456	aI	""DH-eZ47DIIbM*BBCDeVd1g-./abA!	59 Ry|U2Yq\D%89:bc
r   c                T    / n[        XSU5        SR                  S U 5       5      nU$ )Nr      
c              3  6   #    U  H  u  pS U-  U-   v   M     g7f)s     NrK   )r]   lrx   s      r   ra   prettyformat.<locals>.<genexpr>   s     :EDAQEs   )r   r   )rA   r   r   outputs       r   prettyformatr      s,    E$1e,ZZ:E::FMr   c                x  ^ [        U [        5      (       d  U $ U S   nUT;  a  U4[        U4S jU SS  5       5      -   $ / nU nUS   U:X  a/  USS u  pVUR                  [        UT5      5        UnUS   U:X  a  M/  UR                  [        UT5      5        UR                  U5        [        [	        U5      5      $ )a{  Flatten chained infix operations to reduce usage of Python stack

>>> from . import pycompat
>>> def f(tree):
...     s = prettyformat(simplifyinfixops(tree, (b'or',)), (b'symbol',))
...     print(pycompat.sysstr(s))
>>> f((b'or',
...     (b'or',
...       (b'symbol', b'1'),
...       (b'symbol', b'2')),
...     (b'symbol', b'3')))
(or
  (symbol '1')
  (symbol '2')
  (symbol '3'))
>>> f((b'func',
...     (b'symbol', b'p1'),
...     (b'or',
...       (b'or',
...         (b'func',
...           (b'symbol', b'sort'),
...           (b'list',
...             (b'or',
...               (b'or',
...                 (b'symbol', b'1'),
...                 (b'symbol', b'2')),
...               (b'symbol', b'3')),
...             (b'negate',
...               (b'symbol', b'rev')))),
...         (b'and',
...           (b'symbol', b'4'),
...           (b'group',
...             (b'or',
...               (b'or',
...                 (b'symbol', b'5'),
...                 (b'symbol', b'6')),
...               (b'symbol', b'7'))))),
...       (b'symbol', b'8'))))
(func
  (symbol 'p1')
  (or
    (func
      (symbol 'sort')
      (list
        (or
          (symbol '1')
          (symbol '2')
          (symbol '3'))
        (negate
          (symbol 'rev'))))
    (and
      (symbol '4')
      (group
        (or
          (symbol '5')
          (symbol '6')
          (symbol '7'))))
    (symbol '8')))
r   c              3  <   >#    U  H  n[        UT5      v   M     g 7fr   )simplifyinfixops)r]   r_   targetnodess     r   ra   #simplifyinfixops.<locals>.<genexpr>5  s     Px!-a==xs   r   N)r>   r?   r~   r   reversed)rA   r   op
simplifiedr_   r   rs    `     r   r   r      s    x dE""	aB	uuPtABxPPPP
 JA
A$"*u*1k:; A$"* &q+67b*%&&r   c                   ^^ U T:X  a  TR                  5       $ [        U [        5      (       d  U $ [        UU4S jU  5       5      $ )Nc              3  >   >#    U  H  n[        UTT5      v   M     g 7fr   )
_buildtree)r]   r_   placeholder	replstacks     r   ra   _buildtree.<locals>.<genexpr>J  s     I1A{I66s   )popr>   r?   )templater   r   s    ``r   r   r   E  s:    ;}}h&&IIIIr   c                    [        U[        5      (       d  [        R                  " S5      e[	        [        U5      5      n[        XU5      nU(       a  [        R                  " S5      eU$ )a  Create new tree by substituting placeholders by replacements

>>> _ = (b'symbol', b'_')
>>> def f(template, *repls):
...     return buildtree(template, _, *repls)
>>> f((b'func', (b'symbol', b'only'), (b'list', _, _)),
...   ('symbol', '1'), ('symbol', '2'))
('func', ('symbol', 'only'), ('list', ('symbol', '1'), ('symbol', '2')))
>>> f((b'and', _, (b'not', _)), (b'symbol', b'1'), (b'symbol', b'2'))
('and', ('symbol', '1'), ('not', ('symbol', '2')))
    placeholder must be a node tuples   too many replacements)r>   r?   r   rP   listr   r   )r   r   replsr   r   s        r   	buildtreer   M  sW     k5))$$%HIIXe_%I8)4A$$%=>>Hr   c                  ^^^ X:X  a  g[        U [        5      (       a  [        U[        5      (       d  gU T:X  a  US   T;  a  TR                  U5        g[        U 5      [        U5      :w  a  g[	        UUU4S j[        X5       5       5      $ )NTFr   c              3  D   >#    U  H  u  p[        XTTT5      v   M     g 7fr   )
_matchtree)r]   pr_   incompletenodesmatchesr   s      r   ra   _matchtree.<locals>.<genexpr>l  s(      &DA 	1ow??&s    )r>   r?   r~   rQ   allrf   patternrA   r   r   r   s     ```r   r   r   b  s{    gu%%Ze-D-D+$q'"@t
7|s4y  &  r   Nc                    Ub+  [        U[        5      (       d  [        R                  " S5      eU/n[	        XX#U5      (       a  U$ g)a  If a tree matches the pattern, return a list of the tree and nodes
matched with the placeholder; Otherwise None

>>> def f(pattern, tree):
...     m = matchtree(pattern, tree, _, {b'keyvalue', b'list'})
...     if m:
...         return m[1:]

>>> _ = (b'symbol', b'_')
>>> f((b'func', (b'symbol', b'ancestors'), _),
...   (b'func', (b'symbol', b'ancestors'), (b'symbol', b'1')))
[('symbol', '1')]
>>> f((b'func', (b'symbol', b'ancestors'), _),
...   (b'func', (b'symbol', b'ancestors'), None))
>>> f((b'range', (b'dagrange', _, _), _),
...   (b'range',
...     (b'dagrange', (b'symbol', b'1'), (b'symbol', b'2')),
...     (b'symbol', b'3')))
[('symbol', '1'), ('symbol', '2'), ('symbol', '3')]

The placeholder does not match the specified incomplete nodes because
an incomplete node (e.g. argument list) cannot construct an expression.

>>> f((b'func', (b'symbol', b'ancestors'), _),
...   (b'func', (b'symbol', b'ancestors'),
...     (b'list', (b'symbol', b'1'), (b'symbol', b'2'))))

The placeholder may be omitted, but which shouldn't match a None node.

>>> _ = None
>>> f((b'func', (b'symbol', b'ancestors'), None),
...   (b'func', (b'symbol', b'ancestors'), (b'symbol', b'0')))
Nr   )r>   r?   r   rP   r   r   s        r   	matchtreer   r  sJ    D z+u'E'E$$%HIIfG'wGG Hr   c                |    U R                   b$  [        S5      U R                   U R                  4-  $ U R                  $ )z6Compose error message from specified ParseError objects	   at %d: %s)locationr   message)insts    r   parseerrordetailr     s2    }} $--!>>>||r   c                      \ rS rSrSrS rSrg)aliasi  zParsed result of aliasc                B    Xl         X l        X0l        X@l        SU l        g )NF)namero   r   replacementwarned)r   r   ro   errr   s        r   r   alias.__init__  s     		
& r   )ro   r   r   r   r   N)rF   rG   rH   rI   __doc__r   rJ   rK   r   r   r   r     s
     r   r   c                      \ rS rSrSrSrSrS r\S 5       r	\S 5       r
\S 5       r\S	 5       r\S
 5       r\S 5       r\S 5       r\S 5       r\S 5       r\S 5       r\S 5       rSrg)basealiasrulesi  a[  Parsing and expansion rule set of aliases

This is a helper for fileset/revset/template aliases. A concrete rule set
should be made by sub-classing this and implementing class/static methods.

It supports alias expansion of symbol and function-call styles::

    # decl = defn
    h = heads(default)
    b($1) = ancestors($1) - ancestors(default)
Ns   symbolc                2    [        SU R                  -  5      e)Ns   '%s' is not instantiatable)	TypeErrorrF   )clss    r   __new__basealiasrules.__new__  s    5DEEr   c                    [         e)z-Parse an alias name, arguments and definitionNotImplementedError)rR   s    r   r*   basealiasrules._parse  
     "!r   c                    [         e)z9Return (name, args) if tree is a function; otherwise Noner   )rA   s    r   _trygetfuncbasealiasrules._trygetfunc  r   r   c                  ^   T R                  U5      nUS   T R                  :X  a1  US   nUR                  S5      (       a  US[        S5      U-  4$ USS4$ T R                  U5      nU(       a  Uu  pFUR                  S5      (       a  US[        S5      U-  4$ [        U 4S jU 5       5      (       a  US[        S5      4$ [        U5      [        [        U5      5      :w  a  US[        S	5      4$ XF Vs/ s H  owS   PM	     snS4$ US[        S
5      4$ ! [        R                   a  nUS[        U5      4s SnA$ SnAff = fs  snf )aI  Parse an alias declaration into ``(name, args, errorstr)``

This function analyzes the parsed tree. The parsing rule is provided
by ``_parse()``.

- ``name``: of declared alias (may be ``decl`` itself at error)
- ``args``: list of argument names (or None for symbol declaration)
- ``errorstr``: detail about detected error (or None)

>>> sym = lambda x: (b'symbol', x)
>>> symlist = lambda *xs: (b'list',) + tuple(sym(x) for x in xs)
>>> func = lambda n, a: (b'func', sym(n), a)
>>> parsemap = {
...     b'foo': sym(b'foo'),
...     b'$foo': sym(b'$foo'),
...     b'foo::bar': (b'dagrange', sym(b'foo'), sym(b'bar')),
...     b'foo()': func(b'foo', None),
...     b'$foo()': func(b'$foo', None),
...     b'foo($1, $2)': func(b'foo', symlist(b'$1', b'$2')),
...     b'foo(bar_bar, baz.baz)':
...         func(b'foo', symlist(b'bar_bar', b'baz.baz')),
...     b'foo(bar($1, $2))':
...         func(b'foo', func(b'bar', symlist(b'$1', b'$2'))),
...     b'foo($1, $2, nested($1, $2))':
...         func(b'foo', (symlist(b'$1', b'$2') +
...                      (func(b'nested', symlist(b'$1', b'$2')),))),
...     b'foo("bar")': func(b'foo', (b'string', b'bar')),
...     b'foo($1, $2': error.ParseError(b'unexpected token: end', 10),
...     b'foo("bar': error.ParseError(b'unterminated string', 5),
...     b'foo($1, $2, $1)': func(b'foo', symlist(b'$1', b'$2', b'$1')),
... }
>>> def parse(expr):
...     x = parsemap[expr]
...     if isinstance(x, Exception):
...         raise x
...     return x
>>> def trygetfunc(tree):
...     if not tree or tree[0] != b'func' or tree[1][0] != b'symbol':
...         return None
...     if not tree[2]:
...         return tree[1][1], []
...     if tree[2][0] == b'list':
...         return tree[1][1], list(tree[2][1:])
...     return tree[1][1], [tree[2]]
>>> class aliasrules(basealiasrules):
...     _parse = staticmethod(parse)
...     _trygetfunc = staticmethod(trygetfunc)
>>> builddecl = aliasrules._builddecl
>>> builddecl(b'foo')
('foo', None, None)
>>> builddecl(b'$foo')
('$foo', None, "invalid symbol '$foo'")
>>> builddecl(b'foo::bar')
('foo::bar', None, 'invalid format')
>>> builddecl(b'foo()')
('foo', [], None)
>>> builddecl(b'$foo()')
('$foo()', None, "invalid function '$foo'")
>>> builddecl(b'foo($1, $2)')
('foo', ['$1', '$2'], None)
>>> builddecl(b'foo(bar_bar, baz.baz)')
('foo', ['bar_bar', 'baz.baz'], None)
>>> builddecl(b'foo($1, $2, nested($1, $2))')
('foo($1, $2, nested($1, $2))', None, 'invalid argument list')
>>> builddecl(b'foo(bar($1, $2))')
('foo(bar($1, $2))', None, 'invalid argument list')
>>> builddecl(b'foo("bar")')
('foo("bar")', None, 'invalid argument list')
>>> builddecl(b'foo($1, $2')
('foo($1, $2', None, 'at 10: unexpected token: end')
>>> builddecl(b'foo("bar')
('foo("bar', None, 'at 5: unterminated string')
>>> builddecl(b'foo($1, $2, $1)')
('foo', None, 'argument names collide with each other')
Nr   r      $   invalid symbol '%s's   invalid function '%s'c              3  F   >#    U  H  oS    TR                   :g  v   M     g7fr\   )_symbolnode)r]   r   r   s     r   ra   ,basealiasrules._builddecl.<locals>.<genexpr>/  s     9DqQ43??*Ds   !s   invalid argument lists&   argument names collide with each others   invalid format)r*   r   r%   r   r   
startswithr   r   r    rQ   set)r   declrA   r   r   funcro   r   s   `       r   
_builddeclbasealiasrules._builddecl  sX   Z	8::d#D 7coo%7Dt$$dA&<$=$DEE$%%t$JDt$$dA&>$?$$FGG9D999dA&>$?@@4yCD	N*?@ 
 .AQ4.55dA/0115  	8$ 0 677	80 /s#   D 6EE+D>8E>Ec                P  ^ ^ [        U[        5      (       d  U$ US   nUT R                  :w  a  U4[        UU 4S jUSS  5       5      -   $ [        U5      S:X  d   eUS   nUT;   a  SnX44$ UR	                  S5      (       a"  [
        R                  " [        S5      U-  5      eX44$ )	z%Mark alias arguments as ``_aliasarg``r   c              3  H   >#    U  H  nTR                  UT5      v   M     g 7fr   )_relabelargs)r]   r_   ro   r   s     r   ra   .basealiasrules._relabelargs.<locals>.<genexpr>B  s!      MHq!1!1!T!:!:H   "r   Nr$   	   _aliasargr   r   )r>   r?   r   rQ   r   r   r%   r   )r   rA   ro   r   syms   ` `  r   r   basealiasrules._relabelargs;  s     $&&K!W 55 MDH MMMM4yA~~1g$;B y ^^D!!""1%;#<s#BCCyr   c                    U R                  U5      nU(       a  [        U5      nO
[        5       nU R                  X25      $ )a  Parse an alias definition into a tree and marks substitutions

This function marks alias argument references as ``_aliasarg``. The
parsing rule is provided by ``_parse()``.

``args`` is a list of alias argument names, or None if the alias
is declared as a symbol.

>>> from . import pycompat
>>> parsemap = {
...     b'$1 or foo': (b'or', (b'symbol', b'$1'), (b'symbol', b'foo')),
...     b'$1 or $bar':
...         (b'or', (b'symbol', b'$1'), (b'symbol', b'$bar')),
...     b'$10 or baz':
...         (b'or', (b'symbol', b'$10'), (b'symbol', b'baz')),
...     b'"$1" or "foo"':
...         (b'or', (b'string', b'$1'), (b'string', b'foo')),
... }
>>> class aliasrules(basealiasrules):
...     _parse = staticmethod(parsemap.__getitem__)
...     _trygetfunc = staticmethod(lambda x: None)
>>> builddefn = aliasrules._builddefn
>>> def pprint(tree):
...     s = prettyformat(tree, (b'_aliasarg', b'string', b'symbol'))
...     print(pycompat.sysstr(s))
>>> args = [b'$1', b'$2', b'foo']
>>> pprint(builddefn(b'$1 or foo', args))
(or
  (_aliasarg '$1')
  (_aliasarg 'foo'))
>>> try:
...     builddefn(b'$1 or $bar', args)
... except error.ParseError as inst:
...     print(pycompat.sysstr(parseerrordetail(inst)))
invalid symbol '$bar'
>>> args = [b'$1', b'$10', b'foo']
>>> pprint(builddefn(b'$10 or baz', args))
(or
  (_aliasarg '$10')
  (symbol 'baz'))
>>> pprint(builddefn(b'"$1" or "foo"', args))
(or
  (string '$1')
  (string 'foo'))
)r*   r   r   )r   defnro   rA   s       r   
_builddefnbasealiasrules._builddefnL  s7    ^ zz$t9D5D++r   c                4   S=p4U R                  U5      u  pVnU(       a  [        S5      nO U R                  X&5      nU(       a  UU R                  UUS.-  n[        XVXs5      $ ! [        R                   a   n[        U5      n[        S5      n SnANUSnAff = f)z>Parse an alias declaration and definition into an alias objectNs4   bad declaration of %(section)s "%(name)s": %(error)ss3   bad definition of %(section)s "%(name)s": %(error)s)   section   names   error)r   r   r   r   r%   r   _sectionr   )	r   r   r   replefmtr   ro   r   r   s	            r   buildbasealiasrules.build  s     ...CLMDQ~~d1 LL C
 T++ ## Q&t,OPQs   A# #B7BBc                ^    0 nU H$  u  p4U R                  X45      nXRUR                  '   M&     U$ )zLParse a list of alias (name, replacement) pairs into a dict of
alias objects)r   r   )r   itemsaliasesr   r   as         r   buildmapbasealiasrules.buildmap  s5     JD		$%AAFFO   r   c                :   [        U[        5      (       d  gUS   U R                  :X  a.  US   nUR                  U5      nU(       a  UR                  c  US4$ U R                  U5      nU(       a,  Uu  p6UR                  U5      nU(       a  UR                  b  XF4$ g)zbIf tree looks like an unexpanded alias, return (alias, pattern-args)
pair. Return None otherwise.
Nr   r   )r>   r?   r   getro   r   )r   r   rA   r   r   r   ro   s          r   	_getaliasbasealiasrules._getalias  s    
 $&&7coo%7DD!AQVV^$wt$JDD!AQVV'wr   c                   ^ ^ [        U[        5      (       d  U$ US   S:X  a
  US   nTU   $ [        UU 4S jU 5       5      $ )z_Replace _aliasarg instances with the substitution value of the
same name in args, recursively.
r   r   r   c              3  H   >#    U  H  nTR                  UT5      v   M     g 7fr   )_expandargs)r]   r   ro   r   s     r   ra   -basealiasrules._expandargs.<locals>.<genexpr>  s     <t!S__Q--tr   )r>   r?   )r   rA   ro   r   s   ` ` r   r   basealiasrules._expandargs  sG    
 $&&K7l"q'C9<t<<<r   c           	       ^ ^^^ [        U[        5      (       d  U$ T R                  TU5      nUc  [        UUU U4S jU 5       5      $ Uu  pgUR                  (       a   [        R                  " UR                  5      eUT;   a9  [        R
                  " [        S5      T R                  UR                  S.-  5      eTR                  U5        UR                  T;  a+  T R                  TUR                  TT5      TUR                  '   TUR                     nTR                  5         UR                  c  U$ [        U5      [        UR                  5      :w  a+  [        R
                  " [        S5      [        U5      -  5      eU V	s/ s H  n	T R                  TU	/ T5      PM     nn	T R                  U[!        [#        UR                  U5      5      5      $ s  sn	f )Nc              3  L   >#    U  H  nTR                  TUTT5      v   M     g 7fr   _expand)r]   r   r   cacher   	expandings     r   ra   )basealiasrules._expand.<locals>.<genexpr>  s&      CGaGQ	5994s   !$s5   infinite expansion of %(section)s "%(name)s" detected)r   r   s   invalid number of arguments: %d)r>   r?   r   r   Abortr%   r   r   r   r~   r   r   r   ro   rQ   r   dictrf   )
r   r   rA   r  r   r   r   r   resultr   s
   `` ``     r   r   basealiasrules._expand  s   $&&KMM'4(9 CG   77++agg&&	>""JK"||aff=> 
 	66KK	5E!&&M qvv66>Mq6S[ ""45A>  :;;AS[[!R/;vtCN';<< <s   Gc                (    U R                  X/ 0 5      $ )zoExpand aliases in tree, recursively.

'aliases' is a dictionary mapping user defined aliases to alias objects.
r   )r   r   rA   s      r   expandbasealiasrules.expand  s     {{7"b11r   rK   )rF   rG   rH   rI   r   r   r   r   staticmethodr*   r   classmethodr   r   r   r   r   r   r   r   r  rJ   rK   r   r   r   r     s    
 HKF " " " " h2 h2T    3, 3,j , ,(    & 	= 	=  =  =D 2 2r   r   )NrK   )
__future__r   i18nr    r   r   utilsr   r
   rY   rr   rt   r   r   r   r   r   r   r   r   r   r   rK   r   r   <module>r     sy   & #  M M`"DCLC
;M'`J* &R y2 y2r   