8Tc@sdZddlmZdZddlZefZyeefZWnek rTnXy e Z Wn)ek re Z e e kst nXdddkrdZn dZy ejZWnek rd ZnXd Zeed rd Zn d ZdZdZdZdefdYZdefdYZdZedZdZdZdZ dZ!dZ"dZ#dZ$dZ%dZ&d Z'd!e(fd"YZ)d#e)fd$YZ*d%e*fd&YZ+d'e*fd(YZ,d)e(fd*YZ-d+e-e+fd,YZ.d-e.fd.YZ/d/e-e,fd0YZ0d1e(fd2YZ1d3e1e+fd4YZ2d5e2fd6YZ3d7e1e,fd8YZ4dS(9uA fast, lightweight IPv4/IPv6 manipulation library in Python. This library is used to create/poke/manipulate IPv4 and IPv6 addresses and networks. i(tunicode_literalsu1.0.7NticCs|S(N((tbyt((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pytscCs'g|D]}tjd|d^qS(Ns!Bi(tstructtunpack(Rtb((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyR!scCsP|dkstd}x1|D])}t|ts:t|d>|}qW|S(Nubigii(tAssertionErrort isinstancet_compat_int_types(tbytvalst endianesstrestbv((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt_compat_int_from_byte_vals&s  cCst|tst|dks't|dkrm|dksK|dkr]tjdntjd|S|dkr|dks|dkrtjd ntjd |d ?|d @StdS(Nubigiiii u(integer out of range for 'I' format codes!Iiiu)integer out of range for 'QQ' format codes!QQi@lll (RR RRterrortpacktNotImplementedError(tintvaltlengthR ((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt_compat_to_bytes/s  u bit_lengthcCs |jS(N(t bit_length(ti((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyR>scCsttt|dS(Ni(tlentbintabs(R((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyR@sccs,|}x||kr'|V|d7}q WdS(Ni((tstarttendR((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt _compat_rangeCsi itAddressValueErrorcBseZdZRS(u%A Value Error related to the address.(t__name__t __module__t__doc__(((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRMstNetmaskValueErrorcBseZdZRS(u%A Value Error related to the netmask.(RRR (((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyR!QscCsyt|SWnttfk r'nXyt|SWnttfk rOnXt|trrtd|ntd|dS(uTake an IP string/int and return an object of the correct type. Args: address: A string or integer, the IP address. Either IPv4 or IPv6 addresses may be supplied; integers less than 2**32 will be considered to be IPv4 by default. Returns: An IPv4Address or IPv6Address object. Raises: ValueError: if the *address* passed isn't either a v4 or a v6 address ux%r does not appear to be an IPv4 or IPv6 address. Did you pass in a bytes (str in Python 2) instead of a unicode object?u0%r does not appear to be an IPv4 or IPv6 addressN(t IPv4AddressRR!t IPv6AddressRtbytest ValueError(taddress((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt ip_addressUs cCsjyt||SWnttfk r*nXyt||SWnttfk rUnXtd|dS(uTake an IP string/int and return an object of the correct type. Args: address: A string or integer, the IP network. Either IPv4 or IPv6 networks may be supplied; integers less than 2**32 will be considered to be IPv4 by default. Returns: An IPv4Network or IPv6Network object. Raises: ValueError: if the string passed isn't either a v4 or a v6 address. Or if the network has host bits set. u0%r does not appear to be an IPv4 or IPv6 networkN(t IPv4NetworkRR!t IPv6NetworkR%(R&tstrict((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt ip_networkyscCsdyt|SWnttfk r'nXyt|SWnttfk rOnXtd|dS(ugTake an IP string/int and return an object of the correct type. Args: address: A string or integer, the IP address. Either IPv4 or IPv6 addresses may be supplied; integers less than 2**32 will be considered to be IPv4 by default. Returns: An IPv4Interface or IPv6Interface object. Raises: ValueError: if the string passed isn't either a v4 or a v6 address. Notes: The IPv?Interface classes describe an Address on a particular Network, so they're basically a combination of both the Address and Network classes. u2%r does not appear to be an IPv4 or IPv6 interfaceN(t IPv4InterfaceRR!t IPv6InterfaceR%(R&((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt ip_interfacescCs.yt|ddSWntdnXdS(u`Represent an address as 4 packed bytes in network (big-endian) order. Args: address: An integer representation of an IPv4 IP address. Returns: The integer address packed as 4 bytes in network (big-endian) order. Raises: ValueError: If the integer is negative or too large to be an IPv4 IP address. iubigu&Address negative or too large for IPv4N(RR%(R&((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pytv4_int_to_packedscCs.yt|ddSWntdnXdS(uRepresent an address as 16 packed bytes in network (big-endian) order. Args: address: An integer representation of an IPv6 IP address. Returns: The integer address packed as 16 bytes in network (big-endian) order. iubigu&Address negative or too large for IPv6N(RR%(R&((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pytv6_int_to_packeds cCs>t|jd}t|dkr:td|n|S(uAHelper to split the netmask and raise AddressValueError if neededu/iuOnly one '/' permitted in %r(t _compat_strtsplitRR(R&taddr((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt_split_optional_netmaskscCsM|d}}x2|dD]&}|j|jdkr>|}qPqW||fS(uFind a sequence of IPv#Address. Args: addresses: a list of IPv#Address objects. Returns: A tuple containing the first and last IP addresses in the sequence. ii(t_ip(t addressestfirsttlasttip((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt_find_address_ranges  cCs=|dkr|Sx&t|D]}||?d@r|SqW|S(uCount the number of zero bits on the right hand side. Args: number: an integer. bits: maximum number of bits to count. Returns: The number of zero bits on the right hand side of the number. ii(trange(tnumbertbitsR((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt_count_righthand_zero_bitss ccs^t|tot|ts-tdn|j|jkrXtd||fn||krstdn|jdkrt}n$|jdkrt}n td|j}|j}|j}x||krYt t ||t ||dd}|d|||f}|V|d|>7}|d|j krGPn|j |}qWd S( uSummarize a network range given the first and last IP addresses. Example: >>> list(summarize_address_range(IPv4Address('192.0.2.0'), ... IPv4Address('192.0.2.130'))) ... #doctest: +NORMALIZE_WHITESPACE [IPv4Network('192.0.2.0/25'), IPv4Network('192.0.2.128/31'), IPv4Network('192.0.2.130/32')] Args: first: the first IPv4Address or IPv6Address in the range. last: the last IPv4Address or IPv6Address in the range. Returns: An iterator of the summarized IPv(4|6) network objects. Raise: TypeError: If the first and last objects are not IP addresses. If the first and last objects are not the same version. ValueError: If the last object is not greater than the first. If the version of the first address is not 4 or 6. u1first and last must be IP addresses, not networksu%%s and %s are not of the same versionu*last IP address must be greater than firstiiuunknown IP versioniu%s/%dN(Rt _BaseAddresst TypeErrortversionR%R(R)t_max_prefixlenR5tminR>t_compat_bit_lengtht _ALL_ONESt __class__(R7R8R9tip_bitst first_inttlast_inttnbitstnet((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pytsummarize_address_range s2       cCsxtrd}g}t}x|D]}|sD|}|j|q"|j|jkrq|j|jkrqt}q"|t|jjdkr|j|d<}t}q"|}|j|q"W|}|s|SqWdS(uvLoops through the addresses, collapsing concurrent netblocks. Example: ip1 = IPv4Network('192.0.2.0/26') ip2 = IPv4Network('192.0.2.64/26') ip3 = IPv4Network('192.0.2.128/26') ip4 = IPv4Network('192.0.2.192/26') _collapse_addresses_recursive([ip1, ip2, ip3, ip4]) -> [IPv4Network('192.0.2.0/24')] This shouldn't be called directly; it is called via collapse_addresses([]). Args: addresses: A list of IPv4Network's or IPv6Network's Returns: A list of IPv4Network's or IPv6Network's depending on what we were passed. iiN( tTruetNonetFalsetappendtnetwork_addresstbroadcast_addresstlisttsupernettsubnets(R6t last_addrt ret_arrayt optimizedtcur_addr((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt_collapse_addresses_recursiveEs&   " cCsd}g}g}g}x2|D]*}t|tr}|rm|dj|jkrmtd||dfn|j|q|j|jkr|r|dj|jkrtd||dfny|j|jWqItk r|j|j qIXq|r<|dj|jkr<td||dfn|j|qWt t |}t t |}xU|t |krt ||\}}|j|d}|jt||qtWttt ||dtjS(uCollapse a list of IP objects. Example: collapse_addresses([IPv4Network('192.0.2.0/25'), IPv4Network('192.0.2.128/25')]) -> [IPv4Network('192.0.2.0/24')] Args: addresses: An iterator of IPv4Network or IPv6Network objects. Returns: An iterator of the collapsed IPv(4|6)Network objects. Raises: TypeError: If passed a list of mixed version objects. iiu%%s and %s are not of the same versionitkey(RR?t_versionR@RPt _prefixlenRBR9tAttributeErrorRQtsortedtsetRR:tindextextendRLtiterRZt _BaseNetworkt_get_networks_key(R6RtaddrstipstnetsR9R7R8((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pytcollapse_addressesus<   cCs6t|tr|jSt|tr2|jStS(u2Return a key suitable for sorting between networks and addresses. Address and Network objects are not sortable by default; they're fundamentally different so the expression IPv4Address('192.0.2.0') <= IPv4Network('192.0.2.0/24') doesn't make any sense. There are some times however, where you may wish to have ipaddress sort these for you anyway. If you need to do this, you can use this function as the key= argument to sorted(). Args: obj: either a Network or Address object. Returns: appropriate key. (RRdReR?t_get_address_keytNotImplemented(tobj((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pytget_mixed_type_keys   t_TotalOrderingMixincBs>eZdZdZdZdZdZdZRS(cCs tdS(N(R(tselftother((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt__eq__scCs$|j|}|tkrtS| S(N(RqRk(RoRptequal((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt__ne__s cCs tdS(N(R(RoRp((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt__lt__scCs3|j|}|tks"| r/|j|S|S(N(RtRkRq(RoRptless((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt__le__s cCsI|j|}|tkrtS|j|}|tkr>tS|pG| S(N(RtRkRq(RoRpRuRr((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt__gt__s  cCs$|j|}|tkrtS| S(N(RtRk(RoRpRu((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt__ge__s (RRRqRsRtRvRwRx(((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRns      t_IPAddressBasecBsqeZdZedZedZedZdZdZd dZ ddZ d d Z RS( uThe mother class.cCs |jS(u:Return the longhand version of the IP address as a string.(t_explode_shorthand_ip_string(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pytexplodedscCs t|S(u;Return the shorthand version of the IP address as a string.(R1(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt compressedscCs#dt|f}t|dS(Nu%200s has no version specified(ttypeR(Rotmsg((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRAscCsi|dkr.d}t|||jfn||jkred}t|||j|jfndS(Niu-%d (< 0) is not permitted as an IPv%d addressu2%d (>= 2**%d) is not permitted as an IPv%d address(RR\RERB(RoR&R~((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt_check_int_addresss cCsDt|}||kr@d}t|||||jfndS(Num%r (len %d != %d) is not permitted as an IPv%d address (did you pass in a bytes instead of a unicode object?)(RRR\(RoR&t expected_lent address_lenR~((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt_check_packed_address s    cCs*|dkr|j}n|j|j|?AS(uTurn the prefix length netmask into a int for comparison. Args: prefixlen: An integer, the prefix length. Returns: An integer. N(RNR]RE(Rot prefixlen((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt_ip_int_from_prefixs  i cCs|t||S(uReturn prefix length from the decimal netmask. Args: ip_int: An integer, the IP address. mask: The netmask. Defaults to 32. Returns: An integer, the prefix length. (R>(Rotip_inttmask((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt_prefix_from_ip_int s cCs(|s|j}n|j|j|S(uTurn a prefix length into a dotted decimal string. Args: prefixlen: An integer, the netmask prefix length. Returns: A string, the dotted decimal netmask string. (R]t_string_from_ip_intR(RoR((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt_ip_string_from_prefix-s  N( RRR tpropertyR{R|RARRRNRRR(((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRys   R?cBsheZdZdZdZdZdZdZdZdZ dZ d Z d Z RS( uA generic IP object. This IP class contains the version independent methods which are used by single IP addresses. cCs9t|t r5dt|kr5td|ndS(Nu/uUnexpected '/' in %r(RR$R1R(RoR&((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt__init__Es"cCs|jS(N(R5(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt__int__IscCs?y&|j|jko$|j|jkSWntk r:tSXdS(N(R5R\R^Rk(RoRp((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRqLs  cCsy|j|jkr+td||fnt|tsStd||fn|j|jkru|j|jkStS(Nu%%s and %s are not of the same versionu"%s and %s are not of the same type(R\R@RR?R5RO(RoRp((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRtSscCs*t|tstS|jt||S(N(RR RkRFtint(RoRp((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt__add__`scCs*t|tstS|jt||S(N(RR RkRFR(RoRp((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt__sub__escCsd|jjt|fS(Nu%s(%r)(RFRR1(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt__repr__jscCst|j|jS(N(R1RR5(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt__str__mscCsttt|jS(N(thashthexRR5(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt__hash__pscCs |j|fS(N(R\(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRjss( RRR RRRqRtRRRRRRj(((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyR?<s        RdcBs|eZdZdZdZdZdZdZdZdZ dZ d Z d Z d Z ed Zed ZedZedZedZedZedZedZdZdZdZdd dZdd dZedZedZedZedZ edZ!edZ"RS(!u~A generic IP network object. This IP class contains the version independent methods which are used by networks. cCs i|_dS(N(t_cache(RoR&((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRscCsd|jjt|fS(Nu%s(%r)(RFRR1(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRscCsd|j|jfS(Nu%s/%d(RQR(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRsccsNt|j}t|j}x)t|d|D]}|j|Vq2WdS(uGenerate Iterator over usable hosts in a network. This is like __iter__ except it doesn't return the network or broadcast addresses. iN(RRQRRRt_address_class(Rotnetworkt broadcasttx((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pythostssccsNt|j}t|j}x)t||dD]}|j|Vq2WdS(Ni(RRQRRRR(RoRRR((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt__iter__scCst|j}t|j}|dkrT|||krCtn|j||S|d7}|||krwtn|j||SdS(Nii(RRQRRt IndexErrorR(RotnRR((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt __getitem__s    cCs|j|jkr+td||fnt|tsStd||fn|j|jkru|j|jkS|j|jkr|j|jkStS(Nu%%s and %s are not of the same versionu"%s and %s are not of the same type(R\R@RRdRQtnetmaskRO(RoRp((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRtscCs]yD|j|jkoB|j|jkoBt|jt|jkSWntk rXtSXdS(N(R\RQRRR^Rk(RoRp((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRqs   cCs tt|jt|jAS(N(RRRQR(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRscCs`|j|jkrtSt|tr)tSt|jt|jkoYt|jkSSdS(N(R\RORRdRRQR5RR(RoRp((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt __contains__s  cCs:|j|kp9|j|kp9|j|kp9|j|kS(u*Tell if self is partly contained in other.(RQRR(RoRp((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pytoverlapsscCsW|jjd}|dkrS|jt|jt|jB}||jd other eg: IPv4Network('192.0.2.128/25') > IPv4Network('192.0.2.0/25') IPv6Network('2001:db8::2000/124') > IPv6Network('2001:db8::1000/124') Raises: TypeError if the IP versions are different. u"%s and %s are not of the same typeiii(R\R@RQR(RoRp((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pytcompare_networksOs!cCs|j|j|jfS(uNetwork-only key function. Returns an object that identifies this address' network and netmask. This function is a suitable "key" argument for sorted() and list.sort(). (R\RQR(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyResiccsX|j|jkr|VdS|dk rp||jkrEtdn|dkr`tdn||j}n|dkrtdn|j|}|jt|std||fn|jd|j|j|f}|V|}x]trS|j }||j krdS|j t |d}|jd||f}|VqWdS( uThe subnets which join to make the current subnet. In the case that self contains only one IP (self._prefixlen == 32 for IPv4 or self._prefixlen == 128 for IPv6), yield an iterator with just ourself. Args: prefixlen_diff: An integer, the amount the prefix length should be increased by. This should not be set if new_prefix is also set. new_prefix: The desired new prefix length. This must be a larger number (smaller prefix) than the existing prefix. This should not be set if prefixlen_diff is also set. Returns: An iterator of IPv(4|6) objects. Raises: ValueError: The prefixlen_diff is too small or too large. OR prefixlen_diff and new_prefix are both set or new_prefix is a smaller number than the current prefix (smaller number means a larger network) Nunew prefix must be longeriu(cannot set prefixlen_diff and new_prefixiuprefix length diff must be > 0u0prefix length diff %d is invalid for netblock %su%s/%s( R]RBRNR%t_is_valid_netmasktstrRFRQRMRRRR(Rotprefixlen_difft new_prefixt new_prefixlenR7tcurrentRtnew_addr((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRUs:         cCs|jdkr|S|dk rh||jkr=tdn|dkrXtdn|j|}n|j|dkrtd|j|fn|jd|j|j|fdt}|jd|j|jfS( uThe supernet containing the current network. Args: prefixlen_diff: An integer, the amount the prefix length of the network should be decreased by. For example, given a /24 network and a prefixlen_diff of 3, a supernet with a /21 netmask is returned. Returns: An IPv4 network object. Raises: ValueError: If self.prefixlen - prefixlen_diff < 0. I.e., you have a negative prefix length. OR If prefixlen_diff and new_prefix are both set or new_prefix is a larger number than the current prefix (larger number means a smaller network) iunew prefix must be shorteriu(cannot set prefixlen_diff and new_prefixu;current prefixlen is %d, cannot have a prefixlen_diff of %du%s/%dR*N(R]RNR%RRFRQRO(RoRRtt((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRTs    cCs|jjo|jjS(uTest if the address is reserved for multicast use. Returns: A boolean, True if the address is a multicast address. See RFC 2373 2.7 for details. (RQt is_multicastRR(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRs cCs|jjo|jjS(uTest if the address is otherwise IETF reserved. Returns: A boolean, True if the address is within one of the reserved IPv6 Network ranges. (RQt is_reservedRR(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRs cCs|jjo|jjS(uTest if the address is reserved for link-local. Returns: A boolean, True if the address is reserved per RFC 4291. (RQt is_link_localRR(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRs cCs|jjo|jjS(uTest if this address is allocated for private networks. Returns: A boolean, True if the address is reserved per RFC 4193. (RQt is_privateRR(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRs cCs|jjo|jjS(uTest if the address is unspecified. Returns: A boolean, True if this is the unspecified address as defined in RFC 2373 2.5.2. (RQtis_unspecifiedRR(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRs cCs|jjo|jjS(uTest if the address is a loopback address. Returns: A boolean, True if the address is a loopback address as defined in RFC 2373 2.5.3. (RQt is_loopbackRR(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyR*s N(#RRR RRRRRRRtRqRRRRRRRRRRRRRRRReRNRURTRRRRRR(((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRdws>         N 0 >)     t_BaseV4c BseZdZdedZedZedZd ZdZ dZ dZ dZ dZ dZedZedZRS(uyBase IPv4 object. The following methods are used by IPv4 objects in both single IP addresses and networks. iiu 0123456789iiiiiiiiicCsd|_t|_dS(Ni(R\t IPV4LENGTHRB(RoR&((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRGs cCs t|S(N(R1(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRzKscCs|stdn|jd}t|dkrItd|ny#t|j|}t|dSWn)tk r}td||fnXdS(uTurn the given IP string into an integer for comparison. Args: ip_str: A string, the IP ip_str. Returns: The IP ip_str as an integer. Raises: AddressValueError: if ip_str isn't a valid IPv4 Address. uAddress cannot be emptyu.iuExpected 4 octets in %rubigu%s in %rN(RR2Rtmapt _parse_octetRR%(Rotip_strtoctetstbvstexc((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt_ip_int_from_stringNs cCs|stdn|jj|s@d}t||nt|dkrkd}t||nt|d}|dkr|ddkrd }t||n|d krtd |n|S( u Convert a decimal octet into an integer. Args: octet_str: A string, the number to parse. Returns: The octet as an integer. Raises: ValueError: if the octet isn't strictly a decimal from [0..255]. uEmpty octet not permittedu#Only decimal digits permitted in %riu$At most 3 characters permitted in %ri iiu0u3Ambiguous (octal/decimal) value in %r not permittediuOctet %d (> 255) not permitted(R%t_DECIMAL_DIGITSt issupersetRR(Rot octet_strR~t octet_int((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRhs  cCs#djdt|ddDS(uTurns a 32-bit integer into dotted decimal notation. Args: ip_int: An integer, the IP address. Returns: The IP address as a string in dotted decimal notation. u.css@|]6}tt|tr1tjd|dn|VqdS(s!BiN(R1RR$RR(t.0R((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pys siubig(tjoinR(RoR((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRs cCs|jd}t|dkry.x'|D]}t||jkr+tSq+WWntk rctSXx>t|D]0\}}|dkrq|||dkrqtSqqWtSyt|}Wntk rtSXd|ko|jkSS(uVerify that the netmask is valid. Args: netmask: A string, either a prefix or dotted decimal netmask. Returns: A boolean, True if the prefix represents a valid IPv4 netmask. u.iii( R2RRt_valid_mask_octetsROR%t enumerateRMRB(RoRRRtidxty((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRs"      cCs|jd}y5gtt|D]}||jkr"|^q"}Wntk rXtSXt|t|krutS|d|dkrtStS(uTest if the IP string is a hostmask (rather than a netmask). Args: ip_str: A string, the potential hostmask. Returns: A boolean, True if the IP string is a hostmask. u.ii(R2RRRR%RORRM(RoRR=Rtparts((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt _is_hostmasks 5 cCs|jS(N(RB(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt max_prefixlenscCs|jS(N(R\(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRAs( iiiiiiiii(RRR RREt frozensetRRRRzRRRRRRRRA(((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyR7s      $   R"cBseZdZdZedZedZedZedZedZ edZ edZ RS( u/Represent and manipulate single IPv4 Addresses.cCstj||tj||t|trI|j|||_dSt|tr|j|dt |}t |d|_dSt |}|j ||_dS(u Args: address: A string or integer representing the IP Additionally, an integer can be passed, so IPv4Address('192.0.2.1') == IPv4Address(3221225985). or, more generally IPv4Address(int(IPv4Address('192.0.2.1'))) == IPv4Address('192.0.2.1') Raises: AddressValueError: If ipaddress isn't a valid IPv4 address. Niubig( R?RRRR RR5R$Rt_compat_bytes_to_byte_valsRR1R(RoR&Rtaddr_str((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRs    cCs t|jS(u*The binary representation of this address.(R/R5(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pytpackedscCstd}||kS(uTest if the address is otherwise IETF reserved. Returns: A boolean, True if the address is within the reserved IPv4 Network range. u 240.0.0.0/4(R((Rotreserved_network((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRs cCsFtd}td}td}||kpE||kpE||kS(uTest if this address is allocated for private networks. Returns: A boolean, True if the address is reserved per RFC 1918. u 10.0.0.0/8u 172.16.0.0/12u192.168.0.0/16(R((Rot private_10t private_172t private_192((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRs      cCstd}||kS(uTest if the address is reserved for multicast use. Returns: A boolean, True if the address is multicast. See RFC 3171 for details. u 224.0.0.0/4(R((Rotmulticast_network((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyR!s cCstd}||kS(uTest if the address is unspecified. Returns: A boolean, True if this is the unspecified address as defined in RFC 5735 3. u0.0.0.0(R"(Rotunspecified_address((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyR-s cCstd}||kS(uTest if the address is a loopback address. Returns: A boolean, True if the address is a loopback per RFC 3330. u 127.0.0.0/8(R((Rotloopback_network((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyR9s cCstd}||kS(uTest if the address is reserved for link-local. Returns: A boolean, True if the address is link-local per RFC 3927. u169.254.0.0/16(R((Rotlinklocal_network((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRDs ( RRR RRRRRRRRR(((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyR"s %    R,cBsqeZdZdZdZdZdZedZedZ edZ edZ RS( cCst|tftrHtj||t|j|_|j|_ dSt |}tj||dt|dt |_|jj |_ |jj |_ |jj |_ dS(NiR*(RR$R R"RR(R5RRBR]R4RORR(RoR&R3((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRRs  cCs d|j|j|jjfS(Nu%s/%d(RR5RR(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRbscCsVtj||}| s%|tkr)|Sy|j|jkSWntk rQtSXdS(N(R"RqRkRR^RO(RoRpt address_equal((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRqfs cCsOtj||}|tkr"tSy|j|jkSWntk rJtSXdS(N(R"RtRkRR^RO(RoRpt address_less((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRtrs  cCs|j|jAt|jjAS(N(R5R]RRRQ(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyR}scCs t|jS(N(R"R5(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyR9scCsd|j|j|jfS(Nu%s/%s(RR5R](Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRscCsd|j|j|jfS(Nu%s/%s(RR5R(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRscCsd|j|j|jfS(Nu%s/%s(RR5R(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRs( RRRRRqRtRRR9RRR(((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyR,Ps   R(cBs eZdZeZedZRS(ueThis class represents and manipulates 32-bit IPv4 network + addresses.. Attributes: [examples for IPv4Network('192.0.2.0/27')] .network_address: IPv4Address('192.0.2.0') .hostmask: IPv4Address('0.0.0.31') .broadcast_address: IPv4Address('192.0.2.32') .netmask: IPv4Address('255.255.255.224') .prefixlen: 27 cCstj||tj||t|tr`t||_|j|_t|j |_ dSt|t rt||_|j|_t|j |_ dSt |}t|j |d|_t|dkr|djd}t|dkr|j|dr1t|j |d|_ nM|j|drjt|j |d|j A|_ ntd|d|jt|j |_q|j|dstd|dnt|d|_t|j|j|_ n'|j|_t|j|j|_ |rett|jt|j @|jkretd|qentt|jt|j @|_|j|jdkr|j|_ndS( uInstantiate a new IPv4 network object. Args: address: A string or integer representing the IP [& network]. '192.0.2.0/24' '192.0.2.0/255.255.255.0' '192.0.0.2/0.0.0.255' are all functionally the same in IPv4. Similarly, '192.0.2.1' '192.0.2.1/255.255.255.255' '192.0.2.1/32' are also functionaly equivalent. That is to say, failing to provide a subnetmask will create an object with a mask of /32. If the mask (portion after the / in the argument) is given in dotted quad form, it is treated as a netmask if it starts with a non-zero field (e.g. /255.0.0.0 == /8) and as a hostmask if it starts with a zero field (e.g. 0.255.255.255 == /8), with the single exception of an all-zero mask which is treated as a netmask == /0. If no mask is given, a default of /32 is used. Additionally, an integer can be passed, so IPv4Network('192.0.2.1') == IPv4Network(3221225985) or, more generally IPv4Interface(int(IPv4Interface('192.0.2.1'))) == IPv4Interface('192.0.2.1') Raises: AddressValueError: If ipaddress isn't a valid IPv4 address. NetmaskValueError: If the netmask isn't valid for an IPv4 address. ValueError: If strict is True and a network address is not supplied. Niiiu.iu%r is not a valid netmasku%s has host bits set(RRRdRR$R"RQRBR]RERR R4RRR2RRR!RRRR%RR(RoR&R*R3R((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRsV&    #    (RRR R"RRMR(((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyR(s t_BaseV6cBseZdZdedZdZedZdZdZ dZ dZ d d Z d Zed Zed ZRS(uyBase IPv6 object. The following methods are used by IPv6 objects in both single IP addresses and networks. iiiu0123456789ABCDEFabcdefcCsd|_t|_dS(Ni(R\t IPV6LENGTHRB(RoR&((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRs cCs|stdn|jd}d}t||kr[d||f}t|nd|dkryt|jj}Wn)tk r}td||fnX|jd|d ?d @|jd|d @n|jd }t||kr#d |d |f}t|nd}xYt d t|d D]>} || sC|dk rxd |}t|n| }qCqCW|dk r]|} t||d } |ds| d 8} | rd}t||qn|ds| d 8} | rd}t||qn|j| | } | d krd}t||jd |fqnt||jkrd}t||j|fn|dsd}t||n|dsd}t||nt|} d} d} yd} x5t | D]'} | d K} | |j || O} qW| d | K} x9t | dD]'} | d K} | |j || O} qRW| SWn)t k r}td||fnXdS(uTurn an IPv6 ip_str into an integer. Args: ip_str: A string, the IPv6 ip_str. Returns: An int, the IPv6 address Raises: AddressValueError: if ip_str isn't a valid IPv6 Address. uAddress cannot be emptyu:iu At least %d parts expected in %ru.iu%s in %ru%xiiiu!At most %d colons permitted in %ru At most one '::' permitted in %riu0Leading ':' only permitted as part of '::' in %ru1Trailing ':' only permitted as part of '::' in %ru/Expected at most %d other parts with '::' in %ru,Exactly %d parts expected without '::' in %rN( RR2RR"tpopR5RPt _HEXTET_COUNTRNR;t _parse_hextetR%(RoRRt _min_partsR~tipv4_intRt _max_partst skip_indexRtparts_hitparts_lot parts_skippedR((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRs             #     cCs]|jj|s%td|nt|dkrPd}t||nt|dS(u&Convert an IPv6 hextet string into an integer. Args: hextet_str: A string, the number to parse. Returns: The hextet as an integer. Raises: ValueError: if the input isn't strictly a hex number from [0..FFFF]. uOnly hex digits permitted in %riu$At most 4 characters permitted in %ri(t _HEX_DIGITSRR%RR(Rot hextet_strR~((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRs c Csd}d}d}d}xot|D]a\}}|dkrz|d7}|dkr\|}n||kr|}|}qq%d}d}q%W|dkr||}|t|kr|dg7}ndg|||+|dkrdg|}qn|S(uCompresses a list of hextets. Compresses a list of strings, replacing the longest continuous sequence of "0" in the list with "" and adding empty strings at the beginning or at the end of the string such that subsequently calling ":".join(hextets) will produce the compressed version of the IPv6 address. Args: hextets: A list of strings, the hextets to compress. Returns: A list of strings. iiu0iu(RR( Rothextetstbest_doublecolon_starttbest_doublecolon_lentdoublecolon_starttdoublecolon_lenRathextettbest_doublecolon_end((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt_compress_hextetss.         cCs|d krt|j}n||jkr<tdnd|}gtdddD]$}dt|||d!d^qY}|j|}dj|S( u,Turns a 128-bit integer into hexadecimal notation. Args: ip_int: An integer, the IP address. Returns: A string, the hexadecimal representation of the address. Raises: ValueError: The address is bigger than 128 bits of all ones. uIPv6 address is too largeu%032xii iu%xiu:N(RNRR5RER%R;RR(RoRthex_strRR((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRs  =cCst|tr!t|j}n-t|trBt|j}n t|}|j|}d|}gtdddD]}|||d!^qz}t|ttfrddj ||j fSdj |S(uExpand a shortened IPv6 address. Args: ip_str: A string, the IPv6 address. Returns: A string, the expanded IPv6 address. u%032xii iu%s/%du:( RR)R1RQR-R9RR;RdRR](RoRRRRR((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRzs   0cCs|jS(N(RB(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRscCs|jS(N(R\(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRAsN(RRR RRERRRRRRRRNRRzRRRA(((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyR s   h  /  R#cBseZdZdZedZedZedZedZedZ edZ edZ ed Z ed Z ed Zed ZRS( u/Represent and manipulate single IPv6 Addresses.cCstj||tj||t|trI|j|||_dSt|tr|j|dt |}t |d|_dSt |}|j ||_dS(uInstantiate a new IPv6 address object. Args: address: A string or integer representing the IP Additionally, an integer can be passed, so IPv6Address('2001:db8::') == IPv6Address(42540766411282592856903984951653826560) or, more generally IPv6Address(int(IPv6Address('2001:db8::'))) == IPv6Address('2001:db8::') Raises: AddressValueError: If address isn't a valid IPv6 address. Niubig( R?RRRR RR5R$RRRR1R(RoR&RR((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRs    cCs t|jS(u*The binary representation of this address.(R0R5(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyR.scCstd}||kS(uTest if the address is reserved for multicast use. Returns: A boolean, True if the address is a multicast address. See RFC 2373 2.7 for details. uff00::/8(R)(RoR((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyR3s cstdtdtdtdtdtdtdtdtd td td td td tdtdg}tfd|DS(uTest if the address is otherwise IETF reserved. Returns: A boolean, True if the address is within one of the reserved IPv6 Network ranges. u::/8u100::/8u200::/7u400::/6u800::/5u1000::/4u4000::/3u6000::/3u8000::/3uA000::/3uC000::/3uE000::/4uF000::/5uF800::/6uFE00::/9c3s|]}|kVqdS(N((RR(Ro(s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pys Qs(R)tany(Rot reserved_nets((Ros;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyR?s cCstd}||kS(uTest if the address is reserved for link-local. Returns: A boolean, True if the address is reserved per RFC 4291. u fe80::/10(R)(RoR((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRSs cCstd}||kS(u`Test if the address is reserved for site-local. Note that the site-local address space has been deprecated by RFC 3879. Use is_private to test if this address is in the space of unique local addresses as defined by RFC 4193. Returns: A boolean, True if the address is reserved per RFC 3513 2.5.6. u fec0::/10(R)(Rotsitelocal_network((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt is_site_local^s cCstd}||kS(uTest if this address is allocated for private networks. Returns: A boolean, True if the address is reserved per RFC 4193. ufc00::/7(R)(Rotprivate_network((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRms cCs |jdkS(uTest if the address is unspecified. Returns: A boolean, True if this is the unspecified address as defined in RFC 2373 2.5.2. i(R5(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRxs cCs |jdkS(uTest if the address is a loopback address. Returns: A boolean, True if the address is a loopback address as defined in RFC 2373 2.5.3. i(R5(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRs cCs(|jd?dkrdSt|jd@S(uReturn the IPv4 mapped address. Returns: If the IPv6 address is a v4 mapped address, return the IPv4 mapped address. Return None otherwise. i ilN(R5RNR"(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt ipv4_mappeds cCs@|jd?dkrdSt|jd?d@t|jd@fS(uTuple of embedded teredo IPs. Returns: Tuple of the (server, client) IPs or None if the address doesn't appear to be a teredo address (doesn't start with 2001::/32) i`i i@lN(R5RNR"(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pytteredos cCs,|jd?dkrdSt|jd?d@S(uReturn the IPv4 6to4 embedded address. Returns: The IPv4 6to4-embedded address if present or None if the address doesn't appear to contain a 6to4 embedded address. ipi iPlN(R5RNR"(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt sixtofours (RRR RRRRRRRRRRRRR(((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyR#s &      R-cBseZdZdZdZdZdZedZedZ edZ edZ ed Z ed Z RS( cCst|ttfrGtj||t|j|_|j|_ dSt |}tj||dt|dt |_|jj |_ |jj |_ |jj |_ dS(NiR*(RR$R R#RR)R5RRBR]R4RORR(RoR&R3((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRs  cCs d|j|j|jjfS(Nu%s/%d(RR5RR(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRscCsVtj||}| s%|tkr)|Sy|j|jkSWntk rQtSXdS(N(R#RqRkRR^RO(RoRpR((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRqs cCsOtj||}|tkr"tSy|j|jkSWntk rJtSXdS(N(R#RtRkRR^RO(RoRpR((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRts  cCs|j|jAt|jjAS(N(R5R]RRRQ(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRscCs t|jS(N(R#R5(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyR9scCsd|j|j|jfS(Nu%s/%s(RR5R](Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRscCsd|j|j|jfS(Nu%s/%s(RR5R(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRscCsd|j|j|jfS(Nu%s/%s(RR5R(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRscCs|jdko|jjS(Ni(R5RR(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRscCs|jdko|jjS(Ni(R5RR(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRs(RRRRRqRtRRR9RRRRR(((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyR-s   R)cBs8eZdZeZedZdZedZ RS(uvThis class represents and manipulates 128-bit IPv6 networks. Attributes: [examples for IPv6('2001:db8::1000/124')] .network_address: IPv6Address('2001:db8::1000') .hostmask: IPv6Address('::f') .broadcast_address: IPv6Address('2001:db8::100f') .netmask: IPv6Address('ffff:ffff:ffff:ffff:ffff:ffff:ffff:fff0') .prefixlen: 124 cCstj||tj||t|tr`t||_|j|_t|j |_ dSt|t rt||_|j|_t|j |_ dSt |}t|j |d|_t|dkr|j|drt|d|_q&td|dn |j|_t|j|j|_ |rtt|jt|j @|jkrtd|qntt|jt|j @|_|j|jdkr|j|_ndS(uInstantiate a new IPv6 Network object. Args: address: A string or integer representing the IPv6 network or the IP and prefix/netmask. '2001:db8::/128' '2001:db8:0000:0000:0000:0000:0000:0000/128' '2001:db8::' are all functionally the same in IPv6. That is to say, failing to provide a subnetmask will create an object with a mask of /128. Additionally, an integer can be passed, so IPv6Network('2001:db8::') == IPv6Network(42540766411282592856903984951653826560) or, more generally IPv6Network(int(IPv6Network('2001:db8::'))) == IPv6Network('2001:db8::') strict: A boolean. If true, ensure that we have been passed A true network address, eg, 2001:db8::1000/124 and not an IP address on a network, eg, 2001:db8::1/124. Raises: AddressValueError: If address isn't a valid IPv6 address. NetmaskValueError: If the netmask isn't valid for an IPv6 address. ValueError: If strict was True and a network address was not supplied. Niiiu%r is not a valid netmasku%s has host bits set(RRRdRR R#RQRBR]RERR$R4RRRRR!RR%RR(RoR&R*R3((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRs:      cCs@yt|}Wntk r$tSXd|ko=|jkSS(uVerify that the netmask/prefixlen is valid. Args: prefixlen: A string, the netmask in prefix length format. Returns: A boolean, True if the prefix represents a valid IPv6 netmask. i(RR%RORB(RoR((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyR]s  cCs|jjo|jjS(u`Test if the address is reserved for site-local. Note that the site-local address space has been deprecated by RFC 3879. Use is_private to test if this address is in the space of unique local addresses as defined by RFC 4193. Returns: A boolean, True if the address is reserved per RFC 3513 2.5.6. (RQRRR(Ro((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyRns ( RRR R#RRMRRRR(((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyR)s   K (5R t __future__Rt __version__RRR tlongt NameErrortunicodeR1RR$RRt from_bytesRR^RthasattrRDRRRR%RR!R'RMR+R.R/R0R4R:R>RLRZRiRmtobjectRnRyR?RdRR"R,R(RR#R-R)(((s;/usr/lib/python2.7/vendor-packages/pip/_vendor/ipaddress.pyt sl              $  #      8 0 9 'N;xDuJ