Unnamed repository; edit this file 'description' to name the repository.
Fix panic in `add_type_ascription`
Assist wasn't applicable when the let statement was missing a pattern before, so we should do the same now.
DropDemBits 2023-11-15
parent df62962 · commit 3f99a56
-rw-r--r--crates/ide-assists/src/handlers/add_turbo_fish.rs17
-rw-r--r--crates/ide-assists/src/tests.rs5
2 files changed, 14 insertions, 8 deletions
diff --git a/crates/ide-assists/src/handlers/add_turbo_fish.rs b/crates/ide-assists/src/handlers/add_turbo_fish.rs
index 6afc1693fa..88fd0b1b73 100644
--- a/crates/ide-assists/src/handlers/add_turbo_fish.rs
+++ b/crates/ide-assists/src/handlers/add_turbo_fish.rs
@@ -85,6 +85,10 @@ pub(crate) fn add_turbo_fish(acc: &mut Assists, ctx: &AssistContext<'_>) -> Opti
if let Some(let_stmt) = ctx.find_node_at_offset::<ast::LetStmt>() {
if let_stmt.colon_token().is_none() {
+ if let_stmt.pat().is_none() {
+ return None;
+ }
+
acc.add(
AssistId("add_type_ascription", AssistKind::RefactorRewrite),
"Add `: _` before assignment operator",
@@ -157,7 +161,10 @@ fn get_fish_head(number_of_arguments: usize) -> ast::GenericArgList {
#[cfg(test)]
mod tests {
- use crate::tests::{check_assist, check_assist_by_label, check_assist_not_applicable};
+ use crate::tests::{
+ check_assist, check_assist_by_label, check_assist_not_applicable,
+ check_assist_not_applicable_by_label,
+ };
use super::*;
@@ -400,7 +407,7 @@ fn main() {
#[test]
fn add_type_ascription_missing_pattern() {
- check_assist_by_label(
+ check_assist_not_applicable_by_label(
add_turbo_fish,
r#"
fn make<T>() -> T {}
@@ -408,12 +415,6 @@ fn main() {
let = make$0()
}
"#,
- r#"
-fn make<T>() -> T {}
-fn main() {
- let : ${0:_} = make();
-}
-"#,
"Add `: _` before assignment operator",
);
}
diff --git a/crates/ide-assists/src/tests.rs b/crates/ide-assists/src/tests.rs
index cc3e251a8f..1f72e4f03e 100644
--- a/crates/ide-assists/src/tests.rs
+++ b/crates/ide-assists/src/tests.rs
@@ -98,6 +98,11 @@ pub(crate) fn check_assist_not_applicable(assist: Handler, ra_fixture: &str) {
check(assist, ra_fixture, ExpectedResult::NotApplicable, None);
}
+#[track_caller]
+pub(crate) fn check_assist_not_applicable_by_label(assist: Handler, ra_fixture: &str, label: &str) {
+ check(assist, ra_fixture, ExpectedResult::NotApplicable, Some(label));
+}
+
/// Check assist in unresolved state. Useful to check assists for lazy computation.
#[track_caller]
pub(crate) fn check_assist_unresolved(assist: Handler, ra_fixture: &str) {