Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
int
Rust
提交
03007740
R
Rust
项目概览
int
/
Rust
11 个月 前同步成功
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
Rust
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
03007740
编写于
7月 28, 2018
作者:
B
Bruno Dutra
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Promote EvalSnapshot to newtype
上级
7fa42bee
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
22 addition
and
7 deletion
+22
-7
src/librustc_mir/interpret/eval_context.rs
src/librustc_mir/interpret/eval_context.rs
+21
-6
src/librustc_mir/interpret/step.rs
src/librustc_mir/interpret/step.rs
+1
-1
未找到文件。
src/librustc_mir/interpret/eval_context.rs
浏览文件 @
03007740
...
...
@@ -196,8 +196,24 @@ pub fn access_mut(&mut self) -> EvalResult<'tcx, &mut Operand> {
}
/// The virtual machine state during const-evaluation at a given point in time.
type
EvalSnapshot
<
'a
,
'mir
,
'tcx
,
M
>
=
(
M
,
Vec
<
Frame
<
'mir
,
'tcx
>>
,
Memory
<
'a
,
'mir
,
'tcx
,
M
>
);
#[derive(Eq,
PartialEq,
Hash)]
pub
(
crate
)
struct
EvalSnapshot
<
'a
,
'mir
,
'tcx
:
'a
+
'mir
,
M
:
Machine
<
'mir
,
'tcx
>>
{
machine
:
M
,
memory
:
Memory
<
'a
,
'mir
,
'tcx
,
M
>
,
stack
:
Vec
<
Frame
<
'mir
,
'tcx
>>
,
}
impl
<
'a
,
'mir
,
'tcx
,
M
>
EvalSnapshot
<
'a
,
'mir
,
'tcx
,
M
>
where
M
:
Machine
<
'mir
,
'tcx
>
,
{
fn
new
<
'b
>
(
machine
:
&
M
,
memory
:
&
Memory
<
'a
,
'mir
,
'tcx
,
M
>
,
stack
:
&
[
Frame
<
'mir
,
'tcx
>
])
->
Self
{
EvalSnapshot
{
machine
:
machine
.clone
(),
memory
:
memory
.clone
(),
stack
:
stack
.into
(),
}
}
}
pub
(
super
)
struct
InfiniteLoopDetector
<
'a
,
'mir
,
'tcx
:
'a
+
'mir
,
M
:
Machine
<
'mir
,
'tcx
>>
{
/// The set of all `EvalSnapshot` *hashes* observed by this detector.
...
...
@@ -238,13 +254,12 @@ pub fn is_empty(&self) -> bool {
pub
fn
observe_and_analyze
(
&
mut
self
,
machine
:
&
M
,
stack
:
&
Vec
<
Frame
<
'mir
,
'tcx
>>
,
memory
:
&
Memory
<
'a
,
'mir
,
'tcx
,
M
>
,
stack
:
&
[
Frame
<
'mir
,
'tcx
>
],
)
->
EvalResult
<
'tcx
,
()
>
{
let
snapshot
=
(
machine
,
stack
,
memory
);
let
mut
fx
=
FxHasher
::
default
();
snapshot
.hash
(
&
mut
fx
);
(
machine
,
memory
,
stack
)
.hash
(
&
mut
fx
);
let
hash
=
fx
.finish
();
if
self
.hashes
.insert
(
hash
)
{
...
...
@@ -252,7 +267,7 @@ pub fn observe_and_analyze(
return
Ok
(())
}
if
self
.snapshots
.insert
(
(
machine
.clone
(),
stack
.clone
(),
memory
.clone
()
))
{
if
self
.snapshots
.insert
(
EvalSnapshot
::
new
(
machine
,
memory
,
stack
))
{
// Spurious collision or first cycle
return
Ok
(())
}
...
...
src/librustc_mir/interpret/step.rs
浏览文件 @
03007740
...
...
@@ -73,7 +73,7 @@ pub fn inc_step_counter_and_detect_loops(&mut self) -> EvalResult<'tcx, ()> {
"Constant evaluating a complex constant, this might take some time"
);
}
self
.loop_detector
.observe_and_analyze
(
&
self
.machine
,
&
self
.
stack
,
&
self
.memory
)
self
.loop_detector
.observe_and_analyze
(
&
self
.machine
,
&
self
.
memory
,
&
self
.stack
[
..
]
)
}
pub
fn
run
(
&
mut
self
)
->
EvalResult
<
'tcx
>
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录