objective-lol 0.0.1__cp311-cp311-macosx_10_9_x86_64.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
objective_lol/api.py ADDED
@@ -0,0 +1,1805 @@
1
+
2
+ # python wrapper for package github.com/bjia56/objective-lol/pkg/api within overall package api
3
+ # This is what you import to use the package.
4
+ # File is generated by gopy. Do not edit.
5
+ # gopy build -no-make -dynamic-link=True -symbols=False -output /Users/runner/work/objective-lol/objective-lol/python/build/lib.macosx-10.9-x86_64-cpython-311/objective_lol --vm /Users/runner/work/objective-lol/objective-lol/python/.toolchain/python/python-3.11.13/bin/python3 .
6
+
7
+ # the following is required to enable dlopen to open the _go.so file
8
+ import os,sys,inspect,collections
9
+ try:
10
+ import collections.abc as _collections_abc
11
+ except ImportError:
12
+ _collections_abc = collections
13
+
14
+ cwd = os.getcwd()
15
+ currentdir = os.path.dirname(os.path.abspath(inspect.getfile(inspect.currentframe())))
16
+ os.chdir(currentdir)
17
+ from . import _api
18
+ from . import go
19
+
20
+ os.chdir(cwd)
21
+
22
+ # to use this code in your end-user python file, import it as follows:
23
+ # from api import api
24
+ # and then refer to everything using api. prefix
25
+ # packages imported by this package listed below:
26
+
27
+
28
+
29
+
30
+ # ---- Types ---
31
+
32
+ # Python type for slice []api.GoValue
33
+ class Slice_api_GoValue(go.GoClass):
34
+ """"""
35
+ def __init__(self, *args, **kwargs):
36
+ """
37
+ handle=A Go-side object is always initialized with an explicit handle=arg
38
+ otherwise parameter is a python list that we copy from
39
+ """
40
+ self.index = 0
41
+ if len(kwargs) == 1 and 'handle' in kwargs:
42
+ self.handle = kwargs['handle']
43
+ _api.IncRef(self.handle)
44
+ elif len(args) == 1 and isinstance(args[0], go.GoClass):
45
+ self.handle = args[0].handle
46
+ _api.IncRef(self.handle)
47
+ else:
48
+ self.handle = _api.Slice_api_GoValue_CTor()
49
+ _api.IncRef(self.handle)
50
+ if len(args) > 0:
51
+ if not isinstance(args[0], _collections_abc.Iterable):
52
+ raise TypeError('Slice_api_GoValue.__init__ takes a sequence as argument')
53
+ for elt in args[0]:
54
+ self.append(elt)
55
+ def __del__(self):
56
+ _api.DecRef(self.handle)
57
+ def __str__(self):
58
+ s = 'api.Slice_api_GoValue len: ' + str(len(self)) + ' handle: ' + str(self.handle) + ' ['
59
+ if len(self) < 120:
60
+ s += ', '.join(map(str, self)) + ']'
61
+ return s
62
+ def __repr__(self):
63
+ return 'api.Slice_api_GoValue([' + ', '.join(map(str, self)) + '])'
64
+ def __len__(self):
65
+ return _api.Slice_api_GoValue_len(self.handle)
66
+ def __getitem__(self, key):
67
+ if isinstance(key, slice):
68
+ if key.step == None or key.step == 1:
69
+ st = key.start
70
+ ed = key.stop
71
+ if st == None:
72
+ st = 0
73
+ if ed == None:
74
+ ed = _api.Slice_api_GoValue_len(self.handle)
75
+ return Slice_api_GoValue(handle=_api.Slice_api_GoValue_subslice(self.handle, st, ed))
76
+ return [self[ii] for ii in range(*key.indices(len(self)))]
77
+ elif isinstance(key, int):
78
+ if key < 0:
79
+ key += len(self)
80
+ if key < 0 or key >= len(self):
81
+ raise IndexError('slice index out of range')
82
+ return GoValue(handle=_api.Slice_api_GoValue_elem(self.handle, key))
83
+ else:
84
+ raise TypeError('slice index invalid type')
85
+ def __setitem__(self, idx, value):
86
+ if idx < 0:
87
+ idx += len(self)
88
+ if idx < len(self):
89
+ _api.Slice_api_GoValue_set(self.handle, idx, value.handle)
90
+ return
91
+ raise IndexError('slice index out of range')
92
+ def __iadd__(self, value):
93
+ if not isinstance(value, _collections_abc.Iterable):
94
+ raise TypeError('Slice_api_GoValue.__iadd__ takes a sequence as argument')
95
+ for elt in value:
96
+ self.append(elt)
97
+ return self
98
+ def __iter__(self):
99
+ self.index = 0
100
+ return self
101
+ def __next__(self):
102
+ if self.index < len(self):
103
+ rv = GoValue(handle=_api.Slice_api_GoValue_elem(self.handle, self.index))
104
+ self.index = self.index + 1
105
+ return rv
106
+ raise StopIteration
107
+ def append(self, value):
108
+ _api.Slice_api_GoValue_append(self.handle, value.handle)
109
+ def copy(self, src):
110
+ """ copy emulates the go copy function, copying elements into this list from source list, up to min of size of each list """
111
+ mx = min(len(self), len(src))
112
+ for i in range(mx):
113
+ self[i] = src[i]
114
+
115
+ # Python type for slice []environment.Parameter
116
+ class Slice_environment_Parameter(go.GoClass):
117
+ """"""
118
+ def __init__(self, *args, **kwargs):
119
+ """
120
+ handle=A Go-side object is always initialized with an explicit handle=arg
121
+ otherwise parameter is a python list that we copy from
122
+ """
123
+ self.index = 0
124
+ if len(kwargs) == 1 and 'handle' in kwargs:
125
+ self.handle = kwargs['handle']
126
+ _api.IncRef(self.handle)
127
+ elif len(args) == 1 and isinstance(args[0], go.GoClass):
128
+ self.handle = args[0].handle
129
+ _api.IncRef(self.handle)
130
+ else:
131
+ self.handle = _api.Slice_environment_Parameter_CTor()
132
+ _api.IncRef(self.handle)
133
+ if len(args) > 0:
134
+ if not isinstance(args[0], _collections_abc.Iterable):
135
+ raise TypeError('Slice_environment_Parameter.__init__ takes a sequence as argument')
136
+ for elt in args[0]:
137
+ self.append(elt)
138
+ def __del__(self):
139
+ _api.DecRef(self.handle)
140
+ def __str__(self):
141
+ s = 'api.Slice_environment_Parameter len: ' + str(len(self)) + ' handle: ' + str(self.handle) + ' ['
142
+ if len(self) < 120:
143
+ s += ', '.join(map(str, self)) + ']'
144
+ return s
145
+ def __repr__(self):
146
+ return 'api.Slice_environment_Parameter([' + ', '.join(map(str, self)) + '])'
147
+ def __len__(self):
148
+ return _api.Slice_environment_Parameter_len(self.handle)
149
+ def __getitem__(self, key):
150
+ if isinstance(key, slice):
151
+ if key.step == None or key.step == 1:
152
+ st = key.start
153
+ ed = key.stop
154
+ if st == None:
155
+ st = 0
156
+ if ed == None:
157
+ ed = _api.Slice_environment_Parameter_len(self.handle)
158
+ return Slice_environment_Parameter(handle=_api.Slice_environment_Parameter_subslice(self.handle, st, ed))
159
+ return [self[ii] for ii in range(*key.indices(len(self)))]
160
+ elif isinstance(key, int):
161
+ if key < 0:
162
+ key += len(self)
163
+ if key < 0 or key >= len(self):
164
+ raise IndexError('slice index out of range')
165
+ return go.environment_Parameter(handle=_api.Slice_environment_Parameter_elem(self.handle, key))
166
+ else:
167
+ raise TypeError('slice index invalid type')
168
+ def __setitem__(self, idx, value):
169
+ if idx < 0:
170
+ idx += len(self)
171
+ if idx < len(self):
172
+ _api.Slice_environment_Parameter_set(self.handle, idx, value.handle)
173
+ return
174
+ raise IndexError('slice index out of range')
175
+ def __iadd__(self, value):
176
+ if not isinstance(value, _collections_abc.Iterable):
177
+ raise TypeError('Slice_environment_Parameter.__iadd__ takes a sequence as argument')
178
+ for elt in value:
179
+ self.append(elt)
180
+ return self
181
+ def __iter__(self):
182
+ self.index = 0
183
+ return self
184
+ def __next__(self):
185
+ if self.index < len(self):
186
+ rv = go.environment_Parameter(handle=_api.Slice_environment_Parameter_elem(self.handle, self.index))
187
+ self.index = self.index + 1
188
+ return rv
189
+ raise StopIteration
190
+ def append(self, value):
191
+ _api.Slice_environment_Parameter_append(self.handle, value.handle)
192
+ def copy(self, src):
193
+ """ copy emulates the go copy function, copying elements into this list from source list, up to min of size of each list """
194
+ mx = min(len(self), len(src))
195
+ for i in range(mx):
196
+ self[i] = src[i]
197
+
198
+ # Python type for slice []environment.Value
199
+ class Slice_environment_Value(go.GoClass):
200
+ """"""
201
+ def __init__(self, *args, **kwargs):
202
+ """
203
+ handle=A Go-side object is always initialized with an explicit handle=arg
204
+ otherwise parameter is a python list that we copy from
205
+ """
206
+ self.index = 0
207
+ if len(kwargs) == 1 and 'handle' in kwargs:
208
+ self.handle = kwargs['handle']
209
+ _api.IncRef(self.handle)
210
+ elif len(args) == 1 and isinstance(args[0], go.GoClass):
211
+ self.handle = args[0].handle
212
+ _api.IncRef(self.handle)
213
+ else:
214
+ self.handle = _api.Slice_environment_Value_CTor()
215
+ _api.IncRef(self.handle)
216
+ if len(args) > 0:
217
+ if not isinstance(args[0], _collections_abc.Iterable):
218
+ raise TypeError('Slice_environment_Value.__init__ takes a sequence as argument')
219
+ for elt in args[0]:
220
+ self.append(elt)
221
+ def __del__(self):
222
+ _api.DecRef(self.handle)
223
+ def __str__(self):
224
+ s = 'api.Slice_environment_Value len: ' + str(len(self)) + ' handle: ' + str(self.handle) + ' ['
225
+ if len(self) < 120:
226
+ s += ', '.join(map(str, self)) + ']'
227
+ return s
228
+ def __repr__(self):
229
+ return 'api.Slice_environment_Value([' + ', '.join(map(str, self)) + '])'
230
+ def __len__(self):
231
+ return _api.Slice_environment_Value_len(self.handle)
232
+ def __getitem__(self, key):
233
+ if isinstance(key, slice):
234
+ if key.step == None or key.step == 1:
235
+ st = key.start
236
+ ed = key.stop
237
+ if st == None:
238
+ st = 0
239
+ if ed == None:
240
+ ed = _api.Slice_environment_Value_len(self.handle)
241
+ return Slice_environment_Value(handle=_api.Slice_environment_Value_subslice(self.handle, st, ed))
242
+ return [self[ii] for ii in range(*key.indices(len(self)))]
243
+ elif isinstance(key, int):
244
+ if key < 0:
245
+ key += len(self)
246
+ if key < 0 or key >= len(self):
247
+ raise IndexError('slice index out of range')
248
+ return go.environment_Value(handle=_api.Slice_environment_Value_elem(self.handle, key))
249
+ else:
250
+ raise TypeError('slice index invalid type')
251
+ def __setitem__(self, idx, value):
252
+ if idx < 0:
253
+ idx += len(self)
254
+ if idx < len(self):
255
+ _api.Slice_environment_Value_set(self.handle, idx, value.handle)
256
+ return
257
+ raise IndexError('slice index out of range')
258
+ def __iadd__(self, value):
259
+ if not isinstance(value, _collections_abc.Iterable):
260
+ raise TypeError('Slice_environment_Value.__iadd__ takes a sequence as argument')
261
+ for elt in value:
262
+ self.append(elt)
263
+ return self
264
+ def __iter__(self):
265
+ self.index = 0
266
+ return self
267
+ def __next__(self):
268
+ if self.index < len(self):
269
+ rv = go.environment_Value(handle=_api.Slice_environment_Value_elem(self.handle, self.index))
270
+ self.index = self.index + 1
271
+ return rv
272
+ raise StopIteration
273
+ def append(self, value):
274
+ _api.Slice_environment_Value_append(self.handle, value.handle)
275
+ def copy(self, src):
276
+ """ copy emulates the go copy function, copying elements into this list from source list, up to min of size of each list """
277
+ mx = min(len(self), len(src))
278
+ for i in range(mx):
279
+ self[i] = src[i]
280
+
281
+ # Python type for map map[string]*api.ClassMethod
282
+ class Map_string_Ptr_api_ClassMethod(go.GoClass):
283
+ """"""
284
+ def __init__(self, *args, **kwargs):
285
+ """
286
+ handle=A Go-side object is always initialized with an explicit handle=arg
287
+ otherwise parameter is a python list that we copy from
288
+ """
289
+ self.index = 0
290
+ if len(kwargs) == 1 and 'handle' in kwargs:
291
+ self.handle = kwargs['handle']
292
+ _api.IncRef(self.handle)
293
+ elif len(args) == 1 and isinstance(args[0], go.GoClass):
294
+ self.handle = args[0].handle
295
+ _api.IncRef(self.handle)
296
+ else:
297
+ self.handle = _api.Map_string_Ptr_api_ClassMethod_CTor()
298
+ _api.IncRef(self.handle)
299
+ if len(args) > 0:
300
+ if not isinstance(args[0], _collections_abc.Mapping):
301
+ raise TypeError('Map_string_Ptr_api_ClassMethod.__init__ takes a mapping as argument')
302
+ for k, v in args[0].items():
303
+ _api.Map_string_Ptr_api_ClassMethod_set(self.handle, k, v)
304
+ def __del__(self):
305
+ _api.DecRef(self.handle)
306
+ def __str__(self):
307
+ s = 'api.Map_string_Ptr_api_ClassMethod len: ' + str(len(self)) + ' handle: ' + str(self.handle) + ' {'
308
+ if len(self) < 120:
309
+ for k, v in self.items():
310
+ s += str(k) + '=' + str(v) + ', '
311
+ return s + '}'
312
+ def __repr__(self):
313
+ s = 'api.Map_string_Ptr_api_ClassMethod({'
314
+ for k, v in self.items():
315
+ s += str(k) + '=' + str(v) + ', '
316
+ return s + '})'
317
+ def __len__(self):
318
+ return _api.Map_string_Ptr_api_ClassMethod_len(self.handle)
319
+ def __getitem__(self, key):
320
+ return ClassMethod(handle=_api.Map_string_Ptr_api_ClassMethod_elem(self.handle, key))
321
+ def __setitem__(self, key, value):
322
+ _api.Map_string_Ptr_api_ClassMethod_set(self.handle, key, value.handle)
323
+ def __delitem__(self, key):
324
+ return _api.Map_string_Ptr_api_ClassMethod_delete(self.handle, key)
325
+ def keys(self):
326
+ return go.Slice_string(handle=_api.Map_string_Ptr_api_ClassMethod_keys(self.handle))
327
+ def values(self):
328
+ vls = []
329
+ kys = self.keys()
330
+ for k in kys:
331
+ vls.append(self[k])
332
+ return vls
333
+ def items(self):
334
+ vls = []
335
+ kys = self.keys()
336
+ for k in kys:
337
+ vls.append((k, self[k]))
338
+ return vls
339
+ def __iter__(self):
340
+ return iter(self.items())
341
+ def __contains__(self, key):
342
+ return _api.Map_string_Ptr_api_ClassMethod_contains(self.handle, key)
343
+
344
+ # Python type for map map[string]*api.ClassVariable
345
+ class Map_string_Ptr_api_ClassVariable(go.GoClass):
346
+ """"""
347
+ def __init__(self, *args, **kwargs):
348
+ """
349
+ handle=A Go-side object is always initialized with an explicit handle=arg
350
+ otherwise parameter is a python list that we copy from
351
+ """
352
+ self.index = 0
353
+ if len(kwargs) == 1 and 'handle' in kwargs:
354
+ self.handle = kwargs['handle']
355
+ _api.IncRef(self.handle)
356
+ elif len(args) == 1 and isinstance(args[0], go.GoClass):
357
+ self.handle = args[0].handle
358
+ _api.IncRef(self.handle)
359
+ else:
360
+ self.handle = _api.Map_string_Ptr_api_ClassVariable_CTor()
361
+ _api.IncRef(self.handle)
362
+ if len(args) > 0:
363
+ if not isinstance(args[0], _collections_abc.Mapping):
364
+ raise TypeError('Map_string_Ptr_api_ClassVariable.__init__ takes a mapping as argument')
365
+ for k, v in args[0].items():
366
+ _api.Map_string_Ptr_api_ClassVariable_set(self.handle, k, v)
367
+ def __del__(self):
368
+ _api.DecRef(self.handle)
369
+ def __str__(self):
370
+ s = 'api.Map_string_Ptr_api_ClassVariable len: ' + str(len(self)) + ' handle: ' + str(self.handle) + ' {'
371
+ if len(self) < 120:
372
+ for k, v in self.items():
373
+ s += str(k) + '=' + str(v) + ', '
374
+ return s + '}'
375
+ def __repr__(self):
376
+ s = 'api.Map_string_Ptr_api_ClassVariable({'
377
+ for k, v in self.items():
378
+ s += str(k) + '=' + str(v) + ', '
379
+ return s + '})'
380
+ def __len__(self):
381
+ return _api.Map_string_Ptr_api_ClassVariable_len(self.handle)
382
+ def __getitem__(self, key):
383
+ return ClassVariable(handle=_api.Map_string_Ptr_api_ClassVariable_elem(self.handle, key))
384
+ def __setitem__(self, key, value):
385
+ _api.Map_string_Ptr_api_ClassVariable_set(self.handle, key, value.handle)
386
+ def __delitem__(self, key):
387
+ return _api.Map_string_Ptr_api_ClassVariable_delete(self.handle, key)
388
+ def keys(self):
389
+ return go.Slice_string(handle=_api.Map_string_Ptr_api_ClassVariable_keys(self.handle))
390
+ def values(self):
391
+ vls = []
392
+ kys = self.keys()
393
+ for k in kys:
394
+ vls.append(self[k])
395
+ return vls
396
+ def items(self):
397
+ vls = []
398
+ kys = self.keys()
399
+ for k in kys:
400
+ vls.append((k, self[k]))
401
+ return vls
402
+ def __iter__(self):
403
+ return iter(self.items())
404
+ def __contains__(self, key):
405
+ return _api.Map_string_Ptr_api_ClassVariable_contains(self.handle, key)
406
+
407
+ # Python type for map map[string]*environment.Class
408
+ class Map_string_Ptr_environment_Class(go.GoClass):
409
+ """"""
410
+ def __init__(self, *args, **kwargs):
411
+ """
412
+ handle=A Go-side object is always initialized with an explicit handle=arg
413
+ otherwise parameter is a python list that we copy from
414
+ """
415
+ self.index = 0
416
+ if len(kwargs) == 1 and 'handle' in kwargs:
417
+ self.handle = kwargs['handle']
418
+ _api.IncRef(self.handle)
419
+ elif len(args) == 1 and isinstance(args[0], go.GoClass):
420
+ self.handle = args[0].handle
421
+ _api.IncRef(self.handle)
422
+ else:
423
+ self.handle = _api.Map_string_Ptr_environment_Class_CTor()
424
+ _api.IncRef(self.handle)
425
+ if len(args) > 0:
426
+ if not isinstance(args[0], _collections_abc.Mapping):
427
+ raise TypeError('Map_string_Ptr_environment_Class.__init__ takes a mapping as argument')
428
+ for k, v in args[0].items():
429
+ _api.Map_string_Ptr_environment_Class_set(self.handle, k, v)
430
+ def __del__(self):
431
+ _api.DecRef(self.handle)
432
+ def __str__(self):
433
+ s = 'api.Map_string_Ptr_environment_Class len: ' + str(len(self)) + ' handle: ' + str(self.handle) + ' {'
434
+ if len(self) < 120:
435
+ for k, v in self.items():
436
+ s += str(k) + '=' + str(v) + ', '
437
+ return s + '}'
438
+ def __repr__(self):
439
+ s = 'api.Map_string_Ptr_environment_Class({'
440
+ for k, v in self.items():
441
+ s += str(k) + '=' + str(v) + ', '
442
+ return s + '})'
443
+ def __len__(self):
444
+ return _api.Map_string_Ptr_environment_Class_len(self.handle)
445
+ def __getitem__(self, key):
446
+ return go.Ptr_environment_Class(handle=_api.Map_string_Ptr_environment_Class_elem(self.handle, key))
447
+ def __setitem__(self, key, value):
448
+ _api.Map_string_Ptr_environment_Class_set(self.handle, key, value.handle)
449
+ def __delitem__(self, key):
450
+ return _api.Map_string_Ptr_environment_Class_delete(self.handle, key)
451
+ def keys(self):
452
+ return go.Slice_string(handle=_api.Map_string_Ptr_environment_Class_keys(self.handle))
453
+ def values(self):
454
+ vls = []
455
+ kys = self.keys()
456
+ for k in kys:
457
+ vls.append(self[k])
458
+ return vls
459
+ def items(self):
460
+ vls = []
461
+ kys = self.keys()
462
+ for k in kys:
463
+ vls.append((k, self[k]))
464
+ return vls
465
+ def __iter__(self):
466
+ return iter(self.items())
467
+ def __contains__(self, key):
468
+ return _api.Map_string_Ptr_environment_Class_contains(self.handle, key)
469
+
470
+ # Python type for map map[string]*environment.Function
471
+ class Map_string_Ptr_environment_Function(go.GoClass):
472
+ """"""
473
+ def __init__(self, *args, **kwargs):
474
+ """
475
+ handle=A Go-side object is always initialized with an explicit handle=arg
476
+ otherwise parameter is a python list that we copy from
477
+ """
478
+ self.index = 0
479
+ if len(kwargs) == 1 and 'handle' in kwargs:
480
+ self.handle = kwargs['handle']
481
+ _api.IncRef(self.handle)
482
+ elif len(args) == 1 and isinstance(args[0], go.GoClass):
483
+ self.handle = args[0].handle
484
+ _api.IncRef(self.handle)
485
+ else:
486
+ self.handle = _api.Map_string_Ptr_environment_Function_CTor()
487
+ _api.IncRef(self.handle)
488
+ if len(args) > 0:
489
+ if not isinstance(args[0], _collections_abc.Mapping):
490
+ raise TypeError('Map_string_Ptr_environment_Function.__init__ takes a mapping as argument')
491
+ for k, v in args[0].items():
492
+ _api.Map_string_Ptr_environment_Function_set(self.handle, k, v)
493
+ def __del__(self):
494
+ _api.DecRef(self.handle)
495
+ def __str__(self):
496
+ s = 'api.Map_string_Ptr_environment_Function len: ' + str(len(self)) + ' handle: ' + str(self.handle) + ' {'
497
+ if len(self) < 120:
498
+ for k, v in self.items():
499
+ s += str(k) + '=' + str(v) + ', '
500
+ return s + '}'
501
+ def __repr__(self):
502
+ s = 'api.Map_string_Ptr_environment_Function({'
503
+ for k, v in self.items():
504
+ s += str(k) + '=' + str(v) + ', '
505
+ return s + '})'
506
+ def __len__(self):
507
+ return _api.Map_string_Ptr_environment_Function_len(self.handle)
508
+ def __getitem__(self, key):
509
+ return go.Ptr_environment_Function(handle=_api.Map_string_Ptr_environment_Function_elem(self.handle, key))
510
+ def __setitem__(self, key, value):
511
+ _api.Map_string_Ptr_environment_Function_set(self.handle, key, value.handle)
512
+ def __delitem__(self, key):
513
+ return _api.Map_string_Ptr_environment_Function_delete(self.handle, key)
514
+ def keys(self):
515
+ return go.Slice_string(handle=_api.Map_string_Ptr_environment_Function_keys(self.handle))
516
+ def values(self):
517
+ vls = []
518
+ kys = self.keys()
519
+ for k in kys:
520
+ vls.append(self[k])
521
+ return vls
522
+ def items(self):
523
+ vls = []
524
+ kys = self.keys()
525
+ for k in kys:
526
+ vls.append((k, self[k]))
527
+ return vls
528
+ def __iter__(self):
529
+ return iter(self.items())
530
+ def __contains__(self, key):
531
+ return _api.Map_string_Ptr_environment_Function_contains(self.handle, key)
532
+
533
+ # Python type for map map[string]*environment.MemberVariable
534
+ class Map_string_Ptr_environment_MemberVariable(go.GoClass):
535
+ """"""
536
+ def __init__(self, *args, **kwargs):
537
+ """
538
+ handle=A Go-side object is always initialized with an explicit handle=arg
539
+ otherwise parameter is a python list that we copy from
540
+ """
541
+ self.index = 0
542
+ if len(kwargs) == 1 and 'handle' in kwargs:
543
+ self.handle = kwargs['handle']
544
+ _api.IncRef(self.handle)
545
+ elif len(args) == 1 and isinstance(args[0], go.GoClass):
546
+ self.handle = args[0].handle
547
+ _api.IncRef(self.handle)
548
+ else:
549
+ self.handle = _api.Map_string_Ptr_environment_MemberVariable_CTor()
550
+ _api.IncRef(self.handle)
551
+ if len(args) > 0:
552
+ if not isinstance(args[0], _collections_abc.Mapping):
553
+ raise TypeError('Map_string_Ptr_environment_MemberVariable.__init__ takes a mapping as argument')
554
+ for k, v in args[0].items():
555
+ _api.Map_string_Ptr_environment_MemberVariable_set(self.handle, k, v)
556
+ def __del__(self):
557
+ _api.DecRef(self.handle)
558
+ def __str__(self):
559
+ s = 'api.Map_string_Ptr_environment_MemberVariable len: ' + str(len(self)) + ' handle: ' + str(self.handle) + ' {'
560
+ if len(self) < 120:
561
+ for k, v in self.items():
562
+ s += str(k) + '=' + str(v) + ', '
563
+ return s + '}'
564
+ def __repr__(self):
565
+ s = 'api.Map_string_Ptr_environment_MemberVariable({'
566
+ for k, v in self.items():
567
+ s += str(k) + '=' + str(v) + ', '
568
+ return s + '})'
569
+ def __len__(self):
570
+ return _api.Map_string_Ptr_environment_MemberVariable_len(self.handle)
571
+ def __getitem__(self, key):
572
+ return go.Ptr_environment_MemberVariable(handle=_api.Map_string_Ptr_environment_MemberVariable_elem(self.handle, key))
573
+ def __setitem__(self, key, value):
574
+ _api.Map_string_Ptr_environment_MemberVariable_set(self.handle, key, value.handle)
575
+ def __delitem__(self, key):
576
+ return _api.Map_string_Ptr_environment_MemberVariable_delete(self.handle, key)
577
+ def keys(self):
578
+ return go.Slice_string(handle=_api.Map_string_Ptr_environment_MemberVariable_keys(self.handle))
579
+ def values(self):
580
+ vls = []
581
+ kys = self.keys()
582
+ for k in kys:
583
+ vls.append(self[k])
584
+ return vls
585
+ def items(self):
586
+ vls = []
587
+ kys = self.keys()
588
+ for k in kys:
589
+ vls.append((k, self[k]))
590
+ return vls
591
+ def __iter__(self):
592
+ return iter(self.items())
593
+ def __contains__(self, key):
594
+ return _api.Map_string_Ptr_environment_MemberVariable_contains(self.handle, key)
595
+
596
+ # Python type for map map[string]*environment.Variable
597
+ class Map_string_Ptr_environment_Variable(go.GoClass):
598
+ """"""
599
+ def __init__(self, *args, **kwargs):
600
+ """
601
+ handle=A Go-side object is always initialized with an explicit handle=arg
602
+ otherwise parameter is a python list that we copy from
603
+ """
604
+ self.index = 0
605
+ if len(kwargs) == 1 and 'handle' in kwargs:
606
+ self.handle = kwargs['handle']
607
+ _api.IncRef(self.handle)
608
+ elif len(args) == 1 and isinstance(args[0], go.GoClass):
609
+ self.handle = args[0].handle
610
+ _api.IncRef(self.handle)
611
+ else:
612
+ self.handle = _api.Map_string_Ptr_environment_Variable_CTor()
613
+ _api.IncRef(self.handle)
614
+ if len(args) > 0:
615
+ if not isinstance(args[0], _collections_abc.Mapping):
616
+ raise TypeError('Map_string_Ptr_environment_Variable.__init__ takes a mapping as argument')
617
+ for k, v in args[0].items():
618
+ _api.Map_string_Ptr_environment_Variable_set(self.handle, k, v)
619
+ def __del__(self):
620
+ _api.DecRef(self.handle)
621
+ def __str__(self):
622
+ s = 'api.Map_string_Ptr_environment_Variable len: ' + str(len(self)) + ' handle: ' + str(self.handle) + ' {'
623
+ if len(self) < 120:
624
+ for k, v in self.items():
625
+ s += str(k) + '=' + str(v) + ', '
626
+ return s + '}'
627
+ def __repr__(self):
628
+ s = 'api.Map_string_Ptr_environment_Variable({'
629
+ for k, v in self.items():
630
+ s += str(k) + '=' + str(v) + ', '
631
+ return s + '})'
632
+ def __len__(self):
633
+ return _api.Map_string_Ptr_environment_Variable_len(self.handle)
634
+ def __getitem__(self, key):
635
+ return go.Ptr_environment_Variable(handle=_api.Map_string_Ptr_environment_Variable_elem(self.handle, key))
636
+ def __setitem__(self, key, value):
637
+ _api.Map_string_Ptr_environment_Variable_set(self.handle, key, value.handle)
638
+ def __delitem__(self, key):
639
+ return _api.Map_string_Ptr_environment_Variable_delete(self.handle, key)
640
+ def keys(self):
641
+ return go.Slice_string(handle=_api.Map_string_Ptr_environment_Variable_keys(self.handle))
642
+ def values(self):
643
+ vls = []
644
+ kys = self.keys()
645
+ for k in kys:
646
+ vls.append(self[k])
647
+ return vls
648
+ def items(self):
649
+ vls = []
650
+ kys = self.keys()
651
+ for k in kys:
652
+ vls.append((k, self[k]))
653
+ return vls
654
+ def __iter__(self):
655
+ return iter(self.items())
656
+ def __contains__(self, key):
657
+ return _api.Map_string_Ptr_environment_Variable_contains(self.handle, key)
658
+
659
+ # Python type for map map[string]api.GoValue
660
+ class Map_string_api_GoValue(go.GoClass):
661
+ """"""
662
+ def __init__(self, *args, **kwargs):
663
+ """
664
+ handle=A Go-side object is always initialized with an explicit handle=arg
665
+ otherwise parameter is a python list that we copy from
666
+ """
667
+ self.index = 0
668
+ if len(kwargs) == 1 and 'handle' in kwargs:
669
+ self.handle = kwargs['handle']
670
+ _api.IncRef(self.handle)
671
+ elif len(args) == 1 and isinstance(args[0], go.GoClass):
672
+ self.handle = args[0].handle
673
+ _api.IncRef(self.handle)
674
+ else:
675
+ self.handle = _api.Map_string_api_GoValue_CTor()
676
+ _api.IncRef(self.handle)
677
+ if len(args) > 0:
678
+ if not isinstance(args[0], _collections_abc.Mapping):
679
+ raise TypeError('Map_string_api_GoValue.__init__ takes a mapping as argument')
680
+ for k, v in args[0].items():
681
+ _api.Map_string_api_GoValue_set(self.handle, k, v)
682
+ def __del__(self):
683
+ _api.DecRef(self.handle)
684
+ def __str__(self):
685
+ s = 'api.Map_string_api_GoValue len: ' + str(len(self)) + ' handle: ' + str(self.handle) + ' {'
686
+ if len(self) < 120:
687
+ for k, v in self.items():
688
+ s += str(k) + '=' + str(v) + ', '
689
+ return s + '}'
690
+ def __repr__(self):
691
+ s = 'api.Map_string_api_GoValue({'
692
+ for k, v in self.items():
693
+ s += str(k) + '=' + str(v) + ', '
694
+ return s + '})'
695
+ def __len__(self):
696
+ return _api.Map_string_api_GoValue_len(self.handle)
697
+ def __getitem__(self, key):
698
+ return GoValue(handle=_api.Map_string_api_GoValue_elem(self.handle, key))
699
+ def __setitem__(self, key, value):
700
+ _api.Map_string_api_GoValue_set(self.handle, key, value.handle)
701
+ def __delitem__(self, key):
702
+ return _api.Map_string_api_GoValue_delete(self.handle, key)
703
+ def keys(self):
704
+ return go.Slice_string(handle=_api.Map_string_api_GoValue_keys(self.handle))
705
+ def values(self):
706
+ vls = []
707
+ kys = self.keys()
708
+ for k in kys:
709
+ vls.append(self[k])
710
+ return vls
711
+ def items(self):
712
+ vls = []
713
+ kys = self.keys()
714
+ for k in kys:
715
+ vls.append((k, self[k]))
716
+ return vls
717
+ def __iter__(self):
718
+ return iter(self.items())
719
+ def __contains__(self, key):
720
+ return _api.Map_string_api_GoValue_contains(self.handle, key)
721
+
722
+
723
+ #---- Enums from Go (collections of consts with same type) ---
724
+
725
+
726
+ #---- Constants from Go: Python can only ask that you please don't change these! ---
727
+ CompileErrorType = "compile"
728
+ ConfigErrorType = "config"
729
+ ConversionErrorType = "conversion"
730
+ ForeignModuleNamespace = "foreign:anonymous"
731
+ GoValueIDKey = "__GoValue_id"
732
+ RuntimeErrorType = "runtime"
733
+ TimeoutErrorType = "timeout"
734
+
735
+
736
+ # ---- Global Variables: can only use functions to access ---
737
+
738
+
739
+ # ---- Interfaces ---
740
+
741
+
742
+ # ---- Structs ---
743
+
744
+ # Python type for struct api.UnknownFunctionHandler
745
+ class UnknownFunctionHandler(go.GoClass):
746
+ """"""
747
+ def __init__(self, *args, **kwargs):
748
+ """
749
+ handle=A Go-side object is always initialized with an explicit handle=arg
750
+ otherwise parameters can be unnamed in order of field names or named fields
751
+ in which case a new Go object is constructed first
752
+ """
753
+ if len(kwargs) == 1 and 'handle' in kwargs:
754
+ self.handle = kwargs['handle']
755
+ _api.IncRef(self.handle)
756
+ elif len(args) == 1 and isinstance(args[0], go.GoClass):
757
+ self.handle = args[0].handle
758
+ _api.IncRef(self.handle)
759
+ else:
760
+ self.handle = _api.api_UnknownFunctionHandler_CTor()
761
+ _api.IncRef(self.handle)
762
+ def __del__(self):
763
+ _api.DecRef(self.handle)
764
+ def __str__(self):
765
+ pr = [(p, getattr(self, p)) for p in dir(self) if not p.startswith('__')]
766
+ sv = 'api.UnknownFunctionHandler{'
767
+ first = True
768
+ for v in pr:
769
+ if callable(v[1]):
770
+ continue
771
+ if first:
772
+ first = False
773
+ else:
774
+ sv += ', '
775
+ sv += v[0] + '=' + str(v[1])
776
+ return sv + '}'
777
+ def __repr__(self):
778
+ pr = [(p, getattr(self, p)) for p in dir(self) if not p.startswith('__')]
779
+ sv = 'api.UnknownFunctionHandler ( '
780
+ for v in pr:
781
+ if not callable(v[1]):
782
+ sv += v[0] + '=' + str(v[1]) + ', '
783
+ return sv + ')'
784
+
785
+ # Python type for struct api.VMCompatibilityShim
786
+ class VMCompatibilityShim(go.GoClass):
787
+ """VMCompatibilityShim is a shim to provide compatibility for external\nlanguages that cannot interact with the standard VM interface through\nGo types. Message passing is done through JSON strings.\n"""
788
+ def __init__(self, *args, **kwargs):
789
+ """
790
+ handle=A Go-side object is always initialized with an explicit handle=arg
791
+ otherwise parameters can be unnamed in order of field names or named fields
792
+ in which case a new Go object is constructed first
793
+ """
794
+ if len(kwargs) == 1 and 'handle' in kwargs:
795
+ self.handle = kwargs['handle']
796
+ _api.IncRef(self.handle)
797
+ elif len(args) == 1 and isinstance(args[0], go.GoClass):
798
+ self.handle = args[0].handle
799
+ _api.IncRef(self.handle)
800
+ else:
801
+ self.handle = _api.api_VMCompatibilityShim_CTor()
802
+ _api.IncRef(self.handle)
803
+ def __del__(self):
804
+ _api.DecRef(self.handle)
805
+ def __str__(self):
806
+ pr = [(p, getattr(self, p)) for p in dir(self) if not p.startswith('__')]
807
+ sv = 'api.VMCompatibilityShim{'
808
+ first = True
809
+ for v in pr:
810
+ if callable(v[1]):
811
+ continue
812
+ if first:
813
+ first = False
814
+ else:
815
+ sv += ', '
816
+ sv += v[0] + '=' + str(v[1])
817
+ return sv + '}'
818
+ def __repr__(self):
819
+ pr = [(p, getattr(self, p)) for p in dir(self) if not p.startswith('__')]
820
+ sv = 'api.VMCompatibilityShim ( '
821
+ for v in pr:
822
+ if not callable(v[1]):
823
+ sv += v[0] + '=' + str(v[1]) + ', '
824
+ return sv + ')'
825
+ def DefineFunction(self, id, name, argc, function):
826
+ """DefineFunction(str id, str name, int argc, callable function) str
827
+
828
+ DefineFunction defines a global function with maximum compatibility,
829
+ wrapping arguments and return values as JSON strings.
830
+ An optional id cookie is passed back to the function to identify it.
831
+ jsonArgs is a JSON array string of the arguments.
832
+ The function should return a JSON object string with "result" and "error" fields.
833
+ """
834
+ return _api.api_VMCompatibilityShim_DefineFunction(self.handle, id, name, argc, function)
835
+ def BuildNewClassVariableWithGetter(self, variable, getterID, getter):
836
+ """BuildNewClassVariableWithGetter(object variable, str getterID, callable getter) object"""
837
+ return ClassVariable(handle=_api.api_VMCompatibilityShim_BuildNewClassVariableWithGetter(self.handle, variable.handle, getterID, getter))
838
+ def BuildNewClassVariableWithSetter(self, variable, setterID, setter):
839
+ """BuildNewClassVariableWithSetter(object variable, str setterID, callable setter) object"""
840
+ return ClassVariable(handle=_api.api_VMCompatibilityShim_BuildNewClassVariableWithSetter(self.handle, variable.handle, setterID, setter))
841
+ def BuildNewClassMethod(self, method, id, function):
842
+ """BuildNewClassMethod(object method, str id, callable function) object"""
843
+ return ClassMethod(handle=_api.api_VMCompatibilityShim_BuildNewClassMethod(self.handle, method.handle, id, function))
844
+ def BuildNewUnknownFunctionHandler(self, id, function):
845
+ """BuildNewUnknownFunctionHandler(str id, callable function) object"""
846
+ return UnknownFunctionHandler(handle=_api.api_VMCompatibilityShim_BuildNewUnknownFunctionHandler(self.handle, id, function))
847
+ def IsClassDefined(self, name):
848
+ """IsClassDefined(str name) bool"""
849
+ return _api.api_VMCompatibilityShim_IsClassDefined(self.handle, name)
850
+ def LookupObject(self, id):
851
+ """LookupObject(str id) object, str"""
852
+ return GoValue(handle=_api.api_VMCompatibilityShim_LookupObject(self.handle, id))
853
+ def GetObjectMRO(self, id):
854
+ """GetObjectMRO(str id) []str, str"""
855
+ return go.Slice_string(handle=_api.api_VMCompatibilityShim_GetObjectMRO(self.handle, id))
856
+ def GetObjectImmediateFunctions(self, id):
857
+ """GetObjectImmediateFunctions(str id) []str, str"""
858
+ return go.Slice_string(handle=_api.api_VMCompatibilityShim_GetObjectImmediateFunctions(self.handle, id))
859
+ def GetObjectImmediateVariables(self, id):
860
+ """GetObjectImmediateVariables(str id) []str, str"""
861
+ return go.Slice_string(handle=_api.api_VMCompatibilityShim_GetObjectImmediateVariables(self.handle, id))
862
+ def AddVariableToObject(self, id, variable):
863
+ """AddVariableToObject(str id, object variable) str"""
864
+ return _api.api_VMCompatibilityShim_AddVariableToObject(self.handle, id, variable.handle)
865
+
866
+ # Python type for struct api.VMConfig
867
+ class VMConfig(go.GoClass):
868
+ """VMConfig holds configuration options for the VM\n"""
869
+ def __init__(self, *args, **kwargs):
870
+ """
871
+ handle=A Go-side object is always initialized with an explicit handle=arg
872
+ otherwise parameters can be unnamed in order of field names or named fields
873
+ in which case a new Go object is constructed first
874
+ """
875
+ if len(kwargs) == 1 and 'handle' in kwargs:
876
+ self.handle = kwargs['handle']
877
+ _api.IncRef(self.handle)
878
+ elif len(args) == 1 and isinstance(args[0], go.GoClass):
879
+ self.handle = args[0].handle
880
+ _api.IncRef(self.handle)
881
+ else:
882
+ self.handle = _api.api_VMConfig_CTor()
883
+ _api.IncRef(self.handle)
884
+ if 0 < len(args):
885
+ self.Stdout = args[0]
886
+ if "Stdout" in kwargs:
887
+ self.Stdout = kwargs["Stdout"]
888
+ if 1 < len(args):
889
+ self.Stdin = args[1]
890
+ if "Stdin" in kwargs:
891
+ self.Stdin = kwargs["Stdin"]
892
+ if 2 < len(args):
893
+ self.Timeout = args[2]
894
+ if "Timeout" in kwargs:
895
+ self.Timeout = kwargs["Timeout"]
896
+ if 3 < len(args):
897
+ self.WorkingDirectory = args[3]
898
+ if "WorkingDirectory" in kwargs:
899
+ self.WorkingDirectory = kwargs["WorkingDirectory"]
900
+ def __del__(self):
901
+ _api.DecRef(self.handle)
902
+ def __str__(self):
903
+ pr = [(p, getattr(self, p)) for p in dir(self) if not p.startswith('__')]
904
+ sv = 'api.VMConfig{'
905
+ first = True
906
+ for v in pr:
907
+ if callable(v[1]):
908
+ continue
909
+ if first:
910
+ first = False
911
+ else:
912
+ sv += ', '
913
+ sv += v[0] + '=' + str(v[1])
914
+ return sv + '}'
915
+ def __repr__(self):
916
+ pr = [(p, getattr(self, p)) for p in dir(self) if not p.startswith('__')]
917
+ sv = 'api.VMConfig ( '
918
+ for v in pr:
919
+ if not callable(v[1]):
920
+ sv += v[0] + '=' + str(v[1]) + ', '
921
+ return sv + ')'
922
+ @property
923
+ def Stdout(self):
924
+ """I/O configuration
925
+ """
926
+ return go.io_Writer(handle=_api.api_VMConfig_Stdout_Get(self.handle))
927
+ @Stdout.setter
928
+ def Stdout(self, value):
929
+ if isinstance(value, go.GoClass):
930
+ _api.api_VMConfig_Stdout_Set(self.handle, value.handle)
931
+ else:
932
+ raise TypeError("supplied argument type {t} is not a go.GoClass".format(t=type(value)))
933
+ @property
934
+ def Stdin(self):
935
+ return go.io_Reader(handle=_api.api_VMConfig_Stdin_Get(self.handle))
936
+ @Stdin.setter
937
+ def Stdin(self, value):
938
+ if isinstance(value, go.GoClass):
939
+ _api.api_VMConfig_Stdin_Set(self.handle, value.handle)
940
+ else:
941
+ raise TypeError("supplied argument type {t} is not a go.GoClass".format(t=type(value)))
942
+ @property
943
+ def Timeout(self):
944
+ """Execution configuration
945
+ """
946
+ return _api.api_VMConfig_Timeout_Get(self.handle)
947
+ @Timeout.setter
948
+ def Timeout(self, value):
949
+ if isinstance(value, go.GoClass):
950
+ _api.api_VMConfig_Timeout_Set(self.handle, value.handle)
951
+ else:
952
+ _api.api_VMConfig_Timeout_Set(self.handle, value)
953
+ @property
954
+ def WorkingDirectory(self):
955
+ return _api.api_VMConfig_WorkingDirectory_Get(self.handle)
956
+ @WorkingDirectory.setter
957
+ def WorkingDirectory(self, value):
958
+ if isinstance(value, go.GoClass):
959
+ _api.api_VMConfig_WorkingDirectory_Set(self.handle, value.handle)
960
+ else:
961
+ _api.api_VMConfig_WorkingDirectory_Set(self.handle, value)
962
+ def Validate(self):
963
+ """Validate() str
964
+
965
+ Validate checks if the configuration is valid
966
+ """
967
+ return _api.api_VMConfig_Validate(self.handle)
968
+
969
+ # Python type for struct api.ClassDefinition
970
+ class ClassDefinition(go.GoClass):
971
+ """"""
972
+ def __init__(self, *args, **kwargs):
973
+ """
974
+ handle=A Go-side object is always initialized with an explicit handle=arg
975
+ otherwise parameters can be unnamed in order of field names or named fields
976
+ in which case a new Go object is constructed first
977
+ """
978
+ if len(kwargs) == 1 and 'handle' in kwargs:
979
+ self.handle = kwargs['handle']
980
+ _api.IncRef(self.handle)
981
+ elif len(args) == 1 and isinstance(args[0], go.GoClass):
982
+ self.handle = args[0].handle
983
+ _api.IncRef(self.handle)
984
+ else:
985
+ self.handle = _api.api_ClassDefinition_CTor()
986
+ _api.IncRef(self.handle)
987
+ if 0 < len(args):
988
+ self.Name = args[0]
989
+ if "Name" in kwargs:
990
+ self.Name = kwargs["Name"]
991
+ if 1 < len(args):
992
+ self.PublicVariables = args[1]
993
+ if "PublicVariables" in kwargs:
994
+ self.PublicVariables = kwargs["PublicVariables"]
995
+ if 2 < len(args):
996
+ self.PrivateVariables = args[2]
997
+ if "PrivateVariables" in kwargs:
998
+ self.PrivateVariables = kwargs["PrivateVariables"]
999
+ if 3 < len(args):
1000
+ self.SharedVariables = args[3]
1001
+ if "SharedVariables" in kwargs:
1002
+ self.SharedVariables = kwargs["SharedVariables"]
1003
+ if 4 < len(args):
1004
+ self.PublicMethods = args[4]
1005
+ if "PublicMethods" in kwargs:
1006
+ self.PublicMethods = kwargs["PublicMethods"]
1007
+ if 5 < len(args):
1008
+ self.PrivateMethods = args[5]
1009
+ if "PrivateMethods" in kwargs:
1010
+ self.PrivateMethods = kwargs["PrivateMethods"]
1011
+ if 6 < len(args):
1012
+ self.UnknownFunctionHandler = args[6]
1013
+ if "UnknownFunctionHandler" in kwargs:
1014
+ self.UnknownFunctionHandler = kwargs["UnknownFunctionHandler"]
1015
+ def __del__(self):
1016
+ _api.DecRef(self.handle)
1017
+ def __str__(self):
1018
+ pr = [(p, getattr(self, p)) for p in dir(self) if not p.startswith('__')]
1019
+ sv = 'api.ClassDefinition{'
1020
+ first = True
1021
+ for v in pr:
1022
+ if callable(v[1]):
1023
+ continue
1024
+ if first:
1025
+ first = False
1026
+ else:
1027
+ sv += ', '
1028
+ sv += v[0] + '=' + str(v[1])
1029
+ return sv + '}'
1030
+ def __repr__(self):
1031
+ pr = [(p, getattr(self, p)) for p in dir(self) if not p.startswith('__')]
1032
+ sv = 'api.ClassDefinition ( '
1033
+ for v in pr:
1034
+ if not callable(v[1]):
1035
+ sv += v[0] + '=' + str(v[1]) + ', '
1036
+ return sv + ')'
1037
+ @property
1038
+ def Name(self):
1039
+ return _api.api_ClassDefinition_Name_Get(self.handle)
1040
+ @Name.setter
1041
+ def Name(self, value):
1042
+ if isinstance(value, go.GoClass):
1043
+ _api.api_ClassDefinition_Name_Set(self.handle, value.handle)
1044
+ else:
1045
+ _api.api_ClassDefinition_Name_Set(self.handle, value)
1046
+ @property
1047
+ def PublicVariables(self):
1048
+ return Map_string_Ptr_api_ClassVariable(handle=_api.api_ClassDefinition_PublicVariables_Get(self.handle))
1049
+ @PublicVariables.setter
1050
+ def PublicVariables(self, value):
1051
+ if isinstance(value, go.GoClass):
1052
+ _api.api_ClassDefinition_PublicVariables_Set(self.handle, value.handle)
1053
+ else:
1054
+ raise TypeError("supplied argument type {t} is not a go.GoClass".format(t=type(value)))
1055
+ @property
1056
+ def PrivateVariables(self):
1057
+ return Map_string_Ptr_api_ClassVariable(handle=_api.api_ClassDefinition_PrivateVariables_Get(self.handle))
1058
+ @PrivateVariables.setter
1059
+ def PrivateVariables(self, value):
1060
+ if isinstance(value, go.GoClass):
1061
+ _api.api_ClassDefinition_PrivateVariables_Set(self.handle, value.handle)
1062
+ else:
1063
+ raise TypeError("supplied argument type {t} is not a go.GoClass".format(t=type(value)))
1064
+ @property
1065
+ def SharedVariables(self):
1066
+ return Map_string_Ptr_api_ClassVariable(handle=_api.api_ClassDefinition_SharedVariables_Get(self.handle))
1067
+ @SharedVariables.setter
1068
+ def SharedVariables(self, value):
1069
+ if isinstance(value, go.GoClass):
1070
+ _api.api_ClassDefinition_SharedVariables_Set(self.handle, value.handle)
1071
+ else:
1072
+ raise TypeError("supplied argument type {t} is not a go.GoClass".format(t=type(value)))
1073
+ @property
1074
+ def PublicMethods(self):
1075
+ return Map_string_Ptr_api_ClassMethod(handle=_api.api_ClassDefinition_PublicMethods_Get(self.handle))
1076
+ @PublicMethods.setter
1077
+ def PublicMethods(self, value):
1078
+ if isinstance(value, go.GoClass):
1079
+ _api.api_ClassDefinition_PublicMethods_Set(self.handle, value.handle)
1080
+ else:
1081
+ raise TypeError("supplied argument type {t} is not a go.GoClass".format(t=type(value)))
1082
+ @property
1083
+ def PrivateMethods(self):
1084
+ return Map_string_Ptr_api_ClassMethod(handle=_api.api_ClassDefinition_PrivateMethods_Get(self.handle))
1085
+ @PrivateMethods.setter
1086
+ def PrivateMethods(self, value):
1087
+ if isinstance(value, go.GoClass):
1088
+ _api.api_ClassDefinition_PrivateMethods_Set(self.handle, value.handle)
1089
+ else:
1090
+ raise TypeError("supplied argument type {t} is not a go.GoClass".format(t=type(value)))
1091
+ @property
1092
+ def UnknownFunctionHandler(self):
1093
+ return UnknownFunctionHandler(handle=_api.api_ClassDefinition_UnknownFunctionHandler_Get(self.handle))
1094
+ @UnknownFunctionHandler.setter
1095
+ def UnknownFunctionHandler(self, value):
1096
+ if isinstance(value, go.GoClass):
1097
+ _api.api_ClassDefinition_UnknownFunctionHandler_Set(self.handle, value.handle)
1098
+ else:
1099
+ raise TypeError("supplied argument type {t} is not a go.GoClass".format(t=type(value)))
1100
+
1101
+ # Python type for struct api.ClassMethod
1102
+ class ClassMethod(go.GoClass):
1103
+ """"""
1104
+ def __init__(self, *args, **kwargs):
1105
+ """
1106
+ handle=A Go-side object is always initialized with an explicit handle=arg
1107
+ otherwise parameters can be unnamed in order of field names or named fields
1108
+ in which case a new Go object is constructed first
1109
+ """
1110
+ if len(kwargs) == 1 and 'handle' in kwargs:
1111
+ self.handle = kwargs['handle']
1112
+ _api.IncRef(self.handle)
1113
+ elif len(args) == 1 and isinstance(args[0], go.GoClass):
1114
+ self.handle = args[0].handle
1115
+ _api.IncRef(self.handle)
1116
+ else:
1117
+ self.handle = _api.api_ClassMethod_CTor()
1118
+ _api.IncRef(self.handle)
1119
+ if 0 < len(args):
1120
+ self.Name = args[0]
1121
+ if "Name" in kwargs:
1122
+ self.Name = kwargs["Name"]
1123
+ if 1 < len(args):
1124
+ self.Argc = args[1]
1125
+ if "Argc" in kwargs:
1126
+ self.Argc = kwargs["Argc"]
1127
+ def __del__(self):
1128
+ _api.DecRef(self.handle)
1129
+ def __str__(self):
1130
+ pr = [(p, getattr(self, p)) for p in dir(self) if not p.startswith('__')]
1131
+ sv = 'api.ClassMethod{'
1132
+ first = True
1133
+ for v in pr:
1134
+ if callable(v[1]):
1135
+ continue
1136
+ if first:
1137
+ first = False
1138
+ else:
1139
+ sv += ', '
1140
+ sv += v[0] + '=' + str(v[1])
1141
+ return sv + '}'
1142
+ def __repr__(self):
1143
+ pr = [(p, getattr(self, p)) for p in dir(self) if not p.startswith('__')]
1144
+ sv = 'api.ClassMethod ( '
1145
+ for v in pr:
1146
+ if not callable(v[1]):
1147
+ sv += v[0] + '=' + str(v[1]) + ', '
1148
+ return sv + ')'
1149
+ @property
1150
+ def Name(self):
1151
+ return _api.api_ClassMethod_Name_Get(self.handle)
1152
+ @Name.setter
1153
+ def Name(self, value):
1154
+ if isinstance(value, go.GoClass):
1155
+ _api.api_ClassMethod_Name_Set(self.handle, value.handle)
1156
+ else:
1157
+ _api.api_ClassMethod_Name_Set(self.handle, value)
1158
+ @property
1159
+ def Argc(self):
1160
+ return _api.api_ClassMethod_Argc_Get(self.handle)
1161
+ @Argc.setter
1162
+ def Argc(self, value):
1163
+ if isinstance(value, go.GoClass):
1164
+ _api.api_ClassMethod_Argc_Set(self.handle, value.handle)
1165
+ else:
1166
+ _api.api_ClassMethod_Argc_Set(self.handle, value)
1167
+
1168
+ # Python type for struct api.ExecutionResult
1169
+ class ExecutionResult(go.GoClass):
1170
+ """ExecutionResult represents the result of executing Objective-LOL code\n"""
1171
+ def __init__(self, *args, **kwargs):
1172
+ """
1173
+ handle=A Go-side object is always initialized with an explicit handle=arg
1174
+ otherwise parameters can be unnamed in order of field names or named fields
1175
+ in which case a new Go object is constructed first
1176
+ """
1177
+ if len(kwargs) == 1 and 'handle' in kwargs:
1178
+ self.handle = kwargs['handle']
1179
+ _api.IncRef(self.handle)
1180
+ elif len(args) == 1 and isinstance(args[0], go.GoClass):
1181
+ self.handle = args[0].handle
1182
+ _api.IncRef(self.handle)
1183
+ else:
1184
+ self.handle = _api.api_ExecutionResult_CTor()
1185
+ _api.IncRef(self.handle)
1186
+ if 0 < len(args):
1187
+ self.Value = args[0]
1188
+ if "Value" in kwargs:
1189
+ self.Value = kwargs["Value"]
1190
+ if 1 < len(args):
1191
+ self.RawValue = args[1]
1192
+ if "RawValue" in kwargs:
1193
+ self.RawValue = kwargs["RawValue"]
1194
+ if 2 < len(args):
1195
+ self.Output = args[2]
1196
+ if "Output" in kwargs:
1197
+ self.Output = kwargs["Output"]
1198
+ def __del__(self):
1199
+ _api.DecRef(self.handle)
1200
+ def __str__(self):
1201
+ pr = [(p, getattr(self, p)) for p in dir(self) if not p.startswith('__')]
1202
+ sv = 'api.ExecutionResult{'
1203
+ first = True
1204
+ for v in pr:
1205
+ if callable(v[1]):
1206
+ continue
1207
+ if first:
1208
+ first = False
1209
+ else:
1210
+ sv += ', '
1211
+ sv += v[0] + '=' + str(v[1])
1212
+ return sv + '}'
1213
+ def __repr__(self):
1214
+ pr = [(p, getattr(self, p)) for p in dir(self) if not p.startswith('__')]
1215
+ sv = 'api.ExecutionResult ( '
1216
+ for v in pr:
1217
+ if not callable(v[1]):
1218
+ sv += v[0] + '=' + str(v[1]) + ', '
1219
+ return sv + ')'
1220
+ @property
1221
+ def Value(self):
1222
+ """Return value from the execution (e.g., from MAIN function)
1223
+ """
1224
+ return GoValue(handle=_api.api_ExecutionResult_Value_Get(self.handle))
1225
+ @Value.setter
1226
+ def Value(self, value):
1227
+ if isinstance(value, go.GoClass):
1228
+ _api.api_ExecutionResult_Value_Set(self.handle, value.handle)
1229
+ else:
1230
+ raise TypeError("supplied argument type {t} is not a go.GoClass".format(t=type(value)))
1231
+ @property
1232
+ def RawValue(self):
1233
+ """Raw Objective-LOL value (for advanced use)
1234
+ """
1235
+ return go.environment_Value(handle=_api.api_ExecutionResult_RawValue_Get(self.handle))
1236
+ @RawValue.setter
1237
+ def RawValue(self, value):
1238
+ if isinstance(value, go.GoClass):
1239
+ _api.api_ExecutionResult_RawValue_Set(self.handle, value.handle)
1240
+ else:
1241
+ raise TypeError("supplied argument type {t} is not a go.GoClass".format(t=type(value)))
1242
+ @property
1243
+ def Output(self):
1244
+ """Output captured during execution (if configured)
1245
+ """
1246
+ return _api.api_ExecutionResult_Output_Get(self.handle)
1247
+ @Output.setter
1248
+ def Output(self, value):
1249
+ if isinstance(value, go.GoClass):
1250
+ _api.api_ExecutionResult_Output_Set(self.handle, value.handle)
1251
+ else:
1252
+ _api.api_ExecutionResult_Output_Set(self.handle, value)
1253
+
1254
+ # Python type for struct api.GoValue
1255
+ class GoValue(go.GoClass):
1256
+ """"""
1257
+ def __init__(self, *args, **kwargs):
1258
+ """
1259
+ handle=A Go-side object is always initialized with an explicit handle=arg
1260
+ otherwise parameters can be unnamed in order of field names or named fields
1261
+ in which case a new Go object is constructed first
1262
+ """
1263
+ if len(kwargs) == 1 and 'handle' in kwargs:
1264
+ self.handle = kwargs['handle']
1265
+ _api.IncRef(self.handle)
1266
+ elif len(args) == 1 and isinstance(args[0], go.GoClass):
1267
+ self.handle = args[0].handle
1268
+ _api.IncRef(self.handle)
1269
+ else:
1270
+ self.handle = _api.api_GoValue_CTor()
1271
+ _api.IncRef(self.handle)
1272
+ def __del__(self):
1273
+ _api.DecRef(self.handle)
1274
+ def __str__(self):
1275
+ pr = [(p, getattr(self, p)) for p in dir(self) if not p.startswith('__')]
1276
+ sv = 'api.GoValue{'
1277
+ first = True
1278
+ for v in pr:
1279
+ if callable(v[1]):
1280
+ continue
1281
+ if first:
1282
+ first = False
1283
+ else:
1284
+ sv += ', '
1285
+ sv += v[0] + '=' + str(v[1])
1286
+ return sv + '}'
1287
+ def __repr__(self):
1288
+ pr = [(p, getattr(self, p)) for p in dir(self) if not p.startswith('__')]
1289
+ sv = 'api.GoValue ( '
1290
+ for v in pr:
1291
+ if not callable(v[1]):
1292
+ sv += v[0] + '=' + str(v[1]) + ', '
1293
+ return sv + ')'
1294
+ def ID(self):
1295
+ """ID() str"""
1296
+ return _api.api_GoValue_ID(self.handle)
1297
+ def MarshalJSON(self):
1298
+ """MarshalJSON() []int, str"""
1299
+ return go.Slice_byte(handle=_api.api_GoValue_MarshalJSON(self.handle))
1300
+ def Type(self):
1301
+ """Type() str"""
1302
+ return _api.api_GoValue_Type(self.handle)
1303
+ def Int(self):
1304
+ """Int() long, str"""
1305
+ return _api.api_GoValue_Int(self.handle)
1306
+ def Float(self):
1307
+ """Float() float, str"""
1308
+ return _api.api_GoValue_Float(self.handle)
1309
+ def String(self):
1310
+ """String() str, str"""
1311
+ return _api.api_GoValue_String(self.handle)
1312
+ def Bool(self):
1313
+ """Bool() bool, str"""
1314
+ return _api.api_GoValue_Bool(self.handle)
1315
+ def Slice(self):
1316
+ """Slice() []object, str"""
1317
+ return Slice_api_GoValue(handle=_api.api_GoValue_Slice(self.handle))
1318
+ def Map(self):
1319
+ """Map() object, str"""
1320
+ return Map_string_api_GoValue(handle=_api.api_GoValue_Map(self.handle))
1321
+ def Object(self):
1322
+ """Object() object, str"""
1323
+ return go.Ptr_environment_ObjectInstance(handle=_api.api_GoValue_Object(self.handle))
1324
+
1325
+ # Python type for struct api.SourceLocation
1326
+ class SourceLocation(go.GoClass):
1327
+ """SourceLocation represents a location in source code\n"""
1328
+ def __init__(self, *args, **kwargs):
1329
+ """
1330
+ handle=A Go-side object is always initialized with an explicit handle=arg
1331
+ otherwise parameters can be unnamed in order of field names or named fields
1332
+ in which case a new Go object is constructed first
1333
+ """
1334
+ if len(kwargs) == 1 and 'handle' in kwargs:
1335
+ self.handle = kwargs['handle']
1336
+ _api.IncRef(self.handle)
1337
+ elif len(args) == 1 and isinstance(args[0], go.GoClass):
1338
+ self.handle = args[0].handle
1339
+ _api.IncRef(self.handle)
1340
+ else:
1341
+ self.handle = _api.api_SourceLocation_CTor()
1342
+ _api.IncRef(self.handle)
1343
+ if 0 < len(args):
1344
+ self.Filename = args[0]
1345
+ if "Filename" in kwargs:
1346
+ self.Filename = kwargs["Filename"]
1347
+ if 1 < len(args):
1348
+ self.Line = args[1]
1349
+ if "Line" in kwargs:
1350
+ self.Line = kwargs["Line"]
1351
+ if 2 < len(args):
1352
+ self.Column = args[2]
1353
+ if "Column" in kwargs:
1354
+ self.Column = kwargs["Column"]
1355
+ def __del__(self):
1356
+ _api.DecRef(self.handle)
1357
+ def __str__(self):
1358
+ pr = [(p, getattr(self, p)) for p in dir(self) if not p.startswith('__')]
1359
+ sv = 'api.SourceLocation{'
1360
+ first = True
1361
+ for v in pr:
1362
+ if callable(v[1]):
1363
+ continue
1364
+ if first:
1365
+ first = False
1366
+ else:
1367
+ sv += ', '
1368
+ sv += v[0] + '=' + str(v[1])
1369
+ return sv + '}'
1370
+ def __repr__(self):
1371
+ pr = [(p, getattr(self, p)) for p in dir(self) if not p.startswith('__')]
1372
+ sv = 'api.SourceLocation ( '
1373
+ for v in pr:
1374
+ if not callable(v[1]):
1375
+ sv += v[0] + '=' + str(v[1]) + ', '
1376
+ return sv + ')'
1377
+ @property
1378
+ def Filename(self):
1379
+ return _api.api_SourceLocation_Filename_Get(self.handle)
1380
+ @Filename.setter
1381
+ def Filename(self, value):
1382
+ if isinstance(value, go.GoClass):
1383
+ _api.api_SourceLocation_Filename_Set(self.handle, value.handle)
1384
+ else:
1385
+ _api.api_SourceLocation_Filename_Set(self.handle, value)
1386
+ @property
1387
+ def Line(self):
1388
+ return _api.api_SourceLocation_Line_Get(self.handle)
1389
+ @Line.setter
1390
+ def Line(self, value):
1391
+ if isinstance(value, go.GoClass):
1392
+ _api.api_SourceLocation_Line_Set(self.handle, value.handle)
1393
+ else:
1394
+ _api.api_SourceLocation_Line_Set(self.handle, value)
1395
+ @property
1396
+ def Column(self):
1397
+ return _api.api_SourceLocation_Column_Get(self.handle)
1398
+ @Column.setter
1399
+ def Column(self, value):
1400
+ if isinstance(value, go.GoClass):
1401
+ _api.api_SourceLocation_Column_Set(self.handle, value.handle)
1402
+ else:
1403
+ _api.api_SourceLocation_Column_Set(self.handle, value)
1404
+
1405
+ # Python type for struct api.VMError
1406
+ class VMError(go.GoClass):
1407
+ """VMError represents errors that can occur in the VM API\n"""
1408
+ def __init__(self, *args, **kwargs):
1409
+ """
1410
+ handle=A Go-side object is always initialized with an explicit handle=arg
1411
+ otherwise parameters can be unnamed in order of field names or named fields
1412
+ in which case a new Go object is constructed first
1413
+ """
1414
+ if len(kwargs) == 1 and 'handle' in kwargs:
1415
+ self.handle = kwargs['handle']
1416
+ _api.IncRef(self.handle)
1417
+ elif len(args) == 1 and isinstance(args[0], go.GoClass):
1418
+ self.handle = args[0].handle
1419
+ _api.IncRef(self.handle)
1420
+ else:
1421
+ self.handle = _api.api_VMError_CTor()
1422
+ _api.IncRef(self.handle)
1423
+ if 0 < len(args):
1424
+ self.Type = args[0]
1425
+ if "Type" in kwargs:
1426
+ self.Type = kwargs["Type"]
1427
+ if 1 < len(args):
1428
+ self.Message = args[1]
1429
+ if "Message" in kwargs:
1430
+ self.Message = kwargs["Message"]
1431
+ if 2 < len(args):
1432
+ self.Source = args[2]
1433
+ if "Source" in kwargs:
1434
+ self.Source = kwargs["Source"]
1435
+ if 4 < len(args):
1436
+ self.Duration = args[4]
1437
+ if "Duration" in kwargs:
1438
+ self.Duration = kwargs["Duration"]
1439
+ def __del__(self):
1440
+ _api.DecRef(self.handle)
1441
+ def __str__(self):
1442
+ pr = [(p, getattr(self, p)) for p in dir(self) if not p.startswith('__')]
1443
+ sv = 'api.VMError{'
1444
+ first = True
1445
+ for v in pr:
1446
+ if callable(v[1]):
1447
+ continue
1448
+ if first:
1449
+ first = False
1450
+ else:
1451
+ sv += ', '
1452
+ sv += v[0] + '=' + str(v[1])
1453
+ return sv + '}'
1454
+ def __repr__(self):
1455
+ pr = [(p, getattr(self, p)) for p in dir(self) if not p.startswith('__')]
1456
+ sv = 'api.VMError ( '
1457
+ for v in pr:
1458
+ if not callable(v[1]):
1459
+ sv += v[0] + '=' + str(v[1]) + ', '
1460
+ return sv + ')'
1461
+ @property
1462
+ def Type(self):
1463
+ return _api.api_VMError_Type_Get(self.handle)
1464
+ @Type.setter
1465
+ def Type(self, value):
1466
+ if isinstance(value, go.GoClass):
1467
+ _api.api_VMError_Type_Set(self.handle, value.handle)
1468
+ else:
1469
+ _api.api_VMError_Type_Set(self.handle, value)
1470
+ @property
1471
+ def Message(self):
1472
+ return _api.api_VMError_Message_Get(self.handle)
1473
+ @Message.setter
1474
+ def Message(self, value):
1475
+ if isinstance(value, go.GoClass):
1476
+ _api.api_VMError_Message_Set(self.handle, value.handle)
1477
+ else:
1478
+ _api.api_VMError_Message_Set(self.handle, value)
1479
+ @property
1480
+ def Source(self):
1481
+ return SourceLocation(handle=_api.api_VMError_Source_Get(self.handle))
1482
+ @Source.setter
1483
+ def Source(self, value):
1484
+ if isinstance(value, go.GoClass):
1485
+ _api.api_VMError_Source_Set(self.handle, value.handle)
1486
+ else:
1487
+ raise TypeError("supplied argument type {t} is not a go.GoClass".format(t=type(value)))
1488
+ @property
1489
+ def Duration(self):
1490
+ return _api.api_VMError_Duration_Get(self.handle)
1491
+ @Duration.setter
1492
+ def Duration(self, value):
1493
+ if isinstance(value, go.GoClass):
1494
+ _api.api_VMError_Duration_Set(self.handle, value.handle)
1495
+ else:
1496
+ _api.api_VMError_Duration_Set(self.handle, value)
1497
+ def Error(self):
1498
+ """Error() str"""
1499
+ return _api.api_VMError_Error(self.handle)
1500
+ def Unwrap(self):
1501
+ """Unwrap() str"""
1502
+ return _api.api_VMError_Unwrap(self.handle)
1503
+ def IsCompileError(self):
1504
+ """IsCompileError() bool
1505
+
1506
+ IsCompileError returns true if the error is a compilation error
1507
+ """
1508
+ return _api.api_VMError_IsCompileError(self.handle)
1509
+ def IsRuntimeError(self):
1510
+ """IsRuntimeError() bool
1511
+
1512
+ IsRuntimeError returns true if the error is a runtime error
1513
+ """
1514
+ return _api.api_VMError_IsRuntimeError(self.handle)
1515
+ def IsTimeoutError(self):
1516
+ """IsTimeoutError() bool
1517
+
1518
+ IsTimeoutError returns true if the error is a timeout error
1519
+ """
1520
+ return _api.api_VMError_IsTimeoutError(self.handle)
1521
+ def IsConversionError(self):
1522
+ """IsConversionError() bool
1523
+
1524
+ IsConversionError returns true if the error is a type conversion error
1525
+ """
1526
+ return _api.api_VMError_IsConversionError(self.handle)
1527
+ def IsConfigError(self):
1528
+ """IsConfigError() bool
1529
+
1530
+ IsConfigError returns true if the error is a configuration error
1531
+ """
1532
+ return _api.api_VMError_IsConfigError(self.handle)
1533
+
1534
+ # Python type for struct api.ClassVariable
1535
+ class ClassVariable(go.GoClass):
1536
+ """"""
1537
+ def __init__(self, *args, **kwargs):
1538
+ """
1539
+ handle=A Go-side object is always initialized with an explicit handle=arg
1540
+ otherwise parameters can be unnamed in order of field names or named fields
1541
+ in which case a new Go object is constructed first
1542
+ """
1543
+ if len(kwargs) == 1 and 'handle' in kwargs:
1544
+ self.handle = kwargs['handle']
1545
+ _api.IncRef(self.handle)
1546
+ elif len(args) == 1 and isinstance(args[0], go.GoClass):
1547
+ self.handle = args[0].handle
1548
+ _api.IncRef(self.handle)
1549
+ else:
1550
+ self.handle = _api.api_ClassVariable_CTor()
1551
+ _api.IncRef(self.handle)
1552
+ if 0 < len(args):
1553
+ self.Name = args[0]
1554
+ if "Name" in kwargs:
1555
+ self.Name = kwargs["Name"]
1556
+ if 1 < len(args):
1557
+ self.Value = args[1]
1558
+ if "Value" in kwargs:
1559
+ self.Value = kwargs["Value"]
1560
+ if 2 < len(args):
1561
+ self.Locked = args[2]
1562
+ if "Locked" in kwargs:
1563
+ self.Locked = kwargs["Locked"]
1564
+ def __del__(self):
1565
+ _api.DecRef(self.handle)
1566
+ def __str__(self):
1567
+ pr = [(p, getattr(self, p)) for p in dir(self) if not p.startswith('__')]
1568
+ sv = 'api.ClassVariable{'
1569
+ first = True
1570
+ for v in pr:
1571
+ if callable(v[1]):
1572
+ continue
1573
+ if first:
1574
+ first = False
1575
+ else:
1576
+ sv += ', '
1577
+ sv += v[0] + '=' + str(v[1])
1578
+ return sv + '}'
1579
+ def __repr__(self):
1580
+ pr = [(p, getattr(self, p)) for p in dir(self) if not p.startswith('__')]
1581
+ sv = 'api.ClassVariable ( '
1582
+ for v in pr:
1583
+ if not callable(v[1]):
1584
+ sv += v[0] + '=' + str(v[1]) + ', '
1585
+ return sv + ')'
1586
+ @property
1587
+ def Name(self):
1588
+ return _api.api_ClassVariable_Name_Get(self.handle)
1589
+ @Name.setter
1590
+ def Name(self, value):
1591
+ if isinstance(value, go.GoClass):
1592
+ _api.api_ClassVariable_Name_Set(self.handle, value.handle)
1593
+ else:
1594
+ _api.api_ClassVariable_Name_Set(self.handle, value)
1595
+ @property
1596
+ def Value(self):
1597
+ return GoValue(handle=_api.api_ClassVariable_Value_Get(self.handle))
1598
+ @Value.setter
1599
+ def Value(self, value):
1600
+ if isinstance(value, go.GoClass):
1601
+ _api.api_ClassVariable_Value_Set(self.handle, value.handle)
1602
+ else:
1603
+ raise TypeError("supplied argument type {t} is not a go.GoClass".format(t=type(value)))
1604
+ @property
1605
+ def Locked(self):
1606
+ return _api.api_ClassVariable_Locked_Get(self.handle)
1607
+ @Locked.setter
1608
+ def Locked(self, value):
1609
+ if isinstance(value, go.GoClass):
1610
+ _api.api_ClassVariable_Locked_Set(self.handle, value.handle)
1611
+ else:
1612
+ _api.api_ClassVariable_Locked_Set(self.handle, value)
1613
+
1614
+ # Python type for struct api.VM
1615
+ class VM(go.GoClass):
1616
+ """VM represents an Objective-LOL virtual machine instance\n"""
1617
+ def __init__(self, *args, **kwargs):
1618
+ """
1619
+ handle=A Go-side object is always initialized with an explicit handle=arg
1620
+ otherwise parameters can be unnamed in order of field names or named fields
1621
+ in which case a new Go object is constructed first
1622
+ """
1623
+ if len(kwargs) == 1 and 'handle' in kwargs:
1624
+ self.handle = kwargs['handle']
1625
+ _api.IncRef(self.handle)
1626
+ elif len(args) == 1 and isinstance(args[0], go.GoClass):
1627
+ self.handle = args[0].handle
1628
+ _api.IncRef(self.handle)
1629
+ else:
1630
+ self.handle = _api.api_VM_CTor()
1631
+ _api.IncRef(self.handle)
1632
+ def __del__(self):
1633
+ _api.DecRef(self.handle)
1634
+ def __str__(self):
1635
+ pr = [(p, getattr(self, p)) for p in dir(self) if not p.startswith('__')]
1636
+ sv = 'api.VM{'
1637
+ first = True
1638
+ for v in pr:
1639
+ if callable(v[1]):
1640
+ continue
1641
+ if first:
1642
+ first = False
1643
+ else:
1644
+ sv += ', '
1645
+ sv += v[0] + '=' + str(v[1])
1646
+ return sv + '}'
1647
+ def __repr__(self):
1648
+ pr = [(p, getattr(self, p)) for p in dir(self) if not p.startswith('__')]
1649
+ sv = 'api.VM ( '
1650
+ for v in pr:
1651
+ if not callable(v[1]):
1652
+ sv += v[0] + '=' + str(v[1]) + ', '
1653
+ return sv + ')'
1654
+ def GetCompatibilityShim(self):
1655
+ """GetCompatibilityShim() object
1656
+
1657
+ GetCompatibilityShim returns a compatibility shim for the VM
1658
+ """
1659
+ return VMCompatibilityShim(handle=_api.api_VM_GetCompatibilityShim(self.handle))
1660
+ def Execute(self, code):
1661
+ """Execute(str code) object, str
1662
+
1663
+ Execute executes Objective-LOL code from a string
1664
+ """
1665
+ return ExecutionResult(handle=_api.api_VM_Execute(self.handle, code))
1666
+ def ExecuteWithContext(self, ctx, code):
1667
+ """ExecuteWithContext(object ctx, str code) object, str
1668
+
1669
+ ExecuteWithContext executes code with a context for cancellation/timeout
1670
+ """
1671
+ return ExecutionResult(handle=_api.api_VM_ExecuteWithContext(self.handle, ctx.handle, code))
1672
+ def NewObjectInstance(self, className):
1673
+ """NewObjectInstance(str className) object, str"""
1674
+ return GoValue(handle=_api.api_VM_NewObjectInstance(self.handle, className))
1675
+ def Call(self, functionName, args):
1676
+ """Call(str functionName, []object args) object, str
1677
+
1678
+ Call calls an Objective-LOL function with the given arguments
1679
+ """
1680
+ return GoValue(handle=_api.api_VM_Call(self.handle, functionName, args.handle))
1681
+ def CallMethod(self, object, methodName, args):
1682
+ """CallMethod(object object, str methodName, []object args) object, str
1683
+
1684
+ CallMethod calls a method on an Objective-LOL object
1685
+ """
1686
+ return GoValue(handle=_api.api_VM_CallMethod(self.handle, object.handle, methodName, args.handle))
1687
+ def DefineVariable(self, name, value, constant):
1688
+ """DefineVariable(str name, object value, bool constant) str
1689
+
1690
+ DefineVariable defines a global variable in the VM
1691
+ """
1692
+ return _api.api_VM_DefineVariable(self.handle, name, value.handle, constant)
1693
+ def SetVariable(self, variableName, value):
1694
+ """SetVariable(str variableName, object value) str
1695
+
1696
+ SetVariable sets a variable in the global environment
1697
+ """
1698
+ return _api.api_VM_SetVariable(self.handle, variableName, value.handle)
1699
+ def GetVariable(self, variableName):
1700
+ """GetVariable(str variableName) object, str
1701
+
1702
+ Get gets a variable from the global environment
1703
+ """
1704
+ return GoValue(handle=_api.api_VM_GetVariable(self.handle, variableName))
1705
+ def DefineClass(self, classDef):
1706
+ """DefineClass(object classDef) str"""
1707
+ return _api.api_VM_DefineClass(self.handle, classDef.handle)
1708
+
1709
+
1710
+ # ---- Slices ---
1711
+
1712
+
1713
+ # ---- Maps ---
1714
+
1715
+
1716
+ # ---- Constructors ---
1717
+ def DefaultConfig():
1718
+ """DefaultConfig() object
1719
+
1720
+ DefaultConfig returns a default configuration
1721
+ """
1722
+ return VMConfig(handle=_api.api_DefaultConfig())
1723
+ def NewClassDefinition():
1724
+ """NewClassDefinition() object"""
1725
+ return ClassDefinition(handle=_api.api_NewClassDefinition())
1726
+ def WrapAny(value):
1727
+ """WrapAny(str value) object"""
1728
+ return GoValue(handle=_api.api_WrapAny(value))
1729
+ def WrapObject(value):
1730
+ """WrapObject(object value) object"""
1731
+ return GoValue(handle=_api.api_WrapObject(value.handle))
1732
+ def WrapBool(value):
1733
+ """WrapBool(bool value) object"""
1734
+ return GoValue(handle=_api.api_WrapBool(value))
1735
+ def WrapFloat(value):
1736
+ """WrapFloat(float value) object"""
1737
+ return GoValue(handle=_api.api_WrapFloat(value))
1738
+ def WrapInt(value):
1739
+ """WrapInt(long value) object"""
1740
+ return GoValue(handle=_api.api_WrapInt(value))
1741
+ def ToGoValue(val):
1742
+ """ToGoValue(object val) object, str
1743
+
1744
+ ToGoValue converts an Objective-LOL value to a Go value
1745
+ """
1746
+ return GoValue(handle=_api.api_ToGoValue(val.handle))
1747
+ def WrapString(value):
1748
+ """WrapString(str value) object"""
1749
+ return GoValue(handle=_api.api_WrapString(value))
1750
+ def NewTimeoutError(duration):
1751
+ """NewTimeoutError(long duration) object
1752
+
1753
+ NewTimeoutError creates a new timeout error
1754
+ """
1755
+ return VMError(handle=_api.api_NewTimeoutError(duration))
1756
+ def NewRuntimeError(message, source):
1757
+ """NewRuntimeError(str message, object source) object
1758
+
1759
+ NewRuntimeError creates a new runtime error
1760
+ """
1761
+ return VMError(handle=_api.api_NewRuntimeError(message, source.handle))
1762
+ def NewCompileError(message, source):
1763
+ """NewCompileError(str message, object source) object
1764
+
1765
+ NewCompileError creates a new compile error
1766
+ """
1767
+ return VMError(handle=_api.api_NewCompileError(message, source.handle))
1768
+ def NewConfigError(message, wrapped):
1769
+ """NewConfigError(str message, str wrapped) object
1770
+
1771
+ NewConfigError creates a new configuration error
1772
+ """
1773
+ return VMError(handle=_api.api_NewConfigError(message, wrapped))
1774
+ def NewConversionError(message, wrapped):
1775
+ """NewConversionError(str message, str wrapped) object
1776
+
1777
+ NewConversionError creates a new type conversion error
1778
+ """
1779
+ return VMError(handle=_api.api_NewConversionError(message, wrapped))
1780
+ def NewVM(config):
1781
+ """NewVM(object config) object, str
1782
+
1783
+ NewVM creates a new VM instance with the given config
1784
+ """
1785
+ return VM(handle=_api.api_NewVM(config.handle))
1786
+
1787
+
1788
+ # ---- Functions ---
1789
+ def ConvertArguments(args):
1790
+ """ConvertArguments([]object args) []object, str
1791
+
1792
+ ConvertArguments converts a slice of Go values to Objective-LOL values
1793
+ """
1794
+ return Slice_environment_Value(handle=_api.api_ConvertArguments(args.handle))
1795
+ def FromGoValue(val):
1796
+ """FromGoValue(object val) object, str
1797
+
1798
+ FromGoValue converts a Go value to an Objective-LOL value
1799
+ """
1800
+ return go.environment_Value(handle=_api.api_FromGoValue(val.handle))
1801
+ def LookupObject(id):
1802
+ """LookupObject(str id) object, str"""
1803
+ return go.Ptr_environment_ObjectInstance(handle=_api.api_LookupObject(id))
1804
+
1805
+