Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
int
Rust
提交
de7e941e
R
Rust
项目概览
int
/
Rust
大约 1 年 前同步成功
通知
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,发现更多精彩内容 >>
提交
de7e941e
编写于
6月 11, 2018
作者:
N
Niko Matsakis
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
convert `prove_predicate` into a query
上级
d6136837
变更
8
隐藏空白更改
内联
并排
Showing
8 changed file
with
92 addition
and
17 deletion
+92
-17
src/librustc/dep_graph/dep_node.rs
src/librustc/dep_graph/dep_node.rs
+2
-1
src/librustc/traits/query/mod.rs
src/librustc/traits/query/mod.rs
+3
-0
src/librustc/traits/query/type_op/prove_predicate.rs
src/librustc/traits/query/type_op/prove_predicate.rs
+35
-14
src/librustc/ty/query/config.rs
src/librustc/ty/query/config.rs
+7
-1
src/librustc/ty/query/mod.rs
src/librustc/ty/query/mod.rs
+10
-1
src/librustc/ty/query/plumbing.rs
src/librustc/ty/query/plumbing.rs
+1
-0
src/librustc_traits/lib.rs
src/librustc_traits/lib.rs
+2
-0
src/librustc_traits/type_op_prove_predicate.rs
src/librustc_traits/type_op_prove_predicate.rs
+32
-0
未找到文件。
src/librustc/dep_graph/dep_node.rs
浏览文件 @
de7e941e
...
...
@@ -72,7 +72,7 @@
use
syntax_pos
::
symbol
::
InternedString
;
use
traits
::
query
::{
CanonicalProjectionGoal
,
CanonicalTyGoal
,
CanonicalTypeOpEqGoal
,
CanonicalTypeOpSubtypeGoal
,
CanonicalPredicateGoal
,
CanonicalPredicateGoal
,
CanonicalTypeOpProvePredicateGoal
,
};
use
ty
::{
TyCtxt
,
Instance
,
InstanceDef
,
ParamEnv
,
ParamEnvAnd
,
PolyTraitRef
,
Ty
};
use
ty
::
subst
::
Substs
;
...
...
@@ -651,6 +651,7 @@ pub fn fingerprint_needed_for_crate_hash(self) -> bool {
[]
EvaluateObligation
(
CanonicalPredicateGoal
<
'tcx
>
),
[]
TypeOpEq
(
CanonicalTypeOpEqGoal
<
'tcx
>
),
[]
TypeOpSubtype
(
CanonicalTypeOpSubtypeGoal
<
'tcx
>
),
[]
TypeOpProvePredicate
(
CanonicalTypeOpProvePredicateGoal
<
'tcx
>
),
[]
SubstituteNormalizeAndTestPredicates
{
key
:
(
DefId
,
&
'tcx
Substs
<
'tcx
>
)
},
...
...
src/librustc/traits/query/mod.rs
浏览文件 @
de7e941e
...
...
@@ -38,6 +38,9 @@
pub
type
CanonicalTypeOpSubtypeGoal
<
'tcx
>
=
Canonical
<
'tcx
,
type_op
::
subtype
::
Subtype
<
'tcx
>>
;
pub
type
CanonicalTypeOpProvePredicateGoal
<
'tcx
>
=
Canonical
<
'tcx
,
type_op
::
prove_predicate
::
ProvePredicate
<
'tcx
>>
;
#[derive(Copy,
Clone,
Debug,
PartialEq,
Eq,
Hash)]
pub
struct
NoSolution
;
...
...
src/librustc/traits/query/type_op/prove_predicate.rs
浏览文件 @
de7e941e
...
...
@@ -8,14 +8,13 @@
// option. This file may not be copied, modified, or distributed
// except according to those terms.
use
infer
::{
InferCtxt
,
InferOk
,
InferResult
};
use
traits
::{
Obligation
,
ObligationCause
};
use
infer
::
canonical
::{
Canonical
,
CanonicalizedQueryResult
};
use
ty
::{
ParamEnv
,
Predicate
,
TyCtxt
};
#[derive(
Debug
)]
#[derive(
Copy,
Clone,
Debug,
Hash,
PartialEq,
Eq
)]
pub
struct
ProvePredicate
<
'tcx
>
{
param_env
:
ParamEnv
<
'tcx
>
,
predicate
:
Predicate
<
'tcx
>
,
p
ub
p
aram_env
:
ParamEnv
<
'tcx
>
,
p
ub
p
redicate
:
Predicate
<
'tcx
>
,
}
impl
<
'tcx
>
ProvePredicate
<
'tcx
>
{
...
...
@@ -27,18 +26,40 @@ pub fn new(
}
}
impl
<
'gcx
,
'tcx
>
super
::
TypeOp
<
'gcx
,
'tcx
>
for
ProvePredicate
<
'tcx
>
{
type
Outpu
t
=
();
impl
<
'gcx
:
'tcx
,
'tcx
>
super
::
Query
TypeOp
<
'gcx
,
'tcx
>
for
ProvePredicate
<
'tcx
>
{
type
QueryResul
t
=
();
fn
trivial_noop
(
self
,
_
tcx
:
TyCtxt
<
'_
,
'gcx
,
'tcx
>
)
->
Result
<
Self
::
Outpu
t
,
Self
>
{
fn
trivial_noop
(
self
,
_
tcx
:
TyCtxt
<
'_
,
'gcx
,
'tcx
>
)
->
Result
<
Self
::
QueryResul
t
,
Self
>
{
Err
(
self
)
}
fn
perform
(
self
,
_
infcx
:
&
InferCtxt
<
'_
,
'gcx
,
'tcx
>
)
->
InferResult
<
'tcx
,
Self
::
Output
>
{
let
obligation
=
Obligation
::
new
(
ObligationCause
::
dummy
(),
self
.param_env
,
self
.predicate
);
Ok
(
InferOk
{
value
:
(),
obligations
:
vec!
[
obligation
],
})
fn
param_env
(
&
self
)
->
ParamEnv
<
'tcx
>
{
self
.param_env
}
fn
perform_query
(
tcx
:
TyCtxt
<
'_
,
'gcx
,
'tcx
>
,
canonicalized
:
Canonical
<
'gcx
,
ProvePredicate
<
'gcx
>>
,
)
->
CanonicalizedQueryResult
<
'gcx
,
()
>
{
tcx
.type_op_prove_predicate
(
canonicalized
)
.unwrap
()
}
}
BraceStructTypeFoldableImpl!
{
impl
<
'tcx
>
TypeFoldable
<
'tcx
>
for
ProvePredicate
<
'tcx
>
{
param_env
,
predicate
,
}
}
BraceStructLiftImpl!
{
impl
<
'a
,
'tcx
>
Lift
<
'tcx
>
for
ProvePredicate
<
'a
>
{
type
Lifted
=
ProvePredicate
<
'tcx
>
;
param_env
,
predicate
,
}
}
impl_stable_hash_for!
{
struct
ProvePredicate
<
'tcx
>
{
param_env
,
predicate
}
}
src/librustc/ty/query/config.rs
浏览文件 @
de7e941e
...
...
@@ -14,7 +14,7 @@
use
mir
::
interpret
::{
GlobalId
,
ConstValue
};
use
traits
::
query
::{
CanonicalPredicateGoal
,
CanonicalProjectionGoal
,
CanonicalTyGoal
,
CanonicalTypeOpEqGoal
,
CanonicalTypeOpSubtypeGoal
,
CanonicalTypeOp
ProvePredicateGoal
,
CanonicalTypeOp
SubtypeGoal
,
};
use
ty
::{
self
,
ParamEnvAnd
,
Ty
,
TyCtxt
};
use
ty
::
subst
::
Substs
;
...
...
@@ -117,6 +117,12 @@ fn describe(_tcx: TyCtxt, goal: CanonicalTypeOpSubtypeGoal<'tcx>) -> String {
}
}
impl
<
'tcx
>
QueryDescription
<
'tcx
>
for
queries
::
type_op_prove_predicate
<
'tcx
>
{
fn
describe
(
_
tcx
:
TyCtxt
,
goal
:
CanonicalTypeOpProvePredicateGoal
<
'tcx
>
)
->
String
{
format!
(
"evaluating `type_op_prove_predicate` `{:?}`"
,
goal
)
}
}
impl
<
'tcx
>
QueryDescription
<
'tcx
>
for
queries
::
is_copy_raw
<
'tcx
>
{
fn
describe
(
_
tcx
:
TyCtxt
,
env
:
ty
::
ParamEnvAnd
<
'tcx
,
Ty
<
'tcx
>>
)
->
String
{
format!
(
"computing whether `{}` is `Copy`"
,
env
.value
)
...
...
src/librustc/ty/query/mod.rs
浏览文件 @
de7e941e
...
...
@@ -34,7 +34,8 @@
use
session
::
config
::
OutputFilenames
;
use
traits
::{
self
,
Vtable
};
use
traits
::
query
::{
CanonicalPredicateGoal
,
CanonicalProjectionGoal
,
CanonicalTyGoal
,
CanonicalTypeOpEqGoal
,
CanonicalTypeOpSubtypeGoal
,
NoSolution
};
CanonicalTyGoal
,
CanonicalTypeOpEqGoal
,
CanonicalTypeOpSubtypeGoal
,
CanonicalTypeOpProvePredicateGoal
,
NoSolution
};
use
traits
::
query
::
dropck_outlives
::{
DtorckConstraint
,
DropckOutlivesResult
};
use
traits
::
query
::
normalize
::
NormalizationResult
;
use
traits
::
specialization_graph
;
...
...
@@ -462,6 +463,14 @@
NoSolution
,
>
,
/// Do not call this query directly: invoke `infcx.at().prove_predicates()` instead.
[]
fn
type_op_prove_predicate
:
TypeOpProvePredicate
(
CanonicalTypeOpProvePredicateGoal
<
'tcx
>
)
->
Result
<
Lrc
<
Canonical
<
'tcx
,
canonical
::
QueryResult
<
'tcx
,
()
>>>
,
NoSolution
,
>
,
[]
fn
substitute_normalize_and_test_predicates
:
substitute_normalize_and_test_predicates_node
((
DefId
,
&
'tcx
Substs
<
'tcx
>
))
->
bool
,
...
...
src/librustc/ty/query/plumbing.rs
浏览文件 @
de7e941e
...
...
@@ -1030,6 +1030,7 @@ pub fn force_from_dep_node<'a, 'gcx, 'lcx>(tcx: TyCtxt<'a, 'gcx, 'lcx>,
DepKind
::
EvaluateObligation
|
DepKind
::
TypeOpEq
|
DepKind
::
TypeOpSubtype
|
DepKind
::
TypeOpProvePredicate
|
DepKind
::
SubstituteNormalizeAndTestPredicates
|
DepKind
::
InstanceDefSizeEstimate
|
DepKind
::
ProgramClausesForEnv
|
...
...
src/librustc_traits/lib.rs
浏览文件 @
de7e941e
...
...
@@ -35,6 +35,7 @@
mod
normalize_erasing_regions
;
pub
mod
lowering
;
mod
type_op_eq
;
mod
type_op_prove_predicate
;
mod
type_op_subtype
;
use
rustc
::
ty
::
query
::
Providers
;
...
...
@@ -50,6 +51,7 @@ pub fn provide(p: &mut Providers) {
program_clauses_for_env
:
lowering
::
program_clauses_for_env
,
evaluate_obligation
:
evaluate_obligation
::
evaluate_obligation
,
type_op_eq
:
type_op_eq
::
type_op_eq
,
type_op_prove_predicate
:
type_op_prove_predicate
::
type_op_prove_predicate
,
type_op_subtype
:
type_op_subtype
::
type_op_subtype
,
..*
p
};
...
...
src/librustc_traits/type_op_prove_predicate.rs
0 → 100644
浏览文件 @
de7e941e
// Copyright 2014 The Rust Project Developers. See the COPYRIGHT
// file at the top-level directory of this distribution and at
// http://rust-lang.org/COPYRIGHT.
//
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
// option. This file may not be copied, modified, or distributed
// except according to those terms.
use
rustc
::
infer
::
canonical
::{
Canonical
,
QueryResult
};
use
rustc
::
traits
::
query
::
type_op
::
prove_predicate
::
ProvePredicate
;
use
rustc
::
traits
::
query
::
NoSolution
;
use
rustc
::
traits
::{
FulfillmentContext
,
Obligation
,
ObligationCause
,
TraitEngine
};
use
rustc
::
ty
::
TyCtxt
;
use
rustc_data_structures
::
sync
::
Lrc
;
use
syntax
::
codemap
::
DUMMY_SP
;
crate
fn
type_op_prove_predicate
<
'tcx
>
(
tcx
:
TyCtxt
<
'_
,
'tcx
,
'tcx
>
,
canonicalized
:
Canonical
<
'tcx
,
ProvePredicate
<
'tcx
>>
,
)
->
Result
<
Lrc
<
Canonical
<
'tcx
,
QueryResult
<
'tcx
,
()
>>>
,
NoSolution
>
{
let
tcx
=
tcx
.global_tcx
();
tcx
.infer_ctxt
()
.enter
(|
ref
infcx
|
{
let
(
ProvePredicate
{
param_env
,
predicate
},
canonical_inference_vars
)
=
infcx
.instantiate_canonical_with_fresh_inference_vars
(
DUMMY_SP
,
&
canonicalized
);
let
fulfill_cx
=
&
mut
FulfillmentContext
::
new
();
let
obligation
=
Obligation
::
new
(
ObligationCause
::
dummy
(),
param_env
,
predicate
);
fulfill_cx
.register_predicate_obligation
(
infcx
,
obligation
);
infcx
.make_canonicalized_query_result
(
canonical_inference_vars
,
(),
fulfill_cx
)
})
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录