rapydscript-ns 0.9.0 → 0.9.2

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.
Files changed (100) hide show
  1. package/.agignore +1 -1
  2. package/.github/workflows/ci.yml +38 -38
  3. package/=template.pyj +5 -5
  4. package/CHANGELOG.md +10 -0
  5. package/HACKING.md +103 -103
  6. package/LICENSE +24 -24
  7. package/README.md +7 -6
  8. package/TODO.md +116 -1
  9. package/add-toc-to-readme +2 -2
  10. package/bin/export +75 -75
  11. package/bin/rapydscript +70 -70
  12. package/bin/web-repl-export +102 -102
  13. package/build +2 -2
  14. package/language-service/index.js +9 -9
  15. package/language-service/language-service.d.ts +1 -1
  16. package/package.json +6 -2
  17. package/publish.py +37 -37
  18. package/release/compiler.js +246 -231
  19. package/release/signatures.json +23 -23
  20. package/session.vim +4 -4
  21. package/setup.cfg +2 -2
  22. package/src/compiler.pyj +36 -36
  23. package/src/errors.pyj +30 -30
  24. package/src/lib/aes.pyj +646 -646
  25. package/src/lib/contextlib.pyj +379 -0
  26. package/src/lib/copy.pyj +120 -120
  27. package/src/lib/datetime.pyj +712 -0
  28. package/src/lib/elementmaker.pyj +83 -83
  29. package/src/lib/encodings.pyj +126 -126
  30. package/src/lib/gettext.pyj +569 -569
  31. package/src/lib/io.pyj +500 -0
  32. package/src/lib/itertools.pyj +580 -580
  33. package/src/lib/json.pyj +227 -0
  34. package/src/lib/math.pyj +193 -193
  35. package/src/lib/operator.pyj +11 -11
  36. package/src/lib/pythonize.pyj +20 -20
  37. package/src/lib/random.pyj +118 -118
  38. package/src/lib/react.pyj +74 -74
  39. package/src/lib/traceback.pyj +63 -63
  40. package/src/lib/uuid.pyj +77 -77
  41. package/src/monaco-language-service/diagnostics.js +4 -4
  42. package/src/monaco-language-service/dts.js +550 -550
  43. package/src/monaco-language-service/index.js +2 -2
  44. package/src/output/comments.pyj +45 -45
  45. package/src/output/exceptions.pyj +201 -201
  46. package/src/output/jsx.pyj +164 -164
  47. package/src/output/loops.pyj +9 -0
  48. package/src/output/treeshake.pyj +182 -182
  49. package/src/output/utils.pyj +72 -72
  50. package/src/string_interpolation.pyj +72 -72
  51. package/src/tokenizer.pyj +1 -1
  52. package/src/unicode_aliases.pyj +576 -576
  53. package/src/utils.pyj +192 -192
  54. package/test/_import_one.pyj +37 -37
  55. package/test/_import_two/__init__.pyj +11 -11
  56. package/test/_import_two/level2/deep.pyj +4 -4
  57. package/test/_import_two/other.pyj +6 -6
  58. package/test/_import_two/sub.pyj +13 -13
  59. package/test/aes_vectors.pyj +421 -421
  60. package/test/annotations.pyj +80 -80
  61. package/test/contextlib.pyj +362 -0
  62. package/test/datetime.pyj +500 -0
  63. package/test/debugger_stmt.pyj +41 -0
  64. package/test/decorators.pyj +77 -77
  65. package/test/docstrings.pyj +39 -39
  66. package/test/elementmaker_test.pyj +45 -45
  67. package/test/functions.pyj +151 -151
  68. package/test/generators.pyj +41 -41
  69. package/test/generic.pyj +370 -370
  70. package/test/imports.pyj +72 -72
  71. package/test/internationalization.pyj +73 -73
  72. package/test/io.pyj +316 -0
  73. package/test/json.pyj +196 -0
  74. package/test/lint.pyj +164 -164
  75. package/test/loops.pyj +85 -85
  76. package/test/numpy.pyj +734 -734
  77. package/test/omit_function_metadata.pyj +20 -20
  78. package/test/repl.pyj +121 -121
  79. package/test/scoped_flags.pyj +76 -76
  80. package/test/unit/index.js +66 -0
  81. package/test/unit/language-service-dts.js +543 -543
  82. package/test/unit/language-service-hover.js +455 -455
  83. package/test/unit/language-service.js +1 -1
  84. package/test/unit/web-repl.js +533 -0
  85. package/tools/compiler.d.ts +367 -0
  86. package/tools/completer.js +131 -131
  87. package/tools/gettext.js +185 -185
  88. package/tools/ini.js +65 -65
  89. package/tools/msgfmt.js +187 -187
  90. package/tools/repl.js +223 -223
  91. package/tools/test.js +118 -118
  92. package/tools/utils.js +128 -128
  93. package/tools/web_repl.js +95 -95
  94. package/try +41 -41
  95. package/web-repl/env.js +196 -196
  96. package/web-repl/index.html +163 -163
  97. package/web-repl/prism.css +139 -139
  98. package/web-repl/prism.js +113 -113
  99. package/web-repl/rapydscript.js +224 -224
  100. package/web-repl/sha1.js +25 -25
