Merge pull request #8 from alexflint/parse-urls

Add support for url.URL
This commit is contained in:
Alex Flint 2021-08-17 12:34:34 -07:00 committed by GitHub
commit fd60e96695
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 14 additions and 1 deletions

View File

@ -8,6 +8,7 @@ import (
"fmt"
"net"
"net/mail"
"net/url"
"reflect"
"strconv"
"time"
@ -19,6 +20,7 @@ var (
durationType = reflect.TypeOf(time.Duration(0))
mailAddressType = reflect.TypeOf(mail.Address{})
macType = reflect.TypeOf(net.HardwareAddr{})
urlType = reflect.TypeOf(url.URL{})
)
var (
@ -86,6 +88,13 @@ func ParseValue(v reflect.Value, s string) error {
}
v.Set(reflect.ValueOf(ip))
return nil
case url.URL:
url, err := url.Parse(s)
if err != nil {
return err
}
v.Set(reflect.ValueOf(*url))
return nil
}
// Switch on kind so that we can handle derived types
@ -136,7 +145,7 @@ func CanParse(t reflect.Type) bool {
// Check for other special types
switch t {
case durationType, mailAddressType, macType:
case durationType, mailAddressType, macType, urlType:
return true
}

View File

@ -2,6 +2,7 @@ package scalar
import (
"net"
"net/url"
"reflect"
"testing"
"time"
@ -77,6 +78,9 @@ func TestParseValue(t *testing.T) {
// MAC addresses
assertParse(t, net.HardwareAddr("\x01\x23\x45\x67\x89\xab"), "01:23:45:67:89:ab")
// URL
assertParse(t, url.URL{Scheme: "https", Host: "example.com", Path: "/a/b/c"}, "https://example.com/a/b/c")
// custom text unmarshaler
assertParse(t, textUnmarshaler{3}, "abc")
}