mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-27 20:35:09 +00:00
Use snippets in add function
This commit is contained in:
parent
9c3acd3028
commit
8eb3272ad6
5 changed files with 75 additions and 40 deletions
|
@ -10,7 +10,7 @@ use ra_syntax::{
|
||||||
};
|
};
|
||||||
use rustc_hash::{FxHashMap, FxHashSet};
|
use rustc_hash::{FxHashMap, FxHashSet};
|
||||||
|
|
||||||
use crate::{AssistContext, AssistId, Assists};
|
use crate::{utils::render_snippet, AssistContext, AssistId, Assists};
|
||||||
|
|
||||||
// Assist: add_function
|
// Assist: add_function
|
||||||
//
|
//
|
||||||
|
@ -33,7 +33,7 @@ use crate::{AssistContext, AssistId, Assists};
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
// fn bar(arg: &str, baz: Baz) {
|
// fn bar(arg: &str, baz: Baz) {
|
||||||
// todo!()
|
// ${0:todo!()}
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
// ```
|
// ```
|
||||||
|
@ -58,18 +58,27 @@ pub(crate) fn add_function(acc: &mut Assists, ctx: &AssistContext) -> Option<()>
|
||||||
let function_builder = FunctionBuilder::from_call(&ctx, &call, &path, target_module)?;
|
let function_builder = FunctionBuilder::from_call(&ctx, &call, &path, target_module)?;
|
||||||
|
|
||||||
let target = call.syntax().text_range();
|
let target = call.syntax().text_range();
|
||||||
acc.add(AssistId("add_function"), "Add function", target, |edit| {
|
acc.add(AssistId("add_function"), "Add function", target, |builder| {
|
||||||
let function_template = function_builder.render();
|
let function_template = function_builder.render();
|
||||||
edit.set_file(function_template.file);
|
builder.set_file(function_template.file);
|
||||||
edit.set_cursor(function_template.cursor_offset);
|
match ctx.config.snippet_cap {
|
||||||
edit.insert(function_template.insert_offset, function_template.fn_def.to_string());
|
Some(cap) => {
|
||||||
|
let snippet = render_snippet(
|
||||||
|
function_template.fn_def.syntax(),
|
||||||
|
function_template.placeholder_expr.syntax(),
|
||||||
|
);
|
||||||
|
builder.insert_snippet(cap, function_template.insert_offset, snippet)
|
||||||
|
}
|
||||||
|
None => builder
|
||||||
|
.insert(function_template.insert_offset, function_template.fn_def.to_string()),
|
||||||
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
struct FunctionTemplate {
|
struct FunctionTemplate {
|
||||||
insert_offset: TextSize,
|
insert_offset: TextSize,
|
||||||
cursor_offset: TextSize,
|
|
||||||
fn_def: ast::SourceFile,
|
fn_def: ast::SourceFile,
|
||||||
|
placeholder_expr: ast::MacroCall,
|
||||||
file: FileId,
|
file: FileId,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -136,9 +145,7 @@ impl FunctionBuilder {
|
||||||
|
|
||||||
let placeholder_expr =
|
let placeholder_expr =
|
||||||
fn_def.syntax().descendants().find_map(ast::MacroCall::cast).unwrap();
|
fn_def.syntax().descendants().find_map(ast::MacroCall::cast).unwrap();
|
||||||
let cursor_offset_from_fn_start = placeholder_expr.syntax().text_range().start();
|
FunctionTemplate { insert_offset, placeholder_expr, fn_def, file: self.file }
|
||||||
let cursor_offset = insert_offset + cursor_offset_from_fn_start;
|
|
||||||
FunctionTemplate { insert_offset, cursor_offset, fn_def, file: self.file }
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -316,7 +323,7 @@ fn foo() {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn bar() {
|
fn bar() {
|
||||||
<|>todo!()
|
${0:todo!()}
|
||||||
}
|
}
|
||||||
",
|
",
|
||||||
)
|
)
|
||||||
|
@ -343,7 +350,7 @@ impl Foo {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn bar() {
|
fn bar() {
|
||||||
<|>todo!()
|
${0:todo!()}
|
||||||
}
|
}
|
||||||
",
|
",
|
||||||
)
|
)
|
||||||
|
@ -367,7 +374,7 @@ fn foo1() {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn bar() {
|
fn bar() {
|
||||||
<|>todo!()
|
${0:todo!()}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn foo2() {}
|
fn foo2() {}
|
||||||
|
@ -393,7 +400,7 @@ mod baz {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn bar() {
|
fn bar() {
|
||||||
<|>todo!()
|
${0:todo!()}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
",
|
",
|
||||||
|
@ -419,7 +426,7 @@ fn foo() {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn bar(baz: Baz) {
|
fn bar(baz: Baz) {
|
||||||
<|>todo!()
|
${0:todo!()}
|
||||||
}
|
}
|
||||||
",
|
",
|
||||||
);
|
);
|
||||||
|
@ -452,7 +459,7 @@ impl Baz {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn bar(baz: Baz) {
|
fn bar(baz: Baz) {
|
||||||
<|>todo!()
|
${0:todo!()}
|
||||||
}
|
}
|
||||||
",
|
",
|
||||||
)
|
)
|
||||||
|
@ -473,7 +480,7 @@ fn foo() {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn bar(arg: &str) {
|
fn bar(arg: &str) {
|
||||||
<|>todo!()
|
${0:todo!()}
|
||||||
}
|
}
|
||||||
"#,
|
"#,
|
||||||
)
|
)
|
||||||
|
@ -494,7 +501,7 @@ fn foo() {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn bar(arg: char) {
|
fn bar(arg: char) {
|
||||||
<|>todo!()
|
${0:todo!()}
|
||||||
}
|
}
|
||||||
"#,
|
"#,
|
||||||
)
|
)
|
||||||
|
@ -515,7 +522,7 @@ fn foo() {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn bar(arg: i32) {
|
fn bar(arg: i32) {
|
||||||
<|>todo!()
|
${0:todo!()}
|
||||||
}
|
}
|
||||||
",
|
",
|
||||||
)
|
)
|
||||||
|
@ -536,7 +543,7 @@ fn foo() {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn bar(arg: u8) {
|
fn bar(arg: u8) {
|
||||||
<|>todo!()
|
${0:todo!()}
|
||||||
}
|
}
|
||||||
",
|
",
|
||||||
)
|
)
|
||||||
|
@ -561,7 +568,7 @@ fn foo() {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn bar(x: u8) {
|
fn bar(x: u8) {
|
||||||
<|>todo!()
|
${0:todo!()}
|
||||||
}
|
}
|
||||||
",
|
",
|
||||||
)
|
)
|
||||||
|
@ -584,7 +591,7 @@ fn foo() {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn bar(worble: ()) {
|
fn bar(worble: ()) {
|
||||||
<|>todo!()
|
${0:todo!()}
|
||||||
}
|
}
|
||||||
",
|
",
|
||||||
)
|
)
|
||||||
|
@ -613,7 +620,7 @@ fn baz() {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn bar(foo: impl Foo) {
|
fn bar(foo: impl Foo) {
|
||||||
<|>todo!()
|
${0:todo!()}
|
||||||
}
|
}
|
||||||
",
|
",
|
||||||
)
|
)
|
||||||
|
@ -640,7 +647,7 @@ fn foo() {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn bar(baz: &Baz) {
|
fn bar(baz: &Baz) {
|
||||||
<|>todo!()
|
${0:todo!()}
|
||||||
}
|
}
|
||||||
",
|
",
|
||||||
)
|
)
|
||||||
|
@ -669,7 +676,7 @@ fn foo() {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn bar(baz: Baz::Bof) {
|
fn bar(baz: Baz::Bof) {
|
||||||
<|>todo!()
|
${0:todo!()}
|
||||||
}
|
}
|
||||||
",
|
",
|
||||||
)
|
)
|
||||||
|
@ -692,7 +699,7 @@ fn foo<T>(t: T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn bar<T>(t: T) {
|
fn bar<T>(t: T) {
|
||||||
<|>todo!()
|
${0:todo!()}
|
||||||
}
|
}
|
||||||
",
|
",
|
||||||
)
|
)
|
||||||
|
@ -723,7 +730,7 @@ fn foo() {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn bar(arg: fn() -> Baz) {
|
fn bar(arg: fn() -> Baz) {
|
||||||
<|>todo!()
|
${0:todo!()}
|
||||||
}
|
}
|
||||||
",
|
",
|
||||||
)
|
)
|
||||||
|
@ -748,7 +755,7 @@ fn foo() {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn bar(closure: impl Fn(i64) -> i64) {
|
fn bar(closure: impl Fn(i64) -> i64) {
|
||||||
<|>todo!()
|
${0:todo!()}
|
||||||
}
|
}
|
||||||
",
|
",
|
||||||
)
|
)
|
||||||
|
@ -769,7 +776,7 @@ fn foo() {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn bar(baz: ()) {
|
fn bar(baz: ()) {
|
||||||
<|>todo!()
|
${0:todo!()}
|
||||||
}
|
}
|
||||||
",
|
",
|
||||||
)
|
)
|
||||||
|
@ -794,7 +801,7 @@ fn foo() {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn bar(baz_1: Baz, baz_2: Baz) {
|
fn bar(baz_1: Baz, baz_2: Baz) {
|
||||||
<|>todo!()
|
${0:todo!()}
|
||||||
}
|
}
|
||||||
",
|
",
|
||||||
)
|
)
|
||||||
|
@ -819,7 +826,7 @@ fn foo() {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn bar(baz_1: Baz, baz_2: Baz, arg_1: &str, arg_2: &str) {
|
fn bar(baz_1: Baz, baz_2: Baz, arg_1: &str, arg_2: &str) {
|
||||||
<|>todo!()
|
${0:todo!()}
|
||||||
}
|
}
|
||||||
"#,
|
"#,
|
||||||
)
|
)
|
||||||
|
@ -839,7 +846,7 @@ fn foo() {
|
||||||
r"
|
r"
|
||||||
mod bar {
|
mod bar {
|
||||||
pub(crate) fn my_fn() {
|
pub(crate) fn my_fn() {
|
||||||
<|>todo!()
|
${0:todo!()}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -878,7 +885,7 @@ fn bar() {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn baz(foo: foo::Foo) {
|
fn baz(foo: foo::Foo) {
|
||||||
<|>todo!()
|
${0:todo!()}
|
||||||
}
|
}
|
||||||
",
|
",
|
||||||
)
|
)
|
||||||
|
@ -902,7 +909,7 @@ mod bar {
|
||||||
fn something_else() {}
|
fn something_else() {}
|
||||||
|
|
||||||
pub(crate) fn my_fn() {
|
pub(crate) fn my_fn() {
|
||||||
<|>todo!()
|
${0:todo!()}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -930,7 +937,7 @@ fn foo() {
|
||||||
mod bar {
|
mod bar {
|
||||||
mod baz {
|
mod baz {
|
||||||
pub(crate) fn my_fn() {
|
pub(crate) fn my_fn() {
|
||||||
<|>todo!()
|
${0:todo!()}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -959,7 +966,7 @@ fn main() {
|
||||||
|
|
||||||
|
|
||||||
pub(crate) fn bar() {
|
pub(crate) fn bar() {
|
||||||
<|>todo!()
|
${0:todo!()}
|
||||||
}",
|
}",
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
|
@ -78,7 +78,7 @@ fn foo() {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn bar(arg: &str, baz: Baz) {
|
fn bar(arg: &str, baz: Baz) {
|
||||||
todo!()
|
${0:todo!()}
|
||||||
}
|
}
|
||||||
|
|
||||||
"#####,
|
"#####,
|
||||||
|
|
|
@ -1,18 +1,38 @@
|
||||||
//! Assorted functions shared by several assists.
|
//! Assorted functions shared by several assists.
|
||||||
pub(crate) mod insert_use;
|
pub(crate) mod insert_use;
|
||||||
|
|
||||||
use std::iter;
|
use std::{iter, ops};
|
||||||
|
|
||||||
use hir::{Adt, Crate, Semantics, Trait, Type};
|
use hir::{Adt, Crate, Semantics, Trait, Type};
|
||||||
use ra_ide_db::RootDatabase;
|
use ra_ide_db::RootDatabase;
|
||||||
use ra_syntax::{
|
use ra_syntax::{
|
||||||
ast::{self, make, NameOwner},
|
ast::{self, make, NameOwner},
|
||||||
AstNode, T,
|
AstNode, SyntaxNode, T,
|
||||||
};
|
};
|
||||||
use rustc_hash::FxHashSet;
|
use rustc_hash::FxHashSet;
|
||||||
|
|
||||||
pub(crate) use insert_use::insert_use_statement;
|
pub(crate) use insert_use::insert_use_statement;
|
||||||
|
|
||||||
|
pub(crate) fn render_snippet(node: &SyntaxNode, placeholder: &SyntaxNode) -> String {
|
||||||
|
assert!(placeholder.ancestors().any(|it| it == *node));
|
||||||
|
let range = placeholder.text_range() - node.text_range().start();
|
||||||
|
let range: ops::Range<usize> = range.into();
|
||||||
|
|
||||||
|
let mut placeholder = placeholder.to_string();
|
||||||
|
escape(&mut placeholder);
|
||||||
|
let tab_stop = format!("${{0:{}}}", placeholder);
|
||||||
|
|
||||||
|
let mut buf = node.to_string();
|
||||||
|
buf.replace_range(range, &tab_stop);
|
||||||
|
return buf;
|
||||||
|
|
||||||
|
fn escape(buf: &mut String) {
|
||||||
|
stdx::replace(buf, '{', r"\{");
|
||||||
|
stdx::replace(buf, '}', r"\}");
|
||||||
|
stdx::replace(buf, '$', r"\$");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pub fn get_missing_assoc_items(
|
pub fn get_missing_assoc_items(
|
||||||
sema: &Semantics<RootDatabase>,
|
sema: &Semantics<RootDatabase>,
|
||||||
impl_def: &ast::ImplDef,
|
impl_def: &ast::ImplDef,
|
||||||
|
|
|
@ -116,3 +116,11 @@ pub fn to_lower_snake_case(s: &str) -> String {
|
||||||
}
|
}
|
||||||
buf
|
buf
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn replace(buf: &mut String, from: char, to: &str) {
|
||||||
|
if !buf.contains(from) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
// FIXME: do this in place.
|
||||||
|
*buf = buf.replace(from, to)
|
||||||
|
}
|
||||||
|
|
|
@ -77,7 +77,7 @@ fn foo() {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn bar(arg: &str, baz: Baz) {
|
fn bar(arg: &str, baz: Baz) {
|
||||||
todo!()
|
${0:todo!()}
|
||||||
}
|
}
|
||||||
|
|
||||||
```
|
```
|
||||||
|
|
Loading…
Reference in a new issue