package/src/utils.pyj CHANGED
@@ -1,192 +1,192 @@
1
- # vim:fileencoding=utf-8
2
- # License: BSD Copyright: 2016, Kovid Goyal <kovid at kovidgoyal.net>
3
- from __python__ import hash_literals
4
-
5
- has_prop = Object.prototype.hasOwnProperty.call.bind(Object.prototype.hasOwnProperty)
6
-
7
- def array_to_hash(a):
8
- ret = Object.create(None)
9
- for i in range(len(a)):
10
- ret[a[i]] = True
11
- return ret
12
-
13
- def slice(a, start):
14
- return Array.prototype.slice.call(a, start or 0)
15
-
16
- def characters(str_):
17
- return str_.split("")
18
-
19
- def member(name, array):
20
- for i in range(array.length-1, -1, -1):
21
- if array[i] is name:
22
- return True
23
- return False
24
-
25
- def repeat_string(str_, i):
26
- if i <= 0:
27
- return ""
28
- if i is 1:
29
- return str_
30
- d = repeat_string(str_, i >> 1)
31
- d += d
32
- if i & 1:
33
- d += str_
34
- return d
35
-
36
- class DefaultsError(ValueError):
37
-
38
- def __init__(self, name, defs):
39
- ValueError.__init__(self, name + ' is not a supported option. Supported options are: ' + str(Object.keys(defs)))
40
-
41
- def defaults(args, defs, croak):
42
- if args is True:
43
- args = {}
44
- ret = args or {}
45
- if croak:
46
- for i in ret:
47
- if not has_prop(defs, i):
48
- raise DefaultsError(i, defs)
49
-
50
- for i in defs:
51
- ret[i] = args[i] if args and has_prop(args, i) else defs[i]
52
- return ret
53
-
54
- def merge(obj, ext):
55
- for i in ext:
56
- obj[i] = ext[i]
57
- return obj
58
-
59
- def noop():
60
- pass
61
-
62
- MAP = def():
63
- def MAP(a, f, backwards):
64
- ret = []
65
- top = []
66
-
67
- def doit():
68
- val = f(a[i], i)
69
- is_last = isinstance(val, Last)
70
- if is_last:
71
- val = val.v
72
- if isinstance(val, AtTop):
73
- val = val.v
74
- if isinstance(val, Splice):
75
- top.push.apply(top, (val.v.slice().reverse() if backwards else val.v))
76
- else:
77
- top.push(val)
78
- elif val is not skip:
79
- if isinstance(val, Splice):
80
- ret.push.apply(ret, (val.v.slice().reverse() if backwards else val.v))
81
- else:
82
- ret.push(val)
83
- return is_last
84
-
85
- if Array.isArray(a):
86
- if backwards:
87
- for i in range(a.length-1, -1, -1):
88
- if doit():
89
- break
90
- ret.reverse()
91
- top.reverse()
92
- else:
93
- for i in range(len(a)):
94
- if doit():
95
- break
96
- else:
97
- for i in a:
98
- if doit():
99
- break
100
- return top.concat(ret)
101
-
102
- MAP.at_top = def(val):
103
- return new AtTop(val)
104
- MAP.splice = def(val):
105
- return new Splice(val)
106
- MAP.last = def(val):
107
- return new Last(val)
108
-
109
- skip = MAP.skip = {}
110
- def AtTop(val):
111
- this.v = val
112
-
113
- def Splice(val):
114
- this.v = val
115
-
116
- def Last(val):
117
- this.v = val
118
-
119
- return MAP
120
- .call(this)
121
-
122
- def push_uniq(array, el):
123
- if array.indexOf(el) < 0:
124
- array.push(el)
125
-
126
- def string_template(text, props):
127
- return text.replace(/\{(.+?)\}/g, def(str_, p):
128
- return props[p]
129
- )
130
-
131
- def remove(array, el):
132
- for i in range(array.length-1, -1, -1):
133
- if array[i] is el:
134
- array.splice(i, 1)
135
-
136
- def mergeSort(array, cmp):
137
- if array.length < 2:
138
- return array.slice()
139
-
140
- def merge(a, b):
141
- r = []
142
- ai = 0
143
- bi = 0
144
- i = 0
145
- while ai < a.length and bi < b.length:
146
- if cmp(a[ai], b[bi]) <= 0:
147
- r[i] = a[ai]
148
- ai += 1
149
- else:
150
- r[i] = b[bi]
151
- bi += 1
152
- i += 1
153
- if ai < a.length:
154
- r.push.apply(r, a.slice(ai))
155
- if bi < b.length:
156
- r.push.apply(r, b.slice(bi))
157
- return r
158
-
159
- def _ms(a):
160
- if a.length <= 1:
161
- return a
162
- m = Math.floor(a.length / 2)
163
- left = a.slice(0, m)
164
- right = a.slice(m)
165
- left = _ms(left)
166
- right = _ms(right)
167
- return merge(left, right)
168
- return _ms(array)
169
-
170
- def set_difference(a, b):
171
- return a.filter(def(el):
172
- return b.indexOf(el) < 0
173
- )
174
-
175
- def set_intersection(a, b):
176
- return a.filter(def(el):
177
- return b.indexOf(el) >= 0
178
- )
179
-
180
- def make_predicate(words):
181
- if jstype(words) is 'string':
182
- words = words.split(" ")
183
- a = Object.create(None)
184
- for k in words:
185
- a[k] = True
186
- return a
187
-
188
- def cache_file_name(src, cache_dir):
189
- if cache_dir:
190
- src = str.replace(src, '\\', '/')
191
- return cache_dir + '/' + str.lstrip(str.replace(src, '/', '-') + '.json', '-')
192
- return src + '-cached'
1
+ # vim:fileencoding=utf-8
2
+ # License: BSD Copyright: 2016, Kovid Goyal <kovid at kovidgoyal.net>
3
+ from __python__ import hash_literals
4
+
5
+ has_prop = Object.prototype.hasOwnProperty.call.bind(Object.prototype.hasOwnProperty)
6
+
7
+ def array_to_hash(a):
8
+ ret = Object.create(None)
9
+ for i in range(len(a)):
10
+ ret[a[i]] = True
11
+ return ret
12
+
13
+ def slice(a, start):
14
+ return Array.prototype.slice.call(a, start or 0)
15
+
16
+ def characters(str_):
17
+ return str_.split("")
18
+
19
+ def member(name, array):
20
+ for i in range(array.length-1, -1, -1):
21
+ if array[i] is name:
22
+ return True
23
+ return False
24
+
25
+ def repeat_string(str_, i):
26
+ if i <= 0:
27
+ return ""
28
+ if i is 1:
29
+ return str_
30
+ d = repeat_string(str_, i >> 1)
31
+ d += d
32
+ if i & 1:
33
+ d += str_
34
+ return d
35
+
36
+ class DefaultsError(ValueError):
37
+
38
+ def __init__(self, name, defs):
39
+ ValueError.__init__(self, name + ' is not a supported option. Supported options are: ' + str(Object.keys(defs)))
40
+
41
+ def defaults(args, defs, croak):
42
+ if args is True:
43
+ args = {}
44
+ ret = args or {}
45
+ if croak:
46
+ for i in ret:
47
+ if not has_prop(defs, i):
48
+ raise DefaultsError(i, defs)
49
+
50
+ for i in defs:
51
+ ret[i] = args[i] if args and has_prop(args, i) else defs[i]
52
+ return ret
53
+
54
+ def merge(obj, ext):
55
+ for i in ext:
56
+ obj[i] = ext[i]
57
+ return obj
58
+
59
+ def noop():
60
+ pass
61
+
62
+ MAP = def():
63
+ def MAP(a, f, backwards):
64
+ ret = []
65
+ top = []
66
+
67
+ def doit():
68
+ val = f(a[i], i)
69
+ is_last = isinstance(val, Last)
70
+ if is_last:
71
+ val = val.v
72
+ if isinstance(val, AtTop):
73
+ val = val.v
74
+ if isinstance(val, Splice):
75
+ top.push.apply(top, (val.v.slice().reverse() if backwards else val.v))
76
+ else:
77
+ top.push(val)
78
+ elif val is not skip:
79
+ if isinstance(val, Splice):
80
+ ret.push.apply(ret, (val.v.slice().reverse() if backwards else val.v))
81
+ else:
82
+ ret.push(val)
83
+ return is_last
84
+
85
+ if Array.isArray(a):
86
+ if backwards:
87
+ for i in range(a.length-1, -1, -1):
88
+ if doit():
89
+ break
90
+ ret.reverse()
91
+ top.reverse()
92
+ else:
93
+ for i in range(len(a)):
94
+ if doit():
95
+ break
96
+ else:
97
+ for i in a:
98
+ if doit():
99
+ break
100
+ return top.concat(ret)
101
+
102
+ MAP.at_top = def(val):
103
+ return new AtTop(val)
104
+ MAP.splice = def(val):
105
+ return new Splice(val)
106
+ MAP.last = def(val):
107
+ return new Last(val)
108
+
109
+ skip = MAP.skip = {}
110
+ def AtTop(val):
111
+ this.v = val
112
+
113
+ def Splice(val):
114
+ this.v = val
115
+
116
+ def Last(val):
117
+ this.v = val
118
+
119
+ return MAP
120
+ .call(this)
121
+
122
+ def push_uniq(array, el):
123
+ if array.indexOf(el) < 0:
124
+ array.push(el)
125
+
126
+ def string_template(text, props):
127
+ return text.replace(/\{(.+?)\}/g, def(str_, p):
128
+ return props[p]
129
+ )
130
+
131
+ def remove(array, el):
132
+ for i in range(array.length-1, -1, -1):
133
+ if array[i] is el:
134
+ array.splice(i, 1)
135
+
136
+ def mergeSort(array, cmp):
137
+ if array.length < 2:
138
+ return array.slice()
139
+
140
+ def merge(a, b):
141
+ r = []
142
+ ai = 0
143
+ bi = 0
144
+ i = 0
145
+ while ai < a.length and bi < b.length:
146
+ if cmp(a[ai], b[bi]) <= 0:
147
+ r[i] = a[ai]
148
+ ai += 1
149
+ else:
150
+ r[i] = b[bi]
151
+ bi += 1
152
+ i += 1
153
+ if ai < a.length:
154
+ r.push.apply(r, a.slice(ai))
155
+ if bi < b.length:
156
+ r.push.apply(r, b.slice(bi))
157
+ return r
158
+
159
+ def _ms(a):
160
+ if a.length <= 1:
161
+ return a
162
+ m = Math.floor(a.length / 2)
163
+ left = a.slice(0, m)
164
+ right = a.slice(m)
165
+ left = _ms(left)
166
+ right = _ms(right)
167
+ return merge(left, right)
168
+ return _ms(array)
169
+
170
+ def set_difference(a, b):
171
+ return a.filter(def(el):
172
+ return b.indexOf(el) < 0
173
+ )
174
+
175
+ def set_intersection(a, b):
176
+ return a.filter(def(el):
177
+ return b.indexOf(el) >= 0
178
+ )
179
+
180
+ def make_predicate(words):
181
+ if jstype(words) is 'string':
182
+ words = words.split(" ")
183
+ a = Object.create(None)
184
+ for k in words:
185
+ a[k] = True
186
+ return a
187
+
188
+ def cache_file_name(src, cache_dir):
189
+ if cache_dir:
190
+ src = str.replace(src, '\\', '/')
191
+ return cache_dir + '/' + str.lstrip(str.replace(src, '/', '-') + '.json', '-')
192
+ return src + '-cached'
@@ -1,37 +1,37 @@
1
- # vim:fileencoding=utf-8
2
- nonlocal GLOBAL_SYMBOL
3
-
4
- 'Module level ds1'
5
-
6
- def toplevel_func(a):
7
- return a + 'toplevel'
8
-
9
- '''
10
- Module level ds2
11
- line2
12
- '''
13
-
14
- class TopLevel:
15
-
16
- def __init__(self, a):
17
- self.a = a
18
-
19
- 'Module level ds 3'
20
-
21
- class AClass(TopLevel):
22
-
23
- def __init__(self, a):
24
- self.a = a
25
-
26
- toplevel_var = 'foo'
27
-
28
- if True:
29
- true_var = 'true'
30
- else:
31
- false_var = 'false'
32
-
33
- GLOBAL_SYMBOL = 'i am global'
34
-
35
- from _import_two.other import other
36
-
37
- test_other = other
1
+ # vim:fileencoding=utf-8
2
+ nonlocal GLOBAL_SYMBOL
3
+
4
+ 'Module level ds1'
5
+
6
+ def toplevel_func(a):
7
+ return a + 'toplevel'
8
+
9
+ '''
10
+ Module level ds2
11
+ line2
12
+ '''
13
+
14
+ class TopLevel:
15
+
16
+ def __init__(self, a):
17
+ self.a = a
18
+
19
+ 'Module level ds 3'
20
+
21
+ class AClass(TopLevel):
22
+
23
+ def __init__(self, a):
24
+ self.a = a
25
+
26
+ toplevel_var = 'foo'
27
+
28
+ if True:
29
+ true_var = 'true'
30
+ else:
31
+ false_var = 'false'
32
+
33
+ GLOBAL_SYMBOL = 'i am global'
34
+
35
+ from _import_two.other import other
36
+
37
+ test_other = other
@@ -1,11 +1,11 @@
1
- # vim:fileencoding=utf-8
2
-
3
- def toplevel_func2(a):
4
- return a + 'toplevel2'
5
-
6
- class TopLevel2:
7
-
8
- def __init__(self, a):
9
- self.a = a
10
-
11
- toplevel_var2 = 'foo2'
1
+ # vim:fileencoding=utf-8
2
+
3
+ def toplevel_func2(a):
4
+ return a + 'toplevel2'
5
+
6
+ class TopLevel2:
7
+
8
+ def __init__(self, a):
9
+ self.a = a
10
+
11
+ toplevel_var2 = 'foo2'
@@ -1,4 +1,4 @@
1
- # vim:fileencoding=utf-8
2
- # License: BSD Copyright: 2016, Kovid Goyal <kovid at kovidgoyal.net>
3
-
4
- deep_var = 'deep'
1
+ # vim:fileencoding=utf-8
2
+ # License: BSD Copyright: 2016, Kovid Goyal <kovid at kovidgoyal.net>
3
+
4
+ deep_var = 'deep'
@@ -1,6 +1,6 @@
1
- # vim:fileencoding=utf-8
2
- # License: BSD
3
- # Copyright: 2015, Kovid Goyal <kovid at kovidgoyal.net>
4
-
5
- other = 'other'
6
-
1
+ # vim:fileencoding=utf-8
2
+ # License: BSD
3
+ # Copyright: 2015, Kovid Goyal <kovid at kovidgoyal.net>
4
+
5
+ other = 'other'
6
+
@@ -1,13 +1,13 @@
1
- # vim:fileencoding=utf-8
2
- # License: BSD
3
- # Copyright: 2015, Kovid Goyal <kovid at kovidgoyal.net>
4
-
5
- sub_var = 'sub'
6
-
7
- def sub_func():
8
- return sub_var
9
-
10
- class Sub:
11
-
12
- def __init__(self, a):
13
- self.a = a
1
+ # vim:fileencoding=utf-8
2
+ # License: BSD
3
+ # Copyright: 2015, Kovid Goyal <kovid at kovidgoyal.net>
4
+
5
+ sub_var = 'sub'
6
+
7
+ def sub_func():
8
+ return sub_var
9
+
10
+ class Sub:
11
+
12
+ def __init__(self, a):
13
+ self.a = a