Commit 3ef0e8f8 authored by Joe Tsai's avatar Joe Tsai Committed by Joe Tsai

net: remove parsing of negative decimals in IPv4 literal

https://golang.org/cl/27206 fixed the dtoi function such that
it now properly parses negative number. Ironically, this causes
several other functions that depended on dtoi to now (incorrectly)
parse negative numbers.

For example, ParseCIDR("-1.0.0.0/32") used to be rejected prior to the
above CL, but is now accepted even though it is an invalid CIDR notation.
This CL fixes that regression.

We fix this by removing the signed parsing logic entirely from dtoi.
It was introduced relatively recently in https://golang.org/cl/12447
to fix a bug where an invalid port was improperly being parsed as OK.
It seems to me that the fix in that CL to the port handling logic was
sufficient such that a change to dtoi was unnecessary.

Updates #16350

Change-Id: I414bb1aa27d0a226ebd4b05a09cb40d784691b43
Reviewed-on: https://go-review.googlesource.com/28414Reviewed-by: default avatarMatthew Dempsky <mdempsky@google.com>
Reviewed-by: default avatarMikio Hara <mikioh.mikioh@gmail.com>
Run-TryBot: Joe Tsai <thebrokentoaster@gmail.com>
parent 42433e27
...@@ -28,6 +28,10 @@ var parseIPTests = []struct { ...@@ -28,6 +28,10 @@ var parseIPTests = []struct {
{"2001:4860:0:2001::68", IP{0x20, 0x01, 0x48, 0x60, 0, 0, 0x20, 0x01, 0, 0, 0, 0, 0, 0, 0x00, 0x68}}, {"2001:4860:0:2001::68", IP{0x20, 0x01, 0x48, 0x60, 0, 0, 0x20, 0x01, 0, 0, 0, 0, 0, 0, 0x00, 0x68}},
{"2001:4860:0000:2001:0000:0000:0000:0068", IP{0x20, 0x01, 0x48, 0x60, 0, 0, 0x20, 0x01, 0, 0, 0, 0, 0, 0, 0x00, 0x68}}, {"2001:4860:0000:2001:0000:0000:0000:0068", IP{0x20, 0x01, 0x48, 0x60, 0, 0, 0x20, 0x01, 0, 0, 0, 0, 0, 0, 0x00, 0x68}},
{"-0.0.0.0", nil},
{"0.-1.0.0", nil},
{"0.0.-2.0", nil},
{"0.0.0.-3", nil},
{"127.0.0.256", nil}, {"127.0.0.256", nil},
{"abc", nil}, {"abc", nil},
{"123:", nil}, {"123:", nil},
...@@ -332,6 +336,12 @@ var parseCIDRTests = []struct { ...@@ -332,6 +336,12 @@ var parseCIDRTests = []struct {
{"192.168.1.1/255.255.255.0", nil, nil, &ParseError{Type: "CIDR address", Text: "192.168.1.1/255.255.255.0"}}, {"192.168.1.1/255.255.255.0", nil, nil, &ParseError{Type: "CIDR address", Text: "192.168.1.1/255.255.255.0"}},
{"192.168.1.1/35", nil, nil, &ParseError{Type: "CIDR address", Text: "192.168.1.1/35"}}, {"192.168.1.1/35", nil, nil, &ParseError{Type: "CIDR address", Text: "192.168.1.1/35"}},
{"2001:db8::1/-1", nil, nil, &ParseError{Type: "CIDR address", Text: "2001:db8::1/-1"}}, {"2001:db8::1/-1", nil, nil, &ParseError{Type: "CIDR address", Text: "2001:db8::1/-1"}},
{"2001:db8::1/-0", nil, nil, &ParseError{Type: "CIDR address", Text: "2001:db8::1/-0"}},
{"-0.0.0.0/32", nil, nil, &ParseError{Type: "CIDR address", Text: "-0.0.0.0/32"}},
{"0.-1.0.0/32", nil, nil, &ParseError{Type: "CIDR address", Text: "0.-1.0.0/32"}},
{"0.0.-2.0/32", nil, nil, &ParseError{Type: "CIDR address", Text: "0.0.-2.0/32"}},
{"0.0.0.-3/32", nil, nil, &ParseError{Type: "CIDR address", Text: "0.0.0.-3/32"}},
{"0.0.0.0/-0", nil, nil, &ParseError{Type: "CIDR address", Text: "0.0.0.0/-0"}},
{"", nil, nil, &ParseError{Type: "CIDR address", Text: ""}}, {"", nil, nil, &ParseError{Type: "CIDR address", Text: ""}},
} }
......
...@@ -127,26 +127,14 @@ const big = 0xFFFFFF ...@@ -127,26 +127,14 @@ const big = 0xFFFFFF
// Returns number, characters consumed, success. // Returns number, characters consumed, success.
func dtoi(s string) (n int, i int, ok bool) { func dtoi(s string) (n int, i int, ok bool) {
n = 0 n = 0
neg := false
if len(s) > 0 && s[0] == '-' {
neg = true
s = s[1:]
}
for i = 0; i < len(s) && '0' <= s[i] && s[i] <= '9'; i++ { for i = 0; i < len(s) && '0' <= s[i] && s[i] <= '9'; i++ {
n = n*10 + int(s[i]-'0') n = n*10 + int(s[i]-'0')
if n >= big { if n >= big {
if neg {
return -big, i + 1, false
}
return big, i, false return big, i, false
} }
} }
if i == 0 { if i == 0 {
return 0, i, false return 0, 0, false
}
if neg {
n = -n
i++
} }
return n, i, true return n, i, true
} }
......
...@@ -86,12 +86,11 @@ func TestDtoi(t *testing.T) { ...@@ -86,12 +86,11 @@ func TestDtoi(t *testing.T) {
ok bool ok bool
}{ }{
{"", 0, 0, false}, {"", 0, 0, false},
{"-123456789", -big, 9, false},
{"-1", -1, 2, true},
{"0", 0, 1, true}, {"0", 0, 1, true},
{"65536", 65536, 5, true}, {"65536", 65536, 5, true},
{"123456789", big, 8, false}, {"123456789", big, 8, false},
{"-0", 0, 0, false},
{"-1234", 0, 0, false},
} { } {
n, i, ok := dtoi(tt.in) n, i, ok := dtoi(tt.in)
if n != tt.out || i != tt.off || ok != tt.ok { if n != tt.out || i != tt.off || ok != tt.ok {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment