lVc@sdZddlmZddlZddlZdZefZyeefZWne k r`nXy e Z Wn)e k re Z e e kstnXdddkrdZn dZy ejZWnek rd ZnXd Zeed r d Zn d ZddZdefdYZdZdZdefdYZdefdYZdZedZ dZ!dZ"dZ#dZ$dZ%dZ&d Z'd!Z(d"Z)d#Z*d$efd%YZ+d&e+fd'YZ,d(e+fd)YZ-d*efd+YZ.d,e.e,fd-YZ/d.e/fd/YZ0d0e.e-fd1YZ1d2efd3YZ2e2e/_3d4efd5YZ4d6e4e,fd7YZ5d8e5fd9YZ6d:e4e-fd;YZ7d<efd=YZ8e8e5_3dS(>uA fast, lightweight IPv4/IPv6 manipulation library in Python. This library is used to create/poke/manipulate IPv4 and IPv6 addresses and networks. i(tunicode_literalsNu1.0.16ticCs|S(N((tbyt((s-/usr/lib/python2.7/site-packages/ipaddress.pyt_compat_bytes_to_byte_valsscCs'g|D]}tjd|d^qS(Ns!Bi(tstructtunpack(Rtb((s-/usr/lib/python2.7/site-packages/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/site-packages/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@lIl (RR RRterrortpacktNotImplementedError(tintvaltlengthR ((s-/usr/lib/python2.7/site-packages/ipaddress.pyt_compat_to_bytes0s  u bit_lengthcCs |jS(N(t bit_length(ti((s-/usr/lib/python2.7/site-packages/ipaddress.pyt_compat_bit_length?scCs/x(tjD]}||?dkr |Sq WdS(Ni(t itertoolstcount(RR ((s-/usr/lib/python2.7/site-packages/ipaddress.pyRBsiccs>|dkst|}x||kr9|V||7}qWdS(Ni(R(tstarttendtstepR((s-/usr/lib/python2.7/site-packages/ipaddress.pyt _compat_rangeHs t_TotalOrderingMixincBsDeZdZdZdZdZdZdZdZRS(cCs tdS(N(R(tselftother((s-/usr/lib/python2.7/site-packages/ipaddress.pyt__eq__WscCs$|j|}|tkrtS| S(N(R!tNotImplemented(RR tequal((s-/usr/lib/python2.7/site-packages/ipaddress.pyt__ne__Zs cCs tdS(N(R(RR ((s-/usr/lib/python2.7/site-packages/ipaddress.pyt__lt__`scCs3|j|}|tks"| r/|j|S|S(N(R%R"R!(RR tless((s-/usr/lib/python2.7/site-packages/ipaddress.pyt__le__cs cCsI|j|}|tkrtS|j|}|tkr>tS|pG| S(N(R%R"R!(RR R&R#((s-/usr/lib/python2.7/site-packages/ipaddress.pyt__gt__is  cCs$|j|}|tkrtS| S(N(R%R"(RR R&((s-/usr/lib/python2.7/site-packages/ipaddress.pyt__ge__rs (( t__name__t __module__t __slots__R!R$R%R'R(R)(((s-/usr/lib/python2.7/site-packages/ipaddress.pyRPs     i itAddressValueErrorcBseZdZRS(u%A Value Error related to the address.(R*R+t__doc__(((s-/usr/lib/python2.7/site-packages/ipaddress.pyR-}stNetmaskValueErrorcBseZdZRS(u%A Value Error related to the netmask.(R*R+R.(((s-/usr/lib/python2.7/site-packages/ipaddress.pyR/scCsyt|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 IPv4AddressR-R/t IPv6AddressRtbytest ValueError(taddress((s-/usr/lib/python2.7/site-packages/ipaddress.pyt ip_addresss cCsyt||SWnttfk r*nXyt||SWnttfk rUnXt|trxtd|ntd|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. ux%r does not appear to be an IPv4 or IPv6 network. 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 networkN(t IPv4NetworkR-R/t IPv6NetworkRR2R3(R4tstrict((s-/usr/lib/python2.7/site-packages/ipaddress.pyt ip_networks cCsdyt|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 IPv4InterfaceR-R/t IPv6InterfaceR3(R4((s-/usr/lib/python2.7/site-packages/ipaddress.pyt ip_interfacescCsAyt|ddSWn&tjtfk r<tdnXdS(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(RRRt OverflowErrorR3(R4((s-/usr/lib/python2.7/site-packages/ipaddress.pytv4_int_to_packedscCsAyt|ddSWn&tjtfk r<tdnXdS(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(RRRR=R3(R4((s-/usr/lib/python2.7/site-packages/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_strtsplittlenR-(R4taddr((s-/usr/lib/python2.7/site-packages/ipaddress.pyt_split_optional_netmasksccslt|}t|}}x>|D]6}|j|jdkrS||fV|}n|}q#W||fVdS(uFind a sequence of sorted deduplicated IPv#Address. Args: addresses: a list of IPv#Address objects. Yields: A tuple containing the first and last IP addresses in the sequence. iN(titertnextt_ip(t addressestittfirsttlasttip((s-/usr/lib/python2.7/site-packages/ipaddress.pyt_find_address_ranges     cCs,|dkr|St|t||d@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(tminR(tnumbertbits((s-/usr/lib/python2.7/site-packages/ipaddress.pyt_count_righthand_zero_bits0s ccsKt|tot|ts-tdn|j|jkrXtd||fn||krstdn|jdkrt}n$|jdkrt}n td|j}|j}|j}xz||krFt t ||t ||dd}||||f}|V|d|>7}|d|j krPqqWdS( 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 versioniN( Rt _BaseAddresst TypeErrortversionR3R6R7t_max_prefixlenRGRNRQRt _ALL_ONES(RJRKRLtip_bitst first_inttlast_inttnbitstnet((s-/usr/lib/python2.7/site-packages/ipaddress.pytsummarize_address_range@s0       ccst|}i}xm|r|j}|j}|j|}|dkr[||| [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. N( tlisttpoptsupernettgettNonetappendtsortedtvaluestbroadcast_address(RHtto_mergetsubnetsR[R_texistingRK((s-/usr/lib/python2.7/site-packages/ipaddress.pyt_collapse_addresses_internalws$         cCsg}g}g}x2|D]*}t|trw|rg|dj|jkrgtd||dfn|j|q|j|jkr|r|dj|jkrtd||dfny|j|jWqCtk r|j|j qCXq|r6|dj|jkr6td||dfn|j|qWt t |}|rx3t |D]"\}}|j t||qlWnt||S(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. iu%%s and %s are not of the same version(RRRt_versionRSRbt _prefixlenRURLtAttributeErrortnetwork_addressRctsetRMtextendR\Ri(RHtaddrstipstnetsRLRJRK((s-/usr/lib/python2.7/site-packages/ipaddress.pytcollapse_addressess4  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. (Rt _BaseNetworkt_get_networks_keyRRt_get_address_keyR"(tobj((s-/usr/lib/python2.7/site-packages/ipaddress.pytget_mixed_type_keys   t_IPAddressBasecBseZdZd ZedZedZedZedZdZ dZ e dZ e dZ e d Ze d Ze d Zd ZRS(uThe mother class.cCs |jS(u:Return the longhand version of the IP address as a string.(t_explode_shorthand_ip_string(R((s-/usr/lib/python2.7/site-packages/ipaddress.pytexplodedscCs t|S(u;Return the shorthand version of the IP address as a string.(R@(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyt compressedscCs |jS(uIThe name of the reverse DNS pointer for the IP address, e.g.: >>> ipaddress.ip_address("127.0.0.1").reverse_pointer '1.0.0.127.in-addr.arpa' >>> ipaddress.ip_address("2001:db8::1").reverse_pointer '1.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.8.b.d.0.1.0.0.2.ip6.arpa' (t_reverse_pointer(R((s-/usr/lib/python2.7/site-packages/ipaddress.pytreverse_pointers cCs#dt|f}t|dS(Nu%200s has no version specified(ttypeR(Rtmsg((s-/usr/lib/python2.7/site-packages/ipaddress.pyRTscCsi|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(R-RjRVRU(RR4R((s-/usr/lib/python2.7/site-packages/ipaddress.pyt_check_int_addresss cCsDt|}||kr@d}t|||||jfndS(Nu~%r (len %d != %d) is not permitted as an IPv%d address. Did you pass in a bytes (str in Python 2) instead of a unicode object?(RBR-Rj(RR4t expected_lent address_lenR((s-/usr/lib/python2.7/site-packages/ipaddress.pyt_check_packed_address s    cCs|j|j|?AS(uTurn the prefix length into a bitwise netmask Args: prefixlen: An integer, the prefix length. Returns: An integer. (RV(tclst prefixlen((s-/usr/lib/python2.7/site-packages/ipaddress.pyt_ip_int_from_prefix+s c Cst||j}|j|}||?}d|>d}||kr{|jd}t||d}d}t||n|S(uReturn prefix length from the bitwise netmask. Args: ip_int: An integer, the netmask in expanded bitwise format Returns: An integer, the prefix length. Raises: ValueError: If the input intermingles zeroes & ones iiubigu&Netmask pattern %r mixes zeroes & ones(RQRURR3( Rtip_intttrailing_zeroesRt leading_onestall_onestbyteslentdetailsR((s-/usr/lib/python2.7/site-packages/ipaddress.pyt_prefix_from_ip_int8s      cCsd|}t|dS(Nu%r is not a valid netmask(R/(Rt netmask_strR((s-/usr/lib/python2.7/site-packages/ipaddress.pyt_report_invalid_netmaskQs cCstjj|s"|j|nyt|}Wntk rR|j|nXd|kom|jkns|j|n|S(u Return prefix length from a numeric string Args: prefixlen_str: The string to be converted Returns: An integer, the prefix length. Raises: NetmaskValueError: If the input is not a valid netmask i(t_BaseV4t_DECIMAL_DIGITSt issupersetRtintR3RU(Rt prefixlen_strR((s-/usr/lib/python2.7/site-packages/ipaddress.pyt_prefix_from_prefix_stringVs cCsy|j|}Wntk r3|j|nXy|j|SWntk rXnX||jN}y|j|SWntk r|j|nXdS(uTurn a netmask/hostmask string into a prefix length Args: ip_str: The netmask/hostmask to be converted Returns: An integer, the prefix length. Raises: NetmaskValueError: If the input is not a valid netmask/hostmask N(t_ip_int_from_stringR-RRR3RV(Rtip_strR((s-/usr/lib/python2.7/site-packages/ipaddress.pyt_prefix_from_ip_stringos    cCs|jt|ffS(N(t __class__R@(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyt __reduce__s((R*R+R.R,tpropertyR{R|R~RTRRt classmethodRRRRRR(((s-/usr/lib/python2.7/site-packages/ipaddress.pyRys   "RRcBsneZdZd ZdZdZdZdZdZdZ dZ 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. cCs|jS(N(RG(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyt__int__scCs?y&|j|jko$|j|jkSWntk r:tSXdS(N(RGRjRlR"(RR ((s-/usr/lib/python2.7/site-packages/ipaddress.pyR!s  cCst|tstSt|ts;td||fn|j|jkrftd||fn|j|jkr|j|jkStS(Nu"%s and %s are not of the same typeu%%s and %s are not of the same version(RRyR"RRRSRjRGtFalse(RR ((s-/usr/lib/python2.7/site-packages/ipaddress.pyR%scCs*t|tstS|jt||S(N(RR R"RR(RR ((s-/usr/lib/python2.7/site-packages/ipaddress.pyt__add__scCs*t|tstS|jt||S(N(RR R"RR(RR ((s-/usr/lib/python2.7/site-packages/ipaddress.pyt__sub__scCsd|jjt|fS(Nu%s(%r)(RR*R@(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyt__repr__scCst|j|jS(N(R@t_string_from_ip_intRG(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyt__str__scCsttt|jS(N(thashthexRRG(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyt__hash__scCs |j|fS(N(Rj(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRvscCs|j|jffS(N(RRG(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRs((R*R+R.R,RR!R%RRRRRRvR(((s-/usr/lib/python2.7/site-packages/ipaddress.pyRRs         RtcBseZdZdZdZdZdZdZdZdZ dZ d Z d Z d Z ed Zed ZedZedZedZedZedZedZdZdZdZdd#dZdd#dZedZdZdZedZ edZ!edZ"ed Z#ed!Z$ed"Z%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(RR4((s-/usr/lib/python2.7/site-packages/ipaddress.pyt__init__scCsd|jjt|fS(Nu%s(%r)(RR*R@(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRscCsd|j|jfS(Nu%s/%d(RmR(R((s-/usr/lib/python2.7/site-packages/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(RRmReRt_address_class(Rtnetworkt broadcasttx((s-/usr/lib/python2.7/site-packages/ipaddress.pythostssccsNt|j}t|j}x)t||dD]}|j|Vq2WdS(Ni(RRmReRR(RRRR((s-/usr/lib/python2.7/site-packages/ipaddress.pyt__iter__scCst|j}t|j}|dkrT|||krCtn|j||S|d7}|||krwtn|j||SdS(Nii(RRmRet IndexErrorR(RtnRR((s-/usr/lib/python2.7/site-packages/ipaddress.pyt __getitem__s    cCst|tstSt|ts;td||fn|j|jkrftd||fn|j|jkr|j|jkS|j|jkr|j|jkStS(Nu"%s and %s are not of the same typeu%%s and %s are not of the same version( RRyR"RtRSRjRmtnetmaskR(RR ((s-/usr/lib/python2.7/site-packages/ipaddress.pyR%scCs]yD|j|jkoB|j|jkoBt|jt|jkSWntk rXtSXdS(N(RjRmRRRlR"(RR ((s-/usr/lib/python2.7/site-packages/ipaddress.pyR!s   cCs tt|jt|jAS(N(RRRmR(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRscCs`|j|jkrtSt|tr)tSt|jt|jkoYt|jkSSdS(N(RjRRRtRRmRGRe(RR ((s-/usr/lib/python2.7/site-packages/ipaddress.pyt __contains__s  cCs:|j|kp9|j|kp9|j|kp9|j|kS(u*Tell if self is partly contained in other.(RmRe(RR ((s-/usr/lib/python2.7/site-packages/ipaddress.pytoverlaps)scCsW|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(RjRSRmR(RR ((s-/usr/lib/python2.7/site-packages/ipaddress.pytcompare_networkss!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(). (RjRmR(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRusic cs0|j|jkr|VdS|dk rp||jkrEtdn|dkr`tdn||j}n|dkrtdn|j|}||jkrtd||fnt|j}t|j}t|jd|?}x4t|||D] }|j ||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 %s( RkRURaR3RRmReRRR( Rtprefixlen_difft new_prefixt new_prefixlenRRRtnew_addrtcurrent((s-/usr/lib/python2.7/site-packages/ipaddress.pyRgs,    cCs|jdkr|S|dk rh||jkr=tdn|dkrXtdn|j|}n|j|}|dkrtd|j|fn|jt|jt|j|>@|fS(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 %dN(RkRaR3RRRRmR(RRRR((s-/usr/lib/python2.7/site-packages/ipaddress.pyR_s     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. (Rmt is_multicastRe(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRAs cCsp|j|jkrtSt|drVt|drV|j|jkoU|j|jkStdt|dS(Nunetwork_addressubroadcast_addressu9Unable to test subnet containment with element of type %s(RjRthasattrRmReRSR(RR ((s-/usr/lib/python2.7/site-packages/ipaddress.pyRMscCsp|j|jkrtSt|drVt|drV|j|jkoU|j|jkStdt|dS(Nunetwork_addressubroadcast_addressu9Unable to test subnet containment with element of type %s(RjRRRmReRSR(RR ((s-/usr/lib/python2.7/site-packages/ipaddress.pyt supernet_of[scCs|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. (Rmt is_reservedRe(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRis cCs|jjo|jjS(uTest if the address is reserved for link-local. Returns: A boolean, True if the address is reserved per RFC 4291. (Rmt is_link_localRe(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRus cCs|jjo|jjS(uTest if this address is allocated for private networks. Returns: A boolean, True if the address is reserved per iana-ipv4-special-registry or iana-ipv6-special-registry. (Rmt is_privateRe(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRs cCs|j S(uTest if this address is allocated for public networks. Returns: A boolean, True if the address is not reserved per iana-ipv4-special-registry or iana-ipv6-special-registry. (R(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyt is_globals 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. (Rmtis_unspecifiedRe(R((s-/usr/lib/python2.7/site-packages/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. (Rmt is_loopbackRe(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRs N(&R*R+R.RRRRRRR%R!RRRRReRRRRRRRRRRuRaRgR_RRRRRRRRR(((s-/usr/lib/python2.7/site-packages/ipaddress.pyRtsD          K 0 5)       Rc BseZdZdZdZdedZedZeddddd d d d d g Z eZ iZ dZ e dZe dZe dZe dZdZdZedZedZRS(uyBase IPv4 object. The following methods are used by IPv4 objects in both single IP addresses and networks. iiiu 0123456789iiiiiiiiicCs t|S(N(R@(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRzscCs||jkrt|tr'|}n6y|j|}Wn tk r\|j|}nXt|j|}||f|j| 255) not permitted(R3RRRBR(Rt octet_strRt octet_int((s-/usr/lib/python2.7/site-packages/ipaddress.pyRs 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(R@RR2RR(t.0R((s-/usr/lib/python2.7/site-packages/ipaddress.pys -siubig(tjoinR(RR((s-/usr/lib/python2.7/site-packages/ipaddress.pyR"s 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(RARRt_valid_mask_octetsR3RRBtTrue(RRRPRtparts((s-/usr/lib/python2.7/site-packages/ipaddress.pyt _is_hostmask2s 5 cCs3t|jdddd}dj|dS(uReturn the reverse DNS pointer name for the IPv4 address. This implements the method described in RFC1035 3.5. u.Niu .in-addr.arpa(R@RAR(Rtreverse_octets((s-/usr/lib/python2.7/site-packages/ipaddress.pyR}Gs"cCs|jS(N(RU(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyt max_prefixlenPscCs|jS(N(Rj(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRTTs((R*R+R.R,Rjt IPV4LENGTHRVt frozensetRRRURRzRRRRRRR}RRRT(((s-/usr/lib/python2.7/site-packages/ipaddress.pyRs" ' %  R0cBseZdZd ZdZedZedZedZedZ edZ ed Z ed Z RS( u/Represent and manipulate single IPv4 Addresses.u_ipu __weakref__cCst|tr)|j|||_dSt|trj|j|dt|}t|d|_dSt|}d|krt d|n|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. Niubigu/uUnexpected '/' in %r( RR RRGR2RRRR@R-R(RR4tbvstaddr_str((s-/usr/lib/python2.7/site-packages/ipaddress.pyR_s     cCs t|jS(u*The binary representation of this address.(R>RG(R((s-/usr/lib/python2.7/site-packages/ipaddress.pytpackedscCs||jjkS(uTest if the address is otherwise IETF reserved. Returns: A boolean, True if the address is within the reserved IPv4 Network range. (t _constantst_reserved_network(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRs cs tfdjjDS(uTest if this address is allocated for private networks. Returns: A boolean, True if the address is reserved per iana-ipv4-special-registry. c3s|]}|kVqdS(N((RR[(R(s-/usr/lib/python2.7/site-packages/ipaddress.pys s(tanyRt_private_networks(R((Rs-/usr/lib/python2.7/site-packages/ipaddress.pyRs cCs||jjkS(uTest if the address is reserved for multicast use. Returns: A boolean, True if the address is multicast. See RFC 3171 for details. (Rt_multicast_network(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRs cCs||jjkS(uTest if the address is unspecified. Returns: A boolean, True if this is the unspecified address as defined in RFC 5735 3. (Rt_unspecified_address(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRs cCs||jjkS(uTest if the address is a loopback address. Returns: A boolean, True if the address is a loopback per RFC 3330. (Rt_loopback_network(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRscCs||jjkS(uTest if the address is reserved for link-local. Returns: A boolean, True if the address is link-local per RFC 3927. (Rt_linklocal_network(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRs(u_ipu __weakref__( R*R+R.R,RRRRRRRRR(((s-/usr/lib/python2.7/site-packages/ipaddress.pyR0Ys $     R:cBszeZdZdZdZdZdZejZe dZ e dZ e dZ e dZ RS( cCs;t|ttfrGtj||t|j|_|j|_ dSt|t rtj||dt |dkrt |d|_ n |j|_ t|dt |_|jj|_|jj|_dSt|}tj||dt|dt |_|jj |_ |jj|_|jj|_dS(NiiR8(RR2R R0RR6RGRRURkttupleRBRRRRRD(RR4RC((s-/usr/lib/python2.7/site-packages/ipaddress.pyRs(   cCs d|j|j|jjfS(Nu%s/%d(RRGRR(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRscCsVtj||}| s%|tkr)|Sy|j|jkSWntk rQtSXdS(N(R0R!R"RRlR(RR t address_equal((s-/usr/lib/python2.7/site-packages/ipaddress.pyR!s cCsOtj||}|tkr"tSy|j|jkSWntk rJtSXdS(N(R0R%R"RRlR(RR t address_less((s-/usr/lib/python2.7/site-packages/ipaddress.pyR%s  cCs|j|jAt|jjAS(N(RGRkRRRm(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRscCs t|jS(N(R0RG(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRLscCsd|j|j|jfS(Nu%s/%s(RRGRk(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyR scCsd|j|j|jfS(Nu%s/%s(RRGR(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRscCsd|j|j|jfS(Nu%s/%s(RRGR(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRs(R*R+RRR!R%RRyRRRLRRR(((s-/usr/lib/python2.7/site-packages/ipaddress.pyR:s    R6cBs/eZdZeZedZedZRS(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||t|ttfrVt||_|j|j\|_ |_ dSt|t rt |dkr|d}n |j}t|d|_|j|\|_ |_ t |j}|t |j @|kr|rtd|qt|t |j @|_ndSt|}t|j|d|_t |dkrf|d}n |j}|j|\|_ |_ |rtt |jt |j @|jkrtd|qntt |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 functionally 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. Niiu%s has host bits seti(RtRRR R2R0RmRRURRkRRBRR3RDRRR(RR4R8RRRC((s-/usr/lib/python2.7/site-packages/ipaddress.pyR*sB%      cCs3|jtdko'|jtdk o2|j S(uTest if this address is allocated for public networks. Returns: A boolean, True if the address is not reserved per iana-ipv4-special-registry. u 100.64.0.0/10(RmR6ReR(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRs ( R*R+R.R0RRRRR(((s-/usr/lib/python2.7/site-packages/ipaddress.pyR6s  Ut_IPv4ConstantscBseZedZedZedZededededededededed ed ed ed ed edgZed ZedZ RS(u169.254.0.0/16u 127.0.0.0/8u 224.0.0.0/4u 0.0.0.0/8u 10.0.0.0/8u 172.16.0.0/12u 192.0.0.0/29u192.0.0.170/31u 192.0.2.0/24u192.168.0.0/16u 198.18.0.0/15u198.51.100.0/24u203.0.113.0/24u 240.0.0.0/4u255.255.255.255/32u0.0.0.0( R*R+R6RRRRRR0R(((s-/usr/lib/python2.7/site-packages/ipaddress.pyRs&                 t_BaseV6cBseZdZdZdZdedZdZedZ eZ iZ e dZ e dZe dZe d Ze dd Zd Zd Zed ZedZRS(uyBase IPv6 object. The following methods are used by IPv6 objects in both single IP addresses and networks. iiiiu0123456789ABCDEFabcdefcCsl||jkrat|tr'|}n|j|}t|j|}||f|j|} || 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( R-RARBR0R^RGRbt _HEXTET_COUNTRaRtranget _parse_hextetR3(RRRt _min_partsRtipv4_intRt _max_partst skip_indexRtparts_hitparts_lot parts_skippedR((s-/usr/lib/python2.7/site-packages/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_DIGITSRR3RBR(Rt hextet_strR((s-/usr/lib/python2.7/site-packages/ipaddress.pyR=s 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(t enumerateRB( Rthextetstbest_doublecolon_starttbest_doublecolon_lentdoublecolon_starttdoublecolon_lentindexthextettbest_doublecolon_end((s-/usr/lib/python2.7/site-packages/ipaddress.pyt_compress_hextetsWs.         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(RaRRGRVR3RRR(RRthex_strRR((s-/usr/lib/python2.7/site-packages/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:( RR7R@RmR;RLRRRtRRk(RRRRRR((s-/usr/lib/python2.7/site-packages/ipaddress.pyRzs   0cCs3|jdddjdd}dj|dS(uReturn the reverse DNS pointer name for the IPv6 address. This implements the method described in RFC3596 2.5. Niu:uu.u .ip6.arpa(R{treplaceR(Rt reverse_chars((s-/usr/lib/python2.7/site-packages/ipaddress.pyR}s"cCs|jS(N(RU(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRscCs|jS(N(Rj(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRTs(N(R*R+R.R,Rjt IPV6LENGTHRVRRRRURRRRRRRaRRzR}RRRT(((s-/usr/lib/python2.7/site-packages/ipaddress.pyRs$ i0  R1cBseZdZdZdZedZedZedZedZ edZ ed Z ed Z ed Z ed Zed ZedZedZRS(u/Represent and manipulate single IPv6 Addresses.u_ipu __weakref__cCst|tr)|j|||_dSt|trj|j|dt|}t|d|_dSt|}d|krt d|n|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. Niubigu/uUnexpected '/' in %r( RR RRGR2RRRR@R-R(RR4RR((s-/usr/lib/python2.7/site-packages/ipaddress.pyRs     cCs t|jS(u*The binary representation of this address.(R?RG(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRscCs||jjkS(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. (RR(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRs cs tfdjjDS(uTest if the address is otherwise IETF reserved. Returns: A boolean, True if the address is within one of the reserved IPv6 Network ranges. c3s|]}|kVqdS(N((RR(R(s-/usr/lib/python2.7/site-packages/ipaddress.pys s(RRt_reserved_networks(R((Rs-/usr/lib/python2.7/site-packages/ipaddress.pyRs cCs||jjkS(uTest if the address is reserved for link-local. Returns: A boolean, True if the address is reserved per RFC 4291. (RR(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRscCs||jjkS(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. (Rt_sitelocal_network(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyt is_site_locals cs tfdjjDS(uTest if this address is allocated for private networks. Returns: A boolean, True if the address is reserved per iana-ipv6-special-registry. c3s|]}|kVqdS(N((RR[(R(s-/usr/lib/python2.7/site-packages/ipaddress.pys 2s(RRR(R((Rs-/usr/lib/python2.7/site-packages/ipaddress.pyR)s cCs|j S(uTest if this address is allocated for public networks. Returns: A boolean, true if the address is not reserved per iana-ipv6-special-registry. (R(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyR4s 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(RG(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyR?s 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(RG(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRJs 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 iIN(RGRaR0(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyt ipv4_mappedUs 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@IN(RGRaR0(R((s-/usr/lib/python2.7/site-packages/ipaddress.pytteredobs 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 iPIN(RGRaR0(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyt sixtofourqs (u_ipu __weakref__(R*R+R.R,RRRRRRR RRRRRRR(((s-/usr/lib/python2.7/site-packages/ipaddress.pyR1s %        R;cBseZdZdZdZdZdZejZe dZ e dZ e dZ e dZ e d Ze d ZRS( cCs;t|ttfrGtj||t|j|_|j|_ dSt|t rtj||dt |dkrt |d|_ n |j|_ t|dt |_|jj|_|jj|_dSt|}tj||dt|dt |_|jj|_|jj |_ |jj|_dS(NiiR8(RR2R R1RR7RGRRURkRRBRRRRRD(RR4RC((s-/usr/lib/python2.7/site-packages/ipaddress.pyRs(   cCs d|j|j|jjfS(Nu%s/%d(RRGRR(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRscCsVtj||}| s%|tkr)|Sy|j|jkSWntk rQtSXdS(N(R1R!R"RRlR(RR R((s-/usr/lib/python2.7/site-packages/ipaddress.pyR!s cCsOtj||}|tkr"tSy|j|jkSWntk rJtSXdS(N(R1R%R"RRlR(RR R((s-/usr/lib/python2.7/site-packages/ipaddress.pyR%s  cCs|j|jAt|jjAS(N(RGRkRRRm(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRscCs t|jS(N(R1RG(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRLscCsd|j|j|jfS(Nu%s/%s(RRGRk(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRscCsd|j|j|jfS(Nu%s/%s(RRGR(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRscCsd|j|j|jfS(Nu%s/%s(RRGR(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRscCs|jdko|jjS(Ni(RGRR(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRscCs|jdko|jjS(Ni(RGRR(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyRs(R*R+RRR!R%RRyRRRLRRRRR(((s-/usr/lib/python2.7/site-packages/ipaddress.pyR;s    R7cBs8eZdZeZedZdZedZ 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||t|ttfrVt||_|j|j\|_ |_ dSt|t rt |dkr|d}n |j}|j|\|_ |_ t|d|_t |j}|t |j @|kr|rtd|qt|t |j @|_ndSt|}t|j|d|_t |dkrf|d}n |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. Niiu%s has host bits seti(RtRRR2R R1RmRRURRkRRBRR3RDRRR(RR4R8RRRC((s-/usr/lib/python2.7/site-packages/ipaddress.pyRsB       ccsRt|j}t|j}x-t|d|dD]}|j|Vq6WdS(uGenerate Iterator over usable hosts in a network. This is like __iter__ except it doesn't return the Subnet-Router anycast address. iN(RRmReRR(RRRR((s-/usr/lib/python2.7/site-packages/ipaddress.pyR4 scCs|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. (RmR Re(R((s-/usr/lib/python2.7/site-packages/ipaddress.pyR @ s ( R*R+R.R1RRRRRR (((s-/usr/lib/python2.7/site-packages/ipaddress.pyR7s   O t_IPv6ConstantscBseZedZedZedededededededed ed edg Zed ed ed ededededededededededededgZedZRS(u fe80::/10uff00::/8u::1/128u::/128u ::ffff:0:0/96u100::/64u 2001::/23u 2001:2::/48u 2001:db8::/32u 2001:10::/28ufc00::/7u::/8u100::/8u200::/7u400::/6u800::/5u1000::/4u4000::/3u6000::/3u8000::/3uA000::/3uC000::/3uE000::/4uF000::/5uF800::/6uFE00::/9u fec0::/10(R*R+R7RRRR R (((s-/usr/lib/python2.7/site-packages/ipaddress.pyRP s*           (9R.t __future__RRRt __version__RR tlongt NameErrortunicodeR@tstrR2RRt from_bytesRRlRRRRtobjectRRR R3R-R/R5RR9R<R>R?RDRMRQR\RiRsRxRyRRRtRR0R:R6RRRR1R;R7R(((s-/usr/lib/python2.7/site-packages/ipaddress.pyt sx              ) $ $ #      7 1 6 =pRr V{!