mirror of
https://gitflic.ru/project/openide/openide.git
synced 2026-05-06 05:10:22 +07:00
remove variable: do not leave tailing loops/ifs (IDEA-124489)
This commit is contained in:
@@ -18,7 +18,6 @@ package com.intellij.codeInsight.daemon.impl.quickfix;
|
||||
import com.intellij.psi.*;
|
||||
import com.intellij.psi.util.InheritanceUtil;
|
||||
import com.intellij.psi.util.PropertyUtil;
|
||||
import com.intellij.psi.util.PsiTreeUtil;
|
||||
import com.intellij.psi.util.PsiUtil;
|
||||
import com.intellij.util.IncorrectOperationException;
|
||||
import gnu.trove.THashSet;
|
||||
@@ -221,7 +220,12 @@ public class RemoveUnusedVariableUtil {
|
||||
}
|
||||
}
|
||||
else if (element instanceof PsiExpressionStatement && deleteMode != CANCEL) {
|
||||
element.delete();
|
||||
final PsiElement parent = element.getParent();
|
||||
if (parent instanceof PsiIfStatement || parent instanceof PsiLoopStatement && ((PsiLoopStatement)parent).getBody() == element) {
|
||||
element.replace(JavaPsiFacade.getElementFactory(element.getProject()).createStatementFromText(";", element));
|
||||
} else {
|
||||
element.delete();
|
||||
}
|
||||
break;
|
||||
}
|
||||
else if (element instanceof PsiVariable && element == variable) {
|
||||
|
||||
@@ -0,0 +1,9 @@
|
||||
// "Remove variable 'foo'" "true"
|
||||
class a {
|
||||
private int refactorTest(int i) {
|
||||
int bar = 0;
|
||||
if (i >0) ;
|
||||
return bar;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -0,0 +1,10 @@
|
||||
// "Remove variable 'foo'" "true"
|
||||
class a {
|
||||
private int refactorTest(int i) {
|
||||
int f<caret>oo = 0;
|
||||
int bar = 0;
|
||||
if (i >0) foo++;
|
||||
return bar;
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user