-
Notifications
You must be signed in to change notification settings - Fork 20
/
Copy pathargument.go
227 lines (192 loc) · 4.53 KB
/
argument.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
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
package graphb
import (
"fmt"
)
type argumentValue interface {
stringChan() <-chan string
}
type Argument struct {
Name string
Value argumentValue
}
func (a *Argument) stringChan() <-chan string {
tokenChan := make(chan string)
go func() {
tokenChan <- a.Name
tokenChan <- ":"
for str := range a.Value.stringChan() {
tokenChan <- str
}
close(tokenChan)
}()
return tokenChan
}
func ArgumentAny(name string, value interface{}) (Argument, error) {
switch v := value.(type) {
case bool:
return ArgumentBool(name, v), nil
case []bool:
return ArgumentBoolSlice(name, v...), nil
case int:
return ArgumentInt(name, v), nil
case []int:
return ArgumentIntSlice(name, v...), nil
case string:
return ArgumentString(name, v), nil
case []string:
return ArgumentStringSlice(name, v...), nil
default:
return Argument{}, ArgumentTypeNotSupportedErr{Value: value}
}
}
func ArgumentBool(name string, value bool) Argument {
return Argument{name, argBool(value)}
}
func ArgumentInt(name string, value int) Argument {
return Argument{name, argInt(value)}
}
func ArgumentString(name string, value string) Argument {
return Argument{name, argString(value)}
}
func ArgumentBoolSlice(name string, values ...bool) Argument {
return Argument{name, argBoolSlice(values)}
}
func ArgumentIntSlice(name string, values ...int) Argument {
return Argument{name, argIntSlice(values)}
}
func ArgumentStringSlice(name string, values ...string) Argument {
return Argument{name, argStringSlice(values)}
}
// ArgumentCustomType returns a custom GraphQL type's argument representation, which could be a recursive structure.
func ArgumentCustomType(name string, values ...Argument) Argument {
return Argument{name, argumentSlice(values)}
}
func ArgumentCustomTypeSlice(name string, values ...[]Argument) Argument {
return Argument{name, argCustomTypeSlice(values)}
}
func ArgumentCustomTypeSliceElem(values ...Argument) []Argument {
return values
}
/////////////////////////////
// Primitive Wrapper Types //
/////////////////////////////
// argBool represents a boolean value.
type argBool bool
func (v argBool) stringChan() <-chan string {
tokenChan := make(chan string)
go func() {
tokenChan <- fmt.Sprintf("%t", v)
close(tokenChan)
}()
return tokenChan
}
// argInt represents an integer value.
type argInt int
func (v argInt) stringChan() <-chan string {
tokenChan := make(chan string)
go func() {
tokenChan <- fmt.Sprintf("%d", v)
close(tokenChan)
}()
return tokenChan
}
// argString represents a string value.
type argString string
func (v argString) stringChan() <-chan string {
tokenChan := make(chan string)
go func() {
tokenChan <- fmt.Sprintf(`"%s"`, v)
close(tokenChan)
}()
return tokenChan
}
//////////////////////////////////
// Primitive List Wrapper Types //
//////////////////////////////////
// argBoolSlice implements valueSlice
type argBoolSlice []bool
func (s argBoolSlice) stringChan() <-chan string {
tokenChan := make(chan string)
go func() {
tokenChan <- "["
for i, v := range s {
if i != 0 {
tokenChan <- ","
}
tokenChan <- fmt.Sprintf("%t", v)
}
tokenChan <- "]"
close(tokenChan)
}()
return tokenChan
}
// argIntSlice implements valueSlice
type argIntSlice []int
func (s argIntSlice) stringChan() <-chan string {
tokenChan := make(chan string)
go func() {
tokenChan <- "["
for i, v := range s {
if i != 0 {
tokenChan <- ","
}
tokenChan <- fmt.Sprintf("%d", v)
}
tokenChan <- "]"
close(tokenChan)
}()
return tokenChan
}
// argStringSlice implements valueSlice
type argStringSlice []string
func (s argStringSlice) stringChan() <-chan string {
tokenChan := make(chan string)
go func() {
tokenChan <- "["
for i, v := range s {
if i != 0 {
tokenChan <- ","
}
tokenChan <- fmt.Sprintf(`"%s"`, v)
}
tokenChan <- "]"
close(tokenChan)
}()
return tokenChan
}
type argumentSlice []Argument
func (s argumentSlice) stringChan() <-chan string {
tokenChan := make(chan string)
go func() {
tokenChan <- "{"
for i, v := range s {
if i != 0 {
tokenChan <- ","
}
for str := range v.stringChan() {
tokenChan <- str
}
}
tokenChan <- "}"
close(tokenChan)
}()
return tokenChan
}
type argCustomTypeSlice [][]Argument
func (s argCustomTypeSlice) stringChan() <-chan string {
tokenChan := make(chan string)
go func() {
tokenChan <- "["
for i, v := range s {
if i != 0 {
tokenChan <- ","
}
for str := range argumentSlice(v).stringChan() {
tokenChan <- str
}
}
tokenChan <- "]"
close(tokenChan)
}()
return tokenChan
}