3 �Qgɨ � @ s� d Z ddlZddlZddlZddlZddlZddddddd d ddd ddddddddddgZddddddddd d!d"d#d$d%d&d'd(d)d*gZdddddd+dddd"d d!d,d#d$d%d-d'd(d&d.d/d0d)d*gZddd1d#ddd d!d$d%d2d3d"d&d4gZ dd1d5d6d+ddd,d2d3g Z ddddd d!d"dd$d%d2d3gZddd1ddd6ddd d!d,dd#g Zd7Z d8Zd9d:d;gZd<Zi Zd=d>� Zd?Zd@ZdAdB� ZeefdCdD�ZeefdEdF�ZdGdH� ZG dIdJ� dJe�ZG dKdL� dLe�ZG dMdN� dNe�ZG dOdP� dPee�ZG dQdR� dRee�ZddSlmZ eddT�Z eddU�Z!eddV�Z"dWe _ dXe j#_ dYe j$_ dZe!_ d[e!j%_ d\e!j&_ d]e!j'_ d^e!j(_ d_e!j$_ d`e"_ e!j%j e"j%_ e!j&j e"j&_ e!j'j e"j'_ dae"j)_ e!j(j e"j(_ e!j$j e"j$_ eZ*G dbd� de e�Z+G dcd� de!e�Z,G ddd� de"e�Z-G ded� de e�Z.G dfd� de!e�Z/G dgd� de"e�Z0dhdi� Z1e1� [1d�dkd�Z2dldm� Z3d�dndo�Z4dpdq� Z5drds� Z6dtdu� Z7d�dvd�Z8dwd� Z9dxd� Z:d�dyd�Z;dzd� Z<d{Z=da>d|d� Z?ej@d}�ZAd�d�d�ZBd�d�d �ZCG d�d�� d�eD�ZEd�ZFdaGd�d�d�ZHd�d�d�ZIeJd��ZKeLeK�ZMi ZNG d�d�� d�ejO�ZPd�d�d�ZQd�d�d �ZRd�d�d�ZSd�dddeRfd�d �ZTd�d�� ZUd�d�� ZVdaWd�d�� ZXdaYd�d�� ZZd�d�� Z[d�d�� Z\da]d�d�� Z^d�d�d��Z_d�d�� Z`d�d�� Zad�d�� Zbd�d�� ZcdS )�a3 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. The WHATWG URL Parser spec should also be considered. We are not compliant with it either due to existing user code API behavior expectations (Hyrum's Law). It serves as a useful guide when making changes. � N�urlparse� urlunparse�urljoin� urldefrag�urlsplit� urlunsplit� urlencode�parse_qs� parse_qsl�quote� quote_plus�quote_from_bytes�unquote�unquote_plus�unquote_to_bytes�DefragResult�ParseResult�SplitResult�DefragResultBytes�ParseResultBytes�SplitResultBytes� Zftp�httpZgopherZnntpZimapZwais�fileZhttpsZshttpZmmsZprosperoZrtspZrtspuZsftpZsvnzsvn+sshZwsZwssZtelnetZsnewsZrsyncZnfsZgitzgit+sshZhdlZsipZsipsZtelZmailtoZnewszAabcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+-.z! � � � � c C s t j� tj� dS )z,Clear the parse cache and the quoters cache.N)�_parse_cache�clear� _safe_quoters� r! r! �$/usr/lib64/python3.6/urllib/parse.py�clear_cache` s r# �ascii�strictc C s | S )Nr! )�objr! r! r"