mirror of
https://github.com/rust-lang/rust.git
synced 2024-11-22 23:04:33 +00:00
Simplify AttributesExt::cfg function and remove error emissions since they are not useful
This commit is contained in:
parent
8fac41a530
commit
09c76884bc
@ -776,48 +776,31 @@ impl AttributesExt for [ast::Attribute] {
|
||||
let sess = tcx.sess;
|
||||
let doc_cfg_active = tcx.features().doc_cfg;
|
||||
|
||||
trait SingleExt {
|
||||
type Item;
|
||||
fn single(self) -> Option<Self::Item>;
|
||||
}
|
||||
|
||||
impl<T: IntoIterator> SingleExt for T {
|
||||
type Item = T::Item;
|
||||
fn single(self) -> Option<Self::Item> {
|
||||
let mut iter = self.into_iter();
|
||||
let item = iter.next()?;
|
||||
if iter.next().is_some() {
|
||||
return None;
|
||||
}
|
||||
Some(item)
|
||||
fn single<T: IntoIterator>(it: T) -> Option<T::Item> {
|
||||
let mut iter = it.into_iter();
|
||||
let item = iter.next()?;
|
||||
if iter.next().is_some() {
|
||||
return None;
|
||||
}
|
||||
Some(item)
|
||||
}
|
||||
|
||||
let mut cfg = if doc_cfg_active {
|
||||
let mut doc_cfg = self
|
||||
.iter()
|
||||
.filter(|attr| attr.has_name(sym::doc))
|
||||
.filter_map(|attr| Some(attr.meta_item_list()?.single()?))
|
||||
.flat_map(|attr| attr.meta_item_list().unwrap_or_else(Vec::new))
|
||||
.filter(|attr| attr.has_name(sym::cfg))
|
||||
.filter_map(|attr| Some(attr.meta_item_list()?.single()?.meta_item()?.clone()))
|
||||
.peekable();
|
||||
if doc_cfg.peek().is_some() {
|
||||
doc_cfg
|
||||
.filter_map(|attr| {
|
||||
Cfg::parse(&attr)
|
||||
.map_err(|e| sess.diagnostic().span_err(e.span, e.msg))
|
||||
.ok()
|
||||
})
|
||||
.filter_map(|attr| Cfg::parse(attr.meta_item()?).ok())
|
||||
.fold(Cfg::True, |cfg, new_cfg| cfg & new_cfg)
|
||||
} else {
|
||||
self.iter()
|
||||
.filter(|attr| attr.has_name(sym::cfg))
|
||||
.filter_map(|attr| Some(attr.meta_item_list()?.single()?.meta_item()?.clone()))
|
||||
.filter_map(|attr| {
|
||||
Cfg::parse(&attr)
|
||||
.map_err(|e| sess.diagnostic().span_err(e.span, e.msg))
|
||||
.ok()
|
||||
})
|
||||
.filter_map(|attr| single(attr.meta_item_list()?))
|
||||
.filter_map(|attr| Cfg::parse(attr.meta_item()?).ok())
|
||||
.filter(|cfg| !hidden_cfg.contains(cfg))
|
||||
.fold(Cfg::True, |cfg, new_cfg| cfg & new_cfg)
|
||||
}
|
||||
|
9
src/test/rustdoc-ui/doc-cfg.rs
Normal file
9
src/test/rustdoc-ui/doc-cfg.rs
Normal file
@ -0,0 +1,9 @@
|
||||
#![feature(doc_cfg)]
|
||||
|
||||
#[doc(cfg(), cfg(foo, bar))]
|
||||
//~^ ERROR
|
||||
//~^^ ERROR
|
||||
#[doc(cfg(foo), cfg(bar))] // ok!
|
||||
#[doc(cfg())] //~ ERROR
|
||||
#[doc(cfg(foo, bar))] //~ ERROR
|
||||
pub fn foo() {}
|
26
src/test/rustdoc-ui/doc-cfg.stderr
Normal file
26
src/test/rustdoc-ui/doc-cfg.stderr
Normal file
@ -0,0 +1,26 @@
|
||||
error: `cfg` predicate is not specified
|
||||
--> $DIR/doc-cfg.rs:3:7
|
||||
|
|
||||
LL | #[doc(cfg(), cfg(foo, bar))]
|
||||
| ^^^^^
|
||||
|
||||
error: multiple `cfg` predicates are specified
|
||||
--> $DIR/doc-cfg.rs:3:23
|
||||
|
|
||||
LL | #[doc(cfg(), cfg(foo, bar))]
|
||||
| ^^^
|
||||
|
||||
error: `cfg` predicate is not specified
|
||||
--> $DIR/doc-cfg.rs:7:7
|
||||
|
|
||||
LL | #[doc(cfg())]
|
||||
| ^^^^^
|
||||
|
||||
error: multiple `cfg` predicates are specified
|
||||
--> $DIR/doc-cfg.rs:8:16
|
||||
|
|
||||
LL | #[doc(cfg(foo, bar))]
|
||||
| ^^^
|
||||
|
||||
error: aborting due to 4 previous errors
|
||||
|
Loading…
Reference in New Issue
Block a user