Skip to content

Commit

Permalink
preview2-shim 0.16.1
Browse files Browse the repository at this point in the history
  • Loading branch information
guybedford committed Mar 22, 2024
1 parent 771bdb0 commit 29e51ba
Show file tree
Hide file tree
Showing 20 changed files with 101 additions and 101 deletions.
2 changes: 1 addition & 1 deletion packages/preview2-shim/package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "@bytecodealliance/preview2-shim",
"version": "0.16.0",
"version": "0.16.1",
"description": "WASI Preview2 shim for JS environments",
"author": "Guy Bedford, Eduardo Rodrigues<16357187+eduardomourar@users.noreply.github.com>",
"type": "module",
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
export namespace WasiCliStderr {
export function getStderr(): OutputStream;
}
import type { OutputStream } from '../interfaces/wasi-io-streams.js';
import type { OutputStream } from './wasi-io-streams.js';
export { OutputStream };
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
export namespace WasiCliStdin {
export function getStdin(): InputStream;
}
import type { InputStream } from '../interfaces/wasi-io-streams.js';
import type { InputStream } from './wasi-io-streams.js';
export { InputStream };
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
export namespace WasiCliStdout {
export function getStdout(): OutputStream;
}
import type { OutputStream } from '../interfaces/wasi-io-streams.js';
import type { OutputStream } from './wasi-io-streams.js';
export { OutputStream };
Original file line number Diff line number Diff line change
Expand Up @@ -5,5 +5,5 @@ export namespace WasiCliTerminalStderr {
*/
export function getTerminalStderr(): TerminalOutput | undefined;
}
import type { TerminalOutput } from '../interfaces/wasi-cli-terminal-output.js';
import type { TerminalOutput } from './wasi-cli-terminal-output.js';
export { TerminalOutput };
Original file line number Diff line number Diff line change
Expand Up @@ -5,5 +5,5 @@ export namespace WasiCliTerminalStdin {
*/
export function getTerminalStdin(): TerminalInput | undefined;
}
import type { TerminalInput } from '../interfaces/wasi-cli-terminal-input.js';
import type { TerminalInput } from './wasi-cli-terminal-input.js';
export { TerminalInput };
Original file line number Diff line number Diff line change
Expand Up @@ -5,5 +5,5 @@ export namespace WasiCliTerminalStdout {
*/
export function getTerminalStdout(): TerminalOutput | undefined;
}
import type { TerminalOutput } from '../interfaces/wasi-cli-terminal-output.js';
import type { TerminalOutput } from './wasi-cli-terminal-output.js';
export { TerminalOutput };
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ export namespace WasiClocksMonotonicClock {
*/
export function subscribeDuration(when: Duration): Pollable;
}
import type { Pollable } from '../interfaces/wasi-io-poll.js';
import type { Pollable } from './wasi-io-poll.js';
export { Pollable };
/**
* An instant in time, in nanoseconds. An instant is relative to an
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,5 +4,5 @@ export namespace WasiFilesystemPreopens {
*/
export function getDirectories(): [Descriptor, string][];
}
import type { Descriptor } from '../interfaces/wasi-filesystem-types.js';
import type { Descriptor } from './wasi-filesystem-types.js';
export { Descriptor };
Original file line number Diff line number Diff line change
Expand Up @@ -260,13 +260,13 @@ export namespace WasiFilesystemTypes {
*/
export function filesystemErrorCode(err: Error): ErrorCode | undefined;
}
import type { InputStream } from '../interfaces/wasi-io-streams.js';
import type { InputStream } from './wasi-io-streams.js';
export { InputStream };
import type { OutputStream } from '../interfaces/wasi-io-streams.js';
import type { OutputStream } from './wasi-io-streams.js';
export { OutputStream };
import type { Error } from '../interfaces/wasi-io-streams.js';
import type { Error } from './wasi-io-streams.js';
export { Error };
import type { Datetime } from '../interfaces/wasi-clocks-wall-clock.js';
import type { Datetime } from './wasi-clocks-wall-clock.js';
export { Datetime };
/**
* File size or length of a region within a file.
Expand Down Expand Up @@ -639,6 +639,10 @@ export interface MetadataHashValue {
upper: bigint,
}

export class DirectoryEntryStream {
readDirectoryEntry(): DirectoryEntry | undefined;
}

export class Descriptor {
readViaStream(offset: Filesize): InputStream;
writeViaStream(offset: Filesize): OutputStream;
Expand Down Expand Up @@ -668,7 +672,3 @@ export class Descriptor {
metadataHash(): MetadataHashValue;
metadataHashAt(pathFlags: PathFlags, path: string): MetadataHashValue;
}

export class DirectoryEntryStream {
readDirectoryEntry(): DirectoryEntry | undefined;
}
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ export namespace WasiHttpIncomingHandler {
*/
export function handle(request: IncomingRequest, responseOut: ResponseOutparam): void;
}
import type { IncomingRequest } from '../interfaces/wasi-http-types.js';
import type { IncomingRequest } from './wasi-http-types.js';
export { IncomingRequest };
import type { ResponseOutparam } from '../interfaces/wasi-http-types.js';
import type { ResponseOutparam } from './wasi-http-types.js';
export { ResponseOutparam };
Original file line number Diff line number Diff line change
Expand Up @@ -13,11 +13,11 @@ export namespace WasiHttpOutgoingHandler {
*/
export function handle(request: OutgoingRequest, options: RequestOptions | undefined): FutureIncomingResponse;
}
import type { OutgoingRequest } from '../interfaces/wasi-http-types.js';
import type { OutgoingRequest } from './wasi-http-types.js';
export { OutgoingRequest };
import type { RequestOptions } from '../interfaces/wasi-http-types.js';
import type { RequestOptions } from './wasi-http-types.js';
export { RequestOptions };
import type { FutureIncomingResponse } from '../interfaces/wasi-http-types.js';
import type { FutureIncomingResponse } from './wasi-http-types.js';
export { FutureIncomingResponse };
import type { ErrorCode } from '../interfaces/wasi-http-types.js';
import type { ErrorCode } from './wasi-http-types.js';
export { ErrorCode };
100 changes: 50 additions & 50 deletions packages/preview2-shim/types/interfaces/wasi-http-types.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -354,15 +354,15 @@ export namespace WasiHttpTypes {
* `output-stream` child.
*/
}
import type { Duration } from '../interfaces/wasi-clocks-monotonic-clock.js';
import type { Duration } from './wasi-clocks-monotonic-clock.js';
export { Duration };
import type { InputStream } from '../interfaces/wasi-io-streams.js';
import type { InputStream } from './wasi-io-streams.js';
export { InputStream };
import type { OutputStream } from '../interfaces/wasi-io-streams.js';
import type { OutputStream } from './wasi-io-streams.js';
export { OutputStream };
import type { Error as IoError } from '../interfaces/wasi-io-error.js';
import type { Error as IoError } from './wasi-io-error.js';
export { IoError };
import type { Pollable } from '../interfaces/wasi-io-poll.js';
import type { Pollable } from './wasi-io-poll.js';
export { Pollable };
/**
* This type corresponds to HTTP standard Methods.
Expand Down Expand Up @@ -629,10 +629,6 @@ export type Trailers = Fields;
export type StatusCode = number;
export type Result<T, E> = { tag: 'ok', val: T } | { tag: 'err', val: E };

export class ResponseOutparam {
static set(param: ResponseOutparam, response: Result<OutgoingResponse, ErrorCode>): void;
}

export class OutgoingResponse {
constructor(headers: Headers)
statusCode(): StatusCode;
Expand All @@ -646,42 +642,22 @@ export class OutgoingBody {
static finish(this_: OutgoingBody, trailers: Trailers | undefined): void;
}

export class Fields {
constructor()
static fromList(entries: [FieldKey, FieldValue][]): Fields;
get(name: FieldKey): FieldValue[];
has(name: FieldKey): boolean;
set(name: FieldKey, value: FieldValue[]): void;
'delete'(name: FieldKey): void;
append(name: FieldKey, value: FieldValue): void;
entries(): [FieldKey, FieldValue][];
clone(): Fields;
}

export class IncomingBody {
stream(): InputStream;
static finish(this_: IncomingBody): FutureTrailers;
}

export class FutureIncomingResponse {
subscribe(): Pollable;
get(): Result<Result<IncomingResponse, ErrorCode>, void> | undefined;
}

export class FutureTrailers {
subscribe(): Pollable;
get(): Result<Result<Trailers | undefined, ErrorCode>, void> | undefined;
}

export class IncomingRequest {
method(): Method;
pathWithQuery(): string | undefined;
scheme(): Scheme | undefined;
authority(): string | undefined;
export class IncomingResponse {
status(): StatusCode;
headers(): Headers;
consume(): IncomingBody;
}

export class RequestOptions {
constructor()
connectTimeout(): Duration | undefined;
setConnectTimeout(duration: Duration | undefined): void;
firstByteTimeout(): Duration | undefined;
setFirstByteTimeout(duration: Duration | undefined): void;
betweenBytesTimeout(): Duration | undefined;
setBetweenBytesTimeout(duration: Duration | undefined): void;
}

export class OutgoingRequest {
constructor(headers: Headers)
body(): OutgoingBody;
Expand All @@ -696,18 +672,42 @@ export class OutgoingRequest {
headers(): Headers;
}

export class IncomingResponse {
status(): StatusCode;
export class IncomingRequest {
method(): Method;
pathWithQuery(): string | undefined;
scheme(): Scheme | undefined;
authority(): string | undefined;
headers(): Headers;
consume(): IncomingBody;
}

export class RequestOptions {
export class Fields {
constructor()
connectTimeout(): Duration | undefined;
setConnectTimeout(duration: Duration | undefined): void;
firstByteTimeout(): Duration | undefined;
setFirstByteTimeout(duration: Duration | undefined): void;
betweenBytesTimeout(): Duration | undefined;
setBetweenBytesTimeout(duration: Duration | undefined): void;
static fromList(entries: [FieldKey, FieldValue][]): Fields;
get(name: FieldKey): FieldValue[];
has(name: FieldKey): boolean;
set(name: FieldKey, value: FieldValue[]): void;
'delete'(name: FieldKey): void;
append(name: FieldKey, value: FieldValue): void;
entries(): [FieldKey, FieldValue][];
clone(): Fields;
}

export class FutureTrailers {
subscribe(): Pollable;
get(): Result<Result<Trailers | undefined, ErrorCode>, void> | undefined;
}

export class FutureIncomingResponse {
subscribe(): Pollable;
get(): Result<Result<IncomingResponse, ErrorCode>, void> | undefined;
}

export class IncomingBody {
stream(): InputStream;
static finish(this_: IncomingBody): FutureTrailers;
}

export class ResponseOutparam {
static set(param: ResponseOutparam, response: Result<OutgoingResponse, ErrorCode>): void;
}
4 changes: 2 additions & 2 deletions packages/preview2-shim/types/interfaces/wasi-io-streams.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -188,9 +188,9 @@ export namespace WasiIoStreams {
* is ready for reading, before performing the `splice`.
*/
}
import type { Error } from '../interfaces/wasi-io-error.js';
import type { Error } from './wasi-io-error.js';
export { Error };
import type { Pollable } from '../interfaces/wasi-io-poll.js';
import type { Pollable } from './wasi-io-poll.js';
export { Pollable };
/**
* An error for input-stream and output-stream operations.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,5 +4,5 @@ export namespace WasiSocketsInstanceNetwork {
*/
export function instanceNetwork(): Network;
}
import type { Network } from '../interfaces/wasi-sockets-network.js';
import type { Network } from './wasi-sockets-network.js';
export { Network };
Original file line number Diff line number Diff line change
Expand Up @@ -45,13 +45,13 @@ export namespace WasiSocketsIpNameLookup {
* It's planned to be removed when `future` is natively supported in Preview3.
*/
}
import type { Pollable } from '../interfaces/wasi-io-poll.js';
import type { Pollable } from './wasi-io-poll.js';
export { Pollable };
import type { Network } from '../interfaces/wasi-sockets-network.js';
import type { Network } from './wasi-sockets-network.js';
export { Network };
import type { ErrorCode } from '../interfaces/wasi-sockets-network.js';
import type { ErrorCode } from './wasi-sockets-network.js';
export { ErrorCode };
import type { IpAddress } from '../interfaces/wasi-sockets-network.js';
import type { IpAddress } from './wasi-sockets-network.js';
export { IpAddress };

