11ty-plugin-giallo 0.1.0-alpha.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,2807 @@
1
+ import { environment, exit as exit$1, stderr, stdin, stdout } from '@bytecodealliance/preview2-shim/cli';
2
+ import { preopens, types } from '@bytecodealliance/preview2-shim/filesystem';
3
+ import { error, streams } from '@bytecodealliance/preview2-shim/io';
4
+ import { insecureSeed as insecureSeed$1 } from '@bytecodealliance/preview2-shim/random';
5
+ const { getEnvironment } = environment;
6
+ const { exit } = exit$1;
7
+ const { getStderr } = stderr;
8
+ const { getStdin } = stdin;
9
+ const { getStdout } = stdout;
10
+ const { getDirectories } = preopens;
11
+ const { Descriptor,
12
+ filesystemErrorCode } = types;
13
+ const { Error: Error$1 } = error;
14
+ const { InputStream,
15
+ OutputStream } = streams;
16
+ const { insecureSeed } = insecureSeed$1;
17
+
18
+ let dv = new DataView(new ArrayBuffer());
19
+ const dataView = mem => dv.buffer === mem.buffer ? dv : dv = new DataView(mem.buffer);
20
+
21
+ const toUint64 = val => BigInt.asUintN(64, BigInt(val));
22
+
23
+ function toUint32(val) {
24
+ return val >>> 0;
25
+ }
26
+
27
+ const utf8Decoder = new TextDecoder();
28
+
29
+ const utf8Encoder = new TextEncoder();
30
+ let utf8EncodedLen = 0;
31
+ function utf8Encode(s, realloc, memory) {
32
+ if (typeof s !== 'string') throw new TypeError('expected a string');
33
+ if (s.length === 0) {
34
+ utf8EncodedLen = 0;
35
+ return 1;
36
+ }
37
+ let buf = utf8Encoder.encode(s);
38
+ let ptr = realloc(0, 0, 1, buf.length);
39
+ new Uint8Array(memory.buffer).set(buf, ptr);
40
+ utf8EncodedLen = buf.length;
41
+ return ptr;
42
+ }
43
+
44
+ const T_FLAG = 1 << 30;
45
+
46
+ function rscTableCreateOwn (table, rep) {
47
+ const free = table[0] & ~T_FLAG;
48
+ if (free === 0) {
49
+ table.push(0);
50
+ table.push(rep | T_FLAG);
51
+ return (table.length >> 1) - 1;
52
+ }
53
+ table[0] = table[free << 1];
54
+ table[free << 1] = 0;
55
+ table[(free << 1) + 1] = rep | T_FLAG;
56
+ return free;
57
+ }
58
+
59
+ function rscTableRemove (table, handle) {
60
+ const scope = table[handle << 1];
61
+ const val = table[(handle << 1) + 1];
62
+ const own = (val & T_FLAG) !== 0;
63
+ const rep = val & ~T_FLAG;
64
+ if (val === 0 || (scope & T_FLAG) !== 0) throw new TypeError('Invalid handle');
65
+ table[handle << 1] = table[0] | T_FLAG;
66
+ table[0] = handle | T_FLAG;
67
+ return { rep, scope, own };
68
+ }
69
+
70
+ let curResourceBorrows = [];
71
+
72
+ let NEXT_TASK_ID = 0n;
73
+ function startCurrentTask(componentIdx, isAsync, entryFnName) {
74
+ _debugLog('[startCurrentTask()] args', { componentIdx, isAsync });
75
+ if (componentIdx === undefined || componentIdx === null) {
76
+ throw new Error('missing/invalid component instance index while starting task');
77
+ }
78
+ const tasks = ASYNC_TASKS_BY_COMPONENT_IDX.get(componentIdx);
79
+
80
+ const nextId = ++NEXT_TASK_ID;
81
+ const newTask = new AsyncTask({ id: nextId, componentIdx, isAsync, entryFnName });
82
+ const newTaskMeta = { id: nextId, componentIdx, task: newTask };
83
+
84
+ ASYNC_CURRENT_TASK_IDS.push(nextId);
85
+ ASYNC_CURRENT_COMPONENT_IDXS.push(componentIdx);
86
+
87
+ if (!tasks) {
88
+ ASYNC_TASKS_BY_COMPONENT_IDX.set(componentIdx, [newTaskMeta]);
89
+ return nextId;
90
+ } else {
91
+ tasks.push(newTaskMeta);
92
+ }
93
+
94
+ return nextId;
95
+ }
96
+
97
+ function endCurrentTask(componentIdx, taskId) {
98
+ _debugLog('[endCurrentTask()] args', { componentIdx });
99
+ componentIdx ??= ASYNC_CURRENT_COMPONENT_IDXS.at(-1);
100
+ taskId ??= ASYNC_CURRENT_TASK_IDS.at(-1);
101
+ if (componentIdx === undefined || componentIdx === null) {
102
+ throw new Error('missing/invalid component instance index while ending current task');
103
+ }
104
+ const tasks = ASYNC_TASKS_BY_COMPONENT_IDX.get(componentIdx);
105
+ if (!tasks || !Array.isArray(tasks)) {
106
+ throw new Error('missing/invalid tasks for component instance while ending task');
107
+ }
108
+ if (tasks.length == 0) {
109
+ throw new Error('no current task(s) for component instance while ending task');
110
+ }
111
+
112
+ if (taskId) {
113
+ const last = tasks[tasks.length - 1];
114
+ if (last.id !== taskId) {
115
+ throw new Error('current task does not match expected task ID');
116
+ }
117
+ }
118
+
119
+ ASYNC_CURRENT_TASK_IDS.pop();
120
+ ASYNC_CURRENT_COMPONENT_IDXS.pop();
121
+
122
+ return tasks.pop();
123
+ }
124
+ const ASYNC_TASKS_BY_COMPONENT_IDX = new Map();
125
+ const ASYNC_CURRENT_TASK_IDS = [];
126
+ const ASYNC_CURRENT_COMPONENT_IDXS = [];
127
+
128
+ class AsyncTask {
129
+ static State = {
130
+ INITIAL: 'initial',
131
+ CANCELLED: 'cancelled',
132
+ CANCEL_PENDING: 'cancel-pending',
133
+ CANCEL_DELIVERED: 'cancel-delivered',
134
+ RESOLVED: 'resolved',
135
+ }
136
+
137
+ static BlockResult = {
138
+ CANCELLED: 'block.cancelled',
139
+ NOT_CANCELLED: 'block.not-cancelled',
140
+ }
141
+
142
+ #id;
143
+ #componentIdx;
144
+ #state;
145
+ #isAsync;
146
+ #onResolve = null;
147
+ #entryFnName = null;
148
+ #subtasks = [];
149
+ #completionPromise = null;
150
+
151
+ cancelled = false;
152
+ requested = false;
153
+ alwaysTaskReturn = false;
154
+
155
+ returnCalls = 0;
156
+ storage = [0, 0];
157
+ borrowedHandles = {};
158
+
159
+ awaitableResume = null;
160
+ awaitableCancel = null;
161
+
162
+
163
+ constructor(opts) {
164
+ if (opts?.id === undefined) { throw new TypeError('missing task ID during task creation'); }
165
+ this.#id = opts.id;
166
+ if (opts?.componentIdx === undefined) {
167
+ throw new TypeError('missing component id during task creation');
168
+ }
169
+ this.#componentIdx = opts.componentIdx;
170
+ this.#state = AsyncTask.State.INITIAL;
171
+ this.#isAsync = opts?.isAsync ?? false;
172
+ this.#entryFnName = opts.entryFnName;
173
+
174
+ const {
175
+ promise: completionPromise,
176
+ resolve: resolveCompletionPromise,
177
+ reject: rejectCompletionPromise,
178
+ } = Promise.withResolvers();
179
+ this.#completionPromise = completionPromise;
180
+
181
+ this.#onResolve = (results) => {
182
+ // TODO: handle external facing cancellation (should likely be a rejection)
183
+ resolveCompletionPromise(results);
184
+ }
185
+ }
186
+
187
+ taskState() { return this.#state.slice(); }
188
+ id() { return this.#id; }
189
+ componentIdx() { return this.#componentIdx; }
190
+ isAsync() { return this.#isAsync; }
191
+ entryFnName() { return this.#entryFnName; }
192
+ completionPromise() { return this.#completionPromise; }
193
+
194
+ mayEnter(task) {
195
+ const cstate = getOrCreateAsyncState(this.#componentIdx);
196
+ if (!cstate.backpressure) {
197
+ _debugLog('[AsyncTask#mayEnter()] disallowed due to backpressure', { taskID: this.#id });
198
+ return false;
199
+ }
200
+ if (!cstate.callingSyncImport()) {
201
+ _debugLog('[AsyncTask#mayEnter()] disallowed due to sync import call', { taskID: this.#id });
202
+ return false;
203
+ }
204
+ const callingSyncExportWithSyncPending = cstate.callingSyncExport && !task.isAsync;
205
+ if (!callingSyncExportWithSyncPending) {
206
+ _debugLog('[AsyncTask#mayEnter()] disallowed due to sync export w/ sync pending', { taskID: this.#id });
207
+ return false;
208
+ }
209
+ return true;
210
+ }
211
+
212
+ async enter() {
213
+ _debugLog('[AsyncTask#enter()] args', { taskID: this.#id });
214
+
215
+ // TODO: assert scheduler locked
216
+ // TODO: trap if on the stack
217
+
218
+ const cstate = getOrCreateAsyncState(this.#componentIdx);
219
+
220
+ let mayNotEnter = !this.mayEnter(this);
221
+ const componentHasPendingTasks = cstate.pendingTasks > 0;
222
+ if (mayNotEnter || componentHasPendingTasks) {
223
+ throw new Error('in enter()'); // TODO: remove
224
+ cstate.pendingTasks.set(this.#id, new Awaitable(new Promise()));
225
+
226
+ const blockResult = await this.onBlock(awaitable);
227
+ if (blockResult) {
228
+ // TODO: find this pending task in the component
229
+ const pendingTask = cstate.pendingTasks.get(this.#id);
230
+ if (!pendingTask) {
231
+ throw new Error('pending task [' + this.#id + '] not found for component instance');
232
+ }
233
+ cstate.pendingTasks.remove(this.#id);
234
+ this.#onResolve(new Error('failed enter'));
235
+ return false;
236
+ }
237
+
238
+ mayNotEnter = !this.mayEnter(this);
239
+ if (!mayNotEnter || !cstate.startPendingTask) {
240
+ throw new Error('invalid component entrance/pending task resolution');
241
+ }
242
+ cstate.startPendingTask = false;
243
+ }
244
+
245
+ if (!this.isAsync) { cstate.callingSyncExport = true; }
246
+
247
+ return true;
248
+ }
249
+
250
+ async waitForEvent(opts) {
251
+ const { waitableSetRep, isAsync } = opts;
252
+ _debugLog('[AsyncTask#waitForEvent()] args', { taskID: this.#id, waitableSetRep, isAsync });
253
+
254
+ if (this.#isAsync !== isAsync) {
255
+ throw new Error('async waitForEvent called on non-async task');
256
+ }
257
+
258
+ if (this.status === AsyncTask.State.CANCEL_PENDING) {
259
+ this.#state = AsyncTask.State.CANCEL_DELIVERED;
260
+ return {
261
+ code: ASYNC_EVENT_CODE.TASK_CANCELLED,
262
+ };
263
+ }
264
+
265
+ const state = getOrCreateAsyncState(this.#componentIdx);
266
+ const waitableSet = state.waitableSets.get(waitableSetRep);
267
+ if (!waitableSet) { throw new Error('missing/invalid waitable set'); }
268
+
269
+ waitableSet.numWaiting += 1;
270
+ let event = null;
271
+
272
+ while (event == null) {
273
+ const awaitable = new Awaitable(waitableSet.getPendingEvent());
274
+ const waited = await this.blockOn({ awaitable, isAsync, isCancellable: true });
275
+ if (waited) {
276
+ if (this.#state !== AsyncTask.State.INITIAL) {
277
+ throw new Error('task should be in initial state found [' + this.#state + ']');
278
+ }
279
+ this.#state = AsyncTask.State.CANCELLED;
280
+ return {
281
+ code: ASYNC_EVENT_CODE.TASK_CANCELLED,
282
+ };
283
+ }
284
+
285
+ event = waitableSet.poll();
286
+ }
287
+
288
+ waitableSet.numWaiting -= 1;
289
+ return event;
290
+ }
291
+
292
+ waitForEventSync(opts) {
293
+ throw new Error('AsyncTask#yieldSync() not implemented')
294
+ }
295
+
296
+ async pollForEvent(opts) {
297
+ const { waitableSetRep, isAsync } = opts;
298
+ _debugLog('[AsyncTask#pollForEvent()] args', { taskID: this.#id, waitableSetRep, isAsync });
299
+
300
+ if (this.#isAsync !== isAsync) {
301
+ throw new Error('async pollForEvent called on non-async task');
302
+ }
303
+
304
+ throw new Error('AsyncTask#pollForEvent() not implemented');
305
+ }
306
+
307
+ pollForEventSync(opts) {
308
+ throw new Error('AsyncTask#yieldSync() not implemented')
309
+ }
310
+
311
+ async blockOn(opts) {
312
+ const { awaitable, isCancellable, forCallback } = opts;
313
+ _debugLog('[AsyncTask#blockOn()] args', { taskID: this.#id, awaitable, isCancellable, forCallback });
314
+
315
+ if (awaitable.resolved() && !ASYNC_DETERMINISM && _coinFlip()) {
316
+ return AsyncTask.BlockResult.NOT_CANCELLED;
317
+ }
318
+
319
+ const cstate = getOrCreateAsyncState(this.#componentIdx);
320
+ if (forCallback) { cstate.exclusiveRelease(); }
321
+
322
+ let cancelled = await this.onBlock(awaitable);
323
+ if (cancelled === AsyncTask.BlockResult.CANCELLED && !isCancellable) {
324
+ const secondCancel = await this.onBlock(awaitable);
325
+ if (secondCancel !== AsyncTask.BlockResult.NOT_CANCELLED) {
326
+ throw new Error('uncancellable task was canceled despite second onBlock()');
327
+ }
328
+ }
329
+
330
+ if (forCallback) {
331
+ const acquired = new Awaitable(cstate.exclusiveLock());
332
+ cancelled = await this.onBlock(acquired);
333
+ if (cancelled === AsyncTask.BlockResult.CANCELLED) {
334
+ const secondCancel = await this.onBlock(acquired);
335
+ if (secondCancel !== AsyncTask.BlockResult.NOT_CANCELLED) {
336
+ throw new Error('uncancellable callback task was canceled despite second onBlock()');
337
+ }
338
+ }
339
+ }
340
+
341
+ if (cancelled === AsyncTask.BlockResult.CANCELLED) {
342
+ if (this.#state !== AsyncTask.State.INITIAL) {
343
+ throw new Error('cancelled task is not at initial state');
344
+ }
345
+ if (isCancellable) {
346
+ this.#state = AsyncTask.State.CANCELLED;
347
+ return AsyncTask.BlockResult.CANCELLED;
348
+ } else {
349
+ this.#state = AsyncTask.State.CANCEL_PENDING;
350
+ return AsyncTask.BlockResult.NOT_CANCELLED;
351
+ }
352
+ }
353
+
354
+ return AsyncTask.BlockResult.NOT_CANCELLED;
355
+ }
356
+
357
+ async onBlock(awaitable) {
358
+ _debugLog('[AsyncTask#onBlock()] args', { taskID: this.#id, awaitable });
359
+ if (!(awaitable instanceof Awaitable)) {
360
+ throw new Error('invalid awaitable during onBlock');
361
+ }
362
+
363
+ // Build a promise that this task can await on which resolves when it is awoken
364
+ const { promise, resolve, reject } = Promise.withResolvers();
365
+ this.awaitableResume = () => {
366
+ _debugLog('[AsyncTask] resuming after onBlock', { taskID: this.#id });
367
+ resolve();
368
+ };
369
+ this.awaitableCancel = (err) => {
370
+ _debugLog('[AsyncTask] rejecting after onBlock', { taskID: this.#id, err });
371
+ reject(err);
372
+ };
373
+
374
+ // Park this task/execution to be handled later
375
+ const state = getOrCreateAsyncState(this.#componentIdx);
376
+ state.parkTaskOnAwaitable({ awaitable, task: this });
377
+
378
+ try {
379
+ await promise;
380
+ return AsyncTask.BlockResult.NOT_CANCELLED;
381
+ } catch (err) {
382
+ // rejection means task cancellation
383
+ return AsyncTask.BlockResult.CANCELLED;
384
+ }
385
+ }
386
+
387
+ async asyncOnBlock(awaitable) {
388
+ _debugLog('[AsyncTask#asyncOnBlock()] args', { taskID: this.#id, awaitable });
389
+ if (!(awaitable instanceof Awaitable)) {
390
+ throw new Error('invalid awaitable during onBlock');
391
+ }
392
+ // TODO: watch for waitable AND cancellation
393
+ // TODO: if it WAS cancelled:
394
+ // - return true
395
+ // - only once per subtask
396
+ // - do not wait on the scheduler
397
+ // - control flow should go to the subtask (only once)
398
+ // - Once subtask blocks/resolves, reqlinquishControl() will tehn resolve request_cancel_end (without scheduler lock release)
399
+ // - control flow goes back to request_cancel
400
+ //
401
+ // Subtask cancellation should work similarly to an async import call -- runs sync up until
402
+ // the subtask blocks or resolves
403
+ //
404
+ throw new Error('AsyncTask#asyncOnBlock() not yet implemented');
405
+ }
406
+
407
+ async yield(opts) {
408
+ const { isCancellable, forCallback } = opts;
409
+ _debugLog('[AsyncTask#yield()] args', { taskID: this.#id, isCancellable, forCallback });
410
+
411
+ if (isCancellable && this.status === AsyncTask.State.CANCEL_PENDING) {
412
+ this.#state = AsyncTask.State.CANCELLED;
413
+ return {
414
+ code: ASYNC_EVENT_CODE.TASK_CANCELLED,
415
+ payload: [0, 0],
416
+ };
417
+ }
418
+
419
+ // TODO: Awaitables need to *always* trigger the parking mechanism when they're done...?
420
+ // TODO: Component async state should remember which awaitables are done and work to clear tasks waiting
421
+
422
+ const blockResult = await this.blockOn({
423
+ awaitable: new Awaitable(new Promise(resolve => setTimeout(resolve, 0))),
424
+ isCancellable,
425
+ forCallback,
426
+ });
427
+
428
+ if (blockResult === AsyncTask.BlockResult.CANCELLED) {
429
+ if (this.#state !== AsyncTask.State.INITIAL) {
430
+ throw new Error('task should be in initial state found [' + this.#state + ']');
431
+ }
432
+ this.#state = AsyncTask.State.CANCELLED;
433
+ return {
434
+ code: ASYNC_EVENT_CODE.TASK_CANCELLED,
435
+ payload: [0, 0],
436
+ };
437
+ }
438
+
439
+ return {
440
+ code: ASYNC_EVENT_CODE.NONE,
441
+ payload: [0, 0],
442
+ };
443
+ }
444
+
445
+ yieldSync(opts) {
446
+ throw new Error('AsyncTask#yieldSync() not implemented')
447
+ }
448
+
449
+ cancel() {
450
+ _debugLog('[AsyncTask#cancel()] args', { });
451
+ if (!this.taskState() !== AsyncTask.State.CANCEL_DELIVERED) {
452
+ throw new Error('invalid task state for cancellation');
453
+ }
454
+ if (this.borrowedHandles.length > 0) { throw new Error('task still has borrow handles'); }
455
+
456
+ this.#onResolve(new Error('cancelled'));
457
+ this.#state = AsyncTask.State.RESOLVED;
458
+ }
459
+
460
+ resolve(results) {
461
+ _debugLog('[AsyncTask#resolve()] args', { results });
462
+ if (this.#state === AsyncTask.State.RESOLVED) {
463
+ throw new Error('task is already resolved');
464
+ }
465
+ if (this.borrowedHandles.length > 0) { throw new Error('task still has borrow handles'); }
466
+ this.#onResolve(results.length === 1 ? results[0] : results);
467
+ this.#state = AsyncTask.State.RESOLVED;
468
+ }
469
+
470
+ exit() {
471
+ _debugLog('[AsyncTask#exit()] args', { });
472
+
473
+ // TODO: ensure there is only one task at a time (scheduler.lock() functionality)
474
+ if (this.#state !== AsyncTask.State.RESOLVED) {
475
+ throw new Error('task exited without resolution');
476
+ }
477
+ if (this.borrowedHandles > 0) {
478
+ throw new Error('task exited without clearing borrowed handles');
479
+ }
480
+
481
+ const state = getOrCreateAsyncState(this.#componentIdx);
482
+ if (!state) { throw new Error('missing async state for component [' + this.#componentIdx + ']'); }
483
+ if (!this.#isAsync && !state.inSyncExportCall) {
484
+ throw new Error('sync task must be run from components known to be in a sync export call');
485
+ }
486
+ state.inSyncExportCall = false;
487
+
488
+ this.startPendingTask();
489
+ }
490
+
491
+ startPendingTask(args) {
492
+ _debugLog('[AsyncTask#startPendingTask()] args', args);
493
+ throw new Error('AsyncTask#startPendingTask() not implemented');
494
+ }
495
+
496
+ createSubtask(args) {
497
+ _debugLog('[AsyncTask#createSubtask()] args', args);
498
+ const newSubtask = new AsyncSubtask({
499
+ componentIdx: this.componentIdx(),
500
+ taskID: this.id(),
501
+ memoryIdx: args?.memoryIdx,
502
+ });
503
+ this.#subtasks.push(newSubtask);
504
+ return newSubtask;
505
+ }
506
+
507
+ currentSubtask() {
508
+ _debugLog('[AsyncTask#currentSubtask()]');
509
+ if (this.#subtasks.length === 0) { throw new Error('no current subtask'); }
510
+ return this.#subtasks.at(-1);
511
+ }
512
+
513
+ endCurrentSubtask() {
514
+ _debugLog('[AsyncTask#endCurrentSubtask()]');
515
+ if (this.#subtasks.length === 0) { throw new Error('cannot end current subtask: no current subtask'); }
516
+ const subtask = this.#subtasks.pop();
517
+ subtask.drop();
518
+ return subtask;
519
+ }
520
+ }
521
+
522
+ function unpackCallbackResult(result) {
523
+ _debugLog('[unpackCallbackResult()] args', { result });
524
+ if (!(_typeCheckValidI32(result))) { throw new Error('invalid callback return value [' + result + '], not a valid i32'); }
525
+ const eventCode = result & 0xF;
526
+ if (eventCode < 0 || eventCode > 3) {
527
+ throw new Error('invalid async return value [' + eventCode + '], outside callback code range');
528
+ }
529
+ if (result < 0 || result >= 2**32) { throw new Error('invalid callback result'); }
530
+ // TODO: table max length check?
531
+ const waitableSetIdx = result >> 4;
532
+ return [eventCode, waitableSetIdx];
533
+ }
534
+ const ASYNC_STATE = new Map();
535
+
536
+ function getOrCreateAsyncState(componentIdx, init) {
537
+ if (!ASYNC_STATE.has(componentIdx)) {
538
+ ASYNC_STATE.set(componentIdx, new ComponentAsyncState());
539
+ }
540
+ return ASYNC_STATE.get(componentIdx);
541
+ }
542
+
543
+ class ComponentAsyncState {
544
+ #callingAsyncImport = false;
545
+ #syncImportWait = Promise.withResolvers();
546
+ #lock = null;
547
+
548
+ mayLeave = true;
549
+ waitableSets = new RepTable();
550
+ waitables = new RepTable();
551
+
552
+ #parkedTasks = new Map();
553
+
554
+ callingSyncImport(val) {
555
+ if (val === undefined) { return this.#callingAsyncImport; }
556
+ if (typeof val !== 'boolean') { throw new TypeError('invalid setting for async import'); }
557
+ const prev = this.#callingAsyncImport;
558
+ this.#callingAsyncImport = val;
559
+ if (prev === true && this.#callingAsyncImport === false) {
560
+ this.#notifySyncImportEnd();
561
+ }
562
+ }
563
+
564
+ #notifySyncImportEnd() {
565
+ const existing = this.#syncImportWait;
566
+ this.#syncImportWait = Promise.withResolvers();
567
+ existing.resolve();
568
+ }
569
+
570
+ async waitForSyncImportCallEnd() {
571
+ await this.#syncImportWait.promise;
572
+ }
573
+
574
+ parkTaskOnAwaitable(args) {
575
+ if (!args.awaitable) { throw new TypeError('missing awaitable when trying to park'); }
576
+ if (!args.task) { throw new TypeError('missing task when trying to park'); }
577
+ const { awaitable, task } = args;
578
+
579
+ let taskList = this.#parkedTasks.get(awaitable.id());
580
+ if (!taskList) {
581
+ taskList = [];
582
+ this.#parkedTasks.set(awaitable.id(), taskList);
583
+ }
584
+ taskList.push(task);
585
+
586
+ this.wakeNextTaskForAwaitable(awaitable);
587
+ }
588
+
589
+ wakeNextTaskForAwaitable(awaitable) {
590
+ if (!awaitable) { throw new TypeError('missing awaitable when waking next task'); }
591
+ const awaitableID = awaitable.id();
592
+
593
+ const taskList = this.#parkedTasks.get(awaitableID);
594
+ if (!taskList || taskList.length === 0) {
595
+ _debugLog('[ComponentAsyncState] no tasks waiting for awaitable', { awaitableID: awaitable.id() });
596
+ return;
597
+ }
598
+
599
+ let task = taskList.shift(); // todo(perf)
600
+ if (!task) { throw new Error('no task in parked list despite previous check'); }
601
+
602
+ if (!task.awaitableResume) {
603
+ throw new Error('task ready due to awaitable is missing resume', { taskID: task.id(), awaitableID });
604
+ }
605
+ task.awaitableResume();
606
+ }
607
+
608
+ async exclusiveLock() { // TODO: use atomics
609
+ if (this.#lock === null) {
610
+ this.#lock = { ticket: 0n };
611
+ }
612
+
613
+ // Take a ticket for the next valid usage
614
+ const ticket = ++this.#lock.ticket;
615
+
616
+ _debugLog('[ComponentAsyncState#exclusiveLock()] locking', {
617
+ currentTicket: ticket - 1n,
618
+ ticket
619
+ });
620
+
621
+ // If there is an active promise, then wait for it
622
+ let finishedTicket;
623
+ while (this.#lock.promise) {
624
+ finishedTicket = await this.#lock.promise;
625
+ if (finishedTicket === ticket - 1n) { break; }
626
+ }
627
+
628
+ const { promise, resolve } = Promise.withResolvers();
629
+ this.#lock = {
630
+ ticket,
631
+ promise,
632
+ resolve,
633
+ };
634
+
635
+ return this.#lock.promise;
636
+ }
637
+
638
+ exclusiveRelease() {
639
+ _debugLog('[ComponentAsyncState#exclusiveRelease()] releasing', {
640
+ currentTicket: this.#lock === null ? 'none' : this.#lock.ticket,
641
+ });
642
+
643
+ if (this.#lock === null) { return; }
644
+
645
+ const existingLock = this.#lock;
646
+ this.#lock = null;
647
+ existingLock.resolve(existingLock.ticket);
648
+ }
649
+
650
+ isExclusivelyLocked() { return this.#lock !== null; }
651
+
652
+ }
653
+
654
+ function prepareCall(memoryIdx) {
655
+ _debugLog('[prepareCall()] args', { memoryIdx });
656
+
657
+ const taskMeta = getCurrentTask(ASYNC_CURRENT_COMPONENT_IDXS.at(-1), ASYNC_CURRENT_TASK_IDS.at(-1));
658
+ if (!taskMeta) { throw new Error('invalid/missing current async task meta during prepare call'); }
659
+
660
+ const task = taskMeta.task;
661
+ if (!task) { throw new Error('unexpectedly missing task in task meta during prepare call'); }
662
+
663
+ const state = getOrCreateAsyncState(task.componentIdx());
664
+ if (!state) {
665
+ throw new Error('invalid/missing async state for component instance [' + componentInstanceID + ']');
666
+ }
667
+
668
+ const subtask = task.createSubtask({
669
+ memoryIdx,
670
+ });
671
+
672
+ }
673
+
674
+ function asyncStartCall(callbackIdx, postReturnIdx) {
675
+ _debugLog('[asyncStartCall()] args', { callbackIdx, postReturnIdx });
676
+
677
+ const taskMeta = getCurrentTask(ASYNC_CURRENT_COMPONENT_IDXS.at(-1), ASYNC_CURRENT_TASK_IDS.at(-1));
678
+ if (!taskMeta) { throw new Error('invalid/missing current async task meta during prepare call'); }
679
+
680
+ const task = taskMeta.task;
681
+ if (!task) { throw new Error('unexpectedly missing task in task meta during prepare call'); }
682
+
683
+ const subtask = task.currentSubtask();
684
+ if (!subtask) { throw new Error('invalid/missing subtask during async start call'); }
685
+
686
+ return Number(subtask.waitableRep()) << 4 | subtask.getStateNumber();
687
+ }
688
+
689
+ function syncStartCall(callbackIdx) {
690
+ _debugLog('[syncStartCall()] args', { callbackIdx });
691
+ }
692
+
693
+ if (!Promise.withResolvers) {
694
+ Promise.withResolvers = () => {
695
+ let resolve;
696
+ let reject;
697
+ const promise = new Promise((res, rej) => {
698
+ resolve = res;
699
+ reject = rej;
700
+ });
701
+ return { promise, resolve, reject };
702
+ };
703
+ }
704
+
705
+ const _debugLog = (...args) => {
706
+ if (!globalThis?.process?.env?.JCO_DEBUG) { return; }
707
+ console.debug(...args);
708
+ }
709
+ const ASYNC_DETERMINISM = 'random';
710
+ const _coinFlip = () => { return Math.random() > 0.5; };
711
+ const I32_MAX = 2_147_483_647;
712
+ const I32_MIN = -2_147_483_648;
713
+ const _typeCheckValidI32 = (n) => typeof n === 'number' && n >= I32_MIN && n <= I32_MAX;
714
+
715
+ const base64Compile = str => WebAssembly.compile(typeof Buffer !== 'undefined' ? Buffer.from(str, 'base64') : Uint8Array.from(atob(str), b => b.charCodeAt(0)));
716
+
717
+ const isNode = typeof process !== 'undefined' && process.versions && process.versions.node;
718
+ let _fs;
719
+ async function fetchCompile (url) {
720
+ if (isNode) {
721
+ _fs = _fs || await import('node:fs/promises');
722
+ return WebAssembly.compile(await _fs.readFile(url));
723
+ }
724
+ return fetch(url).then(WebAssembly.compileStreaming);
725
+ }
726
+
727
+ const symbolCabiDispose = Symbol.for('cabiDispose');
728
+
729
+ const symbolRscHandle = Symbol('handle');
730
+
731
+ const symbolRscRep = Symbol.for('cabiRep');
732
+
733
+ const symbolDispose = Symbol.dispose || Symbol.for('dispose');
734
+
735
+ const handleTables = [];
736
+
737
+ class ComponentError extends Error {
738
+ constructor (value) {
739
+ const enumerable = typeof value !== 'string';
740
+ super(enumerable ? `${String(value)} (see error.payload)` : value);
741
+ Object.defineProperty(this, 'payload', { value, enumerable });
742
+ }
743
+ }
744
+
745
+ function getErrorPayload(e) {
746
+ if (e && hasOwnProperty.call(e, 'payload')) return e.payload;
747
+ if (e instanceof Error) throw e;
748
+ return e;
749
+ }
750
+
751
+ class RepTable {
752
+ #data = [0, null];
753
+
754
+ insert(val) {
755
+ _debugLog('[RepTable#insert()] args', { val });
756
+ const freeIdx = this.#data[0];
757
+ if (freeIdx === 0) {
758
+ this.#data.push(val);
759
+ this.#data.push(null);
760
+ return (this.#data.length >> 1) - 1;
761
+ }
762
+ this.#data[0] = this.#data[freeIdx << 1];
763
+ const placementIdx = freeIdx << 1;
764
+ this.#data[placementIdx] = val;
765
+ this.#data[placementIdx + 1] = null;
766
+ return freeIdx;
767
+ }
768
+
769
+ get(rep) {
770
+ _debugLog('[RepTable#get()] args', { rep });
771
+ const baseIdx = rep << 1;
772
+ const val = this.#data[baseIdx];
773
+ return val;
774
+ }
775
+
776
+ contains(rep) {
777
+ _debugLog('[RepTable#contains()] args', { rep });
778
+ const baseIdx = rep << 1;
779
+ return !!this.#data[baseIdx];
780
+ }
781
+
782
+ remove(rep) {
783
+ _debugLog('[RepTable#remove()] args', { rep });
784
+ if (this.#data.length === 2) { throw new Error('invalid'); }
785
+
786
+ const baseIdx = rep << 1;
787
+ const val = this.#data[baseIdx];
788
+ if (val === 0) { throw new Error('invalid resource rep (cannot be 0)'); }
789
+
790
+ this.#data[baseIdx] = this.#data[0];
791
+ this.#data[0] = rep;
792
+
793
+ return val;
794
+ }
795
+
796
+ clear() {
797
+ _debugLog('[RepTable#clear()] args', { rep });
798
+ this.#data = [0, null];
799
+ }
800
+ }
801
+
802
+ const hasOwnProperty = Object.prototype.hasOwnProperty;
803
+
804
+ const instantiateCore = WebAssembly.instantiate;
805
+
806
+
807
+ let exports0;
808
+ const handleTable1 = [T_FLAG, 0];
809
+ const captureTable1= new Map();
810
+ let captureCnt1 = 0;
811
+ handleTables[1] = handleTable1;
812
+
813
+ function trampoline2() {
814
+ _debugLog('[iface="wasi:cli/stderr@0.2.6", function="get-stderr"] [Instruction::CallInterface] (async? sync, @ enter)');
815
+ const _interface_call_currentTaskID = startCurrentTask(0, false, 'get-stderr');
816
+ const ret = getStderr();
817
+ _debugLog('[iface="wasi:cli/stderr@0.2.6", function="get-stderr"] [Instruction::CallInterface] (sync, @ post-call)');
818
+ endCurrentTask(0);
819
+ if (!(ret instanceof OutputStream)) {
820
+ throw new TypeError('Resource error: Not a valid "OutputStream" resource.');
821
+ }
822
+ var handle0 = ret[symbolRscHandle];
823
+ if (!handle0) {
824
+ const rep = ret[symbolRscRep] || ++captureCnt1;
825
+ captureTable1.set(rep, ret);
826
+ handle0 = rscTableCreateOwn(handleTable1, rep);
827
+ }
828
+ _debugLog('[iface="wasi:cli/stderr@0.2.6", function="get-stderr"][Instruction::Return]', {
829
+ funcName: 'get-stderr',
830
+ paramCount: 1,
831
+ async: false,
832
+ postReturn: false
833
+ });
834
+ return handle0;
835
+ }
836
+
837
+ let exports1;
838
+ const handleTable2 = [T_FLAG, 0];
839
+ const captureTable2= new Map();
840
+ let captureCnt2 = 0;
841
+ handleTables[2] = handleTable2;
842
+
843
+ function trampoline6() {
844
+ _debugLog('[iface="wasi:cli/stdin@0.2.6", function="get-stdin"] [Instruction::CallInterface] (async? sync, @ enter)');
845
+ const _interface_call_currentTaskID = startCurrentTask(0, false, 'get-stdin');
846
+ const ret = getStdin();
847
+ _debugLog('[iface="wasi:cli/stdin@0.2.6", function="get-stdin"] [Instruction::CallInterface] (sync, @ post-call)');
848
+ endCurrentTask(0);
849
+ if (!(ret instanceof InputStream)) {
850
+ throw new TypeError('Resource error: Not a valid "InputStream" resource.');
851
+ }
852
+ var handle0 = ret[symbolRscHandle];
853
+ if (!handle0) {
854
+ const rep = ret[symbolRscRep] || ++captureCnt2;
855
+ captureTable2.set(rep, ret);
856
+ handle0 = rscTableCreateOwn(handleTable2, rep);
857
+ }
858
+ _debugLog('[iface="wasi:cli/stdin@0.2.6", function="get-stdin"][Instruction::Return]', {
859
+ funcName: 'get-stdin',
860
+ paramCount: 1,
861
+ async: false,
862
+ postReturn: false
863
+ });
864
+ return handle0;
865
+ }
866
+
867
+
868
+ function trampoline7() {
869
+ _debugLog('[iface="wasi:cli/stdout@0.2.6", function="get-stdout"] [Instruction::CallInterface] (async? sync, @ enter)');
870
+ const _interface_call_currentTaskID = startCurrentTask(0, false, 'get-stdout');
871
+ const ret = getStdout();
872
+ _debugLog('[iface="wasi:cli/stdout@0.2.6", function="get-stdout"] [Instruction::CallInterface] (sync, @ post-call)');
873
+ endCurrentTask(0);
874
+ if (!(ret instanceof OutputStream)) {
875
+ throw new TypeError('Resource error: Not a valid "OutputStream" resource.');
876
+ }
877
+ var handle0 = ret[symbolRscHandle];
878
+ if (!handle0) {
879
+ const rep = ret[symbolRscRep] || ++captureCnt1;
880
+ captureTable1.set(rep, ret);
881
+ handle0 = rscTableCreateOwn(handleTable1, rep);
882
+ }
883
+ _debugLog('[iface="wasi:cli/stdout@0.2.6", function="get-stdout"][Instruction::Return]', {
884
+ funcName: 'get-stdout',
885
+ paramCount: 1,
886
+ async: false,
887
+ postReturn: false
888
+ });
889
+ return handle0;
890
+ }
891
+
892
+
893
+ function trampoline8(arg0) {
894
+ let variant0;
895
+ switch (arg0) {
896
+ case 0: {
897
+ variant0= {
898
+ tag: 'ok',
899
+ val: undefined
900
+ };
901
+ break;
902
+ }
903
+ case 1: {
904
+ variant0= {
905
+ tag: 'err',
906
+ val: undefined
907
+ };
908
+ break;
909
+ }
910
+ default: {
911
+ throw new TypeError('invalid variant discriminant for expected');
912
+ }
913
+ }
914
+ _debugLog('[iface="wasi:cli/exit@0.2.6", function="exit"] [Instruction::CallInterface] (async? sync, @ enter)');
915
+ const _interface_call_currentTaskID = startCurrentTask(0, false, 'exit');
916
+ exit(variant0);
917
+ _debugLog('[iface="wasi:cli/exit@0.2.6", function="exit"] [Instruction::CallInterface] (sync, @ post-call)');
918
+ endCurrentTask(0);
919
+ _debugLog('[iface="wasi:cli/exit@0.2.6", function="exit"][Instruction::Return]', {
920
+ funcName: 'exit',
921
+ paramCount: 0,
922
+ async: false,
923
+ postReturn: false
924
+ });
925
+ }
926
+
927
+ let exports2;
928
+ let memory0;
929
+ let realloc0;
930
+ let realloc1;
931
+ const handleTable0 = [T_FLAG, 0];
932
+ const captureTable0= new Map();
933
+ let captureCnt0 = 0;
934
+ handleTables[0] = handleTable0;
935
+
936
+ function trampoline9(arg0, arg1) {
937
+ var handle1 = arg0;
938
+ var rep2 = handleTable0[(handle1 << 1) + 1] & ~T_FLAG;
939
+ var rsc0 = captureTable0.get(rep2);
940
+ if (!rsc0) {
941
+ rsc0 = Object.create(Error$1.prototype);
942
+ Object.defineProperty(rsc0, symbolRscHandle, { writable: true, value: handle1});
943
+ Object.defineProperty(rsc0, symbolRscRep, { writable: true, value: rep2});
944
+ }
945
+ curResourceBorrows.push(rsc0);
946
+ _debugLog('[iface="wasi:io/error@0.2.6", function="[method]error.to-debug-string"] [Instruction::CallInterface] (async? sync, @ enter)');
947
+ const _interface_call_currentTaskID = startCurrentTask(0, false, '[method]error.to-debug-string');
948
+ const ret = rsc0.toDebugString();
949
+ _debugLog('[iface="wasi:io/error@0.2.6", function="[method]error.to-debug-string"] [Instruction::CallInterface] (sync, @ post-call)');
950
+ for (const rsc of curResourceBorrows) {
951
+ rsc[symbolRscHandle] = undefined;
952
+ }
953
+ curResourceBorrows = [];
954
+ endCurrentTask(0);
955
+ var ptr3 = utf8Encode(ret, realloc0, memory0);
956
+ var len3 = utf8EncodedLen;
957
+ dataView(memory0).setUint32(arg1 + 4, len3, true);
958
+ dataView(memory0).setUint32(arg1 + 0, ptr3, true);
959
+ _debugLog('[iface="wasi:io/error@0.2.6", function="[method]error.to-debug-string"][Instruction::Return]', {
960
+ funcName: '[method]error.to-debug-string',
961
+ paramCount: 0,
962
+ async: false,
963
+ postReturn: false
964
+ });
965
+ }
966
+
967
+
968
+ function trampoline10(arg0, arg1, arg2, arg3) {
969
+ var handle1 = arg0;
970
+ var rep2 = handleTable1[(handle1 << 1) + 1] & ~T_FLAG;
971
+ var rsc0 = captureTable1.get(rep2);
972
+ if (!rsc0) {
973
+ rsc0 = Object.create(OutputStream.prototype);
974
+ Object.defineProperty(rsc0, symbolRscHandle, { writable: true, value: handle1});
975
+ Object.defineProperty(rsc0, symbolRscRep, { writable: true, value: rep2});
976
+ }
977
+ curResourceBorrows.push(rsc0);
978
+ var ptr3 = arg1;
979
+ var len3 = arg2;
980
+ var result3 = new Uint8Array(memory0.buffer.slice(ptr3, ptr3 + len3 * 1));
981
+ _debugLog('[iface="wasi:io/streams@0.2.6", function="[method]output-stream.blocking-write-and-flush"] [Instruction::CallInterface] (async? sync, @ enter)');
982
+ const _interface_call_currentTaskID = startCurrentTask(0, false, '[method]output-stream.blocking-write-and-flush');
983
+ let ret;
984
+ try {
985
+ ret = { tag: 'ok', val: rsc0.blockingWriteAndFlush(result3)};
986
+ } catch (e) {
987
+ ret = { tag: 'err', val: getErrorPayload(e) };
988
+ }
989
+ _debugLog('[iface="wasi:io/streams@0.2.6", function="[method]output-stream.blocking-write-and-flush"] [Instruction::CallInterface] (sync, @ post-call)');
990
+ for (const rsc of curResourceBorrows) {
991
+ rsc[symbolRscHandle] = undefined;
992
+ }
993
+ curResourceBorrows = [];
994
+ endCurrentTask(0);
995
+ var variant6 = ret;
996
+ switch (variant6.tag) {
997
+ case 'ok': {
998
+ const e = variant6.val;
999
+ dataView(memory0).setInt8(arg3 + 0, 0, true);
1000
+ break;
1001
+ }
1002
+ case 'err': {
1003
+ const e = variant6.val;
1004
+ dataView(memory0).setInt8(arg3 + 0, 1, true);
1005
+ var variant5 = e;
1006
+ switch (variant5.tag) {
1007
+ case 'last-operation-failed': {
1008
+ const e = variant5.val;
1009
+ dataView(memory0).setInt8(arg3 + 4, 0, true);
1010
+ if (!(e instanceof Error$1)) {
1011
+ throw new TypeError('Resource error: Not a valid "Error" resource.');
1012
+ }
1013
+ var handle4 = e[symbolRscHandle];
1014
+ if (!handle4) {
1015
+ const rep = e[symbolRscRep] || ++captureCnt0;
1016
+ captureTable0.set(rep, e);
1017
+ handle4 = rscTableCreateOwn(handleTable0, rep);
1018
+ }
1019
+ dataView(memory0).setInt32(arg3 + 8, handle4, true);
1020
+ break;
1021
+ }
1022
+ case 'closed': {
1023
+ dataView(memory0).setInt8(arg3 + 4, 1, true);
1024
+ break;
1025
+ }
1026
+ default: {
1027
+ throw new TypeError(`invalid variant tag value \`${JSON.stringify(variant5.tag)}\` (received \`${variant5}\`) specified for \`StreamError\``);
1028
+ }
1029
+ }
1030
+ break;
1031
+ }
1032
+ default: {
1033
+ throw new TypeError('invalid variant specified for result');
1034
+ }
1035
+ }
1036
+ _debugLog('[iface="wasi:io/streams@0.2.6", function="[method]output-stream.blocking-write-and-flush"][Instruction::Return]', {
1037
+ funcName: '[method]output-stream.blocking-write-and-flush',
1038
+ paramCount: 0,
1039
+ async: false,
1040
+ postReturn: false
1041
+ });
1042
+ }
1043
+
1044
+
1045
+ function trampoline11(arg0) {
1046
+ _debugLog('[iface="wasi:random/insecure-seed@0.2.6", function="insecure-seed"] [Instruction::CallInterface] (async? sync, @ enter)');
1047
+ const _interface_call_currentTaskID = startCurrentTask(0, false, 'insecure-seed');
1048
+ const ret = insecureSeed();
1049
+ _debugLog('[iface="wasi:random/insecure-seed@0.2.6", function="insecure-seed"] [Instruction::CallInterface] (sync, @ post-call)');
1050
+ endCurrentTask(0);
1051
+ var [tuple0_0, tuple0_1] = ret;
1052
+ dataView(memory0).setBigInt64(arg0 + 0, toUint64(tuple0_0), true);
1053
+ dataView(memory0).setBigInt64(arg0 + 8, toUint64(tuple0_1), true);
1054
+ _debugLog('[iface="wasi:random/insecure-seed@0.2.6", function="insecure-seed"][Instruction::Return]', {
1055
+ funcName: 'insecure-seed',
1056
+ paramCount: 0,
1057
+ async: false,
1058
+ postReturn: false
1059
+ });
1060
+ }
1061
+
1062
+
1063
+ function trampoline12(arg0) {
1064
+ _debugLog('[iface="wasi:cli/environment@0.2.6", function="get-environment"] [Instruction::CallInterface] (async? sync, @ enter)');
1065
+ const _interface_call_currentTaskID = startCurrentTask(0, false, 'get-environment');
1066
+ const ret = getEnvironment();
1067
+ _debugLog('[iface="wasi:cli/environment@0.2.6", function="get-environment"] [Instruction::CallInterface] (sync, @ post-call)');
1068
+ endCurrentTask(0);
1069
+ var vec3 = ret;
1070
+ var len3 = vec3.length;
1071
+ var result3 = realloc1(0, 0, 4, len3 * 16);
1072
+ for (let i = 0; i < vec3.length; i++) {
1073
+ const e = vec3[i];
1074
+ const base = result3 + i * 16;var [tuple0_0, tuple0_1] = e;
1075
+ var ptr1 = utf8Encode(tuple0_0, realloc1, memory0);
1076
+ var len1 = utf8EncodedLen;
1077
+ dataView(memory0).setUint32(base + 4, len1, true);
1078
+ dataView(memory0).setUint32(base + 0, ptr1, true);
1079
+ var ptr2 = utf8Encode(tuple0_1, realloc1, memory0);
1080
+ var len2 = utf8EncodedLen;
1081
+ dataView(memory0).setUint32(base + 12, len2, true);
1082
+ dataView(memory0).setUint32(base + 8, ptr2, true);
1083
+ }
1084
+ dataView(memory0).setUint32(arg0 + 4, len3, true);
1085
+ dataView(memory0).setUint32(arg0 + 0, result3, true);
1086
+ _debugLog('[iface="wasi:cli/environment@0.2.6", function="get-environment"][Instruction::Return]', {
1087
+ funcName: 'get-environment',
1088
+ paramCount: 0,
1089
+ async: false,
1090
+ postReturn: false
1091
+ });
1092
+ }
1093
+
1094
+
1095
+ function trampoline13(arg0, arg1) {
1096
+ var handle1 = arg0;
1097
+ var rep2 = handleTable0[(handle1 << 1) + 1] & ~T_FLAG;
1098
+ var rsc0 = captureTable0.get(rep2);
1099
+ if (!rsc0) {
1100
+ rsc0 = Object.create(Error$1.prototype);
1101
+ Object.defineProperty(rsc0, symbolRscHandle, { writable: true, value: handle1});
1102
+ Object.defineProperty(rsc0, symbolRscRep, { writable: true, value: rep2});
1103
+ }
1104
+ curResourceBorrows.push(rsc0);
1105
+ _debugLog('[iface="wasi:filesystem/types@0.2.6", function="filesystem-error-code"] [Instruction::CallInterface] (async? sync, @ enter)');
1106
+ const _interface_call_currentTaskID = startCurrentTask(0, false, 'filesystem-error-code');
1107
+ const ret = filesystemErrorCode(rsc0);
1108
+ _debugLog('[iface="wasi:filesystem/types@0.2.6", function="filesystem-error-code"] [Instruction::CallInterface] (sync, @ post-call)');
1109
+ for (const rsc of curResourceBorrows) {
1110
+ rsc[symbolRscHandle] = undefined;
1111
+ }
1112
+ curResourceBorrows = [];
1113
+ endCurrentTask(0);
1114
+ var variant4 = ret;
1115
+ if (variant4 === null || variant4=== undefined) {
1116
+ dataView(memory0).setInt8(arg1 + 0, 0, true);
1117
+ } else {
1118
+ const e = variant4;
1119
+ dataView(memory0).setInt8(arg1 + 0, 1, true);
1120
+ var val3 = e;
1121
+ let enum3;
1122
+ switch (val3) {
1123
+ case 'access': {
1124
+ enum3 = 0;
1125
+ break;
1126
+ }
1127
+ case 'would-block': {
1128
+ enum3 = 1;
1129
+ break;
1130
+ }
1131
+ case 'already': {
1132
+ enum3 = 2;
1133
+ break;
1134
+ }
1135
+ case 'bad-descriptor': {
1136
+ enum3 = 3;
1137
+ break;
1138
+ }
1139
+ case 'busy': {
1140
+ enum3 = 4;
1141
+ break;
1142
+ }
1143
+ case 'deadlock': {
1144
+ enum3 = 5;
1145
+ break;
1146
+ }
1147
+ case 'quota': {
1148
+ enum3 = 6;
1149
+ break;
1150
+ }
1151
+ case 'exist': {
1152
+ enum3 = 7;
1153
+ break;
1154
+ }
1155
+ case 'file-too-large': {
1156
+ enum3 = 8;
1157
+ break;
1158
+ }
1159
+ case 'illegal-byte-sequence': {
1160
+ enum3 = 9;
1161
+ break;
1162
+ }
1163
+ case 'in-progress': {
1164
+ enum3 = 10;
1165
+ break;
1166
+ }
1167
+ case 'interrupted': {
1168
+ enum3 = 11;
1169
+ break;
1170
+ }
1171
+ case 'invalid': {
1172
+ enum3 = 12;
1173
+ break;
1174
+ }
1175
+ case 'io': {
1176
+ enum3 = 13;
1177
+ break;
1178
+ }
1179
+ case 'is-directory': {
1180
+ enum3 = 14;
1181
+ break;
1182
+ }
1183
+ case 'loop': {
1184
+ enum3 = 15;
1185
+ break;
1186
+ }
1187
+ case 'too-many-links': {
1188
+ enum3 = 16;
1189
+ break;
1190
+ }
1191
+ case 'message-size': {
1192
+ enum3 = 17;
1193
+ break;
1194
+ }
1195
+ case 'name-too-long': {
1196
+ enum3 = 18;
1197
+ break;
1198
+ }
1199
+ case 'no-device': {
1200
+ enum3 = 19;
1201
+ break;
1202
+ }
1203
+ case 'no-entry': {
1204
+ enum3 = 20;
1205
+ break;
1206
+ }
1207
+ case 'no-lock': {
1208
+ enum3 = 21;
1209
+ break;
1210
+ }
1211
+ case 'insufficient-memory': {
1212
+ enum3 = 22;
1213
+ break;
1214
+ }
1215
+ case 'insufficient-space': {
1216
+ enum3 = 23;
1217
+ break;
1218
+ }
1219
+ case 'not-directory': {
1220
+ enum3 = 24;
1221
+ break;
1222
+ }
1223
+ case 'not-empty': {
1224
+ enum3 = 25;
1225
+ break;
1226
+ }
1227
+ case 'not-recoverable': {
1228
+ enum3 = 26;
1229
+ break;
1230
+ }
1231
+ case 'unsupported': {
1232
+ enum3 = 27;
1233
+ break;
1234
+ }
1235
+ case 'no-tty': {
1236
+ enum3 = 28;
1237
+ break;
1238
+ }
1239
+ case 'no-such-device': {
1240
+ enum3 = 29;
1241
+ break;
1242
+ }
1243
+ case 'overflow': {
1244
+ enum3 = 30;
1245
+ break;
1246
+ }
1247
+ case 'not-permitted': {
1248
+ enum3 = 31;
1249
+ break;
1250
+ }
1251
+ case 'pipe': {
1252
+ enum3 = 32;
1253
+ break;
1254
+ }
1255
+ case 'read-only': {
1256
+ enum3 = 33;
1257
+ break;
1258
+ }
1259
+ case 'invalid-seek': {
1260
+ enum3 = 34;
1261
+ break;
1262
+ }
1263
+ case 'text-file-busy': {
1264
+ enum3 = 35;
1265
+ break;
1266
+ }
1267
+ case 'cross-device': {
1268
+ enum3 = 36;
1269
+ break;
1270
+ }
1271
+ default: {
1272
+ if ((e) instanceof Error) {
1273
+ console.error(e);
1274
+ }
1275
+
1276
+ throw new TypeError(`"${val3}" is not one of the cases of error-code`);
1277
+ }
1278
+ }
1279
+ dataView(memory0).setInt8(arg1 + 1, enum3, true);
1280
+ }
1281
+ _debugLog('[iface="wasi:filesystem/types@0.2.6", function="filesystem-error-code"][Instruction::Return]', {
1282
+ funcName: 'filesystem-error-code',
1283
+ paramCount: 0,
1284
+ async: false,
1285
+ postReturn: false
1286
+ });
1287
+ }
1288
+
1289
+ const handleTable4 = [T_FLAG, 0];
1290
+ const captureTable4= new Map();
1291
+ let captureCnt4 = 0;
1292
+ handleTables[4] = handleTable4;
1293
+
1294
+ function trampoline14(arg0, arg1, arg2) {
1295
+ var handle1 = arg0;
1296
+ var rep2 = handleTable4[(handle1 << 1) + 1] & ~T_FLAG;
1297
+ var rsc0 = captureTable4.get(rep2);
1298
+ if (!rsc0) {
1299
+ rsc0 = Object.create(Descriptor.prototype);
1300
+ Object.defineProperty(rsc0, symbolRscHandle, { writable: true, value: handle1});
1301
+ Object.defineProperty(rsc0, symbolRscRep, { writable: true, value: rep2});
1302
+ }
1303
+ curResourceBorrows.push(rsc0);
1304
+ _debugLog('[iface="wasi:filesystem/types@0.2.6", function="[method]descriptor.write-via-stream"] [Instruction::CallInterface] (async? sync, @ enter)');
1305
+ const _interface_call_currentTaskID = startCurrentTask(0, false, '[method]descriptor.write-via-stream');
1306
+ let ret;
1307
+ try {
1308
+ ret = { tag: 'ok', val: rsc0.writeViaStream(BigInt.asUintN(64, arg1))};
1309
+ } catch (e) {
1310
+ ret = { tag: 'err', val: getErrorPayload(e) };
1311
+ }
1312
+ _debugLog('[iface="wasi:filesystem/types@0.2.6", function="[method]descriptor.write-via-stream"] [Instruction::CallInterface] (sync, @ post-call)');
1313
+ for (const rsc of curResourceBorrows) {
1314
+ rsc[symbolRscHandle] = undefined;
1315
+ }
1316
+ curResourceBorrows = [];
1317
+ endCurrentTask(0);
1318
+ var variant5 = ret;
1319
+ switch (variant5.tag) {
1320
+ case 'ok': {
1321
+ const e = variant5.val;
1322
+ dataView(memory0).setInt8(arg2 + 0, 0, true);
1323
+ if (!(e instanceof OutputStream)) {
1324
+ throw new TypeError('Resource error: Not a valid "OutputStream" resource.');
1325
+ }
1326
+ var handle3 = e[symbolRscHandle];
1327
+ if (!handle3) {
1328
+ const rep = e[symbolRscRep] || ++captureCnt1;
1329
+ captureTable1.set(rep, e);
1330
+ handle3 = rscTableCreateOwn(handleTable1, rep);
1331
+ }
1332
+ dataView(memory0).setInt32(arg2 + 4, handle3, true);
1333
+ break;
1334
+ }
1335
+ case 'err': {
1336
+ const e = variant5.val;
1337
+ dataView(memory0).setInt8(arg2 + 0, 1, true);
1338
+ var val4 = e;
1339
+ let enum4;
1340
+ switch (val4) {
1341
+ case 'access': {
1342
+ enum4 = 0;
1343
+ break;
1344
+ }
1345
+ case 'would-block': {
1346
+ enum4 = 1;
1347
+ break;
1348
+ }
1349
+ case 'already': {
1350
+ enum4 = 2;
1351
+ break;
1352
+ }
1353
+ case 'bad-descriptor': {
1354
+ enum4 = 3;
1355
+ break;
1356
+ }
1357
+ case 'busy': {
1358
+ enum4 = 4;
1359
+ break;
1360
+ }
1361
+ case 'deadlock': {
1362
+ enum4 = 5;
1363
+ break;
1364
+ }
1365
+ case 'quota': {
1366
+ enum4 = 6;
1367
+ break;
1368
+ }
1369
+ case 'exist': {
1370
+ enum4 = 7;
1371
+ break;
1372
+ }
1373
+ case 'file-too-large': {
1374
+ enum4 = 8;
1375
+ break;
1376
+ }
1377
+ case 'illegal-byte-sequence': {
1378
+ enum4 = 9;
1379
+ break;
1380
+ }
1381
+ case 'in-progress': {
1382
+ enum4 = 10;
1383
+ break;
1384
+ }
1385
+ case 'interrupted': {
1386
+ enum4 = 11;
1387
+ break;
1388
+ }
1389
+ case 'invalid': {
1390
+ enum4 = 12;
1391
+ break;
1392
+ }
1393
+ case 'io': {
1394
+ enum4 = 13;
1395
+ break;
1396
+ }
1397
+ case 'is-directory': {
1398
+ enum4 = 14;
1399
+ break;
1400
+ }
1401
+ case 'loop': {
1402
+ enum4 = 15;
1403
+ break;
1404
+ }
1405
+ case 'too-many-links': {
1406
+ enum4 = 16;
1407
+ break;
1408
+ }
1409
+ case 'message-size': {
1410
+ enum4 = 17;
1411
+ break;
1412
+ }
1413
+ case 'name-too-long': {
1414
+ enum4 = 18;
1415
+ break;
1416
+ }
1417
+ case 'no-device': {
1418
+ enum4 = 19;
1419
+ break;
1420
+ }
1421
+ case 'no-entry': {
1422
+ enum4 = 20;
1423
+ break;
1424
+ }
1425
+ case 'no-lock': {
1426
+ enum4 = 21;
1427
+ break;
1428
+ }
1429
+ case 'insufficient-memory': {
1430
+ enum4 = 22;
1431
+ break;
1432
+ }
1433
+ case 'insufficient-space': {
1434
+ enum4 = 23;
1435
+ break;
1436
+ }
1437
+ case 'not-directory': {
1438
+ enum4 = 24;
1439
+ break;
1440
+ }
1441
+ case 'not-empty': {
1442
+ enum4 = 25;
1443
+ break;
1444
+ }
1445
+ case 'not-recoverable': {
1446
+ enum4 = 26;
1447
+ break;
1448
+ }
1449
+ case 'unsupported': {
1450
+ enum4 = 27;
1451
+ break;
1452
+ }
1453
+ case 'no-tty': {
1454
+ enum4 = 28;
1455
+ break;
1456
+ }
1457
+ case 'no-such-device': {
1458
+ enum4 = 29;
1459
+ break;
1460
+ }
1461
+ case 'overflow': {
1462
+ enum4 = 30;
1463
+ break;
1464
+ }
1465
+ case 'not-permitted': {
1466
+ enum4 = 31;
1467
+ break;
1468
+ }
1469
+ case 'pipe': {
1470
+ enum4 = 32;
1471
+ break;
1472
+ }
1473
+ case 'read-only': {
1474
+ enum4 = 33;
1475
+ break;
1476
+ }
1477
+ case 'invalid-seek': {
1478
+ enum4 = 34;
1479
+ break;
1480
+ }
1481
+ case 'text-file-busy': {
1482
+ enum4 = 35;
1483
+ break;
1484
+ }
1485
+ case 'cross-device': {
1486
+ enum4 = 36;
1487
+ break;
1488
+ }
1489
+ default: {
1490
+ if ((e) instanceof Error) {
1491
+ console.error(e);
1492
+ }
1493
+
1494
+ throw new TypeError(`"${val4}" is not one of the cases of error-code`);
1495
+ }
1496
+ }
1497
+ dataView(memory0).setInt8(arg2 + 4, enum4, true);
1498
+ break;
1499
+ }
1500
+ default: {
1501
+ throw new TypeError('invalid variant specified for result');
1502
+ }
1503
+ }
1504
+ _debugLog('[iface="wasi:filesystem/types@0.2.6", function="[method]descriptor.write-via-stream"][Instruction::Return]', {
1505
+ funcName: '[method]descriptor.write-via-stream',
1506
+ paramCount: 0,
1507
+ async: false,
1508
+ postReturn: false
1509
+ });
1510
+ }
1511
+
1512
+
1513
+ function trampoline15(arg0, arg1) {
1514
+ var handle1 = arg0;
1515
+ var rep2 = handleTable4[(handle1 << 1) + 1] & ~T_FLAG;
1516
+ var rsc0 = captureTable4.get(rep2);
1517
+ if (!rsc0) {
1518
+ rsc0 = Object.create(Descriptor.prototype);
1519
+ Object.defineProperty(rsc0, symbolRscHandle, { writable: true, value: handle1});
1520
+ Object.defineProperty(rsc0, symbolRscRep, { writable: true, value: rep2});
1521
+ }
1522
+ curResourceBorrows.push(rsc0);
1523
+ _debugLog('[iface="wasi:filesystem/types@0.2.6", function="[method]descriptor.append-via-stream"] [Instruction::CallInterface] (async? sync, @ enter)');
1524
+ const _interface_call_currentTaskID = startCurrentTask(0, false, '[method]descriptor.append-via-stream');
1525
+ let ret;
1526
+ try {
1527
+ ret = { tag: 'ok', val: rsc0.appendViaStream()};
1528
+ } catch (e) {
1529
+ ret = { tag: 'err', val: getErrorPayload(e) };
1530
+ }
1531
+ _debugLog('[iface="wasi:filesystem/types@0.2.6", function="[method]descriptor.append-via-stream"] [Instruction::CallInterface] (sync, @ post-call)');
1532
+ for (const rsc of curResourceBorrows) {
1533
+ rsc[symbolRscHandle] = undefined;
1534
+ }
1535
+ curResourceBorrows = [];
1536
+ endCurrentTask(0);
1537
+ var variant5 = ret;
1538
+ switch (variant5.tag) {
1539
+ case 'ok': {
1540
+ const e = variant5.val;
1541
+ dataView(memory0).setInt8(arg1 + 0, 0, true);
1542
+ if (!(e instanceof OutputStream)) {
1543
+ throw new TypeError('Resource error: Not a valid "OutputStream" resource.');
1544
+ }
1545
+ var handle3 = e[symbolRscHandle];
1546
+ if (!handle3) {
1547
+ const rep = e[symbolRscRep] || ++captureCnt1;
1548
+ captureTable1.set(rep, e);
1549
+ handle3 = rscTableCreateOwn(handleTable1, rep);
1550
+ }
1551
+ dataView(memory0).setInt32(arg1 + 4, handle3, true);
1552
+ break;
1553
+ }
1554
+ case 'err': {
1555
+ const e = variant5.val;
1556
+ dataView(memory0).setInt8(arg1 + 0, 1, true);
1557
+ var val4 = e;
1558
+ let enum4;
1559
+ switch (val4) {
1560
+ case 'access': {
1561
+ enum4 = 0;
1562
+ break;
1563
+ }
1564
+ case 'would-block': {
1565
+ enum4 = 1;
1566
+ break;
1567
+ }
1568
+ case 'already': {
1569
+ enum4 = 2;
1570
+ break;
1571
+ }
1572
+ case 'bad-descriptor': {
1573
+ enum4 = 3;
1574
+ break;
1575
+ }
1576
+ case 'busy': {
1577
+ enum4 = 4;
1578
+ break;
1579
+ }
1580
+ case 'deadlock': {
1581
+ enum4 = 5;
1582
+ break;
1583
+ }
1584
+ case 'quota': {
1585
+ enum4 = 6;
1586
+ break;
1587
+ }
1588
+ case 'exist': {
1589
+ enum4 = 7;
1590
+ break;
1591
+ }
1592
+ case 'file-too-large': {
1593
+ enum4 = 8;
1594
+ break;
1595
+ }
1596
+ case 'illegal-byte-sequence': {
1597
+ enum4 = 9;
1598
+ break;
1599
+ }
1600
+ case 'in-progress': {
1601
+ enum4 = 10;
1602
+ break;
1603
+ }
1604
+ case 'interrupted': {
1605
+ enum4 = 11;
1606
+ break;
1607
+ }
1608
+ case 'invalid': {
1609
+ enum4 = 12;
1610
+ break;
1611
+ }
1612
+ case 'io': {
1613
+ enum4 = 13;
1614
+ break;
1615
+ }
1616
+ case 'is-directory': {
1617
+ enum4 = 14;
1618
+ break;
1619
+ }
1620
+ case 'loop': {
1621
+ enum4 = 15;
1622
+ break;
1623
+ }
1624
+ case 'too-many-links': {
1625
+ enum4 = 16;
1626
+ break;
1627
+ }
1628
+ case 'message-size': {
1629
+ enum4 = 17;
1630
+ break;
1631
+ }
1632
+ case 'name-too-long': {
1633
+ enum4 = 18;
1634
+ break;
1635
+ }
1636
+ case 'no-device': {
1637
+ enum4 = 19;
1638
+ break;
1639
+ }
1640
+ case 'no-entry': {
1641
+ enum4 = 20;
1642
+ break;
1643
+ }
1644
+ case 'no-lock': {
1645
+ enum4 = 21;
1646
+ break;
1647
+ }
1648
+ case 'insufficient-memory': {
1649
+ enum4 = 22;
1650
+ break;
1651
+ }
1652
+ case 'insufficient-space': {
1653
+ enum4 = 23;
1654
+ break;
1655
+ }
1656
+ case 'not-directory': {
1657
+ enum4 = 24;
1658
+ break;
1659
+ }
1660
+ case 'not-empty': {
1661
+ enum4 = 25;
1662
+ break;
1663
+ }
1664
+ case 'not-recoverable': {
1665
+ enum4 = 26;
1666
+ break;
1667
+ }
1668
+ case 'unsupported': {
1669
+ enum4 = 27;
1670
+ break;
1671
+ }
1672
+ case 'no-tty': {
1673
+ enum4 = 28;
1674
+ break;
1675
+ }
1676
+ case 'no-such-device': {
1677
+ enum4 = 29;
1678
+ break;
1679
+ }
1680
+ case 'overflow': {
1681
+ enum4 = 30;
1682
+ break;
1683
+ }
1684
+ case 'not-permitted': {
1685
+ enum4 = 31;
1686
+ break;
1687
+ }
1688
+ case 'pipe': {
1689
+ enum4 = 32;
1690
+ break;
1691
+ }
1692
+ case 'read-only': {
1693
+ enum4 = 33;
1694
+ break;
1695
+ }
1696
+ case 'invalid-seek': {
1697
+ enum4 = 34;
1698
+ break;
1699
+ }
1700
+ case 'text-file-busy': {
1701
+ enum4 = 35;
1702
+ break;
1703
+ }
1704
+ case 'cross-device': {
1705
+ enum4 = 36;
1706
+ break;
1707
+ }
1708
+ default: {
1709
+ if ((e) instanceof Error) {
1710
+ console.error(e);
1711
+ }
1712
+
1713
+ throw new TypeError(`"${val4}" is not one of the cases of error-code`);
1714
+ }
1715
+ }
1716
+ dataView(memory0).setInt8(arg1 + 4, enum4, true);
1717
+ break;
1718
+ }
1719
+ default: {
1720
+ throw new TypeError('invalid variant specified for result');
1721
+ }
1722
+ }
1723
+ _debugLog('[iface="wasi:filesystem/types@0.2.6", function="[method]descriptor.append-via-stream"][Instruction::Return]', {
1724
+ funcName: '[method]descriptor.append-via-stream',
1725
+ paramCount: 0,
1726
+ async: false,
1727
+ postReturn: false
1728
+ });
1729
+ }
1730
+
1731
+
1732
+ function trampoline16(arg0, arg1) {
1733
+ var handle1 = arg0;
1734
+ var rep2 = handleTable4[(handle1 << 1) + 1] & ~T_FLAG;
1735
+ var rsc0 = captureTable4.get(rep2);
1736
+ if (!rsc0) {
1737
+ rsc0 = Object.create(Descriptor.prototype);
1738
+ Object.defineProperty(rsc0, symbolRscHandle, { writable: true, value: handle1});
1739
+ Object.defineProperty(rsc0, symbolRscRep, { writable: true, value: rep2});
1740
+ }
1741
+ curResourceBorrows.push(rsc0);
1742
+ _debugLog('[iface="wasi:filesystem/types@0.2.6", function="[method]descriptor.get-type"] [Instruction::CallInterface] (async? sync, @ enter)');
1743
+ const _interface_call_currentTaskID = startCurrentTask(0, false, '[method]descriptor.get-type');
1744
+ let ret;
1745
+ try {
1746
+ ret = { tag: 'ok', val: rsc0.getType()};
1747
+ } catch (e) {
1748
+ ret = { tag: 'err', val: getErrorPayload(e) };
1749
+ }
1750
+ _debugLog('[iface="wasi:filesystem/types@0.2.6", function="[method]descriptor.get-type"] [Instruction::CallInterface] (sync, @ post-call)');
1751
+ for (const rsc of curResourceBorrows) {
1752
+ rsc[symbolRscHandle] = undefined;
1753
+ }
1754
+ curResourceBorrows = [];
1755
+ endCurrentTask(0);
1756
+ var variant5 = ret;
1757
+ switch (variant5.tag) {
1758
+ case 'ok': {
1759
+ const e = variant5.val;
1760
+ dataView(memory0).setInt8(arg1 + 0, 0, true);
1761
+ var val3 = e;
1762
+ let enum3;
1763
+ switch (val3) {
1764
+ case 'unknown': {
1765
+ enum3 = 0;
1766
+ break;
1767
+ }
1768
+ case 'block-device': {
1769
+ enum3 = 1;
1770
+ break;
1771
+ }
1772
+ case 'character-device': {
1773
+ enum3 = 2;
1774
+ break;
1775
+ }
1776
+ case 'directory': {
1777
+ enum3 = 3;
1778
+ break;
1779
+ }
1780
+ case 'fifo': {
1781
+ enum3 = 4;
1782
+ break;
1783
+ }
1784
+ case 'symbolic-link': {
1785
+ enum3 = 5;
1786
+ break;
1787
+ }
1788
+ case 'regular-file': {
1789
+ enum3 = 6;
1790
+ break;
1791
+ }
1792
+ case 'socket': {
1793
+ enum3 = 7;
1794
+ break;
1795
+ }
1796
+ default: {
1797
+ if ((e) instanceof Error) {
1798
+ console.error(e);
1799
+ }
1800
+
1801
+ throw new TypeError(`"${val3}" is not one of the cases of descriptor-type`);
1802
+ }
1803
+ }
1804
+ dataView(memory0).setInt8(arg1 + 1, enum3, true);
1805
+ break;
1806
+ }
1807
+ case 'err': {
1808
+ const e = variant5.val;
1809
+ dataView(memory0).setInt8(arg1 + 0, 1, true);
1810
+ var val4 = e;
1811
+ let enum4;
1812
+ switch (val4) {
1813
+ case 'access': {
1814
+ enum4 = 0;
1815
+ break;
1816
+ }
1817
+ case 'would-block': {
1818
+ enum4 = 1;
1819
+ break;
1820
+ }
1821
+ case 'already': {
1822
+ enum4 = 2;
1823
+ break;
1824
+ }
1825
+ case 'bad-descriptor': {
1826
+ enum4 = 3;
1827
+ break;
1828
+ }
1829
+ case 'busy': {
1830
+ enum4 = 4;
1831
+ break;
1832
+ }
1833
+ case 'deadlock': {
1834
+ enum4 = 5;
1835
+ break;
1836
+ }
1837
+ case 'quota': {
1838
+ enum4 = 6;
1839
+ break;
1840
+ }
1841
+ case 'exist': {
1842
+ enum4 = 7;
1843
+ break;
1844
+ }
1845
+ case 'file-too-large': {
1846
+ enum4 = 8;
1847
+ break;
1848
+ }
1849
+ case 'illegal-byte-sequence': {
1850
+ enum4 = 9;
1851
+ break;
1852
+ }
1853
+ case 'in-progress': {
1854
+ enum4 = 10;
1855
+ break;
1856
+ }
1857
+ case 'interrupted': {
1858
+ enum4 = 11;
1859
+ break;
1860
+ }
1861
+ case 'invalid': {
1862
+ enum4 = 12;
1863
+ break;
1864
+ }
1865
+ case 'io': {
1866
+ enum4 = 13;
1867
+ break;
1868
+ }
1869
+ case 'is-directory': {
1870
+ enum4 = 14;
1871
+ break;
1872
+ }
1873
+ case 'loop': {
1874
+ enum4 = 15;
1875
+ break;
1876
+ }
1877
+ case 'too-many-links': {
1878
+ enum4 = 16;
1879
+ break;
1880
+ }
1881
+ case 'message-size': {
1882
+ enum4 = 17;
1883
+ break;
1884
+ }
1885
+ case 'name-too-long': {
1886
+ enum4 = 18;
1887
+ break;
1888
+ }
1889
+ case 'no-device': {
1890
+ enum4 = 19;
1891
+ break;
1892
+ }
1893
+ case 'no-entry': {
1894
+ enum4 = 20;
1895
+ break;
1896
+ }
1897
+ case 'no-lock': {
1898
+ enum4 = 21;
1899
+ break;
1900
+ }
1901
+ case 'insufficient-memory': {
1902
+ enum4 = 22;
1903
+ break;
1904
+ }
1905
+ case 'insufficient-space': {
1906
+ enum4 = 23;
1907
+ break;
1908
+ }
1909
+ case 'not-directory': {
1910
+ enum4 = 24;
1911
+ break;
1912
+ }
1913
+ case 'not-empty': {
1914
+ enum4 = 25;
1915
+ break;
1916
+ }
1917
+ case 'not-recoverable': {
1918
+ enum4 = 26;
1919
+ break;
1920
+ }
1921
+ case 'unsupported': {
1922
+ enum4 = 27;
1923
+ break;
1924
+ }
1925
+ case 'no-tty': {
1926
+ enum4 = 28;
1927
+ break;
1928
+ }
1929
+ case 'no-such-device': {
1930
+ enum4 = 29;
1931
+ break;
1932
+ }
1933
+ case 'overflow': {
1934
+ enum4 = 30;
1935
+ break;
1936
+ }
1937
+ case 'not-permitted': {
1938
+ enum4 = 31;
1939
+ break;
1940
+ }
1941
+ case 'pipe': {
1942
+ enum4 = 32;
1943
+ break;
1944
+ }
1945
+ case 'read-only': {
1946
+ enum4 = 33;
1947
+ break;
1948
+ }
1949
+ case 'invalid-seek': {
1950
+ enum4 = 34;
1951
+ break;
1952
+ }
1953
+ case 'text-file-busy': {
1954
+ enum4 = 35;
1955
+ break;
1956
+ }
1957
+ case 'cross-device': {
1958
+ enum4 = 36;
1959
+ break;
1960
+ }
1961
+ default: {
1962
+ if ((e) instanceof Error) {
1963
+ console.error(e);
1964
+ }
1965
+
1966
+ throw new TypeError(`"${val4}" is not one of the cases of error-code`);
1967
+ }
1968
+ }
1969
+ dataView(memory0).setInt8(arg1 + 1, enum4, true);
1970
+ break;
1971
+ }
1972
+ default: {
1973
+ throw new TypeError('invalid variant specified for result');
1974
+ }
1975
+ }
1976
+ _debugLog('[iface="wasi:filesystem/types@0.2.6", function="[method]descriptor.get-type"][Instruction::Return]', {
1977
+ funcName: '[method]descriptor.get-type',
1978
+ paramCount: 0,
1979
+ async: false,
1980
+ postReturn: false
1981
+ });
1982
+ }
1983
+
1984
+
1985
+ function trampoline17(arg0, arg1) {
1986
+ var handle1 = arg0;
1987
+ var rep2 = handleTable4[(handle1 << 1) + 1] & ~T_FLAG;
1988
+ var rsc0 = captureTable4.get(rep2);
1989
+ if (!rsc0) {
1990
+ rsc0 = Object.create(Descriptor.prototype);
1991
+ Object.defineProperty(rsc0, symbolRscHandle, { writable: true, value: handle1});
1992
+ Object.defineProperty(rsc0, symbolRscRep, { writable: true, value: rep2});
1993
+ }
1994
+ curResourceBorrows.push(rsc0);
1995
+ _debugLog('[iface="wasi:filesystem/types@0.2.6", function="[method]descriptor.stat"] [Instruction::CallInterface] (async? sync, @ enter)');
1996
+ const _interface_call_currentTaskID = startCurrentTask(0, false, '[method]descriptor.stat');
1997
+ let ret;
1998
+ try {
1999
+ ret = { tag: 'ok', val: rsc0.stat()};
2000
+ } catch (e) {
2001
+ ret = { tag: 'err', val: getErrorPayload(e) };
2002
+ }
2003
+ _debugLog('[iface="wasi:filesystem/types@0.2.6", function="[method]descriptor.stat"] [Instruction::CallInterface] (sync, @ post-call)');
2004
+ for (const rsc of curResourceBorrows) {
2005
+ rsc[symbolRscHandle] = undefined;
2006
+ }
2007
+ curResourceBorrows = [];
2008
+ endCurrentTask(0);
2009
+ var variant12 = ret;
2010
+ switch (variant12.tag) {
2011
+ case 'ok': {
2012
+ const e = variant12.val;
2013
+ dataView(memory0).setInt8(arg1 + 0, 0, true);
2014
+ var {type: v3_0, linkCount: v3_1, size: v3_2, dataAccessTimestamp: v3_3, dataModificationTimestamp: v3_4, statusChangeTimestamp: v3_5 } = e;
2015
+ var val4 = v3_0;
2016
+ let enum4;
2017
+ switch (val4) {
2018
+ case 'unknown': {
2019
+ enum4 = 0;
2020
+ break;
2021
+ }
2022
+ case 'block-device': {
2023
+ enum4 = 1;
2024
+ break;
2025
+ }
2026
+ case 'character-device': {
2027
+ enum4 = 2;
2028
+ break;
2029
+ }
2030
+ case 'directory': {
2031
+ enum4 = 3;
2032
+ break;
2033
+ }
2034
+ case 'fifo': {
2035
+ enum4 = 4;
2036
+ break;
2037
+ }
2038
+ case 'symbolic-link': {
2039
+ enum4 = 5;
2040
+ break;
2041
+ }
2042
+ case 'regular-file': {
2043
+ enum4 = 6;
2044
+ break;
2045
+ }
2046
+ case 'socket': {
2047
+ enum4 = 7;
2048
+ break;
2049
+ }
2050
+ default: {
2051
+ if ((v3_0) instanceof Error) {
2052
+ console.error(v3_0);
2053
+ }
2054
+
2055
+ throw new TypeError(`"${val4}" is not one of the cases of descriptor-type`);
2056
+ }
2057
+ }
2058
+ dataView(memory0).setInt8(arg1 + 8, enum4, true);
2059
+ dataView(memory0).setBigInt64(arg1 + 16, toUint64(v3_1), true);
2060
+ dataView(memory0).setBigInt64(arg1 + 24, toUint64(v3_2), true);
2061
+ var variant6 = v3_3;
2062
+ if (variant6 === null || variant6=== undefined) {
2063
+ dataView(memory0).setInt8(arg1 + 32, 0, true);
2064
+ } else {
2065
+ const e = variant6;
2066
+ dataView(memory0).setInt8(arg1 + 32, 1, true);
2067
+ var {seconds: v5_0, nanoseconds: v5_1 } = e;
2068
+ dataView(memory0).setBigInt64(arg1 + 40, toUint64(v5_0), true);
2069
+ dataView(memory0).setInt32(arg1 + 48, toUint32(v5_1), true);
2070
+ }
2071
+ var variant8 = v3_4;
2072
+ if (variant8 === null || variant8=== undefined) {
2073
+ dataView(memory0).setInt8(arg1 + 56, 0, true);
2074
+ } else {
2075
+ const e = variant8;
2076
+ dataView(memory0).setInt8(arg1 + 56, 1, true);
2077
+ var {seconds: v7_0, nanoseconds: v7_1 } = e;
2078
+ dataView(memory0).setBigInt64(arg1 + 64, toUint64(v7_0), true);
2079
+ dataView(memory0).setInt32(arg1 + 72, toUint32(v7_1), true);
2080
+ }
2081
+ var variant10 = v3_5;
2082
+ if (variant10 === null || variant10=== undefined) {
2083
+ dataView(memory0).setInt8(arg1 + 80, 0, true);
2084
+ } else {
2085
+ const e = variant10;
2086
+ dataView(memory0).setInt8(arg1 + 80, 1, true);
2087
+ var {seconds: v9_0, nanoseconds: v9_1 } = e;
2088
+ dataView(memory0).setBigInt64(arg1 + 88, toUint64(v9_0), true);
2089
+ dataView(memory0).setInt32(arg1 + 96, toUint32(v9_1), true);
2090
+ }
2091
+ break;
2092
+ }
2093
+ case 'err': {
2094
+ const e = variant12.val;
2095
+ dataView(memory0).setInt8(arg1 + 0, 1, true);
2096
+ var val11 = e;
2097
+ let enum11;
2098
+ switch (val11) {
2099
+ case 'access': {
2100
+ enum11 = 0;
2101
+ break;
2102
+ }
2103
+ case 'would-block': {
2104
+ enum11 = 1;
2105
+ break;
2106
+ }
2107
+ case 'already': {
2108
+ enum11 = 2;
2109
+ break;
2110
+ }
2111
+ case 'bad-descriptor': {
2112
+ enum11 = 3;
2113
+ break;
2114
+ }
2115
+ case 'busy': {
2116
+ enum11 = 4;
2117
+ break;
2118
+ }
2119
+ case 'deadlock': {
2120
+ enum11 = 5;
2121
+ break;
2122
+ }
2123
+ case 'quota': {
2124
+ enum11 = 6;
2125
+ break;
2126
+ }
2127
+ case 'exist': {
2128
+ enum11 = 7;
2129
+ break;
2130
+ }
2131
+ case 'file-too-large': {
2132
+ enum11 = 8;
2133
+ break;
2134
+ }
2135
+ case 'illegal-byte-sequence': {
2136
+ enum11 = 9;
2137
+ break;
2138
+ }
2139
+ case 'in-progress': {
2140
+ enum11 = 10;
2141
+ break;
2142
+ }
2143
+ case 'interrupted': {
2144
+ enum11 = 11;
2145
+ break;
2146
+ }
2147
+ case 'invalid': {
2148
+ enum11 = 12;
2149
+ break;
2150
+ }
2151
+ case 'io': {
2152
+ enum11 = 13;
2153
+ break;
2154
+ }
2155
+ case 'is-directory': {
2156
+ enum11 = 14;
2157
+ break;
2158
+ }
2159
+ case 'loop': {
2160
+ enum11 = 15;
2161
+ break;
2162
+ }
2163
+ case 'too-many-links': {
2164
+ enum11 = 16;
2165
+ break;
2166
+ }
2167
+ case 'message-size': {
2168
+ enum11 = 17;
2169
+ break;
2170
+ }
2171
+ case 'name-too-long': {
2172
+ enum11 = 18;
2173
+ break;
2174
+ }
2175
+ case 'no-device': {
2176
+ enum11 = 19;
2177
+ break;
2178
+ }
2179
+ case 'no-entry': {
2180
+ enum11 = 20;
2181
+ break;
2182
+ }
2183
+ case 'no-lock': {
2184
+ enum11 = 21;
2185
+ break;
2186
+ }
2187
+ case 'insufficient-memory': {
2188
+ enum11 = 22;
2189
+ break;
2190
+ }
2191
+ case 'insufficient-space': {
2192
+ enum11 = 23;
2193
+ break;
2194
+ }
2195
+ case 'not-directory': {
2196
+ enum11 = 24;
2197
+ break;
2198
+ }
2199
+ case 'not-empty': {
2200
+ enum11 = 25;
2201
+ break;
2202
+ }
2203
+ case 'not-recoverable': {
2204
+ enum11 = 26;
2205
+ break;
2206
+ }
2207
+ case 'unsupported': {
2208
+ enum11 = 27;
2209
+ break;
2210
+ }
2211
+ case 'no-tty': {
2212
+ enum11 = 28;
2213
+ break;
2214
+ }
2215
+ case 'no-such-device': {
2216
+ enum11 = 29;
2217
+ break;
2218
+ }
2219
+ case 'overflow': {
2220
+ enum11 = 30;
2221
+ break;
2222
+ }
2223
+ case 'not-permitted': {
2224
+ enum11 = 31;
2225
+ break;
2226
+ }
2227
+ case 'pipe': {
2228
+ enum11 = 32;
2229
+ break;
2230
+ }
2231
+ case 'read-only': {
2232
+ enum11 = 33;
2233
+ break;
2234
+ }
2235
+ case 'invalid-seek': {
2236
+ enum11 = 34;
2237
+ break;
2238
+ }
2239
+ case 'text-file-busy': {
2240
+ enum11 = 35;
2241
+ break;
2242
+ }
2243
+ case 'cross-device': {
2244
+ enum11 = 36;
2245
+ break;
2246
+ }
2247
+ default: {
2248
+ if ((e) instanceof Error) {
2249
+ console.error(e);
2250
+ }
2251
+
2252
+ throw new TypeError(`"${val11}" is not one of the cases of error-code`);
2253
+ }
2254
+ }
2255
+ dataView(memory0).setInt8(arg1 + 8, enum11, true);
2256
+ break;
2257
+ }
2258
+ default: {
2259
+ throw new TypeError('invalid variant specified for result');
2260
+ }
2261
+ }
2262
+ _debugLog('[iface="wasi:filesystem/types@0.2.6", function="[method]descriptor.stat"][Instruction::Return]', {
2263
+ funcName: '[method]descriptor.stat',
2264
+ paramCount: 0,
2265
+ async: false,
2266
+ postReturn: false
2267
+ });
2268
+ }
2269
+
2270
+
2271
+ function trampoline18(arg0, arg1) {
2272
+ var handle1 = arg0;
2273
+ var rep2 = handleTable1[(handle1 << 1) + 1] & ~T_FLAG;
2274
+ var rsc0 = captureTable1.get(rep2);
2275
+ if (!rsc0) {
2276
+ rsc0 = Object.create(OutputStream.prototype);
2277
+ Object.defineProperty(rsc0, symbolRscHandle, { writable: true, value: handle1});
2278
+ Object.defineProperty(rsc0, symbolRscRep, { writable: true, value: rep2});
2279
+ }
2280
+ curResourceBorrows.push(rsc0);
2281
+ _debugLog('[iface="wasi:io/streams@0.2.6", function="[method]output-stream.check-write"] [Instruction::CallInterface] (async? sync, @ enter)');
2282
+ const _interface_call_currentTaskID = startCurrentTask(0, false, '[method]output-stream.check-write');
2283
+ let ret;
2284
+ try {
2285
+ ret = { tag: 'ok', val: rsc0.checkWrite()};
2286
+ } catch (e) {
2287
+ ret = { tag: 'err', val: getErrorPayload(e) };
2288
+ }
2289
+ _debugLog('[iface="wasi:io/streams@0.2.6", function="[method]output-stream.check-write"] [Instruction::CallInterface] (sync, @ post-call)');
2290
+ for (const rsc of curResourceBorrows) {
2291
+ rsc[symbolRscHandle] = undefined;
2292
+ }
2293
+ curResourceBorrows = [];
2294
+ endCurrentTask(0);
2295
+ var variant5 = ret;
2296
+ switch (variant5.tag) {
2297
+ case 'ok': {
2298
+ const e = variant5.val;
2299
+ dataView(memory0).setInt8(arg1 + 0, 0, true);
2300
+ dataView(memory0).setBigInt64(arg1 + 8, toUint64(e), true);
2301
+ break;
2302
+ }
2303
+ case 'err': {
2304
+ const e = variant5.val;
2305
+ dataView(memory0).setInt8(arg1 + 0, 1, true);
2306
+ var variant4 = e;
2307
+ switch (variant4.tag) {
2308
+ case 'last-operation-failed': {
2309
+ const e = variant4.val;
2310
+ dataView(memory0).setInt8(arg1 + 8, 0, true);
2311
+ if (!(e instanceof Error$1)) {
2312
+ throw new TypeError('Resource error: Not a valid "Error" resource.');
2313
+ }
2314
+ var handle3 = e[symbolRscHandle];
2315
+ if (!handle3) {
2316
+ const rep = e[symbolRscRep] || ++captureCnt0;
2317
+ captureTable0.set(rep, e);
2318
+ handle3 = rscTableCreateOwn(handleTable0, rep);
2319
+ }
2320
+ dataView(memory0).setInt32(arg1 + 12, handle3, true);
2321
+ break;
2322
+ }
2323
+ case 'closed': {
2324
+ dataView(memory0).setInt8(arg1 + 8, 1, true);
2325
+ break;
2326
+ }
2327
+ default: {
2328
+ throw new TypeError(`invalid variant tag value \`${JSON.stringify(variant4.tag)}\` (received \`${variant4}\`) specified for \`StreamError\``);
2329
+ }
2330
+ }
2331
+ break;
2332
+ }
2333
+ default: {
2334
+ throw new TypeError('invalid variant specified for result');
2335
+ }
2336
+ }
2337
+ _debugLog('[iface="wasi:io/streams@0.2.6", function="[method]output-stream.check-write"][Instruction::Return]', {
2338
+ funcName: '[method]output-stream.check-write',
2339
+ paramCount: 0,
2340
+ async: false,
2341
+ postReturn: false
2342
+ });
2343
+ }
2344
+
2345
+
2346
+ function trampoline19(arg0, arg1, arg2, arg3) {
2347
+ var handle1 = arg0;
2348
+ var rep2 = handleTable1[(handle1 << 1) + 1] & ~T_FLAG;
2349
+ var rsc0 = captureTable1.get(rep2);
2350
+ if (!rsc0) {
2351
+ rsc0 = Object.create(OutputStream.prototype);
2352
+ Object.defineProperty(rsc0, symbolRscHandle, { writable: true, value: handle1});
2353
+ Object.defineProperty(rsc0, symbolRscRep, { writable: true, value: rep2});
2354
+ }
2355
+ curResourceBorrows.push(rsc0);
2356
+ var ptr3 = arg1;
2357
+ var len3 = arg2;
2358
+ var result3 = new Uint8Array(memory0.buffer.slice(ptr3, ptr3 + len3 * 1));
2359
+ _debugLog('[iface="wasi:io/streams@0.2.6", function="[method]output-stream.write"] [Instruction::CallInterface] (async? sync, @ enter)');
2360
+ const _interface_call_currentTaskID = startCurrentTask(0, false, '[method]output-stream.write');
2361
+ let ret;
2362
+ try {
2363
+ ret = { tag: 'ok', val: rsc0.write(result3)};
2364
+ } catch (e) {
2365
+ ret = { tag: 'err', val: getErrorPayload(e) };
2366
+ }
2367
+ _debugLog('[iface="wasi:io/streams@0.2.6", function="[method]output-stream.write"] [Instruction::CallInterface] (sync, @ post-call)');
2368
+ for (const rsc of curResourceBorrows) {
2369
+ rsc[symbolRscHandle] = undefined;
2370
+ }
2371
+ curResourceBorrows = [];
2372
+ endCurrentTask(0);
2373
+ var variant6 = ret;
2374
+ switch (variant6.tag) {
2375
+ case 'ok': {
2376
+ const e = variant6.val;
2377
+ dataView(memory0).setInt8(arg3 + 0, 0, true);
2378
+ break;
2379
+ }
2380
+ case 'err': {
2381
+ const e = variant6.val;
2382
+ dataView(memory0).setInt8(arg3 + 0, 1, true);
2383
+ var variant5 = e;
2384
+ switch (variant5.tag) {
2385
+ case 'last-operation-failed': {
2386
+ const e = variant5.val;
2387
+ dataView(memory0).setInt8(arg3 + 4, 0, true);
2388
+ if (!(e instanceof Error$1)) {
2389
+ throw new TypeError('Resource error: Not a valid "Error" resource.');
2390
+ }
2391
+ var handle4 = e[symbolRscHandle];
2392
+ if (!handle4) {
2393
+ const rep = e[symbolRscRep] || ++captureCnt0;
2394
+ captureTable0.set(rep, e);
2395
+ handle4 = rscTableCreateOwn(handleTable0, rep);
2396
+ }
2397
+ dataView(memory0).setInt32(arg3 + 8, handle4, true);
2398
+ break;
2399
+ }
2400
+ case 'closed': {
2401
+ dataView(memory0).setInt8(arg3 + 4, 1, true);
2402
+ break;
2403
+ }
2404
+ default: {
2405
+ throw new TypeError(`invalid variant tag value \`${JSON.stringify(variant5.tag)}\` (received \`${variant5}\`) specified for \`StreamError\``);
2406
+ }
2407
+ }
2408
+ break;
2409
+ }
2410
+ default: {
2411
+ throw new TypeError('invalid variant specified for result');
2412
+ }
2413
+ }
2414
+ _debugLog('[iface="wasi:io/streams@0.2.6", function="[method]output-stream.write"][Instruction::Return]', {
2415
+ funcName: '[method]output-stream.write',
2416
+ paramCount: 0,
2417
+ async: false,
2418
+ postReturn: false
2419
+ });
2420
+ }
2421
+
2422
+
2423
+ function trampoline20(arg0, arg1) {
2424
+ var handle1 = arg0;
2425
+ var rep2 = handleTable1[(handle1 << 1) + 1] & ~T_FLAG;
2426
+ var rsc0 = captureTable1.get(rep2);
2427
+ if (!rsc0) {
2428
+ rsc0 = Object.create(OutputStream.prototype);
2429
+ Object.defineProperty(rsc0, symbolRscHandle, { writable: true, value: handle1});
2430
+ Object.defineProperty(rsc0, symbolRscRep, { writable: true, value: rep2});
2431
+ }
2432
+ curResourceBorrows.push(rsc0);
2433
+ _debugLog('[iface="wasi:io/streams@0.2.6", function="[method]output-stream.blocking-flush"] [Instruction::CallInterface] (async? sync, @ enter)');
2434
+ const _interface_call_currentTaskID = startCurrentTask(0, false, '[method]output-stream.blocking-flush');
2435
+ let ret;
2436
+ try {
2437
+ ret = { tag: 'ok', val: rsc0.blockingFlush()};
2438
+ } catch (e) {
2439
+ ret = { tag: 'err', val: getErrorPayload(e) };
2440
+ }
2441
+ _debugLog('[iface="wasi:io/streams@0.2.6", function="[method]output-stream.blocking-flush"] [Instruction::CallInterface] (sync, @ post-call)');
2442
+ for (const rsc of curResourceBorrows) {
2443
+ rsc[symbolRscHandle] = undefined;
2444
+ }
2445
+ curResourceBorrows = [];
2446
+ endCurrentTask(0);
2447
+ var variant5 = ret;
2448
+ switch (variant5.tag) {
2449
+ case 'ok': {
2450
+ const e = variant5.val;
2451
+ dataView(memory0).setInt8(arg1 + 0, 0, true);
2452
+ break;
2453
+ }
2454
+ case 'err': {
2455
+ const e = variant5.val;
2456
+ dataView(memory0).setInt8(arg1 + 0, 1, true);
2457
+ var variant4 = e;
2458
+ switch (variant4.tag) {
2459
+ case 'last-operation-failed': {
2460
+ const e = variant4.val;
2461
+ dataView(memory0).setInt8(arg1 + 4, 0, true);
2462
+ if (!(e instanceof Error$1)) {
2463
+ throw new TypeError('Resource error: Not a valid "Error" resource.');
2464
+ }
2465
+ var handle3 = e[symbolRscHandle];
2466
+ if (!handle3) {
2467
+ const rep = e[symbolRscRep] || ++captureCnt0;
2468
+ captureTable0.set(rep, e);
2469
+ handle3 = rscTableCreateOwn(handleTable0, rep);
2470
+ }
2471
+ dataView(memory0).setInt32(arg1 + 8, handle3, true);
2472
+ break;
2473
+ }
2474
+ case 'closed': {
2475
+ dataView(memory0).setInt8(arg1 + 4, 1, true);
2476
+ break;
2477
+ }
2478
+ default: {
2479
+ throw new TypeError(`invalid variant tag value \`${JSON.stringify(variant4.tag)}\` (received \`${variant4}\`) specified for \`StreamError\``);
2480
+ }
2481
+ }
2482
+ break;
2483
+ }
2484
+ default: {
2485
+ throw new TypeError('invalid variant specified for result');
2486
+ }
2487
+ }
2488
+ _debugLog('[iface="wasi:io/streams@0.2.6", function="[method]output-stream.blocking-flush"][Instruction::Return]', {
2489
+ funcName: '[method]output-stream.blocking-flush',
2490
+ paramCount: 0,
2491
+ async: false,
2492
+ postReturn: false
2493
+ });
2494
+ }
2495
+
2496
+
2497
+ function trampoline21(arg0) {
2498
+ _debugLog('[iface="wasi:filesystem/preopens@0.2.6", function="get-directories"] [Instruction::CallInterface] (async? sync, @ enter)');
2499
+ const _interface_call_currentTaskID = startCurrentTask(0, false, 'get-directories');
2500
+ const ret = getDirectories();
2501
+ _debugLog('[iface="wasi:filesystem/preopens@0.2.6", function="get-directories"] [Instruction::CallInterface] (sync, @ post-call)');
2502
+ endCurrentTask(0);
2503
+ var vec3 = ret;
2504
+ var len3 = vec3.length;
2505
+ var result3 = realloc1(0, 0, 4, len3 * 12);
2506
+ for (let i = 0; i < vec3.length; i++) {
2507
+ const e = vec3[i];
2508
+ const base = result3 + i * 12;var [tuple0_0, tuple0_1] = e;
2509
+ if (!(tuple0_0 instanceof Descriptor)) {
2510
+ throw new TypeError('Resource error: Not a valid "Descriptor" resource.');
2511
+ }
2512
+ var handle1 = tuple0_0[symbolRscHandle];
2513
+ if (!handle1) {
2514
+ const rep = tuple0_0[symbolRscRep] || ++captureCnt4;
2515
+ captureTable4.set(rep, tuple0_0);
2516
+ handle1 = rscTableCreateOwn(handleTable4, rep);
2517
+ }
2518
+ dataView(memory0).setInt32(base + 0, handle1, true);
2519
+ var ptr2 = utf8Encode(tuple0_1, realloc1, memory0);
2520
+ var len2 = utf8EncodedLen;
2521
+ dataView(memory0).setUint32(base + 8, len2, true);
2522
+ dataView(memory0).setUint32(base + 4, ptr2, true);
2523
+ }
2524
+ dataView(memory0).setUint32(arg0 + 4, len3, true);
2525
+ dataView(memory0).setUint32(arg0 + 0, result3, true);
2526
+ _debugLog('[iface="wasi:filesystem/preopens@0.2.6", function="get-directories"][Instruction::Return]', {
2527
+ funcName: 'get-directories',
2528
+ paramCount: 0,
2529
+ async: false,
2530
+ postReturn: false
2531
+ });
2532
+ }
2533
+
2534
+ let exports3;
2535
+ let postReturn0;
2536
+ function trampoline0(handle) {
2537
+ const handleEntry = rscTableRemove(handleTable0, handle);
2538
+ if (handleEntry.own) {
2539
+
2540
+ const rsc = captureTable0.get(handleEntry.rep);
2541
+ if (rsc) {
2542
+ if (rsc[symbolDispose]) rsc[symbolDispose]();
2543
+ captureTable0.delete(handleEntry.rep);
2544
+ } else if (Error$1[symbolCabiDispose]) {
2545
+ Error$1[symbolCabiDispose](handleEntry.rep);
2546
+ }
2547
+ }
2548
+ }
2549
+ function trampoline1(handle) {
2550
+ const handleEntry = rscTableRemove(handleTable1, handle);
2551
+ if (handleEntry.own) {
2552
+
2553
+ const rsc = captureTable1.get(handleEntry.rep);
2554
+ if (rsc) {
2555
+ if (rsc[symbolDispose]) rsc[symbolDispose]();
2556
+ captureTable1.delete(handleEntry.rep);
2557
+ } else if (OutputStream[symbolCabiDispose]) {
2558
+ OutputStream[symbolCabiDispose](handleEntry.rep);
2559
+ }
2560
+ }
2561
+ }
2562
+ const handleTable3 = [T_FLAG, 0];
2563
+ const captureTable3= new Map();
2564
+ let captureCnt3 = 0;
2565
+ handleTables[3] = handleTable3;
2566
+ function trampoline3(handle) {
2567
+ const handleEntry = rscTableRemove(handleTable3, handle);
2568
+ if (handleEntry.own) {
2569
+ throw new TypeError('unreachable trampoline for resource [ResourceIndex(3)]')
2570
+ }
2571
+ }
2572
+ function trampoline4(handle) {
2573
+ const handleEntry = rscTableRemove(handleTable4, handle);
2574
+ if (handleEntry.own) {
2575
+
2576
+ const rsc = captureTable4.get(handleEntry.rep);
2577
+ if (rsc) {
2578
+ if (rsc[symbolDispose]) rsc[symbolDispose]();
2579
+ captureTable4.delete(handleEntry.rep);
2580
+ } else if (Descriptor[symbolCabiDispose]) {
2581
+ Descriptor[symbolCabiDispose](handleEntry.rep);
2582
+ }
2583
+ }
2584
+ }
2585
+ function trampoline5(handle) {
2586
+ const handleEntry = rscTableRemove(handleTable2, handle);
2587
+ if (handleEntry.own) {
2588
+
2589
+ const rsc = captureTable2.get(handleEntry.rep);
2590
+ if (rsc) {
2591
+ if (rsc[symbolDispose]) rsc[symbolDispose]();
2592
+ captureTable2.delete(handleEntry.rep);
2593
+ } else if (InputStream[symbolCabiDispose]) {
2594
+ InputStream[symbolCabiDispose](handleEntry.rep);
2595
+ }
2596
+ }
2597
+ }
2598
+ let syntaxHighlighter001RenderHighlighted;
2599
+
2600
+ function renderHighlighted(arg0, arg1, arg2, arg3) {
2601
+ var ptr0 = utf8Encode(arg0, realloc0, memory0);
2602
+ var len0 = utf8EncodedLen;
2603
+ var ptr1 = utf8Encode(arg1, realloc0, memory0);
2604
+ var len1 = utf8EncodedLen;
2605
+ var ptr2 = utf8Encode(arg2, realloc0, memory0);
2606
+ var len2 = utf8EncodedLen;
2607
+ var ptr3 = utf8Encode(arg3, realloc0, memory0);
2608
+ var len3 = utf8EncodedLen;
2609
+ _debugLog('[iface="docs:giallo-js/syntax-highlighter@0.0.1", function="render-highlighted"][Instruction::CallWasm] enter', {
2610
+ funcName: 'render-highlighted',
2611
+ paramCount: 8,
2612
+ async: false,
2613
+ postReturn: true,
2614
+ });
2615
+ const _wasm_call_currentTaskID = startCurrentTask(0, false, 'syntaxHighlighter001RenderHighlighted');
2616
+ const ret = syntaxHighlighter001RenderHighlighted(ptr0, len0, ptr1, len1, ptr2, len2, ptr3, len3);
2617
+ endCurrentTask(0);
2618
+ let variant6;
2619
+ switch (dataView(memory0).getUint8(ret + 0, true)) {
2620
+ case 0: {
2621
+ var ptr4 = dataView(memory0).getUint32(ret + 4, true);
2622
+ var len4 = dataView(memory0).getUint32(ret + 8, true);
2623
+ var result4 = utf8Decoder.decode(new Uint8Array(memory0.buffer, ptr4, len4));
2624
+ variant6= {
2625
+ tag: 'ok',
2626
+ val: result4
2627
+ };
2628
+ break;
2629
+ }
2630
+ case 1: {
2631
+ var ptr5 = dataView(memory0).getUint32(ret + 4, true);
2632
+ var len5 = dataView(memory0).getUint32(ret + 8, true);
2633
+ var result5 = utf8Decoder.decode(new Uint8Array(memory0.buffer, ptr5, len5));
2634
+ variant6= {
2635
+ tag: 'err',
2636
+ val: result5
2637
+ };
2638
+ break;
2639
+ }
2640
+ default: {
2641
+ throw new TypeError('invalid variant discriminant for expected');
2642
+ }
2643
+ }
2644
+ _debugLog('[iface="docs:giallo-js/syntax-highlighter@0.0.1", function="render-highlighted"][Instruction::Return]', {
2645
+ funcName: 'render-highlighted',
2646
+ paramCount: 1,
2647
+ async: false,
2648
+ postReturn: true
2649
+ });
2650
+ const retCopy = variant6;
2651
+
2652
+ let cstate = getOrCreateAsyncState(0);
2653
+ cstate.mayLeave = false;
2654
+ postReturn0(ret);
2655
+ cstate.mayLeave = true;
2656
+
2657
+
2658
+
2659
+ if (typeof retCopy === 'object' && retCopy.tag === 'err') {
2660
+ throw new ComponentError(retCopy.val);
2661
+ }
2662
+ return retCopy.val;
2663
+
2664
+ }
2665
+
2666
+ const $init = (() => {
2667
+ let gen = (function* _initGenerator () {
2668
+ const module0 = fetchCompile(new URL('./giallo_js.core.wasm', import.meta.url));
2669
+ const module1 = fetchCompile(new URL('./giallo_js.core2.wasm', import.meta.url));
2670
+ const module2 = base64Compile('AGFzbQEAAAABPQpgAn9/AGAEf39/fwBgAX8AYAJ/fwF/YAF/AX9gA39/fwF/YAR/fn9/AX9gBH9/f38Bf2ABfwBgA39+fwADFxYAAQIDAwQDBQYHCAIACQAAAAABAAECBAUBcAEWFgdwFwEwAAABMQABATIAAgEzAAMBNAAEATUABQE2AAYBNwAHATgACAE5AAkCMTAACgIxMQALAjEyAAwCMTMADQIxNAAOAjE1AA8CMTYAEAIxNwARAjE4ABICMTkAEwIyMAAUAjIxABUIJGltcG9ydHMBAAqXAhYLACAAIAFBABEAAAsPACAAIAEgAiADQQERAQALCQAgAEECEQIACwsAIAAgAUEDEQMACwsAIAAgAUEEEQMACwkAIABBBREEAAsLACAAIAFBBhEDAAsNACAAIAEgAkEHEQUACw8AIAAgASACIANBCBEGAAsPACAAIAEgAiADQQkRBwALCQAgAEEKEQgACwkAIABBCxECAAsLACAAIAFBDBEAAAsNACAAIAEgAkENEQkACwsAIAAgAUEOEQAACwsAIAAgAUEPEQAACwsAIAAgAUEQEQAACwsAIAAgAUEREQAACw8AIAAgASACIANBEhEBAAsLACAAIAFBExEAAAsPACAAIAEgAiADQRQRAQALCQAgAEEVEQIACwAvCXByb2R1Y2VycwEMcHJvY2Vzc2VkLWJ5AQ13aXQtY29tcG9uZW50BzAuMjQxLjI');
2671
+ const module3 = base64Compile('AGFzbQEAAAABPQpgAn9/AGAEf39/fwBgAX8AYAJ/fwF/YAF/AX9gA39/fwF/YAR/fn9/AX9gBH9/f38Bf2ABfwBgA39+fwACigEXAAEwAAAAATEAAQABMgACAAEzAAMAATQAAwABNQAEAAE2AAMAATcABQABOAAGAAE5AAcAAjEwAAgAAjExAAIAAjEyAAAAAjEzAAkAAjE0AAAAAjE1AAAAAjE2AAAAAjE3AAAAAjE4AAEAAjE5AAAAAjIwAAEAAjIxAAIACCRpbXBvcnRzAXABFhYJHAEAQQALFgABAgMEBQYHCAkKCwwNDg8QERITFBUALwlwcm9kdWNlcnMBDHByb2Nlc3NlZC1ieQENd2l0LWNvbXBvbmVudAcwLjI0MS4y');
2672
+ ({ exports: exports0 } = yield instantiateCore(yield module2));
2673
+ ({ exports: exports1 } = yield instantiateCore(yield module0, {
2674
+ 'wasi:cli/stderr@0.2.4': {
2675
+ 'get-stderr': trampoline2,
2676
+ },
2677
+ 'wasi:io/error@0.2.4': {
2678
+ '[method]error.to-debug-string': exports0['0'],
2679
+ '[resource-drop]error': trampoline0,
2680
+ },
2681
+ 'wasi:io/streams@0.2.4': {
2682
+ '[method]output-stream.blocking-write-and-flush': exports0['1'],
2683
+ '[resource-drop]output-stream': trampoline1,
2684
+ },
2685
+ 'wasi:random/insecure-seed@0.2.4': {
2686
+ 'insecure-seed': exports0['2'],
2687
+ },
2688
+ wasi_snapshot_preview1: {
2689
+ environ_get: exports0['3'],
2690
+ environ_sizes_get: exports0['4'],
2691
+ fd_close: exports0['5'],
2692
+ fd_prestat_dir_name: exports0['7'],
2693
+ fd_prestat_get: exports0['6'],
2694
+ fd_seek: exports0['8'],
2695
+ fd_write: exports0['9'],
2696
+ proc_exit: exports0['10'],
2697
+ },
2698
+ }));
2699
+ ({ exports: exports2 } = yield instantiateCore(yield module1, {
2700
+ __main_module__: {
2701
+ cabi_realloc: exports1.cabi_realloc,
2702
+ },
2703
+ env: {
2704
+ memory: exports1.memory,
2705
+ },
2706
+ 'wasi:cli/environment@0.2.6': {
2707
+ 'get-environment': exports0['11'],
2708
+ },
2709
+ 'wasi:cli/exit@0.2.6': {
2710
+ exit: trampoline8,
2711
+ },
2712
+ 'wasi:cli/stderr@0.2.6': {
2713
+ 'get-stderr': trampoline2,
2714
+ },
2715
+ 'wasi:cli/stdin@0.2.6': {
2716
+ 'get-stdin': trampoline6,
2717
+ },
2718
+ 'wasi:cli/stdout@0.2.6': {
2719
+ 'get-stdout': trampoline7,
2720
+ },
2721
+ 'wasi:filesystem/preopens@0.2.6': {
2722
+ 'get-directories': exports0['21'],
2723
+ },
2724
+ 'wasi:filesystem/types@0.2.6': {
2725
+ '[method]descriptor.append-via-stream': exports0['14'],
2726
+ '[method]descriptor.get-type': exports0['15'],
2727
+ '[method]descriptor.stat': exports0['16'],
2728
+ '[method]descriptor.write-via-stream': exports0['13'],
2729
+ '[resource-drop]descriptor': trampoline4,
2730
+ '[resource-drop]directory-entry-stream': trampoline3,
2731
+ 'filesystem-error-code': exports0['12'],
2732
+ },
2733
+ 'wasi:io/error@0.2.6': {
2734
+ '[resource-drop]error': trampoline0,
2735
+ },
2736
+ 'wasi:io/streams@0.2.6': {
2737
+ '[method]output-stream.blocking-flush': exports0['19'],
2738
+ '[method]output-stream.blocking-write-and-flush': exports0['20'],
2739
+ '[method]output-stream.check-write': exports0['17'],
2740
+ '[method]output-stream.write': exports0['18'],
2741
+ '[resource-drop]input-stream': trampoline5,
2742
+ '[resource-drop]output-stream': trampoline1,
2743
+ },
2744
+ }));
2745
+ memory0 = exports1.memory;
2746
+ realloc0 = exports1.cabi_realloc;
2747
+ realloc1 = exports2.cabi_import_realloc;
2748
+ ({ exports: exports3 } = yield instantiateCore(yield module3, {
2749
+ '': {
2750
+ $imports: exports0.$imports,
2751
+ '0': trampoline9,
2752
+ '1': trampoline10,
2753
+ '10': exports2.proc_exit,
2754
+ '11': trampoline12,
2755
+ '12': trampoline13,
2756
+ '13': trampoline14,
2757
+ '14': trampoline15,
2758
+ '15': trampoline16,
2759
+ '16': trampoline17,
2760
+ '17': trampoline18,
2761
+ '18': trampoline19,
2762
+ '19': trampoline20,
2763
+ '2': trampoline11,
2764
+ '20': trampoline10,
2765
+ '21': trampoline21,
2766
+ '3': exports2.environ_get,
2767
+ '4': exports2.environ_sizes_get,
2768
+ '5': exports2.fd_close,
2769
+ '6': exports2.fd_prestat_get,
2770
+ '7': exports2.fd_prestat_dir_name,
2771
+ '8': exports2.fd_seek,
2772
+ '9': exports2.fd_write,
2773
+ },
2774
+ }));
2775
+ postReturn0 = exports1['cabi_post_docs:giallo-js/syntax-highlighter@0.0.1#render-highlighted'];
2776
+ syntaxHighlighter001RenderHighlighted = exports1['docs:giallo-js/syntax-highlighter@0.0.1#render-highlighted'];
2777
+ })();
2778
+ let promise, resolve, reject;
2779
+ function runNext (value) {
2780
+ try {
2781
+ let done;
2782
+ do {
2783
+ ({ value, done } = gen.next(value));
2784
+ } while (!(value instanceof Promise) && !done);
2785
+ if (done) {
2786
+ if (resolve) resolve(value);
2787
+ else return value;
2788
+ }
2789
+ if (!promise) promise = new Promise((_resolve, _reject) => (resolve = _resolve, reject = _reject));
2790
+ value.then(runNext, reject);
2791
+ }
2792
+ catch (e) {
2793
+ if (reject) reject(e);
2794
+ else throw e;
2795
+ }
2796
+ }
2797
+ const maybeSyncReturn = runNext(null);
2798
+ return promise || maybeSyncReturn;
2799
+ })();
2800
+
2801
+ await $init;
2802
+ const syntaxHighlighter001 = {
2803
+ renderHighlighted: renderHighlighted,
2804
+
2805
+ };
2806
+
2807
+ export { syntaxHighlighter001 as syntaxHighlighter, syntaxHighlighter001 as 'docs:giallo-js/syntax-highlighter@0.0.1', }