aboutsummaryrefslogtreecommitdiffstats
path: root/tests/text.rs
blob: 087755a98076d056c99798a3f7b2d09410416478 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
#![allow(clippy::cognitive_complexity)]

#[test]
fn ascii() {
    let mut parser = vt100::Parser::default();
    parser.process(b"foo");
    assert_eq!(parser.screen().cell(0, 0).unwrap().contents(), "f");
    assert_eq!(parser.screen().cell(0, 1).unwrap().contents(), "o");
    assert_eq!(parser.screen().cell(0, 2).unwrap().contents(), "o");
    assert_eq!(parser.screen().cell(0, 3).unwrap().contents(), "");
    assert_eq!(parser.screen().cell(1, 0).unwrap().contents(), "");
    assert_eq!(parser.screen().contents(), "foo");
}

#[test]
fn utf8() {
    let mut parser = vt100::Parser::default();
    parser.process("café".as_bytes());
    assert_eq!(parser.screen().cell(0, 0).unwrap().contents(), "c");
    assert_eq!(parser.screen().cell(0, 1).unwrap().contents(), "a");
    assert_eq!(parser.screen().cell(0, 2).unwrap().contents(), "f");
    assert_eq!(parser.screen().cell(0, 3).unwrap().contents(), "é");
    assert_eq!(parser.screen().cell(0, 4).unwrap().contents(), "");
    assert_eq!(parser.screen().cell(1, 0).unwrap().contents(), "");
    assert_eq!(parser.screen().contents(), "café");
}

#[test]
fn newlines() {
    let mut parser = vt100::Parser::default();
    parser.process(b"f\r\noo\r\nood");
    assert_eq!(parser.screen().cell(0, 0).unwrap().contents(), "f");
    assert_eq!(parser.screen().cell(0, 1).unwrap().contents(), "");
    assert_eq!(parser.screen().cell(0, 2).unwrap().contents(), "");
    assert_eq!(parser.screen().cell(1, 0).unwrap().contents(), "o");
    assert_eq!(parser.screen().cell(1, 1).unwrap().contents(), "o");
    assert_eq!(parser.screen().cell(1, 2).unwrap().contents(), "");
    assert_eq!(parser.screen().cell(2, 0).unwrap().contents(), "o");
    assert_eq!(parser.screen().cell(2, 1).unwrap().contents(), "o");
    assert_eq!(parser.screen().cell(2, 2).unwrap().contents(), "d");
    assert_eq!(parser.screen().cell(0, 3).unwrap().contents(), "");
    assert_eq!(parser.screen().cell(3, 0).unwrap().contents(), "");
    assert_eq!(parser.screen().contents(), "f\noo\nood");
}

