2022-02-04 14:09:48 -05:00
|
|
|
use ::bracket_lib::prelude::*;
|
2022-01-11 10:30:32 -05:00
|
|
|
use ::specs::prelude::*;
|
|
|
|
|
|
|
|
use crate::components::{MyTurn, Name, Quips, Viewshed};
|
2022-02-01 11:20:41 -05:00
|
|
|
use crate::gamelog;
|
2022-02-03 14:59:35 -05:00
|
|
|
use crate::rng::roll_dice;
|
2022-01-11 10:30:32 -05:00
|
|
|
|
|
|
|
pub struct QuipSystem {}
|
|
|
|
|
|
|
|
impl<'a> System<'a> for QuipSystem {
|
|
|
|
#[allow(clippy::type_complexity)]
|
|
|
|
type SystemData = (
|
|
|
|
WriteStorage<'a, Quips>,
|
|
|
|
ReadStorage<'a, Name>,
|
|
|
|
ReadStorage<'a, MyTurn>,
|
|
|
|
ReadExpect<'a, Point>,
|
|
|
|
ReadStorage<'a, Viewshed>,
|
|
|
|
);
|
|
|
|
|
|
|
|
fn run(&mut self, data: Self::SystemData) {
|
2022-02-03 14:59:35 -05:00
|
|
|
let (mut quips, names, turns, player_pos, viewsheds) = data;
|
2022-01-11 10:30:32 -05:00
|
|
|
|
|
|
|
for (quip, name, viewshed, _turn) in (&mut quips, &names, &viewsheds, &turns).join() {
|
|
|
|
if !quip.available.is_empty()
|
|
|
|
&& viewshed.visible_tiles.contains(&player_pos)
|
2022-02-03 14:59:35 -05:00
|
|
|
&& roll_dice(1, 6) == 1
|
2022-01-11 10:30:32 -05:00
|
|
|
{
|
|
|
|
let quip_index = if quip.available.len() == 1 {
|
|
|
|
0
|
|
|
|
} else {
|
2022-02-03 14:59:35 -05:00
|
|
|
(roll_dice(1, quip.available.len() as i32) - 1) as usize
|
2022-01-11 10:30:32 -05:00
|
|
|
};
|
|
|
|
|
2022-02-01 11:20:41 -05:00
|
|
|
gamelog::Logger::new()
|
|
|
|
.npc_name(&name.name)
|
|
|
|
.append("says")
|
|
|
|
.npc_name(&quip.available[quip_index])
|
2022-02-01 10:39:46 -05:00
|
|
|
.log();
|
2022-01-11 10:30:32 -05:00
|
|
|
|
|
|
|
quip.available.remove(quip_index);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|