
    h|                       d dl mZ d dlZd dlZd dlZd dlmZ d dlm	Z	 d dl
mZ d dlmZ ddlmZ dd	lmZ d
dlmZ ej(                  rd
dlmZ d
dlmZ  G d dej0                        Ze G d d             Z ej6                  dej8                        Z ej6                  d      Z ej6                  dej8                        ZddddZ d.dZ!d/dZ"d0dZ# G d d      Z$ G d de$      Z% G d d e$      Z& G d! d"e$      Z' G d# d$      Z( G d% d&e$      Z)d1d'Z*d(Z+d)Z, e*e,      Z- e*d*       e*d+      fZ. G d, d-e$      Z/y)2    )annotationsN)	dataclass)Template)CodeType)quote   )iter_multi_items)
_urlencode   )ValidationError)BaseConverter)Mapc                  6    e Zd ZU ded<   ded<   ded<   ded<   y)		Weightingintnumber_static_weightszlist[tuple[int, int]]static_weightsnumber_argument_weightsz	list[int]argument_weightsN)__name__
__module____qualname____annotations__     T/var/www/html/eduruby.in/venv/lib/python3.12/site-packages/werkzeug/routing/rules.pyr   r      s    ))  r   r   c                  D    e Zd ZU dZded<   ded<   ded<   ded<   ded	<   y
)RuleParta$  A part of a rule.

    Rules can be represented by parts as delimited by `/` with
    instances of this class representing those parts. The *content* is
    either the raw content if *static* or a regex string to match
    against. The *weight* can be used to order parts when matching.

    strcontentboolfinalstaticsuffixedr   weightN)r   r   r   __doc__r   r   r   r   r   r      s#     LKLNr   r   a  
    (?:
        (?P<slash>/)                                 # a slash
      |
        (?P<static>[^</]+)                           # static rule data
      |
        (?:
          <
            (?:
              (?P<converter>[a-zA-Z_][a-zA-Z0-9_]*)   # converter name
              (?:\((?P<arguments>.*?)\))?             # converter arguments
              :                                       # variable delimiter
            )?
            (?P<variable>[a-zA-Z_][a-zA-Z0-9_]*)      # variable name
           >
        )
    )
    z	<([^>]+)>z
    ((?P<name>\w+)\s*=\s*)?
    (?P<value>
        True|False|
        \d+.\d+|
        \d+.|
        \d+|
        [\w\d_.]+|
        [urUR]?(?P<stringval>"[^"]*?"|'[^']*')
    )\s*,
    TF)NoneTrueFalsec                \    	 | j                  ||      S # t        $ r t        |       cY S w xY w)zgFind the *target* in *value* after *pos*.

    Returns the *value* length if *target* isn't found.
    )index
ValueErrorlen)valuetargetposs      r   _findr1   W   s1    
{{63'' 5zs    ++c                    | t         v r	t         |    S t        t        fD ]  }	  ||       c S  | d d | dd  k(  r| d   dv r| dd } t	        |       S # t        $ r Y <w xY w)Nr   r   z"')_PYTHON_CONSTANTSr   floatr,   r   )r.   converts     r   
_pythonizer7   b   s    !! '': 	5>!
 RayE"#J58u#4au:	  		s   A	AAc                2   | dz  } g }i }t         j                  |       D ]j  }|j                  d      }||j                  d      }t        |      }|j                  d      s|j	                  |       U|j                  d      }|||<   l t        |      |fS )N,	stringvalr.   name)_converter_args_refinditergroupr7   appendtuple)argstrargskwargsitemr.   r;   s         r   parse_converter_argsrE   o   s    
cMFDF"++F3 	!

