-
Notifications
You must be signed in to change notification settings - Fork 62
/
Copy pathsql_int_enum.go
195 lines (174 loc) · 4.35 KB
/
sql_int_enum.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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
// Code generated by go-enum DO NOT EDIT.
// Version: example
// Revision: example
// Build Date: example
// Built By: example
//go:build example
// +build example
package example
import (
"database/sql/driver"
"errors"
"fmt"
"strconv"
)
const (
// ImageTypeJpeg is a ImageType of type Jpeg.
ImageTypeJpeg ImageType = iota
// ImageTypeJpg is a ImageType of type Jpg.
ImageTypeJpg
// ImageTypePng is a ImageType of type Png.
ImageTypePng
// ImageTypeTiff is a ImageType of type Tiff.
ImageTypeTiff
// ImageTypeGif is a ImageType of type Gif.
ImageTypeGif
)
var ErrInvalidImageType = errors.New("not a valid ImageType")
const _ImageTypeName = "jpegjpgpngtiffgif"
var _ImageTypeMap = map[ImageType]string{
ImageTypeJpeg: _ImageTypeName[0:4],
ImageTypeJpg: _ImageTypeName[4:7],
ImageTypePng: _ImageTypeName[7:10],
ImageTypeTiff: _ImageTypeName[10:14],
ImageTypeGif: _ImageTypeName[14:17],
}
// String implements the Stringer interface.
func (x ImageType) String() string {
if str, ok := _ImageTypeMap[x]; ok {
return str
}
return fmt.Sprintf("ImageType(%d)", x)
}
// IsValid provides a quick way to determine if the typed value is
// part of the allowed enumerated values
func (x ImageType) IsValid() bool {
_, ok := _ImageTypeMap[x]
return ok
}
var _ImageTypeValue = map[string]ImageType{
_ImageTypeName[0:4]: ImageTypeJpeg,
_ImageTypeName[4:7]: ImageTypeJpg,
_ImageTypeName[7:10]: ImageTypePng,
_ImageTypeName[10:14]: ImageTypeTiff,
_ImageTypeName[14:17]: ImageTypeGif,
}
// ParseImageType attempts to convert a string to a ImageType.
func ParseImageType(name string) (ImageType, error) {
if x, ok := _ImageTypeValue[name]; ok {
return x, nil
}
return ImageType(0), fmt.Errorf("%s is %w", name, ErrInvalidImageType)
}
var errImageTypeNilPtr = errors.New("value pointer is nil") // one per type for package clashes
// Scan implements the Scanner interface.
func (x *ImageType) Scan(value interface{}) (err error) {
if value == nil {
*x = ImageType(0)
return
}
// A wider range of scannable types.
// driver.Value values at the top of the list for expediency
switch v := value.(type) {
case int64:
*x = ImageType(v)
case string:
*x, err = ParseImageType(v)
if err != nil {
// try parsing the integer value as a string
if val, verr := strconv.Atoi(v); verr == nil {
*x, err = ImageType(val), nil
}
}
case []byte:
*x, err = ParseImageType(string(v))
if err != nil {
// try parsing the integer value as a string
if val, verr := strconv.Atoi(string(v)); verr == nil {
*x, err = ImageType(val), nil
}
}
case ImageType:
*x = v
case int:
*x = ImageType(v)
case *ImageType:
if v == nil {
return errImageTypeNilPtr
}
*x = *v
case uint:
*x = ImageType(v)
case uint64:
*x = ImageType(v)
case *int:
if v == nil {
return errImageTypeNilPtr
}
*x = ImageType(*v)
case *int64:
if v == nil {
return errImageTypeNilPtr
}
*x = ImageType(*v)
case float64: // json marshals everything as a float64 if it's a number
*x = ImageType(v)
case *float64: // json marshals everything as a float64 if it's a number
if v == nil {
return errImageTypeNilPtr
}
*x = ImageType(*v)
case *uint:
if v == nil {
return errImageTypeNilPtr
}
*x = ImageType(*v)
case *uint64:
if v == nil {
return errImageTypeNilPtr
}
*x = ImageType(*v)
case *string:
if v == nil {
return errImageTypeNilPtr
}
*x, err = ParseImageType(*v)
if err != nil {
// try parsing the integer value as a string
if val, verr := strconv.Atoi(*v); verr == nil {
*x, err = ImageType(val), nil
}
}
}
return
}
// Value implements the driver Valuer interface.
func (x ImageType) Value() (driver.Value, error) {
return int64(x), nil
}
type NullImageType struct {
ImageType ImageType
Valid bool
}
func NewNullImageType(val interface{}) (x NullImageType) {
x.Scan(val) // yes, we ignore this error, it will just be an invalid value.
return
}
// Scan implements the Scanner interface.
func (x *NullImageType) Scan(value interface{}) (err error) {
if value == nil {
x.ImageType, x.Valid = ImageType(0), false
return
}
err = x.ImageType.Scan(value)
x.Valid = (err == nil)
return
}
// Value implements the driver Valuer interface.
func (x NullImageType) Value() (driver.Value, error) {
if !x.Valid {
return nil, nil
}
// driver.Value accepts int64 for int values.
return int64(x.ImageType), nil
}