mirror of
https://github.com/google/uuid.git
synced 2025-02-20 12:33:21 +02:00
A common helper function is used for UUID.String(), UUID.URN(), and UUID.MarshalJSON(). Any perforance hit in UUID.String() and UUID.Marshal() appears to be negligable. The benefit to UUID.MarshalJSON() is several hundred nanoseconds (23% faster) and 2 allocations (21% fewer bytes). Some redundant checks are removed from UUID.UnmarshalJSON() method. The "encoding/json".Unmarshaler interface specifies that implementations can assume input is valid JSON content. This allows one to assume that (1) input is not empty and (2) if index 0 is a quote, then the content is a json string and the last index will contain a terminating quote. The second point is not completely explicit in the documentation but it is true in practice (and it is safe to assume -- errors will be caught).
35 lines
673 B
Go
35 lines
673 B
Go
// Copyright 2014 Google Inc. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package uuid
|
|
|
|
import "errors"
|
|
|
|
func (u UUID) MarshalJSON() ([]byte, error) {
|
|
if len(u) != 16 {
|
|
return []byte(`""`), nil
|
|
}
|
|
var js [38]byte
|
|
js[0] = '"'
|
|
encodeHex(js[1:], u)
|
|
js[37] = '"'
|
|
return js[:], nil
|
|
}
|
|
|
|
func (u *UUID) UnmarshalJSON(data []byte) error {
|
|
if string(data) == `""` {
|
|
return nil
|
|
}
|
|
if data[0] != '"' {
|
|
return errors.New("invalid UUID format")
|
|
}
|
|
data = data[1 : len(data)-1]
|
|
uu := Parse(string(data))
|
|
if uu == nil {
|
|
return errors.New("invalid UUID format")
|
|
}
|
|
*u = uu
|
|
return nil
|
|
}
|