@ugo-studio/jspp 0.2.8 → 0.3.0
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/dist/analysis/typeAnalyzer.js +42 -27
- package/dist/core/codegen/class-handlers.js +6 -6
- package/dist/core/codegen/control-flow-handlers.js +4 -4
- package/dist/core/codegen/declaration-handlers.js +21 -3
- package/dist/core/codegen/destructuring-handlers.js +187 -0
- package/dist/core/codegen/expression-handlers.js +7 -0
- package/dist/core/codegen/function-handlers.js +58 -36
- package/dist/core/codegen/helpers.js +288 -52
- package/dist/core/codegen/index.js +7 -4
- package/dist/core/codegen/statement-handlers.js +43 -23
- package/package.json +1 -1
- package/scripts/precompile-headers.ts +13 -5
- package/src/prelude/any_value.hpp +362 -361
- package/src/prelude/any_value_access.hpp +170 -170
- package/src/prelude/any_value_defines.hpp +189 -189
- package/src/prelude/any_value_helpers.hpp +374 -365
- package/src/prelude/library/array.hpp +185 -185
- package/src/prelude/library/console.hpp +111 -111
- package/src/prelude/library/error.hpp +112 -112
- package/src/prelude/library/function.hpp +10 -10
- package/src/prelude/library/math.hpp +307 -307
- package/src/prelude/library/object.hpp +275 -275
- package/src/prelude/library/performance.hpp +1 -1
- package/src/prelude/library/process.hpp +39 -39
- package/src/prelude/library/promise.hpp +123 -123
- package/src/prelude/library/symbol.hpp +52 -52
- package/src/prelude/library/timer.hpp +91 -91
- package/src/prelude/types.hpp +178 -178
- package/src/prelude/utils/access.hpp +411 -393
- package/src/prelude/utils/operators.hpp +336 -329
- package/src/prelude/values/array.hpp +0 -1
- package/src/prelude/values/async_iterator.hpp +83 -81
- package/src/prelude/values/function.hpp +82 -82
- package/src/prelude/values/helpers/array.hpp +198 -208
- package/src/prelude/values/helpers/async_iterator.hpp +275 -271
- package/src/prelude/values/helpers/function.hpp +108 -108
- package/src/prelude/values/helpers/iterator.hpp +144 -107
- package/src/prelude/values/helpers/promise.hpp +253 -253
- package/src/prelude/values/helpers/string.hpp +37 -47
- package/src/prelude/values/iterator.hpp +32 -5
- package/src/prelude/values/promise.hpp +72 -72
- package/src/prelude/values/prototypes/array.hpp +54 -42
- package/src/prelude/values/prototypes/iterator.hpp +201 -74
- package/src/prelude/values/prototypes/promise.hpp +196 -196
- package/src/prelude/values/prototypes/string.hpp +564 -542
- package/src/prelude/values/string.hpp +25 -26
|
@@ -1,74 +1,201 @@
|
|
|
1
|
-
#pragma once
|
|
2
|
-
|
|
3
|
-
#include "types.hpp"
|
|
4
|
-
#include "values/iterator.hpp"
|
|
5
|
-
#include "any_value.hpp"
|
|
6
|
-
#include "exception.hpp"
|
|
7
|
-
#include "utils/operators.hpp"
|
|
8
|
-
|
|
9
|
-
namespace jspp
|
|
10
|
-
{
|
|
11
|
-
namespace IteratorPrototypes
|
|
12
|
-
{
|
|
13
|
-
inline AnyValue &get_toString_fn()
|
|
14
|
-
{
|
|
15
|
-
static AnyValue fn = AnyValue::make_function([](const AnyValue &thisVal, std::span<const AnyValue>) -> AnyValue
|
|
16
|
-
{ return AnyValue::make_string(thisVal.as_iterator()->to_std_string()); },
|
|
17
|
-
"toString");
|
|
18
|
-
return fn;
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
inline AnyValue &get_iterator_fn()
|
|
22
|
-
{
|
|
23
|
-
static AnyValue fn = AnyValue::make_generator([](const AnyValue &thisVal, std::span<const AnyValue>) -> AnyValue
|
|
24
|
-
{ return thisVal; },
|
|
25
|
-
"Symbol.iterator");
|
|
26
|
-
return fn;
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
inline AnyValue &get_next_fn()
|
|
30
|
-
{
|
|
31
|
-
static AnyValue fn = AnyValue::make_function([](const AnyValue &thisVal, std::span<const AnyValue> args) -> AnyValue
|
|
32
|
-
{
|
|
33
|
-
AnyValue val = args.empty() ? Constants::UNDEFINED : args[0];
|
|
34
|
-
auto res = thisVal.as_iterator()->next(val);
|
|
35
|
-
return AnyValue::make_object({{"value", res.value.value_or(Constants::UNDEFINED)}, {"done", AnyValue::make_boolean(res.done)}}); },
|
|
36
|
-
"next");
|
|
37
|
-
return fn;
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
inline AnyValue &
|
|
41
|
-
{
|
|
42
|
-
static AnyValue fn = AnyValue::make_function([](const AnyValue &thisVal, std::span<const AnyValue>) -> AnyValue
|
|
43
|
-
{
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
1
|
+
#pragma once
|
|
2
|
+
|
|
3
|
+
#include "types.hpp"
|
|
4
|
+
#include "values/iterator.hpp"
|
|
5
|
+
#include "any_value.hpp"
|
|
6
|
+
#include "exception.hpp"
|
|
7
|
+
#include "utils/operators.hpp"
|
|
8
|
+
|
|
9
|
+
namespace jspp
|
|
10
|
+
{
|
|
11
|
+
namespace IteratorPrototypes
|
|
12
|
+
{
|
|
13
|
+
inline AnyValue &get_toString_fn()
|
|
14
|
+
{
|
|
15
|
+
static AnyValue fn = AnyValue::make_function([](const AnyValue &thisVal, std::span<const AnyValue>) -> AnyValue
|
|
16
|
+
{ return AnyValue::make_string(thisVal.as_iterator()->to_std_string()); },
|
|
17
|
+
"toString");
|
|
18
|
+
return fn;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
inline AnyValue &get_iterator_fn()
|
|
22
|
+
{
|
|
23
|
+
static AnyValue fn = AnyValue::make_generator([](const AnyValue &thisVal, std::span<const AnyValue>) -> AnyValue
|
|
24
|
+
{ return thisVal; },
|
|
25
|
+
"Symbol.iterator");
|
|
26
|
+
return fn;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
inline AnyValue &get_next_fn()
|
|
30
|
+
{
|
|
31
|
+
static AnyValue fn = AnyValue::make_function([](const AnyValue &thisVal, std::span<const AnyValue> args) -> AnyValue
|
|
32
|
+
{
|
|
33
|
+
AnyValue val = args.empty() ? Constants::UNDEFINED : args[0];
|
|
34
|
+
auto res = thisVal.as_iterator()->next(val);
|
|
35
|
+
return AnyValue::make_object({{"value", res.value.value_or(Constants::UNDEFINED)}, {"done", AnyValue::make_boolean(res.done)}}); },
|
|
36
|
+
"next");
|
|
37
|
+
return fn;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
inline AnyValue &get_return_fn()
|
|
41
|
+
{
|
|
42
|
+
static AnyValue fn = AnyValue::make_function([](const AnyValue &thisVal, std::span<const AnyValue> args) -> AnyValue
|
|
43
|
+
{
|
|
44
|
+
AnyValue val = args.empty() ? Constants::UNDEFINED : args[0];
|
|
45
|
+
auto res = thisVal.as_iterator()->return_(val);
|
|
46
|
+
return AnyValue::make_object({{"value", res.value.value_or(Constants::UNDEFINED)}, {"done", AnyValue::make_boolean(res.done)}}); },
|
|
47
|
+
"return");
|
|
48
|
+
return fn;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
inline AnyValue &get_throw_fn()
|
|
52
|
+
{
|
|
53
|
+
static AnyValue fn = AnyValue::make_function([](const AnyValue &thisVal, std::span<const AnyValue> args) -> AnyValue
|
|
54
|
+
{
|
|
55
|
+
AnyValue err = args.empty() ? Constants::UNDEFINED : args[0];
|
|
56
|
+
auto res = thisVal.as_iterator()->throw_(err);
|
|
57
|
+
return AnyValue::make_object({{"value", res.value.value_or(Constants::UNDEFINED)}, {"done", AnyValue::make_boolean(res.done)}}); },
|
|
58
|
+
"throw");
|
|
59
|
+
return fn;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
inline AnyValue &get_toArray_fn()
|
|
63
|
+
{
|
|
64
|
+
static AnyValue fn = AnyValue::make_function([](const AnyValue &thisVal, std::span<const AnyValue>) -> AnyValue
|
|
65
|
+
{ return AnyValue::make_array(thisVal.as_iterator()->to_vector()); },
|
|
66
|
+
"drop");
|
|
67
|
+
return fn;
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
inline AnyValue &get_drop_fn()
|
|
71
|
+
{
|
|
72
|
+
static AnyValue fn = AnyValue::make_generator([](AnyValue thisVal, std::vector<AnyValue> args) -> JsIterator<AnyValue>
|
|
73
|
+
{
|
|
74
|
+
auto self = thisVal.as_iterator();
|
|
75
|
+
size_t skip_count = 0;
|
|
76
|
+
if (!args.empty()) {
|
|
77
|
+
skip_count = static_cast<size_t>(args[0].as_double());
|
|
78
|
+
}
|
|
79
|
+
size_t skipped = 0;
|
|
80
|
+
while (true)
|
|
81
|
+
{
|
|
82
|
+
auto next_res = self->next();
|
|
83
|
+
if (next_res.done) { break; }
|
|
84
|
+
if (skipped < skip_count)
|
|
85
|
+
{
|
|
86
|
+
skipped++;
|
|
87
|
+
continue;
|
|
88
|
+
}
|
|
89
|
+
co_yield next_res.value.value_or(Constants::UNDEFINED);
|
|
90
|
+
}
|
|
91
|
+
co_return jspp::Constants::UNDEFINED; },
|
|
92
|
+
"drop");
|
|
93
|
+
return fn;
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
inline AnyValue &get_take_fn()
|
|
97
|
+
{
|
|
98
|
+
static AnyValue fn = AnyValue::make_generator([](AnyValue thisVal, std::vector<AnyValue> args) -> JsIterator<AnyValue>
|
|
99
|
+
{
|
|
100
|
+
auto self = thisVal.as_iterator();
|
|
101
|
+
size_t take_count = 0;
|
|
102
|
+
if (!args.empty()) {
|
|
103
|
+
take_count = static_cast<size_t>(args[0].as_double());
|
|
104
|
+
}
|
|
105
|
+
size_t taken = 0;
|
|
106
|
+
while (true)
|
|
107
|
+
{
|
|
108
|
+
auto next_res = self->next();
|
|
109
|
+
if (next_res.done) { break; }
|
|
110
|
+
if (taken < take_count)
|
|
111
|
+
{
|
|
112
|
+
taken++;
|
|
113
|
+
co_yield next_res.value.value_or(Constants::UNDEFINED);
|
|
114
|
+
}
|
|
115
|
+
if (taken >= take_count)
|
|
116
|
+
{
|
|
117
|
+
// Call the iterator's return() method for early cleanup of resources
|
|
118
|
+
self->return_();
|
|
119
|
+
break;
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
co_return jspp::Constants::UNDEFINED; },
|
|
123
|
+
"take");
|
|
124
|
+
return fn;
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
inline AnyValue &get_some_fn()
|
|
128
|
+
{
|
|
129
|
+
static AnyValue fn = AnyValue::make_function([](const AnyValue &thisVal, std::span<const AnyValue> args) -> AnyValue
|
|
130
|
+
{
|
|
131
|
+
auto self = thisVal.as_iterator();
|
|
132
|
+
if (args.empty() || !args[0].is_function()) throw Exception::make_exception("callback is not a function", "TypeError");
|
|
133
|
+
auto callback = args[0].as_function();
|
|
134
|
+
while (true)
|
|
135
|
+
{
|
|
136
|
+
auto next_res = self->next();
|
|
137
|
+
if (next_res.done) { break; }
|
|
138
|
+
if (is_truthy(callback->call(thisVal, std::span<const AnyValue>((const jspp::AnyValue[]){next_res.value.value_or(Constants::UNDEFINED)}, 1))))
|
|
139
|
+
{
|
|
140
|
+
// Call the iterator's return() method for early cleanup of resources
|
|
141
|
+
self->return_();
|
|
142
|
+
return Constants::TRUE;
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
return jspp::Constants::FALSE; },
|
|
146
|
+
"some");
|
|
147
|
+
return fn;
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
inline std::optional<AnyValue> get(const std::string &key)
|
|
151
|
+
{
|
|
152
|
+
// --- toString() method ---
|
|
153
|
+
if (key == "toString" || key == WellKnownSymbols::toStringTag->key)
|
|
154
|
+
{
|
|
155
|
+
return get_toString_fn();
|
|
156
|
+
}
|
|
157
|
+
// --- [Symbol.iterator]() method ---
|
|
158
|
+
if (key == WellKnownSymbols::iterator->key)
|
|
159
|
+
{
|
|
160
|
+
return get_iterator_fn();
|
|
161
|
+
}
|
|
162
|
+
// --- next() method ---
|
|
163
|
+
if (key == "next")
|
|
164
|
+
{
|
|
165
|
+
return get_next_fn();
|
|
166
|
+
}
|
|
167
|
+
// --- return() method ---
|
|
168
|
+
if (key == "return")
|
|
169
|
+
{
|
|
170
|
+
return get_return_fn();
|
|
171
|
+
}
|
|
172
|
+
// --- throw() method ---
|
|
173
|
+
if (key == "throw")
|
|
174
|
+
{
|
|
175
|
+
return get_throw_fn();
|
|
176
|
+
}
|
|
177
|
+
// --- toArray() method ---
|
|
178
|
+
if (key == "toArray")
|
|
179
|
+
{
|
|
180
|
+
return get_toArray_fn();
|
|
181
|
+
}
|
|
182
|
+
// --- drop() method ---
|
|
183
|
+
if (key == "drop")
|
|
184
|
+
{
|
|
185
|
+
return get_drop_fn();
|
|
186
|
+
}
|
|
187
|
+
// --- take() method ---
|
|
188
|
+
if (key == "take")
|
|
189
|
+
{
|
|
190
|
+
return get_take_fn();
|
|
191
|
+
}
|
|
192
|
+
// --- some() method ---
|
|
193
|
+
if (key == "some")
|
|
194
|
+
{
|
|
195
|
+
return get_some_fn();
|
|
196
|
+
}
|
|
197
|
+
|
|
198
|
+
return std::nullopt;
|
|
199
|
+
}
|
|
200
|
+
}
|
|
201
|
+
}
|