dora_parser/lexer/
position.rs1use std::fmt::{Display, Error, Formatter};
2use std::result::Result;
3
4#[derive(PartialEq, Eq, Debug, Copy, Clone)]
5pub struct Position {
6 pub line: u32,
7 pub column: u32,
8}
9
10impl Position {
11 pub fn new(l: u32, c: u32) -> Position {
12 assert!(l >= 1);
13 assert!(c >= 1);
14
15 Position { line: l, column: c }
16 }
17}
18
19impl Display for Position {
20 fn fmt(&self, f: &mut Formatter) -> Result<(), Error> {
21 write!(f, "{}:{}", self.line, self.column)
22 }
23}
24
25#[derive(Copy, Clone, Debug)]
26pub struct Span {
27 start: Loc,
28 count: u32,
29}
30
31impl Span {
32 pub fn new(start: u32, count: u32) -> Span {
33 Span {
34 start: Loc::new(start),
35 count,
36 }
37 }
38
39 pub fn at(start: u32) -> Span {
40 Span {
41 start: Loc::new(start),
42 count: 0,
43 }
44 }
45
46 pub fn invalid() -> Span {
47 Span {
48 start: Loc::invalid(),
49 count: 0,
50 }
51 }
52
53 pub fn is_valid(&self) -> bool {
54 self.start.is_valid()
55 }
56
57 pub fn start(&self) -> u32 {
58 self.start.idx()
59 }
60
61 pub fn count(&self) -> u32 {
62 self.count
63 }
64
65 pub fn end(&self) -> u32 {
66 self.start.idx() + self.count
67 }
68}
69
70#[derive(Copy, Clone, Debug)]
71pub struct Loc(u32);
72
73impl Loc {
74 fn new(pos: u32) -> Loc {
75 assert!(pos < u32::max_value());
76 Loc(pos)
77 }
78
79 fn invalid() -> Loc {
80 Loc(u32::max_value())
81 }
82
83 fn is_valid(&self) -> bool {
84 self.0 != u32::max_value()
85 }
86
87 fn idx(&self) -> u32 {
88 assert!(self.is_valid());
89 self.0
90 }
91}
92
93#[test]
94fn test_new() {
95 let pos = Position::new(3, 1);
96
97 assert_eq!(pos.line, 3);
98 assert_eq!(pos.column, 1);
99
100 assert_eq!(&format!("{}", pos)[..], "3:1");
101}