diff options
Diffstat (limited to 'src/server.rs')
-rw-r--r-- | src/server.rs | 34 |
1 files changed, 17 insertions, 17 deletions
diff --git a/src/server.rs b/src/server.rs index 4593cfa..aa3e3dc 100644 --- a/src/server.rs +++ b/src/server.rs @@ -549,42 +549,42 @@ fn effective_stats( } fn buffs_tick(mut buffses: Query<&mut Buffs>, time: Res<Time>) { - let dt = time.delta(); + let dt = time.delta().as_secs_f32(); for mut buffs in buffses.iter_mut() { - if let Some(ref mut timer) = &mut buffs.haste { - timer.tick(dt); + if let Some(ref mut duration) = &mut buffs.haste { + *duration = (*duration - dt).max(0.); } - if let Some(ref mut timer) = &mut buffs.shield { - timer.tick(dt); + if let Some(ref mut duration) = &mut buffs.shield { + *duration = (*duration - dt).max(0.); } - if let Some(ref mut timer) = &mut buffs.slow { - timer.tick(dt); + if let Some(ref mut duration) = &mut buffs.slow { + *duration = (*duration - dt).max(0.); } - if let Some(ref mut timer) = &mut buffs.speed { - timer.tick(dt); + if let Some(ref mut duration) = &mut buffs.speed { + *duration = (*duration - dt).max(0.); } } } fn buffs_despawn(mut buffses: Query<&mut Buffs>) { for mut buffs in buffses.iter_mut() { - if let Some(timer) = &buffs.haste { - if timer.finished() { + if let Some(duration) = &buffs.haste { + if *duration <= 0. { buffs.haste = None; } } - if let Some(timer) = &buffs.shield { - if timer.finished() { + if let Some(duration) = &buffs.shield { + if *duration <= 0. { buffs.shield = None; } } - if let Some(timer) = &buffs.slow { - if timer.finished() { + if let Some(duration) = &buffs.slow { + if *duration <= 0. { buffs.slow = None; } } - if let Some(timer) = &buffs.speed { - if timer.finished() { + if let Some(duration) = &buffs.speed { + if *duration <= 0. { buffs.speed = None; } } |