;'=JJw'E5!zz&!KK::f%D F4L	! ;r   c                      e Zd ZdZddZy)RuleFactoryzAs soon as you have more complex URL setups it's a good idea to use rule
    factories to avoid repetitive tasks.  Some of them are builtin, others can
    be added by subclassing `RuleFactory` and overriding `get_rules`.
    c                    t               )zaSubclasses of `RuleFactory` have to override this method and return
        an iterable of rules.)NotImplementedErrorselfmaps     r   	get_ruleszRuleFactory.get_rules   s     "##r   N)rL   r   returnt.Iterable[Rule])r   r   r   r&   rM   r   r   r   rG   rG      s    
$r   rG   c                       e Zd ZdZddZddZy)	Subdomaina  All URLs provided by this factory have the subdomain set to a
    specific domain. For example if you want to use the subdomain for
    the current language this can be a good setup::

        url_map = Map([
            Rule('/', endpoint='#select_language'),
            Subdomain('<string(length=2):lang_code>', [
                Rule('/', endpoint='index'),
                Rule('/about', endpoint='about'),
                Rule('/help', endpoint='help')
            ])
        ])

    All the rules except for the ``'#select_language'`` endpoint will now
    listen on a two letter long subdomain that holds the language code
    for the current request.
    c                     || _         || _        y N)	subdomainrules)rK   rT   rU   s      r   __init__zSubdomain.__init__   s    "
r   c              #     K   | j                   D ]=  }|j                  |      D ]'  }|j                         }| j                  |_        | ) ? y wrS   )rU   rM   emptyrT   rK   rL   rulefactoryrules       r   rM   zSubdomain.get_rules   sN     :: 	K#--c2 zz|!%
	s   AAN)rT   r   rU   t.Iterable[RuleFactory]rN   r'   rL   r   rN   zt.Iterator[Rule]r   r   r   r&   rV   rM   r   r   r   rQ   rQ      s    $r   rQ   c                       e Zd ZdZddZddZy)Submounta}  Like `Subdomain` but prefixes the URL rule with a given string::

        url_map = Map([
            Rule('/', endpoint='index'),
            Submount('/blog', [
                Rule('/', endpoint='blog/index'),
                Rule('/entry/<entry_slug>', endpoint='blog/show')
            ])
        ])

    Now the rule ``'blog/show'`` matches ``/blog/entry/<entry_slug>``.
    c                >    |j                  d      | _        || _        y )N/)rstrippathrU   )rK   rd   rU   s      r   rV   zSubmount.__init__   s    KK$	
r   c              #     K   | j                   D ]J  }|j                  |      D ]4  }|j                         }| j                  |j                  z   |_        | 6 L y wrS   )rU   rM   rX   rd   r[   rY   s       r   rM   zSubmount.get_rules   sW     :: 	K#--c2 zz| II		1	
	   AAN)rd   r   rU   r\   rN   r'   r]   r^   r   r   r   r`   r`      s    r   r`   c                       e Zd ZdZddZddZy)EndpointPrefixa  Prefixes all endpoints (which must be strings for this factory) with
    another string. This can be useful for sub applications::

        url_map = Map([
            Rule('/', endpoint='index'),
            EndpointPrefix('blog/', [Submount('/blog', [
                Rule('/', endpoint='index'),
                Rule('/entry/<entry_slug>', endpoint='show')
            ])])
        ])
    c                     || _         || _        y rS   )prefixrU   )rK   rj   rU   s      r   rV   zEndpointPrefix.__init__   s    
r   c              #     K   | j                   D ]J  }|j                  |      D ]4  }|j                         }| j                  |j                  z   |_        | 6 L y wrS   )rU   rM   rX   rj   endpointrY   s       r   rM   zEndpointPrefix.get_rules   sW     :: 	K#--c2 zz| $dmm ;
	rf   N)rj   r   rU   r\   rN   r'   r]   r^   r   r   r   rh   rh      s    
r   rh   c                       e Zd ZdZddZddZy)RuleTemplateaX  Returns copies of the rules wrapped and expands string templates in
    the endpoint, rule, defaults or subdomain sections.

    Here a small example for such a rule template::

        from werkzeug.routing import Map, Rule, RuleTemplate

        resource = RuleTemplate([
            Rule('/$name/', endpoint='$name.list'),
            Rule('/$name/<int:id>', endpoint='$name.show')
        ])

        url_map = Map([resource(name='user'), resource(name='page')])

    When a rule template is called the keyword arguments are used to
    replace the placeholders in all the string parameters.
    c                $    t        |      | _        y rS   )listrU   )rK   rU   s     r   rV   zRuleTemplate.__init__   s    %[
r   c                @    t        | j                  t        |i |      S rS   )RuleTemplateFactoryrU   dict)rK   rB   rC   s      r   __call__zRuleTemplate.__call__   s    "4::tT/DV/DEEr   N)rU   rO   rN   r'   )rB   t.AnyrC   ru   rN   rr   )r   r   r   r&   rV   rt   r   r   r   rn   rn      s    $!Fr   rn   c                  ,    e Zd ZdZ	 	 	 	 	 	 ddZddZy)rr   zsA factory that fills in template variables into rules.  Used by
    `RuleTemplate` internally.

    :internal:
    c                     || _         || _        y rS   )rU   context)rK   rU   rx   s      r   rV   zRuleTemplateFactory.__init__  s     
r   c              #    K   | j                   D ]_  }|j                  |      D ]G  }d x}}|j                  r]i }|j                  j                         D ]>  \  }}t	        |t
              r$t        |      j                  | j                        }|||<   @ |j                  .t        |j                        j                  | j                        }|j                  }t	        |t
              r$t        |      j                  | j                        }t        t        |j                        j                  | j                        |||j                  |j                  ||j                         J b y wrS   )rU   rM   defaultsitems
isinstancer   r   
substituterx   rT   rl   Ruler[   methods
build_onlystrict_slashes)	rK   rL   rZ   r[   new_defaultsrT   keyr.   new_endpoints	            r   rM   zRuleTemplateFactory.get_rules  s2    :: 	K#--c2 +//y==#%L&*mm&9&9&; 2
U%eS1$,UO$>$>t||$LE,1S)2 >>- ( 8 C CDLL QI#}}lC0#+L#9#D#DT\\#RLTYY'224<<@ LLOO '' 	s   E1E3N)rU   r\   rx   zdict[str, t.Any]rN   r'   r]   r^   r   r   r   rr   rr      s)    ,7G	r   rr   c                (   t        j                  |       j                  d   }t        |t         j                        r|j
                  }t        j                  |      D ]1  }t        |t         j                        sd|j                   |_        3 |S )zEast parse and prefix names with `.` to avoid collision with user varsr   .)	astparsebodyr|   Exprr.   walkNameid)srctreenodes      r   _prefix_namesr   !  sn    99S>q!D$!zz $dCHH%$''mDG$ Kr   z#self._converters[{elem!r}].to_url()zpif kwargs:
    params = self._encode_query_vars(kwargs)
    q = "?" if params else ""
else:
    q = params = ""
