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        F: for<'a> Fn(DiagCtxtHandle<'a>, Level) -> Diag<'a, ()> + DynSend + DynSync + 'static,
376    >(
377        &mut self,
378        lint: &'static Lint,
379        callback: F,
380        span: impl Into<MultiSpan>,
381    ) {
382        self.emit_lint_inner(
383            lint,
384            EmitAttribute(Box::new(move |dcx, level, _| callback(dcx, level))),
385            span,
386        );
387    }
388
389    pub(crate) fn emit_lint_with_sess<
390        F: for<'a> Fn(DiagCtxtHandle<'a>, Level, &Session) -> Diag<'a, ()>
391            + DynSend
392            + DynSync
393            + 'static,
394    >(
395        &mut self,
396        lint: &'static Lint,
397        callback: F,
398        span: impl Into<MultiSpan>,
399    ) {
400        self.emit_lint_inner(lint, EmitAttribute(Box::new(callback)), span);
401    }
402
403    fn emit_lint_inner(
404        &mut self,
405        lint: &'static Lint,
406        kind: EmitAttribute,
407        span: impl Into<MultiSpan>,
408    ) {
409        if !#[allow(non_exhaustive_omitted_patterns)] match self.should_emit {
    ShouldEmit::ErrorsAndLints { .. } | ShouldEmit::EarlyFatal {
        also_emit_lints: true } => true,
    _ => false,
}matches!(
410            self.should_emit,
411            ShouldEmit::ErrorsAndLints { .. } | ShouldEmit::EarlyFatal { also_emit_lints: true }
412        ) {
413            return;
414        }
415        (self.emit_lint)(LintId::of(lint), span.into(), kind);
416    }
417
418    pub(crate) fn warn_unused_duplicate(&mut self, used_span: Span, unused_span: Span) {
419        self.emit_lint(
420            rustc_session::lint::builtin::UNUSED_ATTRIBUTES,
421            move |dcx, level| {
422                rustc_errors::lints::UnusedDuplicate {
423                    this: unused_span,
424                    other: used_span,
425                    warning: false,
426                }
427                .into_diag(dcx, level)
428            },
429            unused_span,
430        )
431    }
432
433    pub(crate) fn warn_unused_duplicate_future_error(
434        &mut self,
435        used_span: Span,
436        unused_span: Span,
437    ) {
438        self.emit_lint(
439            rustc_session::lint::builtin::UNUSED_ATTRIBUTES,
440            move |dcx, level| {
441                rustc_errors::lints::UnusedDuplicate {
442                    this: unused_span,
443                    other: used_span,
444                    warning: true,
445                }
446                .into_diag(dcx, level)
447            },
448            unused_span,
449        )
450    }
451}
452
453impl<'f, 'sess: 'f> AcceptContext<'f, 'sess> {
454    pub(crate) fn adcx(&mut self) -> AttributeDiagnosticContext<'_, 'f, 'sess> {
455        AttributeDiagnosticContext { ctx: self, custom_suggestions: Vec::new() }
456    }
457
458    /// Asserts that this MetaItem is a list that contains a single element. Emits an error and
459    /// returns `None` if it is not the case.
460    ///
461    /// Some examples:
462    ///
463    /// - In `#[allow(warnings)]`, `warnings` is returned
464    /// - In `#[cfg_attr(docsrs, doc = "foo")]`, `None` is returned, "expected a single argument
465    ///   here" is emitted.
466    /// - In `#[cfg()]`, `None` is returned, "expected an argument here" is emitted.
467    ///
468    /// The provided span is used as a fallback for diagnostic generation in case `arg` does not
469    /// contain any. It should be the span of the node that contains `arg`.
470    pub(crate) fn expect_single_element_list<'arg>(
471        &mut self,
472        arg: &'arg ArgParser,
473        span: Span,
474    ) -> Option<&'arg MetaItemOrLitParser> {
475        let ArgParser::List(l) = arg else {
476            self.adcx().expected_list(span, arg);
477            return None;
478        };
479
480        let Some(single) = l.as_single() else {
481            self.adcx().expected_single_argument(l.span, l.len());
482            return None;
483        };
484
485        Some(single)
486    }
487
488    /// Asserts that an [`ArgParser`] is a list and returns it, or emits an error and returns
489    /// `None`.
490    ///
491    /// Some examples:
492    ///
493    /// - `#[allow(clippy::complexity)]`: `(clippy::complexity)` is a list
494    /// - `#[rustfmt::skip::macros(target_macro_name)]`: `(target_macro_name)` is a list
495    ///
496    /// This is a higher-level (and harder to misuse) wrapper over [`ArgParser::as_list`] that
497    /// allows using `?` when the attribute parsing function allows it. You may still want to use
498    /// [`ArgParser::as_list`] for the following reasons:
499    ///
500    /// - You want to emit your own diagnostics (for instance, with [`SharedContext::emit_err`]).
501    /// - The attribute can be parsed in multiple ways and it does not make sense to emit an error.
502    pub(crate) fn expect_list<'arg>(
503        &mut self,
504        args: &'arg ArgParser,
505        span: Span,
506    ) -> Option<&'arg MetaItemListParser> {
507        let list = args.as_list();
508        if list.is_none() {
509            self.adcx().expected_list(span, args);
510        }
511        list
512    }
513
514    /// Asserts that a [`MetaItemListParser`] contains a single element and returns it, or emits an
515    /// error and returns `None`.
516    ///
517    /// This is a higher-level (and harder to misuse) wrapper over [`MetaItemListParser::as_single`],
518    /// that allows using `?` to early return. You may still want to use
519    /// [`MetaItemListParser::as_single`] for the following reasons:
520    ///
521    /// - You want to emit your own diagnostics (for instance, with [`SharedContext::emit_err`]).
522    /// - The attribute can be parsed in multiple ways and it does not make sense to emit an error.
523    pub(crate) fn expect_single<'arg>(
524        &mut self,
525        list: &'arg MetaItemListParser,
526    ) -> Option<&'arg MetaItemOrLitParser> {
527        let single = list.as_single();
528        if single.is_none() {
529            self.adcx().expected_single_argument(list.span, list.len());
530        }
531        single
532    }
533
534    /// Asserts that a node is a name-value pair.
535    ///
536    /// Some examples:
537    ///
538    /// - `#[clippy::cyclomatic_complexity = "100"]`: `clippy::cyclomatic_complexity = "100"` is a
539    ///   name-value pair, where the name is a path (`clippy::cyclomatic_complexity`). You already
540    ///   checked the path to get an `ArgParser`, so this method will effectively only assert that
541    ///   the `= "100"` is there and returns it.
542    /// - `#[doc = "hello"]`: `doc = "hello`  is also a name value pair. `= "hello"` is returned.
543    /// - `#[serde(rename_all = "lowercase")]`: `rename_all = "lowercase"` is a name value pair,
544    ///   where the name is an identifier (`rename_all`) and the value is a literal (`"lowercase"`).
545    ///   This returns both the path and the value.
546    ///
547    /// `arg` must be a reference to any node that may contain a name-value pair, that is:
548    ///
549    /// - [`MetaItemOrLitParser`],
550    /// - [`MetaItemParser`],
551    /// - [`ArgParser`].
552    ///
553    /// `name` can be set to `Some` for a nicer error message talking about the specific name that
554    /// was found lacking a value.
555    ///
556    /// This is a higher-level (and harder to misuse) wrapper over multiple `as_` methods in the
557    /// [`parser`][crate::parser] module. You may still want to use the lower-level methods for the
558    /// following reasons:
559    ///
560    /// - You want to emit your own diagnostics (for instance, with [`SharedContext::emit_err`]).
561    /// - The attribute can be parsed in multiple ways and it does not make sense to emit an error.
562    pub(crate) fn expect_name_value<'arg, Arg>(
563        &mut self,
564        arg: &'arg Arg,
565        span: Span,
566        name: Option<Symbol>,
567    ) -> Option<Arg::Output<'arg>>
568    where
569        Arg: ExpectNameValue,
570    {
571        arg.expect_name_value(self, span, name)
572    }
573}
574
575pub(crate) trait ExpectNameValue {
576    type Output<'a>
577    where
578        Self: 'a;
579
580    fn expect_name_value<'a, 'f, 'sess>(
581        &'a self,
582        cx: &mut AcceptContext<'f, 'sess>,
583        span: Span,
584        name: Option<Symbol>,
585    ) -> Option<Self::Output<'a>>;
586}
587
588impl ExpectNameValue for MetaItemOrLitParser {
589    type Output<'a> = (Ident, &'a NameValueParser);
590
591    fn expect_name_value<'a, 'f, 'sess>(
592        &'a self,
593        cx: &mut AcceptContext<'f, 'sess>,
594        span: Span,
595        name: Option<Symbol>,
596    ) -> Option<Self::Output<'a>> {
597        let Some(meta_item) = self.meta_item() else {
598            cx.adcx().expected_name_value(self.span(), name);
599            return None;
600        };
601
602        meta_item.expect_name_value(cx, span, name)
603    }
604}
605
606impl ExpectNameValue for MetaItemParser {
607    type Output<'a> = (Ident, &'a NameValueParser);
608
609    fn expect_name_value<'a, 'f, 'sess>(
610        &'a self,
611        cx: &mut AcceptContext<'f, 'sess>,
612        _span: Span, // Not needed: `MetaItemOrLitParser` carry its own span.
613        name: Option<Symbol>,
614    ) -> Option<Self::Output<'a>> {
615        let word = self.path().word();
616        let arg = self.args().as_name_value();
617
618        if word.is_none() {
619            cx.adcx().expected_identifier(self.path().span());
620        }
621
622        if arg.is_none() {
623            cx.adcx().expected_name_value(self.span(), name);
624        }
625
626        let Some((word, arg)) = word.zip(arg) else {
627            return None;
628        };
629
630        Some((word, arg))
631    }
632}
633
634impl ExpectNameValue for ArgParser {
635    type Output<'a> = &'a NameValueParser;
636
637    fn expect_name_value<'a, 'f, 'sess>(
638        &'a self,
639        cx: &mut AcceptContext<'f, 'sess>,
640        span: Span,
641        name: Option<Symbol>,
642    ) -> Option<Self::Output<'a>> {
643        let Some(nv) = self.as_name_value() else {
644            cx.adcx().expected_name_value(span, name);
645            return None;
646        };
647
648        Some(nv)
649    }
650}
651
652impl<'f, 'sess> Deref for AcceptContext<'f, 'sess> {
653    type Target = SharedContext<'f, 'sess>;
654
655    fn deref(&self) -> &Self::Target {
656        &self.shared
657    }
658}
659
660impl<'f, 'sess> DerefMut for AcceptContext<'f, 'sess> {
661    fn deref_mut(&mut self) -> &mut Self::Target {
662        &mut self.shared
663    }
664}
665
666/// Context given to every attribute parser during finalization.
667///
668/// Gives [`AttributeParser`](crate::attributes::AttributeParser)s enough information to create
669/// errors, for example.
670pub struct SharedContext<'p, 'sess> {
671    /// The parse context, gives access to the session and the
672    /// diagnostics context.
673    pub(crate) cx: &'p mut AttributeParser<'sess>,
674    /// The span of the syntactical component this attribute was applied to
675    pub(crate) target_span: Span,
676    pub(crate) target: rustc_hir::Target,
677
678    pub(crate) emit_lint: &'p mut dyn FnMut(LintId, MultiSpan, EmitAttribute),
679}
680
681/// Context given to every attribute parser during finalization.
682///
683/// Gives [`AttributeParser`](crate::attributes::AttributeParser)s enough information to create
684/// errors, for example.
685pub(crate) struct FinalizeContext<'p, 'sess> {
686    pub(crate) shared: SharedContext<'p, 'sess>,
687
688    /// A list of all attribute on this syntax node.
689    ///
690    /// Useful for compatibility checks with other attributes in [`finalize`](crate::attributes::AttributeParser::finalize)
691    ///
692    /// Usually, you should use normal attribute parsing logic instead,
693    /// especially when making a *denylist* of other attributes.
694    pub(crate) all_attrs: &'p [RefPathParser<'p>],
695}
696
697impl<'p, 'sess: 'p> Deref for FinalizeContext<'p, 'sess> {
698    type Target = SharedContext<'p, 'sess>;
699
700    fn deref(&self) -> &Self::Target {
701        &self.shared
702    }
703}
704
705impl<'p, 'sess: 'p> DerefMut for FinalizeContext<'p, 'sess> {
706    fn deref_mut(&mut self) -> &mut Self::Target {
707        &mut self.shared
708    }
709}
710
711impl<'p, 'sess: 'p> Deref for SharedContext<'p, 'sess> {
712    type Target = AttributeParser<'sess>;
713
714    fn deref(&self) -> &Self::Target {
715        self.cx
716    }
717}
718
719impl<'p, 'sess: 'p> DerefMut for SharedContext<'p, 'sess> {
720    fn deref_mut(&mut self) -> &mut Self::Target {
721        self.cx
722    }
723}
724
725#[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)]
726pub enum OmitDoc {
727    Lower,
728    Skip,
729}
730
731#[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)]
732pub enum ShouldEmit {
733    /// The operations will emit errors, and lints, and errors are fatal.
734    ///
735    /// Only relevant when early parsing, in late parsing equivalent to `ErrorsAndLints`.
736    /// Late parsing is never fatal, and instead tries to emit as many diagnostics as possible.
737    EarlyFatal { also_emit_lints: bool },
738    /// The operation will emit errors and lints.
739    /// This is usually what you need.
740    ErrorsAndLints {
741        /// Whether [`ArgParser`] will attempt to recover from errors.
742        ///
743        /// Whether it is allowed to recover from bad input (like an invalid literal). Setting
744        /// this to `Forbidden` will instead return early, and not raise errors except at the top
745        /// level (in [`ArgParser::from_attr_args`]).
746        recovery: Recovery,
747    },
748    /// The operation will *not* emit errors and lints.
749    ///
750    /// The parser can still call `delay_bug`, so you *must* ensure that this operation will also be
751    /// called with `ShouldEmit::ErrorsAndLints`.
752    Nothing,
753}
754
755impl ShouldEmit {
756    pub(crate) fn emit_err(&self, diag: Diag<'_>) -> ErrorGuaranteed {
757        match self {
758            ShouldEmit::EarlyFatal { .. } if diag.level() == Level::DelayedBug => diag.emit(),
759            ShouldEmit::EarlyFatal { .. } => diag.upgrade_to_fatal().emit(),
760            ShouldEmit::ErrorsAndLints { .. } => diag.emit(),
761            ShouldEmit::Nothing => diag.delay_as_bug(),
762        }
763    }
764}
765
766pub(crate) struct AttributeDiagnosticContext<'a, 'f, 'sess> {
767    ctx: &'a mut AcceptContext<'f, 'sess>,
768    custom_suggestions: Vec<Suggestion>,
769}
770
771impl<'a, 'f, 'sess: 'f> AttributeDiagnosticContext<'a, 'f, 'sess> {
772    fn emit_parse_error(
773        &mut self,
774        span: Span,
775        reason: AttributeParseErrorReason<'_>,
776    ) -> ErrorGuaranteed {
777        let suggestions = if !self.custom_suggestions.is_empty() {
778            AttributeParseErrorSuggestions::CreatedByParser(mem::take(&mut self.custom_suggestions))
779        } else {
780            AttributeParseErrorSuggestions::CreatedByTemplate(self.template_suggestions())
781        };
782
783        self.emit_err(AttributeParseError {
784            span,
785            attr_span: self.attr_span,
786            template: self.template.clone(),
787            path: self.attr_path.clone(),
788            description: self.parsed_description,
789            reason,
790            suggestions,
791        })
792    }
793
794    /// Adds a custom suggestion to the diagnostic. This also prevents the default (template-based)
795    /// suggestion to be emitted.
796    pub(crate) fn push_suggestion(&mut self, msg: String, span: Span, code: String) -> &mut Self {
797        self.custom_suggestions.push(Suggestion { msg, sp: span, code });
798        self
799    }
800
801    pub(crate) fn template_suggestions(&self) -> Vec<String> {
802        let style = match self.parsed_description {
803            // If the outer and inner spans are equal, we are parsing an embedded attribute
804            ParsedDescription::Attribute if self.attr_span == self.inner_span => {
805                AttrSuggestionStyle::EmbeddedAttribute
806            }
807            ParsedDescription::Attribute => AttrSuggestionStyle::Attribute(self.attr_style),
808            ParsedDescription::Macro => AttrSuggestionStyle::Macro,
809        };
810
811        self.template.suggestions(style, &self.attr_path)
812    }
813}
814
815/// Helpers that can be used to generate errors during attribute parsing.
816impl<'a, 'f, 'sess: 'f> AttributeDiagnosticContext<'a, 'f, 'sess> {
817    pub(crate) fn expected_integer_literal_in_range(
818        &mut self,
819        span: Span,
820        lower_bound: isize,
821        upper_bound: isize,
822    ) -> ErrorGuaranteed {
823        self.emit_parse_error(
824            span,
825            AttributeParseErrorReason::ExpectedIntegerLiteralInRange { lower_bound, upper_bound },
826        )
827    }
828
829    /// The provided span is used as a fallback in case `args` does not contain any. It should be
830    /// the span of the node that contains `args`.
831    pub(crate) fn expected_list(&mut self, span: Span, args: &ArgParser) -> ErrorGuaranteed {
832        let span = match args {
833            ArgParser::NoArgs => span,
834            ArgParser::List(list) => list.span,
835            ArgParser::NameValue(nv) => nv.args_span(),
836        };
837        self.emit_parse_error(span, AttributeParseErrorReason::ExpectedList)
838    }
839
840    pub(crate) fn expected_list_with_num_args_or_more(
841        &mut self,
842        args: usize,
843        span: Span,
844    ) -> ErrorGuaranteed {
845        self.emit_parse_error(
846            span,
847            AttributeParseErrorReason::ExpectedListWithNumArgsOrMore { args },
848        )
849    }
850
851    pub(crate) fn expected_list_or_no_args(&mut self, span: Span) -> ErrorGuaranteed {
852        self.emit_parse_error(span, AttributeParseErrorReason::ExpectedListOrNoArgs)
853    }
854
855    pub(crate) fn expected_nv_or_no_args(&mut self, span: Span) -> ErrorGuaranteed {
856        self.emit_parse_error(span, AttributeParseErrorReason::ExpectedNameValueOrNoArgs)
857    }
858
859    pub(crate) fn expected_non_empty_string_literal(&mut self, span: Span) -> ErrorGuaranteed {
860        self.emit_parse_error(span, AttributeParseErrorReason::ExpectedNonEmptyStringLiteral)
861    }
862
863    pub(crate) fn expected_no_args(&mut self, span: Span) -> ErrorGuaranteed {
864        self.emit_parse_error(span, AttributeParseErrorReason::ExpectedNoArgs)
865    }
866
867    /// Emit an error that a `name` was expected here
868    pub(crate) fn expected_identifier(&mut self, span: Span) -> ErrorGuaranteed {
869        self.emit_parse_error(span, AttributeParseErrorReason::ExpectedIdentifier)
870    }
871
872    /// Emit an error that a `name = value` pair was expected at this span. The symbol can be given for
873    /// a nicer error message talking about the specific name that was found lacking a value.
874    fn expected_name_value(&mut self, span: Span, name: Option<Symbol>) -> ErrorGuaranteed {
875        self.emit_parse_error(span, AttributeParseErrorReason::ExpectedNameValue(name))
876    }
877
878    /// Emit an error that a `name = value` argument is missing in a list of name-value pairs.
879    pub(crate) fn missing_name_value(&mut self, span: Span, name: Symbol) -> ErrorGuaranteed {
880        self.emit_parse_error(span, AttributeParseErrorReason::MissingNameValue(name))
881    }
882
883    /// Emit an error that a `name = value` pair was found where that name was already seen.
884    pub(crate) fn duplicate_key(&mut self, span: Span, key: Symbol) -> ErrorGuaranteed {
885        self.emit_parse_error(span, AttributeParseErrorReason::DuplicateKey(key))
886    }
887
888    /// An error that should be emitted when a [`MetaItemOrLitParser`]
889    /// was expected *not* to be a literal, but instead a meta item.
890    pub(crate) fn expected_not_literal(&mut self, span: Span) -> ErrorGuaranteed {
891        self.emit_parse_error(span, AttributeParseErrorReason::ExpectedNotLiteral)
892    }
893
894    /// Signals that we expected exactly one argument and that we got either zero or two or more.
895    /// The `provided_arguments` argument allows distinguishing between "expected an argument here"
896    /// (when zero arguments are provided) and "expect a single argument here" (when two or more
897    /// arguments are provided).
898    pub(crate) fn expected_single_argument(
899        &mut self,
900        span: Span,
901        provided_arguments: usize,
902    ) -> ErrorGuaranteed {
903        let reason = if provided_arguments == 0 {
904            AttributeParseErrorReason::ExpectedArgument
905        } else {
906            AttributeParseErrorReason::ExpectedSingleArgument
907        };
908
909        self.emit_parse_error(span, reason)
910    }
911
912    pub(crate) fn expected_at_least_one_argument(&mut self, span: Span) -> ErrorGuaranteed {
913        self.emit_parse_error(span, AttributeParseErrorReason::ExpectedAtLeastOneArgument)
914    }
915
916    /// Produces an error along the lines of `expected one of [foo, meow]`
917    pub(crate) fn expected_specific_argument(
918        &mut self,
919        span: Span,
920        possibilities: &[Symbol],
921    ) -> ErrorGuaranteed {
922        self.emit_parse_error(
923            span,
924            AttributeParseErrorReason::ExpectedSpecificArgument {
925                possibilities,
926                strings: false,
927                list: false,
928            },
929        )
930    }
931
932    /// Produces an error along the lines of `expected one of [foo, meow] as an argument`.
933    /// i.e. slightly different wording to [`expected_specific_argument`](Self::expected_specific_argument).
934    pub(crate) fn expected_specific_argument_and_list(
935        &mut self,
936        span: Span,
937        possibilities: &[Symbol],
938    ) -> ErrorGuaranteed {
939        self.emit_parse_error(
940            span,
941            AttributeParseErrorReason::ExpectedSpecificArgument {
942                possibilities,
943                strings: false,
944                list: true,
945            },
946        )
947    }
948
949    /// produces an error along the lines of `expected one of ["foo", "meow"]`
950    pub(crate) fn expected_specific_argument_strings(
951        &mut self,
952        span: Span,
953        possibilities: &[Symbol],
954    ) -> ErrorGuaranteed {
955        self.emit_parse_error(
956            span,
957            AttributeParseErrorReason::ExpectedSpecificArgument {
958                possibilities,
959                strings: true,
960                list: false,
961            },
962        )
963    }
964
965    pub(crate) fn warn_empty_attribute(&mut self, span: Span) {
966        let attr_path = self.attr_path.to_string();
967        let valid_without_list = self.template.word;
968        self.emit_lint(
969            rustc_session::lint::builtin::UNUSED_ATTRIBUTES,
970            move |dcx, level| {
971                crate::errors::EmptyAttributeList {
972                    attr_span: span,
973                    attr_path: &attr_path,
974                    valid_without_list,
975                }
976                .into_diag(dcx, level)
977            },
978            span,
979        );
980    }
981
982    pub(crate) fn warn_ill_formed_attribute_input(&mut self, lint: &'static Lint) {
983        self.warn_ill_formed_attribute_input_with_help(lint, None)
984    }
985    pub(crate) fn warn_ill_formed_attribute_input_with_help(
986        &mut self,
987        lint: &'static Lint,
988        help: Option<String>,
989    ) {
990        let suggestions = self.suggestions();
991        let span = self.attr_span;
992        self.emit_lint(
993            lint,
994            move |dcx, level| {
995                crate::errors::IllFormedAttributeInput::new(&suggestions, None, help.as_deref())
996                    .into_diag(dcx, level)
997            },
998            span,
999        );
1000    }
1001
1002    pub(crate) fn suggestions(&self) -> Vec<String> {
1003        let style = match self.parsed_description {
1004            // If the outer and inner spans are equal, we are parsing an embedded attribute
1005            ParsedDescription::Attribute if self.attr_span == self.inner_span => {
1006                AttrSuggestionStyle::EmbeddedAttribute
1007            }
1008            ParsedDescription::Attribute => AttrSuggestionStyle::Attribute(self.attr_style),
1009            ParsedDescription::Macro => AttrSuggestionStyle::Macro,
1010        };
1011
1012        self.template.suggestions(style, &self.attr_path)
1013    }
1014    /// Error that a string literal was expected.
1015    /// You can optionally give the literal you did find (which you found not to be a string literal)
1016    /// which can make better errors. For example, if the literal was a byte string it will suggest
1017    /// removing the `b` prefix.
1018    pub(crate) fn expected_string_literal(
1019        &mut self,
1020        span: Span,
1021        actual_literal: Option<&MetaItemLit>,
1022    ) -> ErrorGuaranteed {
1023        self.emit_parse_error(
1024            span,
1025            AttributeParseErrorReason::ExpectedStringLiteral {
1026                byte_string: actual_literal.and_then(|i| {
1027                    i.kind.is_bytestr().then(|| self.sess().source_map().start_point(i.span))
1028                }),
1029            },
1030        )
1031    }
1032
1033    /// Error that a filename string literal was expected.
1034    pub(crate) fn expected_filename_literal(&mut self, span: Span) {
1035        self.emit_parse_error(span, AttributeParseErrorReason::ExpectedFilenameLiteral);
1036    }
1037
1038    pub(crate) fn expected_integer_literal(&mut self, span: Span) -> ErrorGuaranteed {
1039        self.emit_parse_error(span, AttributeParseErrorReason::ExpectedIntegerLiteral)
1040    }
1041}
1042
1043impl<'a, 'f, 'sess: 'f> Deref for AttributeDiagnosticContext<'a, 'f, 'sess> {
1044    type Target = AcceptContext<'f, 'sess>;
1045
1046    fn deref(&self) -> &Self::Target {
1047        self.ctx
1048    }
1049}
1050
1051impl<'a, 'f, 'sess: 'f> DerefMut for AttributeDiagnosticContext<'a, 'f, 'sess> {
1052    fn deref_mut(&mut self) -> &mut Self::Target {
1053        self.ctx
1054    }
1055}
1056
1057/// Represents a custom suggestion that an attribute parser can emit.
1058pub(crate) struct Suggestion {
1059    pub(crate) msg: String,
1060    pub(crate) sp: Span,
1061    pub(crate) code: String,
1062}