Skip attrs in Literal::token
This commit is contained in:
parent
41c56c8a0d
commit
474a04615c
@ -229,8 +229,11 @@ pub enum LiteralKind {
|
||||
|
||||
impl ast::Literal {
|
||||
pub fn token(&self) -> SyntaxToken {
|
||||
match self.syntax().first_child_or_token().unwrap() {
|
||||
SyntaxElement::Token(token) => token,
|
||||
let elem = self.syntax()
|
||||
.children_with_tokens()
|
||||
.find(|e| e.kind() != ATTR && !e.kind().is_trivia());
|
||||
match elem {
|
||||
Some(SyntaxElement::Token(token)) => token,
|
||||
_ => unreachable!(),
|
||||
}
|
||||
}
|
||||
@ -268,6 +271,18 @@ impl ast::Literal {
|
||||
}
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_literal_with_attr() {
|
||||
let parse = ast::SourceFile::parse(r#"const _: &str = { #[attr] "Hello" };"#);
|
||||
let lit = parse
|
||||
.tree
|
||||
.syntax()
|
||||
.descendants()
|
||||
.find_map(ast::Literal::cast)
|
||||
.unwrap();
|
||||
assert_eq!(lit.token().text(), r#""Hello""#);
|
||||
}
|
||||
|
||||
impl ast::NamedField {
|
||||
pub fn parent_struct_lit(&self) -> &ast::StructLit {
|
||||
self.syntax().ancestors().find_map(ast::StructLit::cast).unwrap()
|
||||
|
Loading…
x
Reference in New Issue
Block a user