qparamsc                  <   e Zd ZdZ	 	 	 	 	 	 	 	 	 	 	 d	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 ddZddZddZddZddZdddZ		 	 	 	 	 	 	 	 	 	 dd	Z
dd
Zd dZddZed!d       Z	 d"	 	 	 d#dZ	 d"	 	 	 	 	 d$dZd%dZ	 d&	 	 	 	 	 d'dZd(dZd)dZdZd*dZd*dZy)+r~   a  A Rule represents one URL pattern.  There are some options for `Rule`
    that change the way it behaves and are passed to the `Rule` constructor.
    Note that besides the rule-string all arguments *must* be keyword arguments
    in order to not break the application on Werkzeug upgrades.

    `string`
        Rule strings basically are just normal URL paths with placeholders in
        the format ``<converter(arguments):name>`` where the converter and the
        arguments are optional.  If no converter is defined the `default`
        converter is used which means `string` in the normal configuration.

        URL rules that end with a slash are branch URLs, others are leaves.
        If you have `strict_slashes` enabled (which is the default), all
        branch URLs that are matched without a trailing slash will trigger a
        redirect to the same URL with the missing slash appended.

        The converters are defined on the `Map`.

    `endpoint`
        The endpoint for this rule. This can be anything. A reference to a
        function, a string, a number etc.  The preferred way is using a string
        because the endpoint is used for URL generation.

    `defaults`
        An optional dict with defaults for other rules with the same endpoint.
        This is a bit tricky but useful if you want to have unique URLs::

            url_map = Map([
                Rule('/all/', defaults={'page': 1}, endpoint='all_entries'),
                Rule('/all/page/<int:page>', endpoint='all_entries')
            ])

        If a user now visits ``http://example.com/all/page/1`` they will be
        redirected to ``http://example.com/all/``.  If `redirect_defaults` is
        disabled on the `Map` instance this will only affect the URL
        generation.

    `subdomain`
        The subdomain rule string for this rule. If not specified the rule
        only matches for the `default_subdomain` of the map.  If the map is
        not bound to a subdomain this feature is disabled.

        Can be useful if you want to have user profiles on different subdomains
        and all subdomains are forwarded to your application::

            url_map = Map([
                Rule('/', subdomain='<username>', endpoint='user/homepage'),
                Rule('/stats', subdomain='<username>', endpoint='user/stats')
            ])

    `methods`
        A sequence of http methods this rule applies to.  If not specified, all
        methods are allowed. For example this can be useful if you want different
        endpoints for `POST` and `GET`.  If methods are defined and the path
        matches but the method matched against is not in this list or in the
        list of another rule for that path the error raised is of the type
        `MethodNotAllowed` rather than `NotFound`.  If `GET` is present in the
        list of methods and `HEAD` is not, `HEAD` is added automatically.

    `strict_slashes`
        Override the `Map` setting for `strict_slashes` only for this rule. If
        not specified the `Map` setting is used.

    `merge_slashes`
        Override :attr:`Map.merge_slashes` for this rule.

    `build_only`
        Set this to True and the rule will never match but will create a URL
        that can be build. This is useful if you have resources on a subdomain
        or folder that are not handled by the WSGI application (like static data)

    `redirect_to`
        If given this must be either a string or callable.  In case of a
        callable it's called with the url adapter that triggered the match and
        the values of the URL as keyword arguments and has to return the target
        for the redirect, otherwise it has to be a string with placeholders in
        rule syntax::

            def foo_with_slug(adapter, id):
                # ask the database for the slug for the old id.  this of
                # course has nothing to do with werkzeug.
                return f'foo/{Foo.get_slug_for_id(id)}'

            url_map = Map([
                Rule('/foo/<slug>', endpoint='foo'),
                Rule('/some/old/url/<slug>', redirect_to='foo/<slug>'),
                Rule('/other/old/url/<int:id>', redirect_to=foo_with_slug)
            ])

        When the rule is matched the routing system will raise a
        `RequestRedirect` exception with the target for the redirect.

        Keep in mind that the URL will be joined against the URL root of the
        script so don't use a leading slash on the target URL unless you
        really mean root of that domain.

    `alias`
        If enabled this rule serves as an alias for another rule with the same
        endpoint and arguments.

    `host`
        If provided and the URL map has host matching enabled this can be
        used to provide a match rule for the whole host.  This also means
        that the subdomain feature is disabled.

    `websocket`
        If ``True``, this rule is only matches for WebSocket (``ws://``,
        ``wss://``) requests. By default, rules will only match for HTTP
        requests.

    .. versionchanged:: 2.1
        Percent-encoded newlines (``%0a``), which are decoded by WSGI
        servers, are considered when routing instead of terminating the
        match early.

    .. versionadded:: 1.0
        Added ``websocket``.

    .. versionadded:: 1.0
        Added ``merge_slashes``.

    .. versionadded:: 0.7
        Added ``alias`` and ``host``.

    .. versionchanged:: 0.6.1
       ``HEAD`` is added to ``methods`` if ``GET`` is present.
    Nc                   |j                  d      st        d| d      || _        |j                  d       | _        |j                  d      | _        d | _        || _        || _        || _	        || _
        || _        || _        |
| _        || _        |et        |t               rt#        d      |D ch c]  }|j%                          }}d|vrd|v r|j'                  d       |r|h dz
  rt        d      || _        || _        |	| _        |rt/        t        t         |            | _        nt/               | _        i | _        g | _        g | _        y c c}w )	Nrb   z
