Compare commits

..

2 Commits

Author SHA1 Message Date
Alexander Heldt
1e79274187 Correct io_get_chars comment/documentation 2025-11-16 20:38:16 +01:00
Alexander Heldt
9cd1bf2898 Add ability to create character sequences as Input 2025-11-16 20:37:34 +01:00
2 changed files with 14 additions and 10 deletions

View File

@@ -67,10 +67,6 @@ pub fn get_playback_time(socket: Socket) -> Result(PlaybackTime, ControlError) {
} }
} }
pub fn clear_screen() -> Nil {
io.print("\u{001B}[2J\u{001B}[H")
}
fn send_command(socket: Socket, command: json.Json) -> Result(String, Reason) { fn send_command(socket: Socket, command: json.Json) -> Result(String, Reason) {
result.try(tcp.send(socket, json.to_string(command) <> "\n"), fn(_) { result.try(tcp.send(socket, json.to_string(command) <> "\n"), fn(_) {
let timeout_ms = 10_000 let timeout_ms = 10_000

View File

@@ -12,22 +12,30 @@ type TestCase {
} }
pub fn key_from_list_test() { pub fn key_from_list_test() {
let test_cases = [ let base_tests = [TestCase([], key.Continue([]))]
TestCase(["c"], Char("c")),
let char_tests = [TestCase(["c"], Char("c"))]
let escape_tests = [
TestCase([esc, csi], key.Continue([esc, csi])),
TestCase([esc], key.Continue([esc])),
TestCase([esc, csi, "D"], key.Left), TestCase([esc, csi, "D"], key.Left),
TestCase([esc, csi, "C"], key.Right), TestCase([esc, csi, "C"], key.Right),
TestCase([esc, csi, "A"], key.Up), TestCase([esc, csi, "A"], key.Up),
TestCase([esc, csi, "B"], key.Down), TestCase([esc, csi, "B"], key.Down),
TestCase([esc, csi], key.Continue([esc, csi])), ]
TestCase([esc], key.Continue([esc])),
TestCase([], key.Continue([])), let input_tests = [
TestCase(["$"], key.Continue(["$"])), TestCase(["$"], key.Continue(["$"])),
TestCase(["$", "a"], key.Continue(["$", "a"])), TestCase(["$", "a"], key.Continue(["$", "a"])),
TestCase(["$", "a", "b"], key.Continue(["$", "ab"])), TestCase(["$", "a", "b"], key.Continue(["$", "ab"])),
TestCase(["$", "ab", "\r"], key.Input("ab")), TestCase(["$", "ab", "\r"], key.Input("ab")),
] ]
list.each(test_cases, fn(tc) { let test_cases = [base_tests, char_tests, escape_tests, input_tests]
list.each(list.flatten(test_cases), fn(tc) {
assert tc.expected == key.from_list(tc.input) assert tc.expected == key.from_list(tc.input)
}) })
} }