From 55bc5224fba32a45f4c4ae427b4d24c18480358c Mon Sep 17 00:00:00 2001 From: Stanislav Losev Date: Mon, 14 Oct 2024 15:20:00 +0300 Subject: [PATCH] feat: improve switch-case into Validate func --- uuid.go | 20 ++++++++------------ 1 file changed, 8 insertions(+), 12 deletions(-) diff --git a/uuid.go b/uuid.go index dc75cee..0b41737 100644 --- a/uuid.go +++ b/uuid.go @@ -224,6 +224,14 @@ func Validate(s string) error { switch len(s) { // Standard UUID format case 36: + if s[8] != '-' || s[13] != '-' || s[18] != '-' || s[23] != '-' { + return ErrInvalidUUIDFormat + } + for _, x := range []int{0, 2, 4, 6, 9, 11, 14, 16, 19, 21, 24, 26, 28, 30, 32, 34} { + if _, ok := xtob(s[x], s[x+1]); !ok { + return ErrInvalidUUIDFormat + } + } // UUID with "urn:uuid:" prefix case 36 + 9: @@ -252,18 +260,6 @@ func Validate(s string) error { return invalidLengthError{len(s)} } - // Check for standard UUID format - if len(s) == 36 { - if s[8] != '-' || s[13] != '-' || s[18] != '-' || s[23] != '-' { - return ErrInvalidUUIDFormat - } - for _, x := range []int{0, 2, 4, 6, 9, 11, 14, 16, 19, 21, 24, 26, 28, 30, 32, 34} { - if _, ok := xtob(s[x], s[x+1]); !ok { - return ErrInvalidUUIDFormat - } - } - } - return nil }