Spade
Mini Shell
| Directory:~$ /lib/python2.7/site-packages/future/backports/urllib/ |
| [Home] [System Details] [Kill Me] |
�
,�]c@`s�dZddlmZmZmZddlmZmZmZm Z m
Z
mZddlm
Z
ddlZddlZddlZdddd d
ddd
dddddddgZdddddddddddd
d!d"d#d$d%gZddddd&ddddddd'dd
d!d(d"d$d%d#d)d*d+gZdd,dddddd
d!d-d.dd"d#d/gZdd,d0d1d&ddd'd-d.g
Zdddddddd
d!d-d.d"gZdd,ddd1ddddd'ddd"g
Zd2Zd3ZiZd4�Zd5Zd6Zd7�Zeed8�Zeed9�Z
d:�Z!d;e"fd<��YZ#d=e"fd>��YZ$d?e"fd@��YZ%dAe%e#fdB��YZ&dCe%e$fdD��YZ'ddElm(Z(e(dFdG�Z)e(dHdI�Z*e(dJdK�Z+e&Z,dLe)e#fdM��YZ-dNe*e&fdO��YZ.dPe+e&fdQ��YZ/dRe)e$fdS��YZ0dTe*e'fdU��YZ1dVe+e'fdW��YZ2dX�Z3e3�[3d"e4dY�Z5dZ�Z6dd[�Z7d"e4d\�Z8d]�Z9d^�Z:e4d_�Z;d`�Z<daZ=edb�e=D��Z>dc�Z?ej@dd�ZAdedfdg�ZBeCeCdedfdh�ZDeCeCdedfdi�ZEdedfdj�ZFeGedk��ZHeeH�ZIiZJdlejKfdm��YZLdndddo�ZNd"dddp�ZOdndq�ZPeCd"dddr�ZQds�ZRdt�ZSdaTdu�ZUdaVdv�ZWdaXdw�ZYdaZdx�Z[da\dy�Z]da^dzd{�Z_da`d|�Zadabd}�Zcd~�Zddaed�ZfdS(�u�
Ported using Python-Future from the Python 3.3 standard library.
Parse (absolute and relative) URLs.
urlparse module is based upon the following RFC specifications.
RFC 3986 (STD66): "Uniform Resource Identifiers" by T.
Berners-Lee, R. Fielding
and L. Masinter, January 2005.
RFC 2732 : "Format for Literal IPv6 Addresses in URL's by
R.Hinden, B.Carpenter
and L.Masinter, December 1999.
RFC 2396: "Uniform Resource Identifiers (URI)": Generic Syntax
by T.
Berners-Lee, R. Fielding, and L. Masinter, August 1998.
RFC 2368: "The mailto URL scheme", by P.Hoffman , L Masinter, J.
Zawinski, July 1998.
RFC 1808: "Relative Uniform Resource Locators", by R. Fielding,
UC Irvine, June
1995.
RFC 1738: "Uniform Resource Locators (URL)" by T. Berners-Lee, L.
Masinter, M.
McCahill, December 1994
RFC 3986 is considered the current standard and any future changes to
urlparse module should conform with it. The urlparse module is
currently not entirely compliant with this RFC due to defacto
scenarios for parsing, and for backward compatibility purposes, some
parsing quirks from older RFCs are retained. The testcases in
test_urlparse.py provides a good indicator of parsing behavior.
i(tabsolute_importtdivisiontunicode_literals(tbytestchrtdicttinttrangetstr(traise_with_tracebackNuurlparseu
urlunparseuurljoinu urldefraguurlsplitu
urlunsplitu urlencodeuparse_qsu parse_qsluquoteu
quote_plusuquote_from_bytesuunquoteuunquote_plusuunquote_to_bytesuftpuhttpugopherunntpuimapuwaisufileuhttpsushttpummsuprosperourtspurtspuuusftpusvnusvn+sshutelnetusnewsursyncunfsugitugit+sshuhdlusipusipsutelumailtounewsuAabcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+-.icC`stj�tj�dS(u,Clear
the parse cache and the quoters
cache.N(t_parse_cachetcleart
_safe_quoters(((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pytclear_cacheNs
uasciiustrictcC`s|S(N((tobj((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyt_noop]scC`s|j||�S(N(tencode(Rtencodingterrors((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyt_encode_result`sc`st��fd�|D��S(Nc3`s-|]#}|r!|j���ndVqdS(uN(tdecode(t.0tx(RR(sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pys <genexpr>fs(ttuple(targsRR((RRsA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyt_decode_argsdscG`stt|dt�}x<|dD]0}|rt|t�|krtd��qqW|rc|tfSt|�tfS(Niiu$Cannot
mix str and non-str arguments(t
isinstanceRt TypeErrorRRR(Rt str_inputtarg((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyt_coerce_argshst_ResultMixinStrcB`s#eZdZdZddd�ZRS(u>Standard
approach to encoding parsed results from str to
bytesuasciiustrictc`s
|j��fd�|D��S(Nc3`s!|]}|j���VqdS(N(R(RR(RR(sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pys <genexpr>~s(t_encoded_counterpart(tselfRR((RRsA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyR}s((t__name__t
__module__t__doc__t __slots__R(((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyRyst_ResultMixinBytescB`s#eZdZdZddd�ZRS(u>Standard
approach to decoding parsed results from bytes to
struasciiustrictc`s
|j��fd�|D��S(Nc3`s!|]}|j���VqdS(N(R(RR(RR(sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pys <genexpr>�s(t_decoded_counterpart(R!RR((RRsA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyR�s((R"R#R$R%R(((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyR&�st_NetlocResultMixinBasecB`sPeZdZdZed��Zed��Zed��Zed��ZRS(uHShared
methods for the parsed result objects containing a netloc
elementcC`s|jdS(Ni(t _userinfo(R!((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pytusername�scC`s|jdS(Ni(R)(R!((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pytpassword�scC`s;|jd}|sd}n|dk r7|j�}n|S(Ni(t _hostinfotNonetlower(R!thostname((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyR/�s
cC`sO|jd}|dk rKt|d�}d|ko?dknsKdSn|S(Nii
ii��(R,R-R(R!tport((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyR0�s
(( R"R#R$R%tpropertyR*R+R/R0(((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyR(�s t_NetlocResultMixinStrcB`s,eZdZed��Zed��ZRS(cC`se|j}|jd�\}}}|rQ|jd�\}}}|s[d}q[n
d}}||fS(Nu@u:(tnetloct
rpartitiont partitionR-(R!R3tuserinfot have_infothostinfoR*t
have_passwordR+((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyR)�s
c C`s�|j}|jd�\}}}|jd�\}}}|rr|jd�\}}}|jd�\}}}n|jd�\}}}|s�d}n||fS(Nu@u[u]u:(R3R4R5R-( R!R3t_R8thave_open_brt bracketedR/R0t have_port((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyR,�s ((R"R#R%R1R)R,(((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyR2�st_NetlocResultMixinBytescB`s,eZdZed��Zed��ZRS(cC`se|j}|jd�\}}}|rQ|jd�\}}}|s[d}q[n
d}}||fS(Nt@t:(R3R4R5R-(R!R3R6R7R8R*R9R+((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyR)�s
c C`s�|j}|jd�\}}}|jd�\}}}|rr|jd�\}}}|jd�\}}}n|jd�\}}}|s�d}n||fS(NR?t[t]R@(R3R4R5R-( R!R3R:R8R;R<R/R0R=((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyR,�s ((R"R#R%R1R)R,(((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyR>�s(t
namedtupleuDefragResultuurl fragmentuSplitResultu!scheme netloc path
query fragmentuParseResultu(scheme netloc path params query
fragmenttDefragResultcB`seZdZd�ZRS(cC`s&|jr|jd|jS|jSdS(Nu#(tfragmentturl(R!((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pytgeturl�s ((R"R#R%RG(((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyRD�stSplitResultcB`seZdZd�ZRS(cC`s
t|�S(N(t
urlunsplit(R!((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyRG�s((R"R#R%RG(((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyRH�stParseResultcB`seZdZd�ZRS(cC`s
t|�S(N(t
urlunparse(R!((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyRGs((R"R#R%RG(((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyRJ�stDefragResultBytescB`seZdZd�ZRS(cC`s&|jr|jd|jS|jSdS(Nt#(RERF(R!((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyRGs ((R"R#R%RG(((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyRLstSplitResultBytescB`seZdZd�ZRS(cC`s
t|�S(N(RI(R!((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyRGs((R"R#R%RG(((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyRNstParseResultBytescB`seZdZd�ZRS(cC`s
t|�S(N(RK(R!((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyRGs((R"R#R%RG(((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyROscC`sNttfttfttff}x&|D]\}}||_||_q(WdS(N(RDRLRHRNRJROR
R'(t
_result_pairst_decodedt_encoded((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyt_fix_result_transcodings c
C`s�t||�\}}}t|||�}|\}}}}}|tkrld|krlt|�\}}nd}t||||||�} || �S(u#Parse
a URL into 6 components:
<scheme>://<netloc>/<path>;<params>?<query>#<fragment>
Return a 6-tuple: (scheme, netloc, path, params, query, fragment).
Note that we don't break the components up in smaller bits
(e.g. netloc is a single string) and we don't expand %
escapes.u;u(Rturlsplittuses_paramst_splitparamsRJ(
RFtschemetallow_fragmentst_coerce_resulttsplitresultR3tqueryREtparamstresult((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyturlparse$scC`sed|kr@|jd|jd��}|dkrO|dfSn|jd�}||
||dfS(Nu/u;iui(tfindtrfind(RFti((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyRV4s
cC`sbt|�}x>dD]6}|j||�}|dkrt||�}qqW|||!||fS(Nu/?#i(tlenR_tmin(RFtstarttdelimtctwdelim((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyt_splitnetloc=s
c
C`st||�\}}}t|�}|||t|�t|�f}tj|d�}|rg||�Stt�tkr�t�nd}}}|j d�} | dkr.||
dkr�|| j
�}|| d}|d
dkrAt|d�\}}d|krd |ks/d |krAd|krAtd
��qAn|rnd|krn|j
dd�\}}nd|kr�|j
dd�\}}nt|||||�}
|
t|<||
�Sxj||
D]}|tkr�Pq�q�W|| d}|std
�|D��r.|| j
�|}}q.n|d
dkr�t|d�\}}d|krkd |ks�d |kr�d|kr�td
��q�n|r�d|kr�|j
dd�\}}nd|kr�|j
dd�\}}nt|||||�}
|
t|<||
�S(uParse a URL into 5 components:
<scheme>://<netloc>/<path>?<query>#<fragment>
Return a 5-tuple: (scheme, netloc, path, query, fragment).
Note that we don't break the components up in smaller bits
(e.g. netloc is a single string) and we don't expand %
escapes.uu:iuhttpiiu//u[u]uInvalid IPv6
URLu#u?cs`s|]}|dkVqdS(u
0123456789N((RRf((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pys <genexpr>lsN(RtboolttypeR
tgetR-RbtMAX_CACHE_SIZER
R_R.Rht
ValueErrortsplitRHtscheme_charstany(
RFRWRXRYtkeytcachedR3R[RERatvRftrest((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyRTEsX!
cC`sYt|�\}}}}}}}|r:d||f}n|t|||||f��S(u�Put
a parsed URL back together again. This may result in a
slightly different, but equivalent URL, if the URL that was parsed
originally had redundant delimiters, e.g. a ? with an empty query
(the draft states that these are equivalent).u%s;%s(RRI(t
componentsRWR3RFR\R[RERY((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyRK}s!cC`s�t|�\}}}}}}|sF|r�|tkr�|d
dkr�|ri|d
dkrid|}nd|pud|}n|r�|d|}n|r�|d|}n|r�|d|}n||�S( ukCombine
the elements of a tuple as returned by urlsplit() into a
complete URL as a string. The data argument can be any five-item
iterable.
This may result in a slightly different, but equivalent URL, if the URL
that
was parsed originally had unnecessary delimiters (for example, a ? with
an
empty query; the RFC states that these are
equivalent).iu//iu/uu:u?u#(Rtuses_netloc(RuRWR3RFR[RERY((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyRI�s(
cC`s�|s
|S|s|St||�\}}}t|d|�\}}}}}} t|||�\}
}}}
}}|
|ks�|
tkr�||�S|
tkr�|r�|t|
|||
||f��S|}n|d dkr|t|
|||
||f��S|rP|
rP|}|}
|s.|}n|t|
|||
||f��S|jd�d
|jd�}|ddkr�d|d<nxd|kr�|jd�q�Wxqd}t|�d}xU||kr||dkr||dd kr||d|d5Pn|d}q�WPq�|ddgkr@d|d<n2t|�dkrr|ddkrrdg|d)n|t|
|dj|�|
||f��S(
uaJoin a base URL and a possibly relative URL to form an absolute
interpretation of the
latter.uiu/i����u.u..ii����(uu..( RR^t
uses_relativeRvRKRntremoveRbtjoin(tbaseRFRXRYtbschemetbnetloctbpathtbparamstbqueryt bfragmentRWR3tpathR\R[REtsegmentsRatn((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyturljoin�sZ$$
"c C`s|t|�\}}d|kr]t|�\}}}}}}t|||||df�}nd}|}|t||��S(u�Removes
any existing fragment from URL.
Returns a tuple of the defragmented URL and the fragment. If
the URL contained no fragments, the second element is the
empty string.
u#u(RR^RKRD( RFRYtsR�tptatqtfragtdefrag((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyt urldefrag�s!u0123456789ABCDEFabcdefcc`sH|]>}tD]1}||j�tt||d�g�fVq
qdS(iN(t_hexdigRRR(RR�tb((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pys <genexpr>�scC`s�|s|jtd�St|t�r8|jd�}nt|�}|jd�}t|�dkri|S|dg}|j}x^|dD]R}y$|t|d
�||d�Wq�tk
r�|d�||�q�Xq�Wtd�j |�S(u,unquote_to_bytes('abc%20def')
-> b'abc def'.tuutf-8t%iii(
RnRRRRRbtappendt
_hextobytetKeyErrorRy(tstringtbitstresR�titem((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pytunquote_to_bytes�s&
u([-]+)uutf-8ureplacecC`s�d|kr|j|S|dkr,d}n|dkrAd}ntj|�}|dg}|j}xRtdt|�d�D]8}|t||�j||��|||d�qWdj|�S( u�Replace
%xx escapes by their single-character equivalent. The optional
encoding and errors parameters specify how to decode percent-encoded
sequences into Unicode characters, as accepted by the bytes.decode()
method.
By default, percent-encoded sequences are decoded with UTF-8, and
invalid
sequences are replaced by a placeholder character.
unquote('abc%20def') -> 'abc def'.
u%uutf-8ureplaceiiiuN( RnR-t_asciireR�RRbR�RRy(R�RRR�R�R�Ra((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pytunquotes
c C`sli}t|||d|d|�}xA|D]9\}}||krW||j|�q+|g||<q+W|S(uOParse
a query given as a string argument.
Arguments:
qs: percent-encoded query string to be parsed
keep_blank_values: flag indicating whether blank values in
percent-encoded queries should be treated as blank strings.
A true value indicates that blanks should be retained as
blank strings. The default false value indicates that
blank values are to be ignored and treated as if they were
not included.
strict_parsing: flag indicating what to do with parsing errors.
If false (the default), errors are silently ignored.
If true, errors raise a ValueError exception.
encoding and errors: specify how to decode percent-encoded
sequences
into Unicode characters, as accepted by the bytes.decode()
method.
RR(t parse_qslR�( tqstkeep_blank_valueststrict_parsingRRt
parsed_resulttpairstnametvalue((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pytparse_qssc C`sut|�\}}g|jd�D]"}|jd�D]}|^q5q"}g} x|D]}
|
rq|rqqWn|
jdd�}t|�dkr�|r�td|
f��n|rW|jd�q�qWnt|d�s�|rW|djd d
�}t|d|d|�}||�}|djd d
�}
t|
d|d|�}
||
�}
| j||
f�qWqWW| S(
u;Parse a
query given as a string argument.
Arguments:
qs: percent-encoded query string to be parsed
keep_blank_values: flag indicating whether blank values in
percent-encoded queries should be treated as blank strings. A
true value indicates that blanks should be retained as blank
strings. The default false value indicates that blank values
are to be ignored and treated as if they were not included.
strict_parsing: flag indicating what to do with parsing errors. If
false (the default), errors are silently ignored. If true,
errors raise a ValueError exception.
encoding and errors: specify how to decode percent-encoded sequences
into Unicode characters, as accepted by the bytes.decode() method.
Returns a list, as G-d intended.
u&u;u=iiubad query field: %ruiu+u
RR(RRnRbRmR�treplaceR�(R�R�R�RRRYts1ts2R�trt
name_valuetnvR�R�((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyR�<s,8
cC`s"|jdd�}t|||�S(u�Like
unquote(), but also replace plus signs by spaces, as required for
unquoting HTML form values.
unquote_plus('%7e/abc+def') -> '~/abc def'
u+u
(R�R�(R�RR((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pytunquote_pluslssAABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789_.-tQuotercB`s)eZdZd�Zd�Zd�ZRS(u�A
mapping from bytes (in range(0,256)) to strings.
String values are percent-encoded byte values, unless the key < 128,
and
in the "safe" set (either the specified safe set, or default
set).
cC`stjt|��|_dS(usafe: bytes
object.N(t_ALWAYS_SAFEtunionRtsafe(R!R�((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyt__init__�scC`sdt|�S(Nu<Quoter
%r>(R(R!((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyt__repr__�scC`s8||jkrt|�ndj|�}|||<|S(Nu%{0:02X}(R�Rtformat(R!R�R�((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyt__missing__�s*
(R"R#R$R�R�R�(((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyR�|s u/cC`s�t|t�rX|s|S|dkr.d}n|dkrCd}n|j||�}n6|dk rstd��n|dk r�td��nt||�S(u�quote('abc
def') -> 'abc%20def'
Each part of a URL, e.g. the path info, the query, etc., has a
different set of reserved characters that must be quoted.
RFC 2396 Uniform Resource Identifiers (URI): Generic Syntax lists
the following reserved characters.
reserved = ";" | "/" | "?" |
":" | "@" | "&" | "=" |
"+" |
"$" | ","
Each of these characters is reserved in some component of a URL,
but not necessarily in all of them.
By default, the quote function is intended for quoting the path
section of a URL. Thus, it will not encode '/'. This
character
is reserved, but in typical usage the quote function is being
called on a path where the existing slash characters are used as
reserved characters.
string and safe may be either str or bytes objects. encoding must
not be specified if string is a str.
The optional encoding and errors parameters specify how to deal with
non-ASCII characters, as accepted by the str.encode method.
By default, encoding='utf-8' (characters are encoded with
UTF-8), and
errors='strict' (unsupported characters raise a
UnicodeEncodeError).
uutf-8ustrictu,quote() doesn't support 'encoding' for
bytesu*quote() doesn't support 'errors' for
bytesN(RRR-RRtquote_from_bytes(R�R�RR((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pytquote�s cC`s�t|t�rd|ks6t|t�rId|krIt||||�St|t�rgtd�}ntd�}t|||||�}|jdd�S(u�Like
quote(), but also replace ' ' with '+', as required for
quoting
HTML form values. Plus signs in the original string are escaped unless
they are included in safe. It also does not have safe default to
'/'.
u t
u+(RRRR�R�(R�R�RRtspace((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyt
quote_plus�scC`s#t|ttf�s$td��n|s4td�St|�}t|t�rjt|�jdd�}n7t|�}tg|D]}|dkr�|^q��}|jt|�s�|j�Syt |}Wn(t
k
r�t|�jt |<}nXtd�j
g|D]}||�^q
�S(u�Like quote(), but accepts a bytes object rather than a str, and
does
not perform string-to-bytes encoding. It always returns an ASCII
string.
quote_from_bytes(b'abc def?') -> 'abc%20def%3f'
u!quote_from_bytes() expected
bytesuuasciiuignorei�(RRt bytearrayRRRtrstript_ALWAYS_SAFE_BYTESRRR�R�t__getitem__Ry(tbsR�Rftquotertchar((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyR��s
+
c
C`s�t|d�r|j�}niy-t|�rJt|dt�rJt�nWn9tk
r�tj�\}}}ttd�|�nXg}|s:x|D]�\} }
t| t �r�t
| |�} nt
t| �|||�} t|
t �rt
|
|�}
nt
t|
�|||�}
|j| d|
�q�Wn{xx|D]p\} }
t| t �rnt
| |�} nt
t| �|||�} t|
t �r�t
|
|�}
|j| d|
�qAt|
t�r�t
|
|||�}
|j| d|
�qAyt|
�}WnAtk
rNt
t|
�|||�}
|j| d|
�qAXx_|
D]W}t|t �r}t
||�}nt
t|�|||�}|j| d|�qVWqAWtd�j
|�S(u#Encode a
sequence of two-element tuples or dictionary into a URL query string.
If any values in the query arg are sequences and doseq is true, each
sequence element is converted to a separate parameter.
If the query arg is a sequence of two-element tuples, the order of the
parameters in the output will match the order of parameters in the
input.
The query arg may be either a string or a bytes type. When query arg is
a
string, the safe, encoding and error parameters are sent the quote_plus
for
encoding.
uitemsiu1not a valid non-string sequence or mapping
objectu=u&(thasattrtitemsRbRRRtsystexc_infoR RR�RR�Ry(
R[tdoseqR�RRttytvattbtltkRsRtelt((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyt urlencode�sP
cC`s]t|t�rYy|jd�j�}WqYtk
rUtdt|�d��qYXn|S(uto_bytes(u"URL") -->
'URL'.uASCIIuURL u contains non-ASCII
characters(RRRRtUnicodeErrortrepr(RF((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pytto_bytesHs
cC`sot|�j�}|d
dkrH|ddkrH|dd!j�}n|d
dkrk|dj�}n|S(u8unwrap('<URL:type://host/path>')
-->
'type://host/path'.iu<i����u>iuURL:(Rtstrip(RF((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pytunwrapUs
cC`svtdkr*ddl}|jd�antj|�}|rl|jd�}|j�|t|�dfSd|fS(u:splittype('type:opaquestring')
--> 'type', 'opaquestring'.iNu
^([^/:]+):i(t _typeprogR-tretcompiletmatchtgroupR.Rb(RFR�R�RW((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyt splittype^scC`s�tdkr*ddl}|jd�antj|�}|r�|jd�}|jd�}|r�|jd�r�d|}n||fSd|fS(u;splithost('//host[:port]/path')
--> 'host[:port]',
'/path'.iNu^//([^/?]*)(.*)$iiu/(t _hostprogR-R�R�R�R�t
startswith(RFR�R�t host_portR�((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyt splithostls
cC`sYtdkr*ddl}|jd�antj|�}|rO|jdd�Sd|fS(uJsplituser('user[:passwd]@host[:port]')
--> 'user[:passwd]',
'host[:port]'.iNu^(.*)@(.*)$ii(t _userprogR-R�R�R�R�(thostR�R�((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyt splituser}scC`s_tdkr0ddl}|jd|j�antj|�}|rU|jdd�S|dfS(u/splitpasswd('user:passwd')
-> 'user',
'passwd'.iNu^([^:]*):(.*)$ii(t_passwdprogR-R�R�tSR�R�(tuserR�R�((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pytsplitpasswd�scC`sYtdkr*ddl}|jd�antj|�}|rO|jdd�S|dfS(u*splitport('host:port')
--> 'host',
'port'.iNu^(.*):([0-9]+)$ii(t _portprogR-R�R�R�R�(R�R�R�((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyt splitport�si����cC`s�tdkr*ddl}|jd�antj|�}|r�|jdd�\}}y%|sotd��nt|�}Wntk
r�d}nX||fS||fS(u�Split host and port, returning numeric
port.
Return given default port if no ':' found; defaults to -1.
Return numerical port if a valid number are found after ':'.
Return None if ':' but not a valid
number.iNu^(.*):(.*)$iiu no digits(t
_nportprogR-R�R�R�R�RmR(R�tdefportR�R�R0tnport((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyt
splitnport�s
cC`sYtdkr*ddl}|jd�antj|�}|rO|jdd�S|dfS(u/splitquery('/path?query')
--> '/path', 'query'.iNu^(.*)\?([^?]*)$ii(t
_queryprogR-R�R�R�R�(RFR�R�((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyt
splitquery�scC`sYtdkr*ddl}|jd�antj|�}|rO|jdd�S|dfS(u)splittag('/path#tag')
--> '/path',
'tag'.iNu^(.*)#([^#]*)$ii(t_tagprogR-R�R�R�R�(RFR�R�((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pytsplittag�scC`s!|jd�}|d|dfS(uksplitattr('/path;attr1=value1;attr2=value2;...')
->
'/path', ['attr1=value1',
'attr2=value2',
...].u;ii(Rn(RFtwords((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyt splitattr�scC`sYtdkr*ddl}|jd�antj|�}|rO|jdd�S|dfS(u-splitvalue('attr=value')
--> 'attr', 'value'.iNu^([^=]*)=(.*)$ii(t
_valueprogR-R�R�R�R�(tattrR�R�((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyt
splitvalue�s(gR$t
__future__RRRtfuture.builtinsRRRRRRtfuture.utilsR R�R�tcollectionst__all__RwRvRUtnon_hierarchicalt
uses_queryt
uses_fragmentRoRlR
R
t_implicit_encodingt_implicit_errorsRRRRtobjectRR&R(R2R>RCt_DefragResultBaset_SplitResultBaset_ParseResultBaset
ResultBaseRDRHRJRLRNRORStTrueR^RVRhRTRKRIR�R�R�R�R�R�R�R�tFalseR�R�R�t frozensetR�R�RtdefaultdictR�R-R�R�R�R�R�R�R�R�R�R�R�R�R�R�R�R�R�R�R�R�R�R�R�R�R�(((sA/usr/lib/python2.7/site-packages/future/backports/urllib/parse.pyt<module>s�.
8 5
/ ,]