Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
张重言
deno
提交
498f6ad4
D
deno
项目概览
张重言
/
deno
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
deno
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
未验证
提交
498f6ad4
编写于
8月 14, 2019
作者:
R
Ryan Dahl
提交者:
GitHub
8月 14, 2019
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Remove dead code: legacy read/write ops (#2776)
readSync and writeSync use dispatch_minimal now.
上级
e6c349af
变更
9
隐藏空白更改
内联
并排
Showing
9 changed file
with
106 addition
and
223 deletion
+106
-223
cli/main.rs
cli/main.rs
+0
-1
cli/msg.fbs
cli/msg.fbs
+0
-22
cli/ops/dispatch_minimal.rs
cli/ops/dispatch_minimal.rs
+11
-63
cli/ops/files.rs
cli/ops/files.rs
+0
-86
cli/ops/io.rs
cli/ops/io.rs
+43
-0
cli/ops/mod.rs
cli/ops/mod.rs
+18
-10
js/dispatch.ts
js/dispatch.ts
+5
-1
js/dispatch_minimal.ts
js/dispatch_minimal.ts
+13
-0
js/files.ts
js/files.ts
+16
-40
未找到文件。
cli/main.rs
浏览文件 @
498f6ad4
...
...
@@ -21,7 +21,6 @@ pub mod deno_dir;
pub
mod
deno_error
;
pub
mod
diagnostics
;
mod
disk_cache
;
mod
dispatch_minimal
;
mod
file_fetcher
;
pub
mod
flags
;
pub
mod
fmt_errors
;
...
...
cli/msg.fbs
浏览文件 @
498f6ad4
...
...
@@ -48,10 +48,8 @@ union Any {
PermissionRevoke,
Permissions,
PermissionsRes,
Read,
ReadDir,
ReadDirRes,
ReadRes,
Readlink,
ReadlinkRes,
Remove,
...
...
@@ -83,8 +81,6 @@ union Any {
WorkerGetMessage,
WorkerGetMessageRes,
WorkerPostMessage,
Write,
WriteRes,
}
enum ErrorKind: byte {
...
...
@@ -491,24 +487,6 @@ 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;
}
...
...
cli/dispatch_minimal.rs
→
cli/
ops/
dispatch_minimal.rs
浏览文件 @
498f6ad4
...
...
@@ -7,14 +7,11 @@
use
crate
::
state
::
ThreadSafeState
;
use
deno
::
Buf
;
use
deno
::
CoreOp
;
use
deno
::
ErrBox
;
use
deno
::
Op
;
use
deno
::
OpId
;
use
deno
::
PinnedBuf
;
use
futures
::
Future
;
const
OP_READ
:
OpId
=
1
;
const
OP_WRITE
:
OpId
=
2
;
#[derive(Copy,
Clone,
Debug,
PartialEq)]
// This corresponds to RecordMinimal on the TS side.
pub
struct
Record
{
...
...
@@ -72,21 +69,23 @@ fn test_parse_min_record() {
assert_eq!
(
parse_min_record
(
&
buf
),
None
);
}
pub
fn
dispatch_minimal
(
pub
type
MinimalOp
=
dyn
Future
<
Item
=
i32
,
Error
=
ErrBox
>
+
Send
;
pub
type
Dispatcher
=
fn
(
i32
,
Option
<
PinnedBuf
>
)
->
Box
<
MinimalOp
>
;
pub
fn
dispatch
(
d
:
Dispatcher
,
state
:
&
ThreadSafeState
,
op_id
:
OpId
,
mut
record
:
Record
,
control
:
&
[
u8
],
zero_copy
:
Option
<
PinnedBuf
>
,
)
->
CoreOp
{
let
mut
record
=
parse_min_record
(
control
)
.unwrap
();
let
is_sync
=
record
.promise_id
==
0
;
let
min_op
=
match
op_id
{
OP_READ
=>
ops
::
read
(
record
.arg
,
zero_copy
),
OP_WRITE
=>
ops
::
write
(
record
.arg
,
zero_copy
),
_
=>
unimplemented!
(),
};
let
state
=
state
.clone
();
let
rid
=
record
.arg
;
let
min_op
=
d
(
rid
,
zero_copy
);
let
fut
=
Box
::
new
(
min_op
.then
(
move
|
result
|
->
Result
<
Buf
,
()
>
{
match
result
{
Ok
(
r
)
=>
{
...
...
@@ -109,54 +108,3 @@ pub fn dispatch_minimal(
Op
::
Async
(
fut
)
}
}
mod
ops
{
use
crate
::
deno_error
;
use
crate
::
resources
;
use
crate
::
tokio_write
;
use
deno
::
ErrBox
;
use
deno
::
PinnedBuf
;
use
futures
::
Future
;
type
MinimalOp
=
dyn
Future
<
Item
=
i32
,
Error
=
ErrBox
>
+
Send
;
pub
fn
read
(
rid
:
i32
,
zero_copy
:
Option
<
PinnedBuf
>
)
->
Box
<
MinimalOp
>
{
debug!
(
"read rid={}"
,
rid
);
let
zero_copy
=
match
zero_copy
{
None
=>
{
return
Box
::
new
(
futures
::
future
::
err
(
deno_error
::
no_buffer_specified
()),
)
}
Some
(
buf
)
=>
buf
,
};
match
resources
::
lookup
(
rid
as
u32
)
{
None
=>
Box
::
new
(
futures
::
future
::
err
(
deno_error
::
bad_resource
())),
Some
(
resource
)
=>
Box
::
new
(
tokio
::
io
::
read
(
resource
,
zero_copy
)
.map_err
(
ErrBox
::
from
)
.and_then
(
move
|(
_
resource
,
_
buf
,
nread
)|
Ok
(
nread
as
i32
)),
),
}
}
pub
fn
write
(
rid
:
i32
,
zero_copy
:
Option
<
PinnedBuf
>
)
->
Box
<
MinimalOp
>
{
debug!
(
"write rid={}"
,
rid
);
let
zero_copy
=
match
zero_copy
{
None
=>
{
return
Box
::
new
(
futures
::
future
::
err
(
deno_error
::
no_buffer_specified
()),
)
}
Some
(
buf
)
=>
buf
,
};
match
resources
::
lookup
(
rid
as
u32
)
{
None
=>
Box
::
new
(
futures
::
future
::
err
(
deno_error
::
bad_resource
())),
Some
(
resource
)
=>
Box
::
new
(
tokio_write
::
write
(
resource
,
zero_copy
)
.map_err
(
ErrBox
::
from
)
.and_then
(
move
|(
_
resource
,
_
buf
,
nwritten
)|
Ok
(
nwritten
as
i32
)),
),
}
}
}
cli/ops/files.rs
浏览文件 @
498f6ad4
...
...
@@ -8,7 +8,6 @@ use crate::ops::serialize_response;
use
crate
::
ops
::
CliOpResult
;
use
crate
::
resources
;
use
crate
::
state
::
ThreadSafeState
;
use
crate
::
tokio_write
;
use
deno
::
*
;
use
flatbuffers
::
FlatBufferBuilder
;
use
futures
::
Future
;
...
...
@@ -119,91 +118,6 @@ pub fn op_close(
}
}
pub
fn
op_read
(
_
state
:
&
ThreadSafeState
,
base
:
&
msg
::
Base
<
'_
>
,
data
:
Option
<
PinnedBuf
>
,
)
->
CliOpResult
{
let
cmd_id
=
base
.cmd_id
();
let
inner
=
base
.inner_as_read
()
.unwrap
();
let
rid
=
inner
.rid
();
match
resources
::
lookup
(
rid
)
{
None
=>
Err
(
deno_error
::
bad_resource
()),
Some
(
resource
)
=>
{
let
op
=
tokio
::
io
::
read
(
resource
,
data
.unwrap
())
.map_err
(
ErrBox
::
from
)
.and_then
(
move
|(
_
resource
,
_
buf
,
nread
)|
{
let
builder
=
&
mut
FlatBufferBuilder
::
new
();
let
inner
=
msg
::
ReadRes
::
create
(
builder
,
&
msg
::
ReadResArgs
{
nread
:
nread
as
u32
,
eof
:
nread
==
0
,
},
);
Ok
(
serialize_response
(
cmd_id
,
builder
,
msg
::
BaseArgs
{
inner
:
Some
(
inner
.as_union_value
()),
inner_type
:
msg
::
Any
::
ReadRes
,
..
Default
::
default
()
},
))
});
if
base
.sync
()
{
let
buf
=
op
.wait
()
?
;
Ok
(
Op
::
Sync
(
buf
))
}
else
{
Ok
(
Op
::
Async
(
Box
::
new
(
op
)))
}
}
}
}
pub
fn
op_write
(
_
state
:
&
ThreadSafeState
,
base
:
&
msg
::
Base
<
'_
>
,
data
:
Option
<
PinnedBuf
>
,
)
->
CliOpResult
{
let
cmd_id
=
base
.cmd_id
();
let
inner
=
base
.inner_as_write
()
.unwrap
();
let
rid
=
inner
.rid
();
match
resources
::
lookup
(
rid
)
{
None
=>
Err
(
deno_error
::
bad_resource
()),
Some
(
resource
)
=>
{
let
op
=
tokio_write
::
write
(
resource
,
data
.unwrap
())
.map_err
(
ErrBox
::
from
)
.and_then
(
move
|(
_
resource
,
_
buf
,
nwritten
)|
{
let
builder
=
&
mut
FlatBufferBuilder
::
new
();
let
inner
=
msg
::
WriteRes
::
create
(
builder
,
&
msg
::
WriteResArgs
{
nbyte
:
nwritten
as
u32
,
},
);
Ok
(
serialize_response
(
cmd_id
,
builder
,
msg
::
BaseArgs
{
inner
:
Some
(
inner
.as_union_value
()),
inner_type
:
msg
::
Any
::
WriteRes
,
..
Default
::
default
()
},
))
});
if
base
.sync
()
{
let
buf
=
op
.wait
()
?
;
Ok
(
Op
::
Sync
(
buf
))
}
else
{
Ok
(
Op
::
Async
(
Box
::
new
(
op
)))
}
}
}
}
pub
fn
op_seek
(
_
state
:
&
ThreadSafeState
,
base
:
&
msg
::
Base
<
'_
>
,
...
...
cli/ops/io.rs
0 → 100644
浏览文件 @
498f6ad4
use
super
::
dispatch_minimal
::
MinimalOp
;
use
crate
::
deno_error
;
use
crate
::
resources
;
use
crate
::
tokio_write
;
use
deno
::
ErrBox
;
use
deno
::
PinnedBuf
;
use
futures
::
Future
;
pub
fn
op_read
(
rid
:
i32
,
zero_copy
:
Option
<
PinnedBuf
>
)
->
Box
<
MinimalOp
>
{
debug!
(
"read rid={}"
,
rid
);
let
zero_copy
=
match
zero_copy
{
None
=>
{
return
Box
::
new
(
futures
::
future
::
err
(
deno_error
::
no_buffer_specified
()))
}
Some
(
buf
)
=>
buf
,
};
match
resources
::
lookup
(
rid
as
u32
)
{
None
=>
Box
::
new
(
futures
::
future
::
err
(
deno_error
::
bad_resource
())),
Some
(
resource
)
=>
Box
::
new
(
tokio
::
io
::
read
(
resource
,
zero_copy
)
.map_err
(
ErrBox
::
from
)
.and_then
(
move
|(
_
resource
,
_
buf
,
nread
)|
Ok
(
nread
as
i32
)),
),
}
}
pub
fn
op_write
(
rid
:
i32
,
zero_copy
:
Option
<
PinnedBuf
>
)
->
Box
<
MinimalOp
>
{
debug!
(
"write rid={}"
,
rid
);
let
zero_copy
=
match
zero_copy
{
None
=>
{
return
Box
::
new
(
futures
::
future
::
err
(
deno_error
::
no_buffer_specified
()))
}
Some
(
buf
)
=>
buf
,
};
match
resources
::
lookup
(
rid
as
u32
)
{
None
=>
Box
::
new
(
futures
::
future
::
err
(
deno_error
::
bad_resource
())),
Some
(
resource
)
=>
Box
::
new
(
tokio_write
::
write
(
resource
,
zero_copy
)
.map_err
(
ErrBox
::
from
)
.and_then
(
move
|(
_
resource
,
_
buf
,
nwritten
)|
Ok
(
nwritten
as
i32
)),
),
}
}
cli/ops/mod.rs
浏览文件 @
498f6ad4
// Copyright 2018-2019 the Deno authors. All rights reserved. MIT license.
use
crate
::
deno_error
::
GetErrorKind
;
use
crate
::
dispatch_minimal
::
dispatch_minimal
;
use
crate
::
dispatch_minimal
::
parse_min_record
;
use
crate
::
msg
;
use
crate
::
state
::
ThreadSafeState
;
use
crate
::
tokio_util
;
...
...
@@ -13,12 +11,15 @@ use hyper;
use
hyper
::
rt
::
Future
;
use
tokio_threadpool
;
mod
dispatch_minimal
;
mod
io
;
mod
compiler
;
use
compiler
::{
op_cache
,
op_fetch_source_file
};
mod
errors
;
use
errors
::{
op_apply_source_map
,
op_format_error
};
mod
files
;
use
files
::{
op_close
,
op_open
,
op_
read
,
op_seek
,
op_write
};
use
files
::{
op_close
,
op_open
,
op_
seek
};
mod
fetch
;
use
fetch
::
op_fetch
;
mod
fs
;
...
...
@@ -71,6 +72,8 @@ fn empty_buf() -> Buf {
}
const
FLATBUFFER_OP_ID
:
OpId
=
44
;
const
OP_READ
:
OpId
=
1
;
const
OP_WRITE
:
OpId
=
2
;
pub
fn
dispatch_all
(
state
:
&
ThreadSafeState
,
...
...
@@ -81,11 +84,18 @@ pub fn dispatch_all(
)
->
CoreOp
{
let
bytes_sent_control
=
control
.len
();
let
bytes_sent_zero_copy
=
zero_copy
.as_ref
()
.map
(|
b
|
b
.len
())
.unwrap_or
(
0
);
let
op
=
if
op_id
!=
FLATBUFFER_OP_ID
{
let
min_record
=
parse_min_record
(
control
)
.unwrap
();
dispatch_minimal
(
state
,
op_id
,
min_record
,
zero_copy
)
}
else
{
dispatch_all_legacy
(
state
,
control
,
zero_copy
,
op_selector
)
let
op
=
match
op_id
{
OP_READ
=>
{
dispatch_minimal
::
dispatch
(
io
::
op_read
,
state
,
control
,
zero_copy
)
}
OP_WRITE
=>
{
dispatch_minimal
::
dispatch
(
io
::
op_write
,
state
,
control
,
zero_copy
)
}
FLATBUFFER_OP_ID
=>
{
dispatch_all_legacy
(
state
,
control
,
zero_copy
,
op_selector
)
}
_
=>
panic!
(
"bad op_id"
),
};
state
.metrics_op_dispatched
(
bytes_sent_control
,
bytes_sent_zero_copy
);
op
...
...
@@ -226,7 +236,6 @@ pub fn op_selector_std(inner_type: msg::Any) -> Option<CliDispatchFn> {
msg
::
Any
::
Open
=>
Some
(
op_open
),
msg
::
Any
::
PermissionRevoke
=>
Some
(
op_revoke_permission
),
msg
::
Any
::
Permissions
=>
Some
(
op_permissions
),
msg
::
Any
::
Read
=>
Some
(
op_read
),
msg
::
Any
::
ReadDir
=>
Some
(
op_read_dir
),
msg
::
Any
::
Readlink
=>
Some
(
op_read_link
),
msg
::
Any
::
Remove
=>
Some
(
op_remove
),
...
...
@@ -245,7 +254,6 @@ pub fn op_selector_std(inner_type: msg::Any) -> Option<CliDispatchFn> {
msg
::
Any
::
Truncate
=>
Some
(
op_truncate
),
msg
::
Any
::
HomeDir
=>
Some
(
op_home_dir
),
msg
::
Any
::
Utime
=>
Some
(
op_utime
),
msg
::
Any
::
Write
=>
Some
(
op_write
),
// TODO(ry) split these out so that only the appropriate Workers can access
// them.
...
...
js/dispatch.ts
浏览文件 @
498f6ad4
...
...
@@ -32,9 +32,13 @@ function flatbufferRecordFromBuf(buf: Uint8Array): FlatbufferRecord {
}
export
function
handleAsyncMsgFromRust
(
opId
:
number
,
ui8
:
Uint8Array
):
void
{
const
buf32
=
new
Int32Array
(
ui8
.
buffer
,
ui8
.
byteOffset
,
ui8
.
byteLength
/
4
);
if
(
opId
!==
FLATBUFFER_OP_ID
)
{
// Fast and new
const
buf32
=
new
Int32Array
(
ui8
.
buffer
,
ui8
.
byteOffset
,
ui8
.
byteLength
/
4
);
const
recordMin
=
recordFromBufMinimal
(
opId
,
buf32
);
handleAsyncMsgFromRustMinimal
(
ui8
,
recordMin
);
}
else
{
...
...
js/dispatch_minimal.ts
浏览文件 @
498f6ad4
...
...
@@ -52,6 +52,19 @@ export function handleAsyncMsgFromRustMinimal(
promise
!
.
resolve
(
result
);
}
export
function
sendSyncMinimal
(
opId
:
number
,
arg
:
number
,
zeroCopy
:
Uint8Array
):
number
{
scratch32
[
0
]
=
0
;
// promiseId 0 indicates sync
scratch32
[
1
]
=
arg
;
const
res
=
core
.
dispatch
(
opId
,
scratchBytes
,
zeroCopy
)
!
;
const
res32
=
new
Int32Array
(
res
.
buffer
,
res
.
byteOffset
,
3
);
const
resRecord
=
recordFromBufMinimal
(
opId
,
res32
);
return
resRecord
.
result
;
}
export
function
sendAsyncMinimal
(
opId
:
number
,
arg
:
number
,
...
...
js/files.ts
浏览文件 @
498f6ad4
...
...
@@ -11,11 +11,12 @@ import {
SyncSeeker
}
from
"
./io
"
;
import
*
as
dispatch
from
"
./dispatch
"
;
import
{
sendAsyncMinimal
}
from
"
./dispatch_minimal
"
;
import
{
sendAsyncMinimal
,
sendSyncMinimal
}
from
"
./dispatch_minimal
"
;
import
*
as
msg
from
"
gen/cli/msg_generated
"
;
import
{
assert
}
from
"
./util
"
;
import
*
as
flatbuffers
from
"
./flatbuffers
"
;
// Warning: These constants defined in two places. Here and in cli/ops/mod.rs.
const
OP_READ
=
1
;
const
OP_WRITE
=
2
;
...
...
@@ -62,26 +63,6 @@ export async function open(
return
resOpen
(
await
dispatch
.
sendAsync
(...
reqOpen
(
filename
,
mode
)));
}
function
reqRead
(
rid
:
number
,
p
:
Uint8Array
):
[
flatbuffers
.
Builder
,
msg
.
Any
,
flatbuffers
.
Offset
,
Uint8Array
]
{
const
builder
=
flatbuffers
.
createBuilder
();
const
inner
=
msg
.
Read
.
createRead
(
builder
,
rid
);
return
[
builder
,
msg
.
Any
.
Read
,
inner
,
p
];
}
function
resRead
(
baseRes
:
null
|
msg
.
Base
):
number
|
EOF
{
assert
(
baseRes
!=
null
);
assert
(
msg
.
Any
.
ReadRes
===
baseRes
!
.
innerType
());
const
res
=
new
msg
.
ReadRes
();
assert
(
baseRes
!
.
inner
(
res
)
!=
null
);
if
(
res
.
eof
())
{
return
EOF
;
}
return
res
.
nread
();
}
/** Read synchronously from a file ID into an array buffer.
*
* Return `number | EOF` for the operation.
...
...
@@ -93,7 +74,14 @@ function resRead(baseRes: null | msg.Base): number | EOF {
*
*/
export
function
readSync
(
rid
:
number
,
p
:
Uint8Array
):
number
|
EOF
{
return
resRead
(
dispatch
.
sendSync
(...
reqRead
(
rid
,
p
)));
const
nread
=
sendSyncMinimal
(
OP_READ
,
rid
,
p
);
if
(
nread
<
0
)
{
throw
new
Error
(
"
read error
"
);
}
else
if
(
nread
==
0
)
{
return
EOF
;
}
else
{
return
nread
;
}
}
/** Read from a file ID into an array buffer.
...
...
@@ -118,23 +106,6 @@ export async function read(rid: number, p: Uint8Array): Promise<number | EOF> {
}
}
function
reqWrite
(
rid
:
number
,
p
:
Uint8Array
):
[
flatbuffers
.
Builder
,
msg
.
Any
,
flatbuffers
.
Offset
,
Uint8Array
]
{
const
builder
=
flatbuffers
.
createBuilder
();
const
inner
=
msg
.
Write
.
createWrite
(
builder
,
rid
);
return
[
builder
,
msg
.
Any
.
Write
,
inner
,
p
];
}
function
resWrite
(
baseRes
:
null
|
msg
.
Base
):
number
{
assert
(
baseRes
!=
null
);
assert
(
msg
.
Any
.
WriteRes
===
baseRes
!
.
innerType
());
const
res
=
new
msg
.
WriteRes
();
assert
(
baseRes
!
.
inner
(
res
)
!=
null
);
return
res
.
nbyte
();
}
/** Write synchronously to the file ID the contents of the array buffer.
*
* Resolves with the number of bytes written.
...
...
@@ -145,7 +116,12 @@ function resWrite(baseRes: null | msg.Base): number {
* Deno.writeSync(file.rid, data);
*/
export
function
writeSync
(
rid
:
number
,
p
:
Uint8Array
):
number
{
return
resWrite
(
dispatch
.
sendSync
(...
reqWrite
(
rid
,
p
)));
let
result
=
sendSyncMinimal
(
OP_WRITE
,
rid
,
p
);
if
(
result
<
0
)
{
throw
new
Error
(
"
write error
"
);
}
else
{
return
result
;
}
}
/** Write to the file ID the contents of the array buffer.
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录