 694c06f3d0
			
		
	
	
		694c06f3d0
		
			
		
	
	
	
	
		
			
			# Objective Currently the `missing_docs` lint is allowed-by-default and enabled at crate level when their documentations is complete (see #3492). This PR proposes to inverse this logic by making `missing_docs` warn-by-default and mark crates with imcomplete docs allowed. ## Solution Makes `missing_docs` warn at workspace level and allowed at crate level when the docs is imcomplete.
		
			
				
	
	
		
			101 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
			
		
		
	
	
			101 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
| // FIXME(3492): remove once docs are ready
 | |
| #![allow(missing_docs)]
 | |
| 
 | |
| mod as_bind_group;
 | |
| mod extract_component;
 | |
| mod extract_resource;
 | |
| 
 | |
| use bevy_macro_utils::{derive_label, BevyManifest};
 | |
| use proc_macro::TokenStream;
 | |
| use quote::format_ident;
 | |
| use syn::{parse_macro_input, DeriveInput};
 | |
| 
 | |
| pub(crate) fn bevy_render_path() -> syn::Path {
 | |
|     BevyManifest::default()
 | |
|         .maybe_get_path("bevy_render")
 | |
|         // NOTE: If the derivation is within bevy_render, then we need to return 'crate'
 | |
|         .unwrap_or_else(|| BevyManifest::parse_str("crate"))
 | |
| }
 | |
| 
 | |
| #[proc_macro_derive(ExtractResource)]
 | |
| pub fn derive_extract_resource(input: TokenStream) -> TokenStream {
 | |
|     extract_resource::derive_extract_resource(input)
 | |
| }
 | |
| 
 | |
| /// Implements `ExtractComponent` trait for a component.
 | |
| /// The component must implement [`Clone`].
 | |
| /// The component will be extracted into the render world via cloning.
 | |
| /// Note that this only enables extraction of the component, it does not execute the extraction.
 | |
| /// See `ExtractComponentPlugin` to actually perform the extraction.
 | |
| ///
 | |
| /// If you only want to extract a component conditionally, you may use the `extract_component_filter` attribute.
 | |
| ///
 | |
| /// # Example
 | |
| ///
 | |
| /// ```no_compile
 | |
| /// use bevy_ecs::component::Component;
 | |
| /// use bevy_render_macros::ExtractComponent;
 | |
| ///
 | |
| /// #[derive(Component, Clone, ExtractComponent)]
 | |
| /// #[extract_component_filter(With<Camera>)]
 | |
| /// pub struct Foo {
 | |
| ///     pub should_foo: bool,
 | |
| /// }
 | |
| ///
 | |
| /// // Without a filter (unconditional).
 | |
| /// #[derive(Component, Clone, ExtractComponent)]
 | |
| /// pub struct Bar {
 | |
| ///     pub should_bar: bool,
 | |
| /// }
 | |
| /// ```
 | |
| #[proc_macro_derive(ExtractComponent, attributes(extract_component_filter))]
 | |
| pub fn derive_extract_component(input: TokenStream) -> TokenStream {
 | |
|     extract_component::derive_extract_component(input)
 | |
| }
 | |
| 
 | |
| #[proc_macro_derive(
 | |
|     AsBindGroup,
 | |
|     attributes(uniform, storage_texture, texture, sampler, bind_group_data, storage)
 | |
| )]
 | |
| pub fn derive_as_bind_group(input: TokenStream) -> TokenStream {
 | |
|     let input = parse_macro_input!(input as DeriveInput);
 | |
| 
 | |
|     as_bind_group::derive_as_bind_group(input).unwrap_or_else(|err| err.to_compile_error().into())
 | |
| }
 | |
| 
 | |
| /// Derive macro generating an impl of the trait `RenderLabel`.
 | |
| ///
 | |
| /// This does not work for unions.
 | |
| #[proc_macro_derive(RenderLabel)]
 | |
| pub fn derive_render_label(input: TokenStream) -> TokenStream {
 | |
|     let input = parse_macro_input!(input as DeriveInput);
 | |
|     let mut trait_path = bevy_render_path();
 | |
|     trait_path
 | |
|         .segments
 | |
|         .push(format_ident!("render_graph").into());
 | |
|     let mut dyn_eq_path = trait_path.clone();
 | |
|     trait_path
 | |
|         .segments
 | |
|         .push(format_ident!("RenderLabel").into());
 | |
|     dyn_eq_path.segments.push(format_ident!("DynEq").into());
 | |
|     derive_label(input, "RenderLabel", &trait_path, &dyn_eq_path)
 | |
| }
 | |
| 
 | |
| /// Derive macro generating an impl of the trait `RenderSubGraph`.
 | |
| ///
 | |
| /// This does not work for unions.
 | |
| #[proc_macro_derive(RenderSubGraph)]
 | |
| pub fn derive_render_sub_graph(input: TokenStream) -> TokenStream {
 | |
|     let input = parse_macro_input!(input as DeriveInput);
 | |
|     let mut trait_path = bevy_render_path();
 | |
|     trait_path
 | |
|         .segments
 | |
|         .push(format_ident!("render_graph").into());
 | |
|     let mut dyn_eq_path = trait_path.clone();
 | |
|     trait_path
 | |
|         .segments
 | |
|         .push(format_ident!("RenderSubGraph").into());
 | |
|     dyn_eq_path.segments.push(format_ident!("DynEq").into());
 | |
|     derive_label(input, "RenderSubGraph", &trait_path, &dyn_eq_path)
 | |
| }
 |