rustc_attr_parsing/attributes/
cfi_encoding.rs1use super::prelude::*;
2pub(crate) struct CfiEncodingParser;
3impl SingleAttributeParser 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 TEMPLATE: AttributeTemplate = ::rustc_feature::AttributeTemplate {
word: false,
list: None,
one_of: &[],
name_value_str: Some(&["encoding"]),
docs: None,
}template!(NameValueStr: "encoding");
12
13 fn convert(cx: &mut AcceptContext<'_, '_>, args: &ArgParser) -> Option<AttributeKind> {
14 let name_value = cx.expect_name_value(args, cx.attr_span, Some(sym::cfi_encoding))?;
15
16 let Some(value_str) = name_value.value_as_str() else {
17 cx.adcx().expected_string_literal(name_value.value_span, None);
18 return None;
19 };
20
21 if value_str.as_str().trim().is_empty() {
22 cx.adcx().expected_non_empty_string_literal(name_value.value_span);
23 return None;
24 }
25
26 Some(AttributeKind::CfiEncoding { encoding: value_str })
27 }
28}