Unnamed repository; edit this file 'description' to name the repository.
Diffstat (limited to 'crates/syntax/src/ast/syntax_factory/constructors.rs')
-rw-r--r--crates/syntax/src/ast/syntax_factory/constructors.rs67
1 files changed, 41 insertions, 26 deletions
diff --git a/crates/syntax/src/ast/syntax_factory/constructors.rs b/crates/syntax/src/ast/syntax_factory/constructors.rs
index 44f13041c2..1854000d3d 100644
--- a/crates/syntax/src/ast/syntax_factory/constructors.rs
+++ b/crates/syntax/src/ast/syntax_factory/constructors.rs
@@ -1,11 +1,11 @@
//! Wrappers over [`make`] constructors
use crate::{
+ AstNode, NodeOrToken, SyntaxKind, SyntaxNode, SyntaxToken,
ast::{
- self, make, HasArgList, HasGenericArgs, HasGenericParams, HasName, HasTypeBounds,
- HasVisibility,
+ self, HasArgList, HasGenericArgs, HasGenericParams, HasLoopBody, HasName, HasTypeBounds,
+ HasVisibility, make,
},
syntax_editor::SyntaxMappingBuilder,
- AstNode, NodeOrToken, SyntaxKind, SyntaxNode, SyntaxToken,
};
use super::SyntaxFactory;
@@ -241,7 +241,7 @@ impl SyntaxFactory {
ast
}
- pub fn record_pat_field(self, name_ref: ast::NameRef, pat: ast::Pat) -> ast::RecordPatField {
+ pub fn record_pat_field(&self, name_ref: ast::NameRef, pat: ast::Pat) -> ast::RecordPatField {
let ast = make::record_pat_field(name_ref.clone(), pat.clone()).clone_for_update();
if let Some(mut mapping) = self.mappings() {
@@ -290,6 +290,10 @@ impl SyntaxFactory {
ast
}
+ pub fn rest_pat(&self) -> ast::RestPat {
+ make::rest_pat().clone_for_update()
+ }
+
pub fn block_expr(
&self,
statements: impl IntoIterator<Item = ast::Stmt>,
@@ -328,10 +332,7 @@ impl SyntaxFactory {
}
pub fn expr_paren(&self, expr: ast::Expr) -> ast::ParenExpr {
- // FIXME: `make::expr_paren` should return a `ParenExpr`, not just an `Expr`
- let ast::Expr::ParenExpr(ast) = make::expr_paren(expr.clone()).clone_for_update() else {
- unreachable!()
- };
+ let ast = make::expr_paren(expr.clone()).clone_for_update();
if let Some(mut mapping) = self.mappings() {
let mut builder = SyntaxMappingBuilder::new(ast.syntax().clone());
@@ -403,12 +404,7 @@ impl SyntaxFactory {
}
pub fn expr_call(&self, expr: ast::Expr, arg_list: ast::ArgList) -> ast::CallExpr {
- // FIXME: `make::expr_call`` should return a `CallExpr`, not just an `Expr`
- let ast::Expr::CallExpr(ast) =
- make::expr_call(expr.clone(), arg_list.clone()).clone_for_update()
- else {
- unreachable!()
- };
+ let ast = make::expr_call(expr.clone(), arg_list.clone()).clone_for_update();
if let Some(mut mapping) = self.mappings() {
let mut builder = SyntaxMappingBuilder::new(ast.syntax().clone());
@@ -426,13 +422,8 @@ impl SyntaxFactory {
method: ast::NameRef,
arg_list: ast::ArgList,
) -> ast::MethodCallExpr {
- // FIXME: `make::expr_method_call` should return a `MethodCallExpr`, not just an `Expr`
- let ast::Expr::MethodCallExpr(ast) =
- make::expr_method_call(receiver.clone(), method.clone(), arg_list.clone())
- .clone_for_update()
- else {
- unreachable!()
- };
+ let ast = make::expr_method_call(receiver.clone(), method.clone(), arg_list.clone())
+ .clone_for_update();
if let Some(mut mapping) = self.mappings() {
let mut builder = SyntaxMappingBuilder::new(ast.syntax().clone());
@@ -479,11 +470,7 @@ impl SyntaxFactory {
expr: ast::Expr,
) -> ast::ClosureExpr {
let (args, input) = iterator_input(pats);
- // FIXME: `make::expr_paren` should return a `ClosureExpr`, not just an `Expr`
- let ast::Expr::ClosureExpr(ast) = make::expr_closure(args, expr.clone()).clone_for_update()
- else {
- unreachable!()
- };
+ let ast = make::expr_closure(args, expr.clone()).clone_for_update();
if let Some(mut mapping) = self.mappings() {
let mut builder = SyntaxMappingBuilder::new(ast.syntax.clone());
@@ -543,6 +530,19 @@ impl SyntaxFactory {
ast
}
+ pub fn expr_while_loop(&self, condition: ast::Expr, body: ast::BlockExpr) -> ast::WhileExpr {
+ let ast = make::expr_while_loop(condition.clone(), body.clone()).clone_for_update();
+
+ if let Some(mut mapping) = self.mappings() {
+ let mut builder = SyntaxMappingBuilder::new(ast.syntax().clone());
+ builder.map_node(condition.syntax().clone(), ast.condition().unwrap().syntax().clone());
+ builder.map_node(body.syntax().clone(), ast.loop_body().unwrap().syntax().clone());
+ builder.finish(&mut mapping);
+ }
+
+ ast
+ }
+
pub fn expr_let(&self, pattern: ast::Pat, expr: ast::Expr) -> ast::LetExpr {
let ast = make::expr_let(pattern.clone(), expr.clone()).clone_for_update();
@@ -584,6 +584,21 @@ impl SyntaxFactory {
ast
}
+ pub fn expr_macro(&self, path: ast::Path, tt: ast::TokenTree) -> ast::MacroExpr {
+ let ast = make::expr_macro(path.clone(), tt.clone()).clone_for_update();
+
+ if let Some(mut mapping) = self.mappings() {
+ let macro_call = ast.macro_call().unwrap();
+ let mut builder = SyntaxMappingBuilder::new(macro_call.syntax().clone());
+ builder.map_node(path.syntax().clone(), macro_call.path().unwrap().syntax().clone());
+ builder
+ .map_node(tt.syntax().clone(), macro_call.token_tree().unwrap().syntax().clone());
+ builder.finish(&mut mapping);
+ }
+
+ ast
+ }
+
pub fn match_arm(
&self,
pat: ast::Pat,