rustc_attr_parsing/attributes/cfi_encoding.rs
1use super::prelude::*;
2pub(crate) struct CfiEncodingParser;
3impl<S: Stage> SingleAttributeParser<S> for CfiEncodingParser {
4 const PATH: &[Symbol] = &[sym::cfi_encoding];
5 const ALLOWED_TARGETS: AllowedTargets = AllowedTargets::AllowListWarnRest(&[
6 Allow(Target::Struct),
7 Allow(Target::ForeignTy),
8 Allow(Target::Enum),
9 Allow(Target::Union),
10 ]);
11 const ATTRIBUTE_ORDER: AttributeOrder = AttributeOrder::KeepInnermost;
12 const ON_DUPLICATE: OnDuplicate<S> = OnDuplicate::Error;
13 const TEMPLATE: AttributeTemplate = template!(NameValueStr: "encoding");
14
15 fn convert(cx: &mut AcceptContext<'_, '_, S>, args: &ArgParser) -> Option<AttributeKind> {
16 let Some(name_value) = args.name_value() else {
17 cx.expected_name_value(cx.attr_span, Some(sym::cfi_encoding));
18 return None;
19 };
20
21 let Some(value_str) = name_value.value_as_str() else {
22 cx.expected_string_literal(name_value.value_span, None);
23 return None;
24 };
25
26 if value_str.as_str().trim().is_empty() {
27 cx.expected_non_empty_string_literal(name_value.value_span);
28 return None;
29 }
30
31 Some(AttributeKind::CfiEncoding { encoding: value_str })
32 }
33}