arikawa/utils/json/option/string.go

51 lines
1.1 KiB
Go

package option
import (
"encoding/json"
)
// ================================ String ================================
// String is the option type for strings.
type String *string
// NewString creates a new String with the value of the passed string.
func NewString(s string) String { return &s }
// ================================ NullableString ================================
// NullableString is a nullable version of a string.
type NullableString = *NullableStringData
type NullableStringData struct {
Val string
Init bool
}
// NullBool serializes to JSON null.
var NullString = &NullableStringData{}
// NewNullableString creates a new non-null NullableString with the value of the passed string.
func NewNullableString(v string) NullableString {
return &NullableStringData{
Val: v,
Init: true,
}
}
func (s NullableStringData) MarshalJSON() ([]byte, error) {
if !s.Init {
return []byte("null"), nil
}
return json.Marshal(s.Val)
}
func (s *NullableStringData) UnmarshalJSON(b []byte) error {
if string(b) == "null" {
return nil
}
s.Init = true
return json.Unmarshal(b, &s.Val)
}