/plugins/InspectionGadgets/src/com/siyeh/ig/threading/NotifyCalledOnConditionInspection.java
https://bitbucket.org/nbargnesi/idea · Java · 63 lines · 41 code · 7 blank · 15 comment · 1 complexity · 0ea47ad4c768a5d7ef85ce326a1ae550 MD5 · raw file
- /*
- * Copyright 2003-20067 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.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
- package com.siyeh.ig.threading;
- import com.intellij.psi.PsiMethodCallExpression;
- import com.intellij.psi.PsiType;
- import com.siyeh.HardcodedMethodConstants;
- import com.siyeh.InspectionGadgetsBundle;
- import com.siyeh.ig.BaseInspection;
- import com.siyeh.ig.BaseInspectionVisitor;
- import com.siyeh.ig.psiutils.MethodCallUtils;
- import org.jetbrains.annotations.NotNull;
- public class NotifyCalledOnConditionInspection extends BaseInspection {
- @NotNull
- public String getDisplayName() {
- return InspectionGadgetsBundle.message(
- "notify.called.on.condition.display.name");
- }
- @NotNull
- protected String buildErrorString(Object... infos) {
- return InspectionGadgetsBundle.message(
- "notify.called.on.condition.problem.descriptor");
- }
- public BaseInspectionVisitor buildVisitor() {
- return new NotifyCalledOnConditionVisitor();
- }
- private static class NotifyCalledOnConditionVisitor
- extends BaseInspectionVisitor {
- @Override
- public void visitMethodCallExpression(
- @NotNull PsiMethodCallExpression expression) {
- super.visitMethodCallExpression(expression);
- if (!MethodCallUtils.isCallToMethod(expression,
- "java.util.concurrent.locks.Condition", PsiType.VOID,
- HardcodedMethodConstants.NOTIFY) &&
- !MethodCallUtils.isCallToMethod(expression,
- "java.util.concurrent.locks.Condition", PsiType.VOID,
- HardcodedMethodConstants.NOTIFY_ALL)) {
- return;
- }
- registerMethodCallError(expression);
- }
- }
- }