Skip to content

Commit 76b4a2d

Browse files
committed
#18 prevent access to index while service is dumb - 2
1 parent 48bad00 commit 76b4a2d

File tree

7 files changed

+36
-28
lines changed

7 files changed

+36
-28
lines changed

src/com/phpuaca/completion/BaseTypeProvider.java

Lines changed: 0 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -1,9 +1,6 @@
11
package com.phpuaca.completion;
22

3-
import com.intellij.openapi.project.DumbService;
4-
import com.intellij.psi.PsiElement;
53
import com.jetbrains.php.lang.psi.elements.Method;
6-
import com.jetbrains.php.lang.psi.elements.MethodReference;
74
import com.jetbrains.php.lang.psi.elements.PhpClass;
85
import com.jetbrains.php.lang.psi.resolve.types.PhpTypeProvider2;
96
import com.phpuaca.util.PhpClassAdapter;
@@ -12,10 +9,6 @@
129

1310
abstract public class BaseTypeProvider implements PhpTypeProvider2 {
1411

15-
protected boolean isAvailable(@NotNull PsiElement psiElement) {
16-
return (psiElement instanceof MethodReference) && !DumbService.getInstance(psiElement.getProject()).isDumb();
17-
}
18-
1912
@Nullable
2013
protected PhpClassAdapter getPhpClassAdapterForMethod(@NotNull Method method) {
2114
PhpClass phpClass = method.getContainingClass();

src/com/phpuaca/completion/PHPUnitTypeProvider.java

Lines changed: 11 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,6 @@
11
package com.phpuaca.completion;
22

3+
import com.intellij.openapi.project.DumbService;
34
import com.intellij.openapi.project.Project;
45
import com.intellij.psi.PsiElement;
56
import com.jetbrains.php.PhpIndex;
@@ -40,7 +41,12 @@ public char getKey() {
4041
@Nullable
4142
@Override
4243
public String getType(PsiElement psiElement) {
43-
if (!isAvailable(psiElement)) {
44+
Project project = psiElement.getProject();
45+
if (DumbService.isDumb(project)) {
46+
return null;
47+
}
48+
49+
if (!(psiElement instanceof MethodReference)) {
4450
return null;
4551
}
4652

@@ -68,6 +74,10 @@ public String getType(PsiElement psiElement) {
6874

6975
@Override
7076
public Collection<? extends PhpNamedElement> getBySignature(String s, Project project) {
77+
if (DumbService.isDumb(project)) {
78+
return null;
79+
}
80+
7181
PhpIndex phpIndex = PhpIndex.getInstance(project);
7282
Collection<PhpClass> collection = new ArrayList<PhpClass>();
7383
collection.addAll(phpIndex.getInterfacesByFQN(CLASS_PHP_UNIT_MOCK_OBJECT));

src/com/phpuaca/completion/ProphecyTypeProvider.java

Lines changed: 6 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -4,13 +4,7 @@
44
import com.intellij.openapi.project.Project;
55
import com.intellij.psi.PsiElement;
66
import com.jetbrains.php.PhpIndex;
7-
import com.jetbrains.php.lang.psi.elements.FieldReference;
8-
import com.jetbrains.php.lang.psi.elements.Method;
9-
import com.jetbrains.php.lang.psi.elements.MethodReference;
10-
import com.jetbrains.php.lang.psi.elements.Parameter;
11-
import com.jetbrains.php.lang.psi.elements.PhpClass;
12-
import com.jetbrains.php.lang.psi.elements.PhpNamedElement;
13-
import com.jetbrains.php.lang.psi.elements.Variable;
7+
import com.jetbrains.php.lang.psi.elements.*;
148
import com.jetbrains.php.lang.psi.resolve.types.PhpType;
159
import com.phpuaca.util.PhpClassAdapter;
1610
import com.phpuaca.util.PhpClassResolver;
@@ -46,8 +40,7 @@ public char getKey() {
4640
@Override
4741
public String getType(PsiElement psiElement) {
4842
Project project = psiElement.getProject();
49-
50-
if (DumbService.getInstance(project).isDumb()) {
43+
if (DumbService.isDumb(project)) {
5144
return null;
5245
}
5346

@@ -96,6 +89,10 @@ public String getType(PsiElement psiElement) {
9689

9790
@Override
9891
public Collection<? extends PhpNamedElement> getBySignature(String s, Project project) {
92+
if (DumbService.isDumb(project)) {
93+
return null;
94+
}
95+
9996
PhpIndex phpIndex = PhpIndex.getInstance(project);
10097
Collection<PhpClass> collection = new ArrayList<PhpClass>();
10198
for (String FQN : s.split(TYPE_SEPARATOR)) {

src/com/phpuaca/completion/StringCompletionProvider.java

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -4,6 +4,7 @@
44
import com.intellij.codeInsight.completion.CompletionProvider;
55
import com.intellij.codeInsight.completion.CompletionResultSet;
66
import com.intellij.codeInsight.lookup.LookupElement;
7+
import com.intellij.openapi.project.DumbService;
78
import com.intellij.psi.PsiElement;
89
import com.intellij.util.ProcessingContext;
910
import com.jetbrains.php.completion.PhpLookupElement;
@@ -22,7 +23,7 @@ public class StringCompletionProvider extends CompletionProvider<CompletionParam
2223
@Override
2324
protected void addCompletions(@NotNull CompletionParameters completionParameters, ProcessingContext processingContext, @NotNull CompletionResultSet completionResultSet) {
2425
PsiElement originalPosition = completionParameters.getOriginalPosition();
25-
if (originalPosition != null) {
26+
if (originalPosition != null && !DumbService.isDumb(originalPosition.getProject())) {
2627
Filter filter = FilterFactory.getInstance().getFilter(originalPosition.getParent());
2728
if (filter != null) {
2829
completionResultSet.addAllElements(getLookupElements(filter));

src/com/phpuaca/helper/AvailabilityHelper.java

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,6 @@
11
package com.phpuaca.helper;
22

3+
import com.intellij.openapi.project.DumbService;
34
import com.intellij.psi.PsiElement;
45
import com.intellij.psi.PsiFile;
56
import com.jetbrains.php.lang.psi.elements.ArrayCreationExpression;
@@ -21,6 +22,10 @@ public boolean checkScope(@Nullable PsiElement psiElement) {
2122
return false;
2223
}
2324

25+
if (DumbService.isDumb(psiElement.getProject())) {
26+
return false;
27+
}
28+
2429
// $this->method('cursor');
2530
PsiElement stringLiteralExpressionContext = psiElement.getContext();
2631
if (stringLiteralExpressionContext instanceof ParameterList) {

src/com/phpuaca/reference/StringReference.java

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,7 @@
11
package com.phpuaca.reference;
22

33
import com.intellij.lang.ASTNode;
4+
import com.intellij.openapi.project.DumbService;
45
import com.intellij.openapi.util.TextRange;
56
import com.intellij.psi.PsiElement;
67
import com.intellij.psi.PsiReference;
@@ -35,6 +36,10 @@ public TextRange getRangeInElement() {
3536
@Nullable
3637
@Override
3738
public PsiElement resolve() {
39+
if (DumbService.isDumb(getElement().getProject())) {
40+
return null;
41+
}
42+
3843
PsiElement resolvedElement = null;
3944
Filter filter = FilterFactory.getInstance().getFilter(getElement());
4045
if (filter != null) {

src/com/phpuaca/util/PhpClassResolver.java

Lines changed: 7 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,5 @@
11
package com.phpuaca.util;
22

3-
import com.intellij.openapi.project.DumbService;
43
import com.intellij.openapi.project.Project;
54
import com.intellij.psi.PsiElement;
65
import com.intellij.psi.util.PsiTreeUtil;
@@ -32,15 +31,13 @@ public PhpClass resolveByClassConstantReference(@NotNull ClassConstantReference
3231

3332
@Nullable
3433
public PhpClass resolveByClassStringLiteralExpression(@NotNull StringLiteralExpression stringLiteralExpression) {
35-
Project project = stringLiteralExpression.getProject();
36-
if (!DumbService.getInstance(project).isDumb()) {
37-
String className = stringLiteralExpression.getContents();
38-
if (!className.isEmpty()) {
39-
className = className.replace("\\\\", "\\");
40-
Collection<PhpClass> phpClasses = PhpIndex.getInstance(project).getAnyByFQN(className);
41-
if (!phpClasses.isEmpty()) {
42-
return phpClasses.iterator().next();
43-
}
34+
String className = stringLiteralExpression.getContents();
35+
if (!className.isEmpty()) {
36+
className = className.replace("\\\\", "\\");
37+
Project project = stringLiteralExpression.getProject();
38+
Collection<PhpClass> phpClasses = PhpIndex.getInstance(project).getAnyByFQN(className);
39+
if (!phpClasses.isEmpty()) {
40+
return phpClasses.iterator().next();
4441
}
4542
}
4643

0 commit comments

Comments
 (0)