URL rule 'z' must start with a slash.z&'methods' should be a list of strings.HEADGET>   r   r   OPTIONSzBWebSocket rules can only use 'GET', 'HEAD', and 'OPTIONS' methods.)
startswithr,   r[   endswithis_leaf	is_branchrL   r   merge_slashesrT   hostrz   r   alias	websocketr|   r   	TypeErrorupperaddr   rl   redirect_toset	arguments_converters_trace_parts)rK   stringrz   rT   r   r   rl   r   r   r   r   r   r   xs                 r   rV   zRule.__init__  sO      %z&1KLMM	!??3//-,*"	 $
"'3' HII*12Qqwwy2G2W$')9F#W'AA X  %& S(!34DN UDN57.0&(+ 3s   5Ec                V     t        |       | j                  fi | j                         S )z
        Return an unbound copy of this rule.

        This can be useful if want to reuse an already bound URL for another
        map.  See ``get_empty_kwargs`` to override what keyword arguments are
        provided to the new copy.
        )typer[   get_empty_kwargsrK   s    r   rX   z
Rule.empty  s'     tDz$))?t'<'<'>??r   c                   d}| j                   rt        | j                         }t        || j                  | j                  | j                  | j
                  | j                  | j                  | j                  | j                  	      S )a  
        Provides kwargs for instantiating empty copy with empty()

        Use this method to provide custom keyword arguments to the subclass of
        ``Rule`` when calling ``some_rule.empty()``.  Helpful when the subclass
        has custom keyword arguments that are needed at instantiation.

        Must return a ``dict`` that will be provided as kwargs to the new
        instance of ``Rule``, following the initial ``self.rule`` value which
        is always provided as the first, required positional argument.
        N)	rz   rT   r   r   rl   r   r   r   r   )
rz   rs   rT   r   r   rl   r   r   r   r   )rK   rz   s     r   r   zRule.get_empty_kwargs  sj     ==DMM*HnnLL]]..((**

 
	
r   c              #     K   |  y wrS   r   rJ   s     r   rM   zRule.get_rules  s     
s   c                >    | j                  | j                  d       y)zqRebinds and refreshes the URL.  Call this if you modified the
        rule in place.

        :internal:
        T)rebindN)bindrL   r   s    r   refreshzRule.refresh  s     			$((4	(r   c                2   | j                   |st        d| d| j                         || _         | j                  |j                  | _        | j                  |j                  | _        | j                  |j
                  | _        | j                          y)zBind the url to a map and create a regular expression based on
        the information from the rule itself and the defaults from the map.

        :internal:
        Nz	url rule z already bound to map )rL   RuntimeErrorr   r   rT   default_subdomaincompile)rK   rL   r   s      r   r   z	Rule.bind$  s     884(2HUVV&"%"4"4D%!$!2!2D>>! 22DNr   c                    || j                   j                  vrt        d|d       | j                   j                  |   | j                   g|i |S )zWLooks up the converter for the given parameter.

        .. versionadded:: 0.9
        zthe converter z does not exist)rL   
convertersLookupError)rK   variable_nameconverter_namerB   rC   s        r   get_converterzRule.get_converter5  sU     !4!44~.@PQQ2txx"">2488MdMfMMr   c                    t        |      }| j                  j                  r!t        || j                  j                        }t        |      S )N)r   )r	   rL   sort_parameterssortedsort_keyr
   )rK   
