aboutsummaryrefslogtreecommitdiff
path: root/src/input/resources.rs
diff options
context:
space:
mode:
authorLibravatar Silas Bartha <silas@exvacuum.dev>2024-12-20 08:02:55 -0500
committerLibravatar Silas Bartha <silas@exvacuum.dev>2024-12-20 08:02:55 -0500
commit652a17e0f90a045b99a80044be313e23b9529005 (patch)
tree0fec702d8a143cc67c1845eb4214aba5ee0d1d7d /src/input/resources.rs
parent87172fd904a9d461b10438be7dc55660e7ced680 (diff)
parent39e8be3872232d929c4ccaa1b595bf61d656b2fe (diff)
Merge branch 'wip'
Diffstat (limited to 'src/input/resources.rs')
-rw-r--r--src/input/resources.rs53
1 files changed, 2 insertions, 51 deletions
diff --git a/src/input/resources.rs b/src/input/resources.rs
index a733984..f8b9032 100644
--- a/src/input/resources.rs
+++ b/src/input/resources.rs
@@ -1,56 +1,7 @@
-use bevy::{prelude::*, utils::HashSet};
-use crossterm::event::{Event, KeyCode};
+use bevy::prelude::*;
+use crossterm::event::Event;
use std::sync::{Arc, Mutex};
-/// Resource containing currently pressed and released keys
-#[derive(Resource, Default)]
-pub struct TerminalInput {
- pressed_keys: HashSet<KeyCode>,
- just_pressed_keys: HashSet<KeyCode>,
- just_released_keys: HashSet<KeyCode>,
-}
-
-impl TerminalInput {
- /// Gets whether the given key is pressed
- pub fn is_pressed(&self, code: KeyCode) -> bool {
- self.pressed_keys.contains(&code)
- }
-
- /// Gets whether the given key was just pressed
- pub fn just_pressed(&self, code: KeyCode) -> bool {
- self.just_pressed_keys.contains(&code)
- }
-
- /// Gets whether the given key was just released
- pub fn just_released(&self, code: KeyCode) -> bool {
- self.just_released_keys.contains(&code)
- }
-
- /// Sets given key to pressed
- pub(super) fn press(&mut self, code: KeyCode) {
- if !self.pressed_keys.contains(&code) {
- self.pressed_keys.insert(code);
- self.just_pressed_keys.insert(code);
- }
- }
-
- /// Sets given key to released and removes pressed state
- pub(super) fn release(&mut self, code: KeyCode) {
- self.pressed_keys.remove(&code);
- self.just_released_keys.insert(code);
- }
-
- /// Clears all just released keys
- pub(super) fn clear_just_released(&mut self) {
- self.just_released_keys.clear();
- }
-
- /// Clears all just pressed keys
- pub(super) fn clear_just_pressed(&mut self) {
- self.just_pressed_keys.clear();
- }
-}
-
/// Event queue for crossterm input event thread
#[derive(Resource, Default)]
pub(crate) struct EventQueue(pub(super) Arc<Mutex<Vec<Event>>>);