1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
|
/*
Hurry Curry! - a game about cooking
Copyright 2024 metamuffin
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as published by
the Free Software Foundation, version 3 of the License only.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
use super::{bot::BotDriver, Entity, EntityContext};
use anyhow::Result;
use hurrycurry_bot::algos::Customer;
use rand::random;
pub struct Customers {
customers: Vec<BotDriver<Customer>>,
spawn_cooldown: f32,
}
impl Customers {
pub fn new() -> Result<Self> {
Ok(Self {
customers: Default::default(),
spawn_cooldown: 0.,
})
}
}
impl Entity for Customers {
fn tick(&mut self, c: EntityContext) -> Result<()> {
self.spawn_cooldown -= c.dt;
self.spawn_cooldown = self.spawn_cooldown.max(0.);
if self.customers.len() < 5 && self.spawn_cooldown <= 0. {
self.spawn_cooldown = 10. + random::<f32>() * 10.;
let bot = BotDriver::new(
"".to_string(),
-1 - (random::<u16>() as i32),
Customer::default(),
);
self.customers.push(bot)
}
for bot in &mut self.customers {
bot.tick(EntityContext {
game: c.game,
packet_out: c.packet_out,
packet_in: c.packet_in,
score_changed: c.score_changed,
dt: c.dt,
scoreboard: c.scoreboard,
load_map: c.load_map,
})?;
}
self.customers.retain(|c| !c.finished());
Ok(())
}
}
|