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
use crate::nodes::Token;
#[derive(Clone, Debug, PartialEq, Eq)]
pub struct Identifier {
name: String,
token: Option<Token>,
}
impl Identifier {
pub fn new<S: Into<String>>(name: S) -> Self {
Self {
name: name.into(),
token: None,
}
}
pub fn with_token(mut self, token: Token) -> Self {
self.token = Some(token);
self
}
#[inline]
pub fn set_token(&mut self, token: Token) {
self.token = Some(token);
}
#[inline]
pub fn get_token(&self) -> Option<&Token> {
self.token.as_ref()
}
#[inline]
pub fn get_name(&self) -> &String {
&self.name
}
#[inline]
pub fn mutate_name(&mut self) -> &mut String {
&mut self.name
}
#[inline]
pub fn set_name<IntoString: Into<String>>(&mut self, name: IntoString) {
let name = name.into();
if let Some(token) = &mut self.token {
token.replace_with_content(name.clone());
}
self.name = name;
}
#[inline]
pub fn into_name(self) -> String {
self.name
}
}
impl<IntoString: Into<String>> From<IntoString> for Identifier {
fn from(identifier: IntoString) -> Self {
Self {
name: identifier.into(),
token: None,
}
}
}
#[cfg(test)]
mod test {
use crate::nodes::Position;
use super::*;
#[test]
fn set_name_replaces_the_token_content() {
let token = Token::new_with_line(7, 10, 1);
let mut identifier = Identifier::new("var").with_token(token);
identifier.set_name("newVar");
assert_eq!(
identifier.get_token().unwrap(),
&Token::from_position(Position::LineNumber {
line_number: 1,
content: "newVar".into(),
})
);
}
}