summaryrefslogtreecommitdiff
path: root/src/systems/growth.rs
diff options
context:
space:
mode:
authortroido <troido@protonmail.com>2020-04-13 12:03:44 +0200
committertroido <troido@protonmail.com>2020-04-13 12:03:44 +0200
commit88d3414f523d01a0109604103e6aeb8b68a7fa20 (patch)
treea102e4fa9d4b7acd164830295944e973aa4d6dac /src/systems/growth.rs
parent9bc90bcff5bec4fbb03a568f59e14b1b016e0e44 (diff)
grow is now also using build trigger/component
Diffstat (limited to 'src/systems/growth.rs')
-rw-r--r--src/systems/growth.rs31
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);
}
}
}