From 7d2d3ac3db6ea7bbb3d77569495176da3b2992e6 Mon Sep 17 00:00:00 2001 From: Aleksey Kladov Date: Wed, 15 Jan 2020 18:30:23 +0100 Subject: More fluent API --- crates/ra_syntax/src/ast/edit.rs | 22 ++++++++++++---------- 1 file changed, 12 insertions(+), 10 deletions(-) (limited to 'crates/ra_syntax') diff --git a/crates/ra_syntax/src/ast/edit.rs b/crates/ra_syntax/src/ast/edit.rs index 3037f2715..d88a0cf4b 100644 --- a/crates/ra_syntax/src/ast/edit.rs +++ b/crates/ra_syntax/src/ast/edit.rs @@ -23,7 +23,7 @@ impl ast::BinExpr { pub fn replace_op(&self, op: SyntaxKind) -> Option { let op_node: SyntaxElement = self.op_details()?.0.into(); let to_insert: Option = Some(make::token(op).into()); - Some(replace_children(self, single_node(op_node), to_insert.into_iter())) + Some(replace_children(self, single_node(op_node), to_insert)) } } @@ -39,10 +39,10 @@ impl ast::FnDef { } else { to_insert.push(make::tokens::single_space().into()); to_insert.push(body.syntax().clone().into()); - return insert_children(self, InsertPosition::Last, to_insert.into_iter()); + return insert_children(self, InsertPosition::Last, to_insert); }; to_insert.push(body.syntax().clone().into()); - replace_children(self, single_node(old_body_or_semi), to_insert.into_iter()) + replace_children(self, single_node(old_body_or_semi), to_insert) } } @@ -75,7 +75,7 @@ impl ast::ItemList { let ws = tokens::WsBuilder::new(&format!("\n{}", indent)); let to_insert: ArrayVec<[SyntaxElement; 2]> = [ws.ws().into(), item.syntax().clone().into()].into(); - insert_children(self, position, to_insert.into_iter()) + insert_children(self, position, to_insert) } fn l_curly(&self) -> Option { @@ -184,7 +184,7 @@ impl ast::RecordFieldList { InsertPosition::After(anchor) => after_field!(anchor), }; - insert_children(self, position, to_insert.iter().cloned()) + insert_children(self, position, to_insert) } fn l_curly(&self) -> Option { @@ -228,9 +228,10 @@ fn strip_attrs_and_docs_inner(mut node: SyntaxNode) -> SyntaxNode { #[must_use] pub fn replace_descendants( parent: &N, - replacement_map: impl Iterator, + replacement_map: impl IntoIterator, ) -> N { let map = replacement_map + .into_iter() .map(|(from, to)| (from.syntax().clone().into(), to.syntax().clone().into())) .collect::>(); let new_syntax = algo::replace_descendants(parent.syntax(), &|n| map.get(n).cloned()); @@ -344,9 +345,9 @@ fn prev_tokens(token: SyntaxToken) -> impl Iterator { fn insert_children( parent: &N, position: InsertPosition, - mut to_insert: impl Iterator, + to_insert: impl IntoIterator, ) -> N { - let new_syntax = algo::insert_children(parent.syntax(), position, &mut to_insert); + let new_syntax = algo::insert_children(parent.syntax(), position, &mut to_insert.into_iter()); N::cast(new_syntax).unwrap() } @@ -359,9 +360,10 @@ fn single_node(element: impl Into) -> RangeInclusive( parent: &N, to_replace: RangeInclusive, - mut to_insert: impl Iterator, + to_insert: impl IntoIterator, ) -> N { - let new_syntax = algo::replace_children(parent.syntax(), to_replace, &mut to_insert); + let new_syntax = + algo::replace_children(parent.syntax(), to_replace, &mut to_insert.into_iter()); N::cast(new_syntax).unwrap() } -- cgit v1.2.3