query_varsr{   s      r   _encode_query_varszRule._encode_query_varsD  s:    -=j-I88##5dhh&7&78E%  r   c              #  F  K   d}d}g }g }d}d}d}|t        |      k  rt        j                  ||      }	|	t        d|      |	j	                         }
|
d   k|j                  t        |      t        |
d          f       | j                  j                  d|
d   f       ||r|
d   nt        j                  |
d         z  }|
d   |rt        j                  |      }d}t        |
d   xs d      \  }}| j                  |
d   |
d	   xs d
||      }|| j                  |
d   <   | j                  j                  |
d          |j                  sd}|d| d|j                   dz  }|dz  }|j                  |j                          | j                  j                  d|
d   f       |
d   j| j                  j                  d       |r|dz  }nG|s|dz  }t#        t        |       |t        |       |      }t%        |||d|       d}d}g }g }d}d}|	j'                         }|t        |      k  rd}|r|d   dk(  r
d}|d d dz   }|s|dz  }t#        t        |       |t        |       |      }t%        |||||       |rt%        dddd|       y y w)N TFr   zmalformed url rule: r#   variabler   	converterdefaultz(?P<__werkzeug_>)r   slash)Frb   rb   z\Zr    r"   r#   r$   r%   r3   z
(?<!/)(/?))r-   _part_rematchr,   	groupdictr?   r   reescaperE   r   r   r   r   part_isolatingregexr%   r   r   end)rK   r[   r    r#   r   r   r"   convertor_numberr0   r   datac_argsc_kwargsconvobjr%   r$   s                   r   _parse_rulezRule._parse_ruleL  s    02CIoNN4-E} #7x!@AA??$DH~)%%s>':Sh=P<P&QR""E4>#:;V4>4>9RRJ+ ii0G#7[8I8OR#P ,,$d;&7&D9fh 6=  j!12""4
#34-- E_-=,>aaPP A%  ''7""D$z*:#;<G}(""<0sNG!5(&^,,&-..(	F # '#%!&%  !G!F')$%'N!E'($))+Cq CIot WR[C' Hcrl\1GuG  !""	
 
 	
 %uV  s   H6J!:A'J!c                   | j                   J d       | j                   j                  r| j                  xs d}n| j                  xs d}g | _        g | _        i | _        |dk(  r#t        ddddt        dg dg             g| _        n*| j                  j                  | j                  |             | j
                  j                  d       | j                  }| j                  r!t        j                  d	d
| j                        }| j                  j                  | j                  |             |  | j!                  d      j#                  | d      | _        |  | j!                  d      j#                  | d      | _        y)z.Compiles the regular expression and stores it.Nzrule not boundr   FTr   r   )F|z/{2,}?rb   )rL   host_matchingr   rT   r   r   r   r   r   extendr   r?   r[   r   r   sub_compile_builder__get___build_build_unknown)rK   domain_ruler[   s      r   r   zRule.compile  sD   xx#5%55#88!!))/rK...BK""$QAr2DK KKt//<=<(yy66(C3D4++D12++E2::4F"33D9AA$Mr   c                .    i }i }t        | ||       ||   S rS   )exec)coder;   globslocss       r   _get_func_codezRule._get_func_code  s"    "$!#T5$Dzr   c           
        | j                   xs i }g }g }|}| j                  D ]  \  }}|dk(  r||u r|}|r9||v r5| j                  |   j                  ||         }|j	                  d|f       M|s|j	                  dt        |d      f       n|j	                  d|f        dddfd} ||      }	 ||      }
|sg }nt        g}|
j                  t               dd}|j	                  t        j                  t        j                   ||	       ||
      gt        j                                            ||z   D cg c]  \  }}|r||vr| }}}|D cg c]  }t        |       }}t        d	      }d
