blob: 5469fbdc7af05e3aa1bcaf41ef9c825cfbfefb32 (
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
|
#include "FileVT.class.h"
FileVT::FileVT(String filename, u8int mode, FSNode *start, u8int encoding) :
m_file(filename, mode, start, encoding), m_buffer() {
if (mode != FM_READ) {
m_isWriting = true;
m_bufferPos = 0;
} else {
m_isWriting = false;
m_buffer = m_file.readLine();
}
}
void FileVT::setCursorCol(u32int col) {
if (!m_isWriting) return;
while (m_buffer.size() < col) {
put(" ");
}
}
void FileVT::put(WChar c, bool updatecsr) {
if (!m_isWriting) return;
if (c.value == '\n') {
m_file.write(m_buffer, true);
m_buffer.clear();
} else if (c.value == '\t') {
u32int nc = (m_buffer.size() + 8) &~(8 - 1);
while (m_buffer.size() < nc) put(" ");
} else {
m_buffer += c;
}
}
keypress_t FileVT::getKeypress(bool show, bool block) {
keypress_t ret;
if (m_isWriting) return ret;
if (m_bufferPos == m_buffer.size()) {
ret.hascmd = true;
ret.command = KBDC_ENTER;
if (m_file.eof()) {
m_buffer = ".";
} else {
m_buffer = m_file.readLine();
}
m_bufferPos = 0;
} else {
WChar c = m_buffer[m_bufferPos];
m_bufferPos++;
if (c.value == '\t') {
ret.hascmd = true;
ret.command = KBDC_TAB;
} else if (c.value == '\b') {
ret.hascmd = true;
ret.command = KBDC_BACKSPACE;
} else {
ret.haschar = true;
ret.character = c;
}
}
return ret;
}
|