rustc_attr_parsing/attributes/
transparency.rs1use rustc_feature::AttributeStability;
2use rustc_span::hygiene::Transparency;
3
4use super::prelude::*;
5
6pub(crate) struct RustcMacroTransparencyParser;
7
8impl SingleAttributeParser for RustcMacroTransparencyParser {
9 const PATH: &[Symbol] = &[sym::rustc_macro_transparency];
10 const ON_DUPLICATE: OnDuplicate = OnDuplicate::Custom(|cx, used, unused| {
11 cx.dcx().span_err(::alloc::boxed::box_assume_init_into_vec_unsafe(::alloc::intrinsics::write_box_via_move(::alloc::boxed::Box::new_uninit(),
[used, unused]))vec![used, unused], "multiple macro transparency attributes");
12 });
13 const STABILITY: AttributeStability = AttributeStability::Unstable {
gate_name: rustc_span::sym::rustc_attrs,
gate_check: rustc_feature::Features::rustc_attrs,
notes: &[],
}unstable!(rustc_attrs);
14 const ALLOWED_TARGETS: AllowedTargets = AllowedTargets::AllowList(&[Allow(Target::MacroDef)]);
15 const TEMPLATE: AttributeTemplate =
16 ::rustc_feature::AttributeTemplate {
word: false,
list: None,
one_of: &[],
name_value_str: Some(&["transparent", "semiopaque", "opaque"]),
docs: None,
}template!(NameValueStr: ["transparent", "semiopaque", "opaque"]);
17
18 fn convert(cx: &mut AcceptContext<'_, '_>, args: &ArgParser) -> Option<AttributeKind> {
19 let nv = cx.expect_name_value(args, cx.attr_span, None)?;
20 match nv.value_as_str() {
21 Some(sym::transparent) => Some(Transparency::Transparent),
22 Some(sym::semiopaque) => Some(Transparency::SemiOpaque),
23 Some(sym::opaque) => Some(Transparency::Opaque),
24 Some(_) => {
25 cx.adcx().expected_specific_argument_strings(
26 nv.value_span,
27 &[sym::transparent, sym::semiopaque, sym::opaque],
28 );
29 None
30 }
31 None => None,
32 }
33 .map(AttributeKind::RustcMacroTransparency)
34 }
35}