| j                  d|_        |j"                  j"                  j	                  t        j$                  dd              ||z   D ];  }|j"                  j"                  j	                  t        j$                  |d              = t        j$                  dd       |j"                  _        |D ]:  }|j"                  j                   j	                  t        j(                  d             < ||_        t        j,                  d      }|g|_        t        j.                  |      D ]k  }d|j0                  v rd|_        d|j0                  v r|j2                  |_        d|j0                  v rd|_        d|j0                  v s[|j6                  |_        m t;        |dd      }| j=                  ||j                         S c c}}w c c}w )Nr   Fz!$&'()*+,/:;=@)safeTc                    t        t        j                  |             }t        j                  t        |       t        j                               g|_        |S )N)elem)r   _CALL_CONVERTER_CODE_FMTformatr   r   r   LoadrB   )r   rets     r   _convertz'Rule._compile_builder.<locals>._convert  s?     8 ? ?T ? JKCTCHHJ78CHJr   c                   | D cg c]$  \  }}|r |      nt        j                  |      & }}}|xs t        j                  d      g}|d   g}|dd  D ]}  }t        |t         j                        rPt        |d   t         j                        r3t        j                  |d   j                  |j                  z         |d<   m|j	                  |        |S c c}}w )Nr   r   r   r3   )r   Constantr|   r.   r?   )ops
is_dynamicr   partsr   pr   s         r   r   z%Rule._compile_builder.<locals>._parts  s     ),$J #-#,,t2DDE  /cll2./E8*C12Y "a.:c"gs||3T!ll3r7==177+BCCGJJqM	"
 Js   )Cc                R    t        |       dk(  r| d   S t        j                  |       S )Nr   r   )r-   r   	JoinedStr)r   s    r   _joinz$Rule._compile_builder.<locals>._join  s%    5zQQx==''r   zdef _(): passz	<builder:r   z.selfz.kwargsr   linenor   
end_lineno
col_offsetr   end_col_offsetz<werkzeug routing>r   )r   r   rN   ast.stmt)r   zlist[tuple[bool, str]]rN   list[ast.AST])r   r  rN   zast.AST)rz   r   r   to_urlr?   r   _IF_KWARGS_URL_ENCODE_ASTr   _URL_ENCODE_AST_NAMESr   ReturnTupler   r   r   r[   r;   rB   argkwargr   r   r   r   _attributesr   r   r  r  r   r   )rK   append_unknownrz   dom_opsurl_opsoplr   r   r   	dom_parts	url_partsr   r   r   pargskkargsfunc_astr
  _moduler   r   r   s                          @r   r   zRule._compile_builder  s    ==&B*,*, $ 	)Js{sg~ dh.''-44Xd^D

E4=)

E54D#EFG

D$<(	) 	
	 7O	7O	D-.D23	(
 	JJsyy%	"2E)4D!EsxxzRS	
 %,g$5
 
Dd(2 
 

 "**AQ**$1/$B#DII=2!!#'''4"895= 	:CMM%%cggc4&89	:!ggi6 	<AMM""))#,,r*:;	< 2j
 HHV$ 	6D4+++t///"&++t///"#4#3#33&*oo#	6 v3V<""477I

 +s   MM	c                n    	 |r | j                   di |S  | j                  di |S # t        $ r Y yw xY w)zAssembles the relative url for that rule and the subdomain.
        If building doesn't work for some reasons `None` is returned.

        :internal:
        Nr   )r   r   r   )rK   valuesr  s      r   buildz
