intellij-lsp/intellij-lsp-plugin

View on GitHub
src/main/scala/com/github/gtache/lsp/contributors/LSPFindUsagesHandlerFactory.scala

Summary

Maintainability
A
1 hr
Test Coverage
F
0%
/**
 *     Copyright 2017-2018 Guillaume Tâche
 *
 *     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.github.gtache.lsp.contributors

import java.util

import com.github.gtache.lsp.contributors.psi.LSPPsiElement
import com.github.gtache.lsp.editor.EditorEventManager
import com.github.gtache.lsp.utils.{ApplicationUtils, FileUtils}
import com.intellij.find.findUsages.{FindUsagesHandler, FindUsagesHandlerFactory}
import com.intellij.psi.search.SearchScope
import com.intellij.psi.{PsiElement, PsiFile, PsiReference}

class LSPFindUsagesHandlerFactory extends FindUsagesHandlerFactory {

  import scala.collection.JavaConverters._

  override def createFindUsagesHandler(element: PsiElement, forHighlightUsages: Boolean): FindUsagesHandler =
    new FindUsagesHandler(element) {
      @volatile private var elements: Iterable[PsiElement] = Seq.empty
      element match {
        case p: PsiFile =>
          val editor = FileUtils.editorFromPsiFile(p)
          EditorEventManager.forEditor(editor) match {
            case Some(m) => ApplicationUtils.invokeLater(() => elements = m.references(editor.getCaretModel.getCurrentCaret.getOffset, getOriginalElement = true)._1)
            case None =>
          }
        case l: LSPPsiElement =>
          val editor = FileUtils.editorFromPsiFile(l.getContainingFile)
          EditorEventManager.forEditor(editor) match {
            case Some(m) => ApplicationUtils.invokeLater(() => elements = m.references(editor.getCaretModel.getCurrentCaret.getOffset, getOriginalElement = true)._1)
            case None =>
          }
        case _ =>
      }

      override def findReferencesToHighlight(target: PsiElement, searchScope: SearchScope): util.Collection[PsiReference] = {
        target match {
          case p: PsiFile if p == element =>
            elements.map(p => p.getReference).toList.asJava
          case l: LSPPsiElement if elements.exists(p => p == l) =>
            elements.map(p => p.getReference).toList.asJava
          case _ => Seq().asJava
        }
      }

      override def getPrimaryElements: Array[PsiElement] = {
        elements.toArray
      }

    }

  override def canFindUsages(element: PsiElement): Boolean = {
    element match {
      case p: PsiFile => true
      case l: LSPPsiElement => true
      case _ => false
    }
  }
}