hyb
2026-01-30 44480e71b27aa9d4cb8441f50c873f1b110e9691
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
Ë
ñúhØ7ãóÞ—ddlmZddlZddlmZddlmZddlmZgd¢Z    dZ
ejd    «Z ejd
«Z ejd ejejz«Zd Zd Zdj'ee¬«ZeedœZgd¢ZdZddj1eDcgc]}|ez‘Œ    c}«zdzZdezdzZdezdzezdzZdZejd«Zejdezdz«Zejdezdz«Zejdezdz«Z ejdeddzdz«Z!ejdezd z«Z"d!e›de›de›d"Z#eje#ejejz«Z$e%d#«Z&e%d$«Z'e&e'zd%hzZ(e(d&d'hzZ)e)d(hzxZ*Z+Gd)„d*ed*e    ««Z,d+„Z-d3d,„Z.d-„Z/d.„Z0d/„Z1d0„Z2d1„Z3d2„Z4ycc}w)4é)Úabsolute_importN)Ú
namedtupleé)ÚLocationParseError)Úsix©ÚschemeÚauthÚhostÚportÚpathÚqueryÚfragment)ÚhttpÚhttpsNz%[a-fA-F0-9]{2}z^(?:[a-zA-Z][a-zA-Z0-9+-]*:|/)zS^(?:([a-zA-Z][a-zA-Z0-9+.-]*):)?(?://([^\\/?#]*))?([^?#]*)(?:\?([^#]*))?(?:#(.*))?$z(?:[0-9]{1,3}\.){3}[0-9]{1,3}z[0-9A-Fa-f]{1,4}z(?:{hex}:{hex}|{ipv4}))ÚhexÚipv4)rÚls32)    z(?:%(hex)s:){6}%(ls32)sz::(?:%(hex)s:){5}%(ls32)sz%(?:%(hex)s)?::(?:%(hex)s:){4}%(ls32)sz2(?:(?:%(hex)s:)?%(hex)s)?::(?:%(hex)s:){3}%(ls32)sz6(?:(?:%(hex)s:){0,2}%(hex)s)?::(?:%(hex)s:){2}%(ls32)sz/(?:(?:%(hex)s:){0,3}%(hex)s)?::%(hex)s:%(ls32)sz'(?:(?:%(hex)s:){0,4}%(hex)s)?::%(ls32)sz&(?:(?:%(hex)s:){0,5}%(hex)s)?::%(hex)sz(?:(?:%(hex)s:){0,6}%(hex)s)?::zCABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789._\-~z(?:ú|ú)z (?:%25|%)(?:[z]|%[a-fA-F0-9]{2})+z\[z)?\]z!(?:[^\[\]%:/?#]|%[a-fA-F0-9]{2})*z!^(/[^?#]*)(?:\?([^#]*))?(?:#.*)?$ú^ú$éþÿÿÿú(z)\]$z^(z)(?::0*?(|0|[1-9][0-9]{0,4}))?$zBABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789._-~z !$&'()*+,;=ú:ú@ú/ú?có|‡—eZdZdZdZ                            d    ˆfd„    Zed„«Zed„«Zed„«Z    ed„«Z
d„Z ˆxZ S)
ÚUrlzÍ
    Data structure for representing an HTTP URL. Used as a return value for
    :func:`parse_url`. Both the scheme and host are normalized as they are
    both case-insensitive according to RFC 3986.
    ©c
