From 5450bf36bf2886541f148ff4930cc52265eb5182 Mon Sep 17 00:00:00 2001 From: Isse <41273856+IsseW@users.noreply.github.com> Date: Mon, 27 Nov 2023 03:00:52 +0100 Subject: [PATCH] Fix paths in SystemData macro (#232) * fix paths in SystemData macro * remove leading :: * revert unintended changes * add missed path * fix examples and tests without default features --- examples/async.rs | 2 +- examples/derive_bundle.rs | 4 +++- examples/generic_derive.rs | 2 +- examples/seq_dispatch.rs | 4 +++- shred-derive/src/lib.rs | 22 +++++++++++----------- tests/dispatch.rs | 6 +++--- 6 files changed, 22 insertions(+), 18 deletions(-) diff --git a/examples/async.rs b/examples/async.rs index a69a0f43..d123c188 100644 --- a/examples/async.rs +++ b/examples/async.rs @@ -1,6 +1,6 @@ extern crate shred; -use shred::{DispatcherBuilder, Read, ResourceId, System, SystemData, World, Write}; +use shred::{DispatcherBuilder, Read, System, SystemData, World, Write}; #[derive(Debug, Default)] struct ResA; diff --git a/examples/derive_bundle.rs b/examples/derive_bundle.rs index 1a016729..b16a15dc 100644 --- a/examples/derive_bundle.rs +++ b/examples/derive_bundle.rs @@ -1,4 +1,6 @@ -use shred::{Read, ResourceId, SystemData, World, Write}; +#[cfg(not(feature = "shred-derive"))] +use shred::ResourceId; +use shred::{Read, SystemData, World, Write}; #[derive(Debug, Default)] struct ResA; diff --git a/examples/generic_derive.rs b/examples/generic_derive.rs index 6669c778..b029a917 100644 --- a/examples/generic_derive.rs +++ b/examples/generic_derive.rs @@ -6,7 +6,7 @@ extern crate shred_derive; use std::fmt::Debug; -use shred::{Read, Resource, ResourceId, SystemData, World, Write}; +use shred::{Read, Resource, SystemData, Write}; trait Hrtb<'a> {} diff --git a/examples/seq_dispatch.rs b/examples/seq_dispatch.rs index 215dd598..a07eecdd 100644 --- a/examples/seq_dispatch.rs +++ b/examples/seq_dispatch.rs @@ -1,4 +1,6 @@ -use shred::{DispatcherBuilder, Read, ResourceId, System, SystemData, World, Write}; +#[cfg(not(feature = "shred-derive"))] +use shred::ResourceId; +use shred::{DispatcherBuilder, Read, System, SystemData, World, Write}; #[derive(Debug, Default)] struct ResA; diff --git a/shred-derive/src/lib.rs b/shred-derive/src/lib.rs index 5eb7041a..757eb8d9 100644 --- a/shred-derive/src/lib.rs +++ b/shred-derive/src/lib.rs @@ -58,35 +58,35 @@ fn impl_system_data(ast: &DeriveInput) -> proc_macro2::TokenStream { quote! { impl #impl_generics - SystemData< #impl_fetch_lt > + shred::SystemData< #impl_fetch_lt > for #name #ty_generics #where_clause { - fn setup(world: &mut World) { + fn setup(world: &mut shred::World) { #( - <#tys as SystemData> :: setup(world); + <#tys as shred::SystemData> :: setup(world); )* } - fn fetch(world: & #impl_fetch_lt World) -> Self { + fn fetch(world: & #impl_fetch_lt shred::World) -> Self { #fetch_return } - fn reads() -> Vec { + fn reads() -> Vec { let mut r = Vec::new(); #( { - let mut reads = <#tys as SystemData> :: reads(); + let mut reads = <#tys as shred::SystemData> :: reads(); r.append(&mut reads); } )* r } - fn writes() -> Vec { + fn writes() -> Vec { let mut r = Vec::new(); #( { - let mut writes = <#tys as SystemData> :: writes(); + let mut writes = <#tys as shred::SystemData> :: writes(); r.append(&mut writes); } )* @@ -107,7 +107,7 @@ fn gen_identifiers(fields: &Punctuated) -> Vec { /// Adds a `SystemData<'lt>` bound on each of the system data types. fn constrain_system_data_types(clause: &mut WhereClause, fetch_lt: &Lifetime, tys: &[Type]) { for ty in tys.iter() { - let where_predicate: WherePredicate = parse_quote!(#ty : SystemData< #fetch_lt >); + let where_predicate: WherePredicate = parse_quote!(#ty : shred::SystemData< #fetch_lt >); clause.predicates.push(where_predicate); } } @@ -138,13 +138,13 @@ fn gen_from_body(ast: &Data, name: &Ident) -> (proc_macro2::TokenStream, Vec { let count = tys.len(); - let fetch = vec![quote! { SystemData::fetch(world) }; count]; + let fetch = vec![quote! { shred::SystemData::fetch(world) }; count]; quote! { #name ( #( #fetch ),* ) diff --git a/tests/dispatch.rs b/tests/dispatch.rs index 6eaca2d5..02741b7a 100644 --- a/tests/dispatch.rs +++ b/tests/dispatch.rs @@ -1,6 +1,6 @@ -use shred::{ - Dispatcher, DispatcherBuilder, Read, ResourceId, RunningTime, System, SystemData, World, Write, -}; +#[cfg(not(feature = "shred-derive"))] +use shred::ResourceId; +use shred::{Dispatcher, DispatcherBuilder, Read, RunningTime, System, SystemData, World, Write}; fn sleep_short() { use std::{thread::sleep, time::Duration};