Skip to content

Commit

Permalink
Add Bevy related test cases
Browse files Browse the repository at this point in the history
  • Loading branch information
spastorino committed Dec 8, 2023
1 parent 287c77e commit adea760
Show file tree
Hide file tree
Showing 3 changed files with 58 additions and 0 deletions.
16 changes: 16 additions & 0 deletions tests/ui/implied-bounds/auxiliary/bevy_ecs.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
pub mod system {
pub trait WorldQuery {}
impl WorldQuery for &u8 {}

pub struct Query<Q: WorldQuery>(Q);

pub trait SystemParam {
type State;
}
impl<Q: WorldQuery + 'static> SystemParam for Query<Q> {
type State = ();
// `Q: 'static` is required because we need the TypeId of Q ...
}

pub struct ParamSet<T: SystemParam>(T) where T::State: Sized;
}
13 changes: 13 additions & 0 deletions tests/ui/implied-bounds/bevy_world_query.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
// aux-crate:bevy_ecs=bevy_ecs.rs
// check-pass

// We currently special case bevy from emitting the `IMPLIED_BOUNDS_FROM_TRAIT_IMPL` lint.
// Otherwise, we would expect this to hit the lint.

extern crate bevy_ecs;

use bevy_ecs::system::*;

fn handler<'a>(_: ParamSet<Query<&'a u8>>) {}

fn main() {}
29 changes: 29 additions & 0 deletions tests/ui/implied-bounds/gluon_salsa.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
// check-pass

pub trait QueryBase {
type Db;
}

pub trait AsyncQueryFunction<'f>: // 'f is important
QueryBase<Db = <Self as AsyncQueryFunction<'f>>::SendDb> // bound is important
{
type SendDb;
}

pub struct QueryTable<'me, Q, DB> {
_q: Option<Q>,
_db: Option<DB>,
_marker: Option<&'me ()>,
}

impl<'me, Q> QueryTable<'me, Q, <Q as QueryBase>::Db> // projection is important
// ^^^ removing 'me (and in QueryTable) gives a different error
where
Q: for<'f> AsyncQueryFunction<'f>,
{
pub fn get_async<'a>(&'a mut self) {
panic!();
}
}

fn main() {}

0 comments on commit adea760

Please sign in to comment.