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
crate::use_native_or_external!(List);
crate::use_native_or_external!(SharedByteList);
use super::DecodedInput;
use crate::source::SourceLine;
impl DecodedInput {
pub fn update_bytes(&mut self, bytes: List<u8>) {
let mut line = SourceLine::new(0, 0, true);
let mut lines = List::<SourceLine>::new();
for (idx, c) in bytes.iter().enumerate() {
line.set_end(idx + 1);
if *c == b'\n' {
line.set_ends_with_eof(false);
lines.push(line);
line = SourceLine::new(idx + 1, 0, true)
}
}
line.set_end(bytes.len());
line.set_ends_with_eof(true);
lines.push(line);
self.set_bytes(bytes);
self.set_lines(lines);
}
pub fn line_col_for_pos(&self, mut pos: usize) -> Option<(usize, usize)> {
if pos == self.len() {
let last_line = self.lines().last()?;
return Some((self.lines().len() - 1, last_line.len()));
}
for (lineno, line) in self.lines().iter().enumerate() {
if line.len() > pos {
return Some((lineno, pos));
} else {
pos -= line.len()
}
}
None
}
pub(crate) fn line_at(&self, idx: usize) -> &SourceLine {
&self.lines()[idx]
}
pub(crate) fn substr_at(&self, start: usize, end: usize) -> Option<&[u8]> {
if start <= end && end <= self.bytes().len() {
Some(&self.bytes()[start..end])
} else {
None
}
}
pub(crate) fn len(&self) -> usize {
self.bytes().len()
}
pub fn as_shared_bytes(&self) -> SharedByteList {
self.bytes().as_slice()
}
}