#[test]
fn wide() {
    let mut parser = vt100::Parser::default();
    let screen = parser.screen().clone();
    parser.process("aデbネ".as_bytes());
    assert_eq!(parser.screen().cell(0, 0).unwrap().contents(), "a");
    assert_eq!(parser.screen().cell(0, 1).unwrap().contents(), "デ");
    assert_eq!(parser.screen().cell(0, 2).unwrap().contents(), "");
    assert_eq!(parser.screen().cell(0, 3).unwrap().contents(), "b");
    assert_eq!(parser.screen().cell(0, 4).unwrap().contents(), "ネ");
    assert_eq!(parser.screen().cell(0, 5).unwrap().contents(), "");
    assert_eq!(parser.screen().cell(0, 6).unwrap().contents(), "");
    assert_eq!(parser.screen().cell(1, 0).unwrap().contents(), "");
    assert_eq!(parser.screen().contents(), "aデbネ");
    assert_eq!(parser.screen().cursor_position(), (0, 6));
    assert_eq!(
        parser.screen().contents_formatted(),
        "\x1b[?25h\x1b[m\x1b[H\x1b[Jaデbネ".as_bytes()
    );
    assert_eq!(parser.screen().contents_diff(&screen), "aデbネ".as_bytes());

    let screen = parser.screen().clone();
    parser.process(b"\x1b[1;1H\x1b[3Cc");
    assert_eq!(parser.screen().contents(), "aデcネ");
    assert_eq!(parser.screen().cursor_position(), (0, 4));
    assert_eq!(
        parser.screen().contents_formatted(),
        "\x1b[?25h\x1b[m\x1b[H\x1b[Jaデcネ\x1b[1;5H".as_bytes()
    );
    assert_eq!(
        parser.screen().contents_diff(&screen),
        "\x1b[1;4Hc".as_bytes()
    );

    let screen = parser.screen().clone();
    parser.process("\x1b[1;7Hfoobar".as_bytes());
    assert_eq!(parser.screen().contents(), "aデcネfoobar");
    assert_eq!(parser.screen().cursor_position(), (0, 12));
    assert_eq!(
        parser.screen().contents_formatted(),
        "\x1b[?25h\x1b[m\x1b[H\x1b[Jaデcネfoobar".as_bytes()
    );
    assert_eq!(
        parser.screen().contents_diff(&screen),
        "\x1b[2Cfoobar".as_bytes()
    );

    let screen = parser.screen().clone();
    parser.process("\x1b[1;1Hデcネfoobar\x1b[K".as_bytes());
    assert_eq!(parser.screen().contents(), "デcネfoobar");
    assert_eq!(parser.screen().cursor_position(), (0, 11));
    assert_eq!(
        parser.screen().contents_formatted(),
        "\x1b[?25h\x1b[m\x1b[H\x1b[Jデcネfoobar".as_bytes()
    );
    assert_eq!(
        parser.screen().contents_diff(&screen),
        "\x1b[Hデcネfo\x1b[Cbar\x1b[K".as_bytes()
    );

    let screen = parser.screen().clone();
    parser.process("\x1b[1;1Haデcネfoobar\x1b[K".as_bytes());
    assert_eq!(parser.screen().contents(), "aデcネfoobar");
    assert_eq!(parser.screen().cursor_position(), (0, 12));
    assert_eq!(
        parser.screen().contents_formatted(),
        "\x1b[?25h\x1b[m\x1b[H\x1b[Jaデcネfoobar".as_bytes()
    );
    assert_eq!(
        parser.screen().contents_diff(&screen),
        "\x1b[Haデcネf\x1b[Cobar".as_bytes()
    );

    let screen = parser.screen().clone();
    parser.process("\x1b[1;1Hデcネfoobar\x1b[K".as_bytes());
    assert_eq!(parser.screen().contents(), "デcネfoobar");
    assert_eq!(parser.screen().cursor_position(), (0, 11));
    assert_eq!(
        parser.screen().contents_formatted(),
        "\x1b[?25h\x1b[m\x1b[H\x1b[Jデcネfoobar".as_bytes()
    );
    assert_eq!(
        parser.screen().contents_diff(&screen),
        "\x1b[Hデcネfo\x1b[Cbar\x1b[K".as_bytes()
    );
}

