Skip to main content

rustc_attr_parsing/attributes/
transparency.rs

1use rustc_span::hygiene::Transparency;
2
3use super::prelude::*;
4
5pub(crate) struct RustcMacroTransparencyParser;
6
7impl SingleAttributeParser for RustcMacroTransparencyParser {
8    const PATH: &[Symbol] = &[sym::rustc_macro_transparency];
9    const ON_DUPLICATE: OnDuplicate = OnDuplicate::Custom(|cx, used, unused| {
10        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");
11    });
12    const ALLOWED_TARGETS: AllowedTargets = AllowedTargets::AllowList(&[Allow(Target::MacroDef)]);
13    const TEMPLATE: AttributeTemplate =
14        ::rustc_feature::AttributeTemplate {
    word: false,
    list: None,
    one_of: &[],
    name_value_str: Some(&["transparent", "semiopaque", "opaque"]),
    docs: None,
}template!(NameValueStr: ["transparent", "semiopaque", "opaque"]);
15
16    fn convert(cx: &mut AcceptContext<'_, '_>, args: &ArgParser) -> Option<AttributeKind> {
17        let nv = cx.expect_name_value(args, cx.attr_span, None)?;
18        match nv.value_as_str() {
19            Some(sym::transparent) => Some(Transparency::Transparent),
20            Some(sym::semiopaque) => Some(Transparency::SemiOpaque),
21            Some(sym::opaque) => Some(Transparency::Opaque),
22            Some(_) => {
23                cx.adcx().expected_specific_argument_strings(
24                    nv.value_span,
25                    &[sym::transparent, sym::semiopaque, sym::opaque],
26                );
27                None
28            }
29            None => None,
30        }
31        .map(AttributeKind::RustcMacroTransparency)
32    }
33}