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, Safety};
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<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<RustcLegacyConstGenericsParser>,
212        Single<RustcLintOptDenyFieldAccessParser>,
213        Single<RustcMacroTransparencyParser>,
214        Single<RustcMustImplementOneOfParser>,
215        Single<RustcNeverTypeOptionsParser>,
216        Single<RustcObjcClassParser>,
217        Single<RustcObjcSelectorParser>,
218        Single<RustcReservationImplParser>,
219        Single<RustcScalableVectorParser>,
220        Single<RustcSimdMonomorphizeLaneLimitParser>,
221        Single<RustcSkipDuringMethodDispatchParser>,
222        Single<RustcTestMarkerParser>,
223        Single<SanitizeParser>,
224        Single<ShouldPanicParser>,
225        Single<TestRunnerParser>,
226        Single<TypeLengthLimitParser>,
227        Single<WindowsSubsystemParser>,
228        Single<WithoutArgs<AllowInternalUnsafeParser>>,
229        Single<WithoutArgs<AutomaticallyDerivedParser>>,
230        Single<WithoutArgs<ColdParser>>,
231        Single<WithoutArgs<CompilerBuiltinsParser>>,
232        Single<WithoutArgs<ConstContinueParser>>,
233        Single<WithoutArgs<CoroutineParser>>,
234        Single<WithoutArgs<DefaultLibAllocatorParser>>,
235        Single<WithoutArgs<ExportStableParser>>,
236        Single<WithoutArgs<FfiConstParser>>,
237        Single<WithoutArgs<FfiPureParser>>,
238        Single<WithoutArgs<FundamentalParser>>,
239        Single<WithoutArgs<LoopMatchParser>>,
240        Single<WithoutArgs<MacroEscapeParser>>,
241        Single<WithoutArgs<MarkerParser>>,
242        Single<WithoutArgs<MayDangleParser>>,
243        Single<WithoutArgs<NeedsAllocatorParser>>,
244        Single<WithoutArgs<NeedsPanicRuntimeParser>>,
245        Single<WithoutArgs<NoBuiltinsParser>>,
246        Single<WithoutArgs<NoCoreParser>>,
247        Single<WithoutArgs<NoImplicitPreludeParser>>,
248        Single<WithoutArgs<NoLinkParser>>,
249        Single<WithoutArgs<NoMainParser>>,
250        Single<WithoutArgs<NoMangleParser>>,
251        Single<WithoutArgs<NoStdParser>>,
252        Single<WithoutArgs<NonExhaustiveParser>>,
253        Single<WithoutArgs<PanicHandlerParser>>,
254        Single<WithoutArgs<PanicRuntimeParser>>,
255        Single<WithoutArgs<PinV2Parser>>,
256        Single<WithoutArgs<PreludeImportParser>>,
257        Single<WithoutArgs<ProcMacroAttributeParser>>,
258        Single<WithoutArgs<ProcMacroParser>>,
259        Single<WithoutArgs<ProfilerRuntimeParser>>,
260        Single<WithoutArgs<RustcAllocatorParser>>,
261        Single<WithoutArgs<RustcAllocatorZeroedParser>>,
262        Single<WithoutArgs<RustcAllowIncoherentImplParser>>,
263        Single<WithoutArgs<RustcAsPtrParser>>,
264        Single<WithoutArgs<RustcCaptureAnalysisParser>>,
265        Single<WithoutArgs<RustcCoherenceIsCoreParser>>,
266        Single<WithoutArgs<RustcCoinductiveParser>>,
267        Single<WithoutArgs<RustcConstStableIndirectParser>>,
268        Single<WithoutArgs<RustcConversionSuggestionParser>>,
269        Single<WithoutArgs<RustcDeallocatorParser>>,
270        Single<WithoutArgs<RustcDelayedBugFromInsideQueryParser>>,
271        Single<WithoutArgs<RustcDenyExplicitImplParser>>,
272        Single<WithoutArgs<RustcDoNotConstCheckParser>>,
273        Single<WithoutArgs<RustcDumpDefParentsParser>>,
274        Single<WithoutArgs<RustcDumpHiddenTypeOfOpaquesParser>>,
275        Single<WithoutArgs<RustcDumpInferredOutlivesParser>>,
276        Single<WithoutArgs<RustcDumpItemBoundsParser>>,
277        Single<WithoutArgs<RustcDumpObjectLifetimeDefaultsParser>>,
278        Single<WithoutArgs<RustcDumpPredicatesParser>>,
279        Single<WithoutArgs<RustcDumpUserArgsParser>>,
280        Single<WithoutArgs<RustcDumpVariancesOfOpaquesParser>>,
281        Single<WithoutArgs<RustcDumpVariancesParser>>,
282        Single<WithoutArgs<RustcDumpVtableParser>>,
283        Single<WithoutArgs<RustcDynIncompatibleTraitParser>>,
284        Single<WithoutArgs<RustcEffectiveVisibilityParser>>,
285        Single<WithoutArgs<RustcEiiForeignItemParser>>,
286        Single<WithoutArgs<RustcEvaluateWhereClausesParser>>,
287        Single<WithoutArgs<RustcExhaustiveParser>>,
288        Single<WithoutArgs<RustcHasIncoherentInherentImplsParser>>,
289        Single<WithoutArgs<RustcInheritOverflowChecksParser>>,
290        Single<WithoutArgs<RustcInsignificantDtorParser>>,
291        Single<WithoutArgs<RustcIntrinsicConstStableIndirectParser>>,
292        Single<WithoutArgs<RustcIntrinsicParser>>,
293        Single<WithoutArgs<RustcLintOptTyParser>>,
294        Single<WithoutArgs<RustcLintQueryInstabilityParser>>,
295        Single<WithoutArgs<RustcLintUntrackedQueryInformationParser>>,
296        Single<WithoutArgs<RustcMainParser>>,
297        Single<WithoutArgs<RustcNeverReturnsNullPtrParser>>,
298        Single<WithoutArgs<RustcNoImplicitAutorefsParser>>,
299        Single<WithoutArgs<RustcNoImplicitBoundsParser>>,
300        Single<WithoutArgs<RustcNoMirInlineParser>>,
301        Single<WithoutArgs<RustcNoWritableParser>>,
302        Single<WithoutArgs<RustcNonConstTraitMethodParser>>,
303        Single<WithoutArgs<RustcNonnullOptimizationGuaranteedParser>>,
304        Single<WithoutArgs<RustcNounwindParser>>,
305        Single<WithoutArgs<RustcOffloadKernelParser>>,
306        Single<WithoutArgs<RustcParenSugarParser>>,
307        Single<WithoutArgs<RustcPassByValueParser>>,
308        Single<WithoutArgs<RustcPassIndirectlyInNonRusticAbisParser>>,
309        Single<WithoutArgs<RustcPreserveUbChecksParser>>,
310        Single<WithoutArgs<RustcProcMacroDeclsParser>>,
311        Single<WithoutArgs<RustcPubTransparentParser>>,
312        Single<WithoutArgs<RustcReallocatorParser>>,
313        Single<WithoutArgs<RustcRegionsParser>>,
314        Single<WithoutArgs<RustcShouldNotBeCalledOnConstItemsParser>>,
315        Single<WithoutArgs<RustcSpecializationTraitParser>>,
316        Single<WithoutArgs<RustcStdInternalSymbolParser>>,
317        Single<WithoutArgs<RustcStrictCoherenceParser>>,
318        Single<WithoutArgs<RustcTrivialFieldReadsParser>>,
319        Single<WithoutArgs<RustcUnsafeSpecializationMarkerParser>>,
320        Single<WithoutArgs<ThreadLocalParser>>,
321        Single<WithoutArgs<TrackCallerParser>>,
322        // tidy-alphabetical-end
323    ];
324);
325
326/// Context given to every attribute parser when accepting
327///
328/// Gives [`AttributeParser`]s enough information to create errors, for example.
329pub struct AcceptContext<'f, 'sess> {
330    pub(crate) shared: SharedContext<'f, 'sess>,
331
332    /// The outer span of the attribute currently being parsed
333    ///
334    /// ```none
335    /// #[attribute(...)]
336    /// ^^^^^^^^^^^^^^^^^ outer span
337    /// ```
338    /// For attributes in `cfg_attr`, the outer span and inner spans are equal.
339    pub(crate) attr_span: Span,
340    /// The inner span of the attribute currently being parsed.
341    ///
342    /// ```none
343    /// #[attribute(...)]
344    ///   ^^^^^^^^^^^^^^  inner span
345    /// ```
346    pub(crate) inner_span: Span,
347
348    /// Whether it is an inner or outer attribute.
349    pub(crate) attr_style: AttrStyle,
350
351    /// A description of the thing we are parsing using this attribute parser.
352    /// We are not only using these parsers for attributes, but also for macros such as the `cfg!()` macro.
353    pub(crate) parsed_description: ParsedDescription,
354
355    /// The expected structure of the attribute.
356    ///
357    /// Used in reporting errors to give a hint to users what the attribute *should* look like.
358    pub(crate) template: &'f AttributeTemplate,
359
360    /// The safety attribute (if any) applied to the attribute.
361    pub(crate) attr_safety: Safety,
362
363    /// The name of the attribute we're currently accepting.
364    pub(crate) attr_path: AttrPath,
365}
366
367impl<'f, 'sess: 'f> SharedContext<'f, 'sess> {
368    pub(crate) fn emit_err(&self, diag: impl for<'x> Diagnostic<'x>) -> ErrorGuaranteed {
369        self.cx.emit_err(diag)
370    }
371
372    /// Emit a lint. This method is somewhat special, since lints emitted during attribute parsing
373    /// must be delayed until after HIR is built. This method will take care of the details of
374    /// that.
375    pub(crate) fn emit_lint(
376        &mut self,
377        lint: &'static Lint,
378        diagnostic: impl for<'x> Diagnostic<'x, ()> + DynSend + DynSync + 'static,
379        span: impl Into<MultiSpan>,
380    ) {
381        self.emit_lint_inner(
382            lint,
383            EmitAttribute(Box::new(move |dcx, level, _| diagnostic.into_diag(dcx, level))),
384            span,
385        );
386    }
387
388    pub(crate) fn emit_lint_with_sess<
389        F: for<'a> FnOnce(DiagCtxtHandle<'a>, Level, &Session) -> Diag<'a, ()>
390            + DynSend
391            + DynSync
392            + 'static,
393    >(
394        &mut self,
395        lint: &'static Lint,
396        callback: F,
397        span: impl Into<MultiSpan>,
398    ) {
399        self.emit_lint_inner(lint, EmitAttribute(Box::new(callback)), span);
400    }
401
402    fn emit_lint_inner(
403        &mut self,
404        lint: &'static Lint,
405        kind: EmitAttribute,
406        span: impl Into<MultiSpan>,
407    ) {
408        if !#[allow(non_exhaustive_omitted_patterns)] match self.should_emit {
    ShouldEmit::ErrorsAndLints { .. } | ShouldEmit::EarlyFatal {
        also_emit_lints: true } => true,
    _ => false,
}matches!(
409            self.should_emit,
410            ShouldEmit::ErrorsAndLints { .. } | ShouldEmit::EarlyFatal { also_emit_lints: true }
411        ) {
412            return;
413        }
414        (self.emit_lint)(LintId::of(lint), span.into(), kind);
415    }
416
417    pub(crate) fn warn_unused_duplicate(&mut self, used_span: Span, unused_span: Span) {
418        self.emit_lint(
419            rustc_session::lint::builtin::UNUSED_ATTRIBUTES,
420            rustc_errors::lints::UnusedDuplicate {
421                this: unused_span,
422                other: used_span,
423                warning: false,
424            },
425            unused_span,
426        )
427    }
428
429    pub(crate) fn warn_unused_duplicate_future_error(
430        &mut self,
431        used_span: Span,
432        unused_span: Span,
433    ) {
434        self.emit_lint(
435            rustc_session::lint::builtin::UNUSED_ATTRIBUTES,
436            rustc_errors::lints::UnusedDuplicate {
437                this: unused_span,
438                other: used_span,
439                warning: true,
440            },
441            unused_span,
442        )
443    }
444}
445
446impl<'f, 'sess: 'f> AcceptContext<'f, 'sess> {
447    pub(crate) fn adcx(&mut self) -> AttributeDiagnosticContext<'_, 'f, 'sess> {
448        AttributeDiagnosticContext { ctx: self, custom_suggestions: Vec::new() }
449    }
450
451    /// Asserts that this MetaItem is a list that contains a single element. Emits an error and
452    /// returns `None` if it is not the case.
453    ///
454    /// Some examples:
455    ///
456    /// - In `#[allow(warnings)]`, `warnings` is returned
457    /// - In `#[cfg_attr(docsrs, doc = "foo")]`, `None` is returned, "expected a single argument
458    ///   here" is emitted.
459    /// - In `#[cfg()]`, `None` is returned, "expected an argument here" is emitted.
460    ///
461    /// The provided span is used as a fallback for diagnostic generation in case `arg` does not
462    /// contain any. It should be the span of the node that contains `arg`.
463    pub(crate) fn expect_single_element_list<'arg>(
464        &mut self,
465        arg: &'arg ArgParser,
466        span: Span,
467    ) -> Option<&'arg MetaItemOrLitParser> {
468        let ArgParser::List(l) = arg else {
469            self.adcx().expected_list(span, arg);
470            return None;
471        };
472
473        let Some(single) = l.as_single() else {
474            self.adcx().expected_single_argument(l.span, l.len());
475            return None;
476        };
477
478        Some(single)
479    }
480
481    /// Asserts that an [`ArgParser`] is a list and returns it, or emits an error and returns
482    /// `None`.
483    ///
484    /// Some examples:
485    ///
486    /// - `#[allow(clippy::complexity)]`: `(clippy::complexity)` is a list
487    /// - `#[rustfmt::skip::macros(target_macro_name)]`: `(target_macro_name)` is a list
488    ///
489    /// This is a higher-level (and harder to misuse) wrapper over [`ArgParser::as_list`] that
490    /// allows using `?` when the attribute parsing function allows it. You may still want to use
491    /// [`ArgParser::as_list`] for the following reasons:
492    ///
493    /// - You want to emit your own diagnostics (for instance, with [`SharedContext::emit_err`]).
494    /// - The attribute can be parsed in multiple ways and it does not make sense to emit an error.
495    pub(crate) fn expect_list<'arg>(
496        &mut self,
497        args: &'arg ArgParser,
498        span: Span,
499    ) -> Option<&'arg MetaItemListParser> {
500        let list = args.as_list();
501        if list.is_none() {
502            self.adcx().expected_list(span, args);
503        }
504        list
505    }
506
507    /// Asserts that a [`MetaItemListParser`] contains a single element and returns it, or emits an
508    /// error and returns `None`.
509    ///
510    /// This is a higher-level (and harder to misuse) wrapper over [`MetaItemListParser::as_single`],
511    /// that allows using `?` to early return. You may still want to use
512    /// [`MetaItemListParser::as_single`] for the following reasons:
513    ///
514    /// - You want to emit your own diagnostics (for instance, with [`SharedContext::emit_err`]).
515    /// - The attribute can be parsed in multiple ways and it does not make sense to emit an error.
516    pub(crate) fn expect_single<'arg>(
517        &mut self,
518        list: &'arg MetaItemListParser,
519    ) -> Option<&'arg MetaItemOrLitParser> {
520        let single = list.as_single();
521        if single.is_none() {
522            self.adcx().expected_single_argument(list.span, list.len());
523        }
524        single
525    }
526
527    /// Asserts that a node is a name-value pair.
528    ///
529    /// Some examples:
530    ///
531    /// - `#[clippy::cyclomatic_complexity = "100"]`: `clippy::cyclomatic_complexity = "100"` is a
532    ///   name-value pair, where the name is a path (`clippy::cyclomatic_complexity`). You already
533    ///   checked the path to get an `ArgParser`, so this method will effectively only assert that
534    ///   the `= "100"` is there and returns it.
535    /// - `#[doc = "hello"]`: `doc = "hello`  is also a name value pair. `= "hello"` is returned.
536    /// - `#[serde(rename_all = "lowercase")]`: `rename_all = "lowercase"` is a name value pair,
537    ///   where the name is an identifier (`rename_all`) and the value is a literal (`"lowercase"`).
538    ///   This returns both the path and the value.
539    ///
540    /// `arg` must be a reference to any node that may contain a name-value pair, that is:
541    ///
542    /// - [`MetaItemOrLitParser`],
543    /// - [`MetaItemParser`],
544    /// - [`ArgParser`].
545    ///
546    /// `name` can be set to `Some` for a nicer error message talking about the specific name that
547    /// was found lacking a value.
548    ///
549    /// This is a higher-level (and harder to misuse) wrapper over multiple `as_` methods in the
550    /// [`parser`][crate::parser] module. You may still want to use the lower-level methods for the
551    /// following reasons:
552    ///
553    /// - You want to emit your own diagnostics (for instance, with [`SharedContext::emit_err`]).
554    /// - The attribute can be parsed in multiple ways and it does not make sense to emit an error.
555    pub(crate) fn expect_name_value<'arg, Arg>(
556        &mut self,
557        arg: &'arg Arg,
558        span: Span,
559        name: Option<Symbol>,
560    ) -> Option<Arg::Output<'arg>>
561    where
562        Arg: ExpectNameValue,
563    {
564        arg.expect_name_value(self, span, name)
565    }
566
567    /// Assert that an [`ArgParser`] has no args, or emits an error and return `None`.
568    ///
569    /// This is a higher-level (and harder to misuse) wrapper over multiple
570    /// [`ArgParser::as_no_args`]. You may still want to use the lower-level methods for the
571    /// following reasons:
572    ///
573    /// - You want to emit your own diagnostics (for instance, with [`SharedContext::emit_err`]).
574    /// - The attribute can be parsed in multiple ways and it does not make sense to emit an error.
575    pub(crate) fn expect_no_args<'arg>(&mut self, arg: &'arg ArgParser) -> Option<()> {
576        if let Err(span) = arg.as_no_args() {
577            self.adcx().expected_no_args(span);
578            return None;
579        }
580
581        Some(())
582    }
583
584    /// Asserts that a node is a string literal, or emits an error and return `None`
585    ///
586    /// `arg` must be a reference to any node that may contain a name-value pair, that is:
587    ///
588    /// - [`NameValueParser`],
589    /// - [`MetaItemOrLitParser`],
590    ///
591    /// This is a higher-level (and harder to misuse) wrapper over multiple `as_` methods in the
592    /// [`parser`][crate::parser] module. You may still want to use the lower-level methods for the
593    /// following reasons:
594    ///
595    /// - You want to emit your own diagnostics (for instance, with [`SharedContext::emit_err`]).
596    /// - The attribute can be parsed in multiple ways and it does not make sense to emit an error.
597    pub(crate) fn expect_string_literal<'arg, Arg>(&mut self, arg: &'arg Arg) -> Option<Symbol>
598    where
599        Arg: ExpectStringLiteral,
600    {
601        arg.expect_string_literal(self)
602    }
603}
604
605pub(crate) trait ExpectNameValue {
606    type Output<'a>
607    where
608        Self: 'a;
609
610    fn expect_name_value<'a, 'f, 'sess>(
611        &'a self,
612        cx: &mut AcceptContext<'f, 'sess>,
613        span: Span,
614        name: Option<Symbol>,
615    ) -> Option<Self::Output<'a>>;
616}
617
618impl ExpectNameValue for MetaItemOrLitParser {
619    type Output<'a> = (Ident, &'a NameValueParser);
620
621    fn expect_name_value<'a, 'f, 'sess>(
622        &'a self,
623        cx: &mut AcceptContext<'f, 'sess>,
624        span: Span,
625        name: Option<Symbol>,
626    ) -> Option<Self::Output<'a>> {
627        let Some(meta_item) = self.meta_item() else {
628            cx.adcx().expected_name_value(self.span(), name);
629            return None;
630        };
631
632        meta_item.expect_name_value(cx, span, name)
633    }
634}
635
636impl ExpectNameValue for MetaItemParser {
637    type Output<'a> = (Ident, &'a NameValueParser);
638
639    fn expect_name_value<'a, 'f, 'sess>(
640        &'a self,
641        cx: &mut AcceptContext<'f, 'sess>,
642        _span: Span, // Not needed: `MetaItemOrLitParser` carry its own span.
643        name: Option<Symbol>,
644    ) -> Option<Self::Output<'a>> {
645        let word = self.path().word();
646        let arg = self.args().as_name_value();
647
648        if word.is_none() {
649            cx.adcx().expected_identifier(self.path().span());
650        }
651
652        if arg.is_none() {
653            cx.adcx().expected_name_value(self.span(), name);
654        }
655
656        let Some((word, arg)) = word.zip(arg) else {
657            return None;
658        };
659
660        Some((word, arg))
661    }
662}
663
664impl ExpectNameValue for ArgParser {
665    type Output<'a> = &'a NameValueParser;
666
667    fn expect_name_value<'a, 'f, 'sess>(
668        &'a self,
669        cx: &mut AcceptContext<'f, 'sess>,
670        span: Span,
671        name: Option<Symbol>,
672    ) -> Option<Self::Output<'a>> {
673        let Some(nv) = self.as_name_value() else {
674            cx.adcx().expected_name_value(span, name);
675            return None;
676        };
677
678        Some(nv)
679    }
680}
681
682pub(crate) trait ExpectStringLiteral {
683    fn expect_string_literal<'f, 'sess>(&self, cx: &mut AcceptContext<'f, 'sess>)
684    -> Option<Symbol>;
685}
686
687impl ExpectStringLiteral for NameValueParser {
688    fn expect_string_literal<'f, 'sess>(
689        &self,
690        cx: &mut AcceptContext<'f, 'sess>,
691    ) -> Option<Symbol> {
692        let value = self.value_as_str();
693        if value.is_none() {
694            cx.adcx().expected_string_literal(self.value_span, Some(self.value_as_lit()));
695        }
696        value
697    }
698}
699
700impl ExpectStringLiteral for MetaItemOrLitParser {
701    fn expect_string_literal<'f, 'sess>(
702        &self,
703        cx: &mut AcceptContext<'f, 'sess>,
704    ) -> Option<Symbol> {
705        let Some(lit) = self.as_lit() else {
706            cx.adcx().expected_string_literal(self.span(), None);
707            return None;
708        };
709
710        let str = lit.value_as_str();
711
712        if str.is_none() {
713            cx.adcx().expected_string_literal(self.span(), Some(lit));
714        }
715
716        str
717    }
718}
719
720impl<'f, 'sess> Deref for AcceptContext<'f, 'sess> {
721    type Target = SharedContext<'f, 'sess>;
722
723    fn deref(&self) -> &Self::Target {
724        &self.shared
725    }
726}
727
728impl<'f, 'sess> DerefMut for AcceptContext<'f, 'sess> {
729    fn deref_mut(&mut self) -> &mut Self::Target {
730        &mut self.shared
731    }
732}
733
734/// Context given to every attribute parser during finalization.
735///
736/// Gives [`AttributeParser`](crate::attributes::AttributeParser)s enough information to create
737/// errors, for example.
738pub struct SharedContext<'p, 'sess> {
739    /// The parse context, gives access to the session and the
740    /// diagnostics context.
741    pub(crate) cx: &'p mut AttributeParser<'sess>,
742    /// The span of the syntactical component this attribute was applied to
743    pub(crate) target_span: Span,
744    pub(crate) target: rustc_hir::Target,
745
746    pub(crate) emit_lint: &'p mut dyn FnMut(LintId, MultiSpan, EmitAttribute),
747}
748
749/// Context given to every attribute parser during finalization.
750///
751/// Gives [`AttributeParser`](crate::attributes::AttributeParser)s enough information to create
752/// errors, for example.
753pub(crate) struct FinalizeContext<'p, 'sess> {
754    pub(crate) shared: SharedContext<'p, 'sess>,
755
756    /// A list of all attribute on this syntax node.
757    ///
758    /// Useful for compatibility checks with other attributes in [`finalize`](crate::attributes::AttributeParser::finalize)
759    ///
760    /// Usually, you should use normal attribute parsing logic instead,
761    /// especially when making a *denylist* of other attributes.
762    pub(crate) all_attrs: &'p [RefPathParser<'p>],
763}
764
765impl<'p, 'sess: 'p> Deref for FinalizeContext<'p, 'sess> {
766    type Target = SharedContext<'p, 'sess>;
767
768    fn deref(&self) -> &Self::Target {
769        &self.shared
770    }
771}
772
773impl<'p, 'sess: 'p> DerefMut for FinalizeContext<'p, 'sess> {
774    fn deref_mut(&mut self) -> &mut Self::Target {
775        &mut self.shared
776    }
777}
778
779impl<'p, 'sess: 'p> Deref for SharedContext<'p, 'sess> {
780    type Target = AttributeParser<'sess>;
781
782    fn deref(&self) -> &Self::Target {
783        self.cx
784    }
785}
786
787impl<'p, 'sess: 'p> DerefMut for SharedContext<'p, 'sess> {
788    fn deref_mut(&mut self) -> &mut Self::Target {
789        self.cx
790    }
791}
792
793#[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)]
794pub enum OmitDoc {
795    Lower,
796    Skip,
797}
798
799#[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)]
800pub enum ShouldEmit {
801    /// The operations will emit errors, and lints, and errors are fatal.
802    ///
803    /// Only relevant when early parsing, in late parsing equivalent to `ErrorsAndLints`.
804    /// Late parsing is never fatal, and instead tries to emit as many diagnostics as possible.
805    EarlyFatal { also_emit_lints: bool },
806    /// The operation will emit errors and lints.
807    /// This is usually what you need.
808    ErrorsAndLints {
809        /// Whether [`ArgParser`] will attempt to recover from errors.
810        ///
811        /// Whether it is allowed to recover from bad input (like an invalid literal). Setting
812        /// this to `Forbidden` will instead return early, and not raise errors except at the top
813        /// level (in [`ArgParser::from_attr_args`]).
814        recovery: Recovery,
815    },
816    /// The operation will *not* emit errors and lints.
817    ///
818    /// The parser can still call `delay_bug`, so you *must* ensure that this operation will also be
819    /// called with `ShouldEmit::ErrorsAndLints`.
820    Nothing,
821}
822
823impl ShouldEmit {
824    pub(crate) fn emit_err(&self, diag: Diag<'_>) -> ErrorGuaranteed {
825        match self {
826            ShouldEmit::EarlyFatal { .. } if diag.level() == Level::DelayedBug => diag.emit(),
827            ShouldEmit::EarlyFatal { .. } => diag.upgrade_to_fatal().emit(),
828            ShouldEmit::ErrorsAndLints { .. } => diag.emit(),
829            ShouldEmit::Nothing => diag.delay_as_bug(),
830        }
831    }
832}
833
834pub(crate) struct AttributeDiagnosticContext<'a, 'f, 'sess> {
835    ctx: &'a mut AcceptContext<'f, 'sess>,
836    custom_suggestions: Vec<Suggestion>,
837}
838
839impl<'a, 'f, 'sess: 'f> AttributeDiagnosticContext<'a, 'f, 'sess> {
840    fn emit_parse_error(
841        &mut self,
842        span: Span,
843        reason: AttributeParseErrorReason<'_>,
844    ) -> ErrorGuaranteed {
845        let suggestions = if !self.custom_suggestions.is_empty() {
846            AttributeParseErrorSuggestions::CreatedByParser(mem::take(&mut self.custom_suggestions))
847        } else {
848            AttributeParseErrorSuggestions::CreatedByTemplate(self.template_suggestions())
849        };
850
851        self.emit_err(AttributeParseError {
852            span,
853            attr_span: self.attr_span,
854            template: self.template.clone(),
855            path: self.attr_path.clone(),
856            description: self.parsed_description,
857            reason,
858            suggestions,
859        })
860    }
861
862    /// Adds a custom suggestion to the diagnostic. This also prevents the default (template-based)
863    /// suggestion to be emitted.
864    pub(crate) fn push_suggestion(&mut self, msg: String, span: Span, code: String) -> &mut Self {
865        self.custom_suggestions.push(Suggestion { msg, sp: span, code });
866        self
867    }
868
869    pub(crate) fn template_suggestions(&self) -> Vec<String> {
870        let style = match self.parsed_description {
871            // If the outer and inner spans are equal, we are parsing an embedded attribute
872            ParsedDescription::Attribute if self.attr_span == self.inner_span => {
873                AttrSuggestionStyle::EmbeddedAttribute
874            }
875            ParsedDescription::Attribute => AttrSuggestionStyle::Attribute(self.attr_style),
876            ParsedDescription::Macro => AttrSuggestionStyle::Macro,
877        };
878
879        self.template.suggestions(style, self.attr_safety, &self.attr_path)
880    }
881}
882
883/// Helpers that can be used to generate errors during attribute parsing.
884impl<'a, 'f, 'sess: 'f> AttributeDiagnosticContext<'a, 'f, 'sess> {
885    pub(crate) fn expected_integer_literal_in_range(
886        &mut self,
887        span: Span,
888        lower_bound: isize,
889        upper_bound: isize,
890    ) -> ErrorGuaranteed {
891        self.emit_parse_error(
892            span,
893            AttributeParseErrorReason::ExpectedIntegerLiteralInRange { lower_bound, upper_bound },
894        )
895    }
896
897    /// The provided span is used as a fallback in case `args` does not contain any. It should be
898    /// the span of the node that contains `args`.
899    pub(crate) fn expected_list(&mut self, span: Span, args: &ArgParser) -> ErrorGuaranteed {
900        let span = match args {
901            ArgParser::NoArgs => span,
902            ArgParser::List(list) => list.span,
903            ArgParser::NameValue(nv) => nv.args_span(),
904        };
905        self.emit_parse_error(span, AttributeParseErrorReason::ExpectedList)
906    }
907
908    pub(crate) fn expected_list_with_num_args_or_more(
909        &mut self,
910        args: usize,
911        span: Span,
912    ) -> ErrorGuaranteed {
913        self.emit_parse_error(
914            span,
915            AttributeParseErrorReason::ExpectedListWithNumArgsOrMore { args },
916        )
917    }
918
919    pub(crate) fn expected_list_or_no_args(&mut self, span: Span) -> ErrorGuaranteed {
920        self.emit_parse_error(span, AttributeParseErrorReason::ExpectedListOrNoArgs)
921    }
922
923    pub(crate) fn expected_nv_or_no_args(&mut self, span: Span) -> ErrorGuaranteed {
924        self.emit_parse_error(span, AttributeParseErrorReason::ExpectedNameValueOrNoArgs)
925    }
926
927    pub(crate) fn expected_non_empty_string_literal(&mut self, span: Span) -> ErrorGuaranteed {
928        self.emit_parse_error(span, AttributeParseErrorReason::ExpectedNonEmptyStringLiteral)
929    }
930
931    pub(crate) fn expected_no_args(&mut self, span: Span) -> ErrorGuaranteed {
932        self.emit_parse_error(span, AttributeParseErrorReason::ExpectedNoArgs)
933    }
934
935    /// Emit an error that a `name` was expected here
936    pub(crate) fn expected_identifier(&mut self, span: Span) -> ErrorGuaranteed {
937        self.emit_parse_error(span, AttributeParseErrorReason::ExpectedIdentifier)
938    }
939
940    /// Emit an error that a `name = value` pair was expected at this span. The symbol can be given for
941    /// a nicer error message talking about the specific name that was found lacking a value.
942    fn expected_name_value(&mut self, span: Span, name: Option<Symbol>) -> ErrorGuaranteed {
943        self.emit_parse_error(span, AttributeParseErrorReason::ExpectedNameValue(name))
944    }
945
946    /// Emit an error that a `name = value` argument is missing in a list of name-value pairs.
947    pub(crate) fn missing_name_value(&mut self, span: Span, name: Symbol) -> ErrorGuaranteed {
948        self.emit_parse_error(span, AttributeParseErrorReason::MissingNameValue(name))
949    }
950
951    /// Emit an error that a `name = value` pair was found where that name was already seen.
952    pub(crate) fn duplicate_key(&mut self, span: Span, key: Symbol) -> ErrorGuaranteed {
953        self.emit_parse_error(span, AttributeParseErrorReason::DuplicateKey(key))
954    }
955
956    /// An error that should be emitted when a [`MetaItemOrLitParser`]
957    /// was expected *not* to be a literal, but instead a meta item.
958    pub(crate) fn expected_not_literal(&mut self, span: Span) -> ErrorGuaranteed {
959        self.emit_parse_error(span, AttributeParseErrorReason::ExpectedNotLiteral)
960    }
961
962    /// Signals that we expected exactly one argument and that we got either zero or two or more.
963    /// The `provided_arguments` argument allows distinguishing between "expected an argument here"
964    /// (when zero arguments are provided) and "expect a single argument here" (when two or more
965    /// arguments are provided).
966    pub(crate) fn expected_single_argument(
967        &mut self,
968        span: Span,
969        provided_arguments: usize,
970    ) -> ErrorGuaranteed {
971        let reason = if provided_arguments == 0 {
972            AttributeParseErrorReason::ExpectedArgument
973        } else {
974            AttributeParseErrorReason::ExpectedSingleArgument
975        };
976
977        self.emit_parse_error(span, reason)
978    }
979
980    pub(crate) fn expected_at_least_one_argument(&mut self, span: Span) -> ErrorGuaranteed {
981        self.emit_parse_error(span, AttributeParseErrorReason::ExpectedAtLeastOneArgument)
982    }
983
984    /// Produces an error along the lines of `expected one of [foo, meow]`
985    pub(crate) fn expected_specific_argument(
986        &mut self,
987        span: Span,
988        possibilities: &[Symbol],
989    ) -> ErrorGuaranteed {
990        self.emit_parse_error(
991            span,
992            AttributeParseErrorReason::ExpectedSpecificArgument {
993                possibilities,
994                strings: false,
995                list: false,
996            },
997        )
998    }
999
1000    /// Produces an error along the lines of `expected one of [foo, meow] as an argument`.
1001    /// i.e. slightly different wording to [`expected_specific_argument`](Self::expected_specific_argument).
1002    pub(crate) fn expected_specific_argument_and_list(
1003        &mut self,
1004        span: Span,
1005        possibilities: &[Symbol],
1006    ) -> ErrorGuaranteed {
1007        self.emit_parse_error(
1008            span,
1009            AttributeParseErrorReason::ExpectedSpecificArgument {
1010                possibilities,
1011                strings: false,
1012                list: true,
1013            },
1014        )
1015    }
1016
1017    /// produces an error along the lines of `expected one of ["foo", "meow"]`
1018    pub(crate) fn expected_specific_argument_strings(
1019        &mut self,
1020        span: Span,
1021        possibilities: &[Symbol],
1022    ) -> ErrorGuaranteed {
1023        self.emit_parse_error(
1024            span,
1025            AttributeParseErrorReason::ExpectedSpecificArgument {
1026                possibilities,
1027                strings: true,
1028                list: false,
1029            },
1030        )
1031    }
1032
1033    pub(crate) fn warn_empty_attribute(&mut self, span: Span) {
1034        let attr_path = self.attr_path.to_string();
1035        let valid_without_list = self.template.word;
1036        self.emit_lint(
1037            rustc_session::lint::builtin::UNUSED_ATTRIBUTES,
1038            crate::errors::EmptyAttributeList { attr_span: span, attr_path, valid_without_list },
1039            span,
1040        );
1041    }
1042
1043    pub(crate) fn warn_ill_formed_attribute_input(&mut self, lint: &'static Lint) {
1044        self.warn_ill_formed_attribute_input_with_help(lint, None)
1045    }
1046    pub(crate) fn warn_ill_formed_attribute_input_with_help(
1047        &mut self,
1048        lint: &'static Lint,
1049        help: Option<String>,
1050    ) {
1051        let suggestions = self.suggestions();
1052        let span = self.attr_span;
1053        self.emit_lint(
1054            lint,
1055            crate::errors::IllFormedAttributeInput::new(&suggestions, None, help.as_deref()),
1056            span,
1057        );
1058    }
1059
1060    pub(crate) fn suggestions(&self) -> Vec<String> {
1061        let style = match self.parsed_description {
1062            // If the outer and inner spans are equal, we are parsing an embedded attribute
1063            ParsedDescription::Attribute if self.attr_span == self.inner_span => {
1064                AttrSuggestionStyle::EmbeddedAttribute
1065            }
1066            ParsedDescription::Attribute => AttrSuggestionStyle::Attribute(self.attr_style),
1067            ParsedDescription::Macro => AttrSuggestionStyle::Macro,
1068        };
1069
1070        self.template.suggestions(style, self.attr_safety, &self.attr_path)
1071    }
1072    /// Error that a string literal was expected.
1073    /// You can optionally give the literal you did find (which you found not to be a string literal)
1074    /// which can make better errors. For example, if the literal was a byte string it will suggest
1075    /// removing the `b` prefix.
1076    pub(crate) fn expected_string_literal(
1077        &mut self,
1078        span: Span,
1079        actual_literal: Option<&MetaItemLit>,
1080    ) -> ErrorGuaranteed {
1081        self.emit_parse_error(
1082            span,
1083            AttributeParseErrorReason::ExpectedStringLiteral {
1084                byte_string: actual_literal.and_then(|i| {
1085                    i.kind.is_bytestr().then(|| self.sess().source_map().start_point(i.span))
1086                }),
1087            },
1088        )
1089    }
1090
1091    /// Error that a filename string literal was expected.
1092    pub(crate) fn expected_filename_literal(&mut self, span: Span) {
1093        self.emit_parse_error(span, AttributeParseErrorReason::ExpectedFilenameLiteral);
1094    }
1095
1096    pub(crate) fn expected_integer_literal(&mut self, span: Span) -> ErrorGuaranteed {
1097        self.emit_parse_error(span, AttributeParseErrorReason::ExpectedIntegerLiteral)
1098    }
1099}
1100
1101impl<'a, 'f, 'sess: 'f> Deref for AttributeDiagnosticContext<'a, 'f, 'sess> {
1102    type Target = AcceptContext<'f, 'sess>;
1103
1104    fn deref(&self) -> &Self::Target {
1105        self.ctx
1106    }
1107}
1108
1109impl<'a, 'f, 'sess: 'f> DerefMut for AttributeDiagnosticContext<'a, 'f, 'sess> {
1110    fn deref_mut(&mut self) -> &mut Self::Target {
1111        self.ctx
1112    }
1113}
1114
1115/// Represents a custom suggestion that an attribute parser can emit.
1116pub(crate) struct Suggestion {
1117    pub(crate) msg: String,
1118    pub(crate) sp: Span,
1119    pub(crate) code: String,
1120}