From 606ec3724dde762b7b2dc3694914673e970a62fb Mon Sep 17 00:00:00 2001 From: Mykola Donin Date: Thu, 17 Mar 2022 21:19:40 +0200 Subject: [PATCH 1/3] 1031: remove deprecated FilenameIndex#getVirtualFilesByName method usage --- .../reference/provider/FilePathReferenceProvider.java | 1 - 1 file changed, 1 deletion(-) diff --git a/src/com/magento/idea/magento2plugin/reference/provider/FilePathReferenceProvider.java b/src/com/magento/idea/magento2plugin/reference/provider/FilePathReferenceProvider.java index 4d44459b8..5f756327d 100644 --- a/src/com/magento/idea/magento2plugin/reference/provider/FilePathReferenceProvider.java +++ b/src/com/magento/idea/magento2plugin/reference/provider/FilePathReferenceProvider.java @@ -117,7 +117,6 @@ private Collection getFiles(@NotNull PsiElement element) if (fileName.matches(".*\\.\\w+$")) { // extension presents files = FilenameIndex.getVirtualFilesByName( - element.getProject(), fileName, GlobalSearchScope.allScope(element.getProject()) ); From 4ee8434910729be50c51c8ce67a2a3ffe98bcbb2 Mon Sep 17 00:00:00 2001 From: Mykola Donin Date: Thu, 17 Mar 2022 22:11:51 +0200 Subject: [PATCH 2/3] 1031: code style --- .../provider/FilePathReferenceProvider.java | 58 ++++++++++++------- 1 file changed, 37 insertions(+), 21 deletions(-) diff --git a/src/com/magento/idea/magento2plugin/reference/provider/FilePathReferenceProvider.java b/src/com/magento/idea/magento2plugin/reference/provider/FilePathReferenceProvider.java index 5f756327d..4265b4e97 100644 --- a/src/com/magento/idea/magento2plugin/reference/provider/FilePathReferenceProvider.java +++ b/src/com/magento/idea/magento2plugin/reference/provider/FilePathReferenceProvider.java @@ -2,11 +2,16 @@ * Copyright © Magento, Inc. All rights reserved. * See COPYING.txt for license details. */ + package com.magento.idea.magento2plugin.reference.provider; import com.intellij.openapi.util.TextRange; -import com.intellij.openapi.vfs.*; -import com.intellij.psi.*; +import com.intellij.openapi.vfs.VirtualFile; +import com.intellij.openapi.vfs.VirtualFileManager; +import com.intellij.psi.PsiElement; +import com.intellij.psi.PsiManager; +import com.intellij.psi.PsiReference; +import com.intellij.psi.PsiReferenceProvider; import com.intellij.psi.search.FilenameIndex; import com.intellij.psi.search.GlobalSearchScope; import com.intellij.util.ProcessingContext; @@ -16,14 +21,20 @@ import com.magento.idea.magento2plugin.reference.provider.util.GetModuleSourceFilesUtil; import com.magento.idea.magento2plugin.reference.xml.PolyVariantReferenceBase; import gnu.trove.THashMap; +import java.util.ArrayList; +import java.util.Collection; +import java.util.List; +import java.util.Map; import org.jetbrains.annotations.NotNull; -import java.util.*; public class FilePathReferenceProvider extends PsiReferenceProvider { @NotNull @Override - public PsiReference[] getReferencesByElement(@NotNull PsiElement element, @NotNull ProcessingContext context) { + public PsiReference[] getReferencesByElement( + @NotNull PsiElement element, + @NotNull ProcessingContext context + ) { List psiReferences = new ArrayList<>(); @@ -56,7 +67,8 @@ public PsiReference[] getReferencesByElement(@NotNull PsiElement element, @NotNu continue; } String rootPathUrl = fileUrl.substring(0, fileUrl.indexOf(filePath)); - String[] relativePathParts = fileUrl.substring(fileUrl.indexOf(filePath)).split("/"); + String[] relativePathParts + = fileUrl.substring(fileUrl.indexOf(filePath)).split("/"); if (!currentPathIsBuilt) { currentPath = currentPath.isEmpty() @@ -73,13 +85,15 @@ public PsiReference[] getReferencesByElement(@NotNull PsiElement element, @NotNu ? psiManager.findDirectory(currentVf) : psiManager.findFile(currentVf); if (null != psiElement) { + final int currentPathIndex = currentPath.lastIndexOf("/") == -1 + ? 0 : currentPath.lastIndexOf("/") + 1; TextRange pathRange = new TextRange( - origValue.indexOf(filePath) - + (currentPath.lastIndexOf("/") == -1 ? 0 : currentPath.lastIndexOf("/") + 1), - origValue.indexOf(filePath) - + (currentPath.lastIndexOf("/") == -1 ? 0 : currentPath.lastIndexOf("/") + 1) - + pathPart.length() + origValue.indexOf(filePath) + + currentPathIndex, + origValue.indexOf(filePath) + + currentPathIndex + + pathPart.length() ); if (!psiPathElements.containsKey(pathRange)) { @@ -94,17 +108,18 @@ public PsiReference[] getReferencesByElement(@NotNull PsiElement element, @NotNu } if (psiPathElements.size() > 0) { - psiPathElements.forEach(((textRange, psiElements) -> - psiReferences.add(new PolyVariantReferenceBase(element, textRange, psiElements)) - )); + psiPathElements.forEach((textRange, psiElements) -> + psiReferences.add( + new PolyVariantReferenceBase(element, textRange, psiElements) + ) + ); } } return psiReferences.toArray(new PsiReference[psiReferences.size()]); } - private Collection getFiles(@NotNull PsiElement element) - { + private Collection getFiles(@NotNull PsiElement element) { Collection files = new ArrayList<>(); String filePath = GetFilePathUtil.getInstance().execute(element.getText()); @@ -123,7 +138,8 @@ private Collection getFiles(@NotNull PsiElement element) files.removeIf(f -> !f.getPath().endsWith(filePath)); // filter by module - Collection vfs = GetModuleSourceFilesUtil.getInstance().execute(element.getText(), element.getProject()); + Collection vfs = GetModuleSourceFilesUtil.getInstance() + .execute(element.getText(), element.getProject()); if (null != vfs) { files.removeIf(f -> { for (VirtualFile vf : vfs) { @@ -136,11 +152,12 @@ private Collection getFiles(@NotNull PsiElement element) } } else if (isModuleNamePresent(element)) { // extension absent - Collection vfs = GetModuleSourceFilesUtil.getInstance().execute(element.getText(), element.getProject()); + Collection vfs = GetModuleSourceFilesUtil.getInstance() + .execute(element.getText(), element.getProject()); if (null != vfs) { for (VirtualFile vf : vfs) { - Collection vfChildren = GetAllSubFilesOfVirtualFileUtil. - getInstance().execute(vf); + Collection vfChildren = GetAllSubFilesOfVirtualFileUtil + .getInstance().execute(vf); if (null != vfChildren) { vfChildren.removeIf(f -> { if (!f.isDirectory()) { @@ -160,8 +177,7 @@ private Collection getFiles(@NotNull PsiElement element) return files; } - private boolean isModuleNamePresent(@NotNull PsiElement element) - { + private boolean isModuleNamePresent(@NotNull PsiElement element) { return GetModuleNameUtil.getInstance().execute(element.getText()) != null; } } From bb097d0746cf7610178ef416a89d7c238135aa38 Mon Sep 17 00:00:00 2001 From: Mykola Donin Date: Fri, 18 Mar 2022 18:29:32 +0200 Subject: [PATCH 3/3] 1031: code style --- .../provider/FilePathReferenceProvider.java | 86 ++++++++++--------- 1 file changed, 46 insertions(+), 40 deletions(-) diff --git a/src/com/magento/idea/magento2plugin/reference/provider/FilePathReferenceProvider.java b/src/com/magento/idea/magento2plugin/reference/provider/FilePathReferenceProvider.java index 4265b4e97..fc3b53808 100644 --- a/src/com/magento/idea/magento2plugin/reference/provider/FilePathReferenceProvider.java +++ b/src/com/magento/idea/magento2plugin/reference/provider/FilePathReferenceProvider.java @@ -1,4 +1,4 @@ -/** +/* * Copyright © Magento, Inc. All rights reserved. * See COPYING.txt for license details. */ @@ -29,45 +29,50 @@ public class FilePathReferenceProvider extends PsiReferenceProvider { + @SuppressWarnings({ + "PMD.CognitiveComplexity", + "PMD.CyclomaticComplexity", + "PMD.NPathComplexity", + "PMD.AvoidInstantiatingObjectsInLoops" + }) @NotNull @Override public PsiReference[] getReferencesByElement( - @NotNull PsiElement element, - @NotNull ProcessingContext context + @NotNull final PsiElement element, + @NotNull final ProcessingContext context ) { + final String origValue = element.getText(); - List psiReferences = new ArrayList<>(); - - String origValue = element.getText(); - - String filePath = GetFilePathUtil.getInstance().execute(origValue); + final String filePath = GetFilePathUtil.getInstance().execute(origValue); if (null == filePath) { return PsiReference.EMPTY_ARRAY; } // Find all files based on provided path - Collection files = getFiles(element); - if (!(files.size() > 0)) { + final Collection files = getFiles(element); + + if (files.isEmpty()) { return PsiReference.EMPTY_ARRAY; } + final PsiManager psiManager = PsiManager.getInstance(element.getProject()); - PsiManager psiManager = PsiManager.getInstance(element.getProject()); + final List psiReferences = new ArrayList<>(); String currentPath = ""; - String[] pathParts = filePath.split("/"); + final String[] pathParts = filePath.split("/"); for (int i = 0; i < pathParts.length; i++) { - String pathPart = pathParts[i]; + final String pathPart = pathParts[i]; Boolean currentPathIsBuilt = false; - Map> psiPathElements = new THashMap<>(); + final Map> psiPathElements = new THashMap<>(); - for (VirtualFile file : files) { - String fileUrl = file.getUrl(); + for (final VirtualFile file : files) { + final String fileUrl = file.getUrl(); if (!fileUrl.contains(filePath)) { continue; } - String rootPathUrl = fileUrl.substring(0, fileUrl.indexOf(filePath)); - String[] relativePathParts + final String rootPathUrl = fileUrl.substring(0, fileUrl.indexOf(filePath)); + final String[] relativePathParts = fileUrl.substring(fileUrl.indexOf(filePath)).split("/"); if (!currentPathIsBuilt) { @@ -77,18 +82,18 @@ public PsiReference[] getReferencesByElement( currentPathIsBuilt = true; } - VirtualFile currentVf = VirtualFileManager.getInstance() + final VirtualFile currentVf = VirtualFileManager.getInstance() .findFileByUrl(rootPathUrl.concat(currentPath)); if (null != currentVf) { - PsiElement psiElement = currentVf.isDirectory() + final PsiElement psiElement = currentVf.isDirectory() ? psiManager.findDirectory(currentVf) : psiManager.findFile(currentVf); if (null != psiElement) { - final int currentPathIndex = currentPath.lastIndexOf("/") == -1 - ? 0 : currentPath.lastIndexOf("/") + 1; + final int currentPathIndex = currentPath.lastIndexOf('/') == -1 + ? 0 : currentPath.lastIndexOf('/') + 1; - TextRange pathRange = new TextRange( + final TextRange pathRange = new TextRange( origValue.indexOf(filePath) + currentPathIndex, origValue.indexOf(filePath) @@ -96,18 +101,18 @@ public PsiReference[] getReferencesByElement( + pathPart.length() ); - if (!psiPathElements.containsKey(pathRange)) { - List list = new ArrayList<>(); + if (psiPathElements.containsKey(pathRange)) { + psiPathElements.get(pathRange).add(psiElement); + } else { + final List list = new ArrayList<>(); list.add(psiElement); psiPathElements.put(pathRange, list); - } else { - psiPathElements.get(pathRange).add(psiElement); } } } } - if (psiPathElements.size() > 0) { + if (!psiPathElements.isEmpty()) { psiPathElements.forEach((textRange, psiElements) -> psiReferences.add( new PolyVariantReferenceBase(element, textRange, psiElements) @@ -116,18 +121,19 @@ public PsiReference[] getReferencesByElement( } } - return psiReferences.toArray(new PsiReference[psiReferences.size()]); + return psiReferences.toArray(new PsiReference[0]); } - private Collection getFiles(@NotNull PsiElement element) { + @SuppressWarnings("PMD.CognitiveComplexity") + private Collection getFiles(final @NotNull PsiElement element) { Collection files = new ArrayList<>(); - String filePath = GetFilePathUtil.getInstance().execute(element.getText()); + final String filePath = GetFilePathUtil.getInstance().execute(element.getText()); if (null == filePath) { return files; } - String fileName = filePath.substring(filePath.lastIndexOf("/") + 1); + final String fileName = filePath.substring(filePath.lastIndexOf('/') + 1); if (fileName.matches(".*\\.\\w+$")) { // extension presents @@ -138,11 +144,11 @@ private Collection getFiles(@NotNull PsiElement element) { files.removeIf(f -> !f.getPath().endsWith(filePath)); // filter by module - Collection vfs = GetModuleSourceFilesUtil.getInstance() + final Collection vfs = GetModuleSourceFilesUtil.getInstance() .execute(element.getText(), element.getProject()); if (null != vfs) { files.removeIf(f -> { - for (VirtualFile vf : vfs) { + for (final VirtualFile vf : vfs) { if (f.getPath().startsWith(vf.getPath().concat("/"))) { return false; } @@ -152,16 +158,16 @@ private Collection getFiles(@NotNull PsiElement element) { } } else if (isModuleNamePresent(element)) { // extension absent - Collection vfs = GetModuleSourceFilesUtil.getInstance() + final Collection vfs = GetModuleSourceFilesUtil.getInstance() .execute(element.getText(), element.getProject()); if (null != vfs) { - for (VirtualFile vf : vfs) { - Collection vfChildren = GetAllSubFilesOfVirtualFileUtil + for (final VirtualFile vf : vfs) { + final Collection vfChildren = GetAllSubFilesOfVirtualFileUtil .getInstance().execute(vf); if (null != vfChildren) { vfChildren.removeIf(f -> { - if (!f.isDirectory()) { - String ext = f.getExtension(); + if (!f.isDirectory()) { //NOPMD + final String ext = f.getExtension(); if (null != ext) { return !f.getPath().endsWith(filePath.concat(".").concat(ext)); } @@ -177,7 +183,7 @@ private Collection getFiles(@NotNull PsiElement element) { return files; } - private boolean isModuleNamePresent(@NotNull PsiElement element) { + private boolean isModuleNamePresent(final @NotNull PsiElement element) { return GetModuleNameUtil.getInstance().execute(element.getText()) != null; } }