󌕗|r|jd«sd|z}||j«}tt|||||||||«S)Nr)Ú
startswithÚlowerÚsuperr Ú__new__)    Úclsr    r
r r r rrÚ    __class__s            €úOH:\Change_password\venv_build\Lib\site-packages\pip/_vendor/urllib3/util/url.pyr&z Url.__new__[sRø€ñ ˜Ÿ™¨Ô,ؘ‘:ˆDØ Ð Ø—\‘\“^ˆFÜ”S˜#Ñ&Ø ˜˜t T¨4°¸ó
ð    
ócó—|jS)z@For backwards-compatibility with urlparse. We're nice like that.)r ©Úselfs r)Úhostnamez Url.hostnamems€ðy‰yÐr*cób—|jxsd}|j|d|jzz }|S)z)Absolute path including the query string.rr)r r)r-Úuris  r)Ú request_urizUrl.request_urirs4€ði‰iÒ˜3ˆà :‰:Ð !Ø 3˜Ÿ™Ñ#Ñ #ˆCàˆ
r*cóh—|jrd|j|jfzS|jS)z(Network location including host and portz%s:%d)r r r,s r)Únetlocz
Url.netloc|s-€ð 9Š9ؘdŸi™i¨¯©Ð3Ñ3Ð 3؏y‰yÐr*có°—|\}}}}}}}d}|||dzz }|||dzz }|||z }||dt|«zz }|||z }||d|zz }||d|zz }|S)aˆ
        Convert self into a url
 
        This function should more or less round-trip with :func:`.parse_url`. The
        returned url may not be exactly the same as the url inputted to
        :func:`.parse_url`, but it should be equivalent by the RFC (e.g., urls
        with a blank port will have : removed).
 
        Example: ::
 
            >>> U = parse_url('http://google.com/mail/')
            >>> U.url
            'http://google.com/mail/'
            >>> Url('http', 'username:password', 'host.com', 80,
            ... '/path', 'query', 'fragment').url
            'http://username:password@host.com:80/path?query#fragment'
        Úz://rrrú#)Ústr)    r-r    r
r r r rrÚurls             r)r8zUrl.urlƒs«€ð&;?Ñ7ˆd˜D $¨¨x؈ð Ð Ø 6˜F‘?Ñ "ˆCØ Ð Ø 4˜$‘;Ñ ˆCØ Ð Ø 4‰KˆCØ Ð Ø 4œ#˜d›)Ñ#Ñ #ˆCØ Ð Ø 4‰KˆCØ Ð Ø 4˜%‘<Ñ ˆCØ Ð Ø 4˜(‘?Ñ "ˆCàˆ
r*có—|jS©N)r8r,s r)Ú__str__z Url.__str__«s €Øx‰xˆr*)NNNNNNN) Ú__name__Ú
__module__Ú __qualname__Ú__doc__Ú    __slots__r&Úpropertyr.r1r3r8r;Ú __classcell__)r(s@r)r r Rsø„ñð €IðØ Ø Ø Ø ØØõ
ð$ñóððñóððñóðð ñ%óð%öNr*r có’—d}d}|D]%}|j|«}|dkrŒ|||ksŒ"|}|}Œ'||dkr|ddfS|d|||dzd|fS)aì
    .. deprecated:: 1.25
 
    Given a string and an iterable of delimiters, split on the first found
    delimiter. Return two split parts and the matched delimiter.
 
    If not found, then the first part is the full input string.
 
    Example::
 
        >>> split_first('foo/bar?baz', '?/=')
        ('foo', 'bar?baz', '/')
        >>> split_first('foo/bar?baz', '123')
        ('foo/bar?baz', '', None)
 
    Scales linearly with number of delims. Not ideal for large number of delims.
    Nrr5é)Úfind)ÚsÚdelimsÚmin_idxÚ    min_delimÚdÚidxs      r)Ú split_firstrL¯s€€ð$€GØ€IØ òˆØf‰fQ‹iˆØ Š7Ø à ˆ?˜c G›m؈G؉Iðð€˜' Aš+ؐ"dˆ{Ðà ˆXˆgˆ;˜˜' A™+˜-Ð(¨)Ð 3Ð3r*có"—|€|Stj|«}tjd„|«\}}|j    dd«}||j d«k(}t «}tdt|««D]„}|||dz}t|«}    |r|dk(s|    dkr|j«|vr||z }Œ:|jdt|    «d    dj    «jd    «j«z«Œ†|j|«S)
