2022-05-09 20:59:12 +08:00
|
|
|
import type { LogLevel } from "./custom_logger";
|
2022-03-23 22:41:12 +08:00
|
|
|
|
2022-05-09 20:59:12 +08:00
|
|
|
export type ControllerMessageType = "inited" | "result" | "syscall" | "log";
|
2022-03-23 22:41:12 +08:00
|
|
|
export type ControllerMessage = {
|
|
|
|
type: ControllerMessageType;
|
|
|
|
id?: number;
|
|
|
|
name?: string;
|
|
|
|
args?: any[];
|
|
|
|
error?: string;
|
2022-05-09 20:59:12 +08:00
|
|
|
level?: LogLevel;
|
|
|
|
message?: string;
|
2022-03-23 22:41:12 +08:00
|
|
|
result?: any;
|
|
|
|
};
|
|
|
|
|
|
|
|
export interface WorkerLike {
|
|
|
|
ready: Promise<void>;
|
|
|
|
onMessage?: (message: any) => Promise<void>;
|
|
|
|
|
|
|
|
postMessage(message: any): void;
|
|
|
|
|
|
|
|
terminate(): void;
|
|
|
|
}
|
|
|
|
|
|
|
|
export type WorkerMessageType = "load" | "invoke" | "syscall-response";
|
2022-03-24 17:48:56 +08:00
|
|
|
|
2022-03-23 22:41:12 +08:00
|
|
|
export type WorkerMessage = {
|
|
|
|
type: WorkerMessageType;
|
|
|
|
id?: number;
|
|
|
|
name?: string;
|
|
|
|
code?: string;
|
|
|
|
args?: any[];
|
|
|
|
result?: any;
|
|
|
|
error?: any;
|
|
|
|
};
|