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.
Files changed (116) 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 +8 -0
  5. package/HACKING.md +103 -103
  6. package/LICENSE +24 -24
  7. package/PYTHON_DIFFERENCES_REPORT.md +2 -2
  8. package/PYTHON_FEATURE_COVERAGE.md +13 -13
  9. package/README.md +670 -6
  10. package/TODO.md +5 -6
  11. package/add-toc-to-readme +2 -2
  12. package/bin/export +75 -75
  13. package/bin/rapydscript +70 -70
  14. package/bin/web-repl-export +102 -102
  15. package/build +2 -2
  16. package/language-service/index.js +155 -6
  17. package/package.json +1 -1
  18. package/publish.py +37 -37
  19. package/release/baselib-plain-pretty.js +2006 -229
  20. package/release/baselib-plain-ugly.js +70 -3
  21. package/release/compiler.js +11554 -3870
  22. package/release/signatures.json +31 -29
  23. package/session.vim +4 -4
  24. package/setup.cfg +2 -2
  25. package/src/ast.pyj +93 -1
  26. package/src/baselib-builtins.pyj +22 -1
  27. package/src/baselib-containers.pyj +99 -0
  28. package/src/baselib-errors.pyj +44 -0
  29. package/src/baselib-internal.pyj +94 -4
  30. package/src/baselib-itertools.pyj +97 -97
  31. package/src/baselib-str.pyj +24 -0
  32. package/src/compiler.pyj +36 -36
  33. package/src/errors.pyj +30 -30
  34. package/src/lib/aes.pyj +646 -646
  35. package/src/lib/copy.pyj +120 -0
  36. package/src/lib/elementmaker.pyj +83 -83
  37. package/src/lib/encodings.pyj +126 -126
  38. package/src/lib/gettext.pyj +569 -569
  39. package/src/lib/itertools.pyj +580 -580
  40. package/src/lib/math.pyj +193 -193
  41. package/src/lib/operator.pyj +11 -11
  42. package/src/lib/pythonize.pyj +20 -20
  43. package/src/lib/random.pyj +118 -118
  44. package/src/lib/re.pyj +470 -470
  45. package/src/lib/react.pyj +74 -0
  46. package/src/lib/traceback.pyj +63 -63
  47. package/src/lib/uuid.pyj +77 -77
  48. package/src/monaco-language-service/builtins.js +5 -0
  49. package/src/monaco-language-service/diagnostics.js +25 -3
  50. package/src/monaco-language-service/dts.js +550 -550
  51. package/src/output/classes.pyj +108 -8
  52. package/src/output/codegen.pyj +16 -2
  53. package/src/output/comments.pyj +45 -45
  54. package/src/output/exceptions.pyj +201 -105
  55. package/src/output/functions.pyj +9 -0
  56. package/src/output/jsx.pyj +164 -0
  57. package/src/output/literals.pyj +28 -2
  58. package/src/output/modules.pyj +1 -1
  59. package/src/output/operators.pyj +8 -2
  60. package/src/output/statements.pyj +2 -2
  61. package/src/output/stream.pyj +1 -0
  62. package/src/output/treeshake.pyj +182 -182
  63. package/src/output/utils.pyj +72 -72
  64. package/src/parse.pyj +417 -113
  65. package/src/string_interpolation.pyj +72 -72
  66. package/src/tokenizer.pyj +29 -0
  67. package/src/unicode_aliases.pyj +576 -576
  68. package/src/utils.pyj +192 -192
  69. package/test/_import_one.pyj +37 -37
  70. package/test/_import_two/__init__.pyj +11 -11
  71. package/test/_import_two/level2/deep.pyj +4 -4
  72. package/test/_import_two/other.pyj +6 -6
  73. package/test/_import_two/sub.pyj +13 -13
  74. package/test/aes_vectors.pyj +421 -421
  75. package/test/annotations.pyj +80 -80
  76. package/test/decorators.pyj +77 -77
  77. package/test/docstrings.pyj +39 -39
  78. package/test/elementmaker_test.pyj +45 -45
  79. package/test/functions.pyj +151 -151
  80. package/test/generators.pyj +41 -41
  81. package/test/generic.pyj +370 -370
  82. package/test/imports.pyj +72 -72
  83. package/test/internationalization.pyj +73 -73
  84. package/test/lint.pyj +164 -164
  85. package/test/loops.pyj +85 -85
  86. package/test/numpy.pyj +734 -734
  87. package/test/omit_function_metadata.pyj +20 -20
  88. package/test/python_features.pyj +19 -6
  89. package/test/regexp.pyj +55 -55
  90. package/test/repl.pyj +121 -121
  91. package/test/scoped_flags.pyj +76 -76
  92. package/test/unit/index.js +2177 -64
  93. package/test/unit/language-service-dts.js +543 -543
  94. package/test/unit/language-service-hover.js +455 -455
  95. package/test/unit/language-service.js +590 -4
  96. package/test/unit/web-repl.js +303 -0
  97. package/tools/cli.js +547 -547
  98. package/tools/compile.js +219 -219
  99. package/tools/completer.js +131 -131
  100. package/tools/embedded_compiler.js +251 -251
  101. package/tools/gettext.js +185 -185
  102. package/tools/ini.js +65 -65
  103. package/tools/msgfmt.js +187 -187
  104. package/tools/repl.js +223 -223
  105. package/tools/test.js +118 -118
  106. package/tools/utils.js +128 -128
  107. package/tools/web_repl.js +95 -95
  108. package/try +41 -41
  109. package/web-repl/env.js +196 -74
  110. package/web-repl/index.html +163 -163
  111. package/web-repl/main.js +252 -254
  112. package/web-repl/prism.css +139 -139
  113. package/web-repl/prism.js +113 -113
  114. package/web-repl/rapydscript.js +224 -102
  115. package/web-repl/sha1.js +25 -25
  116. package/hack_demo.pyj +0 -112
@@ -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))