zfPercent-encodes a URI component without reapplying
    onto an already percent-encoded component.
    Ncó@—|jd«j«S)Nr)ÚgroupÚupper)Úmatchs r)ú<lambda>z'_encode_invalid_chars.<locals>.<lambda>ßs€e—k‘k !“n×*Ñ*Ó,€r*úutf-8Ú surrogatepassó%rrDé€r)rÚ ensure_textÚ
PERCENT_REÚsubnÚencodeÚcountÚ    bytearrayÚrangeÚlenÚordÚdecodeÚextendrÚzfillrP)
Ú    componentÚ allowed_charsÚencodingÚpercent_encodingsÚ    uri_bytesÚis_percent_encodedÚencoded_componentÚiÚbyteÚbyte_ords
          r)Ú_encode_invalid_charsrmÒs€ðÐØÐä—‘     Ó*€Iô
$.§?¡?Ù,¨ió$Ñ €IРð× Ñ  ¨/Ó:€IØ*¨i¯o©o¸dÓ.CÑCÐÜ!› Ðä 1”c˜)“nÓ %ò    Wˆà˜˜Q ™UÐ#ˆÜt“9ˆÙ  4¨4¢<Ø sŠN˜tŸ{™{›}° Ñ=à  Ñ %Ð Ø Ø× Ñ  ¬¨X«°q°rÐ):×)AÑ)AÓ)C×)IÑ)IÈ!Ó)L×)RÑ)RÓ)TÑ!UÕVð    Wð × #Ñ # HÓ -Ð-r*cóP—|jd«}g}|D]2}|dk(rŒ    |dk7r|j|«Œ |sŒ#|j«Œ4|jd«r|r|dr|j    dd«|j d«r|jd«dj |«S)Nrú.z..rr5)z/.z/..)ÚsplitÚappendÚpopr#ÚinsertÚendswithÚjoin)r ÚsegmentsÚoutputÚsegments    r)Ú_remove_path_dot_segmentsryôs›€àz‰z˜#‹€HØ €Fàò
ˆà cŠ>Ø à ˜Š_Ø M‰M˜'Õ "òØ J‰JLð
𠇁sÔ¡V¨v°aªy؏ ‰ a˜Ôð ‡}}]Ô#؏ ‰ bÔà 8‰8FÓ Ðr*c
ó’—|r>t|tj«rtj|«}|tvrt
j |«}|rtj|«}|ri|jd«\}}|||}|jd«r |dk7r|dd}n|dd}dt|t«z}|d|j«|z||dzS|j«Stj |«sJtjdj|j!d«Dcgc] }t#|«‘Œc}««S|Scc}w)NrDz%25éú%ó.ro)Ú
isinstancerÚ binary_typeÚ
ensure_strÚNORMALIZABLE_SCHEMESÚ IPV6_ADDRZ_RErQÚ
ZONE_ID_REÚsearchÚspanr#rmÚUNRESERVED_CHARSr$ÚIPV4_RErurpÚ _idna_encode)r r    Úis_ipv6rQÚstartÚendÚzone_idÚlabels        r)Ú_normalize_hostrŽs+€Ú Ü dœCŸO™OÔ ,Ü—>‘> $Ó'ˆDà Ô)Ò )Ü#×)Ñ)¨$Ó/ˆGÙô#×)Ñ)¨$Ó/ÙØ!&§¡¨A£‘JE˜3Ø" 5¨˜oGà×)Ñ)¨%Ô0°WÀÒ5EØ")¨!¨" +™à")¨!¨" +˜Ø!Ô$9¸'ÔCSÓ$TÑTGØ  ˜<×-Ñ-Ó/°'Ñ9¸DÀÀ¸JÑFÐFàŸ:™:›<Ð'Ü—]‘] 4Ô(Ü—~‘~Ø—I‘IÀÇ
Á
È3ÃÖP°uœ|¨EÕ2ÒPÓQóðð €KùòQsÄ%E có†—|r<td„|D««r*    ddlm}    j|j«dd¬«S|j«jd«S#t$r"t    j
t d«d«YŒlwxYw#j$r%t    j
t d|z«d«YŒ€wxYw)    Nc3ó8K—|]}t|«dk\–—Œy­w)rVN)r_)Ú.0Úxs  r)ú    <genexpr>z_idna_encode.<locals>.<genexpr>2sèø€Ò0 a”C˜“F˜c•MÑ0ùs‚r)Úidnaz-Unable to parse URL without the 'idna' moduleT)ÚstrictÚ
std3_rulesz#Name '%s' is not a valid IDNA labelÚascii)
ÚanyÚ pip._vendorr”Ú ImportErrorrÚ
raise_fromrrZr$Ú    IDNAError)Únamer”s  r)rˆrˆ1s­€Ù ”Ñ0¨4Ô0Ô0ð    Ý (ð     Ø—;‘;˜tŸz™z›|°DÀT;ÓJÐ Jð
:‰:‹<× Ñ ˜wÓ 'Ð'øôò    Ü N‰NÜ"Ð#RÓSØö ð    ûð~‰~ò    Ü N‰NÜ"Ð#IÈDÑ#PÓQÐSWö ð    ús"–A!B Á(B    ÂB     1CÂ?Ccó¦—tj|«j«\}}t|t«}t|t
«}||d|zz }|S)zHPercent-encodes a request target so that there are no invalid charactersr)Ú    TARGET_RErQÚgroupsrmÚ
PATH_CHARSÚ QUERY_CHARS)Útargetr rs   r)Ú_encode_targetr¤CsN€ä—/‘/ &Ó)×0Ñ0Ó2K€Dˆ%Ü " 4¬Ó 4€FÜ ! %¬Ó 5€EØ ÐØ#˜‘+ÑˆØ €Mr*c ó<‡—|s
t«S|}tj|«sd|z}    tj    |«j «\}}}}}|duxs|j «tv}|r|j «}|r]|jd«\}}    }
|xsd}tj    |
«j «\} } |r|rt|t«}| dk(r    d} nd\}} } | -t| «} d| cxkrdkst|«‚t|«‚t| |«} |r|rt|«}t|t «}|r|rt|t"«}|r|rt|t$«}|s    |€|d}nd}t/|t*j0«rt*j2Šnt*j4Šˆfd„} t| |«| |«| | «| | |«| |«| |«¬    «S#t&t(f$r"t+j,t|«d«cYSwxYw)
a
    Given a url, return a parsed :class:`.Url` namedtuple. Best-effort is
    performed to parse incomplete urls. Fields not provided will be None.
    This parser is RFC 3986 and RFC 6874 compliant.
 
    The parser logic and helper functions are based heavily on
    work done in the ``rfc3986`` module.
 
    :param str url: URL to parse into a :class:`.Url` namedtuple.
 
    Partly backwards-compatible with :mod:`urlparse`.
 
    Example::
 
        >>> parse_url('http://google.com/mail/')
        Url(scheme='http', host='google.com', port=None, path='/mail/', ...)
        >>> parse_url('google.com:80')
        Url(scheme=None, host='google.com', port=80, path=None, ...)
        >>> parse_url('/foo?bar')
        Url(scheme=None, host=None, port=None, path='/foo', query='bar', ...)
    z//Nrr5)NNNriÿÿcó•—|€|S‰|«Sr:r!)r’Ú ensure_funcs €r)Ú ensure_typezparse_url.<locals>.ensure_type sø€ØIˆqÐ1¡;¨q£>Ð1r*r)r Ú    SCHEME_REr„ÚURI_RErQr r$rÚ
