@bytecodealliance/preview2-shim 0.0.20 → 0.14.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +4 -14
- package/lib/browser/cli.js +77 -12
- package/lib/browser/clocks.js +15 -27
- package/lib/browser/filesystem.js +147 -205
- package/lib/browser/index.js +1 -3
- package/lib/{common → browser}/io.js +8 -4
- package/lib/common/assert.js +7 -0
- package/lib/io/calls.js +64 -0
- package/lib/io/worker-http.js +95 -0
- package/lib/io/worker-io.js +322 -0
- package/lib/io/worker-thread.js +569 -0
- package/lib/nodejs/cli.js +45 -58
- package/lib/nodejs/clocks.js +13 -27
- package/lib/nodejs/filesystem.js +540 -427
- package/lib/nodejs/http.js +441 -175
- package/lib/nodejs/index.js +4 -1
- package/lib/nodejs/io.js +1 -0
- package/lib/nodejs/sockets/socket-common.js +116 -0
- package/lib/nodejs/sockets/socketopts-bindings.js +94 -0
- package/lib/nodejs/sockets/tcp-socket-impl.js +794 -0
- package/lib/nodejs/sockets/udp-socket-impl.js +628 -0
- package/lib/nodejs/sockets/wasi-sockets.js +320 -0
- package/lib/nodejs/sockets.js +11 -200
- package/lib/synckit/index.js +4 -2
- package/package.json +1 -5
- package/types/interfaces/wasi-cli-terminal-input.d.ts +4 -0
- package/types/interfaces/wasi-cli-terminal-output.d.ts +4 -0
- package/types/interfaces/wasi-clocks-monotonic-clock.d.ts +19 -6
- package/types/interfaces/wasi-filesystem-types.d.ts +1 -178
- package/types/interfaces/wasi-http-outgoing-handler.d.ts +2 -2
- package/types/interfaces/wasi-http-types.d.ts +412 -82
- package/types/interfaces/wasi-io-error.d.ts +16 -0
- package/types/interfaces/wasi-io-poll.d.ts +19 -8
- package/types/interfaces/wasi-io-streams.d.ts +26 -46
- package/types/interfaces/wasi-sockets-ip-name-lookup.d.ts +9 -21
- package/types/interfaces/wasi-sockets-network.d.ts +4 -0
- package/types/interfaces/wasi-sockets-tcp.d.ts +75 -18
- package/types/interfaces/wasi-sockets-udp-create-socket.d.ts +1 -1
- package/types/interfaces/wasi-sockets-udp.d.ts +282 -193
- package/types/wasi-cli-command.d.ts +28 -28
- package/types/wasi-http-proxy.d.ts +12 -12
- package/lib/common/make-request.js +0 -30
- package/types/interfaces/wasi-clocks-timezone.d.ts +0 -56
package/lib/nodejs/cli.js
CHANGED
|
@@ -1,114 +1,101 @@
|
|
|
1
|
-
import { argv, env, cwd } from
|
|
2
|
-
import {
|
|
1
|
+
import { argv, env, cwd } from "node:process";
|
|
2
|
+
import {
|
|
3
|
+
streams,
|
|
4
|
+
inputStreamCreate,
|
|
5
|
+
outputStreamCreate,
|
|
6
|
+
} from "../io/worker-io.js";
|
|
7
|
+
import { STDIN, STDOUT, STDERR } from "../io/calls.js";
|
|
3
8
|
const { InputStream, OutputStream } = streams;
|
|
4
9
|
|
|
5
|
-
|
|
10
|
+
export const _setEnv = env => void (_env = Object.entries(env));
|
|
11
|
+
export const _setArgs = args => void (_args = args);
|
|
12
|
+
export const _setCwd = cwd => void (_cwd = cwd);
|
|
13
|
+
export const _setStdin = stdin => void (stdinStream = stdin);
|
|
14
|
+
export const _setStdout = stdout => void (stdoutStream = stdout);
|
|
15
|
+
export const _setStderr = stderr => void (stderrStream = stderr);
|
|
16
|
+
export const _setTerminalStdin = terminalStdin => void (terminalStdinInstance = terminalStdin);
|
|
17
|
+
export const _setTerminalStdout = terminalStdout => void (terminalStdoutInstance = terminalStdout);
|
|
18
|
+
export const _setTerminalStderr = terminalStderr => void (terminalStderrInstance = terminalStderr);
|
|
19
|
+
|
|
20
|
+
let _env = Object.entries(env),
|
|
21
|
+
_args = argv.slice(1),
|
|
22
|
+
_cwd = cwd();
|
|
6
23
|
|
|
7
24
|
export const environment = {
|
|
8
|
-
getEnvironment
|
|
25
|
+
getEnvironment() {
|
|
9
26
|
return _env;
|
|
10
27
|
},
|
|
11
|
-
getArguments
|
|
28
|
+
getArguments() {
|
|
12
29
|
return _args;
|
|
13
30
|
},
|
|
14
|
-
initialCwd
|
|
31
|
+
initialCwd() {
|
|
15
32
|
return _cwd;
|
|
16
|
-
}
|
|
33
|
+
},
|
|
17
34
|
};
|
|
18
35
|
|
|
19
36
|
export const exit = {
|
|
20
|
-
exit
|
|
21
|
-
process.exit(status.tag ===
|
|
22
|
-
}
|
|
23
|
-
};
|
|
24
|
-
|
|
25
|
-
const stdinStream = new InputStream({
|
|
26
|
-
blockingRead (_len) {
|
|
27
|
-
// TODO
|
|
28
|
-
},
|
|
29
|
-
subscribe () {
|
|
30
|
-
// TODO
|
|
37
|
+
exit(status) {
|
|
38
|
+
process.exit(status.tag === "err" ? 1 : 0);
|
|
31
39
|
},
|
|
32
|
-
|
|
33
|
-
// TODO
|
|
34
|
-
}
|
|
35
|
-
});
|
|
36
|
-
const stdoutStream = new OutputStream({
|
|
37
|
-
write (contents) {
|
|
38
|
-
process.stdout.write(contents);
|
|
39
|
-
},
|
|
40
|
-
blockingFlush () {
|
|
41
|
-
},
|
|
42
|
-
drop () {
|
|
43
|
-
}
|
|
44
|
-
});
|
|
45
|
-
const stderrStream = new OutputStream({
|
|
46
|
-
write (contents) {
|
|
47
|
-
process.stderr.write(contents);
|
|
48
|
-
},
|
|
49
|
-
blockingFlush () {
|
|
50
|
-
|
|
51
|
-
},
|
|
52
|
-
drop () {
|
|
40
|
+
};
|
|
53
41
|
|
|
54
|
-
|
|
55
|
-
|
|
42
|
+
let stdinStream = inputStreamCreate(STDIN, 1);
|
|
43
|
+
let stdoutStream = outputStreamCreate(STDOUT, 2);
|
|
44
|
+
let stderrStream = outputStreamCreate(STDERR, 3);
|
|
56
45
|
|
|
57
46
|
export const stdin = {
|
|
58
47
|
InputStream,
|
|
59
|
-
getStdin
|
|
48
|
+
getStdin() {
|
|
60
49
|
return stdinStream;
|
|
61
|
-
}
|
|
50
|
+
},
|
|
62
51
|
};
|
|
63
52
|
|
|
64
53
|
export const stdout = {
|
|
65
54
|
OutputStream,
|
|
66
|
-
getStdout
|
|
55
|
+
getStdout() {
|
|
67
56
|
return stdoutStream;
|
|
68
|
-
}
|
|
57
|
+
},
|
|
69
58
|
};
|
|
70
59
|
|
|
71
60
|
export const stderr = {
|
|
72
61
|
OutputStream,
|
|
73
|
-
getStderr
|
|
62
|
+
getStderr() {
|
|
74
63
|
return stderrStream;
|
|
75
|
-
}
|
|
64
|
+
},
|
|
76
65
|
};
|
|
77
66
|
|
|
78
67
|
class TerminalInput {}
|
|
79
68
|
class TerminalOutput {}
|
|
80
69
|
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
70
|
+
let terminalStdoutInstance = new TerminalOutput();
|
|
71
|
+
let terminalStderrInstance = new TerminalOutput();
|
|
72
|
+
let terminalStdinInstance = new TerminalInput();
|
|
84
73
|
|
|
85
74
|
export const terminalInput = {
|
|
86
75
|
TerminalInput,
|
|
87
|
-
dropTerminalInput () {}
|
|
88
76
|
};
|
|
89
77
|
|
|
90
78
|
export const terminalOutput = {
|
|
91
79
|
TerminalOutput,
|
|
92
|
-
dropTerminalOutput () {}
|
|
93
80
|
};
|
|
94
81
|
|
|
95
82
|
export const terminalStderr = {
|
|
96
83
|
TerminalOutput,
|
|
97
|
-
getTerminalStderr
|
|
84
|
+
getTerminalStderr() {
|
|
98
85
|
return terminalStderrInstance;
|
|
99
|
-
}
|
|
86
|
+
},
|
|
100
87
|
};
|
|
101
88
|
|
|
102
89
|
export const terminalStdin = {
|
|
103
90
|
TerminalInput,
|
|
104
|
-
getTerminalStdin
|
|
91
|
+
getTerminalStdin() {
|
|
105
92
|
return terminalStdinInstance;
|
|
106
|
-
}
|
|
93
|
+
},
|
|
107
94
|
};
|
|
108
95
|
|
|
109
96
|
export const terminalStdout = {
|
|
110
97
|
TerminalOutput,
|
|
111
|
-
getTerminalStdout
|
|
98
|
+
getTerminalStdout() {
|
|
112
99
|
return terminalStdoutInstance;
|
|
113
|
-
}
|
|
100
|
+
},
|
|
114
101
|
};
|
package/lib/nodejs/clocks.js
CHANGED
|
@@ -1,34 +1,21 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
let _hrStart = hrtime.bigint();
|
|
1
|
+
import { ioCall, createPoll, resolvedPoll } from "../io/worker-io.js";
|
|
2
|
+
import * as calls from "../io/calls.js";
|
|
4
3
|
|
|
5
4
|
export const monotonicClock = {
|
|
6
|
-
resolution
|
|
5
|
+
resolution() {
|
|
7
6
|
return 1n;
|
|
8
7
|
},
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
return hrtime.bigint() - _hrStart;
|
|
8
|
+
now() {
|
|
9
|
+
return ioCall(calls.CLOCKS_NOW);
|
|
12
10
|
},
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
console.log(`[monotonic-clock] Subscribe`);
|
|
16
|
-
}
|
|
17
|
-
};
|
|
18
|
-
|
|
19
|
-
export const timezone = {
|
|
20
|
-
display (timezone, when) {
|
|
21
|
-
console.log(`[timezone] DISPLAY ${timezone} ${when}`);
|
|
11
|
+
subscribeInstant(instant) {
|
|
12
|
+
return createPoll(calls.CLOCKS_INSTANT_SUBSCRIBE, null, instant);
|
|
22
13
|
},
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
return
|
|
14
|
+
subscribeDuration(duration) {
|
|
15
|
+
duration = BigInt(duration);
|
|
16
|
+
if (duration === 0n) return resolvedPoll();
|
|
17
|
+
return createPoll(calls.CLOCKS_DURATION_SUBSCRIBE, null, duration);
|
|
27
18
|
},
|
|
28
|
-
|
|
29
|
-
dropTimezone (timezone) {
|
|
30
|
-
console.log(`[timezone] DROP ${timezone}`);
|
|
31
|
-
}
|
|
32
19
|
};
|
|
33
20
|
|
|
34
21
|
export const wallClock = {
|
|
@@ -37,8 +24,7 @@ export const wallClock = {
|
|
|
37
24
|
const nanoseconds = (Date.now() % 1e3) * 1e6;
|
|
38
25
|
return { seconds, nanoseconds };
|
|
39
26
|
},
|
|
40
|
-
|
|
41
27
|
resolution() {
|
|
42
|
-
|
|
43
|
-
}
|
|
28
|
+
return { seconds: 0n, nanoseconds: 1e6 };
|
|
29
|
+
},
|
|
44
30
|
};
|