Skip to content

Commit 0a240e3

Browse files
committed
succinct code
1 parent 4bcdb05 commit 0a240e3

File tree

1 file changed

+9
-12
lines changed

1 file changed

+9
-12
lines changed

crates/ide_assists/src/handlers/add_turbo_fish.rs

Lines changed: 9 additions & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,5 @@
11
use ide_db::defs::{Definition, NameRefClass};
2+
use itertools::Itertools;
23
use syntax::{ast, AstNode, SyntaxKind, T};
34

45
use crate::{
@@ -94,8 +95,7 @@ pub(crate) fn add_turbo_fish(acc: &mut Assists, ctx: &AssistContext) -> Option<(
9495
builder.insert_snippet(cap, ident.text_range().end(), snip)
9596
}
9697
None => {
97-
let fish_head =
98-
std::iter::repeat("_").take(number_of_arguments).collect::<Vec<_>>().join(", ");
98+
let fish_head = std::iter::repeat("_").take(number_of_arguments).format(", ");
9999
let snip = format!("::<{}>", fish_head);
100100
builder.insert(ident.text_range().end(), snip);
101101
}
@@ -105,12 +105,9 @@ pub(crate) fn add_turbo_fish(acc: &mut Assists, ctx: &AssistContext) -> Option<(
105105

106106
/// This will create a snippet string with tabstops marked
107107
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-
}
108+
let mut fish_head = (1..number_of_arguments)
109+
.format_with("", |i, f| f(&format_args!("${{{}:_}}, ", i)))
110+
.to_string();
114111

115112
// tabstop 0 is a special case and always the last one
116113
fish_head.push_str("${0:_}");
@@ -155,7 +152,7 @@ fn main() {
155152
r#"
156153
fn make<T, A>() -> T {}
157154
fn main() {
158-
make::<${1:_},${0:_}>();
155+
make::<${1:_}, ${0:_}>();
159156
}
160157
"#,
161158
);
@@ -174,7 +171,7 @@ fn main() {
174171
r#"
175172
fn make<T, A, B, C, D, E, F>() -> T {}
176173
fn main() {
177-
make::<${1:_},${2:_},${3:_},${4:_},${5:_},${6:_},${0:_}>();
174+
make::<${1:_}, ${2:_}, ${3:_}, ${4:_}, ${5:_}, ${6:_}, ${0:_}>();
178175
}
179176
"#,
180177
);
@@ -373,7 +370,7 @@ fn main() {
373370
r#"
374371
fn make<'a, T, A>(t: T, a: A) {}
375372
fn main() {
376-
make::<${1:_},${0:_}>(5, 2);
373+
make::<${1:_}, ${0:_}>(5, 2);
377374
}
378375
"#,
379376
);
@@ -392,7 +389,7 @@ fn main() {
392389
r#"
393390
fn make<T, const N: usize>(t: T) {}
394391
fn main() {
395-
make::<${1:_},${0:_}>(3);
392+
make::<${1:_}, ${0:_}>(3);
396393
}
397394
"#,
398395
);

0 commit comments

Comments
 (0)