rpartitionÚ _HOST_PORT_RErmÚUSERINFO_CHARSÚintrrŽryr¡r¢ÚFRAGMENT_CHARSÚ
ValueErrorÚAttributeErrorrr›r~Ú    text_typerWr€)r8Ú
source_urlr    Ú    authorityr rrÚ normalize_urir
Ú_Ú    host_portr r r¨r§s              @r)Ú    parse_urlr¸Msø€ñ, ä‹uˆ à€JÜ × Ñ ˜CÔ  ØS‰jˆð"DÜ39·<±<ÀÓ3D×3KÑ3KÓ3MÑ0ˆ    ˜4 ¨Ø $˜ÒP¨&¯,©,«.Ô<PÐ*Pˆ á Ø—\‘\“^ˆFá Ø!*×!5Ñ!5°cÓ!:Ñ ˆD!YØ’<˜4ˆDÜ&×,Ñ,¨YÓ7×>Ñ>Ó@‰JˆD$Ù™ Ü,¨T´>ÓBØrŠzØ‘à/Ñ ˆD$˜à Рܐt“9ˆDؘÔ& Ò&Ü(¨Ó-Ð-ð'Ü(¨Ó-Ð-ä˜t VÓ,ˆá ™TÜ,¨TÓ2ˆDÜ(¨¬zÓ:ˆDÙ ™UÜ)¨%´Ó=ˆEÙ ™XÜ,¨X´~ÓFˆHñ Ø Ð  Р4؉DàˆDô#”s—}‘}Ô%Ü—o‘o‰ ä—n‘nˆ ô2ô Ù˜6Ó"Ù ˜Ó Ù ˜Ó Ø Ù ˜Ó Ù˜%Ó Ù˜XÓ&ô ðøô/ œÐ 'òD܏~‰~Ô0°Ó<¸dÓCÒCðDús«D>G*Ç*.HÈHcóf—t|«}|jxsd|j|jfS)z4
    Deprecated. Use :func:`parse_url` instead.
    r)r¸r    r.r )r8Úps  r)Úget_hostr»®s+€ô    #‹€AØ 8‰8Ò v˜qŸz™z¨1¯6©6Ð 1Ð1r*)rS)5Ú