#[cfg(feature = "unicode-normalization")]
#[test]
fn combining() {
    let mut parser = vt100::Parser::default();
    parser.process(b"a");
    assert_eq!(parser.screen().cell(0, 0).unwrap().contents(), "a");
    parser.process("\u{0301}".as_bytes());
    assert_eq!(parser.screen().cell(0, 0).unwrap().contents(), "á");
    parser.process(b"\x1bcabcdefg");
    assert_eq!(parser.screen().contents(), "abcdefg");
    parser.process("\x1b[1;6H\u{0301}".as_bytes());
    assert_eq!(parser.screen().contents(), "abcdéfg");
    parser.process(b"\x1b[10;78Haaa");
    assert_eq!(parser.screen().cell(9, 79).unwrap().contents(), "a");
    parser.process("\r\n\u{0301}".as_bytes());
    assert_eq!(parser.screen().cell(9, 79).unwrap().contents(), "a");
    assert_eq!(parser.screen().cell(10, 0).unwrap().contents(), "");

    parser.process("\x1bcabcdefg\x1b[1;3H\u{0301}".as_bytes());
    assert_eq!(parser.screen().contents(), "ab́cdefg");
    parser.process("\x1b[1;2Hb\x1b[1;8H".as_bytes());
    assert_eq!(parser.screen().contents(), "abcdefg");
    let screen = parser.screen().clone();
    parser.process(b"\x1bcabcdefg");
    assert_eq!(parser.screen().contents_diff(&screen), b"");

    parser.process(b"\x1bcaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa");
    assert_eq!(parser.screen().cursor_position(), (0, 80));
    assert_eq!(parser.screen().contents(), "a".repeat(80));

    parser.process("\u{0301}".as_bytes());
    assert_eq!(parser.screen().cursor_position(), (1, 0));
    assert_eq!(parser.screen().contents(), format!("{}á", "a".repeat(79)));

    parser.process("\x1b[H\x1b[Ja\u{0301}".as_bytes());
    assert_eq!(parser.screen().cell(0, 0).unwrap().contents(), "a\u{0301}");
    assert_eq!(parser.screen().cell(0, 1).unwrap().contents(), "");

    parser.process("\x1b[H\x1b[J\x1b[2C\u{0301}".as_bytes());
    assert_eq!(parser.screen().cell(0, 0).unwrap().contents(), "");
    assert_eq!(parser.screen().cell(0, 1).unwrap().contents(), " \u{0301}");
    assert_eq!(parser.screen().cell(0, 2).unwrap().contents(), "");
    assert_eq!(parser.screen().cell(0, 3).unwrap().contents(), "");
}