export class ResolveAddressStream {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,11 +23,11 @@ export namespace WasiSocketsTcpCreateSocket {
*/
export function createTcpSocket(addressFamily: IpAddressFamily): TcpSocket;
}
import type { Network } from '../interfaces/wasi-sockets-network.js';
import type { Network } from './wasi-sockets-network.js';
export { Network };
import type { ErrorCode } from '../interfaces/wasi-sockets-network.js';
import type { ErrorCode } from './wasi-sockets-network.js';
export { ErrorCode };
import type { IpAddressFamily } from '../interfaces/wasi-sockets-network.js';
import type { IpAddressFamily } from './wasi-sockets-network.js';
export { IpAddressFamily };
import type { TcpSocket } from '../interfaces/wasi-sockets-tcp.js';
import type { TcpSocket } from './wasi-sockets-tcp.js';
export { TcpSocket };
16 changes: 8 additions & 8 deletions packages/preview2-shim/types/interfaces/wasi-sockets-tcp.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -302,21 +302,21 @@ export namespace WasiSocketsTcp {
* - <https://man.freebsd.org/cgi/man.cgi?query=shutdown&sektion=2>
*/
}
import type { InputStream } from '../interfaces/wasi-io-streams.js';
import type { InputStream } from './wasi-io-streams.js';
export { InputStream };
import type { OutputStream } from '../interfaces/wasi-io-streams.js';
import type { OutputStream } from './wasi-io-streams.js';
export { OutputStream };
import type { Pollable } from '../interfaces/wasi-io-poll.js';
import type { Pollable } from './wasi-io-poll.js';
export { Pollable };
import type { Duration } from '../interfaces/wasi-clocks-monotonic-clock.js';
import type { Duration } from './wasi-clocks-monotonic-clock.js';
export { Duration };
import type { Network } from '../interfaces/wasi-sockets-network.js';
import type { Network } from './wasi-sockets-network.js';
export { Network };
import type { ErrorCode } from '../interfaces/wasi-sockets-network.js';
import type { ErrorCode } from './wasi-sockets-network.js';
export { ErrorCode };
import type { IpSocketAddress } from '../interfaces/wasi-sockets-network.js';
import type { IpSocketAddress } from './wasi-sockets-network.js';
export { IpSocketAddress };
import type { IpAddressFamily } from '../interfaces/wasi-sockets-network.js';
import type { IpAddressFamily } from './wasi-sockets-network.js';
export { IpAddressFamily };
/**
* # Variants
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,11 +23,11 @@ export namespace WasiSocketsUdpCreateSocket {
*/
export function createUdpSocket(addressFamily: IpAddressFamily): UdpSocket;
}
import type { Network } from '../interfaces/wasi-sockets-network.js';
import type { Network } from './wasi-sockets-network.js';
export { Network };
import type { ErrorCode } from '../interfaces/wasi-sockets-network.js';
import type { ErrorCode } from './wasi-sockets-network.js';
export { ErrorCode };
import type { IpAddressFamily } from '../interfaces/wasi-sockets-network.js';
import type { IpAddressFamily } from './wasi-sockets-network.js';
export { IpAddressFamily };
import type { UdpSocket } from '../interfaces/wasi-sockets-udp.js';
import type { UdpSocket } from './wasi-sockets-udp.js';
export { UdpSocket };
10 changes: 5 additions & 5 deletions packages/preview2-shim/types/interfaces/wasi-sockets-udp.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -220,15 +220,15 @@ export namespace WasiSocketsUdp {
* It's planned to be removed when `future` is natively supported in Preview3.
*/
}
import type { Pollable } from '../interfaces/wasi-io-poll.js';
import type { Pollable } from './wasi-io-poll.js';
export { Pollable };
import type { Network } from '../interfaces/wasi-sockets-network.js';
import type { Network } from './wasi-sockets-network.js';
export { Network };
import type { ErrorCode } from '../interfaces/wasi-sockets-network.js';
import type { ErrorCode } from './wasi-sockets-network.js';
export { ErrorCode };
import type { IpSocketAddress } from '../interfaces/wasi-sockets-network.js';
import type { IpSocketAddress } from './wasi-sockets-network.js';
export { IpSocketAddress };
import type { IpAddressFamily } from '../interfaces/wasi-sockets-network.js';
import type { IpAddressFamily } from './wasi-sockets-network.js';
export { IpAddressFamily };
/**
* A received datagram.
Expand Down

0 comments on commit 29e51ba

Please sign in to comment.