diff options
Diffstat (limited to 'src/systems/growth.rs')
| -rw-r--r-- | src/systems/growth.rs | 31 |
1 files changed, 12 insertions, 19 deletions
diff --git a/src/systems/growth.rs b/src/systems/growth.rs index 97ae5f3..b1b1af5 100644 --- a/src/systems/growth.rs +++ b/src/systems/growth.rs @@ -2,24 +2,20 @@ use rand; use specs::{ - ReadStorage, WriteStorage, Entities, System, Join, - Write, Read }; use crate::{ components::{ - Position, Grow, - Removed, - CreationTime + OwnTime, + TriggerBox }, - resources::{NewEntities, Time}, - componentwrapper::ComponentWrapper + resources::{Time} }; @@ -27,28 +23,25 @@ pub struct Growth; impl <'a> System<'a> for Growth{ type SystemData = ( Entities<'a>, - ReadStorage<'a, Position>, - Write<'a, NewEntities>, WriteStorage<'a, Grow>, - WriteStorage<'a, Removed>, + WriteStorage<'a, TriggerBox>, Read<'a, Time>, - ReadStorage<'a, CreationTime> + WriteStorage<'a, OwnTime> ); - fn run(&mut self, (entities, positions, mut new, mut grows, mut removeds, time, creation_times): Self::SystemData) { - for (entity, position, grow) in (&entities, &positions, &mut grows).join(){ - let creation_time = creation_times.get(entity).map(|ct| ct.time).unwrap_or(time.time); + fn run(&mut self, (entities, mut grows, mut triggerboxes, time, mut own_times): Self::SystemData) { + for (entity, grow) in (&entities, &mut grows).join(){ if grow.target_time == None { + let creation_time = own_times.get(entity).map(|ct| ct.time).unwrap_or(time.time); let duration = grow.delay as f64 * (1.0 + rand::random::<f64>()) / (if rand::random() {1.0} else {2.0}); grow.target_time = Some(creation_time + duration as i64); } let target_time = grow.target_time.unwrap(); if target_time <= time.time { - removeds.insert(entity, Removed).unwrap(); - // todo: error handling - let mut preent = new.encyclopedia.construct(&grow.into).unwrap(); - preent.push(ComponentWrapper::CreationTime(CreationTime{time: target_time + 1})); - new.to_build.push((position.pos, preent)); + if target_time + 1 < time.time { + own_times.insert(entity, OwnTime{time: target_time + 1}).unwrap(); + } + TriggerBox::add_message(&mut triggerboxes, entity, grow.trigger); } } } |
