/
waehrungseinheit_jsonenums.go
56 lines (49 loc) · 1.32 KB
/
waehrungseinheit_jsonenums.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
// Code generated by jsonenums --type Waehrungseinheit; DO NOT EDIT.
package waehrungseinheit
import (
"encoding/json"
"fmt"
)
var (
_WaehrungseinheitNameToValue = map[string]Waehrungseinheit{
"EUR": EUR,
"CT": CT,
}
_WaehrungseinheitValueToName = map[Waehrungseinheit]string{
EUR: "EUR",
CT: "CT",
}
)
func init() {
var v Waehrungseinheit
if _, ok := interface{}(v).(fmt.Stringer); ok {
_WaehrungseinheitNameToValue = map[string]Waehrungseinheit{
interface{}(EUR).(fmt.Stringer).String(): EUR,
interface{}(CT).(fmt.Stringer).String(): CT,
}
}
}
// MarshalJSON is generated so Waehrungseinheit satisfies json.Marshaler.
func (r Waehrungseinheit) MarshalJSON() ([]byte, error) {
if s, ok := interface{}(r).(fmt.Stringer); ok {
return json.Marshal(s.String())
}
s, ok := _WaehrungseinheitValueToName[r]
if !ok {
return nil, fmt.Errorf("invalid Waehrungseinheit: %d", r)
}
return json.Marshal(s)
}
// UnmarshalJSON is generated so Waehrungseinheit satisfies json.Unmarshaler.
func (r *Waehrungseinheit) UnmarshalJSON(data []byte) error {
var s string
if err := json.Unmarshal(data, &s); err != nil {
return fmt.Errorf("Waehrungseinheit should be a string, got %s", data)
}
v, ok := _WaehrungseinheitNameToValue[s]
if !ok {
return fmt.Errorf("invalid Waehrungseinheit %q", s)
}
*r = v
return nil
}