Skip to content

Commit 4bcdb05

Browse files
committed
include tabstops
1 parent 778e71b commit 4bcdb05

File tree

1 file changed

+21
-6
lines changed

1 file changed

+21
-6
lines changed

crates/ide_assists/src/handlers/add_turbo_fish.rs

Lines changed: 21 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -83,25 +83,40 @@ pub(crate) fn add_turbo_fish(acc: &mut Assists, ctx: &AssistContext) -> Option<(
8383
matches!(param, hir::GenericParam::TypeParam(_) | hir::GenericParam::ConstParam(_))
8484
})
8585
.count();
86-
let fish_head = std::iter::repeat("_").take(number_of_arguments).collect::<Vec<_>>().join(",");
8786

8887
acc.add(
8988
AssistId("add_turbo_fish", AssistKind::RefactorRewrite),
9089
"Add `::<>`",
9190
ident.text_range(),
9291
|builder| match ctx.config.snippet_cap {
9392
Some(cap) => {
94-
let snip = format!("::<${{0:{}}}>", fish_head);
93+
let snip = format!("::<{}>", get_snippet_fish_head(number_of_arguments));
9594
builder.insert_snippet(cap, ident.text_range().end(), snip)
9695
}
9796
None => {
97+
let fish_head =
98+
std::iter::repeat("_").take(number_of_arguments).collect::<Vec<_>>().join(", ");
9899
let snip = format!("::<{}>", fish_head);
99100
builder.insert(ident.text_range().end(), snip);
100101
}
101102
},
102103
)
103104
}
104105

106+
/// This will create a snippet string with tabstops marked
107+
fn get_snippet_fish_head(number_of_arguments: usize) -> String {
108+
let mut fish_head = String::new();
109+
let mut i = 1;
110+
while i < number_of_arguments {
111+
fish_head.push_str(&format!("${{{}:_}},", i));
112+
i = i + 1;
113+
}
114+
115+
// tabstop 0 is a special case and always the last one
116+
fish_head.push_str("${0:_}");
117+
fish_head
118+
}
119+
105120
#[cfg(test)]
106121
mod tests {
107122
use crate::tests::{check_assist, check_assist_by_label, check_assist_not_applicable};
@@ -140,7 +155,7 @@ fn main() {
140155
r#"
141156
fn make<T, A>() -> T {}
142157
fn main() {
143-
make::<${0:_,_}>();
158+
make::<${1:_},${0:_}>();
144159
}
145160
"#,
146161
);
@@ -159,7 +174,7 @@ fn main() {
159174
r#"
160175
fn make<T, A, B, C, D, E, F>() -> T {}
161176
fn main() {
162-
make::<${0:_,_,_,_,_,_,_}>();
177+
make::<${1:_},${2:_},${3:_},${4:_},${5:_},${6:_},${0:_}>();
163178
}
164179
"#,
165180
);
@@ -358,7 +373,7 @@ fn main() {
358373
r#"
359374
fn make<'a, T, A>(t: T, a: A) {}
360375
fn main() {
361-
make::<${0:_,_}>(5, 2);
376+
make::<${1:_},${0:_}>(5, 2);
362377
}
363378
"#,
364379
);
@@ -377,7 +392,7 @@ fn main() {
377392
r#"
378393
fn make<T, const N: usize>(t: T) {}
379394
fn main() {
380-
make::<${0:_,_}>(3);
395+
make::<${1:_},${0:_}>(3);
381396
}
382397
"#,
383398
);

0 commit comments

Comments
 (0)