forgecad 0.9.7 → 0.9.8
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/README.md +1 -0
- package/dist/assets/{AdminPage-DX0mpSZT.js → AdminPage-CXaVLMiV.js} +1 -1
- package/dist/assets/{BlogPage-CI_P0_Pf.js → BlogPage-Crpr3JjH.js} +1 -1
- package/dist/assets/{DocsPage-DLhIIZyJ.js → DocsPage-CNBKuitP.js} +2 -2
- package/dist/assets/{EditorApp-DfFT2Dn8.css → EditorApp-D11wL4Qn.css} +51 -0
- package/dist/assets/{EditorApp-BujZvuwX.js → EditorApp-DVMnXOmO.js} +151 -9
- package/dist/assets/{EmbedViewer-0S0qXKog.js → EmbedViewer-KXFLSnpo.js} +2 -2
- package/dist/assets/{LandingPageProofDriven-O_yMtAri.js → LandingPageProofDriven-2q2sn7aW.js} +1 -1
- package/dist/assets/{PricingPage-DGkX3Ahr.js → PricingPage-CVvgdv0i.js} +1 -1
- package/dist/assets/{SettingsPage-DBsqTB_y.js → SettingsPage-BVj1FtEv.js} +1 -1
- package/dist/assets/__vite-browser-external-Dhvy_jtL.js +4 -0
- package/dist/assets/{app-BE2nD6Yz.js → app-Dn4EwHhN.js} +707 -458
- package/dist/assets/cli/{render-iP9qh475.js → render-BI3gLMXz.js} +1011 -145
- package/dist/assets/constructionHistoryWorker-z9_LGiRd.js +42984 -0
- package/dist/assets/{evalWorker-Ds5U4xtN.js → evalWorker-CtO7GsJR.js} +42 -9
- package/dist/assets/{inspectWorker-Dll4eVyD.js → inspectWorker-BZ2CkQZr.js} +785 -111
- package/dist/assets/{manifold-sJ-axdXM.js → manifold-BVi4_OeB.js} +1 -1
- package/dist/assets/{manifold-DjYsd7A_.js → manifold-C6-sZYQN.js} +2 -2
- package/dist/assets/manifold-Cp_dCC7i.js +3018 -0
- package/dist/assets/{manifold-Bk26ViCr.js → manifold-DAzn2Fsa.js} +1 -1
- package/dist/assets/{renderSceneState-Bngp5MrQ.js → renderSceneState-BIvOkPK3.js} +1 -1
- package/dist/assets/{reportWorker-CU8RZ4O0.js → reportWorker-Bz9tGiHb.js} +42 -9
- package/dist/assets/{sectionPlaneMath-BdTjyVfs.js → scalar-sampling-budget-iBAeF8RM.js} +483 -71
- package/dist/cli/render.html +1 -1
- package/dist/docs/index.html +1 -1
- package/dist/docs-raw/CLI.md +10 -10
- package/dist/docs-raw/coding-best-practices.md +1 -1
- package/dist/docs-raw/guides/inspection-bundles.md +77 -19
- package/dist/docs-raw/guides/skill-maintenance.md +1 -1
- package/dist/docs-raw/runbook.md +2 -2
- package/dist/docs-raw/skills/forgecad-make-a-model.md +11 -0
- package/dist/docs-raw/skills/forgecad-render-inspect.md +12 -6
- package/dist/docs-raw/skills/index.md +1 -1
- package/dist/index.html +1 -1
- package/dist/sitemap.xml +6 -6
- package/dist-cli/forgecad.js +596 -354
- package/dist-cli/forgecad.js.map +1 -1
- package/dist-skill/CONTEXT.md +77 -19
- package/dist-skill/docs/CLI.md +10 -10
- package/dist-skill/docs/guides/inspection-bundles.md +77 -19
- package/dist-skill/docs-dev/CLI.md +10 -10
- package/dist-skill/docs-dev/coding-best-practices.md +1 -1
- package/dist-skill/docs-dev/guides/inspection-bundles.md +77 -19
- package/dist-skill/docs-dev/guides/skill-maintenance.md +1 -1
- package/dist-skill/library/forgecad-make-a-model/SKILL.md +11 -0
- package/dist-skill/library/forgecad-render-inspect/SKILL.md +12 -6
- package/package.json +6 -3
|
@@ -0,0 +1,3018 @@
|
|
|
1
|
+
var Module = (() => {
|
|
2
|
+
var _scriptName = import.meta.url;
|
|
3
|
+
return (async function(moduleArg = {}) {
|
|
4
|
+
var moduleRtn;
|
|
5
|
+
var Module2 = moduleArg;
|
|
6
|
+
var readyPromiseResolve, readyPromiseReject;
|
|
7
|
+
var readyPromise = new Promise((resolve, reject) => {
|
|
8
|
+
readyPromiseResolve = resolve;
|
|
9
|
+
readyPromiseReject = reject;
|
|
10
|
+
});
|
|
11
|
+
var ENVIRONMENT_IS_WEB = typeof window == "object";
|
|
12
|
+
var ENVIRONMENT_IS_WORKER = typeof WorkerGlobalScope != "undefined";
|
|
13
|
+
var ENVIRONMENT_IS_NODE = typeof process == "object" && typeof process.versions == "object" && typeof process.versions.node == "string" && process.type != "renderer";
|
|
14
|
+
if (ENVIRONMENT_IS_NODE) {
|
|
15
|
+
const { createRequire } = await import("./__vite-browser-external-Dhvy_jtL.js");
|
|
16
|
+
var require2 = createRequire(import.meta.url);
|
|
17
|
+
}
|
|
18
|
+
var _ManifoldInitialized = false;
|
|
19
|
+
Module2.setup = function() {
|
|
20
|
+
if (_ManifoldInitialized) return;
|
|
21
|
+
_ManifoldInitialized = true;
|
|
22
|
+
Module2.initTBB();
|
|
23
|
+
function toVec(vec, list, f = ((x) => x)) {
|
|
24
|
+
if (list) {
|
|
25
|
+
for (let x of list) {
|
|
26
|
+
vec.push_back(f(x));
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
return vec;
|
|
30
|
+
}
|
|
31
|
+
function fromVec(vec, f = ((x) => x)) {
|
|
32
|
+
const result = [];
|
|
33
|
+
const size = vec.size();
|
|
34
|
+
for (let i = 0; i < size; i++) result.push(f(vec.get(i)));
|
|
35
|
+
return result;
|
|
36
|
+
}
|
|
37
|
+
function vec2polygons(vec, f = ((x) => x)) {
|
|
38
|
+
const result = [];
|
|
39
|
+
const nPoly = vec.size();
|
|
40
|
+
for (let i = 0; i < nPoly; i++) {
|
|
41
|
+
const v = vec.get(i);
|
|
42
|
+
const nPts = v.size();
|
|
43
|
+
const poly = [];
|
|
44
|
+
for (let j = 0; j < nPts; j++) {
|
|
45
|
+
poly.push(f(v.get(j)));
|
|
46
|
+
}
|
|
47
|
+
result.push(poly);
|
|
48
|
+
}
|
|
49
|
+
return result;
|
|
50
|
+
}
|
|
51
|
+
function polygons2vec(polygons) {
|
|
52
|
+
if (polygons[0].length < 3) {
|
|
53
|
+
polygons = [polygons];
|
|
54
|
+
}
|
|
55
|
+
return toVec(
|
|
56
|
+
new Module2.Vector2_vec2(),
|
|
57
|
+
polygons,
|
|
58
|
+
(poly) => toVec(new Module2.Vector_vec2(), poly, (p) => {
|
|
59
|
+
if (p instanceof Array) return { x: p[0], y: p[1] };
|
|
60
|
+
return p;
|
|
61
|
+
})
|
|
62
|
+
);
|
|
63
|
+
}
|
|
64
|
+
function disposePolygons(polygonsVec) {
|
|
65
|
+
for (let i = 0; i < polygonsVec.size(); i++)
|
|
66
|
+
polygonsVec.get(i).delete();
|
|
67
|
+
polygonsVec.delete();
|
|
68
|
+
}
|
|
69
|
+
function vararg2vec2(vec) {
|
|
70
|
+
if (vec[0] instanceof Array) return { x: vec[0][0], y: vec[0][1] };
|
|
71
|
+
if (typeof vec[0] == "number") return { x: vec[0] || 0, y: vec[1] || 0 };
|
|
72
|
+
return vec[0];
|
|
73
|
+
}
|
|
74
|
+
function vararg2vec3(vec) {
|
|
75
|
+
if (vec[0] instanceof Array)
|
|
76
|
+
return { x: vec[0][0], y: vec[0][1], z: vec[0][2] };
|
|
77
|
+
if (typeof vec[0] == "number")
|
|
78
|
+
return { x: vec[0] || 0, y: vec[1] || 0, z: vec[2] || 0 };
|
|
79
|
+
return vec[0];
|
|
80
|
+
}
|
|
81
|
+
function fillRuleToInt(fillRule) {
|
|
82
|
+
return fillRule == "EvenOdd" ? 0 : fillRule == "NonZero" ? 1 : fillRule == "Negative" ? 3 : 2;
|
|
83
|
+
}
|
|
84
|
+
function joinTypeToInt(joinType) {
|
|
85
|
+
return joinType == "Round" ? 1 : joinType == "Miter" ? 2 : 0;
|
|
86
|
+
}
|
|
87
|
+
const CrossSectionCtor = Module2.CrossSection;
|
|
88
|
+
function cross(polygons, fillRule = "Positive") {
|
|
89
|
+
if (polygons instanceof CrossSectionCtor) {
|
|
90
|
+
return polygons;
|
|
91
|
+
} else {
|
|
92
|
+
const polygonsVec = polygons2vec(polygons);
|
|
93
|
+
const cs = new CrossSectionCtor(polygonsVec, fillRuleToInt(fillRule));
|
|
94
|
+
disposePolygons(polygonsVec);
|
|
95
|
+
return cs;
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
Module2.CrossSection.prototype.translate = function(...vec) {
|
|
99
|
+
return this._Translate(vararg2vec2(vec));
|
|
100
|
+
};
|
|
101
|
+
Module2.CrossSection.prototype.scale = function(vec) {
|
|
102
|
+
if (typeof vec == "number") {
|
|
103
|
+
return this._Scale({ x: vec, y: vec });
|
|
104
|
+
}
|
|
105
|
+
return this._Scale(vararg2vec2([vec]));
|
|
106
|
+
};
|
|
107
|
+
Module2.CrossSection.prototype.mirror = function(vec) {
|
|
108
|
+
return this._Mirror(vararg2vec2([vec]));
|
|
109
|
+
};
|
|
110
|
+
Module2.CrossSection.prototype.warp = function(func) {
|
|
111
|
+
const wasmFuncPtr = addFunction(function(vec2Ptr) {
|
|
112
|
+
const x = getValue(vec2Ptr, "double");
|
|
113
|
+
const y = getValue(vec2Ptr + 8, "double");
|
|
114
|
+
const vert = [x, y];
|
|
115
|
+
func(vert);
|
|
116
|
+
setValue(vec2Ptr, vert[0], "double");
|
|
117
|
+
setValue(vec2Ptr + 8, vert[1], "double");
|
|
118
|
+
}, "vi");
|
|
119
|
+
const out = this._Warp(wasmFuncPtr);
|
|
120
|
+
removeFunction(wasmFuncPtr);
|
|
121
|
+
return out;
|
|
122
|
+
};
|
|
123
|
+
Module2.CrossSection.prototype.decompose = function() {
|
|
124
|
+
const vec = this._Decompose();
|
|
125
|
+
const result = fromVec(vec);
|
|
126
|
+
vec.delete();
|
|
127
|
+
return result;
|
|
128
|
+
};
|
|
129
|
+
Module2.CrossSection.prototype.bounds = function() {
|
|
130
|
+
const result = this._Bounds();
|
|
131
|
+
return {
|
|
132
|
+
min: ["x", "y"].map((f) => result.min[f]),
|
|
133
|
+
max: ["x", "y"].map((f) => result.max[f])
|
|
134
|
+
};
|
|
135
|
+
};
|
|
136
|
+
Module2.CrossSection.prototype.offset = function(delta, joinType = "Square", miterLimit = 2, circularSegments = 0) {
|
|
137
|
+
return this._Offset(
|
|
138
|
+
delta,
|
|
139
|
+
joinTypeToInt(joinType),
|
|
140
|
+
miterLimit,
|
|
141
|
+
circularSegments
|
|
142
|
+
);
|
|
143
|
+
};
|
|
144
|
+
Module2.CrossSection.prototype.simplify = function(epsilon = 1e-6) {
|
|
145
|
+
return this._Simplify(epsilon);
|
|
146
|
+
};
|
|
147
|
+
Module2.CrossSection.prototype.extrude = function(height, nDivisions = 0, twistDegrees = 0, scaleTop = [1, 1], center = false) {
|
|
148
|
+
scaleTop = vararg2vec2([scaleTop]);
|
|
149
|
+
const man = Module2._Extrude(
|
|
150
|
+
this._ToPolygons(),
|
|
151
|
+
height,
|
|
152
|
+
nDivisions,
|
|
153
|
+
twistDegrees,
|
|
154
|
+
scaleTop
|
|
155
|
+
);
|
|
156
|
+
return center ? man.translate([0, 0, -height / 2]) : man;
|
|
157
|
+
};
|
|
158
|
+
Module2.CrossSection.prototype.revolve = function(circularSegments = 0, revolveDegrees = 360) {
|
|
159
|
+
return Module2._Revolve(
|
|
160
|
+
this._ToPolygons(),
|
|
161
|
+
circularSegments,
|
|
162
|
+
revolveDegrees
|
|
163
|
+
);
|
|
164
|
+
};
|
|
165
|
+
Module2.CrossSection.prototype.add = function(other) {
|
|
166
|
+
return this._add(cross(other));
|
|
167
|
+
};
|
|
168
|
+
Module2.CrossSection.prototype.subtract = function(other) {
|
|
169
|
+
return this._subtract(cross(other));
|
|
170
|
+
};
|
|
171
|
+
Module2.CrossSection.prototype.intersect = function(other) {
|
|
172
|
+
return this._intersect(cross(other));
|
|
173
|
+
};
|
|
174
|
+
Module2.CrossSection.prototype.toPolygons = function() {
|
|
175
|
+
const vec = this._ToPolygons();
|
|
176
|
+
const result = vec2polygons(vec, (v) => [v.x, v.y]);
|
|
177
|
+
vec.delete();
|
|
178
|
+
return result;
|
|
179
|
+
};
|
|
180
|
+
Module2.Manifold.prototype.smoothOut = function(minSharpAngle = 60, minSmoothness = 0) {
|
|
181
|
+
return this._SmoothOut(minSharpAngle, minSmoothness);
|
|
182
|
+
};
|
|
183
|
+
Module2.Manifold.prototype.warp = function(func) {
|
|
184
|
+
const wasmFuncPtr = addFunction(function(vec3Ptr) {
|
|
185
|
+
const x = getValue(vec3Ptr, "double");
|
|
186
|
+
const y = getValue(vec3Ptr + 8, "double");
|
|
187
|
+
const z = getValue(vec3Ptr + 16, "double");
|
|
188
|
+
const vert = [x, y, z];
|
|
189
|
+
func(vert);
|
|
190
|
+
setValue(vec3Ptr, vert[0], "double");
|
|
191
|
+
setValue(vec3Ptr + 8, vert[1], "double");
|
|
192
|
+
setValue(vec3Ptr + 16, vert[2], "double");
|
|
193
|
+
}, "vi");
|
|
194
|
+
const out = this._Warp(wasmFuncPtr);
|
|
195
|
+
removeFunction(wasmFuncPtr);
|
|
196
|
+
const status = out.status();
|
|
197
|
+
if (status.value !== 0) {
|
|
198
|
+
throw new Module2.ManifoldError(status.value);
|
|
199
|
+
}
|
|
200
|
+
return out;
|
|
201
|
+
};
|
|
202
|
+
Module2.Manifold.prototype.calculateNormals = function(normalIdx, minSharpAngle = 60) {
|
|
203
|
+
return this._CalculateNormals(normalIdx, minSharpAngle);
|
|
204
|
+
};
|
|
205
|
+
Module2.Manifold.prototype.setProperties = function(numProp, func) {
|
|
206
|
+
const oldNumProp = this.numProp();
|
|
207
|
+
const wasmFuncPtr = addFunction(function(newPtr, vec3Ptr, oldPtr) {
|
|
208
|
+
const newProp = [];
|
|
209
|
+
for (let i = 0; i < numProp; ++i) {
|
|
210
|
+
newProp[i] = getValue(newPtr + 8 * i, "double");
|
|
211
|
+
}
|
|
212
|
+
const pos = [];
|
|
213
|
+
for (let i = 0; i < 3; ++i) {
|
|
214
|
+
pos[i] = getValue(vec3Ptr + 8 * i, "double");
|
|
215
|
+
}
|
|
216
|
+
const oldProp = [];
|
|
217
|
+
for (let i = 0; i < oldNumProp; ++i) {
|
|
218
|
+
oldProp[i] = getValue(oldPtr + 8 * i, "double");
|
|
219
|
+
}
|
|
220
|
+
func(newProp, pos, oldProp);
|
|
221
|
+
for (let i = 0; i < numProp; ++i) {
|
|
222
|
+
setValue(newPtr + 8 * i, newProp[i], "double");
|
|
223
|
+
}
|
|
224
|
+
}, "viii");
|
|
225
|
+
const out = this._SetProperties(numProp, wasmFuncPtr);
|
|
226
|
+
removeFunction(wasmFuncPtr);
|
|
227
|
+
return out;
|
|
228
|
+
};
|
|
229
|
+
Module2.Manifold.prototype.translate = function(...vec) {
|
|
230
|
+
return this._Translate(vararg2vec3(vec));
|
|
231
|
+
};
|
|
232
|
+
Module2.Manifold.prototype.rotate = function(xOrVec, y, z) {
|
|
233
|
+
if (Array.isArray(xOrVec)) {
|
|
234
|
+
return this._Rotate(...xOrVec);
|
|
235
|
+
} else {
|
|
236
|
+
return this._Rotate(xOrVec, y || 0, z || 0);
|
|
237
|
+
}
|
|
238
|
+
};
|
|
239
|
+
Module2.Manifold.prototype.scale = function(vec) {
|
|
240
|
+
if (typeof vec == "number") {
|
|
241
|
+
return this._Scale({ x: vec, y: vec, z: vec });
|
|
242
|
+
}
|
|
243
|
+
return this._Scale(vararg2vec3([vec]));
|
|
244
|
+
};
|
|
245
|
+
Module2.Manifold.prototype.mirror = function(vec) {
|
|
246
|
+
return this._Mirror(vararg2vec3([vec]));
|
|
247
|
+
};
|
|
248
|
+
Module2.Manifold.prototype.trimByPlane = function(normal, offset = 0) {
|
|
249
|
+
return this._TrimByPlane(vararg2vec3([normal]), offset);
|
|
250
|
+
};
|
|
251
|
+
Module2.Manifold.prototype.slice = function(height = 0) {
|
|
252
|
+
const polygonsVec = this._Slice(height);
|
|
253
|
+
const result = new CrossSectionCtor(polygonsVec, fillRuleToInt("Positive"));
|
|
254
|
+
disposePolygons(polygonsVec);
|
|
255
|
+
return result;
|
|
256
|
+
};
|
|
257
|
+
Module2.Manifold.prototype.project = function() {
|
|
258
|
+
const polygonsVec = this._Project();
|
|
259
|
+
const result = new CrossSectionCtor(polygonsVec, fillRuleToInt("Positive"));
|
|
260
|
+
disposePolygons(polygonsVec);
|
|
261
|
+
return result;
|
|
262
|
+
};
|
|
263
|
+
Module2.Manifold.prototype.split = function(manifold) {
|
|
264
|
+
const vec = this._Split(manifold);
|
|
265
|
+
const result = fromVec(vec);
|
|
266
|
+
vec.delete();
|
|
267
|
+
return result;
|
|
268
|
+
};
|
|
269
|
+
Module2.Manifold.prototype.splitByPlane = function(normal, offset = 0) {
|
|
270
|
+
const vec = this._SplitByPlane(vararg2vec3([normal]), offset);
|
|
271
|
+
const result = fromVec(vec);
|
|
272
|
+
vec.delete();
|
|
273
|
+
return result;
|
|
274
|
+
};
|
|
275
|
+
Module2.Manifold.prototype.decompose = function() {
|
|
276
|
+
const vec = this._Decompose();
|
|
277
|
+
const result = fromVec(vec);
|
|
278
|
+
vec.delete();
|
|
279
|
+
return result;
|
|
280
|
+
};
|
|
281
|
+
Module2.Manifold.prototype.boundingBox = function() {
|
|
282
|
+
const result = this._boundingBox();
|
|
283
|
+
return {
|
|
284
|
+
min: ["x", "y", "z"].map((f) => result.min[f]),
|
|
285
|
+
max: ["x", "y", "z"].map((f) => result.max[f])
|
|
286
|
+
};
|
|
287
|
+
};
|
|
288
|
+
class Mesh {
|
|
289
|
+
constructor({
|
|
290
|
+
numProp = 3,
|
|
291
|
+
triVerts = new Uint32Array(),
|
|
292
|
+
vertProperties = new Float32Array(),
|
|
293
|
+
mergeFromVert,
|
|
294
|
+
mergeToVert,
|
|
295
|
+
runIndex,
|
|
296
|
+
runOriginalID,
|
|
297
|
+
faceID,
|
|
298
|
+
halfedgeTangent,
|
|
299
|
+
runTransform
|
|
300
|
+
} = {}) {
|
|
301
|
+
this.numProp = numProp;
|
|
302
|
+
this.triVerts = triVerts;
|
|
303
|
+
this.vertProperties = vertProperties;
|
|
304
|
+
this.mergeFromVert = mergeFromVert;
|
|
305
|
+
this.mergeToVert = mergeToVert;
|
|
306
|
+
this.runIndex = runIndex;
|
|
307
|
+
this.runOriginalID = runOriginalID;
|
|
308
|
+
this.faceID = faceID;
|
|
309
|
+
this.halfedgeTangent = halfedgeTangent;
|
|
310
|
+
this.runTransform = runTransform;
|
|
311
|
+
}
|
|
312
|
+
get numTri() {
|
|
313
|
+
return this.triVerts.length / 3;
|
|
314
|
+
}
|
|
315
|
+
get numVert() {
|
|
316
|
+
return this.vertProperties.length / this.numProp;
|
|
317
|
+
}
|
|
318
|
+
get numRun() {
|
|
319
|
+
return this.runOriginalID.length;
|
|
320
|
+
}
|
|
321
|
+
merge() {
|
|
322
|
+
const { changed, mesh } = Module2._Merge(this);
|
|
323
|
+
Object.assign(this, { ...mesh });
|
|
324
|
+
return changed;
|
|
325
|
+
}
|
|
326
|
+
verts(tri) {
|
|
327
|
+
return this.triVerts.subarray(3 * tri, 3 * (tri + 1));
|
|
328
|
+
}
|
|
329
|
+
position(vert) {
|
|
330
|
+
return this.vertProperties.subarray(
|
|
331
|
+
this.numProp * vert,
|
|
332
|
+
this.numProp * vert + 3
|
|
333
|
+
);
|
|
334
|
+
}
|
|
335
|
+
extras(vert) {
|
|
336
|
+
return this.vertProperties.subarray(
|
|
337
|
+
this.numProp * vert + 3,
|
|
338
|
+
this.numProp * (vert + 1)
|
|
339
|
+
);
|
|
340
|
+
}
|
|
341
|
+
tangent(halfedge) {
|
|
342
|
+
return this.halfedgeTangent.subarray(4 * halfedge, 4 * (halfedge + 1));
|
|
343
|
+
}
|
|
344
|
+
transform(run2) {
|
|
345
|
+
const mat4 = new Array(16);
|
|
346
|
+
for (const col of [0, 1, 2, 3]) {
|
|
347
|
+
for (const row of [0, 1, 2]) {
|
|
348
|
+
mat4[4 * col + row] = this.runTransform[12 * run2 + 3 * col + row];
|
|
349
|
+
}
|
|
350
|
+
}
|
|
351
|
+
mat4[15] = 1;
|
|
352
|
+
return mat4;
|
|
353
|
+
}
|
|
354
|
+
}
|
|
355
|
+
Module2.Mesh = Mesh;
|
|
356
|
+
Module2.Manifold.prototype.getMesh = function(normalIdx = -1) {
|
|
357
|
+
return new Mesh(this._GetMeshJS(normalIdx));
|
|
358
|
+
};
|
|
359
|
+
Module2.ManifoldError = function ManifoldError(code, ...args) {
|
|
360
|
+
let message = "Unknown error";
|
|
361
|
+
switch (code) {
|
|
362
|
+
case Module2.status.NonFiniteVertex.value:
|
|
363
|
+
message = "Non-finite vertex";
|
|
364
|
+
break;
|
|
365
|
+
case Module2.status.NotManifold.value:
|
|
366
|
+
message = "Not manifold";
|
|
367
|
+
break;
|
|
368
|
+
case Module2.status.VertexOutOfBounds.value:
|
|
369
|
+
message = "Vertex index out of bounds";
|
|
370
|
+
break;
|
|
371
|
+
case Module2.status.PropertiesWrongLength.value:
|
|
372
|
+
message = "Properties have wrong length";
|
|
373
|
+
break;
|
|
374
|
+
case Module2.status.MissingPositionProperties.value:
|
|
375
|
+
message = "Less than three properties";
|
|
376
|
+
break;
|
|
377
|
+
case Module2.status.MergeVectorsDifferentLengths.value:
|
|
378
|
+
message = "Merge vectors have different lengths";
|
|
379
|
+
break;
|
|
380
|
+
case Module2.status.MergeIndexOutOfBounds.value:
|
|
381
|
+
message = "Merge index out of bounds";
|
|
382
|
+
break;
|
|
383
|
+
case Module2.status.TransformWrongLength.value:
|
|
384
|
+
message = "Transform vector has wrong length";
|
|
385
|
+
break;
|
|
386
|
+
case Module2.status.RunIndexWrongLength.value:
|
|
387
|
+
message = "Run index vector has wrong length";
|
|
388
|
+
break;
|
|
389
|
+
case Module2.status.FaceIDWrongLength.value:
|
|
390
|
+
message = "Face ID vector has wrong length";
|
|
391
|
+
case Module2.status.InvalidConstruction.value:
|
|
392
|
+
message = "Manifold constructed with invalid parameters";
|
|
393
|
+
}
|
|
394
|
+
const base = Error.apply(this, [message, ...args]);
|
|
395
|
+
base.name = this.name = "ManifoldError";
|
|
396
|
+
this.message = base.message;
|
|
397
|
+
this.stack = base.stack;
|
|
398
|
+
this.code = code;
|
|
399
|
+
};
|
|
400
|
+
Module2.ManifoldError.prototype = Object.create(Error.prototype, {
|
|
401
|
+
constructor: { value: Module2.ManifoldError, writable: true, configurable: true }
|
|
402
|
+
});
|
|
403
|
+
Module2.CrossSection = function(polygons, fillRule = "Positive") {
|
|
404
|
+
const polygonsVec = polygons2vec(polygons);
|
|
405
|
+
const cs = new CrossSectionCtor(polygonsVec, fillRuleToInt(fillRule));
|
|
406
|
+
disposePolygons(polygonsVec);
|
|
407
|
+
return cs;
|
|
408
|
+
};
|
|
409
|
+
Module2.CrossSection.ofPolygons = function(polygons, fillRule = "Positive") {
|
|
410
|
+
return new Module2.CrossSection(polygons, fillRule);
|
|
411
|
+
};
|
|
412
|
+
Module2.CrossSection.square = function(...args) {
|
|
413
|
+
let size = void 0;
|
|
414
|
+
if (args.length == 0)
|
|
415
|
+
size = { x: 1, y: 1 };
|
|
416
|
+
else if (typeof args[0] == "number")
|
|
417
|
+
size = { x: args[0], y: args[0] };
|
|
418
|
+
else
|
|
419
|
+
size = vararg2vec2(args);
|
|
420
|
+
const center = args[1] || false;
|
|
421
|
+
return Module2._Square(size, center);
|
|
422
|
+
};
|
|
423
|
+
Module2.CrossSection.circle = function(radius, circularSegments = 0) {
|
|
424
|
+
return Module2._Circle(radius, circularSegments);
|
|
425
|
+
};
|
|
426
|
+
function crossSectionBatchbool(name) {
|
|
427
|
+
return function(...args) {
|
|
428
|
+
if (args.length == 1) args = args[0];
|
|
429
|
+
const v = new Module2.Vector_crossSection();
|
|
430
|
+
for (const cs of args) v.push_back(cross(cs));
|
|
431
|
+
const result = Module2["_crossSection" + name](v);
|
|
432
|
+
v.delete();
|
|
433
|
+
return result;
|
|
434
|
+
};
|
|
435
|
+
}
|
|
436
|
+
Module2.CrossSection.compose = crossSectionBatchbool("Compose");
|
|
437
|
+
Module2.CrossSection.union = crossSectionBatchbool("UnionN");
|
|
438
|
+
Module2.CrossSection.difference = crossSectionBatchbool("DifferenceN");
|
|
439
|
+
Module2.CrossSection.intersection = crossSectionBatchbool("IntersectionN");
|
|
440
|
+
function pushVec2(vec, ps) {
|
|
441
|
+
toVec(vec, ps, (p) => {
|
|
442
|
+
if (p instanceof Array) return { x: p[0], y: p[1] };
|
|
443
|
+
return p;
|
|
444
|
+
});
|
|
445
|
+
}
|
|
446
|
+
Module2.CrossSection.hull = function(...args) {
|
|
447
|
+
if (args.length == 1) args = args[0];
|
|
448
|
+
let pts = new Module2.Vector_vec2();
|
|
449
|
+
for (const cs of args) {
|
|
450
|
+
if (cs instanceof CrossSectionCtor) {
|
|
451
|
+
Module2._crossSectionCollectVertices(pts, cs);
|
|
452
|
+
} else if (cs instanceof Array && cs.length == 2 && typeof cs[0] == "number") {
|
|
453
|
+
pts.push_back({ x: cs[0], y: cs[1] });
|
|
454
|
+
} else if (cs.x) {
|
|
455
|
+
pts.push_back(cs);
|
|
456
|
+
} else {
|
|
457
|
+
const wrap = cs[0].length == 2 && typeof cs[0][0] == "number" || cs[0].x;
|
|
458
|
+
const polys = wrap ? [cs] : cs;
|
|
459
|
+
for (const poly of polys) pushVec2(pts, poly);
|
|
460
|
+
}
|
|
461
|
+
}
|
|
462
|
+
const result = Module2._crossSectionHullPoints(pts);
|
|
463
|
+
pts.delete();
|
|
464
|
+
return result;
|
|
465
|
+
};
|
|
466
|
+
Module2.CrossSection.prototype = Object.create(CrossSectionCtor.prototype);
|
|
467
|
+
Object.defineProperty(
|
|
468
|
+
Module2.CrossSection,
|
|
469
|
+
Symbol.hasInstance,
|
|
470
|
+
{ get: () => (t) => t instanceof CrossSectionCtor }
|
|
471
|
+
);
|
|
472
|
+
const ManifoldCtor = Module2.Manifold;
|
|
473
|
+
Module2.Manifold = function(mesh) {
|
|
474
|
+
const manifold = new ManifoldCtor(mesh);
|
|
475
|
+
const status = manifold.status();
|
|
476
|
+
if (status.value !== 0) {
|
|
477
|
+
throw new Module2.ManifoldError(status.value);
|
|
478
|
+
}
|
|
479
|
+
return manifold;
|
|
480
|
+
};
|
|
481
|
+
Module2.Manifold.ofMesh = function(mesh) {
|
|
482
|
+
return new Module2.Manifold(mesh);
|
|
483
|
+
};
|
|
484
|
+
Module2.Manifold.tetrahedron = function() {
|
|
485
|
+
return Module2._Tetrahedron();
|
|
486
|
+
};
|
|
487
|
+
Module2.Manifold.cube = function(...args) {
|
|
488
|
+
let size = void 0;
|
|
489
|
+
if (args.length == 0)
|
|
490
|
+
size = { x: 1, y: 1, z: 1 };
|
|
491
|
+
else if (typeof args[0] == "number")
|
|
492
|
+
size = { x: args[0], y: args[0], z: args[0] };
|
|
493
|
+
else
|
|
494
|
+
size = vararg2vec3(args);
|
|
495
|
+
const center = args[1] || false;
|
|
496
|
+
return Module2._Cube(size, center);
|
|
497
|
+
};
|
|
498
|
+
Module2.Manifold.cylinder = function(height, radiusLow, radiusHigh = -1, circularSegments = 0, center = false) {
|
|
499
|
+
return Module2._Cylinder(
|
|
500
|
+
height,
|
|
501
|
+
radiusLow,
|
|
502
|
+
radiusHigh,
|
|
503
|
+
circularSegments,
|
|
504
|
+
center
|
|
505
|
+
);
|
|
506
|
+
};
|
|
507
|
+
Module2.Manifold.sphere = function(radius, circularSegments = 0) {
|
|
508
|
+
return Module2._Sphere(radius, circularSegments);
|
|
509
|
+
};
|
|
510
|
+
Module2.Manifold.smooth = function(mesh, sharpenedEdges = []) {
|
|
511
|
+
const sharp = new Module2.Vector_smoothness();
|
|
512
|
+
toVec(sharp, sharpenedEdges);
|
|
513
|
+
const result = Module2._Smooth(mesh, sharp);
|
|
514
|
+
sharp.delete();
|
|
515
|
+
return result;
|
|
516
|
+
};
|
|
517
|
+
Module2.Manifold.extrude = function(polygons, height, nDivisions = 0, twistDegrees = 0, scaleTop = [1, 1], center = false) {
|
|
518
|
+
const cs = polygons instanceof CrossSectionCtor ? polygons : Module2.CrossSection(polygons, "Positive");
|
|
519
|
+
return cs.extrude(height, nDivisions, twistDegrees, scaleTop, center);
|
|
520
|
+
};
|
|
521
|
+
Module2.Manifold.revolve = function(polygons, circularSegments = 0, revolveDegrees = 360) {
|
|
522
|
+
const cs = polygons instanceof CrossSectionCtor ? polygons : Module2.CrossSection(polygons, "Positive");
|
|
523
|
+
return cs.revolve(circularSegments, revolveDegrees);
|
|
524
|
+
};
|
|
525
|
+
Module2.Manifold.reserveIDs = function(n) {
|
|
526
|
+
return Module2._ReserveIDs(n);
|
|
527
|
+
};
|
|
528
|
+
Module2.Manifold.compose = function(manifolds) {
|
|
529
|
+
const vec = new Module2.Vector_manifold();
|
|
530
|
+
toVec(vec, manifolds);
|
|
531
|
+
const result = Module2._manifoldCompose(vec);
|
|
532
|
+
vec.delete();
|
|
533
|
+
return result;
|
|
534
|
+
};
|
|
535
|
+
function manifoldBatchbool(name) {
|
|
536
|
+
return function(...args) {
|
|
537
|
+
if (args.length == 1) args = args[0];
|
|
538
|
+
const v = new Module2.Vector_manifold();
|
|
539
|
+
for (const m of args) v.push_back(m);
|
|
540
|
+
const result = Module2["_manifold" + name + "N"](v);
|
|
541
|
+
v.delete();
|
|
542
|
+
return result;
|
|
543
|
+
};
|
|
544
|
+
}
|
|
545
|
+
Module2.Manifold.union = manifoldBatchbool("Union");
|
|
546
|
+
Module2.Manifold.difference = manifoldBatchbool("Difference");
|
|
547
|
+
Module2.Manifold.intersection = manifoldBatchbool("Intersection");
|
|
548
|
+
Module2.Manifold.levelSet = function(sdf, bounds, edgeLength, level = 0, tolerance = -1) {
|
|
549
|
+
const bounds2 = {
|
|
550
|
+
min: { x: bounds.min[0], y: bounds.min[1], z: bounds.min[2] },
|
|
551
|
+
max: { x: bounds.max[0], y: bounds.max[1], z: bounds.max[2] }
|
|
552
|
+
};
|
|
553
|
+
const wasmFuncPtr = addFunction(function(vec3Ptr) {
|
|
554
|
+
const x = getValue(vec3Ptr, "double");
|
|
555
|
+
const y = getValue(vec3Ptr + 8, "double");
|
|
556
|
+
const z = getValue(vec3Ptr + 16, "double");
|
|
557
|
+
const vert = [x, y, z];
|
|
558
|
+
return sdf(vert);
|
|
559
|
+
}, "di");
|
|
560
|
+
const out = Module2._LevelSet(
|
|
561
|
+
wasmFuncPtr,
|
|
562
|
+
bounds2,
|
|
563
|
+
edgeLength,
|
|
564
|
+
level,
|
|
565
|
+
tolerance
|
|
566
|
+
);
|
|
567
|
+
removeFunction(wasmFuncPtr);
|
|
568
|
+
return out;
|
|
569
|
+
};
|
|
570
|
+
function pushVec3(vec, ps) {
|
|
571
|
+
toVec(vec, ps, (p) => {
|
|
572
|
+
if (p instanceof Array) return { x: p[0], y: p[1], z: p[2] };
|
|
573
|
+
return p;
|
|
574
|
+
});
|
|
575
|
+
}
|
|
576
|
+
Module2.Manifold.hull = function(...args) {
|
|
577
|
+
if (args.length == 1) args = args[0];
|
|
578
|
+
let pts = new Module2.Vector_vec3();
|
|
579
|
+
for (const m of args) {
|
|
580
|
+
if (m instanceof ManifoldCtor) {
|
|
581
|
+
Module2._manifoldCollectVertices(pts, m);
|
|
582
|
+
} else if (m instanceof Array && m.length == 3 && typeof m[0] == "number") {
|
|
583
|
+
pts.push_back({ x: m[0], y: m[1], z: m[2] });
|
|
584
|
+
} else if (m.x) {
|
|
585
|
+
pts.push_back(m);
|
|
586
|
+
} else {
|
|
587
|
+
pushVec3(pts, m);
|
|
588
|
+
}
|
|
589
|
+
}
|
|
590
|
+
const result = Module2._manifoldHullPoints(pts);
|
|
591
|
+
pts.delete();
|
|
592
|
+
return result;
|
|
593
|
+
};
|
|
594
|
+
Module2.Manifold.prototype = Object.create(ManifoldCtor.prototype);
|
|
595
|
+
Object.defineProperty(
|
|
596
|
+
Module2.Manifold,
|
|
597
|
+
Symbol.hasInstance,
|
|
598
|
+
{ get: () => (t) => t instanceof ManifoldCtor }
|
|
599
|
+
);
|
|
600
|
+
Module2.triangulate = function(polygons, epsilon = -1, allowConvex = true) {
|
|
601
|
+
const polygonsVec = polygons2vec(polygons);
|
|
602
|
+
const result = fromVec(
|
|
603
|
+
Module2._Triangulate(polygonsVec, epsilon, allowConvex),
|
|
604
|
+
(x) => [x[0], x[1], x[2]]
|
|
605
|
+
);
|
|
606
|
+
disposePolygons(polygonsVec);
|
|
607
|
+
return result;
|
|
608
|
+
};
|
|
609
|
+
};
|
|
610
|
+
var moduleOverrides = { ...Module2 };
|
|
611
|
+
var scriptDirectory = "";
|
|
612
|
+
function locateFile(path) {
|
|
613
|
+
if (Module2["locateFile"]) {
|
|
614
|
+
return Module2["locateFile"](path, scriptDirectory);
|
|
615
|
+
}
|
|
616
|
+
return scriptDirectory + path;
|
|
617
|
+
}
|
|
618
|
+
var readAsync, readBinary;
|
|
619
|
+
if (ENVIRONMENT_IS_NODE) {
|
|
620
|
+
var fs = require2("fs");
|
|
621
|
+
var nodePath = require2("path");
|
|
622
|
+
if (!import.meta.url.startsWith("data:")) {
|
|
623
|
+
scriptDirectory = nodePath.dirname(require2("url").fileURLToPath(import.meta.url)) + "/";
|
|
624
|
+
}
|
|
625
|
+
readBinary = (filename) => {
|
|
626
|
+
filename = isFileURI(filename) ? new URL(filename) : filename;
|
|
627
|
+
var ret = fs.readFileSync(filename);
|
|
628
|
+
return ret;
|
|
629
|
+
};
|
|
630
|
+
readAsync = async (filename, binary = true) => {
|
|
631
|
+
filename = isFileURI(filename) ? new URL(filename) : filename;
|
|
632
|
+
var ret = fs.readFileSync(filename, binary ? void 0 : "utf8");
|
|
633
|
+
return ret;
|
|
634
|
+
};
|
|
635
|
+
if (!Module2["thisProgram"] && process.argv.length > 1) {
|
|
636
|
+
process.argv[1].replace(/\\/g, "/");
|
|
637
|
+
}
|
|
638
|
+
process.argv.slice(2);
|
|
639
|
+
} else if (ENVIRONMENT_IS_WEB || ENVIRONMENT_IS_WORKER) {
|
|
640
|
+
if (ENVIRONMENT_IS_WORKER) {
|
|
641
|
+
scriptDirectory = self.location.href;
|
|
642
|
+
} else if (typeof document != "undefined" && document.currentScript) {
|
|
643
|
+
scriptDirectory = document.currentScript.src;
|
|
644
|
+
}
|
|
645
|
+
if (_scriptName) {
|
|
646
|
+
scriptDirectory = _scriptName;
|
|
647
|
+
}
|
|
648
|
+
if (scriptDirectory.startsWith("blob:")) {
|
|
649
|
+
scriptDirectory = "";
|
|
650
|
+
} else {
|
|
651
|
+
scriptDirectory = scriptDirectory.slice(
|
|
652
|
+
0,
|
|
653
|
+
scriptDirectory.replace(/[?#].*/, "").lastIndexOf("/") + 1
|
|
654
|
+
);
|
|
655
|
+
}
|
|
656
|
+
{
|
|
657
|
+
if (ENVIRONMENT_IS_WORKER) {
|
|
658
|
+
readBinary = (url) => {
|
|
659
|
+
var xhr = new XMLHttpRequest();
|
|
660
|
+
xhr.open("GET", url, false);
|
|
661
|
+
xhr.responseType = "arraybuffer";
|
|
662
|
+
xhr.send(null);
|
|
663
|
+
return new Uint8Array(xhr.response);
|
|
664
|
+
};
|
|
665
|
+
}
|
|
666
|
+
readAsync = async (url) => {
|
|
667
|
+
if (isFileURI(url)) {
|
|
668
|
+
return new Promise((resolve, reject) => {
|
|
669
|
+
var xhr = new XMLHttpRequest();
|
|
670
|
+
xhr.open("GET", url, true);
|
|
671
|
+
xhr.responseType = "arraybuffer";
|
|
672
|
+
xhr.onload = () => {
|
|
673
|
+
if (xhr.status == 200 || xhr.status == 0 && xhr.response) {
|
|
674
|
+
resolve(xhr.response);
|
|
675
|
+
return;
|
|
676
|
+
}
|
|
677
|
+
reject(xhr.status);
|
|
678
|
+
};
|
|
679
|
+
xhr.onerror = reject;
|
|
680
|
+
xhr.send(null);
|
|
681
|
+
});
|
|
682
|
+
}
|
|
683
|
+
var response = await fetch(url, { credentials: "same-origin" });
|
|
684
|
+
if (response.ok) {
|
|
685
|
+
return response.arrayBuffer();
|
|
686
|
+
}
|
|
687
|
+
throw new Error(response.status + " : " + response.url);
|
|
688
|
+
};
|
|
689
|
+
}
|
|
690
|
+
} else ;
|
|
691
|
+
Module2["print"] || console.log.bind(console);
|
|
692
|
+
var err = Module2["printErr"] || console.error.bind(console);
|
|
693
|
+
Object.assign(Module2, moduleOverrides);
|
|
694
|
+
moduleOverrides = null;
|
|
695
|
+
if (Module2["arguments"]) Module2["arguments"];
|
|
696
|
+
if (Module2["thisProgram"]) Module2["thisProgram"];
|
|
697
|
+
var wasmBinary = Module2["wasmBinary"];
|
|
698
|
+
var wasmMemory;
|
|
699
|
+
var ABORT = false;
|
|
700
|
+
var HEAP8, HEAPU8, HEAP16, HEAPU16, HEAP32, HEAPU32, HEAPF32, HEAP64, HEAPU64, HEAPF64;
|
|
701
|
+
var isFileURI = (filename) => filename.startsWith("file://");
|
|
702
|
+
function updateMemoryViews() {
|
|
703
|
+
var b = wasmMemory.buffer;
|
|
704
|
+
Module2["HEAP8"] = HEAP8 = new Int8Array(b);
|
|
705
|
+
Module2["HEAP16"] = HEAP16 = new Int16Array(b);
|
|
706
|
+
Module2["HEAPU8"] = HEAPU8 = new Uint8Array(b);
|
|
707
|
+
Module2["HEAPU16"] = HEAPU16 = new Uint16Array(b);
|
|
708
|
+
Module2["HEAP32"] = HEAP32 = new Int32Array(b);
|
|
709
|
+
Module2["HEAPU32"] = HEAPU32 = new Uint32Array(b);
|
|
710
|
+
Module2["HEAPF32"] = HEAPF32 = new Float32Array(b);
|
|
711
|
+
Module2["HEAPF64"] = HEAPF64 = new Float64Array(b);
|
|
712
|
+
Module2["HEAP64"] = HEAP64 = new BigInt64Array(b);
|
|
713
|
+
Module2["HEAPU64"] = HEAPU64 = new BigUint64Array(b);
|
|
714
|
+
}
|
|
715
|
+
function preRun() {
|
|
716
|
+
if (Module2["preRun"]) {
|
|
717
|
+
if (typeof Module2["preRun"] == "function")
|
|
718
|
+
Module2["preRun"] = [Module2["preRun"]];
|
|
719
|
+
while (Module2["preRun"].length) {
|
|
720
|
+
addOnPreRun(Module2["preRun"].shift());
|
|
721
|
+
}
|
|
722
|
+
}
|
|
723
|
+
callRuntimeCallbacks(onPreRuns);
|
|
724
|
+
}
|
|
725
|
+
function initRuntime() {
|
|
726
|
+
wasmExports["J"]();
|
|
727
|
+
}
|
|
728
|
+
function postRun() {
|
|
729
|
+
if (Module2["postRun"]) {
|
|
730
|
+
if (typeof Module2["postRun"] == "function")
|
|
731
|
+
Module2["postRun"] = [Module2["postRun"]];
|
|
732
|
+
while (Module2["postRun"].length) {
|
|
733
|
+
addOnPostRun(Module2["postRun"].shift());
|
|
734
|
+
}
|
|
735
|
+
}
|
|
736
|
+
callRuntimeCallbacks(onPostRuns);
|
|
737
|
+
}
|
|
738
|
+
var runDependencies = 0;
|
|
739
|
+
var dependenciesFulfilled = null;
|
|
740
|
+
function addRunDependency(id) {
|
|
741
|
+
var _a;
|
|
742
|
+
runDependencies++;
|
|
743
|
+
(_a = Module2["monitorRunDependencies"]) == null ? void 0 : _a.call(Module2, runDependencies);
|
|
744
|
+
}
|
|
745
|
+
function removeRunDependency(id) {
|
|
746
|
+
var _a;
|
|
747
|
+
runDependencies--;
|
|
748
|
+
(_a = Module2["monitorRunDependencies"]) == null ? void 0 : _a.call(Module2, runDependencies);
|
|
749
|
+
if (runDependencies == 0) {
|
|
750
|
+
if (dependenciesFulfilled) {
|
|
751
|
+
var callback = dependenciesFulfilled;
|
|
752
|
+
dependenciesFulfilled = null;
|
|
753
|
+
callback();
|
|
754
|
+
}
|
|
755
|
+
}
|
|
756
|
+
}
|
|
757
|
+
function abort(what) {
|
|
758
|
+
var _a;
|
|
759
|
+
(_a = Module2["onAbort"]) == null ? void 0 : _a.call(Module2, what);
|
|
760
|
+
what = "Aborted(" + what + ")";
|
|
761
|
+
err(what);
|
|
762
|
+
ABORT = true;
|
|
763
|
+
what += ". Build with -sASSERTIONS for more info.";
|
|
764
|
+
var e = new WebAssembly.RuntimeError(what);
|
|
765
|
+
readyPromiseReject(e);
|
|
766
|
+
throw e;
|
|
767
|
+
}
|
|
768
|
+
var wasmBinaryFile;
|
|
769
|
+
function findWasmBinary() {
|
|
770
|
+
if (Module2["locateFile"]) {
|
|
771
|
+
return locateFile("manifold.wasm");
|
|
772
|
+
}
|
|
773
|
+
return new URL("/assets/manifold-C44_QbND.wasm", import.meta.url).href;
|
|
774
|
+
}
|
|
775
|
+
function getBinarySync(file) {
|
|
776
|
+
if (file == wasmBinaryFile && wasmBinary) {
|
|
777
|
+
return new Uint8Array(wasmBinary);
|
|
778
|
+
}
|
|
779
|
+
if (readBinary) {
|
|
780
|
+
return readBinary(file);
|
|
781
|
+
}
|
|
782
|
+
throw "both async and sync fetching of the wasm failed";
|
|
783
|
+
}
|
|
784
|
+
async function getWasmBinary(binaryFile) {
|
|
785
|
+
if (!wasmBinary) {
|
|
786
|
+
try {
|
|
787
|
+
var response = await readAsync(binaryFile);
|
|
788
|
+
return new Uint8Array(response);
|
|
789
|
+
} catch {
|
|
790
|
+
}
|
|
791
|
+
}
|
|
792
|
+
return getBinarySync(binaryFile);
|
|
793
|
+
}
|
|
794
|
+
async function instantiateArrayBuffer(binaryFile, imports) {
|
|
795
|
+
try {
|
|
796
|
+
var binary = await getWasmBinary(binaryFile);
|
|
797
|
+
var instance = await WebAssembly.instantiate(binary, imports);
|
|
798
|
+
return instance;
|
|
799
|
+
} catch (reason) {
|
|
800
|
+
err(`failed to asynchronously prepare wasm: ${reason}`);
|
|
801
|
+
abort(reason);
|
|
802
|
+
}
|
|
803
|
+
}
|
|
804
|
+
async function instantiateAsync(binary, binaryFile, imports) {
|
|
805
|
+
if (!binary && typeof WebAssembly.instantiateStreaming == "function" && !isFileURI(binaryFile) && !ENVIRONMENT_IS_NODE) {
|
|
806
|
+
try {
|
|
807
|
+
var response = fetch(binaryFile, { credentials: "same-origin" });
|
|
808
|
+
var instantiationResult = await WebAssembly.instantiateStreaming(response, imports);
|
|
809
|
+
return instantiationResult;
|
|
810
|
+
} catch (reason) {
|
|
811
|
+
err(`wasm streaming compile failed: ${reason}`);
|
|
812
|
+
err("falling back to ArrayBuffer instantiation");
|
|
813
|
+
}
|
|
814
|
+
}
|
|
815
|
+
return instantiateArrayBuffer(binaryFile, imports);
|
|
816
|
+
}
|
|
817
|
+
function getWasmImports() {
|
|
818
|
+
return {
|
|
819
|
+
a: wasmImports
|
|
820
|
+
};
|
|
821
|
+
}
|
|
822
|
+
async function createWasm() {
|
|
823
|
+
function receiveInstance(instance, module) {
|
|
824
|
+
wasmExports = instance.exports;
|
|
825
|
+
wasmExports = applySignatureConversions(wasmExports);
|
|
826
|
+
wasmMemory = wasmExports["I"];
|
|
827
|
+
updateMemoryViews();
|
|
828
|
+
wasmTable = wasmExports["L"];
|
|
829
|
+
removeRunDependency();
|
|
830
|
+
return wasmExports;
|
|
831
|
+
}
|
|
832
|
+
addRunDependency();
|
|
833
|
+
function receiveInstantiationResult(result2) {
|
|
834
|
+
return receiveInstance(result2["instance"]);
|
|
835
|
+
}
|
|
836
|
+
var info = getWasmImports();
|
|
837
|
+
if (Module2["instantiateWasm"]) {
|
|
838
|
+
return new Promise(
|
|
839
|
+
(resolve, reject) => {
|
|
840
|
+
Module2["instantiateWasm"](info, (mod, inst) => {
|
|
841
|
+
receiveInstance(mod);
|
|
842
|
+
resolve(mod.exports);
|
|
843
|
+
});
|
|
844
|
+
}
|
|
845
|
+
);
|
|
846
|
+
}
|
|
847
|
+
wasmBinaryFile ?? (wasmBinaryFile = findWasmBinary());
|
|
848
|
+
try {
|
|
849
|
+
var result = await instantiateAsync(wasmBinary, wasmBinaryFile, info);
|
|
850
|
+
var exports$1 = receiveInstantiationResult(result);
|
|
851
|
+
return exports$1;
|
|
852
|
+
} catch (e) {
|
|
853
|
+
readyPromiseReject(e);
|
|
854
|
+
return Promise.reject(e);
|
|
855
|
+
}
|
|
856
|
+
}
|
|
857
|
+
var callRuntimeCallbacks = (callbacks) => {
|
|
858
|
+
while (callbacks.length > 0) {
|
|
859
|
+
callbacks.shift()(Module2);
|
|
860
|
+
}
|
|
861
|
+
};
|
|
862
|
+
var onPostRuns = [];
|
|
863
|
+
var addOnPostRun = (cb) => onPostRuns.unshift(cb);
|
|
864
|
+
var onPreRuns = [];
|
|
865
|
+
var addOnPreRun = (cb) => onPreRuns.unshift(cb);
|
|
866
|
+
function getValue(ptr, type = "i8") {
|
|
867
|
+
if (type.endsWith("*")) type = "*";
|
|
868
|
+
switch (type) {
|
|
869
|
+
case "i1":
|
|
870
|
+
return HEAP8[ptr >>> 0];
|
|
871
|
+
case "i8":
|
|
872
|
+
return HEAP8[ptr >>> 0];
|
|
873
|
+
case "i16":
|
|
874
|
+
return HEAP16[ptr >>> 1 >>> 0];
|
|
875
|
+
case "i32":
|
|
876
|
+
return HEAP32[ptr >>> 2 >>> 0];
|
|
877
|
+
case "i64":
|
|
878
|
+
return HEAP64[ptr >>> 3];
|
|
879
|
+
case "float":
|
|
880
|
+
return HEAPF32[ptr >>> 2 >>> 0];
|
|
881
|
+
case "double":
|
|
882
|
+
return HEAPF64[ptr >>> 3 >>> 0];
|
|
883
|
+
case "*":
|
|
884
|
+
return HEAPU32[ptr >>> 2 >>> 0];
|
|
885
|
+
default:
|
|
886
|
+
abort(`invalid type for getValue: ${type}`);
|
|
887
|
+
}
|
|
888
|
+
}
|
|
889
|
+
Module2["noExitRuntime"] || true;
|
|
890
|
+
function setValue(ptr, value, type = "i8") {
|
|
891
|
+
if (type.endsWith("*")) type = "*";
|
|
892
|
+
switch (type) {
|
|
893
|
+
case "i1":
|
|
894
|
+
HEAP8[ptr >>> 0] = value;
|
|
895
|
+
break;
|
|
896
|
+
case "i8":
|
|
897
|
+
HEAP8[ptr >>> 0] = value;
|
|
898
|
+
break;
|
|
899
|
+
case "i16":
|
|
900
|
+
HEAP16[ptr >>> 1 >>> 0] = value;
|
|
901
|
+
break;
|
|
902
|
+
case "i32":
|
|
903
|
+
HEAP32[ptr >>> 2 >>> 0] = value;
|
|
904
|
+
break;
|
|
905
|
+
case "i64":
|
|
906
|
+
HEAP64[ptr >>> 3] = BigInt(value);
|
|
907
|
+
break;
|
|
908
|
+
case "float":
|
|
909
|
+
HEAPF32[ptr >>> 2 >>> 0] = value;
|
|
910
|
+
break;
|
|
911
|
+
case "double":
|
|
912
|
+
HEAPF64[ptr >>> 3 >>> 0] = value;
|
|
913
|
+
break;
|
|
914
|
+
case "*":
|
|
915
|
+
HEAPU32[ptr >>> 2 >>> 0] = value;
|
|
916
|
+
break;
|
|
917
|
+
default:
|
|
918
|
+
abort(`invalid type for setValue: ${type}`);
|
|
919
|
+
}
|
|
920
|
+
}
|
|
921
|
+
class ExceptionInfo {
|
|
922
|
+
constructor(excPtr) {
|
|
923
|
+
this.excPtr = excPtr;
|
|
924
|
+
this.ptr = excPtr - 24;
|
|
925
|
+
}
|
|
926
|
+
set_type(type) {
|
|
927
|
+
HEAPU32[this.ptr + 4 >>> 2 >>> 0] = type;
|
|
928
|
+
}
|
|
929
|
+
get_type() {
|
|
930
|
+
return HEAPU32[this.ptr + 4 >>> 2 >>> 0];
|
|
931
|
+
}
|
|
932
|
+
set_destructor(destructor) {
|
|
933
|
+
HEAPU32[this.ptr + 8 >>> 2 >>> 0] = destructor;
|
|
934
|
+
}
|
|
935
|
+
get_destructor() {
|
|
936
|
+
return HEAPU32[this.ptr + 8 >>> 2 >>> 0];
|
|
937
|
+
}
|
|
938
|
+
set_caught(caught) {
|
|
939
|
+
caught = caught ? 1 : 0;
|
|
940
|
+
HEAP8[this.ptr + 12 >>> 0] = caught;
|
|
941
|
+
}
|
|
942
|
+
get_caught() {
|
|
943
|
+
return HEAP8[this.ptr + 12 >>> 0] != 0;
|
|
944
|
+
}
|
|
945
|
+
set_rethrown(rethrown) {
|
|
946
|
+
rethrown = rethrown ? 1 : 0;
|
|
947
|
+
HEAP8[this.ptr + 13 >>> 0] = rethrown;
|
|
948
|
+
}
|
|
949
|
+
get_rethrown() {
|
|
950
|
+
return HEAP8[this.ptr + 13 >>> 0] != 0;
|
|
951
|
+
}
|
|
952
|
+
init(type, destructor) {
|
|
953
|
+
this.set_adjusted_ptr(0);
|
|
954
|
+
this.set_type(type);
|
|
955
|
+
this.set_destructor(destructor);
|
|
956
|
+
}
|
|
957
|
+
set_adjusted_ptr(adjustedPtr) {
|
|
958
|
+
HEAPU32[this.ptr + 16 >>> 2 >>> 0] = adjustedPtr;
|
|
959
|
+
}
|
|
960
|
+
get_adjusted_ptr() {
|
|
961
|
+
return HEAPU32[this.ptr + 16 >>> 2 >>> 0];
|
|
962
|
+
}
|
|
963
|
+
}
|
|
964
|
+
var exceptionLast = 0;
|
|
965
|
+
function ___cxa_throw(ptr, type, destructor) {
|
|
966
|
+
ptr >>>= 0;
|
|
967
|
+
type >>>= 0;
|
|
968
|
+
destructor >>>= 0;
|
|
969
|
+
var info = new ExceptionInfo(ptr);
|
|
970
|
+
info.init(type, destructor);
|
|
971
|
+
exceptionLast = ptr;
|
|
972
|
+
throw exceptionLast;
|
|
973
|
+
}
|
|
974
|
+
var __abort_js = () => abort("");
|
|
975
|
+
var structRegistrations = {};
|
|
976
|
+
var runDestructors = (destructors) => {
|
|
977
|
+
while (destructors.length) {
|
|
978
|
+
var ptr = destructors.pop();
|
|
979
|
+
var del = destructors.pop();
|
|
980
|
+
del(ptr);
|
|
981
|
+
}
|
|
982
|
+
};
|
|
983
|
+
function readPointer(pointer) {
|
|
984
|
+
return this["fromWireType"](HEAPU32[pointer >>> 2 >>> 0]);
|
|
985
|
+
}
|
|
986
|
+
var awaitingDependencies = {};
|
|
987
|
+
var registeredTypes = {};
|
|
988
|
+
var typeDependencies = {};
|
|
989
|
+
var InternalError = Module2["InternalError"] = class InternalError extends Error {
|
|
990
|
+
constructor(message) {
|
|
991
|
+
super(message);
|
|
992
|
+
this.name = "InternalError";
|
|
993
|
+
}
|
|
994
|
+
};
|
|
995
|
+
var throwInternalError = (message) => {
|
|
996
|
+
throw new InternalError(message);
|
|
997
|
+
};
|
|
998
|
+
var whenDependentTypesAreResolved = (myTypes, dependentTypes, getTypeConverters) => {
|
|
999
|
+
myTypes.forEach((type) => typeDependencies[type] = dependentTypes);
|
|
1000
|
+
function onComplete(typeConverters2) {
|
|
1001
|
+
var myTypeConverters = getTypeConverters(typeConverters2);
|
|
1002
|
+
if (myTypeConverters.length !== myTypes.length) {
|
|
1003
|
+
throwInternalError("Mismatched type converter count");
|
|
1004
|
+
}
|
|
1005
|
+
for (var i = 0; i < myTypes.length; ++i) {
|
|
1006
|
+
registerType(myTypes[i], myTypeConverters[i]);
|
|
1007
|
+
}
|
|
1008
|
+
}
|
|
1009
|
+
var typeConverters = new Array(dependentTypes.length);
|
|
1010
|
+
var unregisteredTypes = [];
|
|
1011
|
+
var registered = 0;
|
|
1012
|
+
dependentTypes.forEach((dt, i) => {
|
|
1013
|
+
if (registeredTypes.hasOwnProperty(dt)) {
|
|
1014
|
+
typeConverters[i] = registeredTypes[dt];
|
|
1015
|
+
} else {
|
|
1016
|
+
unregisteredTypes.push(dt);
|
|
1017
|
+
if (!awaitingDependencies.hasOwnProperty(dt)) {
|
|
1018
|
+
awaitingDependencies[dt] = [];
|
|
1019
|
+
}
|
|
1020
|
+
awaitingDependencies[dt].push(() => {
|
|
1021
|
+
typeConverters[i] = registeredTypes[dt];
|
|
1022
|
+
++registered;
|
|
1023
|
+
if (registered === unregisteredTypes.length) {
|
|
1024
|
+
onComplete(typeConverters);
|
|
1025
|
+
}
|
|
1026
|
+
});
|
|
1027
|
+
}
|
|
1028
|
+
});
|
|
1029
|
+
if (0 === unregisteredTypes.length) {
|
|
1030
|
+
onComplete(typeConverters);
|
|
1031
|
+
}
|
|
1032
|
+
};
|
|
1033
|
+
var __embind_finalize_value_object = function(structType) {
|
|
1034
|
+
structType >>>= 0;
|
|
1035
|
+
var reg = structRegistrations[structType];
|
|
1036
|
+
delete structRegistrations[structType];
|
|
1037
|
+
var rawConstructor = reg.rawConstructor;
|
|
1038
|
+
var rawDestructor = reg.rawDestructor;
|
|
1039
|
+
var fieldRecords = reg.fields;
|
|
1040
|
+
var fieldTypes = fieldRecords.map((field) => field.getterReturnType).concat(fieldRecords.map((field) => field.setterArgumentType));
|
|
1041
|
+
whenDependentTypesAreResolved([structType], fieldTypes, (fieldTypes2) => {
|
|
1042
|
+
var fields = {};
|
|
1043
|
+
fieldRecords.forEach((field, i) => {
|
|
1044
|
+
var fieldName = field.fieldName;
|
|
1045
|
+
var getterReturnType = fieldTypes2[i];
|
|
1046
|
+
var optional = fieldTypes2[i].optional;
|
|
1047
|
+
var getter = field.getter;
|
|
1048
|
+
var getterContext = field.getterContext;
|
|
1049
|
+
var setterArgumentType = fieldTypes2[i + fieldRecords.length];
|
|
1050
|
+
var setter = field.setter;
|
|
1051
|
+
var setterContext = field.setterContext;
|
|
1052
|
+
fields[fieldName] = {
|
|
1053
|
+
read: (ptr) => getterReturnType["fromWireType"](getter(getterContext, ptr)),
|
|
1054
|
+
write: (ptr, o) => {
|
|
1055
|
+
var destructors = [];
|
|
1056
|
+
setter(
|
|
1057
|
+
setterContext,
|
|
1058
|
+
ptr,
|
|
1059
|
+
setterArgumentType["toWireType"](destructors, o)
|
|
1060
|
+
);
|
|
1061
|
+
runDestructors(destructors);
|
|
1062
|
+
},
|
|
1063
|
+
optional
|
|
1064
|
+
};
|
|
1065
|
+
});
|
|
1066
|
+
return [{
|
|
1067
|
+
name: reg.name,
|
|
1068
|
+
fromWireType: (ptr) => {
|
|
1069
|
+
var rv = {};
|
|
1070
|
+
for (var i in fields) {
|
|
1071
|
+
rv[i] = fields[i].read(ptr);
|
|
1072
|
+
}
|
|
1073
|
+
rawDestructor(ptr);
|
|
1074
|
+
return rv;
|
|
1075
|
+
},
|
|
1076
|
+
toWireType: (destructors, o) => {
|
|
1077
|
+
for (var fieldName in fields) {
|
|
1078
|
+
if (!(fieldName in o) && !fields[fieldName].optional) {
|
|
1079
|
+
throw new TypeError(`Missing field: "${fieldName}"`);
|
|
1080
|
+
}
|
|
1081
|
+
}
|
|
1082
|
+
var ptr = rawConstructor();
|
|
1083
|
+
for (fieldName in fields) {
|
|
1084
|
+
fields[fieldName].write(ptr, o[fieldName]);
|
|
1085
|
+
}
|
|
1086
|
+
if (destructors !== null) {
|
|
1087
|
+
destructors.push(rawDestructor, ptr);
|
|
1088
|
+
}
|
|
1089
|
+
return ptr;
|
|
1090
|
+
},
|
|
1091
|
+
argPackAdvance: GenericWireTypeSize,
|
|
1092
|
+
readValueFromPointer: readPointer,
|
|
1093
|
+
destructorFunction: rawDestructor
|
|
1094
|
+
}];
|
|
1095
|
+
});
|
|
1096
|
+
};
|
|
1097
|
+
var embindRepr = (v) => {
|
|
1098
|
+
if (v === null) {
|
|
1099
|
+
return "null";
|
|
1100
|
+
}
|
|
1101
|
+
var t = typeof v;
|
|
1102
|
+
if (t === "object" || t === "array" || t === "function") {
|
|
1103
|
+
return v.toString();
|
|
1104
|
+
} else {
|
|
1105
|
+
return "" + v;
|
|
1106
|
+
}
|
|
1107
|
+
};
|
|
1108
|
+
var embind_init_charCodes = () => {
|
|
1109
|
+
var codes = new Array(256);
|
|
1110
|
+
for (var i = 0; i < 256; ++i) {
|
|
1111
|
+
codes[i] = String.fromCharCode(i);
|
|
1112
|
+
}
|
|
1113
|
+
embind_charCodes = codes;
|
|
1114
|
+
};
|
|
1115
|
+
var embind_charCodes;
|
|
1116
|
+
var readLatin1String = (ptr) => {
|
|
1117
|
+
var ret = "";
|
|
1118
|
+
var c = ptr;
|
|
1119
|
+
while (HEAPU8[c >>> 0]) {
|
|
1120
|
+
ret += embind_charCodes[HEAPU8[c++ >>> 0]];
|
|
1121
|
+
}
|
|
1122
|
+
return ret;
|
|
1123
|
+
};
|
|
1124
|
+
var BindingError = Module2["BindingError"] = class BindingError extends Error {
|
|
1125
|
+
constructor(message) {
|
|
1126
|
+
super(message);
|
|
1127
|
+
this.name = "BindingError";
|
|
1128
|
+
}
|
|
1129
|
+
};
|
|
1130
|
+
var throwBindingError = (message) => {
|
|
1131
|
+
throw new BindingError(message);
|
|
1132
|
+
};
|
|
1133
|
+
function sharedRegisterType(rawType, registeredInstance, options = {}) {
|
|
1134
|
+
var name = registeredInstance.name;
|
|
1135
|
+
if (!rawType) {
|
|
1136
|
+
throwBindingError(
|
|
1137
|
+
`type "${name}" must have a positive integer typeid pointer`
|
|
1138
|
+
);
|
|
1139
|
+
}
|
|
1140
|
+
if (registeredTypes.hasOwnProperty(rawType)) {
|
|
1141
|
+
if (options.ignoreDuplicateRegistrations) {
|
|
1142
|
+
return;
|
|
1143
|
+
} else {
|
|
1144
|
+
throwBindingError(`Cannot register type '${name}' twice`);
|
|
1145
|
+
}
|
|
1146
|
+
}
|
|
1147
|
+
registeredTypes[rawType] = registeredInstance;
|
|
1148
|
+
delete typeDependencies[rawType];
|
|
1149
|
+
if (awaitingDependencies.hasOwnProperty(rawType)) {
|
|
1150
|
+
var callbacks = awaitingDependencies[rawType];
|
|
1151
|
+
delete awaitingDependencies[rawType];
|
|
1152
|
+
callbacks.forEach((cb) => cb());
|
|
1153
|
+
}
|
|
1154
|
+
}
|
|
1155
|
+
function registerType(rawType, registeredInstance, options = {}) {
|
|
1156
|
+
return sharedRegisterType(rawType, registeredInstance, options);
|
|
1157
|
+
}
|
|
1158
|
+
var integerReadValueFromPointer = (name, width, signed) => {
|
|
1159
|
+
switch (width) {
|
|
1160
|
+
case 1:
|
|
1161
|
+
return signed ? (pointer) => HEAP8[pointer >>> 0] : (pointer) => HEAPU8[pointer >>> 0];
|
|
1162
|
+
case 2:
|
|
1163
|
+
return signed ? (pointer) => HEAP16[pointer >>> 1 >>> 0] : (pointer) => HEAPU16[pointer >>> 1 >>> 0];
|
|
1164
|
+
case 4:
|
|
1165
|
+
return signed ? (pointer) => HEAP32[pointer >>> 2 >>> 0] : (pointer) => HEAPU32[pointer >>> 2 >>> 0];
|
|
1166
|
+
case 8:
|
|
1167
|
+
return signed ? (pointer) => HEAP64[pointer >>> 3] : (pointer) => HEAPU64[pointer >>> 3];
|
|
1168
|
+
default:
|
|
1169
|
+
throw new TypeError(`invalid integer width (${width}): ${name}`);
|
|
1170
|
+
}
|
|
1171
|
+
};
|
|
1172
|
+
function __embind_register_bigint(primitiveType, name, size, minRange, maxRange) {
|
|
1173
|
+
primitiveType >>>= 0;
|
|
1174
|
+
name >>>= 0;
|
|
1175
|
+
size >>>= 0;
|
|
1176
|
+
name = readLatin1String(name);
|
|
1177
|
+
var isUnsignedType = name.indexOf("u") != -1;
|
|
1178
|
+
registerType(primitiveType, {
|
|
1179
|
+
name,
|
|
1180
|
+
fromWireType: (value) => value,
|
|
1181
|
+
toWireType: function(destructors, value) {
|
|
1182
|
+
if (typeof value != "bigint" && typeof value != "number") {
|
|
1183
|
+
throw new TypeError(
|
|
1184
|
+
`Cannot convert "${embindRepr(value)}" to ${this.name}`
|
|
1185
|
+
);
|
|
1186
|
+
}
|
|
1187
|
+
if (typeof value == "number") {
|
|
1188
|
+
value = BigInt(value);
|
|
1189
|
+
}
|
|
1190
|
+
return value;
|
|
1191
|
+
},
|
|
1192
|
+
argPackAdvance: GenericWireTypeSize,
|
|
1193
|
+
readValueFromPointer: integerReadValueFromPointer(name, size, !isUnsignedType),
|
|
1194
|
+
destructorFunction: null
|
|
1195
|
+
});
|
|
1196
|
+
}
|
|
1197
|
+
var GenericWireTypeSize = 8;
|
|
1198
|
+
function __embind_register_bool(rawType, name, trueValue, falseValue) {
|
|
1199
|
+
rawType >>>= 0;
|
|
1200
|
+
name >>>= 0;
|
|
1201
|
+
name = readLatin1String(name);
|
|
1202
|
+
registerType(rawType, {
|
|
1203
|
+
name,
|
|
1204
|
+
fromWireType: function(wt) {
|
|
1205
|
+
return !!wt;
|
|
1206
|
+
},
|
|
1207
|
+
toWireType: function(destructors, o) {
|
|
1208
|
+
return o ? trueValue : falseValue;
|
|
1209
|
+
},
|
|
1210
|
+
argPackAdvance: GenericWireTypeSize,
|
|
1211
|
+
readValueFromPointer: function(pointer) {
|
|
1212
|
+
return this["fromWireType"](HEAPU8[pointer >>> 0]);
|
|
1213
|
+
},
|
|
1214
|
+
destructorFunction: null
|
|
1215
|
+
});
|
|
1216
|
+
}
|
|
1217
|
+
var shallowCopyInternalPointer = (o) => ({
|
|
1218
|
+
count: o.count,
|
|
1219
|
+
deleteScheduled: o.deleteScheduled,
|
|
1220
|
+
preservePointerOnDelete: o.preservePointerOnDelete,
|
|
1221
|
+
ptr: o.ptr,
|
|
1222
|
+
ptrType: o.ptrType,
|
|
1223
|
+
smartPtr: o.smartPtr,
|
|
1224
|
+
smartPtrType: o.smartPtrType
|
|
1225
|
+
});
|
|
1226
|
+
var throwInstanceAlreadyDeleted = (obj) => {
|
|
1227
|
+
function getInstanceTypeName(handle) {
|
|
1228
|
+
return handle.$$.ptrType.registeredClass.name;
|
|
1229
|
+
}
|
|
1230
|
+
throwBindingError(getInstanceTypeName(obj) + " instance already deleted");
|
|
1231
|
+
};
|
|
1232
|
+
var finalizationRegistry = false;
|
|
1233
|
+
var detachFinalizer = (handle) => {
|
|
1234
|
+
};
|
|
1235
|
+
var runDestructor = ($$) => {
|
|
1236
|
+
if ($$.smartPtr) {
|
|
1237
|
+
$$.smartPtrType.rawDestructor($$.smartPtr);
|
|
1238
|
+
} else {
|
|
1239
|
+
$$.ptrType.registeredClass.rawDestructor($$.ptr);
|
|
1240
|
+
}
|
|
1241
|
+
};
|
|
1242
|
+
var releaseClassHandle = ($$) => {
|
|
1243
|
+
$$.count.value -= 1;
|
|
1244
|
+
var toDelete = 0 === $$.count.value;
|
|
1245
|
+
if (toDelete) {
|
|
1246
|
+
runDestructor($$);
|
|
1247
|
+
}
|
|
1248
|
+
};
|
|
1249
|
+
var attachFinalizer = (handle) => {
|
|
1250
|
+
if ("undefined" === typeof FinalizationRegistry) {
|
|
1251
|
+
attachFinalizer = (handle2) => handle2;
|
|
1252
|
+
return handle;
|
|
1253
|
+
}
|
|
1254
|
+
finalizationRegistry = new FinalizationRegistry((info) => {
|
|
1255
|
+
releaseClassHandle(info.$$);
|
|
1256
|
+
});
|
|
1257
|
+
attachFinalizer = (handle2) => {
|
|
1258
|
+
var $$ = handle2.$$;
|
|
1259
|
+
var hasSmartPtr = !!$$.smartPtr;
|
|
1260
|
+
if (hasSmartPtr) {
|
|
1261
|
+
var info = { $$ };
|
|
1262
|
+
finalizationRegistry.register(handle2, info, handle2);
|
|
1263
|
+
}
|
|
1264
|
+
return handle2;
|
|
1265
|
+
};
|
|
1266
|
+
detachFinalizer = (handle2) => finalizationRegistry.unregister(handle2);
|
|
1267
|
+
return attachFinalizer(handle);
|
|
1268
|
+
};
|
|
1269
|
+
var init_ClassHandle = () => {
|
|
1270
|
+
let proto = ClassHandle.prototype;
|
|
1271
|
+
Object.assign(proto, {
|
|
1272
|
+
isAliasOf(other) {
|
|
1273
|
+
if (!(this instanceof ClassHandle)) {
|
|
1274
|
+
return false;
|
|
1275
|
+
}
|
|
1276
|
+
if (!(other instanceof ClassHandle)) {
|
|
1277
|
+
return false;
|
|
1278
|
+
}
|
|
1279
|
+
var leftClass = this.$$.ptrType.registeredClass;
|
|
1280
|
+
var left = this.$$.ptr;
|
|
1281
|
+
other.$$ = other.$$;
|
|
1282
|
+
var rightClass = other.$$.ptrType.registeredClass;
|
|
1283
|
+
var right = other.$$.ptr;
|
|
1284
|
+
while (leftClass.baseClass) {
|
|
1285
|
+
left = leftClass.upcast(left);
|
|
1286
|
+
leftClass = leftClass.baseClass;
|
|
1287
|
+
}
|
|
1288
|
+
while (rightClass.baseClass) {
|
|
1289
|
+
right = rightClass.upcast(right);
|
|
1290
|
+
rightClass = rightClass.baseClass;
|
|
1291
|
+
}
|
|
1292
|
+
return leftClass === rightClass && left === right;
|
|
1293
|
+
},
|
|
1294
|
+
clone() {
|
|
1295
|
+
if (!this.$$.ptr) {
|
|
1296
|
+
throwInstanceAlreadyDeleted(this);
|
|
1297
|
+
}
|
|
1298
|
+
if (this.$$.preservePointerOnDelete) {
|
|
1299
|
+
this.$$.count.value += 1;
|
|
1300
|
+
return this;
|
|
1301
|
+
} else {
|
|
1302
|
+
var clone = attachFinalizer(Object.create(
|
|
1303
|
+
Object.getPrototypeOf(this),
|
|
1304
|
+
{ $$: { value: shallowCopyInternalPointer(this.$$) } }
|
|
1305
|
+
));
|
|
1306
|
+
clone.$$.count.value += 1;
|
|
1307
|
+
clone.$$.deleteScheduled = false;
|
|
1308
|
+
return clone;
|
|
1309
|
+
}
|
|
1310
|
+
},
|
|
1311
|
+
delete() {
|
|
1312
|
+
if (!this.$$.ptr) {
|
|
1313
|
+
throwInstanceAlreadyDeleted(this);
|
|
1314
|
+
}
|
|
1315
|
+
if (this.$$.deleteScheduled && !this.$$.preservePointerOnDelete) {
|
|
1316
|
+
throwBindingError("Object already scheduled for deletion");
|
|
1317
|
+
}
|
|
1318
|
+
detachFinalizer(this);
|
|
1319
|
+
releaseClassHandle(this.$$);
|
|
1320
|
+
if (!this.$$.preservePointerOnDelete) {
|
|
1321
|
+
this.$$.smartPtr = void 0;
|
|
1322
|
+
this.$$.ptr = void 0;
|
|
1323
|
+
}
|
|
1324
|
+
},
|
|
1325
|
+
isDeleted() {
|
|
1326
|
+
return !this.$$.ptr;
|
|
1327
|
+
},
|
|
1328
|
+
deleteLater() {
|
|
1329
|
+
if (!this.$$.ptr) {
|
|
1330
|
+
throwInstanceAlreadyDeleted(this);
|
|
1331
|
+
}
|
|
1332
|
+
if (this.$$.deleteScheduled && !this.$$.preservePointerOnDelete) {
|
|
1333
|
+
throwBindingError("Object already scheduled for deletion");
|
|
1334
|
+
}
|
|
1335
|
+
this.$$.deleteScheduled = true;
|
|
1336
|
+
return this;
|
|
1337
|
+
}
|
|
1338
|
+
});
|
|
1339
|
+
const symbolDispose = Symbol.dispose;
|
|
1340
|
+
if (symbolDispose) {
|
|
1341
|
+
proto[symbolDispose] = proto["delete"];
|
|
1342
|
+
}
|
|
1343
|
+
};
|
|
1344
|
+
function ClassHandle() {
|
|
1345
|
+
}
|
|
1346
|
+
var createNamedFunction = (name, func) => Object.defineProperty(func, "name", { value: name });
|
|
1347
|
+
var registeredPointers = {};
|
|
1348
|
+
var ensureOverloadTable = (proto, methodName, humanName) => {
|
|
1349
|
+
if (void 0 === proto[methodName].overloadTable) {
|
|
1350
|
+
var prevFunc = proto[methodName];
|
|
1351
|
+
proto[methodName] = function(...args) {
|
|
1352
|
+
if (!proto[methodName].overloadTable.hasOwnProperty(args.length)) {
|
|
1353
|
+
throwBindingError(`Function '${humanName}' called with an invalid number of arguments (${args.length}) - expects one of (${proto[methodName].overloadTable})!`);
|
|
1354
|
+
}
|
|
1355
|
+
return proto[methodName].overloadTable[args.length].apply(this, args);
|
|
1356
|
+
};
|
|
1357
|
+
proto[methodName].overloadTable = [];
|
|
1358
|
+
proto[methodName].overloadTable[prevFunc.argCount] = prevFunc;
|
|
1359
|
+
}
|
|
1360
|
+
};
|
|
1361
|
+
var exposePublicSymbol = (name, value, numArguments) => {
|
|
1362
|
+
if (Module2.hasOwnProperty(name)) {
|
|
1363
|
+
if (void 0 === numArguments || void 0 !== Module2[name].overloadTable && void 0 !== Module2[name].overloadTable[numArguments]) {
|
|
1364
|
+
throwBindingError(`Cannot register public name '${name}' twice`);
|
|
1365
|
+
}
|
|
1366
|
+
ensureOverloadTable(Module2, name, name);
|
|
1367
|
+
if (Module2[name].overloadTable.hasOwnProperty(numArguments)) {
|
|
1368
|
+
throwBindingError(
|
|
1369
|
+
`Cannot register multiple overloads of a function with the same number of arguments (${numArguments})!`
|
|
1370
|
+
);
|
|
1371
|
+
}
|
|
1372
|
+
Module2[name].overloadTable[numArguments] = value;
|
|
1373
|
+
} else {
|
|
1374
|
+
Module2[name] = value;
|
|
1375
|
+
Module2[name].argCount = numArguments;
|
|
1376
|
+
}
|
|
1377
|
+
};
|
|
1378
|
+
var char_0 = 48;
|
|
1379
|
+
var char_9 = 57;
|
|
1380
|
+
var makeLegalFunctionName = (name) => {
|
|
1381
|
+
name = name.replace(/[^a-zA-Z0-9_]/g, "$");
|
|
1382
|
+
var f = name.charCodeAt(0);
|
|
1383
|
+
if (f >= char_0 && f <= char_9) {
|
|
1384
|
+
return `_${name}`;
|
|
1385
|
+
}
|
|
1386
|
+
return name;
|
|
1387
|
+
};
|
|
1388
|
+
function RegisteredClass(name, constructor, instancePrototype, rawDestructor, baseClass, getActualType, upcast, downcast) {
|
|
1389
|
+
this.name = name;
|
|
1390
|
+
this.constructor = constructor;
|
|
1391
|
+
this.instancePrototype = instancePrototype;
|
|
1392
|
+
this.rawDestructor = rawDestructor;
|
|
1393
|
+
this.baseClass = baseClass;
|
|
1394
|
+
this.getActualType = getActualType;
|
|
1395
|
+
this.upcast = upcast;
|
|
1396
|
+
this.downcast = downcast;
|
|
1397
|
+
this.pureVirtualFunctions = [];
|
|
1398
|
+
}
|
|
1399
|
+
var upcastPointer = (ptr, ptrClass, desiredClass) => {
|
|
1400
|
+
while (ptrClass !== desiredClass) {
|
|
1401
|
+
if (!ptrClass.upcast) {
|
|
1402
|
+
throwBindingError(`Expected null or instance of ${desiredClass.name}, got an instance of ${ptrClass.name}`);
|
|
1403
|
+
}
|
|
1404
|
+
ptr = ptrClass.upcast(ptr);
|
|
1405
|
+
ptrClass = ptrClass.baseClass;
|
|
1406
|
+
}
|
|
1407
|
+
return ptr;
|
|
1408
|
+
};
|
|
1409
|
+
function constNoSmartPtrRawPointerToWireType(destructors, handle) {
|
|
1410
|
+
if (handle === null) {
|
|
1411
|
+
if (this.isReference) {
|
|
1412
|
+
throwBindingError(`null is not a valid ${this.name}`);
|
|
1413
|
+
}
|
|
1414
|
+
return 0;
|
|
1415
|
+
}
|
|
1416
|
+
if (!handle.$$) {
|
|
1417
|
+
throwBindingError(
|
|
1418
|
+
`Cannot pass "${embindRepr(handle)}" as a ${this.name}`
|
|
1419
|
+
);
|
|
1420
|
+
}
|
|
1421
|
+
if (!handle.$$.ptr) {
|
|
1422
|
+
throwBindingError(
|
|
1423
|
+
`Cannot pass deleted object as a pointer of type ${this.name}`
|
|
1424
|
+
);
|
|
1425
|
+
}
|
|
1426
|
+
var handleClass = handle.$$.ptrType.registeredClass;
|
|
1427
|
+
var ptr = upcastPointer(handle.$$.ptr, handleClass, this.registeredClass);
|
|
1428
|
+
return ptr;
|
|
1429
|
+
}
|
|
1430
|
+
function genericPointerToWireType(destructors, handle) {
|
|
1431
|
+
var ptr;
|
|
1432
|
+
if (handle === null) {
|
|
1433
|
+
if (this.isReference) {
|
|
1434
|
+
throwBindingError(`null is not a valid ${this.name}`);
|
|
1435
|
+
}
|
|
1436
|
+
if (this.isSmartPointer) {
|
|
1437
|
+
ptr = this.rawConstructor();
|
|
1438
|
+
if (destructors !== null) {
|
|
1439
|
+
destructors.push(this.rawDestructor, ptr);
|
|
1440
|
+
}
|
|
1441
|
+
return ptr;
|
|
1442
|
+
} else {
|
|
1443
|
+
return 0;
|
|
1444
|
+
}
|
|
1445
|
+
}
|
|
1446
|
+
if (!handle || !handle.$$) {
|
|
1447
|
+
throwBindingError(
|
|
1448
|
+
`Cannot pass "${embindRepr(handle)}" as a ${this.name}`
|
|
1449
|
+
);
|
|
1450
|
+
}
|
|
1451
|
+
if (!handle.$$.ptr) {
|
|
1452
|
+
throwBindingError(
|
|
1453
|
+
`Cannot pass deleted object as a pointer of type ${this.name}`
|
|
1454
|
+
);
|
|
1455
|
+
}
|
|
1456
|
+
if (!this.isConst && handle.$$.ptrType.isConst) {
|
|
1457
|
+
throwBindingError(`Cannot convert argument of type ${handle.$$.smartPtrType ? handle.$$.smartPtrType.name : handle.$$.ptrType.name} to parameter type ${this.name}`);
|
|
1458
|
+
}
|
|
1459
|
+
var handleClass = handle.$$.ptrType.registeredClass;
|
|
1460
|
+
ptr = upcastPointer(handle.$$.ptr, handleClass, this.registeredClass);
|
|
1461
|
+
if (this.isSmartPointer) {
|
|
1462
|
+
if (void 0 === handle.$$.smartPtr) {
|
|
1463
|
+
throwBindingError("Passing raw pointer to smart pointer is illegal");
|
|
1464
|
+
}
|
|
1465
|
+
switch (this.sharingPolicy) {
|
|
1466
|
+
case 0:
|
|
1467
|
+
if (handle.$$.smartPtrType === this) {
|
|
1468
|
+
ptr = handle.$$.smartPtr;
|
|
1469
|
+
} else {
|
|
1470
|
+
throwBindingError(`Cannot convert argument of type ${handle.$$.smartPtrType ? handle.$$.smartPtrType.name : handle.$$.ptrType.name} to parameter type ${this.name}`);
|
|
1471
|
+
}
|
|
1472
|
+
break;
|
|
1473
|
+
case 1:
|
|
1474
|
+
ptr = handle.$$.smartPtr;
|
|
1475
|
+
break;
|
|
1476
|
+
case 2:
|
|
1477
|
+
if (handle.$$.smartPtrType === this) {
|
|
1478
|
+
ptr = handle.$$.smartPtr;
|
|
1479
|
+
} else {
|
|
1480
|
+
var clonedHandle = handle["clone"]();
|
|
1481
|
+
ptr = this.rawShare(
|
|
1482
|
+
ptr,
|
|
1483
|
+
Emval.toHandle(() => clonedHandle["delete"]())
|
|
1484
|
+
);
|
|
1485
|
+
if (destructors !== null) {
|
|
1486
|
+
destructors.push(this.rawDestructor, ptr);
|
|
1487
|
+
}
|
|
1488
|
+
}
|
|
1489
|
+
break;
|
|
1490
|
+
default:
|
|
1491
|
+
throwBindingError("Unsupporting sharing policy");
|
|
1492
|
+
}
|
|
1493
|
+
}
|
|
1494
|
+
return ptr;
|
|
1495
|
+
}
|
|
1496
|
+
function nonConstNoSmartPtrRawPointerToWireType(destructors, handle) {
|
|
1497
|
+
if (handle === null) {
|
|
1498
|
+
if (this.isReference) {
|
|
1499
|
+
throwBindingError(`null is not a valid ${this.name}`);
|
|
1500
|
+
}
|
|
1501
|
+
return 0;
|
|
1502
|
+
}
|
|
1503
|
+
if (!handle.$$) {
|
|
1504
|
+
throwBindingError(
|
|
1505
|
+
`Cannot pass "${embindRepr(handle)}" as a ${this.name}`
|
|
1506
|
+
);
|
|
1507
|
+
}
|
|
1508
|
+
if (!handle.$$.ptr) {
|
|
1509
|
+
throwBindingError(
|
|
1510
|
+
`Cannot pass deleted object as a pointer of type ${this.name}`
|
|
1511
|
+
);
|
|
1512
|
+
}
|
|
1513
|
+
if (handle.$$.ptrType.isConst) {
|
|
1514
|
+
throwBindingError(`Cannot convert argument of type ${handle.$$.ptrType.name} to parameter type ${this.name}`);
|
|
1515
|
+
}
|
|
1516
|
+
var handleClass = handle.$$.ptrType.registeredClass;
|
|
1517
|
+
var ptr = upcastPointer(handle.$$.ptr, handleClass, this.registeredClass);
|
|
1518
|
+
return ptr;
|
|
1519
|
+
}
|
|
1520
|
+
var downcastPointer = (ptr, ptrClass, desiredClass) => {
|
|
1521
|
+
if (ptrClass === desiredClass) {
|
|
1522
|
+
return ptr;
|
|
1523
|
+
}
|
|
1524
|
+
if (void 0 === desiredClass.baseClass) {
|
|
1525
|
+
return null;
|
|
1526
|
+
}
|
|
1527
|
+
var rv = downcastPointer(ptr, ptrClass, desiredClass.baseClass);
|
|
1528
|
+
if (rv === null) {
|
|
1529
|
+
return null;
|
|
1530
|
+
}
|
|
1531
|
+
return desiredClass.downcast(rv);
|
|
1532
|
+
};
|
|
1533
|
+
var registeredInstances = {};
|
|
1534
|
+
var getBasestPointer = (class_, ptr) => {
|
|
1535
|
+
if (ptr === void 0) {
|
|
1536
|
+
throwBindingError("ptr should not be undefined");
|
|
1537
|
+
}
|
|
1538
|
+
while (class_.baseClass) {
|
|
1539
|
+
ptr = class_.upcast(ptr);
|
|
1540
|
+
class_ = class_.baseClass;
|
|
1541
|
+
}
|
|
1542
|
+
return ptr;
|
|
1543
|
+
};
|
|
1544
|
+
var getInheritedInstance = (class_, ptr) => {
|
|
1545
|
+
ptr = getBasestPointer(class_, ptr);
|
|
1546
|
+
return registeredInstances[ptr];
|
|
1547
|
+
};
|
|
1548
|
+
var makeClassHandle = (prototype, record) => {
|
|
1549
|
+
if (!record.ptrType || !record.ptr) {
|
|
1550
|
+
throwInternalError("makeClassHandle requires ptr and ptrType");
|
|
1551
|
+
}
|
|
1552
|
+
var hasSmartPtrType = !!record.smartPtrType;
|
|
1553
|
+
var hasSmartPtr = !!record.smartPtr;
|
|
1554
|
+
if (hasSmartPtrType !== hasSmartPtr) {
|
|
1555
|
+
throwInternalError("Both smartPtrType and smartPtr must be specified");
|
|
1556
|
+
}
|
|
1557
|
+
record.count = { value: 1 };
|
|
1558
|
+
return attachFinalizer(
|
|
1559
|
+
Object.create(prototype, { $$: { value: record, writable: true } })
|
|
1560
|
+
);
|
|
1561
|
+
};
|
|
1562
|
+
function RegisteredPointer_fromWireType(ptr) {
|
|
1563
|
+
var rawPointer = this.getPointee(ptr);
|
|
1564
|
+
if (!rawPointer) {
|
|
1565
|
+
this.destructor(ptr);
|
|
1566
|
+
return null;
|
|
1567
|
+
}
|
|
1568
|
+
var registeredInstance = getInheritedInstance(this.registeredClass, rawPointer);
|
|
1569
|
+
if (void 0 !== registeredInstance) {
|
|
1570
|
+
if (0 === registeredInstance.$$.count.value) {
|
|
1571
|
+
registeredInstance.$$.ptr = rawPointer;
|
|
1572
|
+
registeredInstance.$$.smartPtr = ptr;
|
|
1573
|
+
return registeredInstance["clone"]();
|
|
1574
|
+
} else {
|
|
1575
|
+
var rv = registeredInstance["clone"]();
|
|
1576
|
+
this.destructor(ptr);
|
|
1577
|
+
return rv;
|
|
1578
|
+
}
|
|
1579
|
+
}
|
|
1580
|
+
function makeDefaultHandle() {
|
|
1581
|
+
if (this.isSmartPointer) {
|
|
1582
|
+
return makeClassHandle(this.registeredClass.instancePrototype, {
|
|
1583
|
+
ptrType: this.pointeeType,
|
|
1584
|
+
ptr: rawPointer,
|
|
1585
|
+
smartPtrType: this,
|
|
1586
|
+
smartPtr: ptr
|
|
1587
|
+
});
|
|
1588
|
+
} else {
|
|
1589
|
+
return makeClassHandle(
|
|
1590
|
+
this.registeredClass.instancePrototype,
|
|
1591
|
+
{ ptrType: this, ptr }
|
|
1592
|
+
);
|
|
1593
|
+
}
|
|
1594
|
+
}
|
|
1595
|
+
var actualType = this.registeredClass.getActualType(rawPointer);
|
|
1596
|
+
var registeredPointerRecord = registeredPointers[actualType];
|
|
1597
|
+
if (!registeredPointerRecord) {
|
|
1598
|
+
return makeDefaultHandle.call(this);
|
|
1599
|
+
}
|
|
1600
|
+
var toType;
|
|
1601
|
+
if (this.isConst) {
|
|
1602
|
+
toType = registeredPointerRecord.constPointerType;
|
|
1603
|
+
} else {
|
|
1604
|
+
toType = registeredPointerRecord.pointerType;
|
|
1605
|
+
}
|
|
1606
|
+
var dp = downcastPointer(
|
|
1607
|
+
rawPointer,
|
|
1608
|
+
this.registeredClass,
|
|
1609
|
+
toType.registeredClass
|
|
1610
|
+
);
|
|
1611
|
+
if (dp === null) {
|
|
1612
|
+
return makeDefaultHandle.call(this);
|
|
1613
|
+
}
|
|
1614
|
+
if (this.isSmartPointer) {
|
|
1615
|
+
return makeClassHandle(
|
|
1616
|
+
toType.registeredClass.instancePrototype,
|
|
1617
|
+
{ ptrType: toType, ptr: dp, smartPtrType: this, smartPtr: ptr }
|
|
1618
|
+
);
|
|
1619
|
+
} else {
|
|
1620
|
+
return makeClassHandle(
|
|
1621
|
+
toType.registeredClass.instancePrototype,
|
|
1622
|
+
{ ptrType: toType, ptr: dp }
|
|
1623
|
+
);
|
|
1624
|
+
}
|
|
1625
|
+
}
|
|
1626
|
+
var init_RegisteredPointer = () => {
|
|
1627
|
+
Object.assign(RegisteredPointer.prototype, {
|
|
1628
|
+
getPointee(ptr) {
|
|
1629
|
+
if (this.rawGetPointee) {
|
|
1630
|
+
ptr = this.rawGetPointee(ptr);
|
|
1631
|
+
}
|
|
1632
|
+
return ptr;
|
|
1633
|
+
},
|
|
1634
|
+
destructor(ptr) {
|
|
1635
|
+
var _a;
|
|
1636
|
+
(_a = this.rawDestructor) == null ? void 0 : _a.call(this, ptr);
|
|
1637
|
+
},
|
|
1638
|
+
argPackAdvance: GenericWireTypeSize,
|
|
1639
|
+
readValueFromPointer: readPointer,
|
|
1640
|
+
fromWireType: RegisteredPointer_fromWireType
|
|
1641
|
+
});
|
|
1642
|
+
};
|
|
1643
|
+
function RegisteredPointer(name, registeredClass, isReference, isConst, isSmartPointer, pointeeType, sharingPolicy, rawGetPointee, rawConstructor, rawShare, rawDestructor) {
|
|
1644
|
+
this.name = name;
|
|
1645
|
+
this.registeredClass = registeredClass;
|
|
1646
|
+
this.isReference = isReference;
|
|
1647
|
+
this.isConst = isConst;
|
|
1648
|
+
this.isSmartPointer = isSmartPointer;
|
|
1649
|
+
this.pointeeType = pointeeType;
|
|
1650
|
+
this.sharingPolicy = sharingPolicy;
|
|
1651
|
+
this.rawGetPointee = rawGetPointee;
|
|
1652
|
+
this.rawConstructor = rawConstructor;
|
|
1653
|
+
this.rawShare = rawShare;
|
|
1654
|
+
this.rawDestructor = rawDestructor;
|
|
1655
|
+
if (!isSmartPointer && registeredClass.baseClass === void 0) {
|
|
1656
|
+
if (isConst) {
|
|
1657
|
+
this["toWireType"] = constNoSmartPtrRawPointerToWireType;
|
|
1658
|
+
this.destructorFunction = null;
|
|
1659
|
+
} else {
|
|
1660
|
+
this["toWireType"] = nonConstNoSmartPtrRawPointerToWireType;
|
|
1661
|
+
this.destructorFunction = null;
|
|
1662
|
+
}
|
|
1663
|
+
} else {
|
|
1664
|
+
this["toWireType"] = genericPointerToWireType;
|
|
1665
|
+
}
|
|
1666
|
+
}
|
|
1667
|
+
var replacePublicSymbol = (name, value, numArguments) => {
|
|
1668
|
+
if (!Module2.hasOwnProperty(name)) {
|
|
1669
|
+
throwInternalError("Replacing nonexistent public symbol");
|
|
1670
|
+
}
|
|
1671
|
+
if (void 0 !== Module2[name].overloadTable && void 0 !== numArguments) {
|
|
1672
|
+
Module2[name].overloadTable[numArguments] = value;
|
|
1673
|
+
} else {
|
|
1674
|
+
Module2[name] = value;
|
|
1675
|
+
Module2[name].argCount = numArguments;
|
|
1676
|
+
}
|
|
1677
|
+
};
|
|
1678
|
+
var wasmTable;
|
|
1679
|
+
var getWasmTableEntry = (funcPtr) => wasmTable.get(funcPtr);
|
|
1680
|
+
var dynCall = (sig, ptr, args = [], promising = false) => {
|
|
1681
|
+
var func = getWasmTableEntry(ptr);
|
|
1682
|
+
var rtn = func(...args);
|
|
1683
|
+
return sig[0] == "p" ? rtn >>> 0 : rtn;
|
|
1684
|
+
};
|
|
1685
|
+
var getDynCaller = (sig, ptr, promising = false) => (...args) => dynCall(sig, ptr, args, promising);
|
|
1686
|
+
var embind__requireFunction = (signature, rawFunction, isAsync = false) => {
|
|
1687
|
+
signature = readLatin1String(signature);
|
|
1688
|
+
function makeDynCaller() {
|
|
1689
|
+
if (signature.includes("p")) {
|
|
1690
|
+
return getDynCaller(signature, rawFunction, isAsync);
|
|
1691
|
+
}
|
|
1692
|
+
var rtn = getWasmTableEntry(rawFunction);
|
|
1693
|
+
return rtn;
|
|
1694
|
+
}
|
|
1695
|
+
var fp = makeDynCaller();
|
|
1696
|
+
if (typeof fp != "function") {
|
|
1697
|
+
throwBindingError(`unknown function pointer with signature ${signature}: ${rawFunction}`);
|
|
1698
|
+
}
|
|
1699
|
+
return fp;
|
|
1700
|
+
};
|
|
1701
|
+
class UnboundTypeError extends Error {
|
|
1702
|
+
}
|
|
1703
|
+
var getTypeName = (type) => {
|
|
1704
|
+
var ptr = ___getTypeName(type);
|
|
1705
|
+
var rv = readLatin1String(ptr);
|
|
1706
|
+
_free(ptr);
|
|
1707
|
+
return rv;
|
|
1708
|
+
};
|
|
1709
|
+
var throwUnboundTypeError = (message, types) => {
|
|
1710
|
+
var unboundTypes = [];
|
|
1711
|
+
var seen = {};
|
|
1712
|
+
function visit(type) {
|
|
1713
|
+
if (seen[type]) {
|
|
1714
|
+
return;
|
|
1715
|
+
}
|
|
1716
|
+
if (registeredTypes[type]) {
|
|
1717
|
+
return;
|
|
1718
|
+
}
|
|
1719
|
+
if (typeDependencies[type]) {
|
|
1720
|
+
typeDependencies[type].forEach(visit);
|
|
1721
|
+
return;
|
|
1722
|
+
}
|
|
1723
|
+
unboundTypes.push(type);
|
|
1724
|
+
seen[type] = true;
|
|
1725
|
+
}
|
|
1726
|
+
types.forEach(visit);
|
|
1727
|
+
throw new UnboundTypeError(
|
|
1728
|
+
`${message}: ` + unboundTypes.map(getTypeName).join([", "])
|
|
1729
|
+
);
|
|
1730
|
+
};
|
|
1731
|
+
function __embind_register_class(rawType, rawPointerType, rawConstPointerType, baseClassRawType, getActualTypeSignature, getActualType, upcastSignature, upcast, downcastSignature, downcast, name, destructorSignature, rawDestructor) {
|
|
1732
|
+
rawType >>>= 0;
|
|
1733
|
+
rawPointerType >>>= 0;
|
|
1734
|
+
rawConstPointerType >>>= 0;
|
|
1735
|
+
baseClassRawType >>>= 0;
|
|
1736
|
+
getActualTypeSignature >>>= 0;
|
|
1737
|
+
getActualType >>>= 0;
|
|
1738
|
+
upcastSignature >>>= 0;
|
|
1739
|
+
upcast >>>= 0;
|
|
1740
|
+
downcastSignature >>>= 0;
|
|
1741
|
+
downcast >>>= 0;
|
|
1742
|
+
name >>>= 0;
|
|
1743
|
+
destructorSignature >>>= 0;
|
|
1744
|
+
rawDestructor >>>= 0;
|
|
1745
|
+
name = readLatin1String(name);
|
|
1746
|
+
getActualType = embind__requireFunction(getActualTypeSignature, getActualType);
|
|
1747
|
+
upcast && (upcast = embind__requireFunction(upcastSignature, upcast));
|
|
1748
|
+
downcast && (downcast = embind__requireFunction(downcastSignature, downcast));
|
|
1749
|
+
rawDestructor = embind__requireFunction(destructorSignature, rawDestructor);
|
|
1750
|
+
var legalFunctionName = makeLegalFunctionName(name);
|
|
1751
|
+
exposePublicSymbol(legalFunctionName, function() {
|
|
1752
|
+
throwUnboundTypeError(
|
|
1753
|
+
`Cannot construct ${name} due to unbound types`,
|
|
1754
|
+
[baseClassRawType]
|
|
1755
|
+
);
|
|
1756
|
+
});
|
|
1757
|
+
whenDependentTypesAreResolved(
|
|
1758
|
+
[rawType, rawPointerType, rawConstPointerType],
|
|
1759
|
+
baseClassRawType ? [baseClassRawType] : [],
|
|
1760
|
+
(base) => {
|
|
1761
|
+
var _a;
|
|
1762
|
+
base = base[0];
|
|
1763
|
+
var baseClass;
|
|
1764
|
+
var basePrototype;
|
|
1765
|
+
if (baseClassRawType) {
|
|
1766
|
+
baseClass = base.registeredClass;
|
|
1767
|
+
basePrototype = baseClass.instancePrototype;
|
|
1768
|
+
} else {
|
|
1769
|
+
basePrototype = ClassHandle.prototype;
|
|
1770
|
+
}
|
|
1771
|
+
var constructor = createNamedFunction(name, function(...args) {
|
|
1772
|
+
if (Object.getPrototypeOf(this) !== instancePrototype) {
|
|
1773
|
+
throw new BindingError(`Use 'new' to construct ${name}`);
|
|
1774
|
+
}
|
|
1775
|
+
if (void 0 === registeredClass.constructor_body) {
|
|
1776
|
+
throw new BindingError(`${name} has no accessible constructor`);
|
|
1777
|
+
}
|
|
1778
|
+
var body = registeredClass.constructor_body[args.length];
|
|
1779
|
+
if (void 0 === body) {
|
|
1780
|
+
throw new BindingError(`Tried to invoke ctor of ${name} with invalid number of parameters (${args.length}) - expected (${Object.keys(registeredClass.constructor_body).toString()}) parameters instead!`);
|
|
1781
|
+
}
|
|
1782
|
+
return body.apply(this, args);
|
|
1783
|
+
});
|
|
1784
|
+
var instancePrototype = Object.create(
|
|
1785
|
+
basePrototype,
|
|
1786
|
+
{ constructor: { value: constructor } }
|
|
1787
|
+
);
|
|
1788
|
+
constructor.prototype = instancePrototype;
|
|
1789
|
+
var registeredClass = new RegisteredClass(
|
|
1790
|
+
name,
|
|
1791
|
+
constructor,
|
|
1792
|
+
instancePrototype,
|
|
1793
|
+
rawDestructor,
|
|
1794
|
+
baseClass,
|
|
1795
|
+
getActualType,
|
|
1796
|
+
upcast,
|
|
1797
|
+
downcast
|
|
1798
|
+
);
|
|
1799
|
+
if (registeredClass.baseClass) {
|
|
1800
|
+
(_a = registeredClass.baseClass).__derivedClasses ?? (_a.__derivedClasses = []);
|
|
1801
|
+
registeredClass.baseClass.__derivedClasses.push(registeredClass);
|
|
1802
|
+
}
|
|
1803
|
+
var referenceConverter = new RegisteredPointer(
|
|
1804
|
+
name,
|
|
1805
|
+
registeredClass,
|
|
1806
|
+
true,
|
|
1807
|
+
false,
|
|
1808
|
+
false
|
|
1809
|
+
);
|
|
1810
|
+
var pointerConverter = new RegisteredPointer(
|
|
1811
|
+
name + "*",
|
|
1812
|
+
registeredClass,
|
|
1813
|
+
false,
|
|
1814
|
+
false,
|
|
1815
|
+
false
|
|
1816
|
+
);
|
|
1817
|
+
var constPointerConverter = new RegisteredPointer(
|
|
1818
|
+
name + " const*",
|
|
1819
|
+
registeredClass,
|
|
1820
|
+
false,
|
|
1821
|
+
true,
|
|
1822
|
+
false
|
|
1823
|
+
);
|
|
1824
|
+
registeredPointers[rawType] = {
|
|
1825
|
+
pointerType: pointerConverter,
|
|
1826
|
+
constPointerType: constPointerConverter
|
|
1827
|
+
};
|
|
1828
|
+
replacePublicSymbol(legalFunctionName, constructor);
|
|
1829
|
+
return [referenceConverter, pointerConverter, constPointerConverter];
|
|
1830
|
+
}
|
|
1831
|
+
);
|
|
1832
|
+
}
|
|
1833
|
+
var heap32VectorToArray = (count, firstElement) => {
|
|
1834
|
+
var array = [];
|
|
1835
|
+
for (var i = 0; i < count; i++) {
|
|
1836
|
+
array.push(HEAPU32[firstElement + i * 4 >>> 2 >>> 0]);
|
|
1837
|
+
}
|
|
1838
|
+
return array;
|
|
1839
|
+
};
|
|
1840
|
+
function usesDestructorStack(argTypes) {
|
|
1841
|
+
for (var i = 1; i < argTypes.length; ++i) {
|
|
1842
|
+
if (argTypes[i] !== null && argTypes[i].destructorFunction === void 0) {
|
|
1843
|
+
return true;
|
|
1844
|
+
}
|
|
1845
|
+
}
|
|
1846
|
+
return false;
|
|
1847
|
+
}
|
|
1848
|
+
function createJsInvoker(argTypes, isClassMethodFunc, returns, isAsync) {
|
|
1849
|
+
var needsDestructorStack = usesDestructorStack(argTypes);
|
|
1850
|
+
var argCount = argTypes.length - 2;
|
|
1851
|
+
var argsList = [];
|
|
1852
|
+
var argsListWired = ["fn"];
|
|
1853
|
+
if (isClassMethodFunc) {
|
|
1854
|
+
argsListWired.push("thisWired");
|
|
1855
|
+
}
|
|
1856
|
+
for (var i = 0; i < argCount; ++i) {
|
|
1857
|
+
argsList.push(`arg${i}`);
|
|
1858
|
+
argsListWired.push(`arg${i}Wired`);
|
|
1859
|
+
}
|
|
1860
|
+
argsList = argsList.join(",");
|
|
1861
|
+
argsListWired = argsListWired.join(",");
|
|
1862
|
+
var invokerFnBody = `return function (${argsList}) {
|
|
1863
|
+
`;
|
|
1864
|
+
if (needsDestructorStack) {
|
|
1865
|
+
invokerFnBody += "var destructors = [];\n";
|
|
1866
|
+
}
|
|
1867
|
+
var dtorStack = needsDestructorStack ? "destructors" : "null";
|
|
1868
|
+
var args1 = [
|
|
1869
|
+
"humanName",
|
|
1870
|
+
"throwBindingError",
|
|
1871
|
+
"invoker",
|
|
1872
|
+
"fn",
|
|
1873
|
+
"runDestructors",
|
|
1874
|
+
"retType",
|
|
1875
|
+
"classParam"
|
|
1876
|
+
];
|
|
1877
|
+
if (isClassMethodFunc) {
|
|
1878
|
+
invokerFnBody += `var thisWired = classParam['toWireType'](${dtorStack}, this);
|
|
1879
|
+
`;
|
|
1880
|
+
}
|
|
1881
|
+
for (var i = 0; i < argCount; ++i) {
|
|
1882
|
+
invokerFnBody += `var arg${i}Wired = argType${i}['toWireType'](${dtorStack}, arg${i});
|
|
1883
|
+
`;
|
|
1884
|
+
args1.push(`argType${i}`);
|
|
1885
|
+
}
|
|
1886
|
+
invokerFnBody += (returns || isAsync ? "var rv = " : "") + `invoker(${argsListWired});
|
|
1887
|
+
`;
|
|
1888
|
+
if (needsDestructorStack) {
|
|
1889
|
+
invokerFnBody += "runDestructors(destructors);\n";
|
|
1890
|
+
} else {
|
|
1891
|
+
for (var i = isClassMethodFunc ? 1 : 2; i < argTypes.length; ++i) {
|
|
1892
|
+
var paramName = i === 1 ? "thisWired" : "arg" + (i - 2) + "Wired";
|
|
1893
|
+
if (argTypes[i].destructorFunction !== null) {
|
|
1894
|
+
invokerFnBody += `${paramName}_dtor(${paramName});
|
|
1895
|
+
`;
|
|
1896
|
+
args1.push(`${paramName}_dtor`);
|
|
1897
|
+
}
|
|
1898
|
+
}
|
|
1899
|
+
}
|
|
1900
|
+
if (returns) {
|
|
1901
|
+
invokerFnBody += "var ret = retType['fromWireType'](rv);\nreturn ret;\n";
|
|
1902
|
+
}
|
|
1903
|
+
invokerFnBody += "}\n";
|
|
1904
|
+
return [args1, invokerFnBody];
|
|
1905
|
+
}
|
|
1906
|
+
function craftInvokerFunction(humanName, argTypes, classType, cppInvokerFunc, cppTargetFunc, isAsync) {
|
|
1907
|
+
var argCount = argTypes.length;
|
|
1908
|
+
if (argCount < 2) {
|
|
1909
|
+
throwBindingError(
|
|
1910
|
+
"argTypes array size mismatch! Must at least get return value and 'this' types!"
|
|
1911
|
+
);
|
|
1912
|
+
}
|
|
1913
|
+
var isClassMethodFunc = argTypes[1] !== null && classType !== null;
|
|
1914
|
+
var needsDestructorStack = usesDestructorStack(argTypes);
|
|
1915
|
+
var returns = argTypes[0].name !== "void";
|
|
1916
|
+
var closureArgs = [
|
|
1917
|
+
humanName,
|
|
1918
|
+
throwBindingError,
|
|
1919
|
+
cppInvokerFunc,
|
|
1920
|
+
cppTargetFunc,
|
|
1921
|
+
runDestructors,
|
|
1922
|
+
argTypes[0],
|
|
1923
|
+
argTypes[1]
|
|
1924
|
+
];
|
|
1925
|
+
for (var i = 0; i < argCount - 2; ++i) {
|
|
1926
|
+
closureArgs.push(argTypes[i + 2]);
|
|
1927
|
+
}
|
|
1928
|
+
if (!needsDestructorStack) {
|
|
1929
|
+
for (var i = isClassMethodFunc ? 1 : 2; i < argTypes.length; ++i) {
|
|
1930
|
+
if (argTypes[i].destructorFunction !== null) {
|
|
1931
|
+
closureArgs.push(argTypes[i].destructorFunction);
|
|
1932
|
+
}
|
|
1933
|
+
}
|
|
1934
|
+
}
|
|
1935
|
+
let [args, invokerFnBody] = createJsInvoker(argTypes, isClassMethodFunc, returns, isAsync);
|
|
1936
|
+
var invokerFn = new Function(...args, invokerFnBody)(...closureArgs);
|
|
1937
|
+
return createNamedFunction(humanName, invokerFn);
|
|
1938
|
+
}
|
|
1939
|
+
var __embind_register_class_constructor = function(rawClassType, argCount, rawArgTypesAddr, invokerSignature, invoker, rawConstructor) {
|
|
1940
|
+
rawClassType >>>= 0;
|
|
1941
|
+
rawArgTypesAddr >>>= 0;
|
|
1942
|
+
invokerSignature >>>= 0;
|
|
1943
|
+
invoker >>>= 0;
|
|
1944
|
+
rawConstructor >>>= 0;
|
|
1945
|
+
var rawArgTypes = heap32VectorToArray(argCount, rawArgTypesAddr);
|
|
1946
|
+
invoker = embind__requireFunction(invokerSignature, invoker);
|
|
1947
|
+
whenDependentTypesAreResolved([], [rawClassType], (classType) => {
|
|
1948
|
+
classType = classType[0];
|
|
1949
|
+
var humanName = `constructor ${classType.name}`;
|
|
1950
|
+
if (void 0 === classType.registeredClass.constructor_body) {
|
|
1951
|
+
classType.registeredClass.constructor_body = [];
|
|
1952
|
+
}
|
|
1953
|
+
if (void 0 !== classType.registeredClass.constructor_body[argCount - 1]) {
|
|
1954
|
+
throw new BindingError(
|
|
1955
|
+
`Cannot register multiple constructors with identical number of parameters (${argCount - 1}) for class '${classType.name}'! Overload resolution is currently only performed using the parameter count, not actual type info!`
|
|
1956
|
+
);
|
|
1957
|
+
}
|
|
1958
|
+
classType.registeredClass.constructor_body[argCount - 1] = () => {
|
|
1959
|
+
throwUnboundTypeError(
|
|
1960
|
+
`Cannot construct ${classType.name} due to unbound types`,
|
|
1961
|
+
rawArgTypes
|
|
1962
|
+
);
|
|
1963
|
+
};
|
|
1964
|
+
whenDependentTypesAreResolved([], rawArgTypes, (argTypes) => {
|
|
1965
|
+
argTypes.splice(1, 0, null);
|
|
1966
|
+
classType.registeredClass.constructor_body[argCount - 1] = craftInvokerFunction(
|
|
1967
|
+
humanName,
|
|
1968
|
+
argTypes,
|
|
1969
|
+
null,
|
|
1970
|
+
invoker,
|
|
1971
|
+
rawConstructor
|
|
1972
|
+
);
|
|
1973
|
+
return [];
|
|
1974
|
+
});
|
|
1975
|
+
return [];
|
|
1976
|
+
});
|
|
1977
|
+
};
|
|
1978
|
+
var getFunctionName = (signature) => {
|
|
1979
|
+
signature = signature.trim();
|
|
1980
|
+
const argsIndex = signature.indexOf("(");
|
|
1981
|
+
if (argsIndex === -1) return signature;
|
|
1982
|
+
return signature.slice(0, argsIndex);
|
|
1983
|
+
};
|
|
1984
|
+
var __embind_register_class_function = function(rawClassType, methodName, argCount, rawArgTypesAddr, invokerSignature, rawInvoker, context, isPureVirtual, isAsync, isNonnullReturn) {
|
|
1985
|
+
rawClassType >>>= 0;
|
|
1986
|
+
methodName >>>= 0;
|
|
1987
|
+
rawArgTypesAddr >>>= 0;
|
|
1988
|
+
invokerSignature >>>= 0;
|
|
1989
|
+
rawInvoker >>>= 0;
|
|
1990
|
+
context >>>= 0;
|
|
1991
|
+
var rawArgTypes = heap32VectorToArray(argCount, rawArgTypesAddr);
|
|
1992
|
+
methodName = readLatin1String(methodName);
|
|
1993
|
+
methodName = getFunctionName(methodName);
|
|
1994
|
+
rawInvoker = embind__requireFunction(invokerSignature, rawInvoker, isAsync);
|
|
1995
|
+
whenDependentTypesAreResolved([], [rawClassType], (classType) => {
|
|
1996
|
+
classType = classType[0];
|
|
1997
|
+
var humanName = `${classType.name}.${methodName}`;
|
|
1998
|
+
if (methodName.startsWith("@@")) {
|
|
1999
|
+
methodName = Symbol[methodName.substring(2)];
|
|
2000
|
+
}
|
|
2001
|
+
if (isPureVirtual) {
|
|
2002
|
+
classType.registeredClass.pureVirtualFunctions.push(methodName);
|
|
2003
|
+
}
|
|
2004
|
+
function unboundTypesHandler() {
|
|
2005
|
+
throwUnboundTypeError(
|
|
2006
|
+
`Cannot call ${humanName} due to unbound types`,
|
|
2007
|
+
rawArgTypes
|
|
2008
|
+
);
|
|
2009
|
+
}
|
|
2010
|
+
var proto = classType.registeredClass.instancePrototype;
|
|
2011
|
+
var method = proto[methodName];
|
|
2012
|
+
if (void 0 === method || void 0 === method.overloadTable && method.className !== classType.name && method.argCount === argCount - 2) {
|
|
2013
|
+
unboundTypesHandler.argCount = argCount - 2;
|
|
2014
|
+
unboundTypesHandler.className = classType.name;
|
|
2015
|
+
proto[methodName] = unboundTypesHandler;
|
|
2016
|
+
} else {
|
|
2017
|
+
ensureOverloadTable(proto, methodName, humanName);
|
|
2018
|
+
proto[methodName].overloadTable[argCount - 2] = unboundTypesHandler;
|
|
2019
|
+
}
|
|
2020
|
+
whenDependentTypesAreResolved([], rawArgTypes, (argTypes) => {
|
|
2021
|
+
var memberFunction = craftInvokerFunction(
|
|
2022
|
+
humanName,
|
|
2023
|
+
argTypes,
|
|
2024
|
+
classType,
|
|
2025
|
+
rawInvoker,
|
|
2026
|
+
context,
|
|
2027
|
+
isAsync
|
|
2028
|
+
);
|
|
2029
|
+
if (void 0 === proto[methodName].overloadTable) {
|
|
2030
|
+
memberFunction.argCount = argCount - 2;
|
|
2031
|
+
proto[methodName] = memberFunction;
|
|
2032
|
+
} else {
|
|
2033
|
+
proto[methodName].overloadTable[argCount - 2] = memberFunction;
|
|
2034
|
+
}
|
|
2035
|
+
return [];
|
|
2036
|
+
});
|
|
2037
|
+
return [];
|
|
2038
|
+
});
|
|
2039
|
+
};
|
|
2040
|
+
var emval_freelist = [];
|
|
2041
|
+
var emval_handles = [];
|
|
2042
|
+
function __emval_decref(handle) {
|
|
2043
|
+
handle >>>= 0;
|
|
2044
|
+
if (handle > 9 && 0 === --emval_handles[handle + 1]) {
|
|
2045
|
+
emval_handles[handle] = void 0;
|
|
2046
|
+
emval_freelist.push(handle);
|
|
2047
|
+
}
|
|
2048
|
+
}
|
|
2049
|
+
var count_emval_handles = () => emval_handles.length / 2 - 5 - emval_freelist.length;
|
|
2050
|
+
var init_emval = () => {
|
|
2051
|
+
emval_handles.push(0, 1, void 0, 1, null, 1, true, 1, false, 1);
|
|
2052
|
+
Module2["count_emval_handles"] = count_emval_handles;
|
|
2053
|
+
};
|
|
2054
|
+
var Emval = {
|
|
2055
|
+
toValue: (handle) => {
|
|
2056
|
+
if (!handle) {
|
|
2057
|
+
throwBindingError(`Cannot use deleted val. handle = ${handle}`);
|
|
2058
|
+
}
|
|
2059
|
+
return emval_handles[handle];
|
|
2060
|
+
},
|
|
2061
|
+
toHandle: (value) => {
|
|
2062
|
+
switch (value) {
|
|
2063
|
+
case void 0:
|
|
2064
|
+
return 2;
|
|
2065
|
+
case null:
|
|
2066
|
+
return 4;
|
|
2067
|
+
case true:
|
|
2068
|
+
return 6;
|
|
2069
|
+
case false:
|
|
2070
|
+
return 8;
|
|
2071
|
+
default: {
|
|
2072
|
+
const handle = emval_freelist.pop() || emval_handles.length;
|
|
2073
|
+
emval_handles[handle] = value;
|
|
2074
|
+
emval_handles[handle + 1] = 1;
|
|
2075
|
+
return handle;
|
|
2076
|
+
}
|
|
2077
|
+
}
|
|
2078
|
+
}
|
|
2079
|
+
};
|
|
2080
|
+
var EmValType = {
|
|
2081
|
+
name: "emscripten::val",
|
|
2082
|
+
fromWireType: (handle) => {
|
|
2083
|
+
var rv = Emval.toValue(handle);
|
|
2084
|
+
__emval_decref(handle);
|
|
2085
|
+
return rv;
|
|
2086
|
+
},
|
|
2087
|
+
toWireType: (destructors, value) => Emval.toHandle(value),
|
|
2088
|
+
argPackAdvance: GenericWireTypeSize,
|
|
2089
|
+
readValueFromPointer: readPointer,
|
|
2090
|
+
destructorFunction: null
|
|
2091
|
+
};
|
|
2092
|
+
function __embind_register_emval(rawType) {
|
|
2093
|
+
rawType >>>= 0;
|
|
2094
|
+
return registerType(rawType, EmValType);
|
|
2095
|
+
}
|
|
2096
|
+
var enumReadValueFromPointer = (name, width, signed) => {
|
|
2097
|
+
switch (width) {
|
|
2098
|
+
case 1:
|
|
2099
|
+
return signed ? function(pointer) {
|
|
2100
|
+
return this["fromWireType"](HEAP8[pointer >>> 0]);
|
|
2101
|
+
} : function(pointer) {
|
|
2102
|
+
return this["fromWireType"](HEAPU8[pointer >>> 0]);
|
|
2103
|
+
};
|
|
2104
|
+
case 2:
|
|
2105
|
+
return signed ? function(pointer) {
|
|
2106
|
+
return this["fromWireType"](HEAP16[pointer >>> 1 >>> 0]);
|
|
2107
|
+
} : function(pointer) {
|
|
2108
|
+
return this["fromWireType"](HEAPU16[pointer >>> 1 >>> 0]);
|
|
2109
|
+
};
|
|
2110
|
+
case 4:
|
|
2111
|
+
return signed ? function(pointer) {
|
|
2112
|
+
return this["fromWireType"](HEAP32[pointer >>> 2 >>> 0]);
|
|
2113
|
+
} : function(pointer) {
|
|
2114
|
+
return this["fromWireType"](HEAPU32[pointer >>> 2 >>> 0]);
|
|
2115
|
+
};
|
|
2116
|
+
default:
|
|
2117
|
+
throw new TypeError(`invalid integer width (${width}): ${name}`);
|
|
2118
|
+
}
|
|
2119
|
+
};
|
|
2120
|
+
function __embind_register_enum(rawType, name, size, isSigned) {
|
|
2121
|
+
rawType >>>= 0;
|
|
2122
|
+
name >>>= 0;
|
|
2123
|
+
size >>>= 0;
|
|
2124
|
+
name = readLatin1String(name);
|
|
2125
|
+
function ctor() {
|
|
2126
|
+
}
|
|
2127
|
+
ctor.values = {};
|
|
2128
|
+
registerType(rawType, {
|
|
2129
|
+
name,
|
|
2130
|
+
constructor: ctor,
|
|
2131
|
+
fromWireType: function(c) {
|
|
2132
|
+
return this.constructor.values[c];
|
|
2133
|
+
},
|
|
2134
|
+
toWireType: (destructors, c) => c.value,
|
|
2135
|
+
argPackAdvance: GenericWireTypeSize,
|
|
2136
|
+
readValueFromPointer: enumReadValueFromPointer(name, size, isSigned),
|
|
2137
|
+
destructorFunction: null
|
|
2138
|
+
});
|
|
2139
|
+
exposePublicSymbol(name, ctor);
|
|
2140
|
+
}
|
|
2141
|
+
var requireRegisteredType = (rawType, humanName) => {
|
|
2142
|
+
var impl = registeredTypes[rawType];
|
|
2143
|
+
if (void 0 === impl) {
|
|
2144
|
+
throwBindingError(
|
|
2145
|
+
`${humanName} has unknown type ${getTypeName(rawType)}`
|
|
2146
|
+
);
|
|
2147
|
+
}
|
|
2148
|
+
return impl;
|
|
2149
|
+
};
|
|
2150
|
+
function __embind_register_enum_value(rawEnumType, name, enumValue) {
|
|
2151
|
+
rawEnumType >>>= 0;
|
|
2152
|
+
name >>>= 0;
|
|
2153
|
+
var enumType = requireRegisteredType(rawEnumType, "enum");
|
|
2154
|
+
name = readLatin1String(name);
|
|
2155
|
+
var Enum = enumType.constructor;
|
|
2156
|
+
var Value = Object.create(enumType.constructor.prototype, {
|
|
2157
|
+
value: { value: enumValue },
|
|
2158
|
+
constructor: {
|
|
2159
|
+
value: createNamedFunction(`${enumType.name}_${name}`, function() {
|
|
2160
|
+
})
|
|
2161
|
+
}
|
|
2162
|
+
});
|
|
2163
|
+
Enum.values[enumValue] = Value;
|
|
2164
|
+
Enum[name] = Value;
|
|
2165
|
+
}
|
|
2166
|
+
var floatReadValueFromPointer = (name, width) => {
|
|
2167
|
+
switch (width) {
|
|
2168
|
+
case 4:
|
|
2169
|
+
return function(pointer) {
|
|
2170
|
+
return this["fromWireType"](HEAPF32[pointer >>> 2 >>> 0]);
|
|
2171
|
+
};
|
|
2172
|
+
case 8:
|
|
2173
|
+
return function(pointer) {
|
|
2174
|
+
return this["fromWireType"](HEAPF64[pointer >>> 3 >>> 0]);
|
|
2175
|
+
};
|
|
2176
|
+
default:
|
|
2177
|
+
throw new TypeError(`invalid float width (${width}): ${name}`);
|
|
2178
|
+
}
|
|
2179
|
+
};
|
|
2180
|
+
var __embind_register_float = function(rawType, name, size) {
|
|
2181
|
+
rawType >>>= 0;
|
|
2182
|
+
name >>>= 0;
|
|
2183
|
+
size >>>= 0;
|
|
2184
|
+
name = readLatin1String(name);
|
|
2185
|
+
registerType(rawType, {
|
|
2186
|
+
name,
|
|
2187
|
+
fromWireType: (value) => value,
|
|
2188
|
+
toWireType: (destructors, value) => value,
|
|
2189
|
+
argPackAdvance: GenericWireTypeSize,
|
|
2190
|
+
readValueFromPointer: floatReadValueFromPointer(name, size),
|
|
2191
|
+
destructorFunction: null
|
|
2192
|
+
});
|
|
2193
|
+
};
|
|
2194
|
+
function __embind_register_function(name, argCount, rawArgTypesAddr, signature, rawInvoker, fn, isAsync, isNonnullReturn) {
|
|
2195
|
+
name >>>= 0;
|
|
2196
|
+
rawArgTypesAddr >>>= 0;
|
|
2197
|
+
signature >>>= 0;
|
|
2198
|
+
rawInvoker >>>= 0;
|
|
2199
|
+
fn >>>= 0;
|
|
2200
|
+
var argTypes = heap32VectorToArray(argCount, rawArgTypesAddr);
|
|
2201
|
+
name = readLatin1String(name);
|
|
2202
|
+
name = getFunctionName(name);
|
|
2203
|
+
rawInvoker = embind__requireFunction(signature, rawInvoker, isAsync);
|
|
2204
|
+
exposePublicSymbol(name, function() {
|
|
2205
|
+
throwUnboundTypeError(
|
|
2206
|
+
`Cannot call ${name} due to unbound types`,
|
|
2207
|
+
argTypes
|
|
2208
|
+
);
|
|
2209
|
+
}, argCount - 1);
|
|
2210
|
+
whenDependentTypesAreResolved([], argTypes, (argTypes2) => {
|
|
2211
|
+
var invokerArgsArray = [argTypes2[0], null].concat(argTypes2.slice(1));
|
|
2212
|
+
replacePublicSymbol(
|
|
2213
|
+
name,
|
|
2214
|
+
craftInvokerFunction(
|
|
2215
|
+
name,
|
|
2216
|
+
invokerArgsArray,
|
|
2217
|
+
null,
|
|
2218
|
+
rawInvoker,
|
|
2219
|
+
fn,
|
|
2220
|
+
isAsync
|
|
2221
|
+
),
|
|
2222
|
+
argCount - 1
|
|
2223
|
+
);
|
|
2224
|
+
return [];
|
|
2225
|
+
});
|
|
2226
|
+
}
|
|
2227
|
+
function __embind_register_integer(primitiveType, name, size, minRange, maxRange) {
|
|
2228
|
+
primitiveType >>>= 0;
|
|
2229
|
+
name >>>= 0;
|
|
2230
|
+
size >>>= 0;
|
|
2231
|
+
name = readLatin1String(name);
|
|
2232
|
+
var fromWireType = (value) => value;
|
|
2233
|
+
if (minRange === 0) {
|
|
2234
|
+
var bitshift = 32 - 8 * size;
|
|
2235
|
+
fromWireType = (value) => value << bitshift >>> bitshift;
|
|
2236
|
+
}
|
|
2237
|
+
var isUnsignedType = name.includes("unsigned");
|
|
2238
|
+
var checkAssertions = (value, toTypeName) => {
|
|
2239
|
+
};
|
|
2240
|
+
var toWireType;
|
|
2241
|
+
if (isUnsignedType) {
|
|
2242
|
+
toWireType = function(destructors, value) {
|
|
2243
|
+
checkAssertions(value, this.name);
|
|
2244
|
+
return value >>> 0;
|
|
2245
|
+
};
|
|
2246
|
+
} else {
|
|
2247
|
+
toWireType = function(destructors, value) {
|
|
2248
|
+
checkAssertions(value, this.name);
|
|
2249
|
+
return value;
|
|
2250
|
+
};
|
|
2251
|
+
}
|
|
2252
|
+
registerType(primitiveType, {
|
|
2253
|
+
name,
|
|
2254
|
+
fromWireType,
|
|
2255
|
+
toWireType,
|
|
2256
|
+
argPackAdvance: GenericWireTypeSize,
|
|
2257
|
+
readValueFromPointer: integerReadValueFromPointer(name, size, minRange !== 0),
|
|
2258
|
+
destructorFunction: null
|
|
2259
|
+
});
|
|
2260
|
+
}
|
|
2261
|
+
function __embind_register_memory_view(rawType, dataTypeIndex, name) {
|
|
2262
|
+
rawType >>>= 0;
|
|
2263
|
+
name >>>= 0;
|
|
2264
|
+
var typeMapping = [
|
|
2265
|
+
Int8Array,
|
|
2266
|
+
Uint8Array,
|
|
2267
|
+
Int16Array,
|
|
2268
|
+
Uint16Array,
|
|
2269
|
+
Int32Array,
|
|
2270
|
+
Uint32Array,
|
|
2271
|
+
Float32Array,
|
|
2272
|
+
Float64Array,
|
|
2273
|
+
BigInt64Array,
|
|
2274
|
+
BigUint64Array
|
|
2275
|
+
];
|
|
2276
|
+
var TA = typeMapping[dataTypeIndex];
|
|
2277
|
+
function decodeMemoryView(handle) {
|
|
2278
|
+
var size = HEAPU32[handle >>> 2 >>> 0];
|
|
2279
|
+
var data = HEAPU32[handle + 4 >>> 2 >>> 0];
|
|
2280
|
+
return new TA(HEAP8.buffer, data, size);
|
|
2281
|
+
}
|
|
2282
|
+
name = readLatin1String(name);
|
|
2283
|
+
registerType(
|
|
2284
|
+
rawType,
|
|
2285
|
+
{
|
|
2286
|
+
name,
|
|
2287
|
+
fromWireType: decodeMemoryView,
|
|
2288
|
+
argPackAdvance: GenericWireTypeSize,
|
|
2289
|
+
readValueFromPointer: decodeMemoryView
|
|
2290
|
+
},
|
|
2291
|
+
{ ignoreDuplicateRegistrations: true }
|
|
2292
|
+
);
|
|
2293
|
+
}
|
|
2294
|
+
var EmValOptionalType = Object.assign({ optional: true }, EmValType);
|
|
2295
|
+
function __embind_register_optional(rawOptionalType, rawType) {
|
|
2296
|
+
rawOptionalType >>>= 0;
|
|
2297
|
+
registerType(rawOptionalType, EmValOptionalType);
|
|
2298
|
+
}
|
|
2299
|
+
var stringToUTF8Array = (str, heap, outIdx, maxBytesToWrite) => {
|
|
2300
|
+
outIdx >>>= 0;
|
|
2301
|
+
if (!(maxBytesToWrite > 0)) return 0;
|
|
2302
|
+
var startIdx = outIdx;
|
|
2303
|
+
var endIdx = outIdx + maxBytesToWrite - 1;
|
|
2304
|
+
for (var i = 0; i < str.length; ++i) {
|
|
2305
|
+
var u = str.charCodeAt(i);
|
|
2306
|
+
if (u >= 55296 && u <= 57343) {
|
|
2307
|
+
var u1 = str.charCodeAt(++i);
|
|
2308
|
+
u = 65536 + ((u & 1023) << 10) | u1 & 1023;
|
|
2309
|
+
}
|
|
2310
|
+
if (u <= 127) {
|
|
2311
|
+
if (outIdx >= endIdx) break;
|
|
2312
|
+
heap[outIdx++ >>> 0] = u;
|
|
2313
|
+
} else if (u <= 2047) {
|
|
2314
|
+
if (outIdx + 1 >= endIdx) break;
|
|
2315
|
+
heap[outIdx++ >>> 0] = 192 | u >> 6;
|
|
2316
|
+
heap[outIdx++ >>> 0] = 128 | u & 63;
|
|
2317
|
+
} else if (u <= 65535) {
|
|
2318
|
+
if (outIdx + 2 >= endIdx) break;
|
|
2319
|
+
heap[outIdx++ >>> 0] = 224 | u >> 12;
|
|
2320
|
+
heap[outIdx++ >>> 0] = 128 | u >> 6 & 63;
|
|
2321
|
+
heap[outIdx++ >>> 0] = 128 | u & 63;
|
|
2322
|
+
} else {
|
|
2323
|
+
if (outIdx + 3 >= endIdx) break;
|
|
2324
|
+
heap[outIdx++ >>> 0] = 240 | u >> 18;
|
|
2325
|
+
heap[outIdx++ >>> 0] = 128 | u >> 12 & 63;
|
|
2326
|
+
heap[outIdx++ >>> 0] = 128 | u >> 6 & 63;
|
|
2327
|
+
heap[outIdx++ >>> 0] = 128 | u & 63;
|
|
2328
|
+
}
|
|
2329
|
+
}
|
|
2330
|
+
heap[outIdx >>> 0] = 0;
|
|
2331
|
+
return outIdx - startIdx;
|
|
2332
|
+
};
|
|
2333
|
+
var stringToUTF8 = (str, outPtr, maxBytesToWrite) => stringToUTF8Array(str, HEAPU8, outPtr, maxBytesToWrite);
|
|
2334
|
+
var lengthBytesUTF8 = (str) => {
|
|
2335
|
+
var len = 0;
|
|
2336
|
+
for (var i = 0; i < str.length; ++i) {
|
|
2337
|
+
var c = str.charCodeAt(i);
|
|
2338
|
+
if (c <= 127) {
|
|
2339
|
+
len++;
|
|
2340
|
+
} else if (c <= 2047) {
|
|
2341
|
+
len += 2;
|
|
2342
|
+
} else if (c >= 55296 && c <= 57343) {
|
|
2343
|
+
len += 4;
|
|
2344
|
+
++i;
|
|
2345
|
+
} else {
|
|
2346
|
+
len += 3;
|
|
2347
|
+
}
|
|
2348
|
+
}
|
|
2349
|
+
return len;
|
|
2350
|
+
};
|
|
2351
|
+
var UTF8Decoder = typeof TextDecoder != "undefined" ? new TextDecoder() : void 0;
|
|
2352
|
+
var UTF8ArrayToString = (heapOrArray, idx = 0, maxBytesToRead = NaN) => {
|
|
2353
|
+
idx >>>= 0;
|
|
2354
|
+
var endIdx = idx + maxBytesToRead;
|
|
2355
|
+
var endPtr = idx;
|
|
2356
|
+
while (heapOrArray[endPtr] && !(endPtr >= endIdx)) ++endPtr;
|
|
2357
|
+
if (endPtr - idx > 16 && heapOrArray.buffer && UTF8Decoder) {
|
|
2358
|
+
return UTF8Decoder.decode(heapOrArray.subarray(idx, endPtr));
|
|
2359
|
+
}
|
|
2360
|
+
var str = "";
|
|
2361
|
+
while (idx < endPtr) {
|
|
2362
|
+
var u0 = heapOrArray[idx++];
|
|
2363
|
+
if (!(u0 & 128)) {
|
|
2364
|
+
str += String.fromCharCode(u0);
|
|
2365
|
+
continue;
|
|
2366
|
+
}
|
|
2367
|
+
var u1 = heapOrArray[idx++] & 63;
|
|
2368
|
+
if ((u0 & 224) == 192) {
|
|
2369
|
+
str += String.fromCharCode((u0 & 31) << 6 | u1);
|
|
2370
|
+
continue;
|
|
2371
|
+
}
|
|
2372
|
+
var u2 = heapOrArray[idx++] & 63;
|
|
2373
|
+
if ((u0 & 240) == 224) {
|
|
2374
|
+
u0 = (u0 & 15) << 12 | u1 << 6 | u2;
|
|
2375
|
+
} else {
|
|
2376
|
+
u0 = (u0 & 7) << 18 | u1 << 12 | u2 << 6 | heapOrArray[idx++] & 63;
|
|
2377
|
+
}
|
|
2378
|
+
if (u0 < 65536) {
|
|
2379
|
+
str += String.fromCharCode(u0);
|
|
2380
|
+
} else {
|
|
2381
|
+
var ch = u0 - 65536;
|
|
2382
|
+
str += String.fromCharCode(55296 | ch >> 10, 56320 | ch & 1023);
|
|
2383
|
+
}
|
|
2384
|
+
}
|
|
2385
|
+
return str;
|
|
2386
|
+
};
|
|
2387
|
+
var UTF8ToString = (ptr, maxBytesToRead) => {
|
|
2388
|
+
ptr >>>= 0;
|
|
2389
|
+
return ptr ? UTF8ArrayToString(HEAPU8, ptr, maxBytesToRead) : "";
|
|
2390
|
+
};
|
|
2391
|
+
function __embind_register_std_string(rawType, name) {
|
|
2392
|
+
rawType >>>= 0;
|
|
2393
|
+
name >>>= 0;
|
|
2394
|
+
name = readLatin1String(name);
|
|
2395
|
+
registerType(rawType, {
|
|
2396
|
+
name,
|
|
2397
|
+
fromWireType(value) {
|
|
2398
|
+
var length = HEAPU32[value >>> 2 >>> 0];
|
|
2399
|
+
var payload = value + 4;
|
|
2400
|
+
var str;
|
|
2401
|
+
var i;
|
|
2402
|
+
{
|
|
2403
|
+
var decodeStartPtr = payload;
|
|
2404
|
+
for (var i = 0; i <= length; ++i) {
|
|
2405
|
+
var currentBytePtr = payload + i;
|
|
2406
|
+
if (i == length || HEAPU8[currentBytePtr >>> 0] == 0) {
|
|
2407
|
+
var maxRead = currentBytePtr - decodeStartPtr;
|
|
2408
|
+
var stringSegment = UTF8ToString(decodeStartPtr, maxRead);
|
|
2409
|
+
if (str === void 0) {
|
|
2410
|
+
str = stringSegment;
|
|
2411
|
+
} else {
|
|
2412
|
+
str += String.fromCharCode(0);
|
|
2413
|
+
str += stringSegment;
|
|
2414
|
+
}
|
|
2415
|
+
decodeStartPtr = currentBytePtr + 1;
|
|
2416
|
+
}
|
|
2417
|
+
}
|
|
2418
|
+
}
|
|
2419
|
+
_free(value);
|
|
2420
|
+
return str;
|
|
2421
|
+
},
|
|
2422
|
+
toWireType(destructors, value) {
|
|
2423
|
+
if (value instanceof ArrayBuffer) {
|
|
2424
|
+
value = new Uint8Array(value);
|
|
2425
|
+
}
|
|
2426
|
+
var length;
|
|
2427
|
+
var valueIsOfTypeString = typeof value == "string";
|
|
2428
|
+
if (!(valueIsOfTypeString || ArrayBuffer.isView(value) && value.BYTES_PER_ELEMENT == 1)) {
|
|
2429
|
+
throwBindingError("Cannot pass non-string to std::string");
|
|
2430
|
+
}
|
|
2431
|
+
if (valueIsOfTypeString) {
|
|
2432
|
+
length = lengthBytesUTF8(value);
|
|
2433
|
+
} else {
|
|
2434
|
+
length = value.length;
|
|
2435
|
+
}
|
|
2436
|
+
var base = _malloc(4 + length + 1);
|
|
2437
|
+
var ptr = base + 4;
|
|
2438
|
+
HEAPU32[base >>> 2 >>> 0] = length;
|
|
2439
|
+
if (valueIsOfTypeString) {
|
|
2440
|
+
{
|
|
2441
|
+
stringToUTF8(value, ptr, length + 1);
|
|
2442
|
+
}
|
|
2443
|
+
} else {
|
|
2444
|
+
HEAPU8.set(value, ptr >>> 0);
|
|
2445
|
+
}
|
|
2446
|
+
if (destructors !== null) {
|
|
2447
|
+
destructors.push(_free, base);
|
|
2448
|
+
}
|
|
2449
|
+
return base;
|
|
2450
|
+
},
|
|
2451
|
+
argPackAdvance: GenericWireTypeSize,
|
|
2452
|
+
readValueFromPointer: readPointer,
|
|
2453
|
+
destructorFunction(ptr) {
|
|
2454
|
+
_free(ptr);
|
|
2455
|
+
}
|
|
2456
|
+
});
|
|
2457
|
+
}
|
|
2458
|
+
var UTF16Decoder = typeof TextDecoder != "undefined" ? new TextDecoder("utf-16le") : void 0;
|
|
2459
|
+
var UTF16ToString = (ptr, maxBytesToRead) => {
|
|
2460
|
+
var endPtr = ptr;
|
|
2461
|
+
var idx = endPtr >> 1;
|
|
2462
|
+
var maxIdx = idx + maxBytesToRead / 2;
|
|
2463
|
+
while (!(idx >= maxIdx) && HEAPU16[idx >>> 0]) ++idx;
|
|
2464
|
+
endPtr = idx << 1;
|
|
2465
|
+
if (endPtr - ptr > 32 && UTF16Decoder)
|
|
2466
|
+
return UTF16Decoder.decode(HEAPU8.subarray(ptr >>> 0, endPtr >>> 0));
|
|
2467
|
+
var str = "";
|
|
2468
|
+
for (var i = 0; !(i >= maxBytesToRead / 2); ++i) {
|
|
2469
|
+
var codeUnit = HEAP16[ptr + i * 2 >>> 1 >>> 0];
|
|
2470
|
+
if (codeUnit == 0) break;
|
|
2471
|
+
str += String.fromCharCode(codeUnit);
|
|
2472
|
+
}
|
|
2473
|
+
return str;
|
|
2474
|
+
};
|
|
2475
|
+
var stringToUTF16 = (str, outPtr, maxBytesToWrite) => {
|
|
2476
|
+
maxBytesToWrite ?? (maxBytesToWrite = 2147483647);
|
|
2477
|
+
if (maxBytesToWrite < 2) return 0;
|
|
2478
|
+
maxBytesToWrite -= 2;
|
|
2479
|
+
var startPtr = outPtr;
|
|
2480
|
+
var numCharsToWrite = maxBytesToWrite < str.length * 2 ? maxBytesToWrite / 2 : str.length;
|
|
2481
|
+
for (var i = 0; i < numCharsToWrite; ++i) {
|
|
2482
|
+
var codeUnit = str.charCodeAt(i);
|
|
2483
|
+
HEAP16[outPtr >>> 1 >>> 0] = codeUnit;
|
|
2484
|
+
outPtr += 2;
|
|
2485
|
+
}
|
|
2486
|
+
HEAP16[outPtr >>> 1 >>> 0] = 0;
|
|
2487
|
+
return outPtr - startPtr;
|
|
2488
|
+
};
|
|
2489
|
+
var lengthBytesUTF16 = (str) => str.length * 2;
|
|
2490
|
+
var UTF32ToString = (ptr, maxBytesToRead) => {
|
|
2491
|
+
var i = 0;
|
|
2492
|
+
var str = "";
|
|
2493
|
+
while (!(i >= maxBytesToRead / 4)) {
|
|
2494
|
+
var utf32 = HEAP32[ptr + i * 4 >>> 2 >>> 0];
|
|
2495
|
+
if (utf32 == 0) break;
|
|
2496
|
+
++i;
|
|
2497
|
+
if (utf32 >= 65536) {
|
|
2498
|
+
var ch = utf32 - 65536;
|
|
2499
|
+
str += String.fromCharCode(55296 | ch >> 10, 56320 | ch & 1023);
|
|
2500
|
+
} else {
|
|
2501
|
+
str += String.fromCharCode(utf32);
|
|
2502
|
+
}
|
|
2503
|
+
}
|
|
2504
|
+
return str;
|
|
2505
|
+
};
|
|
2506
|
+
var stringToUTF32 = (str, outPtr, maxBytesToWrite) => {
|
|
2507
|
+
outPtr >>>= 0;
|
|
2508
|
+
maxBytesToWrite ?? (maxBytesToWrite = 2147483647);
|
|
2509
|
+
if (maxBytesToWrite < 4) return 0;
|
|
2510
|
+
var startPtr = outPtr;
|
|
2511
|
+
var endPtr = startPtr + maxBytesToWrite - 4;
|
|
2512
|
+
for (var i = 0; i < str.length; ++i) {
|
|
2513
|
+
var codeUnit = str.charCodeAt(i);
|
|
2514
|
+
if (codeUnit >= 55296 && codeUnit <= 57343) {
|
|
2515
|
+
var trailSurrogate = str.charCodeAt(++i);
|
|
2516
|
+
codeUnit = 65536 + ((codeUnit & 1023) << 10) | trailSurrogate & 1023;
|
|
2517
|
+
}
|
|
2518
|
+
HEAP32[outPtr >>> 2 >>> 0] = codeUnit;
|
|
2519
|
+
outPtr += 4;
|
|
2520
|
+
if (outPtr + 4 > endPtr) break;
|
|
2521
|
+
}
|
|
2522
|
+
HEAP32[outPtr >>> 2 >>> 0] = 0;
|
|
2523
|
+
return outPtr - startPtr;
|
|
2524
|
+
};
|
|
2525
|
+
var lengthBytesUTF32 = (str) => {
|
|
2526
|
+
var len = 0;
|
|
2527
|
+
for (var i = 0; i < str.length; ++i) {
|
|
2528
|
+
var codeUnit = str.charCodeAt(i);
|
|
2529
|
+
if (codeUnit >= 55296 && codeUnit <= 57343) ++i;
|
|
2530
|
+
len += 4;
|
|
2531
|
+
}
|
|
2532
|
+
return len;
|
|
2533
|
+
};
|
|
2534
|
+
var __embind_register_std_wstring = function(rawType, charSize, name) {
|
|
2535
|
+
rawType >>>= 0;
|
|
2536
|
+
charSize >>>= 0;
|
|
2537
|
+
name >>>= 0;
|
|
2538
|
+
name = readLatin1String(name);
|
|
2539
|
+
var decodeString, encodeString, readCharAt, lengthBytesUTF;
|
|
2540
|
+
if (charSize === 2) {
|
|
2541
|
+
decodeString = UTF16ToString;
|
|
2542
|
+
encodeString = stringToUTF16;
|
|
2543
|
+
lengthBytesUTF = lengthBytesUTF16;
|
|
2544
|
+
readCharAt = (pointer) => HEAPU16[pointer >>> 1 >>> 0];
|
|
2545
|
+
} else if (charSize === 4) {
|
|
2546
|
+
decodeString = UTF32ToString;
|
|
2547
|
+
encodeString = stringToUTF32;
|
|
2548
|
+
lengthBytesUTF = lengthBytesUTF32;
|
|
2549
|
+
readCharAt = (pointer) => HEAPU32[pointer >>> 2 >>> 0];
|
|
2550
|
+
}
|
|
2551
|
+
registerType(rawType, {
|
|
2552
|
+
name,
|
|
2553
|
+
fromWireType: (value) => {
|
|
2554
|
+
var length = HEAPU32[value >>> 2 >>> 0];
|
|
2555
|
+
var str;
|
|
2556
|
+
var decodeStartPtr = value + 4;
|
|
2557
|
+
for (var i = 0; i <= length; ++i) {
|
|
2558
|
+
var currentBytePtr = value + 4 + i * charSize;
|
|
2559
|
+
if (i == length || readCharAt(currentBytePtr) == 0) {
|
|
2560
|
+
var maxReadBytes = currentBytePtr - decodeStartPtr;
|
|
2561
|
+
var stringSegment = decodeString(decodeStartPtr, maxReadBytes);
|
|
2562
|
+
if (str === void 0) {
|
|
2563
|
+
str = stringSegment;
|
|
2564
|
+
} else {
|
|
2565
|
+
str += String.fromCharCode(0);
|
|
2566
|
+
str += stringSegment;
|
|
2567
|
+
}
|
|
2568
|
+
decodeStartPtr = currentBytePtr + charSize;
|
|
2569
|
+
}
|
|
2570
|
+
}
|
|
2571
|
+
_free(value);
|
|
2572
|
+
return str;
|
|
2573
|
+
},
|
|
2574
|
+
toWireType: (destructors, value) => {
|
|
2575
|
+
if (!(typeof value == "string")) {
|
|
2576
|
+
throwBindingError(
|
|
2577
|
+
`Cannot pass non-string to C++ string type ${name}`
|
|
2578
|
+
);
|
|
2579
|
+
}
|
|
2580
|
+
var length = lengthBytesUTF(value);
|
|
2581
|
+
var ptr = _malloc(4 + length + charSize);
|
|
2582
|
+
HEAPU32[ptr >>> 2 >>> 0] = length / charSize;
|
|
2583
|
+
encodeString(value, ptr + 4, length + charSize);
|
|
2584
|
+
if (destructors !== null) {
|
|
2585
|
+
destructors.push(_free, ptr);
|
|
2586
|
+
}
|
|
2587
|
+
return ptr;
|
|
2588
|
+
},
|
|
2589
|
+
argPackAdvance: GenericWireTypeSize,
|
|
2590
|
+
readValueFromPointer: readPointer,
|
|
2591
|
+
destructorFunction(ptr) {
|
|
2592
|
+
_free(ptr);
|
|
2593
|
+
}
|
|
2594
|
+
});
|
|
2595
|
+
};
|
|
2596
|
+
function __embind_register_value_object(rawType, name, constructorSignature, rawConstructor, destructorSignature, rawDestructor) {
|
|
2597
|
+
rawType >>>= 0;
|
|
2598
|
+
name >>>= 0;
|
|
2599
|
+
constructorSignature >>>= 0;
|
|
2600
|
+
rawConstructor >>>= 0;
|
|
2601
|
+
destructorSignature >>>= 0;
|
|
2602
|
+
rawDestructor >>>= 0;
|
|
2603
|
+
structRegistrations[rawType] = {
|
|
2604
|
+
name: readLatin1String(name),
|
|
2605
|
+
rawConstructor: embind__requireFunction(constructorSignature, rawConstructor),
|
|
2606
|
+
rawDestructor: embind__requireFunction(destructorSignature, rawDestructor),
|
|
2607
|
+
fields: []
|
|
2608
|
+
};
|
|
2609
|
+
}
|
|
2610
|
+
function __embind_register_value_object_field(structType, fieldName, getterReturnType, getterSignature, getter, getterContext, setterArgumentType, setterSignature, setter, setterContext) {
|
|
2611
|
+
structType >>>= 0;
|
|
2612
|
+
fieldName >>>= 0;
|
|
2613
|
+
getterReturnType >>>= 0;
|
|
2614
|
+
getterSignature >>>= 0;
|
|
2615
|
+
getter >>>= 0;
|
|
2616
|
+
getterContext >>>= 0;
|
|
2617
|
+
setterArgumentType >>>= 0;
|
|
2618
|
+
setterSignature >>>= 0;
|
|
2619
|
+
setter >>>= 0;
|
|
2620
|
+
setterContext >>>= 0;
|
|
2621
|
+
structRegistrations[structType].fields.push({
|
|
2622
|
+
fieldName: readLatin1String(fieldName),
|
|
2623
|
+
getterReturnType,
|
|
2624
|
+
getter: embind__requireFunction(getterSignature, getter),
|
|
2625
|
+
getterContext,
|
|
2626
|
+
setterArgumentType,
|
|
2627
|
+
setter: embind__requireFunction(setterSignature, setter),
|
|
2628
|
+
setterContext
|
|
2629
|
+
});
|
|
2630
|
+
}
|
|
2631
|
+
var __embind_register_void = function(rawType, name) {
|
|
2632
|
+
rawType >>>= 0;
|
|
2633
|
+
name >>>= 0;
|
|
2634
|
+
name = readLatin1String(name);
|
|
2635
|
+
registerType(rawType, {
|
|
2636
|
+
isVoid: true,
|
|
2637
|
+
name,
|
|
2638
|
+
argPackAdvance: 0,
|
|
2639
|
+
fromWireType: () => void 0,
|
|
2640
|
+
toWireType: (destructors, o) => void 0
|
|
2641
|
+
});
|
|
2642
|
+
};
|
|
2643
|
+
var emval_returnValue = (returnType, destructorsRef, handle) => {
|
|
2644
|
+
var destructors = [];
|
|
2645
|
+
var result = returnType["toWireType"](destructors, handle);
|
|
2646
|
+
if (destructors.length) {
|
|
2647
|
+
HEAPU32[destructorsRef >>> 2 >>> 0] = Emval.toHandle(destructors);
|
|
2648
|
+
}
|
|
2649
|
+
return result;
|
|
2650
|
+
};
|
|
2651
|
+
function __emval_as(handle, returnType, destructorsRef) {
|
|
2652
|
+
handle >>>= 0;
|
|
2653
|
+
returnType >>>= 0;
|
|
2654
|
+
destructorsRef >>>= 0;
|
|
2655
|
+
handle = Emval.toValue(handle);
|
|
2656
|
+
returnType = requireRegisteredType(returnType, "emval::as");
|
|
2657
|
+
return emval_returnValue(returnType, destructorsRef, handle);
|
|
2658
|
+
}
|
|
2659
|
+
var emval_symbols = {};
|
|
2660
|
+
var getStringOrSymbol = (address) => {
|
|
2661
|
+
var symbol = emval_symbols[address];
|
|
2662
|
+
if (symbol === void 0) {
|
|
2663
|
+
return readLatin1String(address);
|
|
2664
|
+
}
|
|
2665
|
+
return symbol;
|
|
2666
|
+
};
|
|
2667
|
+
var emval_methodCallers = [];
|
|
2668
|
+
function __emval_call_method(caller, objHandle, methodName, destructorsRef, args) {
|
|
2669
|
+
caller >>>= 0;
|
|
2670
|
+
objHandle >>>= 0;
|
|
2671
|
+
methodName >>>= 0;
|
|
2672
|
+
destructorsRef >>>= 0;
|
|
2673
|
+
args >>>= 0;
|
|
2674
|
+
caller = emval_methodCallers[caller];
|
|
2675
|
+
objHandle = Emval.toValue(objHandle);
|
|
2676
|
+
methodName = getStringOrSymbol(methodName);
|
|
2677
|
+
return caller(objHandle, objHandle[methodName], destructorsRef, args);
|
|
2678
|
+
}
|
|
2679
|
+
function __emval_equals(first, second) {
|
|
2680
|
+
first >>>= 0;
|
|
2681
|
+
second >>>= 0;
|
|
2682
|
+
first = Emval.toValue(first);
|
|
2683
|
+
second = Emval.toValue(second);
|
|
2684
|
+
return first == second;
|
|
2685
|
+
}
|
|
2686
|
+
var emval_addMethodCaller = (caller) => {
|
|
2687
|
+
var id = emval_methodCallers.length;
|
|
2688
|
+
emval_methodCallers.push(caller);
|
|
2689
|
+
return id;
|
|
2690
|
+
};
|
|
2691
|
+
var emval_lookupTypes = (argCount, argTypes) => {
|
|
2692
|
+
var a = new Array(argCount);
|
|
2693
|
+
for (var i = 0; i < argCount; ++i) {
|
|
2694
|
+
a[i] = requireRegisteredType(
|
|
2695
|
+
HEAPU32[argTypes + i * 4 >>> 2 >>> 0],
|
|
2696
|
+
`parameter ${i}`
|
|
2697
|
+
);
|
|
2698
|
+
}
|
|
2699
|
+
return a;
|
|
2700
|
+
};
|
|
2701
|
+
function __emval_get_method_caller(argCount, argTypes, kind) {
|
|
2702
|
+
argTypes >>>= 0;
|
|
2703
|
+
var types = emval_lookupTypes(argCount, argTypes);
|
|
2704
|
+
var retType = types.shift();
|
|
2705
|
+
argCount--;
|
|
2706
|
+
var functionBody = `return function (obj, func, destructorsRef, args) {
|
|
2707
|
+
`;
|
|
2708
|
+
var offset = 0;
|
|
2709
|
+
var argsList = [];
|
|
2710
|
+
if (kind === 0) {
|
|
2711
|
+
argsList.push("obj");
|
|
2712
|
+
}
|
|
2713
|
+
var params = ["retType"];
|
|
2714
|
+
var args = [retType];
|
|
2715
|
+
for (var i = 0; i < argCount; ++i) {
|
|
2716
|
+
argsList.push(`arg${i}`);
|
|
2717
|
+
params.push(`argType${i}`);
|
|
2718
|
+
args.push(types[i]);
|
|
2719
|
+
functionBody += ` var arg${i} = argType${i}.readValueFromPointer(args${offset ? "+" + offset : ""});
|
|
2720
|
+
`;
|
|
2721
|
+
offset += types[i].argPackAdvance;
|
|
2722
|
+
}
|
|
2723
|
+
var invoker = kind === 1 ? "new func" : "func.call";
|
|
2724
|
+
functionBody += ` var rv = ${invoker}(${argsList.join(", ")});
|
|
2725
|
+
`;
|
|
2726
|
+
if (!retType.isVoid) {
|
|
2727
|
+
params.push("emval_returnValue");
|
|
2728
|
+
args.push(emval_returnValue);
|
|
2729
|
+
functionBody += " return emval_returnValue(retType, destructorsRef, rv);\n";
|
|
2730
|
+
}
|
|
2731
|
+
functionBody += "};\n";
|
|
2732
|
+
var invokerFunction = new Function(...params, functionBody)(...args);
|
|
2733
|
+
var functionName = `methodCaller<(${types.map((t) => t.name).join(", ")}) => ${retType.name}>`;
|
|
2734
|
+
return emval_addMethodCaller(
|
|
2735
|
+
createNamedFunction(functionName, invokerFunction)
|
|
2736
|
+
);
|
|
2737
|
+
}
|
|
2738
|
+
function __emval_get_property(handle, key) {
|
|
2739
|
+
handle >>>= 0;
|
|
2740
|
+
key >>>= 0;
|
|
2741
|
+
handle = Emval.toValue(handle);
|
|
2742
|
+
key = Emval.toValue(key);
|
|
2743
|
+
return Emval.toHandle(handle[key]);
|
|
2744
|
+
}
|
|
2745
|
+
function __emval_incref(handle) {
|
|
2746
|
+
handle >>>= 0;
|
|
2747
|
+
if (handle > 9) {
|
|
2748
|
+
emval_handles[handle + 1] += 1;
|
|
2749
|
+
}
|
|
2750
|
+
}
|
|
2751
|
+
function __emval_new_cstring(v) {
|
|
2752
|
+
v >>>= 0;
|
|
2753
|
+
return Emval.toHandle(getStringOrSymbol(v));
|
|
2754
|
+
}
|
|
2755
|
+
function __emval_new_object() {
|
|
2756
|
+
return Emval.toHandle({});
|
|
2757
|
+
}
|
|
2758
|
+
function __emval_run_destructors(handle) {
|
|
2759
|
+
handle >>>= 0;
|
|
2760
|
+
var destructors = Emval.toValue(handle);
|
|
2761
|
+
runDestructors(destructors);
|
|
2762
|
+
__emval_decref(handle);
|
|
2763
|
+
}
|
|
2764
|
+
function __emval_set_property(handle, key, value) {
|
|
2765
|
+
handle >>>= 0;
|
|
2766
|
+
key >>>= 0;
|
|
2767
|
+
value >>>= 0;
|
|
2768
|
+
handle = Emval.toValue(handle);
|
|
2769
|
+
key = Emval.toValue(key);
|
|
2770
|
+
value = Emval.toValue(value);
|
|
2771
|
+
handle[key] = value;
|
|
2772
|
+
}
|
|
2773
|
+
function __emval_take_value(type, arg) {
|
|
2774
|
+
type >>>= 0;
|
|
2775
|
+
arg >>>= 0;
|
|
2776
|
+
type = requireRegisteredType(type, "_emval_take_value");
|
|
2777
|
+
var v = type["readValueFromPointer"](arg);
|
|
2778
|
+
return Emval.toHandle(v);
|
|
2779
|
+
}
|
|
2780
|
+
var getHeapMax = () => 4294901760;
|
|
2781
|
+
var alignMemory = (size, alignment) => Math.ceil(size / alignment) * alignment;
|
|
2782
|
+
var growMemory = (size) => {
|
|
2783
|
+
var b = wasmMemory.buffer;
|
|
2784
|
+
var pages = (size - b.byteLength + 65535) / 65536 | 0;
|
|
2785
|
+
try {
|
|
2786
|
+
wasmMemory.grow(pages);
|
|
2787
|
+
updateMemoryViews();
|
|
2788
|
+
return 1;
|
|
2789
|
+
} catch (e) {
|
|
2790
|
+
}
|
|
2791
|
+
};
|
|
2792
|
+
function _emscripten_resize_heap(requestedSize) {
|
|
2793
|
+
requestedSize >>>= 0;
|
|
2794
|
+
var oldSize = HEAPU8.length;
|
|
2795
|
+
var maxHeapSize = getHeapMax();
|
|
2796
|
+
if (requestedSize > maxHeapSize) {
|
|
2797
|
+
return false;
|
|
2798
|
+
}
|
|
2799
|
+
for (var cutDown = 1; cutDown <= 4; cutDown *= 2) {
|
|
2800
|
+
var overGrownHeapSize = oldSize * (1 + 0.2 / cutDown);
|
|
2801
|
+
overGrownHeapSize = Math.min(overGrownHeapSize, requestedSize + 100663296);
|
|
2802
|
+
var newSize = Math.min(
|
|
2803
|
+
maxHeapSize,
|
|
2804
|
+
alignMemory(Math.max(requestedSize, overGrownHeapSize), 65536)
|
|
2805
|
+
);
|
|
2806
|
+
var replacement = growMemory(newSize);
|
|
2807
|
+
if (replacement) {
|
|
2808
|
+
return true;
|
|
2809
|
+
}
|
|
2810
|
+
}
|
|
2811
|
+
return false;
|
|
2812
|
+
}
|
|
2813
|
+
var uleb128Encode = (n, target) => {
|
|
2814
|
+
if (n < 128) {
|
|
2815
|
+
target.push(n);
|
|
2816
|
+
} else {
|
|
2817
|
+
target.push(n % 128 | 128, n >> 7);
|
|
2818
|
+
}
|
|
2819
|
+
};
|
|
2820
|
+
var sigToWasmTypes = (sig) => {
|
|
2821
|
+
var typeNames = { i: "i32", j: "i64", f: "f32", d: "f64", e: "externref", p: "i32" };
|
|
2822
|
+
var type = {
|
|
2823
|
+
parameters: [],
|
|
2824
|
+
results: sig[0] == "v" ? [] : [typeNames[sig[0]]]
|
|
2825
|
+
};
|
|
2826
|
+
for (var i = 1; i < sig.length; ++i) {
|
|
2827
|
+
type.parameters.push(typeNames[sig[i]]);
|
|
2828
|
+
}
|
|
2829
|
+
return type;
|
|
2830
|
+
};
|
|
2831
|
+
var generateFuncType = (sig, target) => {
|
|
2832
|
+
var sigRet = sig.slice(0, 1);
|
|
2833
|
+
var sigParam = sig.slice(1);
|
|
2834
|
+
var typeCodes = { i: 127, p: 127, j: 126, f: 125, d: 124, e: 111 };
|
|
2835
|
+
target.push(96);
|
|
2836
|
+
uleb128Encode(sigParam.length, target);
|
|
2837
|
+
for (var paramType of sigParam) {
|
|
2838
|
+
target.push(typeCodes[paramType]);
|
|
2839
|
+
}
|
|
2840
|
+
if (sigRet == "v") {
|
|
2841
|
+
target.push(0);
|
|
2842
|
+
} else {
|
|
2843
|
+
target.push(1, typeCodes[sigRet]);
|
|
2844
|
+
}
|
|
2845
|
+
};
|
|
2846
|
+
var convertJsFunctionToWasm = (func, sig) => {
|
|
2847
|
+
if (typeof WebAssembly.Function == "function") {
|
|
2848
|
+
return new WebAssembly.Function(sigToWasmTypes(sig), func);
|
|
2849
|
+
}
|
|
2850
|
+
var typeSectionBody = [1];
|
|
2851
|
+
generateFuncType(sig, typeSectionBody);
|
|
2852
|
+
var bytes = [0, 97, 115, 109, 1, 0, 0, 0, 1];
|
|
2853
|
+
uleb128Encode(typeSectionBody.length, bytes);
|
|
2854
|
+
bytes.push(...typeSectionBody);
|
|
2855
|
+
bytes.push(2, 7, 1, 1, 101, 1, 102, 0, 0, 7, 5, 1, 1, 102, 0, 0);
|
|
2856
|
+
var module = new WebAssembly.Module(new Uint8Array(bytes));
|
|
2857
|
+
var instance = new WebAssembly.Instance(module, { e: { f: func } });
|
|
2858
|
+
var wrappedFunc = instance.exports["f"];
|
|
2859
|
+
return wrappedFunc;
|
|
2860
|
+
};
|
|
2861
|
+
var updateTableMap = (offset, count) => {
|
|
2862
|
+
if (functionsInTableMap) {
|
|
2863
|
+
for (var i = offset; i < offset + count; i++) {
|
|
2864
|
+
var item = getWasmTableEntry(i);
|
|
2865
|
+
if (item) {
|
|
2866
|
+
functionsInTableMap.set(item, i);
|
|
2867
|
+
}
|
|
2868
|
+
}
|
|
2869
|
+
}
|
|
2870
|
+
};
|
|
2871
|
+
var functionsInTableMap;
|
|
2872
|
+
var getFunctionAddress = (func) => {
|
|
2873
|
+
if (!functionsInTableMap) {
|
|
2874
|
+
functionsInTableMap = /* @__PURE__ */ new WeakMap();
|
|
2875
|
+
updateTableMap(0, wasmTable.length);
|
|
2876
|
+
}
|
|
2877
|
+
return functionsInTableMap.get(func) || 0;
|
|
2878
|
+
};
|
|
2879
|
+
var freeTableIndexes = [];
|
|
2880
|
+
var getEmptyTableSlot = () => {
|
|
2881
|
+
if (freeTableIndexes.length) {
|
|
2882
|
+
return freeTableIndexes.pop();
|
|
2883
|
+
}
|
|
2884
|
+
try {
|
|
2885
|
+
wasmTable.grow(1);
|
|
2886
|
+
} catch (err2) {
|
|
2887
|
+
if (!(err2 instanceof RangeError)) {
|
|
2888
|
+
throw err2;
|
|
2889
|
+
}
|
|
2890
|
+
throw "Unable to grow wasm table. Set ALLOW_TABLE_GROWTH.";
|
|
2891
|
+
}
|
|
2892
|
+
return wasmTable.length - 1;
|
|
2893
|
+
};
|
|
2894
|
+
var setWasmTableEntry = (idx, func) => wasmTable.set(idx, func);
|
|
2895
|
+
var addFunction = (func, sig) => {
|
|
2896
|
+
var rtn = getFunctionAddress(func);
|
|
2897
|
+
if (rtn) {
|
|
2898
|
+
return rtn;
|
|
2899
|
+
}
|
|
2900
|
+
var ret = getEmptyTableSlot();
|
|
2901
|
+
try {
|
|
2902
|
+
setWasmTableEntry(ret, func);
|
|
2903
|
+
} catch (err2) {
|
|
2904
|
+
if (!(err2 instanceof TypeError)) {
|
|
2905
|
+
throw err2;
|
|
2906
|
+
}
|
|
2907
|
+
var wrapped = convertJsFunctionToWasm(func, sig);
|
|
2908
|
+
setWasmTableEntry(ret, wrapped);
|
|
2909
|
+
}
|
|
2910
|
+
functionsInTableMap.set(func, ret);
|
|
2911
|
+
return ret;
|
|
2912
|
+
};
|
|
2913
|
+
var removeFunction = (index) => {
|
|
2914
|
+
functionsInTableMap.delete(getWasmTableEntry(index));
|
|
2915
|
+
setWasmTableEntry(index, null);
|
|
2916
|
+
freeTableIndexes.push(index);
|
|
2917
|
+
};
|
|
2918
|
+
embind_init_charCodes();
|
|
2919
|
+
init_ClassHandle();
|
|
2920
|
+
init_RegisteredPointer();
|
|
2921
|
+
init_emval();
|
|
2922
|
+
var wasmImports = {
|
|
2923
|
+
i: ___cxa_throw,
|
|
2924
|
+
C: __abort_js,
|
|
2925
|
+
n: __embind_finalize_value_object,
|
|
2926
|
+
x: __embind_register_bigint,
|
|
2927
|
+
G: __embind_register_bool,
|
|
2928
|
+
h: __embind_register_class,
|
|
2929
|
+
g: __embind_register_class_constructor,
|
|
2930
|
+
a: __embind_register_class_function,
|
|
2931
|
+
E: __embind_register_emval,
|
|
2932
|
+
t: __embind_register_enum,
|
|
2933
|
+
f: __embind_register_enum_value,
|
|
2934
|
+
w: __embind_register_float,
|
|
2935
|
+
c: __embind_register_function,
|
|
2936
|
+
j: __embind_register_integer,
|
|
2937
|
+
e: __embind_register_memory_view,
|
|
2938
|
+
k: __embind_register_optional,
|
|
2939
|
+
F: __embind_register_std_string,
|
|
2940
|
+
s: __embind_register_std_wstring,
|
|
2941
|
+
o: __embind_register_value_object,
|
|
2942
|
+
l: __embind_register_value_object_field,
|
|
2943
|
+
H: __embind_register_void,
|
|
2944
|
+
v: __emval_as,
|
|
2945
|
+
z: __emval_call_method,
|
|
2946
|
+
b: __emval_decref,
|
|
2947
|
+
m: __emval_equals,
|
|
2948
|
+
y: __emval_get_method_caller,
|
|
2949
|
+
B: __emval_get_property,
|
|
2950
|
+
u: __emval_incref,
|
|
2951
|
+
q: __emval_new_cstring,
|
|
2952
|
+
A: __emval_new_object,
|
|
2953
|
+
p: __emval_run_destructors,
|
|
2954
|
+
r: __emval_set_property,
|
|
2955
|
+
d: __emval_take_value,
|
|
2956
|
+
D: _emscripten_resize_heap
|
|
2957
|
+
};
|
|
2958
|
+
var wasmExports = await createWasm();
|
|
2959
|
+
wasmExports["J"];
|
|
2960
|
+
var ___getTypeName = wasmExports["K"];
|
|
2961
|
+
var _free = wasmExports["M"];
|
|
2962
|
+
var _malloc = wasmExports["N"];
|
|
2963
|
+
function applySignatureConversions(wasmExports2) {
|
|
2964
|
+
wasmExports2 = Object.assign({}, wasmExports2);
|
|
2965
|
+
var makeWrapper_pp = (f) => (a0) => f(a0) >>> 0;
|
|
2966
|
+
var makeWrapper_p = (f) => () => f() >>> 0;
|
|
2967
|
+
wasmExports2["K"] = makeWrapper_pp(wasmExports2["K"]);
|
|
2968
|
+
wasmExports2["N"] = makeWrapper_pp(wasmExports2["N"]);
|
|
2969
|
+
wasmExports2["_emscripten_stack_alloc"] = makeWrapper_pp(wasmExports2["_emscripten_stack_alloc"]);
|
|
2970
|
+
wasmExports2["emscripten_stack_get_current"] = makeWrapper_p(wasmExports2["emscripten_stack_get_current"]);
|
|
2971
|
+
return wasmExports2;
|
|
2972
|
+
}
|
|
2973
|
+
Module2["addFunction"] = addFunction;
|
|
2974
|
+
Module2["removeFunction"] = removeFunction;
|
|
2975
|
+
function run() {
|
|
2976
|
+
if (runDependencies > 0) {
|
|
2977
|
+
dependenciesFulfilled = run;
|
|
2978
|
+
return;
|
|
2979
|
+
}
|
|
2980
|
+
preRun();
|
|
2981
|
+
if (runDependencies > 0) {
|
|
2982
|
+
dependenciesFulfilled = run;
|
|
2983
|
+
return;
|
|
2984
|
+
}
|
|
2985
|
+
function doRun() {
|
|
2986
|
+
var _a;
|
|
2987
|
+
Module2["calledRun"] = true;
|
|
2988
|
+
if (ABORT) return;
|
|
2989
|
+
initRuntime();
|
|
2990
|
+
readyPromiseResolve(Module2);
|
|
2991
|
+
(_a = Module2["onRuntimeInitialized"]) == null ? void 0 : _a.call(Module2);
|
|
2992
|
+
postRun();
|
|
2993
|
+
}
|
|
2994
|
+
if (Module2["setStatus"]) {
|
|
2995
|
+
Module2["setStatus"]("Running...");
|
|
2996
|
+
setTimeout(() => {
|
|
2997
|
+
setTimeout(() => Module2["setStatus"](""), 1);
|
|
2998
|
+
doRun();
|
|
2999
|
+
}, 1);
|
|
3000
|
+
} else {
|
|
3001
|
+
doRun();
|
|
3002
|
+
}
|
|
3003
|
+
}
|
|
3004
|
+
if (Module2["preInit"]) {
|
|
3005
|
+
if (typeof Module2["preInit"] == "function")
|
|
3006
|
+
Module2["preInit"] = [Module2["preInit"]];
|
|
3007
|
+
while (Module2["preInit"].length > 0) {
|
|
3008
|
+
Module2["preInit"].pop()();
|
|
3009
|
+
}
|
|
3010
|
+
}
|
|
3011
|
+
run();
|
|
3012
|
+
moduleRtn = readyPromise;
|
|
3013
|
+
return moduleRtn;
|
|
3014
|
+
});
|
|
3015
|
+
})();
|
|
3016
|
+
export {
|
|
3017
|
+
Module as default
|
|
3018
|
+
};
|