diff options
author | metamuffin <metamuffin@disroot.org> | 2024-07-26 18:51:21 +0200 |
---|---|---|
committer | metamuffin <metamuffin@disroot.org> | 2024-07-26 18:51:21 +0200 |
commit | 731c55b70f6d4c29a8ddaac229272caa4bd30084 (patch) | |
tree | f6f3e7894013be126902658ecec893ab155064b7 /server/src/entity/mod.rs | |
parent | 9c7673253f7dcc50d761345c3fdcd0d6d3654f3e (diff) | |
download | hurrycurry-731c55b70f6d4c29a8ddaac229272caa4bd30084.tar hurrycurry-731c55b70f6d4c29a8ddaac229272caa4bd30084.tar.bz2 hurrycurry-731c55b70f6d4c29a8ddaac229272caa4bd30084.tar.zst |
refactor environment effects
Diffstat (limited to 'server/src/entity/mod.rs')
-rw-r--r-- | server/src/entity/mod.rs | 12 |
1 files changed, 7 insertions, 5 deletions
diff --git a/server/src/entity/mod.rs b/server/src/entity/mod.rs index d042d458..747dd6b7 100644 --- a/server/src/entity/mod.rs +++ b/server/src/entity/mod.rs @@ -17,14 +17,15 @@ */ pub mod conveyor; pub mod customers; +pub mod environment_effect; pub mod item_portal; pub mod player_portal; -pub mod weather; use crate::{data::ItemTileRegistry, game::Game, interaction::Recipe}; use anyhow::{anyhow, Result}; use conveyor::Conveyor; use customers::{demands::generate_demands, Customers}; +use environment_effect::{EnvironmentEffect, EnvironmentEffectController}; use hurrycurry_protocol::{ glam::{IVec2, Vec2}, ItemIndex, PacketC, TileIndex, @@ -33,7 +34,6 @@ use item_portal::ItemPortal; use player_portal::PlayerPortal; use serde::{Deserialize, Serialize}; use std::collections::{HashMap, HashSet, VecDeque}; -use weather::WeatherController; pub trait EntityT: Clone { fn tick(&mut self, game: &mut Game, packet_out: &mut VecDeque<PacketC>, dt: f32) -> Result<()>; @@ -56,7 +56,7 @@ entities!( ItemPortal, PlayerPortal, Customers, - WeatherController + EnvironmentEffectController ); #[derive(Debug, Clone, Deserialize, Serialize)] @@ -79,7 +79,7 @@ pub enum EntityDecl { to: Vec2, }, Customers {}, - Weather {}, + EnvironmentEffect(EnvironmentEffect), } pub fn construct_entity( @@ -134,6 +134,8 @@ pub fn construct_entity( .collect(); Entity::Customers(Customers::new(chairs, demands)?) } - EntityDecl::Weather {} => Entity::WeatherController(WeatherController::default()), + EntityDecl::EnvironmentEffect(config) => { + Entity::EnvironmentEffectController(EnvironmentEffectController::new(config)) + } }) } |