Unnamed repository; edit this file 'description' to name the repository.
Auto merge of #16009 - werifu:fix-extract-function, r=Veykril
fix: bug in extract_function.rs There is a little bug in extract_function: It appends `use path::to::ControlFlow;` if the function created contains string "ControlFlow". A case below (also in the test named `does_not_import_control_flow` which will fail in the original code) <img width="322" alt="image" src="https://github.com/rust-lang/rust-analyzer/assets/53432474/4b80bb58-0cfd-4d56-b64c-d9649eed336e"> <img width="391" alt="image" src="https://github.com/rust-lang/rust-analyzer/assets/53432474/3d7262f4-8a4c-44ea-822d-304b8b23fe28"> Now I have changed the condition determining whether adding import statement. Only when the new function body contains ControlFlow::Break or ControlFlow::Continue can the import statement be added. Last related PR: https://github.com/rust-lang/rust-analyzer/pull/10309
bors 2023-12-08
parent 9975650 · parent 05e8b92 · commit 49dd380
-rw-r--r--crates/ide-assists/src/handlers/extract_function.rs28
1 files changed, 27 insertions, 1 deletions
diff --git a/crates/ide-assists/src/handlers/extract_function.rs b/crates/ide-assists/src/handlers/extract_function.rs
index d4a1230779..347a3e9ba0 100644
--- a/crates/ide-assists/src/handlers/extract_function.rs
+++ b/crates/ide-assists/src/handlers/extract_function.rs
@@ -147,7 +147,12 @@ pub(crate) fn extract_function(acc: &mut Assists, ctx: &AssistContext<'_>) -> Op
_ => format_function(ctx, module, &fun, old_indent, new_indent),
};
- if fn_def.contains("ControlFlow") {
+ // There are external control flows
+ if fun
+ .control_flow
+ .kind
+ .is_some_and(|kind| matches!(kind, FlowKind::Break(_, _) | FlowKind::Continue(_)))
+ {
let scope = match scope {
ImportScope::File(it) => ImportScope::File(builder.make_mut(it)),
ImportScope::Module(it) => ImportScope::Module(builder.make_mut(it)),
@@ -4971,6 +4976,27 @@ fn $0fun_name(arg: &mut Foo) {
"#,
);
}
+ #[test]
+ fn does_not_import_control_flow() {
+ check_assist(
+ extract_function,
+ r#"
+//- minicore: try
+fn func() {
+ $0let cf = "I'm ControlFlow";$0
+}
+"#,
+ r#"
+fn func() {
+ fun_name();
+}
+
+fn $0fun_name() {
+ let cf = "I'm ControlFlow";
+}
+"#,
+ );
+ }
#[test]
fn extract_function_copies_comment_at_start() {