 8e1f660e1d
			
		
	
	
		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.
		
			
				
	
	
		
			21 lines
		
	
	
		
			851 B
		
	
	
	
		
			Rust
		
	
	
	
	
	
			
		
		
	
	
			21 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",
 | |
|         )),
 | |
|     }
 | |
| }
 |