__future__rÚreÚ collectionsrÚ
exceptionsrÚpackagesrÚ    url_attrsrÚcompilerXr©ÚUNICODEÚDOTALLrªÚIPV4_PATÚHEX_PATÚformatÚLS32_PATÚ_subsÚ _variationsÚUNRESERVED_PATruÚIPV6_PATÚ ZONE_ID_PATÚIPV6_ADDRZ_PATÚ REG_NAME_PATrŸr‡ÚIPV6_REr‚ÚBRACELESS_IPV6_ADDRZ_RErƒÚ_HOST_PORT_PATr¬Úsetr†ÚSUB_DELIM_CHARSr­r¡r¢r¯r rLrmryrŽrˆr¤r¸r»)r’s0r)ú<module>rÕsYðÝ&ã    Ý"å+Ýâ K€    ð/ÐðˆRZ‰ZÐ*Ó +€
Ø ˆBJ‰JÐ8Ó 9€    Ø    ˆ‰ðð
‡JJ—‘Ñó 
€ð ,€Ø
€Ø #× *Ñ *¨w¸XÐ *Ó F€Ø Ñ*€ò€ ð*X€Ø 3—8‘8° Ö<¨1˜Q ›YÒ<Ó=Ñ =ÀÑ C€Ø Ñ.Ð1FÑF€ ؘÑ! FÑ*¨[Ñ8¸7ÑB€Ø3€ Ø ˆBJ‰JÐ;Ó <€    à
ˆ"*‰*S˜8‘^ cÑ)Ó
*ۯ
ˆ"*‰*S˜8‘^ cÑ)Ó
*€Ø—
‘
˜3 Ñ/°#Ñ5Ó6€ Ø$˜"Ÿ*™* S¨>¸!¸BÐ+?Ñ%?À#Ñ%EÓFÐØ ˆRZ‰Z˜˜kÑ)¨GÑ3Ó 4
òÚ Úð€ð
—
‘
˜>¨2¯:©:¸¿    ¹    Ñ+AÓB€ áØHóÐñmÓ$€Ø! OÑ3°s°eÑ;€Ø ˜s C˜jÑ (€
Ø)¨S¨EÑ1Ð1€ ˆnôZ‰*U˜IÓ
&ôZòz 4óF.òDò<ò>(ò$ò^óB2ùòq =sÂ# G*