Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
bevyengine
GitHub Repository: bevyengine/bevy
Path: blob/main/crates/bevy_reflect/derive/src/impls/tuple_structs.rs
6600 views
1
use crate::{
2
impls::{common_partial_reflect_methods, impl_full_reflect, impl_type_path, impl_typed},
3
struct_utility::FieldAccessors,
4
ReflectStruct,
5
};
6
use bevy_macro_utils::fq_std::{FQDefault, FQOption, FQResult};
7
use quote::{quote, ToTokens};
8
9
/// Implements `TupleStruct`, `GetTypeRegistration`, and `Reflect` for the given derive data.
10
pub(crate) fn impl_tuple_struct(reflect_struct: &ReflectStruct) -> proc_macro2::TokenStream {
11
let fqoption = FQOption.into_token_stream();
12
13
let bevy_reflect_path = reflect_struct.meta().bevy_reflect_path();
14
let struct_path = reflect_struct.meta().type_path();
15
16
let FieldAccessors {
17
fields_ref,
18
fields_mut,
19
field_indices,
20
field_count,
21
..
22
} = FieldAccessors::new(reflect_struct);
23
24
let where_clause_options = reflect_struct.where_clause_options();
25
let get_type_registration_impl = reflect_struct.get_type_registration(&where_clause_options);
26
27
let typed_impl = impl_typed(&where_clause_options, reflect_struct.to_info_tokens(true));
28
29
let type_path_impl = impl_type_path(reflect_struct.meta());
30
let full_reflect_impl = impl_full_reflect(&where_clause_options);
31
let common_methods = common_partial_reflect_methods(
32
reflect_struct.meta(),
33
|| Some(quote!(#bevy_reflect_path::tuple_struct_partial_eq)),
34
|| None,
35
);
36
let clone_fn = reflect_struct.get_clone_impl();
37
38
#[cfg(not(feature = "functions"))]
39
let function_impls = None::<proc_macro2::TokenStream>;
40
#[cfg(feature = "functions")]
41
let function_impls = crate::impls::impl_function_traits(&where_clause_options);
42
43
let (impl_generics, ty_generics, where_clause) = reflect_struct
44
.meta()
45
.type_path()
46
.generics()
47
.split_for_impl();
48
49
#[cfg(not(feature = "auto_register"))]
50
let auto_register = None::<proc_macro2::TokenStream>;
51
#[cfg(feature = "auto_register")]
52
let auto_register = crate::impls::reflect_auto_registration(reflect_struct.meta());
53
54
let where_reflect_clause = where_clause_options.extend_where_clause(where_clause);
55
56
quote! {
57
#get_type_registration_impl
58
59
#typed_impl
60
61
#type_path_impl
62
63
#full_reflect_impl
64
65
#function_impls
66
67
#auto_register
68
69
impl #impl_generics #bevy_reflect_path::TupleStruct for #struct_path #ty_generics #where_reflect_clause {
70
fn field(&self, index: usize) -> #FQOption<&dyn #bevy_reflect_path::PartialReflect> {
71
match index {
72
#(#field_indices => #fqoption::Some(#fields_ref),)*
73
_ => #FQOption::None,
74
}
75
}
76
77
fn field_mut(&mut self, index: usize) -> #FQOption<&mut dyn #bevy_reflect_path::PartialReflect> {
78
match index {
79
#(#field_indices => #fqoption::Some(#fields_mut),)*
80
_ => #FQOption::None,
81
}
82
}
83
#[inline]
84
fn field_len(&self) -> usize {
85
#field_count
86
}
87
#[inline]
88
fn iter_fields(&self) -> #bevy_reflect_path::TupleStructFieldIter {
89
#bevy_reflect_path::TupleStructFieldIter::new(self)
90
}
91
92
fn to_dynamic_tuple_struct(&self) -> #bevy_reflect_path::DynamicTupleStruct {
93
let mut dynamic: #bevy_reflect_path::DynamicTupleStruct = #FQDefault::default();
94
dynamic.set_represented_type(#bevy_reflect_path::PartialReflect::get_represented_type_info(self));
95
#(dynamic.insert_boxed(#bevy_reflect_path::PartialReflect::to_dynamic(#fields_ref));)*
96
dynamic
97
}
98
}
99
100
impl #impl_generics #bevy_reflect_path::PartialReflect for #struct_path #ty_generics #where_reflect_clause {
101
#[inline]
102
fn get_represented_type_info(&self) -> #FQOption<&'static #bevy_reflect_path::TypeInfo> {
103
#FQOption::Some(<Self as #bevy_reflect_path::Typed>::type_info())
104
}
105
106
#[inline]
107
fn try_apply(
108
&mut self,
109
value: &dyn #bevy_reflect_path::PartialReflect
110
) -> #FQResult<(), #bevy_reflect_path::ApplyError> {
111
if let #bevy_reflect_path::ReflectRef::TupleStruct(struct_value) =
112
#bevy_reflect_path::PartialReflect::reflect_ref(value) {
113
for (i, value) in ::core::iter::Iterator::enumerate(#bevy_reflect_path::TupleStruct::iter_fields(struct_value)) {
114
if let #FQOption::Some(v) = #bevy_reflect_path::TupleStruct::field_mut(self, i) {
115
#bevy_reflect_path::PartialReflect::try_apply(v, value)?;
116
}
117
}
118
} else {
119
return #FQResult::Err(
120
#bevy_reflect_path::ApplyError::MismatchedKinds {
121
from_kind: #bevy_reflect_path::PartialReflect::reflect_kind(value),
122
to_kind: #bevy_reflect_path::ReflectKind::TupleStruct,
123
}
124
);
125
}
126
#FQResult::Ok(())
127
}
128
#[inline]
129
fn reflect_kind(&self) -> #bevy_reflect_path::ReflectKind {
130
#bevy_reflect_path::ReflectKind::TupleStruct
131
}
132
#[inline]
133
fn reflect_ref(&self) -> #bevy_reflect_path::ReflectRef {
134
#bevy_reflect_path::ReflectRef::TupleStruct(self)
135
}
136
#[inline]
137
fn reflect_mut(&mut self) -> #bevy_reflect_path::ReflectMut {
138
#bevy_reflect_path::ReflectMut::TupleStruct(self)
139
}
140
#[inline]
141
fn reflect_owned(self: #bevy_reflect_path::__macro_exports::alloc_utils::Box<Self>) -> #bevy_reflect_path::ReflectOwned {
142
#bevy_reflect_path::ReflectOwned::TupleStruct(self)
143
}
144
145
#common_methods
146
147
#clone_fn
148
}
149
}
150
}
151
152