Rule.build5  sF    	*t**4V44"t{{,V,, 		s   ( ( 	44c                    t        | j                   xrI | j                  xr; | j                  |j                  k(  xr  | |k7  xr | j                  |j                  k(        S )zNCheck if this rule has defaults for a given rule.

        :internal:
        )r!   r   rz   rl   r   )rK   r[   s     r   provides_defaults_forzRule.provides_defaults_forE  sa    
  11.1 1 $..0
 	
r   c                    || j                   || j                   vry| j                  xs d}| j                  D ]  }||vs||vs y |r'|j                         D ]  \  }}||v s|||   k7  s y y)z\Check if the dict of values has enough data for url generation.

        :internal:
        Fr   T)r   rz   r   r{   )rK   r  methodrz   r   r.   s         r   suitable_forzRule.suitable_forR  s     (dll*==&B >> 	C("s&'8	 &nn. !
U&=UfSk%9 ! r   c                    | j                   rdndt        | j                         t        | j                  xs d       fS )z?The build compare key for sorting.

        :internal:
        r   r   r   )r   r-   r   rz   r   s    r   build_compare_keyzRule.build_compare_keys  s7    
 ZZQT^^)<(<s4==CVTV?W>WXXr   c                b    t        |t        |             xr | j                  |j                  k(  S rS   )r|   r   r   )rK   others     r   __eq__zRule.__eq__z  s%    %d,L1LLr   c                    | j                   S rS   )r[   r   s    r   __str__zRule.__str__  s    yyr   c                   | j                   dt        |       j                   dS g }| j                  D ].  \  }}|r|j	                  d| d       |j	                  |       0 dj                  |      j                  d      }| j                  ddj                  | j                         dnd}dt        |       j                   d	|| d
| j                   dS )N<z (unbound)>r   r   r   z (z, r    z -> )	rL   r   r   r   r?   joinlstripr   rl   )rK   r   r   r   r   s        r   __repr__zRule.__repr__  s    88tDz**+;77 $ 	#Jqa[)T"		#
 %%c*59\\5MBtyy./q1SU4:&&'q	'$t}}oQOOr   )NNNFNNNNFNF)r   r   rz   zt.Mapping[str, t.Any] | NonerT   
str | Noner   zt.Iterable[str] | Noner   r!   rl   r.  r   bool | Noner   r/  r   z!str | t.Callable[..., str] | Noner   r!   r   r.  r   r!   rN   r'   )rN   r~   )rN   t.Mapping[str, t.Any]r]   )rN   r'   )F)rL   r   r   r!   rN   r'   )
r   r   r   r   rB   zt.TuplerC   r0  rN   r   )r   r0  rN   r   )r[   r   rN   zt.Iterable[RulePart])r   r   r;   r   rN    t.Callable[..., tuple[str, str]])T)r  r!   rN   r1  )r  r0  r  r!   rN   ztuple[str, str] | None)r[   r~   rN   r!   rS   )r  r0  r  r.  rN   r!   )rN   ztuple[int, int, int])r$  objectrN   r!   )rN   r   )r   r   r   r&   rV   rX   r   rM   r   r   r   r   r   r   staticmethodr   r   r  r  r   r"  r%  __hash__r'  r-  r   r   r   r~   r~   8  s   ~F 26 $*. #&*%)9=9)9) /9) 	9)
 (9) 9) 9) $9) #9) 79) 9) 9) 9) 
9)v@
6)"NN N 	N
 &N 
N![z ND   &*a8"a8	)a8H EI+=A	 
 CG+5?	BYM HPr   r~   )r.   r   r/   r   r0   r   rN   r   )r.   r   rN   zNone | bool | int | float | str)rA   r   rN   z tuple[t.Tuple, dict[str, t.Any]])r   r   rN   r  )0
__future__r   r   r   typingtdataclassesr   r   r   typesr   urllib.parser   datastructuresr	   urlsr
   r   r   TYPE_CHECKINGr   rL   r   
NamedTupler   r   r   VERBOSEr   _simple_rule_rer<   r4   r1   r7   rE   rG   rQ   r`   rh   rn   rr   r   r   _IF_KWARGS_URL_ENCODE_CODEr  r  r~   r   r   r   <module>rB     s[   " 
 	  !    -  '??)      " 2::$ JJ', "**\*RZZ
 JJ   "4%@ 
&	$ 	$ >{ 4[ 2F F4$+ $N A   **DE &s+]8-DE U	P; U	Pr   