Skip to main content

rustc_attr_parsing/
context.rs

1use std::cell::RefCell;
2use std::collections::BTreeMap;
3use std::collections::btree_map::Entry;
4use std::mem;
5use std::ops::{Deref, DerefMut};
6use std::sync::LazyLock;
7
8use rustc_ast::{AttrStyle, MetaItemLit};
9use rustc_data_structures::sync::{DynSend, DynSync};
10use rustc_errors::{Diag, DiagCtxtHandle, Diagnostic, Level, MultiSpan};
11use rustc_feature::{AttrSuggestionStyle, AttributeTemplate};
12use rustc_hir::AttrPath;
13use rustc_hir::attrs::AttributeKind;
14use rustc_parse::parser::Recovery;
15use rustc_session::Session;
16use rustc_session::lint::{Lint, LintId};
17use rustc_span::{ErrorGuaranteed, Ident, Span, Symbol};
18
19// Glob imports to avoid big, bitrotty import lists
20use crate::attributes::allow_unstable::*;
21use crate::attributes::autodiff::*;
22use crate::attributes::body::*;
23use crate::attributes::cfi_encoding::*;
24use crate::attributes::codegen_attrs::*;
25use crate::attributes::confusables::*;
26use crate::attributes::crate_level::*;
27use crate::attributes::debugger::*;
28use crate::attributes::deprecation::*;
29use crate::attributes::diagnostic::do_not_recommend::*;
30use crate::attributes::diagnostic::on_const::*;
31use crate::attributes::diagnostic::on_move::*;
32use crate::attributes::diagnostic::on_unimplemented::*;
33use crate::attributes::diagnostic::on_unknown::*;
34use crate::attributes::diagnostic::on_unmatch_args::*;
35use crate::attributes::doc::*;
36use crate::attributes::dummy::*;
37use crate::attributes::inline::*;
38use crate::attributes::instruction_set::*;
39use crate::attributes::link_attrs::*;
40use crate::attributes::lint_helpers::*;
41use crate::attributes::loop_match::*;
42use crate::attributes::macro_attrs::*;
43use crate::attributes::must_not_suspend::*;
44use crate::attributes::must_use::*;
45use crate::attributes::no_implicit_prelude::*;
46use crate::attributes::no_link::*;
47use crate::attributes::non_exhaustive::*;
48use crate::attributes::path::PathParser as PathAttributeParser;
49use crate::attributes::pin_v2::*;
50use crate::attributes::proc_macro_attrs::*;
51use crate::attributes::prototype::*;
52use crate::attributes::repr::*;
53use crate::attributes::rustc_allocator::*;
54use crate::attributes::rustc_dump::*;
55use crate::attributes::rustc_internal::*;
56use crate::attributes::semantics::*;
57use crate::attributes::stability::*;
58use crate::attributes::test_attrs::*;
59use crate::attributes::traits::*;
60use crate::attributes::transparency::*;
61use crate::attributes::{AttributeParser as _, AttributeSafety, Combine, Single, WithoutArgs};
62use crate::parser::{
63    ArgParser, MetaItemListParser, MetaItemOrLitParser, MetaItemParser, NameValueParser,
64    RefPathParser,
65};
66use crate::session_diagnostics::{
67    AttributeParseError, AttributeParseErrorReason, AttributeParseErrorSuggestions,
68    ParsedDescription,
69};
70use crate::target_checking::AllowedTargets;
71use crate::{AttributeParser, EmitAttribute};
72
73type GroupType = LazyLock<GroupTypeInner>;
74
75pub(super) struct GroupTypeInner {
76    pub(super) accepters: BTreeMap<&'static [Symbol], GroupTypeInnerAccept>,
77}
78
79pub(super) struct GroupTypeInnerAccept {
80    pub(super) template: AttributeTemplate,
81    pub(super) accept_fn: AcceptFn,
82    pub(super) allowed_targets: AllowedTargets,
83    pub(super) safety: AttributeSafety,
84    pub(super) finalizer: FinalizeFn,
85}
86
87pub(crate) type AcceptFn =
88    Box<dyn for<'sess, 'a> Fn(&mut AcceptContext<'_, 'sess>, &ArgParser) + Send + Sync>;
89pub(crate) type FinalizeFn = fn(&mut FinalizeContext<'_, '_>) -> Option<AttributeKind>;
90
91macro_rules! attribute_parsers {
92    (
93        pub(crate) static $name: ident = [$($names: ty),* $(,)?];
94    ) => {
95        pub(crate) static $name: GroupType = LazyLock::new(|| {
96            let mut accepters = BTreeMap::<_, GroupTypeInnerAccept>::new();
97            $(
98                {
99                    thread_local! {
100                        static STATE_OBJECT: RefCell<$names> = RefCell::new(<$names>::default());
101                    };
102
103                    for (path, template, accept_fn) in <$names>::ATTRIBUTES {
104                        match accepters.entry(*path) {
105                            Entry::Vacant(e) => {
106                                e.insert(GroupTypeInnerAccept {
107                                    template: *template,
108                                    accept_fn: Box::new(|cx, args| {
109                                        STATE_OBJECT.with_borrow_mut(|s| {
110                                            accept_fn(s, cx, args)
111                                        })
112                                    }),
113                                    safety: <$names as crate::attributes::AttributeParser>::SAFETY,
114                                    allowed_targets: <$names as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
115                                    finalizer: |cx| {
116                                        let state = STATE_OBJECT.take();
117                                        state.finalize(cx)
118                                    }
119                                });
120                            }
121                            Entry::Occupied(_) => panic!("Attribute {path:?} has multiple accepters"),
122                        }
123                    }
124                }
125            )*
126
127            GroupTypeInner { accepters }
128        });
129    };
130}
131pub(crate) static ATTRIBUTE_PARSERS: GroupType =
    LazyLock::new(||
            {
                let mut accepters =
                    BTreeMap::<_, GroupTypeInnerAccept>::new();
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<BodyStabilityParser>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<BodyStabilityParser> {
                                RefCell::new(<BodyStabilityParser>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<BodyStabilityParser>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<BodyStabilityParser>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<BodyStabilityParser>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <BodyStabilityParser>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <BodyStabilityParser as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <BodyStabilityParser as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<ConfusablesParser>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<ConfusablesParser> {
                                RefCell::new(<ConfusablesParser>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<ConfusablesParser>>() {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<ConfusablesParser>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<ConfusablesParser>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <ConfusablesParser>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <ConfusablesParser as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <ConfusablesParser as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<ConstStabilityParser>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<ConstStabilityParser> {
                                RefCell::new(<ConstStabilityParser>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<ConstStabilityParser>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<ConstStabilityParser>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<ConstStabilityParser>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <ConstStabilityParser>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <ConstStabilityParser as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <ConstStabilityParser as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<DocParser>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn() -> RefCell<DocParser> {
                                RefCell::new(<DocParser>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<DocParser>>() {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<DocParser>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<DocParser>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in <DocParser>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <DocParser as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <DocParser as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<MacroUseParser>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<MacroUseParser> {
                                RefCell::new(<MacroUseParser>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<MacroUseParser>>() {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<MacroUseParser>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<MacroUseParser>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <MacroUseParser>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <MacroUseParser as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <MacroUseParser as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<NakedParser>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn() -> RefCell<NakedParser> {
                                RefCell::new(<NakedParser>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<NakedParser>>() {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<NakedParser>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<NakedParser>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in <NakedParser>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <NakedParser as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <NakedParser as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<OnConstParser>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn() -> RefCell<OnConstParser> {
                                RefCell::new(<OnConstParser>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<OnConstParser>>() {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<OnConstParser>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<OnConstParser>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <OnConstParser>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <OnConstParser as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <OnConstParser as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<OnMoveParser>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn() -> RefCell<OnMoveParser> {
                                RefCell::new(<OnMoveParser>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<OnMoveParser>>() {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<OnMoveParser>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<OnMoveParser>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <OnMoveParser>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <OnMoveParser as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <OnMoveParser as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<OnUnimplementedParser>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<OnUnimplementedParser> {
                                RefCell::new(<OnUnimplementedParser>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<OnUnimplementedParser>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<OnUnimplementedParser>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<OnUnimplementedParser>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <OnUnimplementedParser>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <OnUnimplementedParser as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <OnUnimplementedParser as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<OnUnknownParser>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<OnUnknownParser> {
                                RefCell::new(<OnUnknownParser>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<OnUnknownParser>>() {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<OnUnknownParser>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<OnUnknownParser>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <OnUnknownParser>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <OnUnknownParser as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <OnUnknownParser as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<OnUnmatchArgsParser>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<OnUnmatchArgsParser> {
                                RefCell::new(<OnUnmatchArgsParser>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<OnUnmatchArgsParser>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<OnUnmatchArgsParser>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<OnUnmatchArgsParser>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <OnUnmatchArgsParser>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <OnUnmatchArgsParser as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <OnUnmatchArgsParser as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<RustcAlignParser>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<RustcAlignParser> {
                                RefCell::new(<RustcAlignParser>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<RustcAlignParser>>() {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<RustcAlignParser>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<RustcAlignParser>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <RustcAlignParser>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <RustcAlignParser as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <RustcAlignParser as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<RustcAlignStaticParser>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<RustcAlignStaticParser> {
                                RefCell::new(<RustcAlignStaticParser>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<RustcAlignStaticParser>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<RustcAlignStaticParser>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<RustcAlignStaticParser>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <RustcAlignStaticParser>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <RustcAlignStaticParser as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <RustcAlignStaticParser as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<RustcCguTestAttributeParser>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<RustcCguTestAttributeParser> {
                                RefCell::new(<RustcCguTestAttributeParser>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<RustcCguTestAttributeParser>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<RustcCguTestAttributeParser>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<RustcCguTestAttributeParser>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <RustcCguTestAttributeParser>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <RustcCguTestAttributeParser as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <RustcCguTestAttributeParser as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<StabilityParser>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<StabilityParser> {
                                RefCell::new(<StabilityParser>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<StabilityParser>>() {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<StabilityParser>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<StabilityParser>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <StabilityParser>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <StabilityParser as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <StabilityParser as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<UsedParser>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn() -> RefCell<UsedParser> {
                                RefCell::new(<UsedParser>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<UsedParser>>() {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<UsedParser>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<UsedParser>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in <UsedParser>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <UsedParser as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <UsedParser as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Combine<AllowInternalUnstableParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Combine<AllowInternalUnstableParser>> {
                                RefCell::new(<Combine<AllowInternalUnstableParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Combine<AllowInternalUnstableParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Combine<AllowInternalUnstableParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Combine<AllowInternalUnstableParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Combine<AllowInternalUnstableParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Combine<AllowInternalUnstableParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Combine<AllowInternalUnstableParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Combine<CrateTypeParser>>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Combine<CrateTypeParser>> {
                                RefCell::new(<Combine<CrateTypeParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Combine<CrateTypeParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Combine<CrateTypeParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Combine<CrateTypeParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Combine<CrateTypeParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Combine<CrateTypeParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Combine<CrateTypeParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Combine<DebuggerViualizerParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Combine<DebuggerViualizerParser>> {
                                RefCell::new(<Combine<DebuggerViualizerParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Combine<DebuggerViualizerParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Combine<DebuggerViualizerParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Combine<DebuggerViualizerParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Combine<DebuggerViualizerParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Combine<DebuggerViualizerParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Combine<DebuggerViualizerParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Combine<FeatureParser>>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Combine<FeatureParser>> {
                                RefCell::new(<Combine<FeatureParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Combine<FeatureParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Combine<FeatureParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Combine<FeatureParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Combine<FeatureParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Combine<FeatureParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Combine<FeatureParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Combine<ForceTargetFeatureParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Combine<ForceTargetFeatureParser>> {
                                RefCell::new(<Combine<ForceTargetFeatureParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Combine<ForceTargetFeatureParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Combine<ForceTargetFeatureParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Combine<ForceTargetFeatureParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Combine<ForceTargetFeatureParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Combine<ForceTargetFeatureParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Combine<ForceTargetFeatureParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Combine<LinkParser>>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Combine<LinkParser>> {
                                RefCell::new(<Combine<LinkParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Combine<LinkParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Combine<LinkParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Combine<LinkParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Combine<LinkParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Combine<LinkParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Combine<LinkParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Combine<RegisterToolParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Combine<RegisterToolParser>> {
                                RefCell::new(<Combine<RegisterToolParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Combine<RegisterToolParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Combine<RegisterToolParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Combine<RegisterToolParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Combine<RegisterToolParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Combine<RegisterToolParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Combine<RegisterToolParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Combine<ReprParser>>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Combine<ReprParser>> {
                                RefCell::new(<Combine<ReprParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Combine<ReprParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Combine<ReprParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Combine<ReprParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Combine<ReprParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Combine<ReprParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Combine<ReprParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Combine<RustcAllowConstFnUnstableParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Combine<RustcAllowConstFnUnstableParser>> {
                                RefCell::new(<Combine<RustcAllowConstFnUnstableParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Combine<RustcAllowConstFnUnstableParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Combine<RustcAllowConstFnUnstableParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Combine<RustcAllowConstFnUnstableParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Combine<RustcAllowConstFnUnstableParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Combine<RustcAllowConstFnUnstableParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Combine<RustcAllowConstFnUnstableParser>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Combine<RustcCleanParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Combine<RustcCleanParser>> {
                                RefCell::new(<Combine<RustcCleanParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Combine<RustcCleanParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Combine<RustcCleanParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Combine<RustcCleanParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Combine<RustcCleanParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Combine<RustcCleanParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Combine<RustcCleanParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Combine<RustcDumpLayoutParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Combine<RustcDumpLayoutParser>> {
                                RefCell::new(<Combine<RustcDumpLayoutParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Combine<RustcDumpLayoutParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Combine<RustcDumpLayoutParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Combine<RustcDumpLayoutParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Combine<RustcDumpLayoutParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Combine<RustcDumpLayoutParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Combine<RustcDumpLayoutParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Combine<RustcMirParser>>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Combine<RustcMirParser>> {
                                RefCell::new(<Combine<RustcMirParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Combine<RustcMirParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Combine<RustcMirParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Combine<RustcMirParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Combine<RustcMirParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Combine<RustcMirParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Combine<RustcMirParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Combine<RustcThenThisWouldNeedParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Combine<RustcThenThisWouldNeedParser>> {
                                RefCell::new(<Combine<RustcThenThisWouldNeedParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Combine<RustcThenThisWouldNeedParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Combine<RustcThenThisWouldNeedParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Combine<RustcThenThisWouldNeedParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Combine<RustcThenThisWouldNeedParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Combine<RustcThenThisWouldNeedParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Combine<RustcThenThisWouldNeedParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Combine<TargetFeatureParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Combine<TargetFeatureParser>> {
                                RefCell::new(<Combine<TargetFeatureParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Combine<TargetFeatureParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Combine<TargetFeatureParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Combine<TargetFeatureParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Combine<TargetFeatureParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Combine<TargetFeatureParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Combine<TargetFeatureParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Combine<UnstableFeatureBoundParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Combine<UnstableFeatureBoundParser>> {
                                RefCell::new(<Combine<UnstableFeatureBoundParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Combine<UnstableFeatureBoundParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Combine<UnstableFeatureBoundParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Combine<UnstableFeatureBoundParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Combine<UnstableFeatureBoundParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Combine<UnstableFeatureBoundParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Combine<UnstableFeatureBoundParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Combine<UnstableRemovedParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Combine<UnstableRemovedParser>> {
                                RefCell::new(<Combine<UnstableRemovedParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Combine<UnstableRemovedParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Combine<UnstableRemovedParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Combine<UnstableRemovedParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Combine<UnstableRemovedParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Combine<UnstableRemovedParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Combine<UnstableRemovedParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<CfiEncodingParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<CfiEncodingParser>> {
                                RefCell::new(<Single<CfiEncodingParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<CfiEncodingParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<CfiEncodingParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<CfiEncodingParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<CfiEncodingParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<CfiEncodingParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<CfiEncodingParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<CollapseDebugInfoParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<CollapseDebugInfoParser>> {
                                RefCell::new(<Single<CollapseDebugInfoParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<CollapseDebugInfoParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<CollapseDebugInfoParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<CollapseDebugInfoParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<CollapseDebugInfoParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<CollapseDebugInfoParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<CollapseDebugInfoParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<CoverageParser>>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<CoverageParser>> {
                                RefCell::new(<Single<CoverageParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<CoverageParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<CoverageParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<CoverageParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<CoverageParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<CoverageParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<CoverageParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<CrateNameParser>>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<CrateNameParser>> {
                                RefCell::new(<Single<CrateNameParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<CrateNameParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<CrateNameParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<CrateNameParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<CrateNameParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<CrateNameParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<CrateNameParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<CustomMirParser>>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<CustomMirParser>> {
                                RefCell::new(<Single<CustomMirParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<CustomMirParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<CustomMirParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<CustomMirParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<CustomMirParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<CustomMirParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<CustomMirParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<DeprecatedParser>>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<DeprecatedParser>> {
                                RefCell::new(<Single<DeprecatedParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<DeprecatedParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<DeprecatedParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<DeprecatedParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<DeprecatedParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<DeprecatedParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<DeprecatedParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<DoNotRecommendParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<DoNotRecommendParser>> {
                                RefCell::new(<Single<DoNotRecommendParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<DoNotRecommendParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<DoNotRecommendParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<DoNotRecommendParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<DoNotRecommendParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<DoNotRecommendParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<DoNotRecommendParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<ExportNameParser>>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<ExportNameParser>> {
                                RefCell::new(<Single<ExportNameParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<ExportNameParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<ExportNameParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<ExportNameParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<ExportNameParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<ExportNameParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<ExportNameParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<IgnoreParser>>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<IgnoreParser>> {
                                RefCell::new(<Single<IgnoreParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<IgnoreParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<IgnoreParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<IgnoreParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<IgnoreParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<IgnoreParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<IgnoreParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<InlineParser>>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<InlineParser>> {
                                RefCell::new(<Single<InlineParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<InlineParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<InlineParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<InlineParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<InlineParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<InlineParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<InlineParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<InstructionSetParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<InstructionSetParser>> {
                                RefCell::new(<Single<InstructionSetParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<InstructionSetParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<InstructionSetParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<InstructionSetParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<InstructionSetParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<InstructionSetParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<InstructionSetParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<LangParser>>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<LangParser>> {
                                RefCell::new(<Single<LangParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<LangParser>>>() {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<LangParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<LangParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<LangParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<LangParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<LangParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<LinkNameParser>>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<LinkNameParser>> {
                                RefCell::new(<Single<LinkNameParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<LinkNameParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<LinkNameParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<LinkNameParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<LinkNameParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<LinkNameParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<LinkNameParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<LinkOrdinalParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<LinkOrdinalParser>> {
                                RefCell::new(<Single<LinkOrdinalParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<LinkOrdinalParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<LinkOrdinalParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<LinkOrdinalParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<LinkOrdinalParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<LinkOrdinalParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<LinkOrdinalParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<LinkSectionParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<LinkSectionParser>> {
                                RefCell::new(<Single<LinkSectionParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<LinkSectionParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<LinkSectionParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<LinkSectionParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<LinkSectionParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<LinkSectionParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<LinkSectionParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<LinkageParser>>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<LinkageParser>> {
                                RefCell::new(<Single<LinkageParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<LinkageParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<LinkageParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<LinkageParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<LinkageParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<LinkageParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<LinkageParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<MacroExportParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<MacroExportParser>> {
                                RefCell::new(<Single<MacroExportParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<MacroExportParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<MacroExportParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<MacroExportParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<MacroExportParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<MacroExportParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<MacroExportParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<MoveSizeLimitParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<MoveSizeLimitParser>> {
                                RefCell::new(<Single<MoveSizeLimitParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<MoveSizeLimitParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<MoveSizeLimitParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<MoveSizeLimitParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<MoveSizeLimitParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<MoveSizeLimitParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<MoveSizeLimitParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<MustNotSuspendParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<MustNotSuspendParser>> {
                                RefCell::new(<Single<MustNotSuspendParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<MustNotSuspendParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<MustNotSuspendParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<MustNotSuspendParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<MustNotSuspendParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<MustNotSuspendParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<MustNotSuspendParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<MustUseParser>>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<MustUseParser>> {
                                RefCell::new(<Single<MustUseParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<MustUseParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<MustUseParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<MustUseParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<MustUseParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<MustUseParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<MustUseParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<OptimizeParser>>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<OptimizeParser>> {
                                RefCell::new(<Single<OptimizeParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<OptimizeParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<OptimizeParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<OptimizeParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<OptimizeParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<OptimizeParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<OptimizeParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<PatchableFunctionEntryParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<PatchableFunctionEntryParser>> {
                                RefCell::new(<Single<PatchableFunctionEntryParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<PatchableFunctionEntryParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<PatchableFunctionEntryParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<PatchableFunctionEntryParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<PatchableFunctionEntryParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<PatchableFunctionEntryParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<PatchableFunctionEntryParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<PathAttributeParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<PathAttributeParser>> {
                                RefCell::new(<Single<PathAttributeParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<PathAttributeParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<PathAttributeParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<PathAttributeParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<PathAttributeParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<PathAttributeParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<PathAttributeParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<PatternComplexityLimitParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<PatternComplexityLimitParser>> {
                                RefCell::new(<Single<PatternComplexityLimitParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<PatternComplexityLimitParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<PatternComplexityLimitParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<PatternComplexityLimitParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<PatternComplexityLimitParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<PatternComplexityLimitParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<PatternComplexityLimitParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<ProcMacroDeriveParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<ProcMacroDeriveParser>> {
                                RefCell::new(<Single<ProcMacroDeriveParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<ProcMacroDeriveParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<ProcMacroDeriveParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<ProcMacroDeriveParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<ProcMacroDeriveParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<ProcMacroDeriveParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<ProcMacroDeriveParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<RecursionLimitParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<RecursionLimitParser>> {
                                RefCell::new(<Single<RecursionLimitParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<RecursionLimitParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RecursionLimitParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RecursionLimitParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<RecursionLimitParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<RecursionLimitParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<RecursionLimitParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<ReexportTestHarnessMainParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<ReexportTestHarnessMainParser>> {
                                RefCell::new(<Single<ReexportTestHarnessMainParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<ReexportTestHarnessMainParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<ReexportTestHarnessMainParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<ReexportTestHarnessMainParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<ReexportTestHarnessMainParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<ReexportTestHarnessMainParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<ReexportTestHarnessMainParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<RustcAbiParser>>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<RustcAbiParser>> {
                                RefCell::new(<Single<RustcAbiParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<RustcAbiParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcAbiParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcAbiParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<RustcAbiParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<RustcAbiParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<RustcAbiParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<RustcAllocatorZeroedVariantParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<RustcAllocatorZeroedVariantParser>> {
                                RefCell::new(<Single<RustcAllocatorZeroedVariantParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<RustcAllocatorZeroedVariantParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcAllocatorZeroedVariantParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcAllocatorZeroedVariantParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<RustcAllocatorZeroedVariantParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<RustcAllocatorZeroedVariantParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<RustcAllocatorZeroedVariantParser>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<RustcAutodiffParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<RustcAutodiffParser>> {
                                RefCell::new(<Single<RustcAutodiffParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<RustcAutodiffParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcAutodiffParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcAutodiffParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<RustcAutodiffParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<RustcAutodiffParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<RustcAutodiffParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<RustcBuiltinMacroParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<RustcBuiltinMacroParser>> {
                                RefCell::new(<Single<RustcBuiltinMacroParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<RustcBuiltinMacroParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcBuiltinMacroParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcBuiltinMacroParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<RustcBuiltinMacroParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<RustcBuiltinMacroParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<RustcBuiltinMacroParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<RustcDeprecatedSafe2024Parser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<RustcDeprecatedSafe2024Parser>> {
                                RefCell::new(<Single<RustcDeprecatedSafe2024Parser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<RustcDeprecatedSafe2024Parser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcDeprecatedSafe2024Parser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcDeprecatedSafe2024Parser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<RustcDeprecatedSafe2024Parser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<RustcDeprecatedSafe2024Parser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<RustcDeprecatedSafe2024Parser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<RustcDiagnosticItemParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<RustcDiagnosticItemParser>> {
                                RefCell::new(<Single<RustcDiagnosticItemParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<RustcDiagnosticItemParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcDiagnosticItemParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcDiagnosticItemParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<RustcDiagnosticItemParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<RustcDiagnosticItemParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<RustcDiagnosticItemParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<RustcDocPrimitiveParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<RustcDocPrimitiveParser>> {
                                RefCell::new(<Single<RustcDocPrimitiveParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<RustcDocPrimitiveParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcDocPrimitiveParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcDocPrimitiveParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<RustcDocPrimitiveParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<RustcDocPrimitiveParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<RustcDocPrimitiveParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<RustcDummyParser>>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<RustcDummyParser>> {
                                RefCell::new(<Single<RustcDummyParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<RustcDummyParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcDummyParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcDummyParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<RustcDummyParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<RustcDummyParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<RustcDummyParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<RustcDumpDefPathParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<RustcDumpDefPathParser>> {
                                RefCell::new(<Single<RustcDumpDefPathParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<RustcDumpDefPathParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcDumpDefPathParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcDumpDefPathParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<RustcDumpDefPathParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<RustcDumpDefPathParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<RustcDumpDefPathParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<RustcDumpSymbolNameParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<RustcDumpSymbolNameParser>> {
                                RefCell::new(<Single<RustcDumpSymbolNameParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<RustcDumpSymbolNameParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcDumpSymbolNameParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcDumpSymbolNameParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<RustcDumpSymbolNameParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<RustcDumpSymbolNameParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<RustcDumpSymbolNameParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<RustcForceInlineParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<RustcForceInlineParser>> {
                                RefCell::new(<Single<RustcForceInlineParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<RustcForceInlineParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcForceInlineParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcForceInlineParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<RustcForceInlineParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<RustcForceInlineParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<RustcForceInlineParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<RustcIfThisChangedParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<RustcIfThisChangedParser>> {
                                RefCell::new(<Single<RustcIfThisChangedParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<RustcIfThisChangedParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcIfThisChangedParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcIfThisChangedParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<RustcIfThisChangedParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<RustcIfThisChangedParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<RustcIfThisChangedParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<RustcLayoutScalarValidRangeEndParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<RustcLayoutScalarValidRangeEndParser>> {
                                RefCell::new(<Single<RustcLayoutScalarValidRangeEndParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<RustcLayoutScalarValidRangeEndParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcLayoutScalarValidRangeEndParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcLayoutScalarValidRangeEndParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<RustcLayoutScalarValidRangeEndParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<RustcLayoutScalarValidRangeEndParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<RustcLayoutScalarValidRangeEndParser>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<RustcLayoutScalarValidRangeStartParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<RustcLayoutScalarValidRangeStartParser>> {
                                RefCell::new(<Single<RustcLayoutScalarValidRangeStartParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<RustcLayoutScalarValidRangeStartParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcLayoutScalarValidRangeStartParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcLayoutScalarValidRangeStartParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<RustcLayoutScalarValidRangeStartParser>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<RustcLayoutScalarValidRangeStartParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<RustcLayoutScalarValidRangeStartParser>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<RustcLegacyConstGenericsParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<RustcLegacyConstGenericsParser>> {
                                RefCell::new(<Single<RustcLegacyConstGenericsParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<RustcLegacyConstGenericsParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcLegacyConstGenericsParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcLegacyConstGenericsParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<RustcLegacyConstGenericsParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<RustcLegacyConstGenericsParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<RustcLegacyConstGenericsParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<RustcLintOptDenyFieldAccessParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<RustcLintOptDenyFieldAccessParser>> {
                                RefCell::new(<Single<RustcLintOptDenyFieldAccessParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<RustcLintOptDenyFieldAccessParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcLintOptDenyFieldAccessParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcLintOptDenyFieldAccessParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<RustcLintOptDenyFieldAccessParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<RustcLintOptDenyFieldAccessParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<RustcLintOptDenyFieldAccessParser>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<RustcMacroTransparencyParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<RustcMacroTransparencyParser>> {
                                RefCell::new(<Single<RustcMacroTransparencyParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<RustcMacroTransparencyParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcMacroTransparencyParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcMacroTransparencyParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<RustcMacroTransparencyParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<RustcMacroTransparencyParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<RustcMacroTransparencyParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<RustcMustImplementOneOfParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<RustcMustImplementOneOfParser>> {
                                RefCell::new(<Single<RustcMustImplementOneOfParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<RustcMustImplementOneOfParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcMustImplementOneOfParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcMustImplementOneOfParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<RustcMustImplementOneOfParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<RustcMustImplementOneOfParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<RustcMustImplementOneOfParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<RustcNeverTypeOptionsParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<RustcNeverTypeOptionsParser>> {
                                RefCell::new(<Single<RustcNeverTypeOptionsParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<RustcNeverTypeOptionsParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcNeverTypeOptionsParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcNeverTypeOptionsParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<RustcNeverTypeOptionsParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<RustcNeverTypeOptionsParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<RustcNeverTypeOptionsParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<RustcObjcClassParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<RustcObjcClassParser>> {
                                RefCell::new(<Single<RustcObjcClassParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<RustcObjcClassParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcObjcClassParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcObjcClassParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<RustcObjcClassParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<RustcObjcClassParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<RustcObjcClassParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<RustcObjcSelectorParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<RustcObjcSelectorParser>> {
                                RefCell::new(<Single<RustcObjcSelectorParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<RustcObjcSelectorParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcObjcSelectorParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcObjcSelectorParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<RustcObjcSelectorParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<RustcObjcSelectorParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<RustcObjcSelectorParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<RustcReservationImplParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<RustcReservationImplParser>> {
                                RefCell::new(<Single<RustcReservationImplParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<RustcReservationImplParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcReservationImplParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcReservationImplParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<RustcReservationImplParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<RustcReservationImplParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<RustcReservationImplParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<RustcScalableVectorParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<RustcScalableVectorParser>> {
                                RefCell::new(<Single<RustcScalableVectorParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<RustcScalableVectorParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcScalableVectorParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcScalableVectorParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<RustcScalableVectorParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<RustcScalableVectorParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<RustcScalableVectorParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<RustcSimdMonomorphizeLaneLimitParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<RustcSimdMonomorphizeLaneLimitParser>> {
                                RefCell::new(<Single<RustcSimdMonomorphizeLaneLimitParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<RustcSimdMonomorphizeLaneLimitParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcSimdMonomorphizeLaneLimitParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcSimdMonomorphizeLaneLimitParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<RustcSimdMonomorphizeLaneLimitParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<RustcSimdMonomorphizeLaneLimitParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<RustcSimdMonomorphizeLaneLimitParser>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<RustcSkipDuringMethodDispatchParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<RustcSkipDuringMethodDispatchParser>> {
                                RefCell::new(<Single<RustcSkipDuringMethodDispatchParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<RustcSkipDuringMethodDispatchParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcSkipDuringMethodDispatchParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcSkipDuringMethodDispatchParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<RustcSkipDuringMethodDispatchParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<RustcSkipDuringMethodDispatchParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<RustcSkipDuringMethodDispatchParser>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<RustcTestMarkerParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<RustcTestMarkerParser>> {
                                RefCell::new(<Single<RustcTestMarkerParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<RustcTestMarkerParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcTestMarkerParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<RustcTestMarkerParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<RustcTestMarkerParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<RustcTestMarkerParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<RustcTestMarkerParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<SanitizeParser>>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<SanitizeParser>> {
                                RefCell::new(<Single<SanitizeParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<SanitizeParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<SanitizeParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<SanitizeParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<SanitizeParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<SanitizeParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<SanitizeParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<ShouldPanicParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<ShouldPanicParser>> {
                                RefCell::new(<Single<ShouldPanicParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<ShouldPanicParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<ShouldPanicParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<ShouldPanicParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<ShouldPanicParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<ShouldPanicParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<ShouldPanicParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<TestRunnerParser>>> =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<TestRunnerParser>> {
                                RefCell::new(<Single<TestRunnerParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<TestRunnerParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<TestRunnerParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<TestRunnerParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<TestRunnerParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<TestRunnerParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<TestRunnerParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<TypeLengthLimitParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<TypeLengthLimitParser>> {
                                RefCell::new(<Single<TypeLengthLimitParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<TypeLengthLimitParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<TypeLengthLimitParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<TypeLengthLimitParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<TypeLengthLimitParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<TypeLengthLimitParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<TypeLengthLimitParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WindowsSubsystemParser>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WindowsSubsystemParser>> {
                                RefCell::new(<Single<WindowsSubsystemParser>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WindowsSubsystemParser>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WindowsSubsystemParser>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WindowsSubsystemParser>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WindowsSubsystemParser>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WindowsSubsystemParser> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WindowsSubsystemParser> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<AllowInternalUnsafeParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<AllowInternalUnsafeParser>>> {
                                RefCell::new(<Single<WithoutArgs<AllowInternalUnsafeParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<AllowInternalUnsafeParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<AllowInternalUnsafeParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<AllowInternalUnsafeParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<AllowInternalUnsafeParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<AllowInternalUnsafeParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<AllowInternalUnsafeParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<AutomaticallyDerivedParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<AutomaticallyDerivedParser>>> {
                                RefCell::new(<Single<WithoutArgs<AutomaticallyDerivedParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<AutomaticallyDerivedParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<AutomaticallyDerivedParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<AutomaticallyDerivedParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<AutomaticallyDerivedParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<AutomaticallyDerivedParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<AutomaticallyDerivedParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<ColdParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<ColdParser>>> {
                                RefCell::new(<Single<WithoutArgs<ColdParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<ColdParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<ColdParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<ColdParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<ColdParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<ColdParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<ColdParser>> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<CompilerBuiltinsParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<CompilerBuiltinsParser>>> {
                                RefCell::new(<Single<WithoutArgs<CompilerBuiltinsParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<CompilerBuiltinsParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<CompilerBuiltinsParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<CompilerBuiltinsParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<CompilerBuiltinsParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<CompilerBuiltinsParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<CompilerBuiltinsParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<ConstContinueParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<ConstContinueParser>>> {
                                RefCell::new(<Single<WithoutArgs<ConstContinueParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<ConstContinueParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<ConstContinueParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<ConstContinueParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<ConstContinueParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<ConstContinueParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<ConstContinueParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<CoroutineParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<CoroutineParser>>> {
                                RefCell::new(<Single<WithoutArgs<CoroutineParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<CoroutineParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<CoroutineParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<CoroutineParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<CoroutineParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<CoroutineParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<CoroutineParser>> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<DefaultLibAllocatorParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<DefaultLibAllocatorParser>>> {
                                RefCell::new(<Single<WithoutArgs<DefaultLibAllocatorParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<DefaultLibAllocatorParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<DefaultLibAllocatorParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<DefaultLibAllocatorParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<DefaultLibAllocatorParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<DefaultLibAllocatorParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<DefaultLibAllocatorParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<ExportStableParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<ExportStableParser>>> {
                                RefCell::new(<Single<WithoutArgs<ExportStableParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<ExportStableParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<ExportStableParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<ExportStableParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<ExportStableParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<ExportStableParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<ExportStableParser>> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<FfiConstParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<FfiConstParser>>> {
                                RefCell::new(<Single<WithoutArgs<FfiConstParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<FfiConstParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<FfiConstParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<FfiConstParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<FfiConstParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<FfiConstParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<FfiConstParser>> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<FfiPureParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<FfiPureParser>>> {
                                RefCell::new(<Single<WithoutArgs<FfiPureParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<FfiPureParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<FfiPureParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<FfiPureParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<FfiPureParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<FfiPureParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<FfiPureParser>> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<FundamentalParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<FundamentalParser>>> {
                                RefCell::new(<Single<WithoutArgs<FundamentalParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<FundamentalParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<FundamentalParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<FundamentalParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<FundamentalParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<FundamentalParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<FundamentalParser>> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<LoopMatchParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<LoopMatchParser>>> {
                                RefCell::new(<Single<WithoutArgs<LoopMatchParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<LoopMatchParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<LoopMatchParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<LoopMatchParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<LoopMatchParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<LoopMatchParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<LoopMatchParser>> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<MacroEscapeParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<MacroEscapeParser>>> {
                                RefCell::new(<Single<WithoutArgs<MacroEscapeParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<MacroEscapeParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<MacroEscapeParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<MacroEscapeParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<MacroEscapeParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<MacroEscapeParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<MacroEscapeParser>> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<MarkerParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<MarkerParser>>> {
                                RefCell::new(<Single<WithoutArgs<MarkerParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<MarkerParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<MarkerParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<MarkerParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<MarkerParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<MarkerParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<MarkerParser>> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<MayDangleParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<MayDangleParser>>> {
                                RefCell::new(<Single<WithoutArgs<MayDangleParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<MayDangleParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<MayDangleParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<MayDangleParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<MayDangleParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<MayDangleParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<MayDangleParser>> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<NeedsAllocatorParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<NeedsAllocatorParser>>> {
                                RefCell::new(<Single<WithoutArgs<NeedsAllocatorParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<NeedsAllocatorParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<NeedsAllocatorParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<NeedsAllocatorParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<NeedsAllocatorParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<NeedsAllocatorParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<NeedsAllocatorParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<NeedsPanicRuntimeParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<NeedsPanicRuntimeParser>>> {
                                RefCell::new(<Single<WithoutArgs<NeedsPanicRuntimeParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<NeedsPanicRuntimeParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<NeedsPanicRuntimeParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<NeedsPanicRuntimeParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<NeedsPanicRuntimeParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<NeedsPanicRuntimeParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<NeedsPanicRuntimeParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<NoBuiltinsParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<NoBuiltinsParser>>> {
                                RefCell::new(<Single<WithoutArgs<NoBuiltinsParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<NoBuiltinsParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<NoBuiltinsParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<NoBuiltinsParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<NoBuiltinsParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<NoBuiltinsParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<NoBuiltinsParser>> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<NoCoreParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<NoCoreParser>>> {
                                RefCell::new(<Single<WithoutArgs<NoCoreParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<NoCoreParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<NoCoreParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<NoCoreParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<NoCoreParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<NoCoreParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<NoCoreParser>> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<NoImplicitPreludeParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<NoImplicitPreludeParser>>> {
                                RefCell::new(<Single<WithoutArgs<NoImplicitPreludeParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<NoImplicitPreludeParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<NoImplicitPreludeParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<NoImplicitPreludeParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<NoImplicitPreludeParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<NoImplicitPreludeParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<NoImplicitPreludeParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<NoLinkParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<NoLinkParser>>> {
                                RefCell::new(<Single<WithoutArgs<NoLinkParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<NoLinkParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<NoLinkParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<NoLinkParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<NoLinkParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<NoLinkParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<NoLinkParser>> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<NoMainParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<NoMainParser>>> {
                                RefCell::new(<Single<WithoutArgs<NoMainParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<NoMainParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<NoMainParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<NoMainParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<NoMainParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<NoMainParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<NoMainParser>> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<NoMangleParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<NoMangleParser>>> {
                                RefCell::new(<Single<WithoutArgs<NoMangleParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<NoMangleParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<NoMangleParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<NoMangleParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<NoMangleParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<NoMangleParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<NoMangleParser>> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<NoStdParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<NoStdParser>>> {
                                RefCell::new(<Single<WithoutArgs<NoStdParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<NoStdParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<NoStdParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<NoStdParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<NoStdParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<NoStdParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<NoStdParser>> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<NonExhaustiveParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<NonExhaustiveParser>>> {
                                RefCell::new(<Single<WithoutArgs<NonExhaustiveParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<NonExhaustiveParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<NonExhaustiveParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<NonExhaustiveParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<NonExhaustiveParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<NonExhaustiveParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<NonExhaustiveParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<PanicHandlerParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<PanicHandlerParser>>> {
                                RefCell::new(<Single<WithoutArgs<PanicHandlerParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<PanicHandlerParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<PanicHandlerParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<PanicHandlerParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<PanicHandlerParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<PanicHandlerParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<PanicHandlerParser>> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<PanicRuntimeParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<PanicRuntimeParser>>> {
                                RefCell::new(<Single<WithoutArgs<PanicRuntimeParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<PanicRuntimeParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<PanicRuntimeParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<PanicRuntimeParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<PanicRuntimeParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<PanicRuntimeParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<PanicRuntimeParser>> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<PinV2Parser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<PinV2Parser>>> {
                                RefCell::new(<Single<WithoutArgs<PinV2Parser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<PinV2Parser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<PinV2Parser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<PinV2Parser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<PinV2Parser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<PinV2Parser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<PinV2Parser>> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<PreludeImportParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<PreludeImportParser>>> {
                                RefCell::new(<Single<WithoutArgs<PreludeImportParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<PreludeImportParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<PreludeImportParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<PreludeImportParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<PreludeImportParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<PreludeImportParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<PreludeImportParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<ProcMacroAttributeParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<ProcMacroAttributeParser>>> {
                                RefCell::new(<Single<WithoutArgs<ProcMacroAttributeParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<ProcMacroAttributeParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<ProcMacroAttributeParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<ProcMacroAttributeParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<ProcMacroAttributeParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<ProcMacroAttributeParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<ProcMacroAttributeParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<ProcMacroParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<ProcMacroParser>>> {
                                RefCell::new(<Single<WithoutArgs<ProcMacroParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<ProcMacroParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<ProcMacroParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<ProcMacroParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<ProcMacroParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<ProcMacroParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<ProcMacroParser>> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<ProfilerRuntimeParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<ProfilerRuntimeParser>>> {
                                RefCell::new(<Single<WithoutArgs<ProfilerRuntimeParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<ProfilerRuntimeParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<ProfilerRuntimeParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<ProfilerRuntimeParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<ProfilerRuntimeParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<ProfilerRuntimeParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<ProfilerRuntimeParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcAllocatorParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<RustcAllocatorParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcAllocatorParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcAllocatorParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcAllocatorParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcAllocatorParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcAllocatorParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcAllocatorParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcAllocatorParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcAllocatorZeroedParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcAllocatorZeroedParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcAllocatorZeroedParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcAllocatorZeroedParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcAllocatorZeroedParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcAllocatorZeroedParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcAllocatorZeroedParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcAllocatorZeroedParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcAllocatorZeroedParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcAllowIncoherentImplParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcAllowIncoherentImplParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcAllowIncoherentImplParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcAllowIncoherentImplParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcAllowIncoherentImplParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcAllowIncoherentImplParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcAllowIncoherentImplParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcAllowIncoherentImplParser>>
                                            as crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcAllowIncoherentImplParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcAsPtrParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<RustcAsPtrParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcAsPtrParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcAsPtrParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcAsPtrParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcAsPtrParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcAsPtrParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcAsPtrParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcAsPtrParser>> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcCaptureAnalysisParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcCaptureAnalysisParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcCaptureAnalysisParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcCaptureAnalysisParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcCaptureAnalysisParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcCaptureAnalysisParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcCaptureAnalysisParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcCaptureAnalysisParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcCaptureAnalysisParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcCoherenceIsCoreParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcCoherenceIsCoreParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcCoherenceIsCoreParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcCoherenceIsCoreParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcCoherenceIsCoreParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcCoherenceIsCoreParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcCoherenceIsCoreParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcCoherenceIsCoreParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcCoherenceIsCoreParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcCoinductiveParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<RustcCoinductiveParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcCoinductiveParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcCoinductiveParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcCoinductiveParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcCoinductiveParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcCoinductiveParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcCoinductiveParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcCoinductiveParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcConstStableIndirectParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcConstStableIndirectParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcConstStableIndirectParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcConstStableIndirectParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcConstStableIndirectParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcConstStableIndirectParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcConstStableIndirectParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcConstStableIndirectParser>>
                                            as crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcConstStableIndirectParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcConversionSuggestionParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcConversionSuggestionParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcConversionSuggestionParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcConversionSuggestionParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcConversionSuggestionParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcConversionSuggestionParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcConversionSuggestionParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcConversionSuggestionParser>>
                                            as crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcConversionSuggestionParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcDeallocatorParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<RustcDeallocatorParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcDeallocatorParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcDeallocatorParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcDeallocatorParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcDeallocatorParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcDeallocatorParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcDeallocatorParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcDeallocatorParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcDelayedBugFromInsideQueryParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcDelayedBugFromInsideQueryParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcDelayedBugFromInsideQueryParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcDelayedBugFromInsideQueryParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcDelayedBugFromInsideQueryParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcDelayedBugFromInsideQueryParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcDelayedBugFromInsideQueryParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcDelayedBugFromInsideQueryParser>>
                                            as crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcDelayedBugFromInsideQueryParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcDenyExplicitImplParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcDenyExplicitImplParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcDenyExplicitImplParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcDenyExplicitImplParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcDenyExplicitImplParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcDenyExplicitImplParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcDenyExplicitImplParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcDenyExplicitImplParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcDenyExplicitImplParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcDoNotConstCheckParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcDoNotConstCheckParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcDoNotConstCheckParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcDoNotConstCheckParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcDoNotConstCheckParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcDoNotConstCheckParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcDoNotConstCheckParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcDoNotConstCheckParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcDoNotConstCheckParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcDumpDefParentsParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<RustcDumpDefParentsParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcDumpDefParentsParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcDumpDefParentsParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcDumpDefParentsParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcDumpDefParentsParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcDumpDefParentsParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcDumpDefParentsParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcDumpDefParentsParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcDumpHiddenTypeOfOpaquesParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcDumpHiddenTypeOfOpaquesParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcDumpHiddenTypeOfOpaquesParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcDumpHiddenTypeOfOpaquesParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcDumpHiddenTypeOfOpaquesParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcDumpHiddenTypeOfOpaquesParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcDumpHiddenTypeOfOpaquesParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcDumpHiddenTypeOfOpaquesParser>>
                                            as crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcDumpHiddenTypeOfOpaquesParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcDumpInferredOutlivesParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcDumpInferredOutlivesParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcDumpInferredOutlivesParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcDumpInferredOutlivesParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcDumpInferredOutlivesParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcDumpInferredOutlivesParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcDumpInferredOutlivesParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcDumpInferredOutlivesParser>>
                                            as crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcDumpInferredOutlivesParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcDumpItemBoundsParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<RustcDumpItemBoundsParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcDumpItemBoundsParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcDumpItemBoundsParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcDumpItemBoundsParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcDumpItemBoundsParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcDumpItemBoundsParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcDumpItemBoundsParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcDumpItemBoundsParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcDumpObjectLifetimeDefaultsParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcDumpObjectLifetimeDefaultsParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcDumpObjectLifetimeDefaultsParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcDumpObjectLifetimeDefaultsParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcDumpObjectLifetimeDefaultsParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcDumpObjectLifetimeDefaultsParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcDumpObjectLifetimeDefaultsParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcDumpObjectLifetimeDefaultsParser>>
                                            as crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcDumpObjectLifetimeDefaultsParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcDumpPredicatesParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<RustcDumpPredicatesParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcDumpPredicatesParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcDumpPredicatesParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcDumpPredicatesParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcDumpPredicatesParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcDumpPredicatesParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcDumpPredicatesParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcDumpPredicatesParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcDumpUserArgsParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<RustcDumpUserArgsParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcDumpUserArgsParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcDumpUserArgsParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcDumpUserArgsParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcDumpUserArgsParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcDumpUserArgsParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcDumpUserArgsParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcDumpUserArgsParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcDumpVariancesOfOpaquesParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcDumpVariancesOfOpaquesParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcDumpVariancesOfOpaquesParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcDumpVariancesOfOpaquesParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcDumpVariancesOfOpaquesParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcDumpVariancesOfOpaquesParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcDumpVariancesOfOpaquesParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcDumpVariancesOfOpaquesParser>>
                                            as crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcDumpVariancesOfOpaquesParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcDumpVariancesParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<RustcDumpVariancesParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcDumpVariancesParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcDumpVariancesParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcDumpVariancesParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcDumpVariancesParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcDumpVariancesParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcDumpVariancesParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcDumpVariancesParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcDumpVtableParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<RustcDumpVtableParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcDumpVtableParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcDumpVtableParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcDumpVtableParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcDumpVtableParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcDumpVtableParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcDumpVtableParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcDumpVtableParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcDynIncompatibleTraitParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcDynIncompatibleTraitParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcDynIncompatibleTraitParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcDynIncompatibleTraitParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcDynIncompatibleTraitParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcDynIncompatibleTraitParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcDynIncompatibleTraitParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcDynIncompatibleTraitParser>>
                                            as crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcDynIncompatibleTraitParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcEffectiveVisibilityParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcEffectiveVisibilityParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcEffectiveVisibilityParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcEffectiveVisibilityParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcEffectiveVisibilityParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcEffectiveVisibilityParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcEffectiveVisibilityParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcEffectiveVisibilityParser>>
                                            as crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcEffectiveVisibilityParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcEiiForeignItemParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<RustcEiiForeignItemParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcEiiForeignItemParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcEiiForeignItemParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcEiiForeignItemParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcEiiForeignItemParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcEiiForeignItemParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcEiiForeignItemParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcEiiForeignItemParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcEvaluateWhereClausesParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcEvaluateWhereClausesParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcEvaluateWhereClausesParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcEvaluateWhereClausesParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcEvaluateWhereClausesParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcEvaluateWhereClausesParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcEvaluateWhereClausesParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcEvaluateWhereClausesParser>>
                                            as crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcEvaluateWhereClausesParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcExhaustiveParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<RustcExhaustiveParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcExhaustiveParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcExhaustiveParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcExhaustiveParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcExhaustiveParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcExhaustiveParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcExhaustiveParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcExhaustiveParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcHasIncoherentInherentImplsParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcHasIncoherentInherentImplsParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcHasIncoherentInherentImplsParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcHasIncoherentInherentImplsParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcHasIncoherentInherentImplsParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcHasIncoherentInherentImplsParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcHasIncoherentInherentImplsParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcHasIncoherentInherentImplsParser>>
                                            as crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcHasIncoherentInherentImplsParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcInheritOverflowChecksParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcInheritOverflowChecksParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcInheritOverflowChecksParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcInheritOverflowChecksParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcInheritOverflowChecksParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcInheritOverflowChecksParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcInheritOverflowChecksParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcInheritOverflowChecksParser>>
                                            as crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcInheritOverflowChecksParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcInsignificantDtorParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcInsignificantDtorParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcInsignificantDtorParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcInsignificantDtorParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcInsignificantDtorParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcInsignificantDtorParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcInsignificantDtorParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcInsignificantDtorParser>>
                                            as crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcInsignificantDtorParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcIntrinsicConstStableIndirectParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcIntrinsicConstStableIndirectParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcIntrinsicConstStableIndirectParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcIntrinsicConstStableIndirectParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcIntrinsicConstStableIndirectParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcIntrinsicConstStableIndirectParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcIntrinsicConstStableIndirectParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcIntrinsicConstStableIndirectParser>>
                                            as crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcIntrinsicConstStableIndirectParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcIntrinsicParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<RustcIntrinsicParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcIntrinsicParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcIntrinsicParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcIntrinsicParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcIntrinsicParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcIntrinsicParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcIntrinsicParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcIntrinsicParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcLintOptTyParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<RustcLintOptTyParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcLintOptTyParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcLintOptTyParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcLintOptTyParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcLintOptTyParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcLintOptTyParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcLintOptTyParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcLintOptTyParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcLintQueryInstabilityParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcLintQueryInstabilityParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcLintQueryInstabilityParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcLintQueryInstabilityParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcLintQueryInstabilityParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcLintQueryInstabilityParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcLintQueryInstabilityParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcLintQueryInstabilityParser>>
                                            as crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcLintQueryInstabilityParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcLintUntrackedQueryInformationParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcLintUntrackedQueryInformationParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcLintUntrackedQueryInformationParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcLintUntrackedQueryInformationParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcLintUntrackedQueryInformationParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcLintUntrackedQueryInformationParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcLintUntrackedQueryInformationParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcLintUntrackedQueryInformationParser>>
                                            as crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcLintUntrackedQueryInformationParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcMainParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<RustcMainParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcMainParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcMainParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcMainParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcMainParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcMainParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcMainParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcMainParser>> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcNeverReturnsNullPtrParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcNeverReturnsNullPtrParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcNeverReturnsNullPtrParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcNeverReturnsNullPtrParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcNeverReturnsNullPtrParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcNeverReturnsNullPtrParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcNeverReturnsNullPtrParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcNeverReturnsNullPtrParser>>
                                            as crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcNeverReturnsNullPtrParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcNoImplicitAutorefsParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcNoImplicitAutorefsParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcNoImplicitAutorefsParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcNoImplicitAutorefsParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcNoImplicitAutorefsParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcNoImplicitAutorefsParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcNoImplicitAutorefsParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcNoImplicitAutorefsParser>>
                                            as crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcNoImplicitAutorefsParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcNoImplicitBoundsParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcNoImplicitBoundsParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcNoImplicitBoundsParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcNoImplicitBoundsParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcNoImplicitBoundsParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcNoImplicitBoundsParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcNoImplicitBoundsParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcNoImplicitBoundsParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcNoImplicitBoundsParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcNoMirInlineParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<RustcNoMirInlineParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcNoMirInlineParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcNoMirInlineParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcNoMirInlineParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcNoMirInlineParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcNoMirInlineParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcNoMirInlineParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcNoMirInlineParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcNoWritableParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<RustcNoWritableParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcNoWritableParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcNoWritableParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcNoWritableParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcNoWritableParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcNoWritableParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcNoWritableParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcNoWritableParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcNonConstTraitMethodParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcNonConstTraitMethodParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcNonConstTraitMethodParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcNonConstTraitMethodParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcNonConstTraitMethodParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcNonConstTraitMethodParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcNonConstTraitMethodParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcNonConstTraitMethodParser>>
                                            as crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcNonConstTraitMethodParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcNonnullOptimizationGuaranteedParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcNonnullOptimizationGuaranteedParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcNonnullOptimizationGuaranteedParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcNonnullOptimizationGuaranteedParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcNonnullOptimizationGuaranteedParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcNonnullOptimizationGuaranteedParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcNonnullOptimizationGuaranteedParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcNonnullOptimizationGuaranteedParser>>
                                            as crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcNonnullOptimizationGuaranteedParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcNounwindParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<RustcNounwindParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcNounwindParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcNounwindParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcNounwindParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcNounwindParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcNounwindParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcNounwindParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcNounwindParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcOffloadKernelParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<RustcOffloadKernelParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcOffloadKernelParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcOffloadKernelParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcOffloadKernelParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcOffloadKernelParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcOffloadKernelParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcOffloadKernelParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcOffloadKernelParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcParenSugarParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<RustcParenSugarParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcParenSugarParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcParenSugarParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcParenSugarParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcParenSugarParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcParenSugarParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcParenSugarParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcParenSugarParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcPassByValueParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<RustcPassByValueParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcPassByValueParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcPassByValueParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcPassByValueParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcPassByValueParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcPassByValueParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcPassByValueParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcPassByValueParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcPassIndirectlyInNonRusticAbisParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcPassIndirectlyInNonRusticAbisParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcPassIndirectlyInNonRusticAbisParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcPassIndirectlyInNonRusticAbisParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcPassIndirectlyInNonRusticAbisParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcPassIndirectlyInNonRusticAbisParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcPassIndirectlyInNonRusticAbisParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcPassIndirectlyInNonRusticAbisParser>>
                                            as crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcPassIndirectlyInNonRusticAbisParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcPreserveUbChecksParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcPreserveUbChecksParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcPreserveUbChecksParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcPreserveUbChecksParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcPreserveUbChecksParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcPreserveUbChecksParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcPreserveUbChecksParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcPreserveUbChecksParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcPreserveUbChecksParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcProcMacroDeclsParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<RustcProcMacroDeclsParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcProcMacroDeclsParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcProcMacroDeclsParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcProcMacroDeclsParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcProcMacroDeclsParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcProcMacroDeclsParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcProcMacroDeclsParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcProcMacroDeclsParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcPubTransparentParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<RustcPubTransparentParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcPubTransparentParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcPubTransparentParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcPubTransparentParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcPubTransparentParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcPubTransparentParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcPubTransparentParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcPubTransparentParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcReallocatorParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<RustcReallocatorParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcReallocatorParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcReallocatorParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcReallocatorParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcReallocatorParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcReallocatorParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcReallocatorParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcReallocatorParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcRegionsParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<RustcRegionsParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcRegionsParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcRegionsParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcRegionsParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcRegionsParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcRegionsParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcRegionsParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcRegionsParser>> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcShouldNotBeCalledOnConstItemsParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcShouldNotBeCalledOnConstItemsParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcShouldNotBeCalledOnConstItemsParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcShouldNotBeCalledOnConstItemsParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcShouldNotBeCalledOnConstItemsParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcShouldNotBeCalledOnConstItemsParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcShouldNotBeCalledOnConstItemsParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcShouldNotBeCalledOnConstItemsParser>>
                                            as crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcShouldNotBeCalledOnConstItemsParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcSpecializationTraitParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcSpecializationTraitParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcSpecializationTraitParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcSpecializationTraitParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcSpecializationTraitParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcSpecializationTraitParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcSpecializationTraitParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcSpecializationTraitParser>>
                                            as crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcSpecializationTraitParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcStdInternalSymbolParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcStdInternalSymbolParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcStdInternalSymbolParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcStdInternalSymbolParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcStdInternalSymbolParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcStdInternalSymbolParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcStdInternalSymbolParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcStdInternalSymbolParser>>
                                            as crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcStdInternalSymbolParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcStrictCoherenceParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcStrictCoherenceParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcStrictCoherenceParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcStrictCoherenceParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcStrictCoherenceParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcStrictCoherenceParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcStrictCoherenceParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcStrictCoherenceParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcStrictCoherenceParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcTrivialFieldReadsParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcTrivialFieldReadsParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcTrivialFieldReadsParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcTrivialFieldReadsParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcTrivialFieldReadsParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcTrivialFieldReadsParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcTrivialFieldReadsParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcTrivialFieldReadsParser>>
                                            as crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcTrivialFieldReadsParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<RustcUnsafeSpecializationMarkerParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                ->
                                    RefCell<Single<WithoutArgs<RustcUnsafeSpecializationMarkerParser>>> {
                                RefCell::new(<Single<WithoutArgs<RustcUnsafeSpecializationMarkerParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<RustcUnsafeSpecializationMarkerParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcUnsafeSpecializationMarkerParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<RustcUnsafeSpecializationMarkerParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<RustcUnsafeSpecializationMarkerParser>>>::ATTRIBUTES
                        {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<RustcUnsafeSpecializationMarkerParser>>
                                            as crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<RustcUnsafeSpecializationMarkerParser>>
                                            as crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<ThreadLocalParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<ThreadLocalParser>>> {
                                RefCell::new(<Single<WithoutArgs<ThreadLocalParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<ThreadLocalParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<ThreadLocalParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<ThreadLocalParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<ThreadLocalParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<ThreadLocalParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<ThreadLocalParser>> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                {
                    const STATE_OBJECT:
                        ::std::thread::LocalKey<RefCell<Single<WithoutArgs<TrackCallerParser>>>>
                        =
                        {
                            #[inline]
                            fn __rust_std_internal_init_fn()
                                -> RefCell<Single<WithoutArgs<TrackCallerParser>>> {
                                RefCell::new(<Single<WithoutArgs<TrackCallerParser>>>::default())
                            }
                            unsafe {
                                ::std::thread::LocalKey::new(const {
                                            if ::std::mem::needs_drop::<RefCell<Single<WithoutArgs<TrackCallerParser>>>>()
                                                {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<TrackCallerParser>>>,
                                                            ()> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            } else {
                                                |__rust_std_internal_init|
                                                    {
                                                        #[thread_local]
                                                        static __RUST_STD_INTERNAL_VAL:
                                                            ::std::thread::local_impl::LazyStorage<RefCell<Single<WithoutArgs<TrackCallerParser>>>,
                                                            !> =
                                                            ::std::thread::local_impl::LazyStorage::new();
                                                        __RUST_STD_INTERNAL_VAL.get_or_init(__rust_std_internal_init,
                                                            __rust_std_internal_init_fn)
                                                    }
                                            }
                                        })
                            }
                        };
                    for (path, template, accept_fn) in
                        <Single<WithoutArgs<TrackCallerParser>>>::ATTRIBUTES {
                        match accepters.entry(*path) {
                            Entry::Vacant(e) => {
                                e.insert(GroupTypeInnerAccept {
                                        template: *template,
                                        accept_fn: Box::new(|cx, args|
                                                {
                                                    STATE_OBJECT.with_borrow_mut(|s| { accept_fn(s, cx, args) })
                                                }),
                                        safety: <Single<WithoutArgs<TrackCallerParser>> as
                                            crate::attributes::AttributeParser>::SAFETY,
                                        allowed_targets: <Single<WithoutArgs<TrackCallerParser>> as
                                            crate::attributes::AttributeParser>::ALLOWED_TARGETS,
                                        finalizer: |cx|
                                            { let state = STATE_OBJECT.take(); state.finalize(cx) },
                                    });
                            }
                            Entry::Occupied(_) => {
                                ::core::panicking::panic_fmt(format_args!("Attribute {0:?} has multiple accepters",
                                        path));
                            }
                        }
                    }
                }
                GroupTypeInner { accepters }
            });attribute_parsers!(
132    pub(crate) static ATTRIBUTE_PARSERS = [
133        // tidy-alphabetical-start
134        BodyStabilityParser,
135        ConfusablesParser,
136        ConstStabilityParser,
137        DocParser,
138        MacroUseParser,
139        NakedParser,
140        OnConstParser,
141        OnMoveParser,
142        OnUnimplementedParser,
143        OnUnknownParser,
144        OnUnmatchArgsParser,
145        RustcAlignParser,
146        RustcAlignStaticParser,
147        RustcCguTestAttributeParser,
148        StabilityParser,
149        UsedParser,
150        // tidy-alphabetical-end
151
152        // tidy-alphabetical-start
153        Combine<AllowInternalUnstableParser>,
154        Combine<CrateTypeParser>,
155        Combine<DebuggerViualizerParser>,
156        Combine<FeatureParser>,
157        Combine<ForceTargetFeatureParser>,
158        Combine<LinkParser>,
159        Combine<RegisterToolParser>,
160        Combine<ReprParser>,
161        Combine<RustcAllowConstFnUnstableParser>,
162        Combine<RustcCleanParser>,
163        Combine<RustcDumpLayoutParser>,
164        Combine<RustcMirParser>,
165        Combine<RustcThenThisWouldNeedParser>,
166        Combine<TargetFeatureParser>,
167        Combine<UnstableFeatureBoundParser>,
168        Combine<UnstableRemovedParser>,
169        // tidy-alphabetical-end
170
171        // tidy-alphabetical-start
172        Single<CfiEncodingParser>,
173        Single<CollapseDebugInfoParser>,
174        Single<CoverageParser>,
175        Single<CrateNameParser>,
176        Single<CustomMirParser>,
177        Single<DeprecatedParser>,
178        Single<DoNotRecommendParser>,
179        Single<ExportNameParser>,
180        Single<IgnoreParser>,
181        Single<InlineParser>,
182        Single<InstructionSetParser>,
183        Single<LangParser>,
184        Single<LinkNameParser>,
185        Single<LinkOrdinalParser>,
186        Single<LinkSectionParser>,
187        Single<LinkageParser>,
188        Single<MacroExportParser>,
189        Single<MoveSizeLimitParser>,
190        Single<MustNotSuspendParser>,
191        Single<MustUseParser>,
192        Single<OptimizeParser>,
193        Single<PatchableFunctionEntryParser>,
194        Single<PathAttributeParser>,
195        Single<PatternComplexityLimitParser>,
196        Single<ProcMacroDeriveParser>,
197        Single<RecursionLimitParser>,
198        Single<ReexportTestHarnessMainParser>,
199        Single<RustcAbiParser>,
200        Single<RustcAllocatorZeroedVariantParser>,
201        Single<RustcAutodiffParser>,
202        Single<RustcBuiltinMacroParser>,
203        Single<RustcDeprecatedSafe2024Parser>,
204        Single<RustcDiagnosticItemParser>,
205        Single<RustcDocPrimitiveParser>,
206        Single<RustcDummyParser>,
207        Single<RustcDumpDefPathParser>,
208        Single<RustcDumpSymbolNameParser>,
209        Single<RustcForceInlineParser>,
210        Single<RustcIfThisChangedParser>,
211        Single<RustcLayoutScalarValidRangeEndParser>,
212        Single<RustcLayoutScalarValidRangeStartParser>,
213        Single<RustcLegacyConstGenericsParser>,
214        Single<RustcLintOptDenyFieldAccessParser>,
215        Single<RustcMacroTransparencyParser>,
216        Single<RustcMustImplementOneOfParser>,
217        Single<RustcNeverTypeOptionsParser>,
218        Single<RustcObjcClassParser>,
219        Single<RustcObjcSelectorParser>,
220        Single<RustcReservationImplParser>,
221        Single<RustcScalableVectorParser>,
222        Single<RustcSimdMonomorphizeLaneLimitParser>,
223        Single<RustcSkipDuringMethodDispatchParser>,
224        Single<RustcTestMarkerParser>,
225        Single<SanitizeParser>,
226        Single<ShouldPanicParser>,
227        Single<TestRunnerParser>,
228        Single<TypeLengthLimitParser>,
229        Single<WindowsSubsystemParser>,
230        Single<WithoutArgs<AllowInternalUnsafeParser>>,
231        Single<WithoutArgs<AutomaticallyDerivedParser>>,
232        Single<WithoutArgs<ColdParser>>,
233        Single<WithoutArgs<CompilerBuiltinsParser>>,
234        Single<WithoutArgs<ConstContinueParser>>,
235        Single<WithoutArgs<CoroutineParser>>,
236        Single<WithoutArgs<DefaultLibAllocatorParser>>,
237        Single<WithoutArgs<ExportStableParser>>,
238        Single<WithoutArgs<FfiConstParser>>,
239        Single<WithoutArgs<FfiPureParser>>,
240        Single<WithoutArgs<FundamentalParser>>,
241        Single<WithoutArgs<LoopMatchParser>>,
242        Single<WithoutArgs<MacroEscapeParser>>,
243        Single<WithoutArgs<MarkerParser>>,
244        Single<WithoutArgs<MayDangleParser>>,
245        Single<WithoutArgs<NeedsAllocatorParser>>,
246        Single<WithoutArgs<NeedsPanicRuntimeParser>>,
247        Single<WithoutArgs<NoBuiltinsParser>>,
248        Single<WithoutArgs<NoCoreParser>>,
249        Single<WithoutArgs<NoImplicitPreludeParser>>,
250        Single<WithoutArgs<NoLinkParser>>,
251        Single<WithoutArgs<NoMainParser>>,
252        Single<WithoutArgs<NoMangleParser>>,
253        Single<WithoutArgs<NoStdParser>>,
254        Single<WithoutArgs<NonExhaustiveParser>>,
255        Single<WithoutArgs<PanicHandlerParser>>,
256        Single<WithoutArgs<PanicRuntimeParser>>,
257        Single<WithoutArgs<PinV2Parser>>,
258        Single<WithoutArgs<PreludeImportParser>>,
259        Single<WithoutArgs<ProcMacroAttributeParser>>,
260        Single<WithoutArgs<ProcMacroParser>>,
261        Single<WithoutArgs<ProfilerRuntimeParser>>,
262        Single<WithoutArgs<RustcAllocatorParser>>,
263        Single<WithoutArgs<RustcAllocatorZeroedParser>>,
264        Single<WithoutArgs<RustcAllowIncoherentImplParser>>,
265        Single<WithoutArgs<RustcAsPtrParser>>,
266        Single<WithoutArgs<RustcCaptureAnalysisParser>>,
267        Single<WithoutArgs<RustcCoherenceIsCoreParser>>,
268        Single<WithoutArgs<RustcCoinductiveParser>>,
269        Single<WithoutArgs<RustcConstStableIndirectParser>>,
270        Single<WithoutArgs<RustcConversionSuggestionParser>>,
271        Single<WithoutArgs<RustcDeallocatorParser>>,
272        Single<WithoutArgs<RustcDelayedBugFromInsideQueryParser>>,
273        Single<WithoutArgs<RustcDenyExplicitImplParser>>,
274        Single<WithoutArgs<RustcDoNotConstCheckParser>>,
275        Single<WithoutArgs<RustcDumpDefParentsParser>>,
276        Single<WithoutArgs<RustcDumpHiddenTypeOfOpaquesParser>>,
277        Single<WithoutArgs<RustcDumpInferredOutlivesParser>>,
278        Single<WithoutArgs<RustcDumpItemBoundsParser>>,
279        Single<WithoutArgs<RustcDumpObjectLifetimeDefaultsParser>>,
280        Single<WithoutArgs<RustcDumpPredicatesParser>>,
281        Single<WithoutArgs<RustcDumpUserArgsParser>>,
282        Single<WithoutArgs<RustcDumpVariancesOfOpaquesParser>>,
283        Single<WithoutArgs<RustcDumpVariancesParser>>,
284        Single<WithoutArgs<RustcDumpVtableParser>>,
285        Single<WithoutArgs<RustcDynIncompatibleTraitParser>>,
286        Single<WithoutArgs<RustcEffectiveVisibilityParser>>,
287        Single<WithoutArgs<RustcEiiForeignItemParser>>,
288        Single<WithoutArgs<RustcEvaluateWhereClausesParser>>,
289        Single<WithoutArgs<RustcExhaustiveParser>>,
290        Single<WithoutArgs<RustcHasIncoherentInherentImplsParser>>,
291        Single<WithoutArgs<RustcInheritOverflowChecksParser>>,
292        Single<WithoutArgs<RustcInsignificantDtorParser>>,
293        Single<WithoutArgs<RustcIntrinsicConstStableIndirectParser>>,
294        Single<WithoutArgs<RustcIntrinsicParser>>,
295        Single<WithoutArgs<RustcLintOptTyParser>>,
296        Single<WithoutArgs<RustcLintQueryInstabilityParser>>,
297        Single<WithoutArgs<RustcLintUntrackedQueryInformationParser>>,
298        Single<WithoutArgs<RustcMainParser>>,
299        Single<WithoutArgs<RustcNeverReturnsNullPtrParser>>,
300        Single<WithoutArgs<RustcNoImplicitAutorefsParser>>,
301        Single<WithoutArgs<RustcNoImplicitBoundsParser>>,
302        Single<WithoutArgs<RustcNoMirInlineParser>>,
303        Single<WithoutArgs<RustcNoWritableParser>>,
304        Single<WithoutArgs<RustcNonConstTraitMethodParser>>,
305        Single<WithoutArgs<RustcNonnullOptimizationGuaranteedParser>>,
306        Single<WithoutArgs<RustcNounwindParser>>,
307        Single<WithoutArgs<RustcOffloadKernelParser>>,
308        Single<WithoutArgs<RustcParenSugarParser>>,
309        Single<WithoutArgs<RustcPassByValueParser>>,
310        Single<WithoutArgs<RustcPassIndirectlyInNonRusticAbisParser>>,
311        Single<WithoutArgs<RustcPreserveUbChecksParser>>,
312        Single<WithoutArgs<RustcProcMacroDeclsParser>>,
313        Single<WithoutArgs<RustcPubTransparentParser>>,
314        Single<WithoutArgs<RustcReallocatorParser>>,
315        Single<WithoutArgs<RustcRegionsParser>>,
316        Single<WithoutArgs<RustcShouldNotBeCalledOnConstItemsParser>>,
317        Single<WithoutArgs<RustcSpecializationTraitParser>>,
318        Single<WithoutArgs<RustcStdInternalSymbolParser>>,
319        Single<WithoutArgs<RustcStrictCoherenceParser>>,
320        Single<WithoutArgs<RustcTrivialFieldReadsParser>>,
321        Single<WithoutArgs<RustcUnsafeSpecializationMarkerParser>>,
322        Single<WithoutArgs<ThreadLocalParser>>,
323        Single<WithoutArgs<TrackCallerParser>>,
324        // tidy-alphabetical-end
325    ];
326);
327
328/// Context given to every attribute parser when accepting
329///
330/// Gives [`AttributeParser`]s enough information to create errors, for example.
331pub struct AcceptContext<'f, 'sess> {
332    pub(crate) shared: SharedContext<'f, 'sess>,
333
334    /// The outer span of the attribute currently being parsed
335    ///
336    /// ```none
337    /// #[attribute(...)]
338    /// ^^^^^^^^^^^^^^^^^ outer span
339    /// ```
340    /// For attributes in `cfg_attr`, the outer span and inner spans are equal.
341    pub(crate) attr_span: Span,
342    /// The inner span of the attribute currently being parsed.
343    ///
344    /// ```none
345    /// #[attribute(...)]
346    ///   ^^^^^^^^^^^^^^  inner span
347    /// ```
348    pub(crate) inner_span: Span,
349
350    /// Whether it is an inner or outer attribute.
351    pub(crate) attr_style: AttrStyle,
352
353    /// A description of the thing we are parsing using this attribute parser.
354    /// We are not only using these parsers for attributes, but also for macros such as the `cfg!()` macro.
355    pub(crate) parsed_description: ParsedDescription,
356
357    /// The expected structure of the attribute.
358    ///
359    /// Used in reporting errors to give a hint to users what the attribute *should* look like.
360    pub(crate) template: &'f AttributeTemplate,
361
362    /// The name of the attribute we're currently accepting.
363    pub(crate) attr_path: AttrPath,
364}
365
366impl<'f, 'sess: 'f> SharedContext<'f, 'sess> {
367    pub(crate) fn emit_err(&self, diag: impl for<'x> Diagnostic<'x>) -> ErrorGuaranteed {
368        self.cx.emit_err(diag)
369    }
370
371    /// Emit a lint. This method is somewhat special, since lints emitted during attribute parsing
372    /// must be delayed until after HIR is built. This method will take care of the details of
373    /// that.
374    pub(crate) fn emit_lint(
375        &mut self,
376        lint: &'static Lint,
377        diagnostic: impl for<'x> Diagnostic<'x, ()> + DynSend + DynSync + 'static,
378        span: impl Into<MultiSpan>,
379    ) {
380        self.emit_lint_inner(
381            lint,
382            EmitAttribute(Box::new(move |dcx, level, _| diagnostic.into_diag(dcx, level))),
383            span,
384        );
385    }
386
387    pub(crate) fn emit_lint_with_sess<
388        F: for<'a> FnOnce(DiagCtxtHandle<'a>, Level, &Session) -> Diag<'a, ()>
389            + DynSend
390            + DynSync
391            + 'static,
392    >(
393        &mut self,
394        lint: &'static Lint,
395        callback: F,
396        span: impl Into<MultiSpan>,
397    ) {
398        self.emit_lint_inner(lint, EmitAttribute(Box::new(callback)), span);
399    }
400
401    fn emit_lint_inner(
402        &mut self,
403        lint: &'static Lint,
404        kind: EmitAttribute,
405        span: impl Into<MultiSpan>,
406    ) {
407        if !#[allow(non_exhaustive_omitted_patterns)] match self.should_emit {
    ShouldEmit::ErrorsAndLints { .. } | ShouldEmit::EarlyFatal {
        also_emit_lints: true } => true,
    _ => false,
}matches!(
408            self.should_emit,
409            ShouldEmit::ErrorsAndLints { .. } | ShouldEmit::EarlyFatal { also_emit_lints: true }
410        ) {
411            return;
412        }
413        (self.emit_lint)(LintId::of(lint), span.into(), kind);
414    }
415
416    pub(crate) fn warn_unused_duplicate(&mut self, used_span: Span, unused_span: Span) {
417        self.emit_lint(
418            rustc_session::lint::builtin::UNUSED_ATTRIBUTES,
419            rustc_errors::lints::UnusedDuplicate {
420                this: unused_span,
421                other: used_span,
422                warning: false,
423            },
424            unused_span,
425        )
426    }
427
428    pub(crate) fn warn_unused_duplicate_future_error(
429        &mut self,
430        used_span: Span,
431        unused_span: Span,
432    ) {
433        self.emit_lint(
434            rustc_session::lint::builtin::UNUSED_ATTRIBUTES,
435            rustc_errors::lints::UnusedDuplicate {
436                this: unused_span,
437                other: used_span,
438                warning: true,
439            },
440            unused_span,
441        )
442    }
443}
444
445impl<'f, 'sess: 'f> AcceptContext<'f, 'sess> {
446    pub(crate) fn adcx(&mut self) -> AttributeDiagnosticContext<'_, 'f, 'sess> {
447        AttributeDiagnosticContext { ctx: self, custom_suggestions: Vec::new() }
448    }
449
450    /// Asserts that this MetaItem is a list that contains a single element. Emits an error and
451    /// returns `None` if it is not the case.
452    ///
453    /// Some examples:
454    ///
455    /// - In `#[allow(warnings)]`, `warnings` is returned
456    /// - In `#[cfg_attr(docsrs, doc = "foo")]`, `None` is returned, "expected a single argument
457    ///   here" is emitted.
458    /// - In `#[cfg()]`, `None` is returned, "expected an argument here" is emitted.
459    ///
460    /// The provided span is used as a fallback for diagnostic generation in case `arg` does not
461    /// contain any. It should be the span of the node that contains `arg`.
462    pub(crate) fn expect_single_element_list<'arg>(
463        &mut self,
464        arg: &'arg ArgParser,
465        span: Span,
466    ) -> Option<&'arg MetaItemOrLitParser> {
467        let ArgParser::List(l) = arg else {
468            self.adcx().expected_list(span, arg);
469            return None;
470        };
471
472        let Some(single) = l.as_single() else {
473            self.adcx().expected_single_argument(l.span, l.len());
474            return None;
475        };
476
477        Some(single)
478    }
479
480    /// Asserts that an [`ArgParser`] is a list and returns it, or emits an error and returns
481    /// `None`.
482    ///
483    /// Some examples:
484    ///
485    /// - `#[allow(clippy::complexity)]`: `(clippy::complexity)` is a list
486    /// - `#[rustfmt::skip::macros(target_macro_name)]`: `(target_macro_name)` is a list
487    ///
488    /// This is a higher-level (and harder to misuse) wrapper over [`ArgParser::as_list`] that
489    /// allows using `?` when the attribute parsing function allows it. You may still want to use
490    /// [`ArgParser::as_list`] for the following reasons:
491    ///
492    /// - You want to emit your own diagnostics (for instance, with [`SharedContext::emit_err`]).
493    /// - The attribute can be parsed in multiple ways and it does not make sense to emit an error.
494    pub(crate) fn expect_list<'arg>(
495        &mut self,
496        args: &'arg ArgParser,
497        span: Span,
498    ) -> Option<&'arg MetaItemListParser> {
499        let list = args.as_list();
500        if list.is_none() {
501            self.adcx().expected_list(span, args);
502        }
503        list
504    }
505
506    /// Asserts that a [`MetaItemListParser`] contains a single element and returns it, or emits an
507    /// error and returns `None`.
508    ///
509    /// This is a higher-level (and harder to misuse) wrapper over [`MetaItemListParser::as_single`],
510    /// that allows using `?` to early return. You may still want to use
511    /// [`MetaItemListParser::as_single`] for the following reasons:
512    ///
513    /// - You want to emit your own diagnostics (for instance, with [`SharedContext::emit_err`]).
514    /// - The attribute can be parsed in multiple ways and it does not make sense to emit an error.
515    pub(crate) fn expect_single<'arg>(
516        &mut self,
517        list: &'arg MetaItemListParser,
518    ) -> Option<&'arg MetaItemOrLitParser> {
519        let single = list.as_single();
520        if single.is_none() {
521            self.adcx().expected_single_argument(list.span, list.len());
522        }
523        single
524    }
525
526    /// Asserts that a node is a name-value pair.
527    ///
528    /// Some examples:
529    ///
530    /// - `#[clippy::cyclomatic_complexity = "100"]`: `clippy::cyclomatic_complexity = "100"` is a
531    ///   name-value pair, where the name is a path (`clippy::cyclomatic_complexity`). You already
532    ///   checked the path to get an `ArgParser`, so this method will effectively only assert that
533    ///   the `= "100"` is there and returns it.
534    /// - `#[doc = "hello"]`: `doc = "hello`  is also a name value pair. `= "hello"` is returned.
535    /// - `#[serde(rename_all = "lowercase")]`: `rename_all = "lowercase"` is a name value pair,
536    ///   where the name is an identifier (`rename_all`) and the value is a literal (`"lowercase"`).
537    ///   This returns both the path and the value.
538    ///
539    /// `arg` must be a reference to any node that may contain a name-value pair, that is:
540    ///
541    /// - [`MetaItemOrLitParser`],
542    /// - [`MetaItemParser`],
543    /// - [`ArgParser`].
544    ///
545    /// `name` can be set to `Some` for a nicer error message talking about the specific name that
546    /// was found lacking a value.
547    ///
548    /// This is a higher-level (and harder to misuse) wrapper over multiple `as_` methods in the
549    /// [`parser`][crate::parser] module. You may still want to use the lower-level methods for the
550    /// following reasons:
551    ///
552    /// - You want to emit your own diagnostics (for instance, with [`SharedContext::emit_err`]).
553    /// - The attribute can be parsed in multiple ways and it does not make sense to emit an error.
554    pub(crate) fn expect_name_value<'arg, Arg>(
555        &mut self,
556        arg: &'arg Arg,
557        span: Span,
558        name: Option<Symbol>,
559    ) -> Option<Arg::Output<'arg>>
560    where
561        Arg: ExpectNameValue,
562    {
563        arg.expect_name_value(self, span, name)
564    }
565
566    /// Assert that an [`ArgParser`] has no args, or emits an error and return `None`.
567    pub(crate) fn expect_no_args<'arg>(&mut self, arg: &'arg ArgParser) -> Option<()> {
568        if let Err(span) = arg.as_no_args() {
569            self.adcx().expected_no_args(span);
570            return None;
571        }
572
573        Some(())
574    }
575}
576
577pub(crate) trait ExpectNameValue {
578    type Output<'a>
579    where
580        Self: 'a;
581
582    fn expect_name_value<'a, 'f, 'sess>(
583        &'a self,
584        cx: &mut AcceptContext<'f, 'sess>,
585        span: Span,
586        name: Option<Symbol>,
587    ) -> Option<Self::Output<'a>>;
588}
589
590impl ExpectNameValue for MetaItemOrLitParser {
591    type Output<'a> = (Ident, &'a NameValueParser);
592
593    fn expect_name_value<'a, 'f, 'sess>(
594        &'a self,
595        cx: &mut AcceptContext<'f, 'sess>,
596        span: Span,
597        name: Option<Symbol>,
598    ) -> Option<Self::Output<'a>> {
599        let Some(meta_item) = self.meta_item() else {
600            cx.adcx().expected_name_value(self.span(), name);
601            return None;
602        };
603
604        meta_item.expect_name_value(cx, span, name)
605    }
606}
607
608impl ExpectNameValue for MetaItemParser {
609    type Output<'a> = (Ident, &'a NameValueParser);
610
611    fn expect_name_value<'a, 'f, 'sess>(
612        &'a self,
613        cx: &mut AcceptContext<'f, 'sess>,
614        _span: Span, // Not needed: `MetaItemOrLitParser` carry its own span.
615        name: Option<Symbol>,
616    ) -> Option<Self::Output<'a>> {
617        let word = self.path().word();
618        let arg = self.args().as_name_value();
619
620        if word.is_none() {
621            cx.adcx().expected_identifier(self.path().span());
622        }
623
624        if arg.is_none() {
625            cx.adcx().expected_name_value(self.span(), name);
626        }
627
628        let Some((word, arg)) = word.zip(arg) else {
629            return None;
630        };
631
632        Some((word, arg))
633    }
634}
635
636impl ExpectNameValue for ArgParser {
637    type Output<'a> = &'a NameValueParser;
638
639    fn expect_name_value<'a, 'f, 'sess>(
640        &'a self,
641        cx: &mut AcceptContext<'f, 'sess>,
642        span: Span,
643        name: Option<Symbol>,
644    ) -> Option<Self::Output<'a>> {
645        let Some(nv) = self.as_name_value() else {
646            cx.adcx().expected_name_value(span, name);
647            return None;
648        };
649
650        Some(nv)
651    }
652}
653
654impl<'f, 'sess> Deref for AcceptContext<'f, 'sess> {
655    type Target = SharedContext<'f, 'sess>;
656
657    fn deref(&self) -> &Self::Target {
658        &self.shared
659    }
660}
661
662impl<'f, 'sess> DerefMut for AcceptContext<'f, 'sess> {
663    fn deref_mut(&mut self) -> &mut Self::Target {
664        &mut self.shared
665    }
666}
667
668/// Context given to every attribute parser during finalization.
669///
670/// Gives [`AttributeParser`](crate::attributes::AttributeParser)s enough information to create
671/// errors, for example.
672pub struct SharedContext<'p, 'sess> {
673    /// The parse context, gives access to the session and the
674    /// diagnostics context.
675    pub(crate) cx: &'p mut AttributeParser<'sess>,
676    /// The span of the syntactical component this attribute was applied to
677    pub(crate) target_span: Span,
678    pub(crate) target: rustc_hir::Target,
679
680    pub(crate) emit_lint: &'p mut dyn FnMut(LintId, MultiSpan, EmitAttribute),
681}
682
683/// Context given to every attribute parser during finalization.
684///
685/// Gives [`AttributeParser`](crate::attributes::AttributeParser)s enough information to create
686/// errors, for example.
687pub(crate) struct FinalizeContext<'p, 'sess> {
688    pub(crate) shared: SharedContext<'p, 'sess>,
689
690    /// A list of all attribute on this syntax node.
691    ///
692    /// Useful for compatibility checks with other attributes in [`finalize`](crate::attributes::AttributeParser::finalize)
693    ///
694    /// Usually, you should use normal attribute parsing logic instead,
695    /// especially when making a *denylist* of other attributes.
696    pub(crate) all_attrs: &'p [RefPathParser<'p>],
697}
698
699impl<'p, 'sess: 'p> Deref for FinalizeContext<'p, 'sess> {
700    type Target = SharedContext<'p, 'sess>;
701
702    fn deref(&self) -> &Self::Target {
703        &self.shared
704    }
705}
706
707impl<'p, 'sess: 'p> DerefMut for FinalizeContext<'p, 'sess> {
708    fn deref_mut(&mut self) -> &mut Self::Target {
709        &mut self.shared
710    }
711}
712
713impl<'p, 'sess: 'p> Deref for SharedContext<'p, 'sess> {
714    type Target = AttributeParser<'sess>;
715
716    fn deref(&self) -> &Self::Target {
717        self.cx
718    }
719}
720
721impl<'p, 'sess: 'p> DerefMut for SharedContext<'p, 'sess> {
722    fn deref_mut(&mut self) -> &mut Self::Target {
723        self.cx
724    }
725}
726
727#[derive(#[automatically_derived]
impl ::core::cmp::PartialEq for OmitDoc {
    #[inline]
    fn eq(&self, other: &OmitDoc) -> bool {
        let __self_discr = ::core::intrinsics::discriminant_value(self);
        let __arg1_discr = ::core::intrinsics::discriminant_value(other);
        __self_discr == __arg1_discr
    }
}PartialEq, #[automatically_derived]
impl ::core::clone::Clone for OmitDoc {
    #[inline]
    fn clone(&self) -> OmitDoc { *self }
}Clone, #[automatically_derived]
impl ::core::marker::Copy for OmitDoc { }Copy, #[automatically_derived]
impl ::core::fmt::Debug for OmitDoc {
    #[inline]
    fn fmt(&self, f: &mut ::core::fmt::Formatter) -> ::core::fmt::Result {
        ::core::fmt::Formatter::write_str(f,
            match self {
                OmitDoc::Lower => "Lower",
                OmitDoc::Skip => "Skip",
            })
    }
}Debug)]
728pub enum OmitDoc {
729    Lower,
730    Skip,
731}
732
733#[derive(#[automatically_derived]
impl ::core::marker::Copy for ShouldEmit { }Copy, #[automatically_derived]
impl ::core::clone::Clone for ShouldEmit {
    #[inline]
    fn clone(&self) -> ShouldEmit {
        let _: ::core::clone::AssertParamIsClone<bool>;
        let _: ::core::clone::AssertParamIsClone<Recovery>;
        *self
    }
}Clone, #[automatically_derived]
impl ::core::fmt::Debug for ShouldEmit {
    #[inline]
    fn fmt(&self, f: &mut ::core::fmt::Formatter) -> ::core::fmt::Result {
        match self {
            ShouldEmit::EarlyFatal { also_emit_lints: __self_0 } =>
                ::core::fmt::Formatter::debug_struct_field1_finish(f,
                    "EarlyFatal", "also_emit_lints", &__self_0),
            ShouldEmit::ErrorsAndLints { recovery: __self_0 } =>
                ::core::fmt::Formatter::debug_struct_field1_finish(f,
                    "ErrorsAndLints", "recovery", &__self_0),
            ShouldEmit::Nothing =>
                ::core::fmt::Formatter::write_str(f, "Nothing"),
        }
    }
}Debug)]
734pub enum ShouldEmit {
735    /// The operations will emit errors, and lints, and errors are fatal.
736    ///
737    /// Only relevant when early parsing, in late parsing equivalent to `ErrorsAndLints`.
738    /// Late parsing is never fatal, and instead tries to emit as many diagnostics as possible.
739    EarlyFatal { also_emit_lints: bool },
740    /// The operation will emit errors and lints.
741    /// This is usually what you need.
742    ErrorsAndLints {
743        /// Whether [`ArgParser`] will attempt to recover from errors.
744        ///
745        /// Whether it is allowed to recover from bad input (like an invalid literal). Setting
746        /// this to `Forbidden` will instead return early, and not raise errors except at the top
747        /// level (in [`ArgParser::from_attr_args`]).
748        recovery: Recovery,
749    },
750    /// The operation will *not* emit errors and lints.
751    ///
752    /// The parser can still call `delay_bug`, so you *must* ensure that this operation will also be
753    /// called with `ShouldEmit::ErrorsAndLints`.
754    Nothing,
755}
756
757impl ShouldEmit {
758    pub(crate) fn emit_err(&self, diag: Diag<'_>) -> ErrorGuaranteed {
759        match self {
760            ShouldEmit::EarlyFatal { .. } if diag.level() == Level::DelayedBug => diag.emit(),
761            ShouldEmit::EarlyFatal { .. } => diag.upgrade_to_fatal().emit(),
762            ShouldEmit::ErrorsAndLints { .. } => diag.emit(),
763            ShouldEmit::Nothing => diag.delay_as_bug(),
764        }
765    }
766}
767
768pub(crate) struct AttributeDiagnosticContext<'a, 'f, 'sess> {
769    ctx: &'a mut AcceptContext<'f, 'sess>,
770    custom_suggestions: Vec<Suggestion>,
771}
772
773impl<'a, 'f, 'sess: 'f> AttributeDiagnosticContext<'a, 'f, 'sess> {
774    fn emit_parse_error(
775        &mut self,
776        span: Span,
777        reason: AttributeParseErrorReason<'_>,
778    ) -> ErrorGuaranteed {
779        let suggestions = if !self.custom_suggestions.is_empty() {
780            AttributeParseErrorSuggestions::CreatedByParser(mem::take(&mut self.custom_suggestions))
781        } else {
782            AttributeParseErrorSuggestions::CreatedByTemplate(self.template_suggestions())
783        };
784
785        self.emit_err(AttributeParseError {
786            span,
787            attr_span: self.attr_span,
788            template: self.template.clone(),
789            path: self.attr_path.clone(),
790            description: self.parsed_description,
791            reason,
792            suggestions,
793        })
794    }
795
796    /// Adds a custom suggestion to the diagnostic. This also prevents the default (template-based)
797    /// suggestion to be emitted.
798    pub(crate) fn push_suggestion(&mut self, msg: String, span: Span, code: String) -> &mut Self {
799        self.custom_suggestions.push(Suggestion { msg, sp: span, code });
800        self
801    }
802
803    pub(crate) fn template_suggestions(&self) -> Vec<String> {
804        let style = match self.parsed_description {
805            // If the outer and inner spans are equal, we are parsing an embedded attribute
806            ParsedDescription::Attribute if self.attr_span == self.inner_span => {
807                AttrSuggestionStyle::EmbeddedAttribute
808            }
809            ParsedDescription::Attribute => AttrSuggestionStyle::Attribute(self.attr_style),
810            ParsedDescription::Macro => AttrSuggestionStyle::Macro,
811        };
812
813        self.template.suggestions(style, &self.attr_path)
814    }
815}
816
817/// Helpers that can be used to generate errors during attribute parsing.
818impl<'a, 'f, 'sess: 'f> AttributeDiagnosticContext<'a, 'f, 'sess> {
819    pub(crate) fn expected_integer_literal_in_range(
820        &mut self,
821        span: Span,
822        lower_bound: isize,
823        upper_bound: isize,
824    ) -> ErrorGuaranteed {
825        self.emit_parse_error(
826            span,
827            AttributeParseErrorReason::ExpectedIntegerLiteralInRange { lower_bound, upper_bound },
828        )
829    }
830
831    /// The provided span is used as a fallback in case `args` does not contain any. It should be
832    /// the span of the node that contains `args`.
833    pub(crate) fn expected_list(&mut self, span: Span, args: &ArgParser) -> ErrorGuaranteed {
834        let span = match args {
835            ArgParser::NoArgs => span,
836            ArgParser::List(list) => list.span,
837            ArgParser::NameValue(nv) => nv.args_span(),
838        };
839        self.emit_parse_error(span, AttributeParseErrorReason::ExpectedList)
840    }
841
842    pub(crate) fn expected_list_with_num_args_or_more(
843        &mut self,
844        args: usize,
845        span: Span,
846    ) -> ErrorGuaranteed {
847        self.emit_parse_error(
848            span,
849            AttributeParseErrorReason::ExpectedListWithNumArgsOrMore { args },
850        )
851    }
852
853    pub(crate) fn expected_list_or_no_args(&mut self, span: Span) -> ErrorGuaranteed {
854        self.emit_parse_error(span, AttributeParseErrorReason::ExpectedListOrNoArgs)
855    }
856
857    pub(crate) fn expected_nv_or_no_args(&mut self, span: Span) -> ErrorGuaranteed {
858        self.emit_parse_error(span, AttributeParseErrorReason::ExpectedNameValueOrNoArgs)
859    }
860
861    pub(crate) fn expected_non_empty_string_literal(&mut self, span: Span) -> ErrorGuaranteed {
862        self.emit_parse_error(span, AttributeParseErrorReason::ExpectedNonEmptyStringLiteral)
863    }
864
865    pub(crate) fn expected_no_args(&mut self, span: Span) -> ErrorGuaranteed {
866        self.emit_parse_error(span, AttributeParseErrorReason::ExpectedNoArgs)
867    }
868
869    /// Emit an error that a `name` was expected here
870    pub(crate) fn expected_identifier(&mut self, span: Span) -> ErrorGuaranteed {
871        self.emit_parse_error(span, AttributeParseErrorReason::ExpectedIdentifier)
872    }
873
874    /// Emit an error that a `name = value` pair was expected at this span. The symbol can be given for
875    /// a nicer error message talking about the specific name that was found lacking a value.
876    fn expected_name_value(&mut self, span: Span, name: Option<Symbol>) -> ErrorGuaranteed {
877        self.emit_parse_error(span, AttributeParseErrorReason::ExpectedNameValue(name))
878    }
879
880    /// Emit an error that a `name = value` argument is missing in a list of name-value pairs.
881    pub(crate) fn missing_name_value(&mut self, span: Span, name: Symbol) -> ErrorGuaranteed {
882        self.emit_parse_error(span, AttributeParseErrorReason::MissingNameValue(name))
883    }
884
885    /// Emit an error that a `name = value` pair was found where that name was already seen.
886    pub(crate) fn duplicate_key(&mut self, span: Span, key: Symbol) -> ErrorGuaranteed {
887        self.emit_parse_error(span, AttributeParseErrorReason::DuplicateKey(key))
888    }
889
890    /// An error that should be emitted when a [`MetaItemOrLitParser`]
891    /// was expected *not* to be a literal, but instead a meta item.
892    pub(crate) fn expected_not_literal(&mut self, span: Span) -> ErrorGuaranteed {
893        self.emit_parse_error(span, AttributeParseErrorReason::ExpectedNotLiteral)
894    }
895
896    /// Signals that we expected exactly one argument and that we got either zero or two or more.
897    /// The `provided_arguments` argument allows distinguishing between "expected an argument here"
898    /// (when zero arguments are provided) and "expect a single argument here" (when two or more
899    /// arguments are provided).
900    pub(crate) fn expected_single_argument(
901        &mut self,
902        span: Span,
903        provided_arguments: usize,
904    ) -> ErrorGuaranteed {
905        let reason = if provided_arguments == 0 {
906            AttributeParseErrorReason::ExpectedArgument
907        } else {
908            AttributeParseErrorReason::ExpectedSingleArgument
909        };
910
911        self.emit_parse_error(span, reason)
912    }
913
914    pub(crate) fn expected_at_least_one_argument(&mut self, span: Span) -> ErrorGuaranteed {
915        self.emit_parse_error(span, AttributeParseErrorReason::ExpectedAtLeastOneArgument)
916    }
917
918    /// Produces an error along the lines of `expected one of [foo, meow]`
919    pub(crate) fn expected_specific_argument(
920        &mut self,
921        span: Span,
922        possibilities: &[Symbol],
923    ) -> ErrorGuaranteed {
924        self.emit_parse_error(
925            span,
926            AttributeParseErrorReason::ExpectedSpecificArgument {
927                possibilities,
928                strings: false,
929                list: false,
930            },
931        )
932    }
933
934    /// Produces an error along the lines of `expected one of [foo, meow] as an argument`.
935    /// i.e. slightly different wording to [`expected_specific_argument`](Self::expected_specific_argument).
936    pub(crate) fn expected_specific_argument_and_list(
937        &mut self,
938        span: Span,
939        possibilities: &[Symbol],
940    ) -> ErrorGuaranteed {
941        self.emit_parse_error(
942            span,
943            AttributeParseErrorReason::ExpectedSpecificArgument {
944                possibilities,
945                strings: false,
946                list: true,
947            },
948        )
949    }
950
951    /// produces an error along the lines of `expected one of ["foo", "meow"]`
952    pub(crate) fn expected_specific_argument_strings(
953        &mut self,
954        span: Span,
955        possibilities: &[Symbol],
956    ) -> ErrorGuaranteed {
957        self.emit_parse_error(
958            span,
959            AttributeParseErrorReason::ExpectedSpecificArgument {
960                possibilities,
961                strings: true,
962                list: false,
963            },
964        )
965    }
966
967    pub(crate) fn warn_empty_attribute(&mut self, span: Span) {
968        let attr_path = self.attr_path.to_string();
969        let valid_without_list = self.template.word;
970        self.emit_lint(
971            rustc_session::lint::builtin::UNUSED_ATTRIBUTES,
972            crate::errors::EmptyAttributeList { attr_span: span, attr_path, valid_without_list },
973            span,
974        );
975    }
976
977    pub(crate) fn warn_ill_formed_attribute_input(&mut self, lint: &'static Lint) {
978        self.warn_ill_formed_attribute_input_with_help(lint, None)
979    }
980    pub(crate) fn warn_ill_formed_attribute_input_with_help(
981        &mut self,
982        lint: &'static Lint,
983        help: Option<String>,
984    ) {
985        let suggestions = self.suggestions();
986        let span = self.attr_span;
987        self.emit_lint(
988            lint,
989            crate::errors::IllFormedAttributeInput::new(&suggestions, None, help.as_deref()),
990            span,
991        );
992    }
993
994    pub(crate) fn suggestions(&self) -> Vec<String> {
995        let style = match self.parsed_description {
996            // If the outer and inner spans are equal, we are parsing an embedded attribute
997            ParsedDescription::Attribute if self.attr_span == self.inner_span => {
998                AttrSuggestionStyle::EmbeddedAttribute
999            }
1000            ParsedDescription::Attribute => AttrSuggestionStyle::Attribute(self.attr_style),
1001            ParsedDescription::Macro => AttrSuggestionStyle::Macro,
1002        };
1003
1004        self.template.suggestions(style, &self.attr_path)
1005    }
1006    /// Error that a string literal was expected.
1007    /// You can optionally give the literal you did find (which you found not to be a string literal)
1008    /// which can make better errors. For example, if the literal was a byte string it will suggest
1009    /// removing the `b` prefix.
1010    pub(crate) fn expected_string_literal(
1011        &mut self,
1012        span: Span,
1013        actual_literal: Option<&MetaItemLit>,
1014    ) -> ErrorGuaranteed {
1015        self.emit_parse_error(
1016            span,
1017            AttributeParseErrorReason::ExpectedStringLiteral {
1018                byte_string: actual_literal.and_then(|i| {
1019                    i.kind.is_bytestr().then(|| self.sess().source_map().start_point(i.span))
1020                }),
1021            },
1022        )
1023    }
1024
1025    /// Error that a filename string literal was expected.
1026    pub(crate) fn expected_filename_literal(&mut self, span: Span) {
1027        self.emit_parse_error(span, AttributeParseErrorReason::ExpectedFilenameLiteral);
1028    }
1029
1030    pub(crate) fn expected_integer_literal(&mut self, span: Span) -> ErrorGuaranteed {
1031        self.emit_parse_error(span, AttributeParseErrorReason::ExpectedIntegerLiteral)
1032    }
1033}
1034
1035impl<'a, 'f, 'sess: 'f> Deref for AttributeDiagnosticContext<'a, 'f, 'sess> {
1036    type Target = AcceptContext<'f, 'sess>;
1037
1038    fn deref(&self) -> &Self::Target {
1039        self.ctx
1040    }
1041}
1042
1043impl<'a, 'f, 'sess: 'f> DerefMut for AttributeDiagnosticContext<'a, 'f, 'sess> {
1044    fn deref_mut(&mut self) -> &mut Self::Target {
1045        self.ctx
1046    }
1047}
1048
1049/// Represents a custom suggestion that an attribute parser can emit.
1050pub(crate) struct Suggestion {
1051    pub(crate) msg: String,
1052    pub(crate) sp: Span,
1053    pub(crate) code: String,
1054}