summaryrefslogtreecommitdiffstats
path: root/Lib/ipaddress.py
diff options
context:
space:
mode:
authoropavliuk <40970635+opavlyuk@users.noreply.github.com>2023-07-31 14:33:26 (GMT)
committerGitHub <noreply@github.com>2023-07-31 14:33:26 (GMT)
commitf22bf8e3cf899896cf587099d29290cb43aa9724 (patch)
tree59a8de0bcb07417bbe27a10d5613eac14d734c55 /Lib/ipaddress.py
parent520efecfc3aed34d3a44545c7cd872d1aea8c7dc (diff)
downloadcpython-f22bf8e3cf899896cf587099d29290cb43aa9724.zip
cpython-f22bf8e3cf899896cf587099d29290cb43aa9724.tar.gz
cpython-f22bf8e3cf899896cf587099d29290cb43aa9724.tar.bz2
gh-87799: Improve the textual representation of IPv4-mapped IPv6 addresses (#29345)
Represent IPv4-mapped IPv6 address as x:x:x:x:x:x:d.d.d.d, where the 'x's are the hexadecimal values of the six high-order 16-bit pieces of the address, and the 'd's are the decimal values of the four low-order 8-bit pieces of the address (standard IPv4 representation). --------- Co-authored-by: blurb-it[bot] <43283697+blurb-it[bot]@users.noreply.github.com> Co-authored-by: Andrew Svetlov <andrew.svetlov@gmail.com>
Diffstat (limited to 'Lib/ipaddress.py')
-rw-r--r--Lib/ipaddress.py34
1 files changed, 33 insertions, 1 deletions
diff --git a/Lib/ipaddress.py b/Lib/ipaddress.py
index af1d5c4..f5aba43 100644
--- a/Lib/ipaddress.py
+++ b/Lib/ipaddress.py
@@ -1923,8 +1923,40 @@ class IPv6Address(_BaseV6, _BaseAddress):
self._ip = self._ip_int_from_string(addr_str)
+ def _explode_shorthand_ip_string(self):
+ ipv4_mapped = self.ipv4_mapped
+ if ipv4_mapped is None:
+ long_form = super()._explode_shorthand_ip_string()
+ else:
+ prefix_len = 30
+ raw_exploded_str = super()._explode_shorthand_ip_string()
+ long_form = "%s%s" % (raw_exploded_str[:prefix_len], str(ipv4_mapped))
+ return long_form
+
+ def _ipv4_mapped_ipv6_to_str(self):
+ """Return convenient text representation of IPv4-mapped IPv6 address
+
+ See RFC 4291 2.5.5.2, 2.2 p.3 for details.
+
+ Returns:
+ A string, 'x:x:x:x:x:x:d.d.d.d', where the 'x's are the hexadecimal values of
+ the six high-order 16-bit pieces of the address, and the 'd's are
+ the decimal values of the four low-order 8-bit pieces of the
+ address (standard IPv4 representation) as defined in RFC 4291 2.2 p.3.
+
+ """
+ ipv4_mapped = self.ipv4_mapped
+ if ipv4_mapped is None:
+ raise AddressValueError("Can not apply to non-IPv4-mapped IPv6 address %s" % str(self))
+ high_order_bits = self._ip >> 32
+ return "%s:%s" % (self._string_from_ip_int(high_order_bits), str(ipv4_mapped))
+
def __str__(self):
- ip_str = super().__str__()
+ ipv4_mapped = self.ipv4_mapped
+ if ipv4_mapped is None:
+ ip_str = super().__str__()
+ else:
+ ip_str = self._ipv4_mapped_ipv6_to_str()
return ip_str + '%' + self._scope_id if self._scope_id else ip_str
def __hash__(self):