mirror of
https://github.com/bevyengine/bevy
synced 2025-01-28 04:45:15 +00:00
8e1f660e1d
# Objective Emitting compile errors produces cleaner messages than panicking in a proc-macro. ## Solution - Replace match-with-panic code with call to new `bevy_macro_utils::get_named_struct_fields` function - Replace one use of match-with-panic for enums with inline match _Aside:_ I'm also the maintainer of [`darling`](https://docs.rs/darling), a crate which provides a serde-like API for parsing macro inputs. I avoided using it here because it seemed like overkill, but if there are plans to add lots more attributes/macros then that might be a good way of offloading macro error handling.
20 lines
851 B
Rust
20 lines
851 B
Rust
use proc_macro::Span;
|
|
use syn::{Data, DataStruct, Error, Fields, FieldsNamed};
|
|
|
|
/// Get the fields of a data structure if that structure is a struct with named fields;
|
|
/// otherwise, return a compile error that points to the site of the macro invocation.
|
|
pub fn get_named_struct_fields(data: &syn::Data) -> syn::Result<&FieldsNamed> {
|
|
match data {
|
|
Data::Struct(DataStruct {
|
|
fields: Fields::Named(fields),
|
|
..
|
|
}) => Ok(fields),
|
|
_ => Err(Error::new(
|
|
// This deliberately points to the call site rather than the structure
|
|
// body; marking the entire body as the source of the error makes it
|
|
// impossible to figure out which `derive` has a problem.
|
|
Span::call_site().into(),
|
|
"Only structs with named fields are supported",
|
|
)),
|
|
}
|
|
}
|