summaryrefslogtreecommitdiff
path: root/src/systems
diff options
context:
space:
mode:
authortroido <troido@protonmail.com>2020-05-21 12:45:44 +0200
committertroido <troido@protonmail.com>2020-06-05 22:27:53 +0200
commitf47034bdf86e7ddc831ecb8f50689b9b07a0f6ca (patch)
tree4a2f4f5bee8541c66b6ce6b53b08ef354d59472e /src/systems
parentbd1da23cf18960b36f8683c09899044d64b4bd83 (diff)
actually added talk system and removed reply interaction
Diffstat (limited to 'src/systems')
-rw-r--r--src/systems/interact.rs6
-rw-r--r--src/systems/talk.rs56
2 files changed, 56 insertions, 6 deletions
diff --git a/src/systems/interact.rs b/src/systems/interact.rs
index b377a7a..2090f6f 100644
--- a/src/systems/interact.rs
+++ b/src/systems/interact.rs
@@ -82,12 +82,6 @@ impl <'a> System<'a> for Interact {
Interactable::Trigger(trigger) => {
TriggerBox::add_message(&mut triggerbox, ent, *trigger);
}
- Interactable::Say(text) => {
- say(ear, text.clone(), name);
- }
- Interactable::Reply(text) => {
- say(ear, text.replace("{}", &arg.unwrap()), name);
- }
Interactable::Exchange(prefix, exchanges) => {
if let Some(txt) = arg {
if let (Some(inventory), Some(action)) = (inventories.get_mut(actor), strip_prefix(&txt, prefix)) {
diff --git a/src/systems/talk.rs b/src/systems/talk.rs
new file mode 100644
index 0000000..4bb898a
--- /dev/null
+++ b/src/systems/talk.rs
@@ -0,0 +1,56 @@
+
+use std::collections::HashSet;
+
+use specs::{
+ ReadStorage,
+ WriteStorage,
+ System,
+ Join,
+ Read
+};
+
+use crate::{
+ components::{
+ Controller,
+ Position,
+ Talkable,
+ Notification,
+ Ear,
+ Visible
+ },
+ controls::{Control},
+ resources::{Ground},
+};
+
+pub struct Talk;
+impl <'a> System<'a> for Talk {
+ type SystemData = (
+ ReadStorage<'a, Controller>,
+ ReadStorage<'a, Position>,
+ Read<'a, Ground>,
+ ReadStorage<'a, Talkable>,
+ WriteStorage<'a, Ear>,
+ ReadStorage<'a, Visible>
+ );
+
+ fn run(&mut self, (controllers, positions, ground, talkables, mut ears, visibles): Self::SystemData) {
+ for (controller, position, ear) in (&controllers, &positions, &mut ears).join(){
+ match &controller.control {
+ Control::Interact(directions, None) => {
+ 'targets: for direction in directions {
+ let pos = position.pos + direction.to_position();
+ for ent in ground.cells.get(&pos).unwrap_or(&HashSet::new()) {
+ if let Some(Talkable{text}) = talkables.get(*ent) {
+ let name = visibles.get(*ent).map(|v| v.name.clone());
+ ear.sounds.push(Notification::Sound{text: text.clone(), source: name});
+ break 'targets;
+ }
+ }
+ }
+ }
+ _ => {}
+ }
+ }
+ }
+}
+