From d3dd5264205fcf1f16e3d0d171032ce7c3380f6e Mon Sep 17 00:00:00 2001 From: daviss Date: Thu, 5 Oct 2023 10:26:10 -0700 Subject: [PATCH 1/9] support intellij 2023.2 (232) targets 2023.2 and make the associated gradle version, plugin, java version change. note that things are very broken at this commit - we will need to fix tests and other stuff in the coming commits --- gradle/dependencies.gradle | 2 +- gradle/wrapper/gradle-wrapper.properties | 2 +- intellij/ast/build.gradle | 20 +++++++------------ intellij/build.gradle | 8 +++++++- .../src/main/resources/META-INF/plugin.xml | 6 +++--- tests/build.gradle | 1 - 6 files changed, 19 insertions(+), 20 deletions(-) diff --git a/gradle/dependencies.gradle b/gradle/dependencies.gradle index 3ce9b033..c2b0f3ce 100644 --- a/gradle/dependencies.gradle +++ b/gradle/dependencies.gradle @@ -28,7 +28,7 @@ def versions = [ roomCompilerProcessing: '2.6.0-alpha02', dokka: '1.4.32', "gradleIntellijPlugin": [ - ide: '2020.1' + ide: '2023.2' ], ] diff --git a/gradle/wrapper/gradle-wrapper.properties b/gradle/wrapper/gradle-wrapper.properties index 7665b0fa..070cb702 100644 --- a/gradle/wrapper/gradle-wrapper.properties +++ b/gradle/wrapper/gradle-wrapper.properties @@ -1,5 +1,5 @@ distributionBase=GRADLE_USER_HOME distributionPath=wrapper/dists -distributionUrl=https\://services.gradle.org/distributions/gradle-6.9-all.zip +distributionUrl=https\://services.gradle.org/distributions/gradle-7.6-bin.zip zipStoreBase=GRADLE_USER_HOME zipStorePath=wrapper/dists diff --git a/intellij/ast/build.gradle b/intellij/ast/build.gradle index 1d840a3a..348011d7 100644 --- a/intellij/ast/build.gradle +++ b/intellij/ast/build.gradle @@ -1,5 +1,5 @@ plugins { - id "org.jetbrains.intellij" version "1.0" + id "org.jetbrains.intellij" version "1.15.0" id 'org.jetbrains.kotlin.jvm' id 'org.jetbrains.dokka' } @@ -11,6 +11,12 @@ intellij { updateSinceUntilBuild = false } +java { + toolchain { + languageVersion.set(JavaLanguageVersion.of(17)) + } +} + dependencies { implementation project(':lib') implementation project(':ast') @@ -24,18 +30,6 @@ dependencies { testImplementation project(':intellij:testing') } -compileKotlin { - kotlinOptions { - jvmTarget = "1.8" - } -} - -compileTestKotlin { - kotlinOptions { - jvmTarget = "1.8" - } -} - tasks { buildSearchableOptions { enabled = false diff --git a/intellij/build.gradle b/intellij/build.gradle index 89f998d5..34be84e9 100644 --- a/intellij/build.gradle +++ b/intellij/build.gradle @@ -1,5 +1,5 @@ plugins { - id "org.jetbrains.intellij" version "1.0" + id "org.jetbrains.intellij" version "1.15.0" id 'org.jetbrains.kotlin.jvm' id 'org.jetbrains.dokka' } @@ -11,6 +11,12 @@ intellij { updateSinceUntilBuild = false } +java { + toolchain { + languageVersion.set(JavaLanguageVersion.of(17)) + } +} + group 'com.uber.motif' version '0.0.5' // Plugin version diff --git a/intellij/src/main/resources/META-INF/plugin.xml b/intellij/src/main/resources/META-INF/plugin.xml index 27b5c055..da829338 100644 --- a/intellij/src/main/resources/META-INF/plugin.xml +++ b/intellij/src/main/resources/META-INF/plugin.xml @@ -1,6 +1,6 @@ com.uber.motif - Motif Plugin + Motif 0.0.5 Uber @@ -15,10 +15,10 @@ ]]> - + + Release 0.0.5: Add logging extension point + IntelliJ 2023.2 compatibility.
Release 0.0.4: Update plugin email address.
Release 0.0.3: Minor fixes.
Release 0.0.2: Minor fixes.
diff --git a/tests/build.gradle b/tests/build.gradle index a50a9011..0b5a6326 100644 --- a/tests/build.gradle +++ b/tests/build.gradle @@ -1,5 +1,4 @@ plugins { - id 'net.ltgt.apt-idea' version '0.21' id 'com.google.devtools.ksp' } From dda21dbdc715446a859c06ca6a75e5b90f098ece Mon Sep 17 00:00:00 2001 From: daviss Date: Thu, 5 Oct 2023 11:02:23 -0700 Subject: [PATCH 2/9] prefer LightJavaCodeInsightFixtureTestCase LightCodeInsightFixtureTestCase was deprecated - we needed to update how we set up the ProjectDescriptor as well. Per IDEA-225960, internalJdk will be increasingly deprecated - IDEA seems to updated the internal disposal logic so our static initialization no longer works - they have created fake jdk for test usage - but there seems to be some slight behavior change (e.g. no fully qualified name) that we should probably update separately --- .../ast/intellij/IntelliJAnnotationTest.kt | 16 +++++-------- .../motif/ast/intellij/IntelliJClassTest.kt | 18 ++++++-------- .../motif/ast/intellij/IntelliJKotlinTest.kt | 16 +++++-------- .../test/kotlin/motif/intellij/TestHarness.kt | 15 +++++------- .../motif/intellij/testing/InternalJdk.kt | 24 ------------------- 5 files changed, 25 insertions(+), 64 deletions(-) delete mode 100644 intellij/testing/src/main/kotlin/motif/intellij/testing/InternalJdk.kt diff --git a/intellij/ast/src/test/kotlin/motif/ast/intellij/IntelliJAnnotationTest.kt b/intellij/ast/src/test/kotlin/motif/ast/intellij/IntelliJAnnotationTest.kt index 1ec2a3e3..4609a646 100644 --- a/intellij/ast/src/test/kotlin/motif/ast/intellij/IntelliJAnnotationTest.kt +++ b/intellij/ast/src/test/kotlin/motif/ast/intellij/IntelliJAnnotationTest.kt @@ -15,28 +15,24 @@ */ package motif.ast.intellij -import com.intellij.pom.java.LanguageLevel +import com.intellij.openapi.projectRoots.impl.JavaAwareProjectJdkTableImpl import com.intellij.psi.PsiElementFactory -import com.intellij.testFramework.LightProjectDescriptor -import com.intellij.testFramework.fixtures.LightCodeInsightFixtureTestCase -import motif.intellij.testing.InternalJdk +import com.intellij.testFramework.fixtures.DefaultLightProjectDescriptor +import com.intellij.testFramework.fixtures.LightJavaCodeInsightFixtureTestCase import org.assertj.core.api.Assertions.assertThat import org.intellij.lang.annotations.Language -class IntelliJAnnotationTest : LightCodeInsightFixtureTestCase() { +class IntelliJAnnotationTest : LightJavaCodeInsightFixtureTestCase() { lateinit var psiElementFactory: PsiElementFactory override fun setUp() { super.setUp() - psiElementFactory = PsiElementFactory.SERVICE.getInstance(project) } - override fun getProjectDescriptor(): LightProjectDescriptor { - return object : ProjectDescriptor(LanguageLevel.HIGHEST) { - override fun getSdk() = InternalJdk.instance - } + override fun getProjectDescriptor() = DefaultLightProjectDescriptor { + JavaAwareProjectJdkTableImpl.getInstanceEx().internalJdk } override fun getTestDataPath(): String { diff --git a/intellij/ast/src/test/kotlin/motif/ast/intellij/IntelliJClassTest.kt b/intellij/ast/src/test/kotlin/motif/ast/intellij/IntelliJClassTest.kt index 4ef652eb..cdf467b9 100644 --- a/intellij/ast/src/test/kotlin/motif/ast/intellij/IntelliJClassTest.kt +++ b/intellij/ast/src/test/kotlin/motif/ast/intellij/IntelliJClassTest.kt @@ -15,29 +15,25 @@ */ package motif.ast.intellij -import com.intellij.pom.java.LanguageLevel +import com.intellij.openapi.projectRoots.impl.JavaAwareProjectJdkTableImpl import com.intellij.psi.PsiElementFactory -import com.intellij.testFramework.LightProjectDescriptor -import com.intellij.testFramework.fixtures.LightCodeInsightFixtureTestCase -import motif.intellij.testing.InternalJdk +import com.intellij.testFramework.fixtures.DefaultLightProjectDescriptor +import com.intellij.testFramework.fixtures.LightJavaCodeInsightFixtureTestCase import org.assertj.core.api.Assertions.assertThat import org.intellij.lang.annotations.Language import org.junit.Test -class IntelliJClassTest : LightCodeInsightFixtureTestCase() { +class IntelliJClassTest : LightJavaCodeInsightFixtureTestCase() { lateinit var psiElementFactory: PsiElementFactory override fun setUp() { super.setUp() - - psiElementFactory = PsiElementFactory.SERVICE.getInstance(project) + psiElementFactory = PsiElementFactory.getInstance(project) } - override fun getProjectDescriptor(): LightProjectDescriptor { - return object : ProjectDescriptor(LanguageLevel.HIGHEST) { - override fun getSdk() = InternalJdk.instance - } + override fun getProjectDescriptor() = DefaultLightProjectDescriptor { + JavaAwareProjectJdkTableImpl.getInstanceEx().internalJdk } override fun getTestDataPath(): String { diff --git a/intellij/ast/src/test/kotlin/motif/ast/intellij/IntelliJKotlinTest.kt b/intellij/ast/src/test/kotlin/motif/ast/intellij/IntelliJKotlinTest.kt index 896b71a7..18f37900 100644 --- a/intellij/ast/src/test/kotlin/motif/ast/intellij/IntelliJKotlinTest.kt +++ b/intellij/ast/src/test/kotlin/motif/ast/intellij/IntelliJKotlinTest.kt @@ -15,30 +15,26 @@ */ package motif.ast.intellij -import com.intellij.pom.java.LanguageLevel +import com.intellij.openapi.projectRoots.impl.JavaAwareProjectJdkTableImpl import com.intellij.psi.PsiElementFactory -import com.intellij.testFramework.LightProjectDescriptor -import com.intellij.testFramework.fixtures.LightCodeInsightFixtureTestCase -import motif.intellij.testing.InternalJdk +import com.intellij.testFramework.fixtures.DefaultLightProjectDescriptor +import com.intellij.testFramework.fixtures.LightJavaCodeInsightFixtureTestCase import org.assertj.core.api.Assertions.assertThat import org.jetbrains.kotlin.psi.KtFile import org.jetbrains.uast.UClass import org.jetbrains.uast.toUElementOfType -class IntelliJKotlinTest : LightCodeInsightFixtureTestCase() { +class IntelliJKotlinTest : LightJavaCodeInsightFixtureTestCase() { lateinit var psiElementFactory: PsiElementFactory override fun setUp() { super.setUp() - psiElementFactory = PsiElementFactory.SERVICE.getInstance(project) } - override fun getProjectDescriptor(): LightProjectDescriptor { - return object : ProjectDescriptor(LanguageLevel.HIGHEST) { - override fun getSdk() = InternalJdk.instance - } + override fun getProjectDescriptor() = DefaultLightProjectDescriptor { + JavaAwareProjectJdkTableImpl.getInstanceEx().internalJdk } override fun getTestDataPath(): String { diff --git a/intellij/src/test/kotlin/motif/intellij/TestHarness.kt b/intellij/src/test/kotlin/motif/intellij/TestHarness.kt index 36ef5134..52dbacdd 100644 --- a/intellij/src/test/kotlin/motif/intellij/TestHarness.kt +++ b/intellij/src/test/kotlin/motif/intellij/TestHarness.kt @@ -17,11 +17,11 @@ package motif.intellij import com.google.common.truth.Truth.assertThat import com.google.common.truth.Truth.assertWithMessage -import com.intellij.pom.java.LanguageLevel -import com.intellij.testFramework.LightProjectDescriptor +import com.intellij.openapi.projectRoots.impl.JavaAwareProjectJdkTableImpl import com.intellij.testFramework.Parameterized import com.intellij.testFramework.PsiTestUtil -import com.intellij.testFramework.fixtures.LightCodeInsightFixtureTestCase +import com.intellij.testFramework.fixtures.DefaultLightProjectDescriptor +import com.intellij.testFramework.fixtures.LightJavaCodeInsightFixtureTestCase import java.io.File import javax.annotation.Nullable import javax.inject.Inject @@ -30,7 +30,6 @@ import motif.Scope import motif.core.ResolvedGraph import motif.errormessage.ErrorMessage import motif.intellij.testing.IntelliJRule -import motif.intellij.testing.InternalJdk import motif.viewmodel.TestRenderer import org.junit.After import org.junit.Before @@ -39,16 +38,14 @@ import org.junit.Test import org.junit.runner.RunWith @RunWith(Parameterized::class) -class TestHarness : LightCodeInsightFixtureTestCase() { +class TestHarness : LightJavaCodeInsightFixtureTestCase() { @get:Rule val rule = IntelliJRule() @org.junit.runners.Parameterized.Parameter(0) lateinit var testDir: File - override fun getProjectDescriptor(): LightProjectDescriptor { - return object : ProjectDescriptor(LanguageLevel.HIGHEST) { - override fun getSdk() = InternalJdk.instance - } + override fun getProjectDescriptor() = DefaultLightProjectDescriptor { + JavaAwareProjectJdkTableImpl.getInstanceEx().internalJdk } @Before diff --git a/intellij/testing/src/main/kotlin/motif/intellij/testing/InternalJdk.kt b/intellij/testing/src/main/kotlin/motif/intellij/testing/InternalJdk.kt deleted file mode 100644 index 0f1c4598..00000000 --- a/intellij/testing/src/main/kotlin/motif/intellij/testing/InternalJdk.kt +++ /dev/null @@ -1,24 +0,0 @@ -/* - * Copyright (c) 2018-2019 Uber Technologies, Inc. - * - * 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 motif.intellij.testing - -import com.intellij.openapi.projectRoots.Sdk -import com.intellij.openapi.projectRoots.impl.JavaAwareProjectJdkTableImpl - -object InternalJdk { - - val instance: Sdk by lazy { JavaAwareProjectJdkTableImpl.getInstanceEx().internalJdk } -} From 1c09a1b2e828f23081d87ecc6f035d017653a74b Mon Sep 17 00:00:00 2001 From: daviss Date: Thu, 5 Oct 2023 11:07:54 -0700 Subject: [PATCH 3/9] update HierarchyBrowserBase children HierarchyBrowserBase updated its createTrees generic variance and removed some method - this commit changes the children to follow --- .../motif/intellij/hierarchy/ErrorHierarchyBrowser.kt | 6 +----- .../motif/intellij/hierarchy/ScopeHierarchyBrowser.kt | 6 +----- .../intellij/hierarchy/ScopePropertyHierarchyBrowser.kt | 6 +----- .../motif/intellij/hierarchy/UsageHierarchyBrowser.kt | 6 +----- 4 files changed, 4 insertions(+), 20 deletions(-) diff --git a/intellij/src/main/kotlin/motif/intellij/hierarchy/ErrorHierarchyBrowser.kt b/intellij/src/main/kotlin/motif/intellij/hierarchy/ErrorHierarchyBrowser.kt index 8722c30b..20082b9b 100644 --- a/intellij/src/main/kotlin/motif/intellij/hierarchy/ErrorHierarchyBrowser.kt +++ b/intellij/src/main/kotlin/motif/intellij/hierarchy/ErrorHierarchyBrowser.kt @@ -92,7 +92,7 @@ class ErrorHierarchyBrowser( return null } - override fun createTrees(trees: MutableMap) { + override fun createTrees(trees: MutableMap) { trees[ERROR_HIERARCHY_TYPE] = createTree(true) } @@ -129,10 +129,6 @@ class ErrorHierarchyBrowser( return null } - override fun getBrowserDataKey(): String { - return DATA_KEY.name - } - override fun doRefresh(currentBuilderOnly: Boolean) { MotifProjectComponent.getInstance(project).refreshGraph() } diff --git a/intellij/src/main/kotlin/motif/intellij/hierarchy/ScopeHierarchyBrowser.kt b/intellij/src/main/kotlin/motif/intellij/hierarchy/ScopeHierarchyBrowser.kt index 5d4cfc98..83f437e6 100644 --- a/intellij/src/main/kotlin/motif/intellij/hierarchy/ScopeHierarchyBrowser.kt +++ b/intellij/src/main/kotlin/motif/intellij/hierarchy/ScopeHierarchyBrowser.kt @@ -116,7 +116,7 @@ class ScopeHierarchyBrowser( return null } - override fun createTrees(trees: MutableMap) { + override fun createTrees(trees: MutableMap) { trees[TYPE_HIERARCHY_TYPE] = createTree(true) } @@ -164,10 +164,6 @@ class ScopeHierarchyBrowser( return null } - override fun getBrowserDataKey(): String { - return DATA_KEY.name - } - override fun configureTree(tree: Tree) { super.configureTree(tree) tree.addTreeSelectionListener { diff --git a/intellij/src/main/kotlin/motif/intellij/hierarchy/ScopePropertyHierarchyBrowser.kt b/intellij/src/main/kotlin/motif/intellij/hierarchy/ScopePropertyHierarchyBrowser.kt index 3f287506..c7551437 100644 --- a/intellij/src/main/kotlin/motif/intellij/hierarchy/ScopePropertyHierarchyBrowser.kt +++ b/intellij/src/main/kotlin/motif/intellij/hierarchy/ScopePropertyHierarchyBrowser.kt @@ -113,7 +113,7 @@ class ScopePropertyHierarchyBrowser( return LABEL_GO_NEXT_SCOPE } - override fun createTrees(trees: MutableMap) { + override fun createTrees(trees: MutableMap) { trees[PROPERTY_HIERARCHY_TYPE] = createTree(true) } @@ -186,10 +186,6 @@ class ScopePropertyHierarchyBrowser( return null } - override fun getBrowserDataKey(): String { - return DATA_KEY.name - } - override fun onGraphUpdated(graph: ResolvedGraph) { this.graph = graph super.doRefresh(true) diff --git a/intellij/src/main/kotlin/motif/intellij/hierarchy/UsageHierarchyBrowser.kt b/intellij/src/main/kotlin/motif/intellij/hierarchy/UsageHierarchyBrowser.kt index 823b8993..6c1dc2f9 100644 --- a/intellij/src/main/kotlin/motif/intellij/hierarchy/UsageHierarchyBrowser.kt +++ b/intellij/src/main/kotlin/motif/intellij/hierarchy/UsageHierarchyBrowser.kt @@ -87,7 +87,7 @@ class UsageHierarchyBrowser( return null } - override fun createTrees(trees: MutableMap) { + override fun createTrees(trees: MutableMap) { trees[USAGE_HIERARCHY_TYPE] = createTree(true) } @@ -108,10 +108,6 @@ class UsageHierarchyBrowser( return null } - override fun getBrowserDataKey(): String { - return DATA_KEY.name - } - override fun onGraphUpdated(graph: ResolvedGraph) { this.graph = graph super.doRefresh(true) From e91289e3ae30827f976ade3b4c43b0a2bfde4aca Mon Sep 17 00:00:00 2001 From: daviss Date: Thu, 5 Oct 2023 12:14:01 -0700 Subject: [PATCH 4/9] stop using project component project component has been deprecated - in this commit, we migrate to MotifProjectService and AnalyticsProjectService --- .../AttachMotifProjectServiceActivity.kt | 26 +++++++++++++ ...ectComponent.kt => MotifProjectService.kt} | 37 ++++++++++--------- .../actions/MotifAncestorGraphAction.kt | 15 ++++---- .../intellij/actions/MotifGraphAction.kt | 14 ++++--- .../intellij/actions/MotifUsageAction.kt | 18 +++++---- ...omponent.kt => AnalyticsProjectService.kt} | 12 +++--- .../hierarchy/ErrorHierarchyBrowser.kt | 6 +-- .../hierarchy/ScopeHierarchyBrowser.kt | 10 ++--- .../ScopePropertyHierarchyBrowser.kt | 4 +- .../hierarchy/UsageHierarchyBrowser.kt | 4 +- .../ScopeHierarchyLineMarkerProvider.kt | 17 +++++---- .../ScopeNavigationLineMarkerProvider.kt | 9 +++-- .../motif/intellij/ui/MotifErrorPanel.kt | 4 +- .../motif/intellij/ui/MotifScopePanel.kt | 4 +- .../motif/intellij/ui/MotifUsagePanel.kt | 4 +- .../src/main/resources/META-INF/plugin.xml | 13 ++----- 16 files changed, 114 insertions(+), 83 deletions(-) create mode 100644 intellij/src/main/kotlin/motif/intellij/AttachMotifProjectServiceActivity.kt rename intellij/src/main/kotlin/motif/intellij/{MotifProjectComponent.kt => MotifProjectService.kt} (89%) rename intellij/src/main/kotlin/motif/intellij/analytics/{AnalyticsProjectComponent.kt => AnalyticsProjectService.kt} (82%) diff --git a/intellij/src/main/kotlin/motif/intellij/AttachMotifProjectServiceActivity.kt b/intellij/src/main/kotlin/motif/intellij/AttachMotifProjectServiceActivity.kt new file mode 100644 index 00000000..71699f9d --- /dev/null +++ b/intellij/src/main/kotlin/motif/intellij/AttachMotifProjectServiceActivity.kt @@ -0,0 +1,26 @@ +/* + * Copyright (c) 2023 Uber Technologies, Inc. + * + * 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 motif.intellij + +import com.intellij.openapi.components.service +import com.intellij.openapi.project.Project +import com.intellij.openapi.startup.ProjectActivity + +class AttachMotifProjectServiceActivity : ProjectActivity { + override suspend fun execute(project: Project) { + project.service().attach() + } +} diff --git a/intellij/src/main/kotlin/motif/intellij/MotifProjectComponent.kt b/intellij/src/main/kotlin/motif/intellij/MotifProjectService.kt similarity index 89% rename from intellij/src/main/kotlin/motif/intellij/MotifProjectComponent.kt rename to intellij/src/main/kotlin/motif/intellij/MotifProjectService.kt index df11f638..9b40cc6c 100644 --- a/intellij/src/main/kotlin/motif/intellij/MotifProjectComponent.kt +++ b/intellij/src/main/kotlin/motif/intellij/MotifProjectService.kt @@ -19,10 +19,11 @@ import com.intellij.codeInsight.daemon.LineMarkerProviders import com.intellij.ide.plugins.PluginManager import com.intellij.lang.Language import com.intellij.lang.java.JavaLanguage +import com.intellij.openapi.Disposable import com.intellij.openapi.actionSystem.ActionManager import com.intellij.openapi.actionSystem.AnAction import com.intellij.openapi.application.ApplicationManager -import com.intellij.openapi.components.ProjectComponent +import com.intellij.openapi.components.Service import com.intellij.openapi.progress.ProgressIndicator import com.intellij.openapi.progress.ProgressManager import com.intellij.openapi.progress.Task @@ -36,15 +37,17 @@ import com.intellij.psi.PsiClass import com.intellij.psi.PsiElement import com.intellij.ui.content.Content import com.intellij.ui.content.ContentFactory +import javax.swing.Icon import motif.core.ResolvedGraph -import motif.intellij.analytics.AnalyticsProjectComponent +import motif.intellij.analytics.AnalyticsProjectService import motif.intellij.analytics.MotifAnalyticsActions import motif.intellij.ui.MotifErrorPanel import motif.intellij.ui.MotifScopePanel import motif.intellij.ui.MotifUsagePanel import org.jetbrains.kotlin.idea.KotlinLanguage -class MotifProjectComponent(val project: Project) : ProjectComponent { +@Service(Service.Level.PROJECT) +class MotifProjectService(val project: Project) : Disposable { companion object { const val TOOL_WINDOW_ID: String = "Motif" @@ -61,10 +64,6 @@ class MotifProjectComponent(val project: Project) : ProjectComponent { "Error computing Motif graph. If error persists after you rebuild your project and restart IDE, please make sure to report the issue." private val MOTIF_ACTION_IDS = listOf("motif_usage", "motif_graph", "motif_ancestor_graph") - - fun getInstance(project: Project): MotifProjectComponent { - return project.getComponent(MotifProjectComponent::class.java) - } } private val graphFactory: GraphFactory by lazy { GraphFactory(project) } @@ -79,19 +78,22 @@ class MotifProjectComponent(val project: Project) : ProjectComponent { private var isRefreshing: Boolean = false private var pendingAction: (() -> Unit)? = null - override fun projectOpened() { + fun attach() { DumbService.getInstance(project).runWhenSmart { ApplicationManager.getApplication().runReadAction { // Initialize plugin with empty graph to avoid IDE startup slowdown val emptyGraph: ResolvedGraph = ResolvedGraph.create(emptyList()) onGraphUpdated(emptyGraph) - AnalyticsProjectComponent.getInstance(project) + project + .getService(AnalyticsProjectService::class.java) .logEvent(MotifAnalyticsActions.PROJECT_OPENED) } } } + override fun dispose() {} + fun refreshGraph() { if (isRefreshing) { return @@ -111,12 +113,13 @@ class MotifProjectComponent(val project: Project) : ProjectComponent { if (updatedGraph.errors.isNotEmpty()) MotifAnalyticsActions.GRAPH_UPDATE_ERROR else MotifAnalyticsActions.GRAPH_UPDATE_SUCCESS - AnalyticsProjectComponent.getInstance(project).logEvent(eventName) + project.getService(AnalyticsProjectService::class.java).logEvent(eventName) } catch (t: Throwable) { val emptyGraph: ResolvedGraph = ResolvedGraph.create(emptyList()) onGraphUpdated(emptyGraph) - AnalyticsProjectComponent.getInstance(project) + project + .getService(AnalyticsProjectService::class.java) .logEvent(MotifAnalyticsActions.GRAPH_COMPUTATION_ERROR) PluginManager.getLogger().error(LABEL_GRAPH_COMPUTATION_ERROR, t) } finally { @@ -166,7 +169,7 @@ class MotifProjectComponent(val project: Project) : ProjectComponent { if (toolWindowManager.getToolWindow(TOOL_WINDOW_ID) == null) { val toolWindow: ToolWindow = toolWindowManager.registerToolWindow(TOOL_WINDOW_ID, true, ToolWindowAnchor.RIGHT) - toolWindow.setIcon(IconLoader.getIcon("/icons/icon.svg")) + toolWindow.setIcon(IconLoader.getIcon("/icons/icon.svg", Icon::class.java)) toolWindow.title = TOOL_WINDOW_TITLE scopePanel = MotifScopePanel(project, graph) @@ -211,16 +214,14 @@ class MotifProjectComponent(val project: Project) : ProjectComponent { } private fun createScopeContent(toolWindow: ToolWindow): Content { - val content = - ContentFactory.SERVICE.getInstance().createContent(scopePanel, TAB_NAME_SCOPES, true) + val content = ContentFactory.getInstance().createContent(scopePanel, TAB_NAME_SCOPES, true) content.isCloseable = false toolWindow.contentManager.addContent(content) return content } private fun createErrorContent(toolWindow: ToolWindow): Content { - val content = - ContentFactory.SERVICE.getInstance().createContent(errorPanel, TAB_NAME_ERRORS, true) + val content = ContentFactory.getInstance().createContent(errorPanel, TAB_NAME_ERRORS, true) content.isCloseable = false toolWindow.contentManager.addContent(content) return content @@ -228,7 +229,7 @@ class MotifProjectComponent(val project: Project) : ProjectComponent { private fun createUsageContent(toolWindow: ToolWindow): Content { val content: Content = - ContentFactory.SERVICE.getInstance().createContent(usagePanel, TAB_NAME_USAGE, true) + ContentFactory.getInstance().createContent(usagePanel, TAB_NAME_USAGE, true) content.description = TAB_NAME_USAGE content.isCloseable = true toolWindow.contentManager.addContent(content) @@ -237,7 +238,7 @@ class MotifProjectComponent(val project: Project) : ProjectComponent { private fun createAncestorContent(toolWindow: ToolWindow): Content { val content: Content = - ContentFactory.SERVICE.getInstance().createContent(ancestorPanel, TAB_NAME_ANCESTOR, true) + ContentFactory.getInstance().createContent(ancestorPanel, TAB_NAME_ANCESTOR, true) content.description = TAB_NAME_ANCESTOR content.isCloseable = true toolWindow.contentManager.addContent(content) diff --git a/intellij/src/main/kotlin/motif/intellij/actions/MotifAncestorGraphAction.kt b/intellij/src/main/kotlin/motif/intellij/actions/MotifAncestorGraphAction.kt index 8c1e618b..b0aa009b 100644 --- a/intellij/src/main/kotlin/motif/intellij/actions/MotifAncestorGraphAction.kt +++ b/intellij/src/main/kotlin/motif/intellij/actions/MotifAncestorGraphAction.kt @@ -23,18 +23,18 @@ import com.intellij.openapi.wm.ToolWindowManager import com.intellij.psi.PsiClass import com.intellij.psi.PsiElement import motif.core.ResolvedGraph -import motif.intellij.MotifProjectComponent -import motif.intellij.MotifProjectComponent.Companion.TOOL_WINDOW_ID +import motif.intellij.MotifProjectService +import motif.intellij.MotifProjectService.Companion.TOOL_WINDOW_ID import motif.intellij.ScopeHierarchyUtils.Companion.getParentScopes import motif.intellij.ScopeHierarchyUtils.Companion.isInitializedGraph import motif.intellij.ScopeHierarchyUtils.Companion.isMotifScopeClass -import motif.intellij.analytics.AnalyticsProjectComponent +import motif.intellij.analytics.AnalyticsProjectService import motif.intellij.analytics.MotifAnalyticsActions /* * {@AnAction} used to trigger displaying a particular scope ancestors hierarchy. */ -class MotifAncestorGraphAction : AnAction(), MotifProjectComponent.Listener { +class MotifAncestorGraphAction : AnAction(), MotifProjectService.Listener { private var graph: ResolvedGraph? = null @@ -48,17 +48,18 @@ class MotifAncestorGraphAction : AnAction(), MotifProjectComponent.Listener { val graph = graph ?: return if (!isInitializedGraph(graph)) { - MotifProjectComponent.getInstance(project).refreshGraph { actionPerformed(event) } + project.getService(MotifProjectService::class.java).refreshGraph { actionPerformed(event) } return } val toolWindow: ToolWindow = ToolWindowManager.getInstance(project).getToolWindow(TOOL_WINDOW_ID) ?: return toolWindow.activate { - MotifProjectComponent.getInstance(project).onSelectedAncestorScope(element) + project.getService(MotifProjectService::class.java).onSelectedAncestorScope(element) } - AnalyticsProjectComponent.getInstance(project) + project + .getService(AnalyticsProjectService::class.java) .logEvent(MotifAnalyticsActions.ANCESTOR_MENU_CLICK) } diff --git a/intellij/src/main/kotlin/motif/intellij/actions/MotifGraphAction.kt b/intellij/src/main/kotlin/motif/intellij/actions/MotifGraphAction.kt index ae4e892b..0fbbde2b 100644 --- a/intellij/src/main/kotlin/motif/intellij/actions/MotifGraphAction.kt +++ b/intellij/src/main/kotlin/motif/intellij/actions/MotifGraphAction.kt @@ -20,16 +20,16 @@ import com.intellij.openapi.actionSystem.AnActionEvent import com.intellij.openapi.wm.ToolWindow import com.intellij.openapi.wm.ToolWindowManager import motif.core.ResolvedGraph -import motif.intellij.MotifProjectComponent -import motif.intellij.MotifProjectComponent.Companion.TOOL_WINDOW_ID +import motif.intellij.MotifProjectService +import motif.intellij.MotifProjectService.Companion.TOOL_WINDOW_ID import motif.intellij.ScopeHierarchyUtils.Companion.isInitializedGraph -import motif.intellij.analytics.AnalyticsProjectComponent +import motif.intellij.analytics.AnalyticsProjectService import motif.intellij.analytics.MotifAnalyticsActions /* * {@AnAction} used to trigger displaying entire scope hierarchy. */ -class MotifGraphAction : AnAction(), MotifProjectComponent.Listener { +class MotifGraphAction : AnAction(), MotifProjectService.Listener { private var graph: ResolvedGraph? = null @@ -42,7 +42,7 @@ class MotifGraphAction : AnAction(), MotifProjectComponent.Listener { val graph = graph ?: return if (!isInitializedGraph(graph)) { - MotifProjectComponent.getInstance(project).refreshGraph { actionPerformed(event) } + project.getService(MotifProjectService::class.java).refreshGraph { actionPerformed(event) } return } @@ -50,7 +50,9 @@ class MotifGraphAction : AnAction(), MotifProjectComponent.Listener { ToolWindowManager.getInstance(project).getToolWindow(TOOL_WINDOW_ID) ?: return toolWindow.activate {} - AnalyticsProjectComponent.getInstance(project).logEvent(MotifAnalyticsActions.GRAPH_MENU_CLICK) + project + .getService(AnalyticsProjectService::class.java) + .logEvent(MotifAnalyticsActions.GRAPH_MENU_CLICK) } override fun update(e: AnActionEvent) { diff --git a/intellij/src/main/kotlin/motif/intellij/actions/MotifUsageAction.kt b/intellij/src/main/kotlin/motif/intellij/actions/MotifUsageAction.kt index 6a87669b..e5c85263 100644 --- a/intellij/src/main/kotlin/motif/intellij/actions/MotifUsageAction.kt +++ b/intellij/src/main/kotlin/motif/intellij/actions/MotifUsageAction.kt @@ -23,17 +23,17 @@ import com.intellij.openapi.wm.ToolWindowManager import com.intellij.psi.PsiClass import com.intellij.psi.PsiElement import motif.core.ResolvedGraph -import motif.intellij.MotifProjectComponent -import motif.intellij.MotifProjectComponent.Companion.TOOL_WINDOW_ID +import motif.intellij.MotifProjectService +import motif.intellij.MotifProjectService.Companion.TOOL_WINDOW_ID import motif.intellij.ScopeHierarchyUtils import motif.intellij.ScopeHierarchyUtils.Companion.getUsageCount -import motif.intellij.analytics.AnalyticsProjectComponent +import motif.intellij.analytics.AnalyticsProjectService import motif.intellij.analytics.MotifAnalyticsActions /* * {@AnAction} used to trigger navigation to a particular scope in the scope hierarchy window. */ -class MotifUsageAction : AnAction(), MotifProjectComponent.Listener { +class MotifUsageAction : AnAction(), MotifProjectService.Listener { private var graph: ResolvedGraph? = null @@ -47,15 +47,19 @@ class MotifUsageAction : AnAction(), MotifProjectComponent.Listener { val graph = graph ?: return if (!ScopeHierarchyUtils.isInitializedGraph(graph)) { - MotifProjectComponent.getInstance(project).refreshGraph { actionPerformed(event) } + project.getService(MotifProjectService::class.java).refreshGraph { actionPerformed(event) } return } val toolWindow: ToolWindow = ToolWindowManager.getInstance(project).getToolWindow(TOOL_WINDOW_ID) ?: return - toolWindow.activate { MotifProjectComponent.getInstance(project).onSelectedClass(element) } + toolWindow.activate { + project.getService(MotifProjectService::class.java).onSelectedClass(element) + } - AnalyticsProjectComponent.getInstance(project).logEvent(MotifAnalyticsActions.USAGE_MENU_CLICK) + project + .getService(AnalyticsProjectService::class.java) + .logEvent(MotifAnalyticsActions.USAGE_MENU_CLICK) } override fun update(e: AnActionEvent) { diff --git a/intellij/src/main/kotlin/motif/intellij/analytics/AnalyticsProjectComponent.kt b/intellij/src/main/kotlin/motif/intellij/analytics/AnalyticsProjectService.kt similarity index 82% rename from intellij/src/main/kotlin/motif/intellij/analytics/AnalyticsProjectComponent.kt rename to intellij/src/main/kotlin/motif/intellij/analytics/AnalyticsProjectService.kt index 9034531a..62aba5f5 100644 --- a/intellij/src/main/kotlin/motif/intellij/analytics/AnalyticsProjectComponent.kt +++ b/intellij/src/main/kotlin/motif/intellij/analytics/AnalyticsProjectService.kt @@ -15,23 +15,23 @@ */ package motif.intellij.analytics -import com.intellij.openapi.components.ProjectComponent +import com.intellij.openapi.Disposable +import com.intellij.openapi.components.Service import com.intellij.openapi.extensions.ExtensionPointName import com.intellij.openapi.project.Project import java.util.UUID -class AnalyticsProjectComponent(val project: Project) : ProjectComponent { +@Service(Service.Level.PROJECT) +class AnalyticsProjectService(val project: Project) : Disposable { companion object { private val LOGGER_EXTENSION_POINT_NAME: ExtensionPointName = ExtensionPointName.create("com.uber.motif.motifAnalyticsLogger") private val SESSION_ID = UUID.randomUUID() - - fun getInstance(project: Project): AnalyticsProjectComponent { - return project.getComponent(AnalyticsProjectComponent::class.java) - } } + override fun dispose() {} + fun logEvent(action: String) { val metadata: Map = mapOf("SessionId" to SESSION_ID.toString(), "ActionName" to action) diff --git a/intellij/src/main/kotlin/motif/intellij/hierarchy/ErrorHierarchyBrowser.kt b/intellij/src/main/kotlin/motif/intellij/hierarchy/ErrorHierarchyBrowser.kt index 20082b9b..9a3ffd17 100644 --- a/intellij/src/main/kotlin/motif/intellij/hierarchy/ErrorHierarchyBrowser.kt +++ b/intellij/src/main/kotlin/motif/intellij/hierarchy/ErrorHierarchyBrowser.kt @@ -33,7 +33,7 @@ import javax.swing.JTree import javax.swing.tree.DefaultMutableTreeNode import motif.core.ResolvedGraph import motif.errormessage.ErrorMessage -import motif.intellij.MotifProjectComponent +import motif.intellij.MotifProjectService import motif.intellij.ScopeHierarchyUtils.Companion.isRootElement import motif.intellij.hierarchy.ScopeHierarchyBrowser.Companion.LABEL_GO_NEXT_SCOPE import motif.intellij.hierarchy.ScopeHierarchyBrowser.Companion.LABEL_GO_PREVIOUS_SCOPE @@ -49,7 +49,7 @@ class ErrorHierarchyBrowser( initialGraph: ResolvedGraph, private val rootElement: PsiElement, private val selectionListener: Listener? -) : HierarchyBrowserBase(project, rootElement), MotifProjectComponent.Listener { +) : HierarchyBrowserBase(project, rootElement), MotifProjectService.Listener { private var graph: ResolvedGraph = initialGraph @@ -130,7 +130,7 @@ class ErrorHierarchyBrowser( } override fun doRefresh(currentBuilderOnly: Boolean) { - MotifProjectComponent.getInstance(project).refreshGraph() + project.getService(MotifProjectService::class.java).refreshGraph() } override fun onGraphUpdated(graph: ResolvedGraph) { diff --git a/intellij/src/main/kotlin/motif/intellij/hierarchy/ScopeHierarchyBrowser.kt b/intellij/src/main/kotlin/motif/intellij/hierarchy/ScopeHierarchyBrowser.kt index 83f437e6..95bc83d8 100644 --- a/intellij/src/main/kotlin/motif/intellij/hierarchy/ScopeHierarchyBrowser.kt +++ b/intellij/src/main/kotlin/motif/intellij/hierarchy/ScopeHierarchyBrowser.kt @@ -42,10 +42,10 @@ import motif.ast.IrType import motif.ast.intellij.IntelliJClass import motif.ast.intellij.IntelliJType import motif.core.ResolvedGraph -import motif.intellij.MotifProjectComponent +import motif.intellij.MotifProjectService import motif.intellij.ScopeHierarchyUtils import motif.intellij.ScopeHierarchyUtils.Companion.isMotifScopeClass -import motif.intellij.analytics.AnalyticsProjectComponent +import motif.intellij.analytics.AnalyticsProjectService import motif.intellij.analytics.MotifAnalyticsActions import motif.intellij.hierarchy.descriptor.ScopeHierarchyRootDescriptor import motif.intellij.hierarchy.descriptor.ScopeHierarchyScopeAncestorDescriptor @@ -60,7 +60,7 @@ class ScopeHierarchyBrowser( initialGraph: ResolvedGraph, private val rootElement: PsiElement, private val selectionListener: Listener? -) : HierarchyBrowserBase(project, rootElement), MotifProjectComponent.Listener { +) : HierarchyBrowserBase(project, rootElement), MotifProjectService.Listener { companion object { const val LABEL_GO_PREVIOUS_SCOPE: String = "Go to previous Scope." @@ -189,12 +189,12 @@ class ScopeHierarchyBrowser( else -> {} } - MotifProjectComponent.getInstance(project).refreshGraph() + project.getService(MotifProjectService::class.java).refreshGraph() val action: String = if (status == Status.INITIALIZING) MotifAnalyticsActions.GRAPH_INIT else MotifAnalyticsActions.GRAPH_UPDATE - AnalyticsProjectComponent.getInstance(project).logEvent(action) + project.getService(AnalyticsProjectService::class.java).logEvent(action) } /* diff --git a/intellij/src/main/kotlin/motif/intellij/hierarchy/ScopePropertyHierarchyBrowser.kt b/intellij/src/main/kotlin/motif/intellij/hierarchy/ScopePropertyHierarchyBrowser.kt index c7551437..2847fda1 100644 --- a/intellij/src/main/kotlin/motif/intellij/hierarchy/ScopePropertyHierarchyBrowser.kt +++ b/intellij/src/main/kotlin/motif/intellij/hierarchy/ScopePropertyHierarchyBrowser.kt @@ -41,7 +41,7 @@ import motif.ast.IrType import motif.ast.intellij.IntelliJClass import motif.ast.intellij.IntelliJType import motif.core.ResolvedGraph -import motif.intellij.MotifProjectComponent +import motif.intellij.MotifProjectService import motif.intellij.ScopeHierarchyUtils.Companion.isMotifScopeClass import motif.intellij.hierarchy.ScopeHierarchyBrowser.Companion.LABEL_GO_NEXT_SCOPE import motif.intellij.hierarchy.ScopeHierarchyBrowser.Companion.LABEL_GO_PREVIOUS_SCOPE @@ -61,7 +61,7 @@ class ScopePropertyHierarchyBrowser( initialGraph: ResolvedGraph, private val rootElement: PsiElement, private val hierarchyType: PropertyHierarchyType -) : HierarchyBrowserBase(project, rootElement), MotifProjectComponent.Listener { +) : HierarchyBrowserBase(project, rootElement), MotifProjectService.Listener { private var graph: ResolvedGraph = initialGraph diff --git a/intellij/src/main/kotlin/motif/intellij/hierarchy/UsageHierarchyBrowser.kt b/intellij/src/main/kotlin/motif/intellij/hierarchy/UsageHierarchyBrowser.kt index 6c1dc2f9..f537618e 100644 --- a/intellij/src/main/kotlin/motif/intellij/hierarchy/UsageHierarchyBrowser.kt +++ b/intellij/src/main/kotlin/motif/intellij/hierarchy/UsageHierarchyBrowser.kt @@ -30,7 +30,7 @@ import java.text.MessageFormat import javax.swing.JPanel import javax.swing.JTree import motif.core.ResolvedGraph -import motif.intellij.MotifProjectComponent +import motif.intellij.MotifProjectService import motif.intellij.hierarchy.ScopeHierarchyBrowser.Companion.LABEL_GO_NEXT_SCOPE import motif.intellij.hierarchy.ScopeHierarchyBrowser.Companion.LABEL_GO_PREVIOUS_SCOPE import motif.intellij.hierarchy.descriptor.ScopeHierarchyUsageSectionDescriptor @@ -42,7 +42,7 @@ class UsageHierarchyBrowser( project: Project, initialGraph: ResolvedGraph, private val rootElement: PsiElement -) : HierarchyBrowserBase(project, rootElement), MotifProjectComponent.Listener { +) : HierarchyBrowserBase(project, rootElement), MotifProjectService.Listener { private var graph: ResolvedGraph = initialGraph diff --git a/intellij/src/main/kotlin/motif/intellij/provider/ScopeHierarchyLineMarkerProvider.kt b/intellij/src/main/kotlin/motif/intellij/provider/ScopeHierarchyLineMarkerProvider.kt index 0480ee0f..5663298f 100644 --- a/intellij/src/main/kotlin/motif/intellij/provider/ScopeHierarchyLineMarkerProvider.kt +++ b/intellij/src/main/kotlin/motif/intellij/provider/ScopeHierarchyLineMarkerProvider.kt @@ -32,17 +32,17 @@ import com.intellij.psi.impl.source.PsiClassReferenceType import com.intellij.util.ConstantFunction import java.awt.event.MouseEvent import motif.core.ResolvedGraph -import motif.intellij.MotifProjectComponent -import motif.intellij.MotifProjectComponent.Companion.TOOL_WINDOW_ID +import motif.intellij.MotifProjectService +import motif.intellij.MotifProjectService.Companion.TOOL_WINDOW_ID import motif.intellij.ScopeHierarchyUtils.Companion.getParentScopes import motif.intellij.ScopeHierarchyUtils.Companion.isMotifScopeClass -import motif.intellij.analytics.AnalyticsProjectComponent +import motif.intellij.analytics.AnalyticsProjectService import motif.intellij.analytics.MotifAnalyticsActions /* * {@LineMarkerProvider} used to display icon in gutter to navigate to motif scope ancestors hierarchy. */ -class ScopeHierarchyLineMarkerProvider : LineMarkerProvider, MotifProjectComponent.Listener { +class ScopeHierarchyLineMarkerProvider : LineMarkerProvider, MotifProjectService.Listener { companion object { const val LABEL_ANCESTORS_SCOPE: String = "View Scope Ancestors." @@ -83,18 +83,21 @@ class ScopeHierarchyLineMarkerProvider : LineMarkerProvider, MotifProjectCompone ToolWindowManager.getInstance(project).getToolWindow(TOOL_WINDOW_ID) ?: return if (element is PsiClass) { toolWindow.activate { - MotifProjectComponent.getInstance(project).onSelectedAncestorScope(element) + project.getService(MotifProjectService::class.java).onSelectedAncestorScope(element) } } else if (element is PsiMethod) { if (element.returnType is PsiClassReferenceType) { val returnElementClass: PsiClass = (element.returnType as PsiClassReferenceType).resolve() ?: return toolWindow.activate { - MotifProjectComponent.getInstance(project).onSelectedAncestorScope(returnElementClass) + project + .getService(MotifProjectService::class.java) + .onSelectedAncestorScope(returnElementClass) } } } - AnalyticsProjectComponent.getInstance(project) + project + .getService(AnalyticsProjectService::class.java) .logEvent(MotifAnalyticsActions.ANCESTOR_GUTTER_CLICK) } } diff --git a/intellij/src/main/kotlin/motif/intellij/provider/ScopeNavigationLineMarkerProvider.kt b/intellij/src/main/kotlin/motif/intellij/provider/ScopeNavigationLineMarkerProvider.kt index cf3afa47..8219066a 100644 --- a/intellij/src/main/kotlin/motif/intellij/provider/ScopeNavigationLineMarkerProvider.kt +++ b/intellij/src/main/kotlin/motif/intellij/provider/ScopeNavigationLineMarkerProvider.kt @@ -40,11 +40,11 @@ import java.awt.event.MouseEvent import motif.ast.intellij.IntelliJClass import motif.core.ResolvedGraph import motif.core.ScopeEdge -import motif.intellij.MotifProjectComponent +import motif.intellij.MotifProjectService import motif.intellij.ScopeHierarchyUtils.Companion.getParentScopes import motif.intellij.ScopeHierarchyUtils.Companion.isMotifChildScopeMethod import motif.intellij.ScopeHierarchyUtils.Companion.isMotifScopeClass -import motif.intellij.analytics.AnalyticsProjectComponent +import motif.intellij.analytics.AnalyticsProjectService import motif.intellij.analytics.MotifAnalyticsActions import motif.intellij.toPsiClass import motif.intellij.toPsiMethod @@ -52,7 +52,7 @@ import motif.intellij.toPsiMethod /* * {@LineMarkerProvider} used to display navigation icons in gutter to navigate to parent/children of Motif scopes. */ -class ScopeNavigationLineMarkerProvider : LineMarkerProvider, MotifProjectComponent.Listener { +class ScopeNavigationLineMarkerProvider : LineMarkerProvider, MotifProjectService.Listener { companion object { const val LABEL_NAVIGATE_PARENT_SCOPE: String = "Navigate to parent Scope." @@ -157,7 +157,8 @@ class ScopeNavigationLineMarkerProvider : LineMarkerProvider, MotifProjectCompon } } } - AnalyticsProjectComponent.getInstance(project) + project + .getService(AnalyticsProjectService::class.java) .logEvent(MotifAnalyticsActions.NAVIGATION_GUTTER_CLICK) } diff --git a/intellij/src/main/kotlin/motif/intellij/ui/MotifErrorPanel.kt b/intellij/src/main/kotlin/motif/intellij/ui/MotifErrorPanel.kt index b1d57be9..dfcffe51 100644 --- a/intellij/src/main/kotlin/motif/intellij/ui/MotifErrorPanel.kt +++ b/intellij/src/main/kotlin/motif/intellij/ui/MotifErrorPanel.kt @@ -23,13 +23,13 @@ import javax.swing.JSplitPane import javax.swing.JTextArea import motif.core.ResolvedGraph import motif.errormessage.ErrorMessage -import motif.intellij.MotifProjectComponent +import motif.intellij.MotifProjectService import motif.intellij.ScopeHierarchyUtils import motif.intellij.hierarchy.ErrorHierarchyBrowser import motif.models.MotifError class MotifErrorPanel(project: Project, graph: ResolvedGraph) : - JPanel(), MotifProjectComponent.Listener, ErrorHierarchyBrowser.Listener { + JPanel(), MotifProjectService.Listener, ErrorHierarchyBrowser.Listener { private val splitPane: JSplitPane private val errorBrowser: ErrorHierarchyBrowser diff --git a/intellij/src/main/kotlin/motif/intellij/ui/MotifScopePanel.kt b/intellij/src/main/kotlin/motif/intellij/ui/MotifScopePanel.kt index 572a3b19..ddc50319 100644 --- a/intellij/src/main/kotlin/motif/intellij/ui/MotifScopePanel.kt +++ b/intellij/src/main/kotlin/motif/intellij/ui/MotifScopePanel.kt @@ -24,7 +24,7 @@ import javax.swing.JPanel import javax.swing.JSplitPane import javax.swing.JSplitPane.RIGHT import motif.core.ResolvedGraph -import motif.intellij.MotifProjectComponent +import motif.intellij.MotifProjectService import motif.intellij.ScopeHierarchyUtils import motif.intellij.hierarchy.ScopeHierarchyBrowser import motif.intellij.hierarchy.ScopePropertyHierarchyBrowser @@ -32,7 +32,7 @@ import motif.intellij.hierarchy.ScopePropertyHierarchyBrowser.PropertyHierarchyT import motif.models.Scope class MotifScopePanel(val project: Project, initialGraph: ResolvedGraph) : - JPanel(), ScopeHierarchyBrowser.Listener, MotifProjectComponent.Listener { + JPanel(), ScopeHierarchyBrowser.Listener, MotifProjectService.Listener { private var graph: ResolvedGraph = initialGraph diff --git a/intellij/src/main/kotlin/motif/intellij/ui/MotifUsagePanel.kt b/intellij/src/main/kotlin/motif/intellij/ui/MotifUsagePanel.kt index b4f85c08..1804cb4f 100644 --- a/intellij/src/main/kotlin/motif/intellij/ui/MotifUsagePanel.kt +++ b/intellij/src/main/kotlin/motif/intellij/ui/MotifUsagePanel.kt @@ -21,12 +21,12 @@ import com.intellij.psi.PsiElement import java.awt.BorderLayout import javax.swing.JPanel import motif.core.ResolvedGraph -import motif.intellij.MotifProjectComponent +import motif.intellij.MotifProjectService import motif.intellij.ScopeHierarchyUtils import motif.intellij.hierarchy.UsageHierarchyBrowser class MotifUsagePanel(project: Project, graph: ResolvedGraph) : - JPanel(), MotifProjectComponent.Listener { + JPanel(), MotifProjectService.Listener { private val usageBrowser: UsageHierarchyBrowser diff --git a/intellij/src/main/resources/META-INF/plugin.xml b/intellij/src/main/resources/META-INF/plugin.xml index da829338..81e9066f 100644 --- a/intellij/src/main/resources/META-INF/plugin.xml +++ b/intellij/src/main/resources/META-INF/plugin.xml @@ -30,16 +30,9 @@ org.jetbrains.kotlin com.intellij.modules.lang - - - motif.intellij.MotifProjectComponent - - - motif.intellij.analytics.AnalyticsProjectComponent - - + + + Date: Thu, 5 Oct 2023 16:22:10 -0700 Subject: [PATCH 5/9] fix test harness For some reason, our old way of adding libraries to the test environment stopped working and we need to use a different way. Also, the test rule need to be updated since the test environment now is more properly "faked" and the old rule hangs forever --- .../test/kotlin/motif/intellij/TestHarness.kt | 17 +++++++++++++---- .../motif/intellij/testing/IntelliJRule.kt | 17 ----------------- 2 files changed, 13 insertions(+), 21 deletions(-) diff --git a/intellij/src/test/kotlin/motif/intellij/TestHarness.kt b/intellij/src/test/kotlin/motif/intellij/TestHarness.kt index 52dbacdd..c6f88c91 100644 --- a/intellij/src/test/kotlin/motif/intellij/TestHarness.kt +++ b/intellij/src/test/kotlin/motif/intellij/TestHarness.kt @@ -23,6 +23,7 @@ import com.intellij.testFramework.PsiTestUtil import com.intellij.testFramework.fixtures.DefaultLightProjectDescriptor import com.intellij.testFramework.fixtures.LightJavaCodeInsightFixtureTestCase import java.io.File +import java.net.URI import javax.annotation.Nullable import javax.inject.Inject import kotlin.reflect.KClass @@ -63,10 +64,18 @@ class TestHarness : LightJavaCodeInsightFixtureTestCase() { } private fun addLibrary(clazz: KClass<*>) { - val path = clazz.java.protectionDomain.codeSource.location.path - val file = File(path) - val libName = file.name - PsiTestUtil.addLibrary(myFixture.projectDisposable, module, libName, file.parent, libName) + val fileUri = + clazz + .java + .getResource(clazz.simpleName + ".class") + ?.toString() + ?.let { Regex("file:.*[.]jar").find(it)?.value } + ?.let { URI.create(it) } + if (fileUri != null) { + val file = File(fileUri) + val libName = file.name + PsiTestUtil.addLibrary(myFixture.projectDisposable, module, libName, file.parent, libName) + } } @Test diff --git a/intellij/testing/src/main/kotlin/motif/intellij/testing/IntelliJRule.kt b/intellij/testing/src/main/kotlin/motif/intellij/testing/IntelliJRule.kt index 1d882feb..b50a56d3 100644 --- a/intellij/testing/src/main/kotlin/motif/intellij/testing/IntelliJRule.kt +++ b/intellij/testing/src/main/kotlin/motif/intellij/testing/IntelliJRule.kt @@ -15,9 +15,7 @@ */ package motif.intellij.testing -import com.intellij.openapi.application.ApplicationManager import com.intellij.testFramework.TestApplicationManager -import java.util.concurrent.CountDownLatch import org.junit.rules.TestRule import org.junit.runner.Description import org.junit.runners.model.Statement @@ -29,21 +27,6 @@ class IntelliJRule : TestRule { override fun evaluate() { TestApplicationManager.getInstance() - var e: Throwable? = null - val latch = CountDownLatch(1) - ApplicationManager.getApplication().invokeLater { - ApplicationManager.getApplication().runReadAction { - try { - base.evaluate() - } catch (throwable: Throwable) { - e = throwable - } finally { - latch.countDown() - } - } - } - latch.await() - e?.let { throw it } } } } From 75ea90d64a6f48ea249c26e96aeb0563f065b920 Mon Sep 17 00:00:00 2001 From: daviss Date: Thu, 12 Oct 2023 10:03:50 -0700 Subject: [PATCH 6/9] remove "project" keyword from class Since that was leftover from ProjectComponent --- ...Activity.kt => AttachMotifServiceActivity.kt} | 4 ++-- .../{MotifProjectService.kt => MotifService.kt} | 10 +++++----- .../intellij/actions/MotifAncestorGraphAction.kt | 14 +++++++------- .../motif/intellij/actions/MotifGraphAction.kt | 12 ++++++------ .../motif/intellij/actions/MotifUsageAction.kt | 16 +++++++--------- ...ticsProjectService.kt => AnalyticsService.kt} | 2 +- .../intellij/hierarchy/ErrorHierarchyBrowser.kt | 6 +++--- .../intellij/hierarchy/ScopeHierarchyBrowser.kt | 10 +++++----- .../hierarchy/ScopePropertyHierarchyBrowser.kt | 4 ++-- .../intellij/hierarchy/UsageHierarchyBrowser.kt | 4 ++-- .../provider/ScopeHierarchyLineMarkerProvider.kt | 16 +++++++--------- .../ScopeNavigationLineMarkerProvider.kt | 8 ++++---- .../kotlin/motif/intellij/ui/MotifErrorPanel.kt | 4 ++-- .../kotlin/motif/intellij/ui/MotifScopePanel.kt | 4 ++-- .../kotlin/motif/intellij/ui/MotifUsagePanel.kt | 5 ++--- intellij/src/main/resources/META-INF/plugin.xml | 2 +- 16 files changed, 58 insertions(+), 63 deletions(-) rename intellij/src/main/kotlin/motif/intellij/{AttachMotifProjectServiceActivity.kt => AttachMotifServiceActivity.kt} (88%) rename intellij/src/main/kotlin/motif/intellij/{MotifProjectService.kt => MotifService.kt} (96%) rename intellij/src/main/kotlin/motif/intellij/analytics/{AnalyticsProjectService.kt => AnalyticsService.kt} (95%) diff --git a/intellij/src/main/kotlin/motif/intellij/AttachMotifProjectServiceActivity.kt b/intellij/src/main/kotlin/motif/intellij/AttachMotifServiceActivity.kt similarity index 88% rename from intellij/src/main/kotlin/motif/intellij/AttachMotifProjectServiceActivity.kt rename to intellij/src/main/kotlin/motif/intellij/AttachMotifServiceActivity.kt index 71699f9d..86f8d7ed 100644 --- a/intellij/src/main/kotlin/motif/intellij/AttachMotifProjectServiceActivity.kt +++ b/intellij/src/main/kotlin/motif/intellij/AttachMotifServiceActivity.kt @@ -19,8 +19,8 @@ import com.intellij.openapi.components.service import com.intellij.openapi.project.Project import com.intellij.openapi.startup.ProjectActivity -class AttachMotifProjectServiceActivity : ProjectActivity { +class AttachMotifServiceActivity : ProjectActivity { override suspend fun execute(project: Project) { - project.service().attach() + project.service().attach() } } diff --git a/intellij/src/main/kotlin/motif/intellij/MotifProjectService.kt b/intellij/src/main/kotlin/motif/intellij/MotifService.kt similarity index 96% rename from intellij/src/main/kotlin/motif/intellij/MotifProjectService.kt rename to intellij/src/main/kotlin/motif/intellij/MotifService.kt index 9b40cc6c..cfb1adf7 100644 --- a/intellij/src/main/kotlin/motif/intellij/MotifProjectService.kt +++ b/intellij/src/main/kotlin/motif/intellij/MotifService.kt @@ -39,7 +39,7 @@ import com.intellij.ui.content.Content import com.intellij.ui.content.ContentFactory import javax.swing.Icon import motif.core.ResolvedGraph -import motif.intellij.analytics.AnalyticsProjectService +import motif.intellij.analytics.AnalyticsService import motif.intellij.analytics.MotifAnalyticsActions import motif.intellij.ui.MotifErrorPanel import motif.intellij.ui.MotifScopePanel @@ -47,7 +47,7 @@ import motif.intellij.ui.MotifUsagePanel import org.jetbrains.kotlin.idea.KotlinLanguage @Service(Service.Level.PROJECT) -class MotifProjectService(val project: Project) : Disposable { +class MotifService(val project: Project) : Disposable { companion object { const val TOOL_WINDOW_ID: String = "Motif" @@ -86,7 +86,7 @@ class MotifProjectService(val project: Project) : Disposable { onGraphUpdated(emptyGraph) project - .getService(AnalyticsProjectService::class.java) + .getService(AnalyticsService::class.java) .logEvent(MotifAnalyticsActions.PROJECT_OPENED) } } @@ -113,13 +113,13 @@ class MotifProjectService(val project: Project) : Disposable { if (updatedGraph.errors.isNotEmpty()) MotifAnalyticsActions.GRAPH_UPDATE_ERROR else MotifAnalyticsActions.GRAPH_UPDATE_SUCCESS - project.getService(AnalyticsProjectService::class.java).logEvent(eventName) + project.getService(AnalyticsService::class.java).logEvent(eventName) } catch (t: Throwable) { val emptyGraph: ResolvedGraph = ResolvedGraph.create(emptyList()) onGraphUpdated(emptyGraph) project - .getService(AnalyticsProjectService::class.java) + .getService(AnalyticsService::class.java) .logEvent(MotifAnalyticsActions.GRAPH_COMPUTATION_ERROR) PluginManager.getLogger().error(LABEL_GRAPH_COMPUTATION_ERROR, t) } finally { diff --git a/intellij/src/main/kotlin/motif/intellij/actions/MotifAncestorGraphAction.kt b/intellij/src/main/kotlin/motif/intellij/actions/MotifAncestorGraphAction.kt index b0aa009b..744c9a9b 100644 --- a/intellij/src/main/kotlin/motif/intellij/actions/MotifAncestorGraphAction.kt +++ b/intellij/src/main/kotlin/motif/intellij/actions/MotifAncestorGraphAction.kt @@ -23,18 +23,18 @@ import com.intellij.openapi.wm.ToolWindowManager import com.intellij.psi.PsiClass import com.intellij.psi.PsiElement import motif.core.ResolvedGraph -import motif.intellij.MotifProjectService -import motif.intellij.MotifProjectService.Companion.TOOL_WINDOW_ID +import motif.intellij.MotifService +import motif.intellij.MotifService.Companion.TOOL_WINDOW_ID import motif.intellij.ScopeHierarchyUtils.Companion.getParentScopes import motif.intellij.ScopeHierarchyUtils.Companion.isInitializedGraph import motif.intellij.ScopeHierarchyUtils.Companion.isMotifScopeClass -import motif.intellij.analytics.AnalyticsProjectService +import motif.intellij.analytics.AnalyticsService import motif.intellij.analytics.MotifAnalyticsActions /* * {@AnAction} used to trigger displaying a particular scope ancestors hierarchy. */ -class MotifAncestorGraphAction : AnAction(), MotifProjectService.Listener { +class MotifAncestorGraphAction : AnAction(), MotifService.Listener { private var graph: ResolvedGraph? = null @@ -48,18 +48,18 @@ class MotifAncestorGraphAction : AnAction(), MotifProjectService.Listener { val graph = graph ?: return if (!isInitializedGraph(graph)) { - project.getService(MotifProjectService::class.java).refreshGraph { actionPerformed(event) } + project.getService(MotifService::class.java).refreshGraph { actionPerformed(event) } return } val toolWindow: ToolWindow = ToolWindowManager.getInstance(project).getToolWindow(TOOL_WINDOW_ID) ?: return toolWindow.activate { - project.getService(MotifProjectService::class.java).onSelectedAncestorScope(element) + project.getService(MotifService::class.java).onSelectedAncestorScope(element) } project - .getService(AnalyticsProjectService::class.java) + .getService(AnalyticsService::class.java) .logEvent(MotifAnalyticsActions.ANCESTOR_MENU_CLICK) } diff --git a/intellij/src/main/kotlin/motif/intellij/actions/MotifGraphAction.kt b/intellij/src/main/kotlin/motif/intellij/actions/MotifGraphAction.kt index 0fbbde2b..9f33ac99 100644 --- a/intellij/src/main/kotlin/motif/intellij/actions/MotifGraphAction.kt +++ b/intellij/src/main/kotlin/motif/intellij/actions/MotifGraphAction.kt @@ -20,16 +20,16 @@ import com.intellij.openapi.actionSystem.AnActionEvent import com.intellij.openapi.wm.ToolWindow import com.intellij.openapi.wm.ToolWindowManager import motif.core.ResolvedGraph -import motif.intellij.MotifProjectService -import motif.intellij.MotifProjectService.Companion.TOOL_WINDOW_ID +import motif.intellij.MotifService +import motif.intellij.MotifService.Companion.TOOL_WINDOW_ID import motif.intellij.ScopeHierarchyUtils.Companion.isInitializedGraph -import motif.intellij.analytics.AnalyticsProjectService +import motif.intellij.analytics.AnalyticsService import motif.intellij.analytics.MotifAnalyticsActions /* * {@AnAction} used to trigger displaying entire scope hierarchy. */ -class MotifGraphAction : AnAction(), MotifProjectService.Listener { +class MotifGraphAction : AnAction(), MotifService.Listener { private var graph: ResolvedGraph? = null @@ -42,7 +42,7 @@ class MotifGraphAction : AnAction(), MotifProjectService.Listener { val graph = graph ?: return if (!isInitializedGraph(graph)) { - project.getService(MotifProjectService::class.java).refreshGraph { actionPerformed(event) } + project.getService(MotifService::class.java).refreshGraph { actionPerformed(event) } return } @@ -51,7 +51,7 @@ class MotifGraphAction : AnAction(), MotifProjectService.Listener { toolWindow.activate {} project - .getService(AnalyticsProjectService::class.java) + .getService(AnalyticsService::class.java) .logEvent(MotifAnalyticsActions.GRAPH_MENU_CLICK) } diff --git a/intellij/src/main/kotlin/motif/intellij/actions/MotifUsageAction.kt b/intellij/src/main/kotlin/motif/intellij/actions/MotifUsageAction.kt index e5c85263..35392a60 100644 --- a/intellij/src/main/kotlin/motif/intellij/actions/MotifUsageAction.kt +++ b/intellij/src/main/kotlin/motif/intellij/actions/MotifUsageAction.kt @@ -23,17 +23,17 @@ import com.intellij.openapi.wm.ToolWindowManager import com.intellij.psi.PsiClass import com.intellij.psi.PsiElement import motif.core.ResolvedGraph -import motif.intellij.MotifProjectService -import motif.intellij.MotifProjectService.Companion.TOOL_WINDOW_ID +import motif.intellij.MotifService +import motif.intellij.MotifService.Companion.TOOL_WINDOW_ID import motif.intellij.ScopeHierarchyUtils import motif.intellij.ScopeHierarchyUtils.Companion.getUsageCount -import motif.intellij.analytics.AnalyticsProjectService +import motif.intellij.analytics.AnalyticsService import motif.intellij.analytics.MotifAnalyticsActions /* * {@AnAction} used to trigger navigation to a particular scope in the scope hierarchy window. */ -class MotifUsageAction : AnAction(), MotifProjectService.Listener { +class MotifUsageAction : AnAction(), MotifService.Listener { private var graph: ResolvedGraph? = null @@ -47,18 +47,16 @@ class MotifUsageAction : AnAction(), MotifProjectService.Listener { val graph = graph ?: return if (!ScopeHierarchyUtils.isInitializedGraph(graph)) { - project.getService(MotifProjectService::class.java).refreshGraph { actionPerformed(event) } + project.getService(MotifService::class.java).refreshGraph { actionPerformed(event) } return } val toolWindow: ToolWindow = ToolWindowManager.getInstance(project).getToolWindow(TOOL_WINDOW_ID) ?: return - toolWindow.activate { - project.getService(MotifProjectService::class.java).onSelectedClass(element) - } + toolWindow.activate { project.getService(MotifService::class.java).onSelectedClass(element) } project - .getService(AnalyticsProjectService::class.java) + .getService(AnalyticsService::class.java) .logEvent(MotifAnalyticsActions.USAGE_MENU_CLICK) } diff --git a/intellij/src/main/kotlin/motif/intellij/analytics/AnalyticsProjectService.kt b/intellij/src/main/kotlin/motif/intellij/analytics/AnalyticsService.kt similarity index 95% rename from intellij/src/main/kotlin/motif/intellij/analytics/AnalyticsProjectService.kt rename to intellij/src/main/kotlin/motif/intellij/analytics/AnalyticsService.kt index 62aba5f5..9b0848d3 100644 --- a/intellij/src/main/kotlin/motif/intellij/analytics/AnalyticsProjectService.kt +++ b/intellij/src/main/kotlin/motif/intellij/analytics/AnalyticsService.kt @@ -22,7 +22,7 @@ import com.intellij.openapi.project.Project import java.util.UUID @Service(Service.Level.PROJECT) -class AnalyticsProjectService(val project: Project) : Disposable { +class AnalyticsService(val project: Project) : Disposable { companion object { private val LOGGER_EXTENSION_POINT_NAME: ExtensionPointName = diff --git a/intellij/src/main/kotlin/motif/intellij/hierarchy/ErrorHierarchyBrowser.kt b/intellij/src/main/kotlin/motif/intellij/hierarchy/ErrorHierarchyBrowser.kt index 9a3ffd17..9fbf3ee3 100644 --- a/intellij/src/main/kotlin/motif/intellij/hierarchy/ErrorHierarchyBrowser.kt +++ b/intellij/src/main/kotlin/motif/intellij/hierarchy/ErrorHierarchyBrowser.kt @@ -33,7 +33,7 @@ import javax.swing.JTree import javax.swing.tree.DefaultMutableTreeNode import motif.core.ResolvedGraph import motif.errormessage.ErrorMessage -import motif.intellij.MotifProjectService +import motif.intellij.MotifService import motif.intellij.ScopeHierarchyUtils.Companion.isRootElement import motif.intellij.hierarchy.ScopeHierarchyBrowser.Companion.LABEL_GO_NEXT_SCOPE import motif.intellij.hierarchy.ScopeHierarchyBrowser.Companion.LABEL_GO_PREVIOUS_SCOPE @@ -49,7 +49,7 @@ class ErrorHierarchyBrowser( initialGraph: ResolvedGraph, private val rootElement: PsiElement, private val selectionListener: Listener? -) : HierarchyBrowserBase(project, rootElement), MotifProjectService.Listener { +) : HierarchyBrowserBase(project, rootElement), MotifService.Listener { private var graph: ResolvedGraph = initialGraph @@ -130,7 +130,7 @@ class ErrorHierarchyBrowser( } override fun doRefresh(currentBuilderOnly: Boolean) { - project.getService(MotifProjectService::class.java).refreshGraph() + project.getService(MotifService::class.java).refreshGraph() } override fun onGraphUpdated(graph: ResolvedGraph) { diff --git a/intellij/src/main/kotlin/motif/intellij/hierarchy/ScopeHierarchyBrowser.kt b/intellij/src/main/kotlin/motif/intellij/hierarchy/ScopeHierarchyBrowser.kt index 95bc83d8..6001f3fa 100644 --- a/intellij/src/main/kotlin/motif/intellij/hierarchy/ScopeHierarchyBrowser.kt +++ b/intellij/src/main/kotlin/motif/intellij/hierarchy/ScopeHierarchyBrowser.kt @@ -42,10 +42,10 @@ import motif.ast.IrType import motif.ast.intellij.IntelliJClass import motif.ast.intellij.IntelliJType import motif.core.ResolvedGraph -import motif.intellij.MotifProjectService +import motif.intellij.MotifService import motif.intellij.ScopeHierarchyUtils import motif.intellij.ScopeHierarchyUtils.Companion.isMotifScopeClass -import motif.intellij.analytics.AnalyticsProjectService +import motif.intellij.analytics.AnalyticsService import motif.intellij.analytics.MotifAnalyticsActions import motif.intellij.hierarchy.descriptor.ScopeHierarchyRootDescriptor import motif.intellij.hierarchy.descriptor.ScopeHierarchyScopeAncestorDescriptor @@ -60,7 +60,7 @@ class ScopeHierarchyBrowser( initialGraph: ResolvedGraph, private val rootElement: PsiElement, private val selectionListener: Listener? -) : HierarchyBrowserBase(project, rootElement), MotifProjectService.Listener { +) : HierarchyBrowserBase(project, rootElement), MotifService.Listener { companion object { const val LABEL_GO_PREVIOUS_SCOPE: String = "Go to previous Scope." @@ -189,12 +189,12 @@ class ScopeHierarchyBrowser( else -> {} } - project.getService(MotifProjectService::class.java).refreshGraph() + project.getService(MotifService::class.java).refreshGraph() val action: String = if (status == Status.INITIALIZING) MotifAnalyticsActions.GRAPH_INIT else MotifAnalyticsActions.GRAPH_UPDATE - project.getService(AnalyticsProjectService::class.java).logEvent(action) + project.getService(AnalyticsService::class.java).logEvent(action) } /* diff --git a/intellij/src/main/kotlin/motif/intellij/hierarchy/ScopePropertyHierarchyBrowser.kt b/intellij/src/main/kotlin/motif/intellij/hierarchy/ScopePropertyHierarchyBrowser.kt index 2847fda1..ae0b7159 100644 --- a/intellij/src/main/kotlin/motif/intellij/hierarchy/ScopePropertyHierarchyBrowser.kt +++ b/intellij/src/main/kotlin/motif/intellij/hierarchy/ScopePropertyHierarchyBrowser.kt @@ -41,7 +41,7 @@ import motif.ast.IrType import motif.ast.intellij.IntelliJClass import motif.ast.intellij.IntelliJType import motif.core.ResolvedGraph -import motif.intellij.MotifProjectService +import motif.intellij.MotifService import motif.intellij.ScopeHierarchyUtils.Companion.isMotifScopeClass import motif.intellij.hierarchy.ScopeHierarchyBrowser.Companion.LABEL_GO_NEXT_SCOPE import motif.intellij.hierarchy.ScopeHierarchyBrowser.Companion.LABEL_GO_PREVIOUS_SCOPE @@ -61,7 +61,7 @@ class ScopePropertyHierarchyBrowser( initialGraph: ResolvedGraph, private val rootElement: PsiElement, private val hierarchyType: PropertyHierarchyType -) : HierarchyBrowserBase(project, rootElement), MotifProjectService.Listener { +) : HierarchyBrowserBase(project, rootElement), MotifService.Listener { private var graph: ResolvedGraph = initialGraph diff --git a/intellij/src/main/kotlin/motif/intellij/hierarchy/UsageHierarchyBrowser.kt b/intellij/src/main/kotlin/motif/intellij/hierarchy/UsageHierarchyBrowser.kt index f537618e..3237ebf8 100644 --- a/intellij/src/main/kotlin/motif/intellij/hierarchy/UsageHierarchyBrowser.kt +++ b/intellij/src/main/kotlin/motif/intellij/hierarchy/UsageHierarchyBrowser.kt @@ -30,7 +30,7 @@ import java.text.MessageFormat import javax.swing.JPanel import javax.swing.JTree import motif.core.ResolvedGraph -import motif.intellij.MotifProjectService +import motif.intellij.MotifService import motif.intellij.hierarchy.ScopeHierarchyBrowser.Companion.LABEL_GO_NEXT_SCOPE import motif.intellij.hierarchy.ScopeHierarchyBrowser.Companion.LABEL_GO_PREVIOUS_SCOPE import motif.intellij.hierarchy.descriptor.ScopeHierarchyUsageSectionDescriptor @@ -42,7 +42,7 @@ class UsageHierarchyBrowser( project: Project, initialGraph: ResolvedGraph, private val rootElement: PsiElement -) : HierarchyBrowserBase(project, rootElement), MotifProjectService.Listener { +) : HierarchyBrowserBase(project, rootElement), MotifService.Listener { private var graph: ResolvedGraph = initialGraph diff --git a/intellij/src/main/kotlin/motif/intellij/provider/ScopeHierarchyLineMarkerProvider.kt b/intellij/src/main/kotlin/motif/intellij/provider/ScopeHierarchyLineMarkerProvider.kt index 5663298f..a54e0e1b 100644 --- a/intellij/src/main/kotlin/motif/intellij/provider/ScopeHierarchyLineMarkerProvider.kt +++ b/intellij/src/main/kotlin/motif/intellij/provider/ScopeHierarchyLineMarkerProvider.kt @@ -32,17 +32,17 @@ import com.intellij.psi.impl.source.PsiClassReferenceType import com.intellij.util.ConstantFunction import java.awt.event.MouseEvent import motif.core.ResolvedGraph -import motif.intellij.MotifProjectService -import motif.intellij.MotifProjectService.Companion.TOOL_WINDOW_ID +import motif.intellij.MotifService +import motif.intellij.MotifService.Companion.TOOL_WINDOW_ID import motif.intellij.ScopeHierarchyUtils.Companion.getParentScopes import motif.intellij.ScopeHierarchyUtils.Companion.isMotifScopeClass -import motif.intellij.analytics.AnalyticsProjectService +import motif.intellij.analytics.AnalyticsService import motif.intellij.analytics.MotifAnalyticsActions /* * {@LineMarkerProvider} used to display icon in gutter to navigate to motif scope ancestors hierarchy. */ -class ScopeHierarchyLineMarkerProvider : LineMarkerProvider, MotifProjectService.Listener { +class ScopeHierarchyLineMarkerProvider : LineMarkerProvider, MotifService.Listener { companion object { const val LABEL_ANCESTORS_SCOPE: String = "View Scope Ancestors." @@ -83,21 +83,19 @@ class ScopeHierarchyLineMarkerProvider : LineMarkerProvider, MotifProjectService ToolWindowManager.getInstance(project).getToolWindow(TOOL_WINDOW_ID) ?: return if (element is PsiClass) { toolWindow.activate { - project.getService(MotifProjectService::class.java).onSelectedAncestorScope(element) + project.getService(MotifService::class.java).onSelectedAncestorScope(element) } } else if (element is PsiMethod) { if (element.returnType is PsiClassReferenceType) { val returnElementClass: PsiClass = (element.returnType as PsiClassReferenceType).resolve() ?: return toolWindow.activate { - project - .getService(MotifProjectService::class.java) - .onSelectedAncestorScope(returnElementClass) + project.getService(MotifService::class.java).onSelectedAncestorScope(returnElementClass) } } } project - .getService(AnalyticsProjectService::class.java) + .getService(AnalyticsService::class.java) .logEvent(MotifAnalyticsActions.ANCESTOR_GUTTER_CLICK) } } diff --git a/intellij/src/main/kotlin/motif/intellij/provider/ScopeNavigationLineMarkerProvider.kt b/intellij/src/main/kotlin/motif/intellij/provider/ScopeNavigationLineMarkerProvider.kt index 8219066a..b1883155 100644 --- a/intellij/src/main/kotlin/motif/intellij/provider/ScopeNavigationLineMarkerProvider.kt +++ b/intellij/src/main/kotlin/motif/intellij/provider/ScopeNavigationLineMarkerProvider.kt @@ -40,11 +40,11 @@ import java.awt.event.MouseEvent import motif.ast.intellij.IntelliJClass import motif.core.ResolvedGraph import motif.core.ScopeEdge -import motif.intellij.MotifProjectService +import motif.intellij.MotifService import motif.intellij.ScopeHierarchyUtils.Companion.getParentScopes import motif.intellij.ScopeHierarchyUtils.Companion.isMotifChildScopeMethod import motif.intellij.ScopeHierarchyUtils.Companion.isMotifScopeClass -import motif.intellij.analytics.AnalyticsProjectService +import motif.intellij.analytics.AnalyticsService import motif.intellij.analytics.MotifAnalyticsActions import motif.intellij.toPsiClass import motif.intellij.toPsiMethod @@ -52,7 +52,7 @@ import motif.intellij.toPsiMethod /* * {@LineMarkerProvider} used to display navigation icons in gutter to navigate to parent/children of Motif scopes. */ -class ScopeNavigationLineMarkerProvider : LineMarkerProvider, MotifProjectService.Listener { +class ScopeNavigationLineMarkerProvider : LineMarkerProvider, MotifService.Listener { companion object { const val LABEL_NAVIGATE_PARENT_SCOPE: String = "Navigate to parent Scope." @@ -158,7 +158,7 @@ class ScopeNavigationLineMarkerProvider : LineMarkerProvider, MotifProjectServic } } project - .getService(AnalyticsProjectService::class.java) + .getService(AnalyticsService::class.java) .logEvent(MotifAnalyticsActions.NAVIGATION_GUTTER_CLICK) } diff --git a/intellij/src/main/kotlin/motif/intellij/ui/MotifErrorPanel.kt b/intellij/src/main/kotlin/motif/intellij/ui/MotifErrorPanel.kt index dfcffe51..58770d64 100644 --- a/intellij/src/main/kotlin/motif/intellij/ui/MotifErrorPanel.kt +++ b/intellij/src/main/kotlin/motif/intellij/ui/MotifErrorPanel.kt @@ -23,13 +23,13 @@ import javax.swing.JSplitPane import javax.swing.JTextArea import motif.core.ResolvedGraph import motif.errormessage.ErrorMessage -import motif.intellij.MotifProjectService +import motif.intellij.MotifService import motif.intellij.ScopeHierarchyUtils import motif.intellij.hierarchy.ErrorHierarchyBrowser import motif.models.MotifError class MotifErrorPanel(project: Project, graph: ResolvedGraph) : - JPanel(), MotifProjectService.Listener, ErrorHierarchyBrowser.Listener { + JPanel(), MotifService.Listener, ErrorHierarchyBrowser.Listener { private val splitPane: JSplitPane private val errorBrowser: ErrorHierarchyBrowser diff --git a/intellij/src/main/kotlin/motif/intellij/ui/MotifScopePanel.kt b/intellij/src/main/kotlin/motif/intellij/ui/MotifScopePanel.kt index ddc50319..ff443477 100644 --- a/intellij/src/main/kotlin/motif/intellij/ui/MotifScopePanel.kt +++ b/intellij/src/main/kotlin/motif/intellij/ui/MotifScopePanel.kt @@ -24,7 +24,7 @@ import javax.swing.JPanel import javax.swing.JSplitPane import javax.swing.JSplitPane.RIGHT import motif.core.ResolvedGraph -import motif.intellij.MotifProjectService +import motif.intellij.MotifService import motif.intellij.ScopeHierarchyUtils import motif.intellij.hierarchy.ScopeHierarchyBrowser import motif.intellij.hierarchy.ScopePropertyHierarchyBrowser @@ -32,7 +32,7 @@ import motif.intellij.hierarchy.ScopePropertyHierarchyBrowser.PropertyHierarchyT import motif.models.Scope class MotifScopePanel(val project: Project, initialGraph: ResolvedGraph) : - JPanel(), ScopeHierarchyBrowser.Listener, MotifProjectService.Listener { + JPanel(), ScopeHierarchyBrowser.Listener, MotifService.Listener { private var graph: ResolvedGraph = initialGraph diff --git a/intellij/src/main/kotlin/motif/intellij/ui/MotifUsagePanel.kt b/intellij/src/main/kotlin/motif/intellij/ui/MotifUsagePanel.kt index 1804cb4f..5c312f51 100644 --- a/intellij/src/main/kotlin/motif/intellij/ui/MotifUsagePanel.kt +++ b/intellij/src/main/kotlin/motif/intellij/ui/MotifUsagePanel.kt @@ -21,12 +21,11 @@ import com.intellij.psi.PsiElement import java.awt.BorderLayout import javax.swing.JPanel import motif.core.ResolvedGraph -import motif.intellij.MotifProjectService +import motif.intellij.MotifService import motif.intellij.ScopeHierarchyUtils import motif.intellij.hierarchy.UsageHierarchyBrowser -class MotifUsagePanel(project: Project, graph: ResolvedGraph) : - JPanel(), MotifProjectService.Listener { +class MotifUsagePanel(project: Project, graph: ResolvedGraph) : JPanel(), MotifService.Listener { private val usageBrowser: UsageHierarchyBrowser diff --git a/intellij/src/main/resources/META-INF/plugin.xml b/intellij/src/main/resources/META-INF/plugin.xml index 81e9066f..e49bd34a 100644 --- a/intellij/src/main/resources/META-INF/plugin.xml +++ b/intellij/src/main/resources/META-INF/plugin.xml @@ -31,7 +31,7 @@ com.intellij.modules.lang - + From 10d30d51eb8ff65a4904a1e7ff8401f68ab43936 Mon Sep 17 00:00:00 2001 From: daviss Date: Thu, 12 Oct 2023 10:57:11 -0700 Subject: [PATCH 7/9] fix various stuff found during plugin test * prefer Uber Motif to make plugin easier to identify * fix null pointer exception for icon load --- intellij/src/main/kotlin/motif/intellij/MotifService.kt | 3 +-- intellij/src/main/resources/META-INF/plugin.xml | 2 +- 2 files changed, 2 insertions(+), 3 deletions(-) diff --git a/intellij/src/main/kotlin/motif/intellij/MotifService.kt b/intellij/src/main/kotlin/motif/intellij/MotifService.kt index cfb1adf7..cea7ec95 100644 --- a/intellij/src/main/kotlin/motif/intellij/MotifService.kt +++ b/intellij/src/main/kotlin/motif/intellij/MotifService.kt @@ -37,7 +37,6 @@ import com.intellij.psi.PsiClass import com.intellij.psi.PsiElement import com.intellij.ui.content.Content import com.intellij.ui.content.ContentFactory -import javax.swing.Icon import motif.core.ResolvedGraph import motif.intellij.analytics.AnalyticsService import motif.intellij.analytics.MotifAnalyticsActions @@ -169,7 +168,7 @@ class MotifService(val project: Project) : Disposable { if (toolWindowManager.getToolWindow(TOOL_WINDOW_ID) == null) { val toolWindow: ToolWindow = toolWindowManager.registerToolWindow(TOOL_WINDOW_ID, true, ToolWindowAnchor.RIGHT) - toolWindow.setIcon(IconLoader.getIcon("/icons/icon.svg", Icon::class.java)) + toolWindow.setIcon(IconLoader.getIcon("/icons/icon.svg", this::class.java)) toolWindow.title = TOOL_WINDOW_TITLE scopePanel = MotifScopePanel(project, graph) diff --git a/intellij/src/main/resources/META-INF/plugin.xml b/intellij/src/main/resources/META-INF/plugin.xml index e49bd34a..f1b5da87 100644 --- a/intellij/src/main/resources/META-INF/plugin.xml +++ b/intellij/src/main/resources/META-INF/plugin.xml @@ -1,6 +1,6 @@ com.uber.motif - Motif + Uber Motif 0.0.5 Uber From 5447cce3b31cab3f38c9a83614fe70aae03809a2 Mon Sep 17 00:00:00 2001 From: daviss Date: Tue, 17 Oct 2023 15:33:39 -0700 Subject: [PATCH 8/9] remove rule that skips test We did a partial removal in an earlier commit and unintentionally made the TestHarness skip its tests. This commit removes the rule altogether and fixes the setUp/tearDown calls by removing the annotation (annotation not needed), see https://github.com/JetBrains/intellij-community/blob/master/platform/testFramework/src/com/intellij/testFramework/UsefulTestCase.java#L91 --- intellij/ast/build.gradle | 1 - intellij/build.gradle | 1 - .../test/kotlin/motif/intellij/TestHarness.kt | 13 -------- intellij/testing/build.gradle | 21 ------------ .../motif/intellij/testing/IntelliJRule.kt | 33 ------------------- settings.gradle | 1 - 6 files changed, 70 deletions(-) delete mode 100644 intellij/testing/build.gradle delete mode 100644 intellij/testing/src/main/kotlin/motif/intellij/testing/IntelliJRule.kt diff --git a/intellij/ast/build.gradle b/intellij/ast/build.gradle index 348011d7..2ff5f97d 100644 --- a/intellij/ast/build.gradle +++ b/intellij/ast/build.gradle @@ -27,7 +27,6 @@ dependencies { testImplementation deps.test.junit testImplementation deps.test.assertj testImplementation deps.test.truth - testImplementation project(':intellij:testing') } tasks { diff --git a/intellij/build.gradle b/intellij/build.gradle index 34be84e9..94215cac 100644 --- a/intellij/build.gradle +++ b/intellij/build.gradle @@ -28,7 +28,6 @@ dependencies { implementation deps.kotlin.reflection testImplementation deps.test.truth - testImplementation project(':intellij:testing') testImplementation project(':viewmodel') } diff --git a/intellij/src/test/kotlin/motif/intellij/TestHarness.kt b/intellij/src/test/kotlin/motif/intellij/TestHarness.kt index c6f88c91..2e0ba1aa 100644 --- a/intellij/src/test/kotlin/motif/intellij/TestHarness.kt +++ b/intellij/src/test/kotlin/motif/intellij/TestHarness.kt @@ -30,39 +30,26 @@ import kotlin.reflect.KClass import motif.Scope import motif.core.ResolvedGraph import motif.errormessage.ErrorMessage -import motif.intellij.testing.IntelliJRule import motif.viewmodel.TestRenderer -import org.junit.After -import org.junit.Before -import org.junit.Rule import org.junit.Test import org.junit.runner.RunWith @RunWith(Parameterized::class) class TestHarness : LightJavaCodeInsightFixtureTestCase() { - @get:Rule val rule = IntelliJRule() - @org.junit.runners.Parameterized.Parameter(0) lateinit var testDir: File override fun getProjectDescriptor() = DefaultLightProjectDescriptor { JavaAwareProjectJdkTableImpl.getInstanceEx().internalJdk } - @Before public override fun setUp() { super.setUp() - addLibrary(Inject::class) addLibrary(Scope::class) addLibrary(Nullable::class) } - @After - public override fun tearDown() { - super.tearDown() - } - private fun addLibrary(clazz: KClass<*>) { val fileUri = clazz diff --git a/intellij/testing/build.gradle b/intellij/testing/build.gradle deleted file mode 100644 index a1df613e..00000000 --- a/intellij/testing/build.gradle +++ /dev/null @@ -1,21 +0,0 @@ -plugins { - id "org.jetbrains.intellij" - id 'org.jetbrains.kotlin.jvm' -} - -intellij { - version = deps.versions.gradleIntellijPlugin.ide - plugins = [ 'java', 'Kotlin' ] - pluginName = 'Motif Plugin' - updateSinceUntilBuild = false -} - -dependencies { - implementation deps.test.truth -} - -tasks { - buildSearchableOptions { - enabled = false - } -} diff --git a/intellij/testing/src/main/kotlin/motif/intellij/testing/IntelliJRule.kt b/intellij/testing/src/main/kotlin/motif/intellij/testing/IntelliJRule.kt deleted file mode 100644 index b50a56d3..00000000 --- a/intellij/testing/src/main/kotlin/motif/intellij/testing/IntelliJRule.kt +++ /dev/null @@ -1,33 +0,0 @@ -/* - * Copyright (c) 2018-2019 Uber Technologies, Inc. - * - * 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 motif.intellij.testing - -import com.intellij.testFramework.TestApplicationManager -import org.junit.rules.TestRule -import org.junit.runner.Description -import org.junit.runners.model.Statement - -class IntelliJRule : TestRule { - - override fun apply(base: Statement, description: Description): Statement { - return object : Statement() { - - override fun evaluate() { - TestApplicationManager.getInstance() - } - } - } -} diff --git a/settings.gradle b/settings.gradle index ee6526e1..99f710c5 100644 --- a/settings.gradle +++ b/settings.gradle @@ -40,7 +40,6 @@ include 'samples:sample-kotlin-ksp' include 'samples:dagger-comparison' include 'intellij' include 'intellij-ast' -include 'intellij:testing' include 'core' include 'errormessage' include 'models' From 5aee8c884266ed754cc2661ca4fe53ca5edf89b9 Mon Sep 17 00:00:00 2001 From: daviss Date: Fri, 20 Oct 2023 17:01:25 -0700 Subject: [PATCH 9/9] clean up build script 1. setting the jvm target in a more succinct way 2. avoid noisy build due to spotless depending on its own output https://github.com/diffplug/spotless/issues/870#issuecomment-851726260 --- build.gradle | 8 ++++---- intellij/ast/build.gradle | 6 ++---- intellij/build.gradle | 6 ++---- 3 files changed, 8 insertions(+), 12 deletions(-) diff --git a/build.gradle b/build.gradle index a0ec1818..a63c4f3d 100644 --- a/build.gradle +++ b/build.gradle @@ -74,13 +74,13 @@ subprojects { apply plugin: 'com.diffplug.spotless' spotless { format 'misc', { - target '**/*.md', '**/.gitignore' + target '*.md', '.gitignore' trimTrailingWhitespace() endWithNewline() } kotlin { - target "**/*.kt" + target "src/**/*.kt" ktlint(deps.versions.ktlint).userData(['indent_size': '2', 'continuation_indent_size': '2']) ktfmt(deps.versions.ktfmt) licenseHeaderFile rootProject.file('config/spotless/copyright.kt') @@ -88,7 +88,7 @@ subprojects { endWithNewline() } java { - target "**/*.java" + target "src/**/*.java" googleJavaFormat(deps.versions.gjf) licenseHeaderFile rootProject.file('config/spotless/copyright.java') removeUnusedImports() @@ -96,7 +96,7 @@ subprojects { endWithNewline() } groovyGradle { - target '**/*.gradle' + target '*.gradle' trimTrailingWhitespace() endWithNewline() } diff --git a/intellij/ast/build.gradle b/intellij/ast/build.gradle index 2ff5f97d..6ffafded 100644 --- a/intellij/ast/build.gradle +++ b/intellij/ast/build.gradle @@ -11,10 +11,8 @@ intellij { updateSinceUntilBuild = false } -java { - toolchain { - languageVersion.set(JavaLanguageVersion.of(17)) - } +kotlin { + jvmToolchain(17) } dependencies { diff --git a/intellij/build.gradle b/intellij/build.gradle index 94215cac..a9b28868 100644 --- a/intellij/build.gradle +++ b/intellij/build.gradle @@ -11,10 +11,8 @@ intellij { updateSinceUntilBuild = false } -java { - toolchain { - languageVersion.set(JavaLanguageVersion.of(17)) - } +kotlin { + jvmToolchain(17) } group 'com.uber.motif'