Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
int
Rust
提交
c82834e2
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,发现更多精彩内容 >>
提交
c82834e2
编写于
3月 17, 2019
作者:
B
bors
浏览文件
操作
浏览文件
下载
差异文件
Auto merge of #58994 - oli-obk:deprecated_derive, r=petrochenkov
Hide deprecation warnings inside derive expansions Fixes #58822
上级
f649c76e
a69e12c2
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
38 addition
and
2 deletion
+38
-2
src/librustc/lint/mod.rs
src/librustc/lint/mod.rs
+16
-1
src/librustc/middle/stability.rs
src/librustc/middle/stability.rs
+4
-1
src/test/ui/deprecation/derive_on_deprecated.rs
src/test/ui/deprecation/derive_on_deprecated.rs
+9
-0
src/test/ui/deprecation/derive_on_deprecated_forbidden.rs
src/test/ui/deprecation/derive_on_deprecated_forbidden.rs
+9
-0
未找到文件。
src/librustc/lint/mod.rs
浏览文件 @
c82834e2
...
...
@@ -833,7 +833,8 @@ pub fn provide(providers: &mut Providers<'_>) {
/// Returns whether `span` originates in a foreign crate's external macro.
///
/// This is used to test whether a lint should be entirely aborted above.
/// This is used to test whether a lint should not even begin to figure out whether it should
/// be reported on the current node.
pub
fn
in_external_macro
(
sess
:
&
Session
,
span
:
Span
)
->
bool
{
let
info
=
match
span
.ctxt
()
.outer
()
.expn_info
()
{
Some
(
info
)
=>
info
,
...
...
@@ -859,3 +860,17 @@ pub fn in_external_macro(sess: &Session, span: Span) -> bool {
Err
(
_
)
=>
true
,
}
}
/// Returns whether `span` originates in a derive macro's expansion
pub
fn
in_derive_expansion
(
span
:
Span
)
->
bool
{
let
info
=
match
span
.ctxt
()
.outer
()
.expn_info
()
{
Some
(
info
)
=>
info
,
// no ExpnInfo means this span doesn't come from a macro
None
=>
return
false
,
};
match
info
.format
{
ExpnFormat
::
MacroAttribute
(
symbol
)
=>
symbol
.as_str
()
.starts_with
(
"derive("
),
_
=>
false
,
}
}
src/librustc/middle/stability.rs
浏览文件 @
c82834e2
...
...
@@ -3,7 +3,7 @@
pub
use
self
::
StabilityLevel
::
*
;
use
crate
::
lint
::{
self
,
Lint
};
use
crate
::
lint
::{
self
,
Lint
,
in_derive_expansion
};
use
crate
::
hir
::{
self
,
Item
,
Generics
,
StructField
,
Variant
,
HirId
};
use
crate
::
hir
::
def
::
Def
;
use
crate
::
hir
::
def_id
::{
CrateNum
,
CRATE_DEF_INDEX
,
DefId
,
LOCAL_CRATE
};
...
...
@@ -562,6 +562,9 @@ pub fn eval_stability(self, def_id: DefId, id: Option<HirId>, span: Span) -> Eva
suggestion
:
Option
<
Symbol
>
,
message
:
&
str
,
lint
:
&
'static
Lint
|
{
if
in_derive_expansion
(
span
)
{
return
;
}
let
msg
=
if
let
Some
(
note
)
=
note
{
format!
(
"{}: {}"
,
message
,
note
)
}
else
{
...
...
src/test/ui/deprecation/derive_on_deprecated.rs
0 → 100644
浏览文件 @
c82834e2
// compile-pass
#![deny(deprecated)]
#[deprecated
=
"oh no"
]
#[derive(Default)]
struct
X
;
fn
main
()
{}
src/test/ui/deprecation/derive_on_deprecated_forbidden.rs
0 → 100644
浏览文件 @
c82834e2
// compile-pass
#![forbid(deprecated)]
#[deprecated
=
"oh no"
]
#[derive(Default)]
struct
X
;
fn
main
()
{}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录