summaryrefslogtreecommitdiff
path: root/dns/ipv6.py
diff options
context:
space:
mode:
authorBob Halley <halley@nominum.com>2011-07-12 19:00:13 -0700
committerBob Halley <halley@nominum.com>2011-07-12 19:00:13 -0700
commitc1bc09d236fe7784a303cd601a8a973d1758e3a6 (patch)
tree3381a21cb972701b7b1e47e3c538048680efe02c /dns/ipv6.py
parente189940dec42495869483f71b0be119bf8956d60 (diff)
downloaddnspython-c1bc09d236fe7784a303cd601a8a973d1758e3a6.tar.gz
more v6 strictness; more unit tests
Diffstat (limited to 'dns/ipv6.py')
-rw-r--r--dns/ipv6.py15
1 files changed, 4 insertions, 11 deletions
diff --git a/dns/ipv6.py b/dns/ipv6.py
index 78fe82e..69db34a 100644
--- a/dns/ipv6.py
+++ b/dns/ipv6.py
@@ -89,7 +89,7 @@ def inet_ntoa(address):
hex = ':'.join(chunks)
return hex
-_v4_ending = re.compile(r'(.*):(\d+)\.(\d+)\.(\d+)\.(\d+)$')
+_v4_ending = re.compile(r'(.*):(\d+\.\d+\.\d+\.\d+)$')
_colon_colon_start = re.compile(r'::.*')
_colon_colon_end = re.compile(r'.*::$')
@@ -113,16 +113,9 @@ def inet_aton(text):
#
m = _v4_ending.match(text)
if not m is None:
- try:
- b1 = int(m.group(2))
- b2 = int(m.group(3))
- b3 = int(m.group(4))
- b4 = int(m.group(5))
- except:
- raise dns.exception.SyntaxError
- if b1 > 255 or b2 > 255 or b3 > 255 or b4 > 255:
- raise dns.exception.SyntaxError
- text = "%s:%04x:%04x" % (m.group(1), b1 * 256 + b2, b3 * 256 + b4)
+ b = dns.ipv4.inet_aton(m.group(2))
+ text = "%s:%02x%02x:%02x%02x" % (m.group(1), ord(b[0]), ord(b[1]),
+ ord(b[2]), ord(b[3]))
#
# Try to turn '::<whatever>' into ':<whatever>'; if no match try to
# turn '<whatever>::' into '<whatever>:'