/*
- * Copyright 2003-2015 Dave Griffith, Bas Leijdekkers
+ * Copyright 2003-2016 Dave Griffith, Bas Leijdekkers
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
package com.siyeh.ig.finalization;
import com.intellij.codeInspection.ui.SingleCheckboxOptionsPanel;
-import com.intellij.psi.*;
-import com.siyeh.HardcodedMethodConstants;
+import com.intellij.psi.PsiMethod;
import com.siyeh.InspectionGadgetsBundle;
import com.siyeh.ig.BaseInspection;
import com.siyeh.ig.BaseInspectionVisitor;
@Override
public void visitMethod(@NotNull PsiMethod method) {
- //note: no call to super;
- final String methodName = method.getName();
- if (!HardcodedMethodConstants.FINALIZE.equals(methodName)) {
- return;
- }
- final PsiParameterList parameterList = method.getParameterList();
- if (parameterList.getParametersCount() != 0) {
+ if (!MethodUtils.isFinalize(method)) {
return;
}
if (ignoreTrivialFinalizers && MethodUtils.isTrivial(method, false)) {
import com.intellij.codeInspection.ProblemDescriptor;
import com.intellij.openapi.project.Project;
import com.intellij.psi.*;
-import com.siyeh.HardcodedMethodConstants;
import com.siyeh.InspectionGadgetsBundle;
import com.siyeh.ig.BaseInspection;
import com.siyeh.ig.BaseInspectionVisitor;
import com.siyeh.ig.InspectionGadgetsFix;
+import com.siyeh.ig.psiutils.MethodUtils;
import org.jetbrains.annotations.NotNull;
public class FinalizeNotProtectedInspection extends BaseInspection {
@Override
public void visitMethod(@NotNull PsiMethod method) {
- final String methodName = method.getName();
- if (!HardcodedMethodConstants.FINALIZE.equals(methodName)) {
- return;
- }
- final PsiParameterList parameterList = method.getParameterList();
- if (parameterList.getParametersCount() != 0) {
+ if (!MethodUtils.isFinalize(method)) {
return;
}
if (method.hasModifierProperty(PsiModifier.PROTECTED)) {
/*
- * Copyright 2003-2007 Dave Griffith, Bas Leijdekkers
+ * Copyright 2003-2016 Dave Griffith, Bas Leijdekkers
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
return new NoExplicitFinalizeCallsVisitor();
}
- private static class NoExplicitFinalizeCallsVisitor
- extends BaseInspectionVisitor {
+ private static class NoExplicitFinalizeCallsVisitor extends BaseInspectionVisitor {
@Override
- public void visitMethodCallExpression(
- @NotNull PsiMethodCallExpression expression) {
+ public void visitMethodCallExpression(@NotNull PsiMethodCallExpression expression) {
super.visitMethodCallExpression(expression);
- if (!MethodCallUtils.isCallToMethod(expression, null, PsiType.VOID,
- HardcodedMethodConstants.FINALIZE)) {
+ if (!MethodCallUtils.isCallToMethod(expression, null, PsiType.VOID, HardcodedMethodConstants.FINALIZE)) {
return;
}
- final PsiMethod containingMethod =
- PsiTreeUtil.getParentOfType(expression, PsiMethod.class);
- if (containingMethod == null) {
- return;
- }
- if (MethodUtils.methodMatches(containingMethod, null, PsiType.VOID,
- HardcodedMethodConstants.FINALIZE)) {
+ final PsiMethod containingMethod = PsiTreeUtil.getParentOfType(expression, PsiMethod.class);
+ if (containingMethod == null || MethodUtils.isFinalize(containingMethod)) {
return;
}
registerMethodCallError(expression);
return method != null && methodMatches(method, null, PsiType.INT, HardcodedMethodConstants.HASH_CODE);
}
+ public static boolean isFinalize(@Nullable PsiMethod method) {
+ return method != null && methodMatches(method, null, PsiType.VOID, HardcodedMethodConstants.FINALIZE);
+ }
+
public static boolean isToString(@Nullable PsiMethod method) {
if (method == null) {
return false;