aboutsummaryrefslogtreecommitdiffstats
path: root/tests/scroll.rs
diff options
context:
space:
mode:
authorJesse Luehrs <doy@tozt.net>2019-11-05 01:32:25 -0500
committerJesse Luehrs <doy@tozt.net>2019-11-05 01:32:25 -0500
commit4b4a9c18e4c55a2ba6558ef614292db9c18ab88a (patch)
tree03c9ada690835acbf3d1b02f46341bde5b579989 /tests/scroll.rs
parent59e7c620a516278719c1689ebebeb558bede5b60 (diff)
downloadvt100-rust-4b4a9c18e4c55a2ba6558ef614292db9c18ab88a.tar.gz
vt100-rust-4b4a9c18e4c55a2ba6558ef614292db9c18ab88a.zip
expose the screen separately from the parser
Diffstat (limited to 'tests/scroll.rs')
-rw-r--r--tests/scroll.rs82
1 files changed, 41 insertions, 41 deletions
diff --git a/tests/scroll.rs b/tests/scroll.rs
index b75a54d..a8bfb05 100644
--- a/tests/scroll.rs
+++ b/tests/scroll.rs
@@ -1,64 +1,64 @@
#[test]
fn scroll_regions() {
- let mut screen = vt100::Screen::new(24, 80);
- screen.process(b"\x1b[m\x1b[2J\x1b[H1\r\n2\r\n3\r\n4\r\n5\r\n6\r\n7\r\n8\r\n9\r\n10\r\n11\r\n12\r\n13\r\n14\r\n15\r\n16\r\n17\r\n18\r\n19\r\n20\r\n21\r\n22\r\n23\r\n24");
- assert_eq!(screen.contents(0, 0, 23, 79), "1\n2\n3\n4\n5\n6\n7\n8\n9\n10\n11\n12\n13\n14\n15\n16\n17\n18\n19\n20\n21\n22\n23\n24");
+ let mut parser = vt100::Parser::new(24, 80);
+ parser.process(b"\x1b[m\x1b[2J\x1b[H1\r\n2\r\n3\r\n4\r\n5\r\n6\r\n7\r\n8\r\n9\r\n10\r\n11\r\n12\r\n13\r\n14\r\n15\r\n16\r\n17\r\n18\r\n19\r\n20\r\n21\r\n22\r\n23\r\n24");
+ assert_eq!(parser.screen().contents(0, 0, 23, 79), "1\n2\n3\n4\n5\n6\n7\n8\n9\n10\n11\n12\n13\n14\n15\n16\n17\n18\n19\n20\n21\n22\n23\n24");
- screen.process(b"\x1b[24;50H\n");
- assert_eq!(screen.contents(0, 0, 23, 79), "2\n3\n4\n5\n6\n7\n8\n9\n10\n11\n12\n13\n14\n15\n16\n17\n18\n19\n20\n21\n22\n23\n24");
+ parser.process(b"\x1b[24;50H\n");
+ assert_eq!(parser.screen().contents(0, 0, 23, 79), "2\n3\n4\n5\n6\n7\n8\n9\n10\n11\n12\n13\n14\n15\n16\n17\n18\n19\n20\n21\n22\n23\n24");
- screen.process(b"\x1b[m\x1b[2J\x1b[H1\r\n2\r\n3\r\n4\r\n5\r\n6\r\n7\r\n8\r\n9\r\n10\r\n11\r\n12\r\n13\r\n14\r\n15\r\n16\r\n17\r\n18\r\n19\r\n20\r\n21\r\n22\r\n23\r\n24");
+ parser.process(b"\x1b[m\x1b[2J\x1b[H1\r\n2\r\n3\r\n4\r\n5\r\n6\r\n7\r\n8\r\n9\r\n10\r\n11\r\n12\r\n13\r\n14\r\n15\r\n16\r\n17\r\n18\r\n19\r\n20\r\n21\r\n22\r\n23\r\n24");
- screen.process(b"\x1b[10;20r");
- assert_eq!(screen.cursor_position(), (9, 0));
+ parser.process(b"\x1b[10;20r");
+ assert_eq!(parser.screen().cursor_position(), (9, 0));
- screen.process(b"\x1b[20;50H");
- assert_eq!(screen.cursor_position(), (19, 49));
+ parser.process(b"\x1b[20;50H");
+ assert_eq!(parser.screen().cursor_position(), (19, 49));
- screen.process(b"\n");
- assert_eq!(screen.contents(0, 0, 23, 79), "1\n2\n3\n4\n5\n6\n7\n8\n9\n11\n12\n13\n14\n15\n16\n17\n18\n19\n20\n\n21\n22\n23\n24");
- assert_eq!(screen.cursor_position(), (19, 49));
+ parser.process(b"\n");
+ assert_eq!(parser.screen().contents(0, 0, 23, 79), "1\n2\n3\n4\n5\n6\n7\n8\n9\n11\n12\n13\n14\n15\n16\n17\n18\n19\n20\n\n21\n22\n23\n24");
+ assert_eq!(parser.screen().cursor_position(), (19, 49));
- screen.process(b"\x1b[B");
- assert_eq!(screen.cursor_position(), (19, 49));
+ parser.process(b"\x1b[B");
+ assert_eq!(parser.screen().cursor_position(), (19, 49));
- screen.process(b"\x1b[20A");
- assert_eq!(screen.cursor_position(), (9, 49));
- screen.process(b"\x1b[1;24r\x1b[m\x1b[2J\x1b[H1\r\n2\r\n3\r\n4\r\n5\r\n6\r\n7\r\n8\r\n9\r\n10\r\n11\r\n12\r\n13\r\n14\r\n15\r\n16\r\n17\r\n18\r\n19\r\n20\r\n21\r\n22\r\n23\r\n24");
- screen.process(b"\x1b[10;20r\x1b[15;50H\x1b[2L");
- assert_eq!(screen.contents(0, 0, 23, 79), "1\n2\n3\n4\n5\n6\n7\n8\n9\n10\n11\n12\n13\n14\n\n\n15\n16\n17\n18\n21\n22\n23\n24");
- screen.process(b"\x1b[10;50H\x1bM");
- assert_eq!(screen.contents(0, 0, 23, 79), "1\n2\n3\n4\n5\n6\n7\n8\n9\n\n10\n11\n12\n13\n14\n\n\n15\n16\n17\n21\n22\n23\n24");
+ parser.process(b"\x1b[20A");
+ assert_eq!(parser.screen().cursor_position(), (9, 49));
+ parser.process(b"\x1b[1;24r\x1b[m\x1b[2J\x1b[H1\r\n2\r\n3\r\n4\r\n5\r\n6\r\n7\r\n8\r\n9\r\n10\r\n11\r\n12\r\n13\r\n14\r\n15\r\n16\r\n17\r\n18\r\n19\r\n20\r\n21\r\n22\r\n23\r\n24");
+ parser.process(b"\x1b[10;20r\x1b[15;50H\x1b[2L");
+ assert_eq!(parser.screen().contents(0, 0, 23, 79), "1\n2\n3\n4\n5\n6\n7\n8\n9\n10\n11\n12\n13\n14\n\n\n15\n16\n17\n18\n21\n22\n23\n24");
+ parser.process(b"\x1b[10;50H\x1bM");
+ assert_eq!(parser.screen().contents(0, 0, 23, 79), "1\n2\n3\n4\n5\n6\n7\n8\n9\n\n10\n11\n12\n13\n14\n\n\n15\n16\n17\n21\n22\n23\n24");
}
#[test]
fn origin_mode() {
- let mut screen = vt100::Screen::new(24, 80);
+ let mut parser = vt100::Parser::new(24, 80);
- screen.process(b"\x1b[5;15r");
- assert_eq!(screen.cursor_position(), (4, 0));
+ parser.process(b"\x1b[5;15r");
+ assert_eq!(parser.screen().cursor_position(), (4, 0));
- screen.process(b"\x1b[10;50H");
- assert_eq!(screen.cursor_position(), (9, 49));
+ parser.process(b"\x1b[10;50H");
+ assert_eq!(parser.screen().cursor_position(), (9, 49));
- screen.process(b"\x1b[?6h");
- assert_eq!(screen.cursor_position(), (4, 0));
+ parser.process(b"\x1b[?6h");
+ assert_eq!(parser.screen().cursor_position(), (4, 0));
- screen.process(b"\x1b[10;50H");
- assert_eq!(screen.cursor_position(), (13, 49));
+ parser.process(b"\x1b[10;50H");
+ assert_eq!(parser.screen().cursor_position(), (13, 49));
- screen.process(b"\x1b[?6l");
- assert_eq!(screen.cursor_position(), (0, 0));
+ parser.process(b"\x1b[?6l");
+ assert_eq!(parser.screen().cursor_position(), (0, 0));
- screen.process(b"\x1b[10;50H");
- assert_eq!(screen.cursor_position(), (9, 49));
+ parser.process(b"\x1b[10;50H");
+ assert_eq!(parser.screen().cursor_position(), (9, 49));
- screen.process(b"\x1b[?6h\x1b[?47h\x1b[6;16r\x1b[H");
- assert_eq!(screen.cursor_position(), (0, 0));
+ parser.process(b"\x1b[?6h\x1b[?47h\x1b[6;16r\x1b[H");
+ assert_eq!(parser.screen().cursor_position(), (0, 0));
- screen.process(b"\x1b[?6h");
- assert_eq!(screen.cursor_position(), (5, 0));
+ parser.process(b"\x1b[?6h");
+ assert_eq!(parser.screen().cursor_position(), (5, 0));
- screen.process(b"\x1b[?47l\x1b[H");
- assert_eq!(screen.cursor_position(), (4, 0));
+ parser.process(b"\x1b[?47l\x1b[H");
+ assert_eq!(parser.screen().cursor_position(), (4, 0));
}