mirror of
https://github.com/rust-lang/rust.git
synced 2025-01-09 22:37:34 +00:00
Merge #673
673: minor cleanups r=matklad a=matklad Co-authored-by: Aleksey Kladov <aleksey.kladov@gmail.com>
This commit is contained in:
commit
5af7b2f4af
@ -1,8 +1,9 @@
|
|||||||
use rustc_hash::FxHashSet;
|
use rustc_hash::FxHashSet;
|
||||||
|
|
||||||
use ra_syntax::{
|
use ra_syntax::{
|
||||||
ast, AstNode, Direction, SourceFile, SyntaxNode, TextRange,
|
AstNode, Direction, SourceFile, SyntaxNode, TextRange,
|
||||||
SyntaxKind::{self, *},
|
SyntaxKind::{self, *},
|
||||||
|
ast::{self, VisibilityOwner},
|
||||||
};
|
};
|
||||||
|
|
||||||
#[derive(Debug, PartialEq, Eq)]
|
#[derive(Debug, PartialEq, Eq)]
|
||||||
@ -28,7 +29,7 @@ pub fn folding_ranges(file: &SourceFile) -> Vec<Fold> {
|
|||||||
for node in file.syntax().descendants() {
|
for node in file.syntax().descendants() {
|
||||||
// Fold items that span multiple lines
|
// Fold items that span multiple lines
|
||||||
if let Some(kind) = fold_kind(node.kind()) {
|
if let Some(kind) = fold_kind(node.kind()) {
|
||||||
if has_newline(node) {
|
if node.text().contains('\n') {
|
||||||
res.push(Fold {
|
res.push(Fold {
|
||||||
range: node.range(),
|
range: node.range(),
|
||||||
kind,
|
kind,
|
||||||
@ -83,27 +84,9 @@ fn fold_kind(kind: SyntaxKind) -> Option<FoldKind> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fn has_visibility(node: &SyntaxNode) -> bool {
|
fn has_visibility(node: &SyntaxNode) -> bool {
|
||||||
use ast::VisibilityOwner;
|
ast::Module::cast(node)
|
||||||
|
|
||||||
return ast::Module::cast(node)
|
|
||||||
.and_then(|m| m.visibility())
|
.and_then(|m| m.visibility())
|
||||||
.is_some();
|
.is_some()
|
||||||
}
|
|
||||||
|
|
||||||
fn has_newline(node: &SyntaxNode) -> bool {
|
|
||||||
for descendant in node.descendants() {
|
|
||||||
if let Some(ws) = ast::Whitespace::cast(descendant) {
|
|
||||||
if ws.has_newlines() {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
} else if let Some(comment) = ast::Comment::cast(descendant) {
|
|
||||||
if comment.has_newlines() {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
false
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn contiguous_range_for_group<'a>(
|
fn contiguous_range_for_group<'a>(
|
||||||
|
Loading…
Reference in New Issue
Block a user