mirror of
https://codeberg.org/unspeaker/tengri.git
synced 2025-12-06 11:46:42 +01:00
This commit is contained in:
parent
91dc77cfea
commit
11f686650f
19 changed files with 964 additions and 918 deletions
|
|
@ -1,18 +1,16 @@
|
|||
use crate::*;
|
||||
use crate::{dsl::*, input::*, tui::TuiIn};
|
||||
use crossterm::event::{Event, KeyEvent, KeyCode, KeyModifiers, KeyEventKind, KeyEventState};
|
||||
|
||||
#[test] fn test_subcommand () -> Usually<()> {
|
||||
use crate::tui::TuiIn;
|
||||
use crossterm::event::{Event, KeyEvent, KeyCode, KeyModifiers, KeyEventKind, KeyEventState};
|
||||
use crate::input::*;
|
||||
use crate::dsl::*;
|
||||
struct Test {
|
||||
keys: InputLayers
|
||||
}
|
||||
handle!(TuiIn: |self: Test, input|if let Some(command) = self.keys.command(self, input) {
|
||||
struct Test { keys: InputLayers<Ast> }
|
||||
|
||||
handle!(TuiIn: |self: Test, input|Ok(None));/*if let Some(command) = self.keys.command(self, input) {
|
||||
Ok(Some(true))
|
||||
} else {
|
||||
Ok(None)
|
||||
});
|
||||
});*/
|
||||
|
||||
#[tengri_proc::command(Test)]
|
||||
impl TestCommand {
|
||||
fn do_thing (_state: &mut Test) -> Perhaps<Self> {
|
||||
|
|
@ -25,6 +23,7 @@ use crate::*;
|
|||
Ok(command.execute(state)?.map(|command|Self::DoSub { command }))
|
||||
}
|
||||
}
|
||||
|
||||
#[tengri_proc::command(Test)]
|
||||
impl TestSubcommand {
|
||||
fn do_other_thing (_state: &mut Test) -> Perhaps<Self> {
|
||||
|
|
@ -34,44 +33,46 @@ use crate::*;
|
|||
Ok(None)
|
||||
}
|
||||
}
|
||||
|
||||
let mut test = Test {
|
||||
keys: InputLayers::new(SourceIter::new("
|
||||
keys: InputLayers::from("
|
||||
(@a do-thing)
|
||||
(@b do-thing-arg 0)
|
||||
(@c do-sub do-other-thing)
|
||||
(@d do-sub do-other-thing-arg 0)
|
||||
".into()))
|
||||
")
|
||||
};
|
||||
assert_eq!(Some(true), test.handle(&TuiIn(Default::default(), Event::Key(KeyEvent {
|
||||
kind: KeyEventKind::Press,
|
||||
code: KeyCode::Char('a'),
|
||||
modifiers: KeyModifiers::NONE,
|
||||
state: KeyEventState::NONE,
|
||||
})))?);
|
||||
assert_eq!(Some(true), test.handle(&TuiIn(Default::default(), Event::Key(KeyEvent {
|
||||
kind: KeyEventKind::Press,
|
||||
code: KeyCode::Char('b'),
|
||||
modifiers: KeyModifiers::NONE,
|
||||
state: KeyEventState::NONE,
|
||||
})))?);
|
||||
assert_eq!(Some(true), test.handle(&TuiIn(Default::default(), Event::Key(KeyEvent {
|
||||
kind: KeyEventKind::Press,
|
||||
code: KeyCode::Char('c'),
|
||||
modifiers: KeyModifiers::NONE,
|
||||
state: KeyEventState::NONE,
|
||||
})))?);
|
||||
assert_eq!(Some(true), test.handle(&TuiIn(Default::default(), Event::Key(KeyEvent {
|
||||
kind: KeyEventKind::Press,
|
||||
code: KeyCode::Char('d'),
|
||||
modifiers: KeyModifiers::NONE,
|
||||
state: KeyEventState::NONE,
|
||||
})))?);
|
||||
assert_eq!(None, test.handle(&TuiIn(Default::default(), Event::Key(KeyEvent {
|
||||
kind: KeyEventKind::Press,
|
||||
code: KeyCode::Char('z'),
|
||||
modifiers: KeyModifiers::NONE,
|
||||
state: KeyEventState::NONE,
|
||||
})))?);
|
||||
|
||||
//assert_eq!(Some(true), test.handle(&TuiIn(Default::default(), Event::Key(KeyEvent {
|
||||
//kind: KeyEventKind::Press,
|
||||
//code: KeyCode::Char('a'),
|
||||
//modifiers: KeyModifiers::NONE,
|
||||
//state: KeyEventState::NONE,
|
||||
//})))?);
|
||||
//assert_eq!(Some(true), test.handle(&TuiIn(Default::default(), Event::Key(KeyEvent {
|
||||
//kind: KeyEventKind::Press,
|
||||
//code: KeyCode::Char('b'),
|
||||
//modifiers: KeyModifiers::NONE,
|
||||
//state: KeyEventState::NONE,
|
||||
//})))?);
|
||||
//assert_eq!(Some(true), test.handle(&TuiIn(Default::default(), Event::Key(KeyEvent {
|
||||
//kind: KeyEventKind::Press,
|
||||
//code: KeyCode::Char('c'),
|
||||
//modifiers: KeyModifiers::NONE,
|
||||
//state: KeyEventState::NONE,
|
||||
//})))?);
|
||||
//assert_eq!(Some(true), test.handle(&TuiIn(Default::default(), Event::Key(KeyEvent {
|
||||
//kind: KeyEventKind::Press,
|
||||
//code: KeyCode::Char('d'),
|
||||
//modifiers: KeyModifiers::NONE,
|
||||
//state: KeyEventState::NONE,
|
||||
//})))?);
|
||||
//assert_eq!(None, test.handle(&TuiIn(Default::default(), Event::Key(KeyEvent {
|
||||
//kind: KeyEventKind::Press,
|
||||
//code: KeyCode::Char('z'),
|
||||
//modifiers: KeyModifiers::NONE,
|
||||
//state: KeyEventState::NONE,
|
||||
//})))?);
|
||||
Ok(())
|
||||
}
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue