File tree Expand file tree Collapse file tree 7 files changed +32
-10
lines changed Expand file tree Collapse file tree 7 files changed +32
-10
lines changed Original file line number Diff line number Diff line change @@ -149,6 +149,9 @@ passes_doc_auto_cfg_expects_hide_or_show =
149
149
passes_doc_auto_cfg_hide_show_expects_list =
150
150
`#![doc(auto_cfg({ $attr_name } (...)))]` only expects a list of items
151
151
152
+ passes_doc_auto_cfg_hide_show_unexpected_item =
153
+ `#![doc(auto_cfg({ $attr_name } (...)))]` only accepts identifiers or key/values items
154
+
152
155
passes_doc_auto_cfg_wrong_literal =
153
156
`expected boolean for #[doc(auto_cfg = ...)]`
154
157
Original file line number Diff line number Diff line change @@ -1187,7 +1187,20 @@ impl<'tcx> CheckAttrVisitor<'tcx> {
1187
1187
meta. span ,
1188
1188
errors:: DocAutoCfgExpectsHideOrShow ,
1189
1189
) ;
1190
- } else if item. meta_item_list ( ) . is_none ( ) {
1190
+ } else if let Some ( list) = item. meta_item_list ( ) {
1191
+ for item in list {
1192
+ if item. meta_item_list ( ) . is_some ( ) {
1193
+ self . tcx . emit_node_span_lint (
1194
+ INVALID_DOC_ATTRIBUTES ,
1195
+ hir_id,
1196
+ item. span ( ) ,
1197
+ errors:: DocAutoCfgHideShowUnexpectedItem {
1198
+ attr_name : attr_name. as_str ( ) ,
1199
+ } ,
1200
+ ) ;
1201
+ }
1202
+ }
1203
+ } else {
1191
1204
self . tcx . emit_node_span_lint (
1192
1205
INVALID_DOC_ATTRIBUTES ,
1193
1206
hir_id,
Original file line number Diff line number Diff line change @@ -322,6 +322,12 @@ pub(crate) struct DocAutoCfgHideShowExpectsList<'a> {
322
322
pub attr_name : & ' a str ,
323
323
}
324
324
325
+ #[ derive( LintDiagnostic ) ]
326
+ #[ diag( passes_doc_auto_cfg_hide_show_unexpected_item) ]
327
+ pub ( crate ) struct DocAutoCfgHideShowUnexpectedItem < ' a > {
328
+ pub attr_name : & ' a str ,
329
+ }
330
+
325
331
#[ derive( LintDiagnostic ) ]
326
332
#[ diag( passes_doc_test_unknown_any) ]
327
333
pub ( crate ) struct DocTestUnknownAny {
Original file line number Diff line number Diff line change 78
78
#![ cfg_attr(
79
79
not( bootstrap) ,
80
80
doc( auto_cfg( hide(
81
- test,
82
81
no_global_oom_handling,
83
82
no_rc,
84
83
no_sync,
Original file line number Diff line number Diff line change 243
243
not( no_global_oom_handling)
244
244
) )
245
245
) ]
246
- #![ cfg_attr(
247
- not( bootstrap) ,
248
- doc( auto_cfg( hide(
249
- test,
250
- no_global_oom_handling,
251
- ) ) )
252
- ) ]
246
+ #![ cfg_attr( not( bootstrap) , doc( auto_cfg( hide( no_global_oom_handling) ) ) ) ]
253
247
// Don't link to std. We are std.
254
248
#![ no_std]
255
249
// Tell the compiler to link to either panic_abort or panic_unwind
Original file line number Diff line number Diff line change 1
1
#![ doc( auto_cfg( hide = "test" ) ) ] //~ ERROR
2
2
#![ doc( auto_cfg( hide) ) ] //~ ERROR
3
+ #![ doc( auto_cfg( hide( not( windows) ) ) ) ] //~ ERROR
Original file line number Diff line number Diff line change @@ -12,5 +12,11 @@ error: `#![doc(auto_cfg(hide(...)))]` only expects a list of items
12
12
LL | #![doc(auto_cfg(hide))]
13
13
| ^^^^^^^^^^^^^^
14
14
15
- error: aborting due to 2 previous errors
15
+ error: `#![doc(auto_cfg(hide(...)))]` only accepts identifiers or key/values items
16
+ --> $DIR/doc_cfg_hide.rs:3:22
17
+ |
18
+ LL | #![doc(auto_cfg(hide(not(windows))))]
19
+ | ^^^^^^^^^^^^
20
+
21
+ error: aborting due to 3 previous errors
16
22
You can’t perform that action at this time.
0 commit comments