aboutsummaryrefslogtreecommitdiffstats
path: root/sd-plugin/src/main/java/org/intellij/sdk/language/findUsages/SdFindUsagesHandler.java
diff options
context:
space:
mode:
Diffstat (limited to 'sd-plugin/src/main/java/org/intellij/sdk/language/findUsages/SdFindUsagesHandler.java')
-rw-r--r--sd-plugin/src/main/java/org/intellij/sdk/language/findUsages/SdFindUsagesHandler.java75
1 files changed, 75 insertions, 0 deletions
diff --git a/sd-plugin/src/main/java/org/intellij/sdk/language/findUsages/SdFindUsagesHandler.java b/sd-plugin/src/main/java/org/intellij/sdk/language/findUsages/SdFindUsagesHandler.java
new file mode 100644
index 00000000000..f00ea940613
--- /dev/null
+++ b/sd-plugin/src/main/java/org/intellij/sdk/language/findUsages/SdFindUsagesHandler.java
@@ -0,0 +1,75 @@
+package org.intellij.sdk.language.findUsages;
+
+import com.intellij.find.findUsages.FindUsagesHandler;
+import com.intellij.find.findUsages.FindUsagesOptions;
+import com.intellij.openapi.application.ReadAction;
+import com.intellij.openapi.application.ReadActionProcessor;
+import com.intellij.psi.PsiElement;
+import com.intellij.psi.PsiFile;
+import com.intellij.psi.PsiReference;
+import com.intellij.psi.search.GlobalSearchScope;
+import com.intellij.psi.search.SearchScope;
+import com.intellij.psi.search.searches.ReferencesSearch;
+import com.intellij.usageView.UsageInfo;
+import com.intellij.util.Processor;
+import org.intellij.sdk.language.SdUtil;
+import org.intellij.sdk.language.psi.SdFile;
+import org.intellij.sdk.language.psi.SdFunctionDefinition;
+import org.jetbrains.annotations.NotNull;
+
+import java.util.HashMap;
+import java.util.List;
+
+public class SdFindUsagesHandler extends FindUsagesHandler {
+
+ protected HashMap<String, List<PsiElement>> macrosMap;
+
+ protected SdFindUsagesHandler(@NotNull PsiElement psiElement) {
+ super(psiElement);
+ PsiFile file = psiElement.getContainingFile();
+ macrosMap = file instanceof SdFile ? SdUtil.createMacrosMap((SdFile) psiElement.getContainingFile()) : new HashMap<>();
+ }
+
+ @Override
+ public boolean processElementUsages(@NotNull final PsiElement elementToSearch,
+ @NotNull final Processor<? super UsageInfo> processor,
+ @NotNull final FindUsagesOptions options) {
+ final ReadActionProcessor<PsiReference> refProcessor = new ReadActionProcessor<>() {
+ @Override
+ public boolean processInReadAction(final PsiReference ref) {
+ return processor.process(new UsageInfo(ref));
+ }
+ };
+
+ final SearchScope scope = options.searchScope;
+
+ final boolean searchText = options.isSearchForTextOccurrences && scope instanceof GlobalSearchScope;
+
+ if (options.isUsages) {
+ if (!(elementToSearch instanceof SdFunctionDefinition)) {
+ boolean success =
+ ReferencesSearch.search(createSearchParameters(elementToSearch, scope, options)).forEach(refProcessor);
+ if (!success) return false;
+ } else {
+ String macroName = ReadAction.compute( ((SdFunctionDefinition) elementToSearch)::getName);
+
+ for (PsiElement macroImpl : macrosMap.get(macroName)) {
+ boolean success =
+ ReferencesSearch.search(createSearchParameters(macroImpl, scope, options)).forEach(refProcessor);
+ if (!success) return false;
+ }
+ }
+ }
+ if (searchText) {
+ if (options.fastTrack != null) {
+ options.fastTrack.searchCustom(consumer -> processUsagesInText(elementToSearch, processor, (GlobalSearchScope)scope));
+ }
+ else {
+ return processUsagesInText(elementToSearch, processor, (GlobalSearchScope)scope);
+ }
+ }
+
+ return true;
+ }
+
+}