#[test]
fn wrap() {
    let mut parser = vt100::Parser::default();
    parser.process(b"0123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789");
    assert_eq!(parser.screen().contents(), "0123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789");
    parser.process(b"\x1b[5H01234567890123456789012345678901234567890123456789012345678901234567890123456789");
    parser.process(b"\x1b[6H01234567890123456789012345678901234567890123456789012345678901234567890123456789");
    assert_eq!(parser.screen().contents(), "0123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789\n\n\n01234567890123456789012345678901234567890123456789012345678901234567890123456789\n01234567890123456789012345678901234567890123456789012345678901234567890123456789");

    parser.process(b"\x1b[H\x1b[J");
    parser.process(b"0123456789012345678901234567890123456789012345678901234567890123456789012345678");
    assert_eq!(parser.screen().contents(), "0123456789012345678901234567890123456789012345678901234567890123456789012345678");
    assert_eq!(parser.screen().cursor_position(), (0, 79));
    parser.process(b"9");
    assert_eq!(parser.screen().contents(), "01234567890123456789012345678901234567890123456789012345678901234567890123456789");
    assert_eq!(parser.screen().cursor_position(), (0, 80));
    parser.process(b"a");
    assert_eq!(parser.screen().contents(), "01234567890123456789012345678901234567890123456789012345678901234567890123456789a");
    assert_eq!(parser.screen().cursor_position(), (1, 1));
    parser.process(b"b");
    assert_eq!(parser.screen().contents(), "01234567890123456789012345678901234567890123456789012345678901234567890123456789ab");
    assert_eq!(parser.screen().cursor_position(), (1, 2));

    parser.process(b"\x1b[H\x1b[J");
    parser.process(b"012345678901234567890123456789012345678901234567890123456789012345678901234567");
    assert_eq!(parser.screen().contents(), "012345678901234567890123456789012345678901234567890123456789012345678901234567");
    assert_eq!(parser.screen().cursor_position(), (0, 78));
    parser.process("ネ".as_bytes());
    assert_eq!(parser.screen().contents(), "012345678901234567890123456789012345678901234567890123456789012345678901234567ネ");
    assert_eq!(parser.screen().cursor_position(), (0, 80));
    parser.process(b"a");
    assert_eq!(parser.screen().contents(), "012345678901234567890123456789012345678901234567890123456789012345678901234567ネa");
    assert_eq!(parser.screen().cursor_position(), (1, 1));
    assert_eq!(parser.screen().cell(0, 77).unwrap().contents(), "7");
    assert_eq!(parser.screen().cell(0, 78).unwrap().contents(), "ネ");
    assert_eq!(parser.screen().cell(0, 79).unwrap().contents(), "");
    assert_eq!(parser.screen().cell(1, 0).unwrap().contents(), "a");
    assert_eq!(parser.screen().cell(1, 1).unwrap().contents(), "");

    parser.process(b"\x1b[H\x1b[J");
    parser.process(b"0123456789012345678901234567890123456789012345678901234567890123456789012345678");
    assert_eq!(parser.screen().contents(), "0123456789012345678901234567890123456789012345678901234567890123456789012345678");
    assert_eq!(parser.screen().cursor_position(), (0, 79));
    parser.process("ネ".as_bytes());
    assert_eq!(parser.screen().contents(), "0123456789012345678901234567890123456789012345678901234567890123456789012345678\nネ");
    assert_eq!(parser.screen().cursor_position(), (1, 2));
    parser.process(b"a");
    assert_eq!(parser.screen().contents(), "0123456789012345678901234567890123456789012345678901234567890123456789012345678\nネa");
    assert_eq!(parser.screen().cursor_position(), (1, 3));
    assert_eq!(parser.screen().cell(0, 77).unwrap().contents(), "7");
    assert_eq!(parser.screen().cell(0, 78).unwrap().contents(), "8");
    assert_eq!(parser.screen().cell(0, 79).unwrap().contents(), "");
    assert_eq!(parser.screen().cell(1, 0).unwrap().contents(), "ネ");
    assert_eq!(parser.screen().cell(1, 1).unwrap().contents(), "");
    assert_eq!(parser.screen().cell(1, 2).unwrap().contents(), "a");
    assert_eq!(parser.screen().cell(1, 3).unwrap().contents(), "");

    let mut new_parser = vt100::Parser::default();
    new_parser.process(&parser.screen().contents_formatted());
    assert_eq!(new_parser.screen().contents(), parser.screen().contents());

    parser.process(b"\x1b[H\x1b[J");
    assert_eq!(parser.screen().contents(), "");
    parser.process(b"                                                                                ");
    assert_eq!(parser.screen().contents(), "                                                                                ");
    parser.process(b"\n");
    assert_eq!(parser.screen().contents(), "                                                                                ");
    parser.process(b"\n");
    assert_eq!(parser.screen().contents(), "                                                                                ");
    parser.process(b" ");
    assert_eq!(parser.screen().contents(), "                                                                                \n\n\n ");

    parser.process(b"\x1b[H\x1b[J");
    assert_eq!(parser.screen().contents(), "");
    let screen = parser.screen().clone();
    parser.process("ネa\x1b[L\x1b[1;79Hbcd".as_bytes());
    assert_eq!(parser.screen().contents(), "                                                                              bcd a");
    assert_eq!(
        parser.screen().contents_formatted(),
        "\x1b[?25h\x1b[m\x1b[H\x1b[J\x1b[78Cbcd\x1b[Ca\x1b[2;2H".as_bytes()
    );
    assert_eq!(
        parser.screen().contents_diff(&screen),
        "\x1b[78Cbcd\x1b[Ca\x1b[2;2H".as_bytes()
    );
}

#[test]
fn wrap_weird() {
    let mut parser = vt100::Parser::default();

    let screen = parser.screen().clone();
    parser.process(b"foo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo");
    assert_eq!(parser.screen().contents_formatted(), &b"\x1b[?25h\x1b[m\x1b[H\x1b[Jfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo"[..]);
    assert_eq!(parser.screen().contents_diff(&screen), &b"foo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo"[..]);

    let screen = parser.screen().clone();
    parser.process(b"\x1b[3;80H ");
    assert_eq!(parser.screen().contents_formatted(), &b"\x1b[?25h\x1b[m\x1b[H\x1b[Jfoo\r\nfoo\r\nfoo\x1b[76C \r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\r\nfoo\x1b[3;80H "[..]);
    assert_eq!(parser.screen().contents_diff(&screen), &b"\x1b[3;80H "[..]);
}