rapydscript-ns 0.8.4 → 0.9.1

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 (141) 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 +26 -0
  5. package/HACKING.md +103 -103
  6. package/LICENSE +24 -24
  7. package/README.md +716 -169
  8. package/TODO.md +7 -2
  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 +36 -27
  15. package/package.json +1 -1
  16. package/publish.py +37 -37
  17. package/release/baselib-plain-pretty.js +2358 -168
  18. package/release/baselib-plain-ugly.js +73 -3
  19. package/release/compiler.js +6283 -3093
  20. package/release/signatures.json +31 -30
  21. package/session.vim +4 -4
  22. package/setup.cfg +2 -2
  23. package/src/ast.pyj +1 -0
  24. package/src/baselib-builtins.pyj +340 -2
  25. package/src/baselib-bytes.pyj +664 -0
  26. package/src/baselib-errors.pyj +1 -1
  27. package/src/baselib-internal.pyj +267 -60
  28. package/src/baselib-itertools.pyj +110 -97
  29. package/src/baselib-str.pyj +22 -4
  30. package/src/compiler.pyj +36 -36
  31. package/src/errors.pyj +30 -30
  32. package/src/lib/abc.pyj +317 -0
  33. package/src/lib/aes.pyj +646 -646
  34. package/src/lib/contextlib.pyj +379 -0
  35. package/src/lib/copy.pyj +120 -120
  36. package/src/lib/dataclasses.pyj +532 -0
  37. package/src/lib/datetime.pyj +712 -0
  38. package/src/lib/elementmaker.pyj +83 -83
  39. package/src/lib/encodings.pyj +126 -126
  40. package/src/lib/enum.pyj +125 -0
  41. package/src/lib/gettext.pyj +569 -569
  42. package/src/lib/io.pyj +500 -0
  43. package/src/lib/itertools.pyj +580 -580
  44. package/src/lib/json.pyj +227 -0
  45. package/src/lib/math.pyj +193 -193
  46. package/src/lib/operator.pyj +11 -11
  47. package/src/lib/pythonize.pyj +20 -20
  48. package/src/lib/random.pyj +118 -118
  49. package/src/lib/re.pyj +504 -470
  50. package/src/lib/react.pyj +74 -74
  51. package/src/lib/traceback.pyj +63 -63
  52. package/src/lib/typing.pyj +577 -0
  53. package/src/lib/uuid.pyj +77 -77
  54. package/src/monaco-language-service/builtins.js +14 -4
  55. package/src/monaco-language-service/diagnostics.js +19 -20
  56. package/src/monaco-language-service/dts.js +550 -550
  57. package/src/output/classes.pyj +62 -26
  58. package/src/output/comments.pyj +45 -45
  59. package/src/output/exceptions.pyj +201 -201
  60. package/src/output/functions.pyj +78 -5
  61. package/src/output/jsx.pyj +164 -164
  62. package/src/output/loops.pyj +5 -2
  63. package/src/output/operators.pyj +100 -34
  64. package/src/output/treeshake.pyj +182 -182
  65. package/src/output/utils.pyj +72 -72
  66. package/src/parse.pyj +80 -16
  67. package/src/string_interpolation.pyj +72 -72
  68. package/src/tokenizer.pyj +10 -5
  69. package/src/unicode_aliases.pyj +576 -576
  70. package/src/utils.pyj +192 -192
  71. package/test/_import_one.pyj +37 -37
  72. package/test/_import_two/__init__.pyj +11 -11
  73. package/test/_import_two/level2/deep.pyj +4 -4
  74. package/test/_import_two/other.pyj +6 -6
  75. package/test/_import_two/sub.pyj +13 -13
  76. package/test/abc.pyj +291 -0
  77. package/test/aes_vectors.pyj +421 -421
  78. package/test/annotations.pyj +80 -80
  79. package/test/arithmetic_nostrict.pyj +88 -0
  80. package/test/arithmetic_types.pyj +169 -0
  81. package/test/baselib.pyj +91 -0
  82. package/test/bytes.pyj +467 -0
  83. package/test/classes.pyj +1 -0
  84. package/test/comparison_ops.pyj +173 -0
  85. package/test/contextlib.pyj +362 -0
  86. package/test/dataclasses.pyj +253 -0
  87. package/test/datetime.pyj +500 -0
  88. package/test/debugger_stmt.pyj +41 -0
  89. package/test/decorators.pyj +77 -77
  90. package/test/docstrings.pyj +39 -39
  91. package/test/elementmaker_test.pyj +45 -45
  92. package/test/enum.pyj +134 -0
  93. package/test/eval_exec.pyj +56 -0
  94. package/test/format.pyj +148 -0
  95. package/test/functions.pyj +151 -151
  96. package/test/generators.pyj +41 -41
  97. package/test/generic.pyj +370 -370
  98. package/test/imports.pyj +72 -72
  99. package/test/internationalization.pyj +73 -73
  100. package/test/io.pyj +316 -0
  101. package/test/json.pyj +196 -0
  102. package/test/lint.pyj +164 -164
  103. package/test/loops.pyj +85 -85
  104. package/test/numpy.pyj +734 -734
  105. package/test/object.pyj +64 -0
  106. package/test/omit_function_metadata.pyj +20 -20
  107. package/test/python_compat.pyj +17 -15
  108. package/test/python_features.pyj +70 -15
  109. package/test/regexp.pyj +83 -55
  110. package/test/repl.pyj +121 -121
  111. package/test/scoped_flags.pyj +76 -76
  112. package/test/tuples.pyj +96 -0
  113. package/test/typing.pyj +469 -0
  114. package/test/unit/index.js +116 -7
  115. package/test/unit/language-service-dts.js +543 -543
  116. package/test/unit/language-service-hover.js +455 -455
  117. package/test/unit/language-service.js +84 -0
  118. package/test/unit/web-repl.js +1337 -1
  119. package/test/vars_locals_globals.pyj +94 -0
  120. package/tools/cli.js +558 -547
  121. package/tools/compile.js +224 -219
  122. package/tools/completer.js +131 -131
  123. package/tools/embedded_compiler.js +262 -251
  124. package/tools/gettext.js +185 -185
  125. package/tools/ini.js +65 -65
  126. package/tools/lint.js +16 -19
  127. package/tools/msgfmt.js +187 -187
  128. package/tools/repl.js +223 -223
  129. package/tools/test.js +118 -118
  130. package/tools/utils.js +128 -128
  131. package/tools/web_repl.js +95 -95
  132. package/try +41 -41
  133. package/web-repl/env.js +196 -196
  134. package/web-repl/index.html +163 -163
  135. package/web-repl/main.js +252 -252
  136. package/web-repl/prism.css +139 -139
  137. package/web-repl/prism.js +113 -113
  138. package/web-repl/rapydscript.js +224 -224
  139. package/web-repl/sha1.js +25 -25
  140. package/PYTHON_DIFFERENCES_REPORT.md +0 -291
  141. package/PYTHON_FEATURE_COVERAGE.md +0 -200
@@ -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))