summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authortroido <troido@protonmail.com>2020-04-13 12:28:00 +0200
committertroido <troido@protonmail.com>2020-04-13 12:28:00 +0200
commit56f44d5898696d1af50f38009629384f8d38cb46 (patch)
tree9454fd0085faff433fd15bd08a5fcf405f40a40a /src
parent88d3414f523d01a0109604103e6aeb8b68a7fa20 (diff)
now use TimeOffset instead of OwnTime
Diffstat (limited to 'src')
-rw-r--r--src/components/mod.rs4
-rw-r--r--src/componentwrapper.rs6
-rw-r--r--src/room.rs2
-rw-r--r--src/systems/building.rs12
-rw-r--r--src/systems/growth.rs15
5 files changed, 21 insertions, 18 deletions
diff --git a/src/components/mod.rs b/src/components/mod.rs
index 53de41c..49aacfc 100644
--- a/src/components/mod.rs
+++ b/src/components/mod.rs
@@ -218,8 +218,8 @@ pub struct Grow {
#[derive(Component, Debug, Clone)]
#[storage(HashMapStorage)]
-pub struct OwnTime {
- pub time: Timestamp
+pub struct TimeOffset {
+ pub dtime: i64
}
diff --git a/src/componentwrapper.rs b/src/componentwrapper.rs
index 7a9f2a0..beee01f 100644
--- a/src/componentwrapper.rs
+++ b/src/componentwrapper.rs
@@ -217,11 +217,11 @@ components!(
Grow {
trigger: Trigger::from_str(&trigger).ok_or(aerr!("invalid trigger name {}", trigger))?,
delay,
- target_time: if target_time == 0 { None } else { Some(Timestamp(target_time)) }
- // please forgive me for using 0 as null
+ target_time: if target_time == -1 { None } else { Some(Timestamp(target_time)) }
+ // please forgive me for using -1 as null
};
Equipment () {panic!("equipment from parameters not implemented")};
- OwnTime (time: Int) {OwnTime{time: Timestamp(time)}};
+ TimeOffset (dtime: Int);
Flags (flags: List) {
Flags(
flags
diff --git a/src/room.rs b/src/room.rs
index 1051e28..afe617b 100644
--- a/src/room.rs
+++ b/src/room.rs
@@ -120,7 +120,7 @@ impl <'a, 'b>Room<'a, 'b> {
world.insert(NewEntities::new(encyclopedia));
register_insert!(
world,
- (Position, Visible, Controller, Movable, New, Removed, Moved, Player, Inventory, Health, Serialise, RoomExit, Entered, TriggerBox, Trap, Fighter, Healing, Volatile, ControlCooldown, Autofight, MonsterAI, Home, AttackInbox, Item, Spawner, Clan, Faction, Interactable, Loot, Grow, Equipment, OwnTime, Flags, Ear, Build),
+ (Position, Visible, Controller, Movable, New, Removed, Moved, Player, Inventory, Health, Serialise, RoomExit, Entered, TriggerBox, Trap, Fighter, Healing, Volatile, ControlCooldown, Autofight, MonsterAI, Home, AttackInbox, Item, Spawner, Clan, Faction, Interactable, Loot, Grow, Equipment, TimeOffset, Flags, Ear, Build),
(Ground, Input, Output, Size, Spawn, Players, Emigration, Time)
);
diff --git a/src/systems/building.rs b/src/systems/building.rs
index 8459144..0f23467 100644
--- a/src/systems/building.rs
+++ b/src/systems/building.rs
@@ -13,7 +13,7 @@ use crate::{
Build,
Trigger,
TriggerBox,
- OwnTime
+ TimeOffset
},
resources::{NewEntities},
};
@@ -26,18 +26,18 @@ impl <'a> System<'a> for Building{
Write<'a, NewEntities>,
ReadStorage<'a, TriggerBox>,
ReadStorage<'a, Build>,
- ReadStorage<'a, OwnTime>
+ ReadStorage<'a, TimeOffset>
);
- fn run(&mut self, (positions, mut new, triggerboxes, builds, own_times): Self::SystemData) {
- for (position, triggerbox, build, own_time) in (&positions, &triggerboxes, &builds, (&own_times).maybe()).join(){
+ fn run(&mut self, (positions, mut new, triggerboxes, builds, time_offsets): Self::SystemData) {
+ for (position, triggerbox, build, time_offset) in (&positions, &triggerboxes, &builds, (&time_offsets).maybe()).join(){
for message in triggerbox.messages.iter() {
match message {
Trigger::Build | Trigger::Change => {
// todo: better error handling
let mut preent = new.encyclopedia.construct(&build.obj).unwrap();
- if let Some(time) = own_time {
- preent.push(ComponentWrapper::OwnTime(time.clone()));
+ if let Some(time) = time_offset {
+ preent.push(ComponentWrapper::TimeOffset(time.clone()));
}
new.to_build.push((position.pos, preent));
}
diff --git a/src/systems/growth.rs b/src/systems/growth.rs
index b1b1af5..3baa3e8 100644
--- a/src/systems/growth.rs
+++ b/src/systems/growth.rs
@@ -12,7 +12,7 @@ use specs::{
use crate::{
components::{
Grow,
- OwnTime,
+ TimeOffset,
TriggerBox
},
resources::{Time}
@@ -26,22 +26,25 @@ impl <'a> System<'a> for Growth{
WriteStorage<'a, Grow>,
WriteStorage<'a, TriggerBox>,
Read<'a, Time>,
- WriteStorage<'a, OwnTime>
+ WriteStorage<'a, TimeOffset>
);
- fn run(&mut self, (entities, mut grows, mut triggerboxes, time, mut own_times): Self::SystemData) {
+ fn run(&mut self, (entities, mut grows, mut triggerboxes, time, mut time_offsets): 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 creation_time = time.time + time_offsets.get(entity).map(|ct| ct.dtime).unwrap_or(0);
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 {
- if target_time + 1 < time.time {
- own_times.insert(entity, OwnTime{time: target_time + 1}).unwrap();
+ if target_time < time.time {
+ time_offsets.insert(entity, TimeOffset{dtime: target_time.0 - time.time.0}).unwrap();
+ } else {
+ time_offsets.remove(entity);
}
TriggerBox::add_message(&mut triggerboxes, entity, grow.trigger);
+ grow.target_time = None;
}
}
}