rapydscript-ns 0.8.3 → 0.8.4
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.
- package/.agignore +1 -1
- package/.github/workflows/ci.yml +38 -38
- package/=template.pyj +5 -5
- package/CHANGELOG.md +8 -0
- package/HACKING.md +103 -103
- package/LICENSE +24 -24
- package/PYTHON_DIFFERENCES_REPORT.md +2 -2
- package/PYTHON_FEATURE_COVERAGE.md +13 -13
- package/README.md +670 -6
- package/TODO.md +5 -6
- package/add-toc-to-readme +2 -2
- package/bin/export +75 -75
- package/bin/rapydscript +70 -70
- package/bin/web-repl-export +102 -102
- package/build +2 -2
- package/language-service/index.js +155 -6
- package/package.json +1 -1
- package/publish.py +37 -37
- package/release/baselib-plain-pretty.js +2006 -229
- package/release/baselib-plain-ugly.js +70 -3
- package/release/compiler.js +11554 -3870
- package/release/signatures.json +31 -29
- package/session.vim +4 -4
- package/setup.cfg +2 -2
- package/src/ast.pyj +93 -1
- package/src/baselib-builtins.pyj +22 -1
- package/src/baselib-containers.pyj +99 -0
- package/src/baselib-errors.pyj +44 -0
- package/src/baselib-internal.pyj +94 -4
- package/src/baselib-itertools.pyj +97 -97
- package/src/baselib-str.pyj +24 -0
- package/src/compiler.pyj +36 -36
- package/src/errors.pyj +30 -30
- package/src/lib/aes.pyj +646 -646
- package/src/lib/copy.pyj +120 -0
- package/src/lib/elementmaker.pyj +83 -83
- package/src/lib/encodings.pyj +126 -126
- package/src/lib/gettext.pyj +569 -569
- package/src/lib/itertools.pyj +580 -580
- package/src/lib/math.pyj +193 -193
- package/src/lib/operator.pyj +11 -11
- package/src/lib/pythonize.pyj +20 -20
- package/src/lib/random.pyj +118 -118
- package/src/lib/re.pyj +470 -470
- package/src/lib/react.pyj +74 -0
- package/src/lib/traceback.pyj +63 -63
- package/src/lib/uuid.pyj +77 -77
- package/src/monaco-language-service/builtins.js +5 -0
- package/src/monaco-language-service/diagnostics.js +25 -3
- package/src/monaco-language-service/dts.js +550 -550
- package/src/output/classes.pyj +108 -8
- package/src/output/codegen.pyj +16 -2
- package/src/output/comments.pyj +45 -45
- package/src/output/exceptions.pyj +201 -105
- package/src/output/functions.pyj +9 -0
- package/src/output/jsx.pyj +164 -0
- package/src/output/literals.pyj +28 -2
- package/src/output/modules.pyj +1 -1
- package/src/output/operators.pyj +8 -2
- package/src/output/statements.pyj +2 -2
- package/src/output/stream.pyj +1 -0
- package/src/output/treeshake.pyj +182 -182
- package/src/output/utils.pyj +72 -72
- package/src/parse.pyj +417 -113
- package/src/string_interpolation.pyj +72 -72
- package/src/tokenizer.pyj +29 -0
- package/src/unicode_aliases.pyj +576 -576
- package/src/utils.pyj +192 -192
- package/test/_import_one.pyj +37 -37
- package/test/_import_two/__init__.pyj +11 -11
- package/test/_import_two/level2/deep.pyj +4 -4
- package/test/_import_two/other.pyj +6 -6
- package/test/_import_two/sub.pyj +13 -13
- package/test/aes_vectors.pyj +421 -421
- package/test/annotations.pyj +80 -80
- package/test/decorators.pyj +77 -77
- package/test/docstrings.pyj +39 -39
- package/test/elementmaker_test.pyj +45 -45
- package/test/functions.pyj +151 -151
- package/test/generators.pyj +41 -41
- package/test/generic.pyj +370 -370
- package/test/imports.pyj +72 -72
- package/test/internationalization.pyj +73 -73
- package/test/lint.pyj +164 -164
- package/test/loops.pyj +85 -85
- package/test/numpy.pyj +734 -734
- package/test/omit_function_metadata.pyj +20 -20
- package/test/python_features.pyj +19 -6
- package/test/regexp.pyj +55 -55
- package/test/repl.pyj +121 -121
- package/test/scoped_flags.pyj +76 -76
- package/test/unit/index.js +2177 -64
- package/test/unit/language-service-dts.js +543 -543
- package/test/unit/language-service-hover.js +455 -455
- package/test/unit/language-service.js +590 -4
- package/test/unit/web-repl.js +303 -0
- package/tools/cli.js +547 -547
- package/tools/compile.js +219 -219
- package/tools/completer.js +131 -131
- package/tools/embedded_compiler.js +251 -251
- package/tools/gettext.js +185 -185
- package/tools/ini.js +65 -65
- package/tools/msgfmt.js +187 -187
- package/tools/repl.js +223 -223
- package/tools/test.js +118 -118
- package/tools/utils.js +128 -128
- package/tools/web_repl.js +95 -95
- package/try +41 -41
- package/web-repl/env.js +196 -74
- package/web-repl/index.html +163 -163
- package/web-repl/main.js +252 -254
- package/web-repl/prism.css +139 -139
- package/web-repl/prism.js +113 -113
- package/web-repl/rapydscript.js +224 -102
- package/web-repl/sha1.js +25 -25
- package/hack_demo.pyj +0 -112
package/src/lib/random.pyj
CHANGED
|
@@ -1,118 +1,118 @@
|
|
|
1
|
-
###########################################################
|
|
2
|
-
# RapydScript Standard Library
|
|
3
|
-
# Author: Alexander Tsepkov
|
|
4
|
-
# Copyright 2013 Pyjeon Software LLC
|
|
5
|
-
# License: Apache License 2.0
|
|
6
|
-
# This library is covered under Apache license, so that
|
|
7
|
-
# you can distribute it with your RapydScript applications.
|
|
8
|
-
###########################################################
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
# basic implementation of Python's 'random' library
|
|
12
|
-
|
|
13
|
-
# JavaScript's Math.random() does not allow seeding its random generator, to bypass that, this module implements its own
|
|
14
|
-
# version that can be seeded. I decided on RC4 algorithm for this.
|
|
15
|
-
|
|
16
|
-
# please don't mess with this from the outside
|
|
17
|
-
|
|
18
|
-
ρσ_seed_state = {
|
|
19
|
-
'key': [],
|
|
20
|
-
'key_i': 0,
|
|
21
|
-
'key_j': 0
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
ρσ_get_random_byte = def():
|
|
25
|
-
ρσ_seed_state.key_i = (ρσ_seed_state.key_i + 1) % 256
|
|
26
|
-
ρσ_seed_state.key_j = (ρσ_seed_state.key_j + ρσ_seed_state.key[ρσ_seed_state.key_i]) % 256
|
|
27
|
-
ρσ_seed_state.key[ρσ_seed_state.key_i], ρσ_seed_state.key[ρσ_seed_state.key_j] = \
|
|
28
|
-
ρσ_seed_state.key[ρσ_seed_state.key_j], ρσ_seed_state.key[ρσ_seed_state.key_i]
|
|
29
|
-
return ρσ_seed_state.key[(ρσ_seed_state.key[ρσ_seed_state.key_i] + \
|
|
30
|
-
ρσ_seed_state.key[ρσ_seed_state.key_j]) % 256]
|
|
31
|
-
|
|
32
|
-
def seed(x=Date().getTime()):
|
|
33
|
-
ρσ_seed_state.key_i = ρσ_seed_state.key_j = 0
|
|
34
|
-
if jstype(x) is 'number':
|
|
35
|
-
x = x.toString()
|
|
36
|
-
elif jstype(x) is not 'string':
|
|
37
|
-
raise TypeError("unhashable type: '" + jstype(x) + "'")
|
|
38
|
-
for i in range(256):
|
|
39
|
-
ρσ_seed_state.key[i] = i
|
|
40
|
-
j = 0
|
|
41
|
-
for i in range(256):
|
|
42
|
-
j = (j + ρσ_seed_state.key[i] + x.charCodeAt(i % x.length)) % 256
|
|
43
|
-
ρσ_seed_state.key[i], ρσ_seed_state.key[j] = ρσ_seed_state.key[j], ρσ_seed_state.key[i]
|
|
44
|
-
seed()
|
|
45
|
-
|
|
46
|
-
def random():
|
|
47
|
-
n = 0
|
|
48
|
-
m = 1
|
|
49
|
-
for i in range(8):
|
|
50
|
-
n += ρσ_get_random_byte() * m
|
|
51
|
-
m *= 256
|
|
52
|
-
return v'n / 0x10000000000000000'
|
|
53
|
-
|
|
54
|
-
def randrange():
|
|
55
|
-
if arguments.length is 1:
|
|
56
|
-
return randbelow(int(arguments[0]))
|
|
57
|
-
start = int(arguments[0])
|
|
58
|
-
stop = int(arguments[1])
|
|
59
|
-
if arguments.length < 3:
|
|
60
|
-
step = 1
|
|
61
|
-
else:
|
|
62
|
-
step = int(arguments[2])
|
|
63
|
-
width = stop - start
|
|
64
|
-
if step is 1:
|
|
65
|
-
if width > 0:
|
|
66
|
-
return start + randbelow(width)
|
|
67
|
-
raise ValueError("empty range for randrange()")
|
|
68
|
-
if step > 0:
|
|
69
|
-
n = (width + step - 1) // step
|
|
70
|
-
elif step < 0:
|
|
71
|
-
n = (width + step + 1) // step
|
|
72
|
-
else:
|
|
73
|
-
raise ValueError("zero step for randrange()")
|
|
74
|
-
if n <= 0:
|
|
75
|
-
raise ValueError(f"empty range in randrange({start}, {stop}, {step})")
|
|
76
|
-
return start + step * randbelow(n)
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
def randint(a, b):
|
|
80
|
-
return int(random()*(b-a+1) + a)
|
|
81
|
-
|
|
82
|
-
def uniform(a, b):
|
|
83
|
-
return random()*(b-a) + a
|
|
84
|
-
|
|
85
|
-
def randbelow(n):
|
|
86
|
-
return Math.floor(random()*n)
|
|
87
|
-
|
|
88
|
-
def choice(seq):
|
|
89
|
-
if seq.length > 0:
|
|
90
|
-
return seq[randbelow(seq.length)]
|
|
91
|
-
else:
|
|
92
|
-
raise IndexError()
|
|
93
|
-
|
|
94
|
-
# uses Fisher-Yates algorithm to shuffle an array
|
|
95
|
-
def shuffle(x, random_f=random):
|
|
96
|
-
for i in range(x.length):
|
|
97
|
-
j = Math.floor(random_f() * (i+1))
|
|
98
|
-
x[i], x[j] = x[j], x[i]
|
|
99
|
-
return x
|
|
100
|
-
|
|
101
|
-
# similar to shuffle, but only shuffles a subset and creates a copy
|
|
102
|
-
def sample(population, k):
|
|
103
|
-
x = population.slice()
|
|
104
|
-
for i in range(population.length-1, population.length-k-1, -1):
|
|
105
|
-
j = Math.floor(random() * (i+1))
|
|
106
|
-
x[i], x[j] = x[j], x[i]
|
|
107
|
-
return x.slice(population.length-k)
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
#import stdlib
|
|
111
|
-
#a = range(50)
|
|
112
|
-
#random.seed(5)
|
|
113
|
-
#print(random.choice(a))
|
|
114
|
-
#print(random.shuffle(a))
|
|
115
|
-
#print(random.randrange(10))
|
|
116
|
-
#print(random.randint(1,5))
|
|
117
|
-
#print(random.uniform(1,5))
|
|
118
|
-
#print(random.sample(range(20),5))
|
|
1
|
+
###########################################################
|
|
2
|
+
# RapydScript Standard Library
|
|
3
|
+
# Author: Alexander Tsepkov
|
|
4
|
+
# Copyright 2013 Pyjeon Software LLC
|
|
5
|
+
# License: Apache License 2.0
|
|
6
|
+
# This library is covered under Apache license, so that
|
|
7
|
+
# you can distribute it with your RapydScript applications.
|
|
8
|
+
###########################################################
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
# basic implementation of Python's 'random' library
|
|
12
|
+
|
|
13
|
+
# JavaScript's Math.random() does not allow seeding its random generator, to bypass that, this module implements its own
|
|
14
|
+
# version that can be seeded. I decided on RC4 algorithm for this.
|
|
15
|
+
|
|
16
|
+
# please don't mess with this from the outside
|
|
17
|
+
|
|
18
|
+
ρσ_seed_state = {
|
|
19
|
+
'key': [],
|
|
20
|
+
'key_i': 0,
|
|
21
|
+
'key_j': 0
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
ρσ_get_random_byte = def():
|
|
25
|
+
ρσ_seed_state.key_i = (ρσ_seed_state.key_i + 1) % 256
|
|
26
|
+
ρσ_seed_state.key_j = (ρσ_seed_state.key_j + ρσ_seed_state.key[ρσ_seed_state.key_i]) % 256
|
|
27
|
+
ρσ_seed_state.key[ρσ_seed_state.key_i], ρσ_seed_state.key[ρσ_seed_state.key_j] = \
|
|
28
|
+
ρσ_seed_state.key[ρσ_seed_state.key_j], ρσ_seed_state.key[ρσ_seed_state.key_i]
|
|
29
|
+
return ρσ_seed_state.key[(ρσ_seed_state.key[ρσ_seed_state.key_i] + \
|
|
30
|
+
ρσ_seed_state.key[ρσ_seed_state.key_j]) % 256]
|
|
31
|
+
|
|
32
|
+
def seed(x=Date().getTime()):
|
|
33
|
+
ρσ_seed_state.key_i = ρσ_seed_state.key_j = 0
|
|
34
|
+
if jstype(x) is 'number':
|
|
35
|
+
x = x.toString()
|
|
36
|
+
elif jstype(x) is not 'string':
|
|
37
|
+
raise TypeError("unhashable type: '" + jstype(x) + "'")
|
|
38
|
+
for i in range(256):
|
|
39
|
+
ρσ_seed_state.key[i] = i
|
|
40
|
+
j = 0
|
|
41
|
+
for i in range(256):
|
|
42
|
+
j = (j + ρσ_seed_state.key[i] + x.charCodeAt(i % x.length)) % 256
|
|
43
|
+
ρσ_seed_state.key[i], ρσ_seed_state.key[j] = ρσ_seed_state.key[j], ρσ_seed_state.key[i]
|
|
44
|
+
seed()
|
|
45
|
+
|
|
46
|
+
def random():
|
|
47
|
+
n = 0
|
|
48
|
+
m = 1
|
|
49
|
+
for i in range(8):
|
|
50
|
+
n += ρσ_get_random_byte() * m
|
|
51
|
+
m *= 256
|
|
52
|
+
return v'n / 0x10000000000000000'
|
|
53
|
+
|
|
54
|
+
def randrange():
|
|
55
|
+
if arguments.length is 1:
|
|
56
|
+
return randbelow(int(arguments[0]))
|
|
57
|
+
start = int(arguments[0])
|
|
58
|
+
stop = int(arguments[1])
|
|
59
|
+
if arguments.length < 3:
|
|
60
|
+
step = 1
|
|
61
|
+
else:
|
|
62
|
+
step = int(arguments[2])
|
|
63
|
+
width = stop - start
|
|
64
|
+
if step is 1:
|
|
65
|
+
if width > 0:
|
|
66
|
+
return start + randbelow(width)
|
|
67
|
+
raise ValueError("empty range for randrange()")
|
|
68
|
+
if step > 0:
|
|
69
|
+
n = (width + step - 1) // step
|
|
70
|
+
elif step < 0:
|
|
71
|
+
n = (width + step + 1) // step
|
|
72
|
+
else:
|
|
73
|
+
raise ValueError("zero step for randrange()")
|
|
74
|
+
if n <= 0:
|
|
75
|
+
raise ValueError(f"empty range in randrange({start}, {stop}, {step})")
|
|
76
|
+
return start + step * randbelow(n)
|
|
77
|
+
|
|
78
|
+
|
|
79
|
+
def randint(a, b):
|
|
80
|
+
return int(random()*(b-a+1) + a)
|
|
81
|
+
|
|
82
|
+
def uniform(a, b):
|
|
83
|
+
return random()*(b-a) + a
|
|
84
|
+
|
|
85
|
+
def randbelow(n):
|
|
86
|
+
return Math.floor(random()*n)
|
|
87
|
+
|
|
88
|
+
def choice(seq):
|
|
89
|
+
if seq.length > 0:
|
|
90
|
+
return seq[randbelow(seq.length)]
|
|
91
|
+
else:
|
|
92
|
+
raise IndexError()
|
|
93
|
+
|
|
94
|
+
# uses Fisher-Yates algorithm to shuffle an array
|
|
95
|
+
def shuffle(x, random_f=random):
|
|
96
|
+
for i in range(x.length):
|
|
97
|
+
j = Math.floor(random_f() * (i+1))
|
|
98
|
+
x[i], x[j] = x[j], x[i]
|
|
99
|
+
return x
|
|
100
|
+
|
|
101
|
+
# similar to shuffle, but only shuffles a subset and creates a copy
|
|
102
|
+
def sample(population, k):
|
|
103
|
+
x = population.slice()
|
|
104
|
+
for i in range(population.length-1, population.length-k-1, -1):
|
|
105
|
+
j = Math.floor(random() * (i+1))
|
|
106
|
+
x[i], x[j] = x[j], x[i]
|
|
107
|
+
return x.slice(population.length-k)
|
|
108
|
+
|
|
109
|
+
|
|
110
|
+
#import stdlib
|
|
111
|
+
#a = range(50)
|
|
112
|
+
#random.seed(5)
|
|
113
|
+
#print(random.choice(a))
|
|
114
|
+
#print(random.shuffle(a))
|
|
115
|
+
#print(random.randrange(10))
|
|
116
|
+
#print(random.randint(1,5))
|
|
117
|
+
#print(random.uniform(1,5))
|
|
118
|
+
#print(random.sample(range(20),5))
|