From 7e02aa0efff228126ffc43e81e5e127e1b9e32dd Mon Sep 17 00:00:00 2001 From: Aleksey Kladov Date: Fri, 19 Jul 2019 00:35:27 +0300 Subject: migrate ra_fmt to new rowan --- crates/ra_fmt/src/lib.rs | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) (limited to 'crates/ra_fmt') diff --git a/crates/ra_fmt/src/lib.rs b/crates/ra_fmt/src/lib.rs index 1c2c04ad2..d6e895729 100644 --- a/crates/ra_fmt/src/lib.rs +++ b/crates/ra_fmt/src/lib.rs @@ -3,7 +3,7 @@ use itertools::Itertools; use ra_syntax::{ ast::{self, AstNode, AstToken}, - SyntaxKind, + SmolStr, SyntaxKind, SyntaxKind::*, SyntaxNode, SyntaxToken, T, }; @@ -15,12 +15,12 @@ pub fn reindent(text: &str, indent: &str) -> String { } /// If the node is on the beginning of the line, calculate indent. -pub fn leading_indent(node: &SyntaxNode) -> Option<&str> { +pub fn leading_indent(node: &SyntaxNode) -> Option { for token in prev_tokens(node.first_token()?) { - if let Some(ws) = ast::Whitespace::cast(token) { + if let Some(ws) = ast::Whitespace::cast(token.clone()) { let ws_text = ws.text(); if let Some(pos) = ws_text.rfind('\n') { - return Some(&ws_text[pos + 1..]); + return Some(ws_text[pos + 1..].into()); } } if token.text().contains('\n') { @@ -31,17 +31,17 @@ pub fn leading_indent(node: &SyntaxNode) -> Option<&str> { } fn prev_tokens(token: SyntaxToken) -> impl Iterator { - successors(token.prev_token(), |&token| token.prev_token()) + successors(token.prev_token(), |token| token.prev_token()) } -pub fn extract_trivial_expression(block: &ast::Block) -> Option<&ast::Expr> { +pub fn extract_trivial_expression(block: &ast::Block) -> Option { let expr = block.expr()?; if expr.syntax().text().contains('\n') { return None; } let non_trivial_children = block.syntax().children().filter(|it| match it.kind() { WHITESPACE | T!['{'] | T!['}'] => false, - _ => it != &expr.syntax(), + _ => it != expr.syntax(), }); if non_trivial_children.count() > 0 { return None; -- cgit v1.2.3