1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-16 19:04:02 -05:00
denoland-deno/cli/msg.fbs

504 lines
6.7 KiB
Text
Raw Normal View History

union Any {
2019-03-11 23:25:18 -04:00
Accept,
Chdir,
Chmod,
Close,
CopyFile,
Cwd,
CwdRes,
Dial,
Environ,
EnvironRes,
2019-03-11 23:25:18 -04:00
Exit,
2018-10-30 15:02:18 -04:00
Fetch,
2019-03-11 23:25:18 -04:00
FetchModuleMetaData,
FetchModuleMetaDataRes,
FetchRes,
2019-03-11 23:25:18 -04:00
FormatError,
FormatErrorRes,
GlobalTimer,
GlobalTimerRes,
GlobalTimerStop,
2019-03-11 23:25:18 -04:00
IsTTY,
IsTTYRes,
Listen,
ListenRes,
2018-08-24 00:36:45 +02:00
MakeTempDir,
MakeTempDirRes,
2019-03-11 23:25:18 -04:00
Metrics,
MetricsRes,
2018-09-10 14:18:36 +04:30
Mkdir,
2019-03-11 23:25:18 -04:00
NewConn,
Now,
NowRes,
Open,
OpenRes,
PermissionRevoke,
Permissions,
PermissionsRes,
Read,
2018-10-04 06:56:56 +09:00
ReadDir,
ReadDirRes,
2019-03-11 23:25:18 -04:00
ReadRes,
2018-09-24 21:20:49 -07:00
Readlink,
ReadlinkRes,
2019-03-11 23:25:18 -04:00
Remove,
Rename,
ReplReadline,
ReplReadlineRes,
2019-03-11 23:25:18 -04:00
ReplStart,
ReplStartRes,
2018-10-30 20:58:55 +01:00
Resources,
ResourcesRes,
Run,
RunRes,
RunStatus,
2019-02-02 09:27:42 +03:00
RunStatusRes,
Seek,
2019-03-11 23:25:18 -04:00
SetEnv,
Shutdown,
Start,
StartRes,
Stat,
StatRes,
Symlink,
Truncate,
WorkerGetMessage,
WorkerGetMessageRes,
WorkerPostMessage,
Write,
WriteRes,
2018-07-04 14:50:28 -04:00
}
enum ErrorKind: byte {
NoError = 0,
// io errors
NotFound,
PermissionDenied,
ConnectionRefused,
ConnectionReset,
ConnectionAborted,
NotConnected,
AddrInUse,
AddrNotAvailable,
BrokenPipe,
AlreadyExists,
WouldBlock,
InvalidInput,
InvalidData,
TimedOut,
Interrupted,
WriteZero,
Other,
UnexpectedEof,
2018-10-11 00:15:47 +09:00
BadResource,
CommandFailed,
// url errors
EmptyHost,
IdnaError,
InvalidPort,
InvalidIpv4Address,
InvalidIpv6Address,
InvalidDomainCharacter,
RelativeUrlWithoutBase,
RelativeUrlWithCannotBeABaseBase,
SetHostOnCannotBeABaseUrl,
Overflow,
// hyper errors
HttpUser,
HttpClosed,
HttpCanceled,
HttpParse,
HttpOther,
TooLarge,
// custom errors
InvalidUri,
InvalidSeekMode,
}
2018-10-14 01:33:27 +05:30
table Cwd {}
table CwdRes {
cwd: string;
}
2018-10-22 13:14:27 +11:00
enum MediaType: byte {
JavaScript = 0,
TypeScript,
Json,
Unknown
}
table Base {
2018-08-17 16:59:57 -04:00
cmd_id: uint32;
2018-12-12 22:24:36 +09:00
sync: bool = false;
error_kind: ErrorKind = NoError;
error: string;
inner: Any;
2018-07-04 14:50:28 -04:00
}
table Start {
unused: int8;
}
table StartRes {
cwd: string;
2019-01-06 14:16:42 -05:00
pid: uint32;
argv: [string];
2019-02-15 19:22:02 +03:00
exec_path: string;
2019-02-12 21:14:02 -05:00
main_module: string; // Absolute URL.
debug_flag: bool;
deps_flag: bool;
2018-10-12 08:23:22 +11:00
types_flag: bool;
version_flag: bool;
deno_version: string;
v8_version: string;
2019-02-08 22:13:04 -05:00
no_color: bool;
}
table FormatError {
error: string;
}
table FormatErrorRes {
error: string;
}
table WorkerGetMessage {
unused: int8;
}
table WorkerGetMessageRes {
data: [ubyte];
}
table WorkerPostMessage {
// data passed thru the zero-copy data parameter.
}
2019-02-19 02:42:15 +11:00
table FetchModuleMetaData {
specifier: string;
referrer: string;
}
2019-02-19 02:42:15 +11:00
table FetchModuleMetaDataRes {
// If it's a non-http module, moduleName and filename will be the same.
// For http modules, moduleName is its resolved http URL, and filename
// is the location of the locally downloaded source code.
module_name: string;
filename: string;
2018-10-22 13:14:27 +11:00
media_type: MediaType;
2019-02-19 02:42:15 +11:00
data: [ubyte];
}
2018-10-14 01:33:27 +05:30
table Chdir {
directory: string;
}
table GlobalTimer {
timeout: int;
}
table GlobalTimerRes { }
table GlobalTimerStop { }
table Exit {
code: int;
}
table Environ {}
table SetEnv {
2018-09-08 07:59:02 +09:00
key: string;
value: string;
}
table EnvironRes {
2018-11-02 20:09:10 -04:00
map: [KeyValue];
}
2018-11-02 20:09:10 -04:00
table KeyValue {
2018-09-08 07:59:02 +09:00
key: string;
value: string;
}
table Permissions {}
table PermissionRevoke {
permission: string;
}
table PermissionsRes {
run: bool;
read: bool;
write: bool;
net: bool;
env: bool;
}
// Note this represents The WHOLE header of an http message, not just the key
// value pairs. That means it includes method and url for Requests and status
// for responses. This is why it is singular "Header" instead of "Headers".
table HttpHeader {
is_request: bool;
// Request only:
method: string;
url: string;
// Response only:
status: uint16;
// Both:
fields: [KeyValue];
}
table Fetch {
header: HttpHeader;
}
table FetchRes {
header: HttpHeader;
body_rid: uint32;
}
2018-08-24 00:36:45 +02:00
table MakeTempDir {
dir: string;
prefix: string;
suffix: string;
}
table MakeTempDirRes {
path: string;
}
2018-09-10 14:18:36 +04:30
table Mkdir {
2018-08-26 10:56:30 +04:30
path: string;
recursive: bool;
mode: uint; // Specified by https://godoc.org/os#FileMode
2018-08-26 10:56:30 +04:30
}
table Chmod {
path: string;
mode: uint; // Specified by https://godoc.org/os#FileMode
}
table Remove {
path: string;
recursive: bool;
}
2018-10-04 06:56:56 +09:00
table ReadDir {
path: string;
}
table ReadDirRes {
entries: [StatRes];
}
2018-09-30 15:06:41 -07:00
table CopyFile {
from: string;
to: string;
}
2018-09-12 08:44:58 -07:00
table Rename {
2018-09-03 17:22:30 -07:00
oldpath: string;
newpath: string;
}
2018-09-24 21:20:49 -07:00
table Readlink {
name: string;
}
table ReadlinkRes {
path: string;
}
table ReplStart {
history_file: string;
// TODO add config
}
table ReplStartRes {
rid: uint32;
}
table ReplReadline {
rid: uint32;
prompt: string;
}
table ReplReadlineRes {
line: string;
}
2018-10-30 20:58:55 +01:00
table Resources {}
table Resource {
rid: uint32;
2018-10-30 20:58:55 +01:00
repr: string;
}
table ResourcesRes {
resources: [Resource];
}
2018-09-18 21:38:24 -07:00
table Symlink {
oldname: string;
newname: string;
}
2018-09-12 00:08:53 +04:30
table Stat {
2018-08-29 14:22:25 +01:00
filename: string;
lstat: bool;
}
2018-09-12 00:08:53 +04:30
table StatRes {
2018-08-29 14:22:25 +01:00
is_file: bool;
is_symlink: bool;
len: ulong;
modified:ulong;
accessed:ulong;
created:ulong;
mode: uint;
has_mode: bool; // false on windows
2018-10-04 06:56:56 +09:00
name: string;
path: string;
2018-08-29 14:22:25 +01:00
}
2018-10-01 03:06:20 +08:00
table Truncate {
name: string;
len: uint;
}
table Open {
filename: string;
perm: uint;
2018-12-12 18:05:58 +01:00
mode: string;
}
table OpenRes {
rid: uint32;
}
table Read {
rid: uint32;
// (ptr, len) is passed as second parameter to Deno.core.send().
}
table ReadRes {
nread: uint;
eof: bool;
}
table Write {
rid: uint32;
}
table WriteRes {
nbyte: uint;
}
table Close {
rid: uint32;
}
table Shutdown {
rid: uint32;
how: uint;
}
table Listen {
network: string;
address: string;
}
table ListenRes {
rid: uint32;
}
table Accept {
rid: uint32;
}
table Dial {
network: string;
address: string;
}
// Response to Accept and Dial.
table NewConn {
rid: uint32;
remote_addr: string;
local_addr: string;
}
2018-10-05 19:21:15 +02:00
table Metrics {}
table MetricsRes {
ops_dispatched: uint64;
ops_completed: uint64;
bytes_sent_control: uint64;
bytes_sent_data: uint64;
bytes_received: uint64;
}
enum ProcessStdio: byte { Inherit, Piped, Null }
table Run {
args: [string];
cwd: string;
2019-02-16 00:37:04 +09:00
env: [KeyValue];
stdin: ProcessStdio;
stdout: ProcessStdio;
stderr: ProcessStdio;
}
table RunRes {
rid: uint32;
pid: uint32;
// The following stdio rids are only valid if "Piped" was specified for the
// corresponding stdio stream. The caller MUST issue a close op for all valid
// stdio streams.
stdin_rid: uint32;
stdout_rid: uint32;
stderr_rid: uint32;
}
table RunStatus {
rid: uint32;
}
table RunStatusRes {
got_signal: bool;
exit_code: int;
exit_signal: int;
}
2019-02-02 09:27:42 +03:00
table Now {}
table NowRes {
time: uint64;
}
2019-02-03 06:05:30 +03:00
table IsTTY {}
table IsTTYRes {
stdin: bool;
stdout: bool;
stderr: bool;
}
table Seek {
rid: uint32;
offset: int;
whence: uint;
}
root_type Base;