diff --git a/.scalafix.conf b/.scalafix.conf index 2c0c7153f08..c2690c2b9ea 100644 --- a/.scalafix.conf +++ b/.scalafix.conf @@ -1,19 +1,15 @@ rules = [ - OrganizeImports, - ExplicitResultTypes, - RemoveUnused + OrganizeImports ] -ExplicitResultTypes.rewriteStructuralTypesToNamedSubclass = false - -RemoveUnused.imports = false - OrganizeImports.groupedImports = Explode OrganizeImports.expandRelative = true -OrganizeImports.removeUnused = true +OrganizeImports.removeUnused = false OrganizeImports.groups = [ "re:javax?\\." "scala." "scala.meta." "*" ] + +OrganizeImports.targetDialect = StandardLayout \ No newline at end of file diff --git a/.scalafix2.conf b/.scalafix2.conf new file mode 100644 index 00000000000..2c0c7153f08 --- /dev/null +++ b/.scalafix2.conf @@ -0,0 +1,19 @@ +rules = [ + OrganizeImports, + ExplicitResultTypes, + RemoveUnused +] + +ExplicitResultTypes.rewriteStructuralTypesToNamedSubclass = false + +RemoveUnused.imports = false + +OrganizeImports.groupedImports = Explode +OrganizeImports.expandRelative = true +OrganizeImports.removeUnused = true +OrganizeImports.groups = [ + "re:javax?\\." + "scala." + "scala.meta." + "*" +] diff --git a/.scalafix3.conf b/.scalafix3.conf deleted file mode 100644 index 24d6b64c9bd..00000000000 --- a/.scalafix3.conf +++ /dev/null @@ -1,14 +0,0 @@ -rules = [ - OrganizeImports -] - -OrganizeImports.groupedImports = Explode -OrganizeImports.expandRelative = true -OrganizeImports.removeUnused = false -OrganizeImports.groups = [ - "re:javax?\\." - "scala." - "scala.meta." - "*" -] -OrganizeImports.targetDialect = StandardLayout diff --git a/.scalafmt.conf b/.scalafmt.conf index 04ed98649f6..ae0bf8e6a6a 100644 --- a/.scalafmt.conf +++ b/.scalafmt.conf @@ -1,5 +1,5 @@ version = "3.8.3" -runner.dialect = scala213source3 +runner.dialect = scala3 project.git = true align.preset = none align.stripMargin = true @@ -37,6 +37,7 @@ fileOverride { }, "glob:**/mtags*/**" { trailingCommas = never + runner.dialect = scala213 } "glob:**/tests/cross/src/**" { trailingCommas = never diff --git a/build.sbt b/build.sbt index 0e90d8eb4cc..992985c0909 100644 --- a/build.sbt +++ b/build.sbt @@ -36,7 +36,7 @@ def crossSetting[A]( logo := Welcome.logo usefulTasks := Welcome.tasks -ThisBuild / scalafixScalaBinaryVersion := scalaBinaryVersion.value +ThisBuild / scalafixScalaBinaryVersion := "2.13" inThisBuild( List( @@ -44,8 +44,8 @@ inThisBuild( if (isCI) dynVer else localSnapshotVersion // only for local publishing }, - scalaVersion := V.scala213, - crossScalaVersions := List(V.scala213), + scalaVersion := V.scala3, + crossScalaVersions := List(V.scala3), organization := "org.scalameta", licenses := Seq( "Apache-2.0" -> url("http://www.apache.org/licenses/LICENSE-2.0") @@ -128,7 +128,7 @@ commands ++= Seq( runMtagsPublishLocal(st, v, localSnapshotVersion) } "interfaces/publishLocal" :: - s"++${V.scala213} metals/publishLocal" :: + s"++${V.scala3} metals/publishLocal" :: "mtags-java/publishLocal" :: publishMtags }, @@ -218,6 +218,27 @@ val sharedSettings = sharedJavacOptions ++ sharedScalacOptions ++ List( ) ), ), + excludeDependencies ++= crossSetting( + scalaVersion.value, + if3 = { + // Exclude cross published version dependencies leading to conflicts in Scala 3 vs 2.13 + // When using Scala 3 exclude Scala 2.13 standard native libraries, + // when using Scala 2.13 exclude Scala 3 standard native libraries + // Use full name, Maven style published artifacts cannot use artifact/cross version for exclusion rules + List( + ExclusionRule() + .withOrganization("org.scala-lang.modules") + .withName( + "scala-collection-compat_2.13" + ), + ExclusionRule() + .withOrganization("org.scala-lang.modules") + .withName( + "scala-xml_2.13" + ), + ) + }, + ), scalacOptions ++= lintingOptions(scalaVersion.value), ) @@ -299,6 +320,10 @@ def withExcludes(moduleId: ModuleID) = "com.lihaoyi", "sourcecode_2.13", ) // avoid 2.13 and 3 on the classpath since it comes in via pprint + .exclude( + "org.scala-lang.modules", + "scala-parallel-collections_2.13", + ) // avoid 2.13 and 3 on the classpath since it comes in via pprint def scala3SemanticdbDependency: ModuleID = withExcludes( ("org.scalameta" % s"semanticdb-shared_${V.scala213}" % V.scalameta) @@ -309,6 +334,10 @@ def scala3ScalametaDependency: ModuleID = withExcludes( .cross(CrossVersion.for3Use2_13) ) +def scala3MetapDependency: ModuleID = withExcludes( + "org.scalameta" % s"semanticdb-metap_${V.scala213}" % V.scalameta +) + val mtagsSettings = List( crossScalaVersions := V.supportedScalaVersions, crossTarget := target.value / s"scala-${scalaVersion.value}", @@ -370,7 +399,7 @@ val mtagsSettings = List( }, ) -lazy val mtags3 = project +lazy val mtags2 = project .in(file(".mtags")) .settings( Compile / unmanagedSourceDirectories := Seq(), @@ -378,14 +407,14 @@ lazy val mtags3 = project mtagsSettings, Compile / unmanagedSourceDirectories += (ThisBuild / baseDirectory).value / "mtags" / "src" / "main" / "scala", Compile / unmanagedSourceDirectories += (ThisBuild / baseDirectory).value / "mtags-shared" / "src" / "main" / "scala", - Compile / unmanagedSourceDirectories += (ThisBuild / baseDirectory).value / "mtags-shared" / "src" / "main" / "scala-3", - moduleName := "mtags3", - scalaVersion := V.scala3, - target := (ThisBuild / baseDirectory).value / "mtags" / "target" / "target3", + Compile / unmanagedSourceDirectories += (ThisBuild / baseDirectory).value / "mtags-shared" / "src" / "main" / "scala-2.13", + moduleName := "mtags2", + scalaVersion := V.scala213, + target := (ThisBuild / baseDirectory).value / "mtags" / "target" / "target2", publish / skip := true, libraryDependencies += V.guava, scalafixConfig := Some( - (ThisBuild / baseDirectory).value / ".scalafix3.conf" + (ThisBuild / baseDirectory).value / ".scalafix2.conf" ), ) .dependsOn(interfaces) @@ -433,44 +462,51 @@ lazy val metals = project // for BSP "org.scala-sbt.ipcsocket" % "ipcsocket" % "1.6.2", "ch.epfl.scala" % "bsp4j" % V.bsp, - "ch.epfl.scala" %% "bloop-rifle" % V.bloop, + ("ch.epfl.scala" %% "bloop-rifle" % V.bloop) + .cross(CrossVersion.for3Use2_13), // for LSP V.lsp4j, // for DAP V.dap4j, - "ch.epfl.scala" %% "scala-debug-adapter" % V.debugAdapter, + withExcludes( + ("ch.epfl.scala" %% "scala-debug-adapter" % V.debugAdapter) + .cross(CrossVersion.for3Use2_13) + ), // for finding paths of global log/cache directories "dev.dirs" % "directories" % "26", // ================== // Scala dependencies // ================== "org.scalameta" % "mdoc-interfaces" % V.mdoc, - "org.scalameta" %% "scalafmt-dynamic" % V.scalafmt, + ("org.scalameta" %% "scalafmt-dynamic" % V.scalafmt) + .cross(CrossVersion.for3Use2_13), + "com.googlecode.java-diff-utils" % "diffutils" % "1.3.0", "ch.epfl.scala" % "scalafix-interfaces" % V.scalafix, // For reading classpaths. // for fetching ch.epfl.scala:bloop-frontend and other library dependencies "io.get-coursier" % "interface" % V.coursierInterfaces, // for comparing versions && fetching from sbt maven repository - "io.get-coursier" %% "coursier" % V.coursier, - "io.get-coursier" %% "coursier-sbt-maven-repository" % V.coursier, + ("io.get-coursier" %% "versions" % "0.3.2") + .cross(CrossVersion.for3Use2_13), + ("io.get-coursier" %% "coursier-sbt-maven-repository" % V.coursier) + .cross(CrossVersion.for3Use2_13), + ("io.get-coursier" %% "coursier" % V.coursier) + .cross(CrossVersion.for3Use2_13), // for logging "com.outr" %% "scribe" % V.scribe, "com.outr" %% "scribe-file" % V.scribe, "com.outr" %% "scribe-slf4j2" % V.scribe, // needed for flyway database migrations // for JSON formatted doctor - "com.lihaoyi" %% "ujson" % "4.0.0", + "com.lihaoyi" %% "ujson" % "3.3.1", // For fetching projects' templates "com.lihaoyi" %% "requests" % "0.9.0", // for producing SemanticDB from Scala source files, to be sure we want the same version of scalameta - "org.scalameta" %% "scalameta" % V.semanticdb(scalaVersion.value), - "org.scalameta" %% "semanticdb-metap" % V.semanticdb( - scalaVersion.value - ) cross CrossVersion.full, - "org.scalameta" % "semanticdb-shared" % V.semanticdb( - scalaVersion.value - ) cross CrossVersion.full, + scala3ScalametaDependency, + scala3MetapDependency, + scala3SemanticdbDependency, // For starting Ammonite - "io.github.alexarchambault.ammonite" %% "ammonite-runner" % "0.4.0", + ("io.github.alexarchambault.ammonite" %% "ammonite-runner" % "0.4.0") + .cross(CrossVersion.for3Use2_13), "org.scala-lang.modules" %% "scala-xml" % "2.3.0", "org.scala-lang.modules" %% "scala-parallel-collections" % "1.0.4", ("org.virtuslab.scala-cli" % "scala-cli-bsp" % V.scalaCli) @@ -540,6 +576,7 @@ lazy val input = project .in(file("tests/input")) .settings( sharedSettings, + scalaVersion := V.scala213, scalacOptions -= "-Xsource:3", publish / skip := true, libraryDependencies ++= List( @@ -716,6 +753,7 @@ lazy val metalsDependencies = project .in(file("target/.dependencies")) .settings( publish / skip := true, + scalaVersion := V.scala213, // silent the intransitive dependency warning publishMavenStyle := false, libraryDependencies ++= List( @@ -745,8 +783,10 @@ lazy val unit = project sharedSettings, Test / javaOptions += "-Xmx2G", libraryDependencies ++= List( - "io.get-coursier" %% "coursier" % V.coursier, // for jars - "ch.epfl.scala" %% "bloop-config" % V.bloopConfig, + ("io.get-coursier" %% "coursier" % V.coursier) + .cross(CrossVersion.for3Use2_13), // for jars + ("ch.epfl.scala" %% "bloop-config" % V.bloopConfig) + .cross(CrossVersion.for3Use2_13), "org.scalameta" %% "munit" % V.munit, ), buildInfoPackage := "tests", diff --git a/dep.txt b/dep.txt new file mode 100644 index 00000000000..a8a743121ba --- /dev/null +++ b/dep.txt @@ -0,0 +1,694 @@ +[info] welcome to sbt 1.9.9 (Eclipse Adoptium Java 17.0.6) +[info] loading global plugins from /home/tgodzik/.sbt/1.0/plugins +[info] loading settings for project metals-build-build-build from metals.sbt ... +[info] loading project definition from /home/tgodzik/Documents/metals/project/project/project +[info] loading settings for project metals-build-build from metals.sbt ... +[info] loading project definition from /home/tgodzik/Documents/metals/project/project +[success] Generated .bloop/metals-build-build.json +[success] Total time: 1 s, completed Aug 16, 2024, 6:21:30 PM +[info] loading settings for project metals-build from metals.sbt,plugins.sbt ... +[info] loading project definition from /home/tgodzik/Documents/metals/project +[success] Generated .bloop/metals-build.json +[success] Total time: 1 s, completed Aug 16, 2024, 6:21:32 PM +[info] loading settings for project default-ce2872 from build.sbt ... +[info] resolving key references (19696 settings) ... +[info] _ _ +[info] /\/\ ___| |_ __ _| |___ +[info] / \ / _ \ __/ _` | / __| +[info] / /\/\ \ __/ || (_| | \__ \ +[info] \/ \/\___|\__\__,_|_|___/ +[info] +[info] Useful sbt tasks: +[info] a. unit/testOnly tests.DefinitionSuite - run a specific unit test suite. +[info] b. unit/testOnly tests.DefinitionSuite -- *exact-test-name* - run a specific test case inside the unit test suite. +[info] c. unit/testOnly tests.DefinitionSuite -- -F - use `-F` flag to show the full stack trace in case it is missing +[info] d. slow/testOnly -- tests.sbt.* - run all slow tests inside tests.sbt package, they will publish needed mtags locally. +[info] e. ~cross/testOnly tests.hover.HoverTermSuite - automatically rerun on changes a specific presentation compiler test, great for edit/test/debug workflows. +[info] f. +cross/test - run all presentation compiler tests for all non-deprecated Scala versions. +[info] g. publishLocal - publish Metals for the currently used Scala version. +[info] h. +publishLocal - publish Metals for all supported used Scala versions. +[info] i. quick-publish-local - publish Metals artifacts but with only limited set of Scala versions +[info] j. ++3.3.3 mtags/publishLocal - publish changes for a single Scala version, especially useful if working on a feature inside mtags module. `publishLocal` will still need to be run before at least once. +[warn] there's a key that's not used by any other settings/tasks: +[warn] +[warn] * ThisBuild / scalafixScalaBinaryVersion +[warn] +- /home/tgodzik/Documents/metals/build.sbt:39 +[warn] +[warn] note: a setting might still be used by a command; to exclude a key from this `lintUnused` check +[warn] either append it to `Global / excludeLintKeys` or call .withRank(KeyRanks.Invisible) on the key +[info] org.scalameta:metals_3:1.3.6-SNAPSHOT +[info] +-ch.epfl.scala:bloop-rifle_2.13:2.0.0-RC1 [S] +[info] | +-ch.epfl.scala:bsp4j:2.1.1 (evicted by: 2.2.0-M2) +[info] | +-ch.epfl.scala:bsp4j:2.2.0-M2 +[info] | | +-org.eclipse.lsp4j:org.eclipse.lsp4j.generator:0.20.1 +[info] | | | +-org.eclipse.lsp4j:org.eclipse.lsp4j.jsonrpc:0.20.1 (evicted by: 0.23.. +[info] | | | +-org.eclipse.lsp4j:org.eclipse.lsp4j.jsonrpc:0.23.1 +[info] | | | | +-com.google.code.gson:gson:2.11.0 +[info] | | | | | +-com.google.errorprone:error_prone_annotations:2.27.0 +[info] | | | | | +[info] | | | | +-com.google.code.gson:gson:[2.9.1,3.0) (evicted by: 2.11.0) +[info] | | | | +[info] | | | +-org.eclipse.xtend:org.eclipse.xtend.lib:2.28.0 +[info] | | | +-org.eclipse.xtend:org.eclipse.xtend.lib.macro:2.28.0 +[info] | | | | +-org.eclipse.xtext:org.eclipse.xtext.xbase.lib:2.28.0 +[info] | | | | +-com.google.guava:guava:33.2.1-jre +[info] | | | | +-com.google.code.findbugs:jsr305:3.0.2 +[info] | | | | +-com.google.errorprone:error_prone_annotations:2.26.1 (evicte.. +[info] | | | | +-com.google.errorprone:error_prone_annotations:2.27.0 +[info] | | | | +-com.google.guava:failureaccess:1.0.2 +[info] | | | | +-com.google.guava:listenablefuture:9999.0-empty-to-avoid-conf.. +[info] | | | | +-com.google.j2objc:j2objc-annotations:3.0.0 +[info] | | | | +-org.checkerframework:checker-qual:3.42.0 +[info] | | | | +[info] | | | +-org.eclipse.xtext:org.eclipse.xtext.xbase.lib:2.28.0 +[info] | | | +-com.google.guava:guava:33.2.1-jre +[info] | | | +-com.google.code.findbugs:jsr305:3.0.2 +[info] | | | +-com.google.errorprone:error_prone_annotations:2.26.1 (evicted .. +[info] | | | +-com.google.errorprone:error_prone_annotations:2.27.0 +[info] | | | +-com.google.guava:failureaccess:1.0.2 +[info] | | | +-com.google.guava:listenablefuture:9999.0-empty-to-avoid-confli.. +[info] | | | +-com.google.j2objc:j2objc-annotations:3.0.0 +[info] | | | +-org.checkerframework:checker-qual:3.42.0 +[info] | | | +[info] | | +-org.eclipse.lsp4j:org.eclipse.lsp4j.jsonrpc:0.20.1 (evicted by: 0.23.1) +[info] | | +-org.eclipse.lsp4j:org.eclipse.lsp4j.jsonrpc:0.23.1 +[info] | | +-com.google.code.gson:gson:2.11.0 +[info] | | | +-com.google.errorprone:error_prone_annotations:2.27.0 +[info] | | | +[info] | | +-com.google.code.gson:gson:[2.9.1,3.0) (evicted by: 2.11.0) +[info] | | +[info] | +-ch.epfl.scala:libdaemon_2.13:0.0.12 +[info] | +-io.github.alexarchambault.scala-cli.snailgun:snailgun-core_2.13:0.4.1-sc.. +[info] | +[info] +-ch.epfl.scala:bsp4j:2.2.0-M2 +[info] | +-org.eclipse.lsp4j:org.eclipse.lsp4j.generator:0.20.1 +[info] | | +-org.eclipse.lsp4j:org.eclipse.lsp4j.jsonrpc:0.20.1 (evicted by: 0.23.1) +[info] | | +-org.eclipse.lsp4j:org.eclipse.lsp4j.jsonrpc:0.23.1 +[info] | | | +-com.google.code.gson:gson:2.11.0 +[info] | | | | +-com.google.errorprone:error_prone_annotations:2.27.0 +[info] | | | | +[info] | | | +-com.google.code.gson:gson:[2.9.1,3.0) (evicted by: 2.11.0) +[info] | | | +[info] | | +-org.eclipse.xtend:org.eclipse.xtend.lib:2.28.0 +[info] | | +-org.eclipse.xtend:org.eclipse.xtend.lib.macro:2.28.0 +[info] | | | +-org.eclipse.xtext:org.eclipse.xtext.xbase.lib:2.28.0 +[info] | | | +-com.google.guava:guava:33.2.1-jre +[info] | | | +-com.google.code.findbugs:jsr305:3.0.2 +[info] | | | +-com.google.errorprone:error_prone_annotations:2.26.1 (evicted .. +[info] | | | +-com.google.errorprone:error_prone_annotations:2.27.0 +[info] | | | +-com.google.guava:failureaccess:1.0.2 +[info] | | | +-com.google.guava:listenablefuture:9999.0-empty-to-avoid-confli.. +[info] | | | +-com.google.j2objc:j2objc-annotations:3.0.0 +[info] | | | +-org.checkerframework:checker-qual:3.42.0 +[info] | | | +[info] | | +-org.eclipse.xtext:org.eclipse.xtext.xbase.lib:2.28.0 +[info] | | +-com.google.guava:guava:33.2.1-jre +[info] | | +-com.google.code.findbugs:jsr305:3.0.2 +[info] | | +-com.google.errorprone:error_prone_annotations:2.26.1 (evicted by.. +[info] | | +-com.google.errorprone:error_prone_annotations:2.27.0 +[info] | | +-com.google.guava:failureaccess:1.0.2 +[info] | | +-com.google.guava:listenablefuture:9999.0-empty-to-avoid-conflict.. +[info] | | +-com.google.j2objc:j2objc-annotations:3.0.0 +[info] | | +-org.checkerframework:checker-qual:3.42.0 +[info] | | +[info] | +-org.eclipse.lsp4j:org.eclipse.lsp4j.jsonrpc:0.20.1 (evicted by: 0.23.1) +[info] | +-org.eclipse.lsp4j:org.eclipse.lsp4j.jsonrpc:0.23.1 +[info] | +-com.google.code.gson:gson:2.11.0 +[info] | | +-com.google.errorprone:error_prone_annotations:2.27.0 +[info] | | +[info] | +-com.google.code.gson:gson:[2.9.1,3.0) (evicted by: 2.11.0) +[info] | +[info] +-ch.epfl.scala:scala-debug-adapter_2.13:4.2.0 [S] +[info] | +-ch.epfl.scala:com-microsoft-java-debug-core:0.34.0+31 +[info] | | +-com.google.code.gson:gson:2.11.0 +[info] | | | +-com.google.errorprone:error_prone_annotations:2.27.0 +[info] | | | +[info] | | +-commons-io:commons-io:2.16.1 +[info] | | +-io.reactivex.rxjava2:rxjava:2.2.21 +[info] | | | +-org.reactivestreams:reactive-streams:1.0.3 (evicted by: 1.0.4) +[info] | | | +-org.reactivestreams:reactive-streams:1.0.4 +[info] | | | +[info] | | +-org.apache.commons:commons-lang3:3.14.0 +[info] | | +-org.reactivestreams:reactive-streams:1.0.4 +[info] | | +[info] | +-org.ow2.asm:asm-util:9.7 +[info] | | +-org.ow2.asm:asm-analysis:9.7 +[info] | | | +-org.ow2.asm:asm-tree:9.7 +[info] | | | +-org.ow2.asm:asm:9.7 +[info] | | | +[info] | | +-org.ow2.asm:asm-tree:9.7 +[info] | | | +-org.ow2.asm:asm:9.7 +[info] | | | +[info] | | +-org.ow2.asm:asm:9.7 +[info] | | +[info] | +-org.ow2.asm:asm:9.7 +[info] | +-org.scala-lang.modules:scala-parallel-collections_2.13:1.0.4 [S] +[info] | +-org.scala-lang:scala-reflect:2.13.14 [S] +[info] | +-org.scala-sbt:test-agent:1.10.1 +[info] | | +-org.scala-sbt:test-interface:1.0 +[info] | | +[info] | +-org.scalameta:parsers_2.13:4.9.7 (evicted by: 4.9.9) +[info] | +-org.scalameta:parsers_2.13:4.9.9 [S] +[info] | +-org.scalameta:trees_2.13:4.9.9 [S] +[info] | +-org.scalameta:common_2.13:4.9.9 [S] +[info] | +-com.lihaoyi:sourcecode_2.13:0.4.2 [S] +[info] | +[info] +-ch.epfl.scala:scalafix-interfaces:0.12.1 +[info] | +-io.get-coursier:interface:1.0.19 +[info] | +-org.slf4j:slf4j-api:1.7.36 (evicted by: 2.0.13) +[info] | +-org.slf4j:slf4j-api:2.0.13 +[info] | +[info] +-com.google.guava:guava:33.2.1-jre +[info] | +-com.google.code.findbugs:jsr305:3.0.2 +[info] | +-com.google.errorprone:error_prone_annotations:2.26.1 (evicted by: 2.27.0) +[info] | +-com.google.errorprone:error_prone_annotations:2.27.0 +[info] | +-com.google.guava:failureaccess:1.0.2 +[info] | +-com.google.guava:listenablefuture:9999.0-empty-to-avoid-conflict-with-gu.. +[info] | +-com.google.j2objc:j2objc-annotations:3.0.0 +[info] | +-org.checkerframework:checker-qual:3.42.0 +[info] | +[info] +-com.googlecode.java-diff-utils:diffutils:1.3.0 +[info] +-com.h2database:h2:2.3.230 +[info] +-com.lihaoyi:requests_3:0.9.0 +[info] | +-com.lihaoyi:geny_3:1.0.0 (evicted by: 1.1.1) +[info] | +-com.lihaoyi:geny_3:1.1.1 +[info] | | +-org.scala-lang:scala3-library_3:3.3.1 (evicted by: 3.4.2) +[info] | | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | | +[info] | +-org.scala-lang:scala3-library_3:3.1.1 (evicted by: 3.4.2) +[info] | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | +[info] +-com.lihaoyi:ujson_3:4.0.0 +[info] | +-com.lihaoyi:upickle-core_3:4.0.0 +[info] | | +-com.lihaoyi:geny_3:1.1.1 +[info] | | | +-org.scala-lang:scala3-library_3:3.3.1 (evicted by: 3.4.2) +[info] | | | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | | | +[info] | | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | | +[info] | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | +[info] +-com.outr:scribe-file_3:3.15.0 +[info] | +-com.outr:scribe_3:3.15.0 +[info] | | +-com.lihaoyi:sourcecode_3:0.4.2 +[info] | | | +-org.scala-lang:scala3-library_3:3.3.1 (evicted by: 3.4.2) +[info] | | | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | | | +[info] | | +-com.outr:moduload_3:1.1.7 +[info] | | | +-org.scala-lang.modules:scala-collection-compat_3:2.11.0 (evicted by:.. +[info] | | | +-org.scala-lang.modules:scala-collection-compat_3:2.12.0 +[info] | | | | +-org.scala-lang:scala3-library_3:3.2.2 (evicted by: 3.4.2) +[info] | | | | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | | | | +[info] | | | +-org.scala-lang:scala3-library_3:3.3.0 (evicted by: 3.4.2) +[info] | | | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | | | +[info] | | +-com.outr:perfolation_3:1.2.11 +[info] | | | +-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) +[info] | | | | #-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) (cyc.. +[info] | | | | +[info] | | | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | | | +[info] | | +-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) +[info] | | | #-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) (cycle) +[info] | | | +[info] | | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | | +[info] | +-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) +[info] | | #-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) (cycle) +[info] | | +[info] | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | +[info] +-com.outr:scribe-slf4j2_3:3.15.0 +[info] | +-com.outr:scribe_3:3.15.0 +[info] | | +-com.lihaoyi:sourcecode_3:0.4.2 +[info] | | | +-org.scala-lang:scala3-library_3:3.3.1 (evicted by: 3.4.2) +[info] | | | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | | | +[info] | | +-com.outr:moduload_3:1.1.7 +[info] | | | +-org.scala-lang.modules:scala-collection-compat_3:2.11.0 (evicted by:.. +[info] | | | +-org.scala-lang.modules:scala-collection-compat_3:2.12.0 +[info] | | | | +-org.scala-lang:scala3-library_3:3.2.2 (evicted by: 3.4.2) +[info] | | | | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | | | | +[info] | | | +-org.scala-lang:scala3-library_3:3.3.0 (evicted by: 3.4.2) +[info] | | | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | | | +[info] | | +-com.outr:perfolation_3:1.2.11 +[info] | | | +-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) +[info] | | | | #-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) (cyc.. +[info] | | | | +[info] | | | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | | | +[info] | | +-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) +[info] | | | #-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) (cycle) +[info] | | | +[info] | | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | | +[info] | +-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) +[info] | | #-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) (cycle) +[info] | | +[info] | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | +-org.slf4j:slf4j-api:2.0.13 +[info] | +[info] +-com.outr:scribe_3:3.15.0 +[info] | +-com.lihaoyi:sourcecode_3:0.4.2 +[info] | | +-org.scala-lang:scala3-library_3:3.3.1 (evicted by: 3.4.2) +[info] | | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | | +[info] | +-com.outr:moduload_3:1.1.7 +[info] | | +-org.scala-lang.modules:scala-collection-compat_3:2.11.0 (evicted by: 2.. +[info] | | +-org.scala-lang.modules:scala-collection-compat_3:2.12.0 +[info] | | | +-org.scala-lang:scala3-library_3:3.2.2 (evicted by: 3.4.2) +[info] | | | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | | | +[info] | | +-org.scala-lang:scala3-library_3:3.3.0 (evicted by: 3.4.2) +[info] | | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | | +[info] | +-com.outr:perfolation_3:1.2.11 +[info] | | +-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) +[info] | | | #-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) (cycle) +[info] | | | +[info] | | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | | +[info] | +-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) +[info] | | #-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) (cycle) +[info] | | +[info] | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | +[info] +-com.swoval:file-tree-views:2.1.12 +[info] +-dev.dirs:directories:26 +[info] +-io.get-coursier:coursier-sbt-maven-repository_2.13:2.1.10 [S] +[info] | +-io.get-coursier:coursier-core_2.13:2.1.10 [S] +[info] | +-io.get-coursier:coursier-util_2.13:2.1.10 [S] +[info] | +-io.github.alexarchambault:concurrent-reference-hash-map:1.1.0 +[info] | +[info] +-io.get-coursier:coursier_2.13:2.1.10 [S] +[info] | +-com.github.plokhotnyuk.jsoniter-scala:jsoniter-scala-core_2.13:2.13.5 (e.. +[info] | +-com.github.plokhotnyuk.jsoniter-scala:jsoniter-scala-core_2.13:2.13.5.2 .. +[info] | +-io.get-coursier:coursier-cache_2.13:2.1.10 [S] +[info] | | +-io.get-coursier.jniutils:windows-jni-utils:0.3.3 +[info] | | +-io.get-coursier:coursier-util_2.13:2.1.10 [S] +[info] | | +-io.github.alexarchambault.windows-ansi:windows-ansi:0.0.5 +[info] | | | +-org.fusesource.jansi:jansi:1.18 +[info] | | | +[info] | | +-org.codehaus.plexus:plexus-archiver:4.9.0 +[info] | | | +-com.github.luben:zstd-jni:1.5.5-10 +[info] | | | +-commons-io:commons-io:2.15.0 (evicted by: 2.16.1) +[info] | | | +-commons-io:commons-io:2.16.1 +[info] | | | +-javax.inject:javax.inject:1 +[info] | | | +-org.apache.commons:commons-compress:1.24.0 +[info] | | | +-org.codehaus.plexus:plexus-io:3.4.1 +[info] | | | | +-commons-io:commons-io:2.11.0 (evicted by: 2.16.1) +[info] | | | | +-commons-io:commons-io:2.16.1 +[info] | | | | +-javax.inject:javax.inject:1 +[info] | | | | +-org.codehaus.plexus:plexus-utils:3.5.0 (evicted by: 4.0.0) +[info] | | | | +-org.codehaus.plexus:plexus-utils:4.0.0 +[info] | | | | +[info] | | | +-org.codehaus.plexus:plexus-utils:4.0.0 +[info] | | | +-org.iq80.snappy:snappy:0.4 +[info] | | | +-org.slf4j:slf4j-api:1.7.36 (evicted by: 2.0.13) +[info] | | | +-org.slf4j:slf4j-api:2.0.13 +[info] | | | +-org.tukaani:xz:1.9 +[info] | | | +[info] | | +-org.codehaus.plexus:plexus-container-default:2.1.1 +[info] | | | +-org.apache.xbean:xbean-reflect:3.7 +[info] | | | +-org.codehaus.plexus:plexus-classworlds:2.6.0 +[info] | | | +-org.codehaus.plexus:plexus-utils:3.1.1 (evicted by: 4.0.0) +[info] | | | +-org.codehaus.plexus:plexus-utils:4.0.0 +[info] | | | +[info] | | +-org.virtuslab.scala-cli:config_2.13:0.2.1 [S] +[info] | | +-com.github.plokhotnyuk.jsoniter-scala:jsoniter-scala-core_2.13:2.13... +[info] | | +[info] | +-io.get-coursier:coursier-core_2.13:2.1.10 [S] +[info] | | +-io.get-coursier:coursier-util_2.13:2.1.10 [S] +[info] | | +-io.github.alexarchambault:concurrent-reference-hash-map:1.1.0 +[info] | | +[info] | +-io.get-coursier:coursier-proxy-setup:2.1.10 +[info] | +[info] +-io.get-coursier:interface:1.0.19 +[info] | +-org.slf4j:slf4j-api:1.7.36 (evicted by: 2.0.13) +[info] | +-org.slf4j:slf4j-api:2.0.13 +[info] | +[info] +-io.get-coursier:versions_2.13:0.3.2 [S] +[info] +-io.github.alexarchambault.ammonite:ammonite-runner_2.13:0.4.0 [S] +[info] | +-io.get-coursier:coursier-launcher_2.13:2.0.16 [S] +[info] | +-io.get-coursier:interface:1.0.19 +[info] | | +-org.slf4j:slf4j-api:1.7.36 (evicted by: 2.0.13) +[info] | | +-org.slf4j:slf4j-api:2.0.13 +[info] | | +[info] | +-io.get-coursier:interface:1.0.8 (evicted by: 1.0.19) +[info] | +[info] +-io.undertow:undertow-core:2.2.20.Final +[info] | +-org.jboss.logging:jboss-logging:3.4.1.Final +[info] | +-org.jboss.threads:jboss-threads:3.1.0.Final +[info] | | +-org.jboss.logging:jboss-logging:3.4.1.Final +[info] | | +-org.wildfly.common:wildfly-common:1.5.0.Final (evicted by: 1.5.4.Final) +[info] | | +-org.wildfly.common:wildfly-common:1.5.4.Final +[info] | | +[info] | +-org.jboss.xnio:xnio-api:3.8.16.Final +[info] | | +-org.jboss.threads:jboss-threads:2.3.6.Final (evicted by: 3.1.0.Final) +[info] | | +-org.jboss.threads:jboss-threads:3.1.0.Final +[info] | | | +-org.jboss.logging:jboss-logging:3.4.1.Final +[info] | | | +-org.wildfly.common:wildfly-common:1.5.0.Final (evicted by: 1.5.4.Fin.. +[info] | | | +-org.wildfly.common:wildfly-common:1.5.4.Final +[info] | | | +[info] | | +-org.wildfly.client:wildfly-client-config:1.0.1.Final +[info] | | | +-org.jboss.logging:jboss-logging:3.3.1.Final (evicted by: 3.4.1.Final) +[info] | | | +-org.jboss.logging:jboss-logging:3.4.1.Final +[info] | | | +[info] | | +-org.wildfly.common:wildfly-common:1.5.4.Final +[info] | | +[info] | +-org.jboss.xnio:xnio-api:3.8.7.Final (evicted by: 3.8.16.Final) +[info] | +-org.jboss.xnio:xnio-nio:3.8.16.Final +[info] | | +-org.jboss.xnio:xnio-api:3.8.16.Final +[info] | | +-org.jboss.threads:jboss-threads:2.3.6.Final (evicted by: 3.1.0.Final) +[info] | | +-org.jboss.threads:jboss-threads:3.1.0.Final +[info] | | | +-org.jboss.logging:jboss-logging:3.4.1.Final +[info] | | | +-org.wildfly.common:wildfly-common:1.5.0.Final (evicted by: 1.5.4.F.. +[info] | | | +-org.wildfly.common:wildfly-common:1.5.4.Final +[info] | | | +[info] | | +-org.wildfly.client:wildfly-client-config:1.0.1.Final +[info] | | | +-org.jboss.logging:jboss-logging:3.3.1.Final (evicted by: 3.4.1.Fin.. +[info] | | | +-org.jboss.logging:jboss-logging:3.4.1.Final +[info] | | | +[info] | | +-org.wildfly.common:wildfly-common:1.5.4.Final +[info] | | +[info] | +-org.jboss.xnio:xnio-nio:3.8.7.Final (evicted by: 3.8.16.Final) +[info] | +[info] +-org.eclipse.jdt:org.eclipse.jdt.core:3.25.0 +[info] +-org.eclipse.lsp4j:org.eclipse.lsp4j.debug:0.23.1 +[info] | +-org.eclipse.lsp4j:org.eclipse.lsp4j.jsonrpc.debug:0.23.1 +[info] | +-com.google.code.gson:gson:2.11.0 +[info] | | +-com.google.errorprone:error_prone_annotations:2.27.0 +[info] | | +[info] | +-com.google.code.gson:gson:[2.9.1,3.0) (evicted by: 2.11.0) +[info] | +-org.eclipse.lsp4j:org.eclipse.lsp4j.jsonrpc:0.23.1 +[info] | +-com.google.code.gson:gson:2.11.0 +[info] | | +-com.google.errorprone:error_prone_annotations:2.27.0 +[info] | | +[info] | +-com.google.code.gson:gson:[2.9.1,3.0) (evicted by: 2.11.0) +[info] | +[info] +-org.eclipse.lsp4j:org.eclipse.lsp4j:0.23.1 +[info] | +-org.eclipse.lsp4j:org.eclipse.lsp4j.jsonrpc:0.23.1 +[info] | +-com.google.code.gson:gson:2.11.0 +[info] | | +-com.google.errorprone:error_prone_annotations:2.27.0 +[info] | | +[info] | +-com.google.code.gson:gson:[2.9.1,3.0) (evicted by: 2.11.0) +[info] | +[info] +-org.eclipse.platform:org.eclipse.ant.core:3.5.500 +[info] +-org.eclipse.platform:org.eclipse.compare.core:3.6.600 +[info] +-org.eclipse.platform:org.eclipse.core.commands:3.9.500 +[info] +-org.eclipse.platform:org.eclipse.core.contenttype:3.7.500 +[info] +-org.eclipse.platform:org.eclipse.core.expressions:3.6.500 +[info] +-org.eclipse.platform:org.eclipse.core.filesystem:1.7.500 +[info] +-org.eclipse.platform:org.eclipse.core.jobs:3.10.500 +[info] +-org.eclipse.platform:org.eclipse.core.resources:3.13.500 +[info] +-org.eclipse.platform:org.eclipse.core.runtime:3.16.0 +[info] +-org.eclipse.platform:org.eclipse.core.variables:3.4.600 +[info] +-org.eclipse.platform:org.eclipse.equinox.app:1.4.300 +[info] +-org.eclipse.platform:org.eclipse.equinox.common:3.10.600 +[info] +-org.eclipse.platform:org.eclipse.equinox.preferences:3.7.600 +[info] +-org.eclipse.platform:org.eclipse.equinox.registry:3.8.600 +[info] +-org.eclipse.platform:org.eclipse.osgi:3.15.0 +[info] +-org.eclipse.platform:org.eclipse.team.core:3.8.700 +[info] +-org.eclipse.platform:org.eclipse.text:3.9.0 +[info] +-org.flywaydb:flyway-core:9.22.3 +[info] | +-com.fasterxml.jackson.dataformat:jackson-dataformat-toml:2.15.2 +[info] | | +-com.fasterxml.jackson.core:jackson-core:2.15.2 +[info] | | +-com.fasterxml.jackson.core:jackson-databind:2.15.2 +[info] | | +-com.fasterxml.jackson.core:jackson-annotations:2.15.2 +[info] | | +-com.fasterxml.jackson.core:jackson-core:2.15.2 +[info] | | +[info] | +-com.google.code.gson:gson:2.10.1 (evicted by: 2.11.0) +[info] | +-com.google.code.gson:gson:2.11.0 +[info] | +-com.google.errorprone:error_prone_annotations:2.27.0 +[info] | +[info] +-org.jboss.xnio:xnio-nio:3.8.16.Final +[info] | +-org.jboss.xnio:xnio-api:3.8.16.Final +[info] | +-org.jboss.threads:jboss-threads:2.3.6.Final (evicted by: 3.1.0.Final) +[info] | +-org.jboss.threads:jboss-threads:3.1.0.Final +[info] | | +-org.jboss.logging:jboss-logging:3.4.1.Final +[info] | | +-org.wildfly.common:wildfly-common:1.5.0.Final (evicted by: 1.5.4.Fin.. +[info] | | +-org.wildfly.common:wildfly-common:1.5.4.Final +[info] | | +[info] | +-org.wildfly.client:wildfly-client-config:1.0.1.Final +[info] | | +-org.jboss.logging:jboss-logging:3.3.1.Final (evicted by: 3.4.1.Final) +[info] | | +-org.jboss.logging:jboss-logging:3.4.1.Final +[info] | | +[info] | +-org.wildfly.common:wildfly-common:1.5.4.Final +[info] | +[info] +-org.openjdk.jol:jol-core:0.17 +[info] +-org.scala-lang.modules:scala-parallel-collections_3:1.0.4 +[info] | +-org.scala-lang:scala3-library_3:3.0.2 (evicted by: 3.4.2) +[info] | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | +[info] +-org.scala-lang.modules:scala-xml_3:2.3.0 +[info] | +-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) +[info] | | #-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) (cycle) +[info] | | +[info] | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | +[info] +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] +-org.scala-sbt.ipcsocket:ipcsocket:1.6.2 +[info] | +-net.java.dev.jna:jna-platform:5.12.0 +[info] | | +-net.java.dev.jna:jna:5.12.0 +[info] | | +[info] | +-net.java.dev.jna:jna:5.12.0 +[info] | +[info] +-org.scalameta:mdoc-interfaces:2.5.4 +[info] | +-io.get-coursier:interface:1.0.19 +[info] | +-org.slf4j:slf4j-api:1.7.36 (evicted by: 2.0.13) +[info] | +-org.slf4j:slf4j-api:2.0.13 +[info] | +[info] +-org.scalameta:metaconfig-core_3:0.13.0 +[info] | +-org.scala-lang.modules:scala-collection-compat_3:2.12.0 +[info] | | +-org.scala-lang:scala3-library_3:3.2.2 (evicted by: 3.4.2) +[info] | | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | | +[info] | +-org.scala-lang:scala-reflect:2.13.14 [S] +[info] | +-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) +[info] | | #-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) (cycle) +[info] | | +[info] | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | +-org.scalameta:metaconfig-pprint_3:0.13.0 +[info] | | +-com.lihaoyi:fansi_3:0.5.0 +[info] | | | +-com.lihaoyi:sourcecode_3:0.4.0 (evicted by: 0.4.2) +[info] | | | +-com.lihaoyi:sourcecode_3:0.4.2 +[info] | | | | +-org.scala-lang:scala3-library_3:3.3.1 (evicted by: 3.4.2) +[info] | | | | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | | | | +[info] | | | +-org.scala-lang:scala3-library_3:3.3.1 (evicted by: 3.4.2) +[info] | | | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | | | +[info] | | +-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) +[info] | | | #-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) (cycle) +[info] | | | +[info] | | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | | +[info] | +-org.typelevel:paiges-core_3:0.4.4 +[info] | +-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) +[info] | | #-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) (cycle) +[info] | | +[info] | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | +[info] +-org.scalameta:mtags-java_3:1.3.6-SNAPSHOT +[info] | +-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) +[info] | | #-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) (cycle) +[info] | | +[info] | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | +-org.scalameta:mtags-interfaces:1.3.6-SNAPSHOT +[info] | | +-org.eclipse.lsp4j:org.eclipse.lsp4j:0.23.1 +[info] | | +-org.eclipse.lsp4j:org.eclipse.lsp4j.jsonrpc:0.23.1 +[info] | | +-com.google.code.gson:gson:2.11.0 +[info] | | | +-com.google.errorprone:error_prone_annotations:2.27.0 +[info] | | | +[info] | | +-com.google.code.gson:gson:[2.9.1,3.0) (evicted by: 2.11.0) +[info] | | +[info] | +-org.scalameta:mtags-shared_3.3.3:1.3.6-SNAPSHOT +[info] | +-com.google.guava:guava:33.2.1-jre +[info] | | +-com.google.code.findbugs:jsr305:3.0.2 +[info] | | +-com.google.errorprone:error_prone_annotations:2.26.1 (evicted by: 2... +[info] | | +-com.google.errorprone:error_prone_annotations:2.27.0 +[info] | | +-com.google.guava:failureaccess:1.0.2 +[info] | | +-com.google.guava:listenablefuture:9999.0-empty-to-avoid-conflict-wit.. +[info] | | +-com.google.j2objc:j2objc-annotations:3.0.0 +[info] | | +-org.checkerframework:checker-qual:3.42.0 +[info] | | +[info] | +-com.google.protobuf:protobuf-java:4.27.3 +[info] | +-io.get-coursier:interface:1.0.19 +[info] | | +-org.slf4j:slf4j-api:1.7.36 (evicted by: 2.0.13) +[info] | | +-org.slf4j:slf4j-api:2.0.13 +[info] | | +[info] | +-org.lz4:lz4-java:1.8.0 +[info] | +-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) +[info] | | #-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) (cycle) +[info] | | +[info] | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | +-org.scalameta:mtags-interfaces:1.3.6-SNAPSHOT +[info] | +-org.eclipse.lsp4j:org.eclipse.lsp4j:0.23.1 +[info] | +-org.eclipse.lsp4j:org.eclipse.lsp4j.jsonrpc:0.23.1 +[info] | +-com.google.code.gson:gson:2.11.0 +[info] | | +-com.google.errorprone:error_prone_annotations:2.27.0 +[info] | | +[info] | +-com.google.code.gson:gson:[2.9.1,3.0) (evicted by: 2.11.0) +[info] | +[info] +-org.scalameta:mtags_3.3.3:1.3.6-SNAPSHOT +[info] | +-com.lihaoyi:geny_3:1.0.0 (evicted by: 1.1.1) +[info] | +-com.lihaoyi:geny_3:1.1.1 +[info] | | +-org.scala-lang:scala3-library_3:3.3.1 (evicted by: 3.4.2) +[info] | | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | | +[info] | +-com.lihaoyi:pprint_3:0.7.3 +[info] | | +-com.lihaoyi:fansi_3:0.3.1 (evicted by: 0.5.0) +[info] | | +-com.lihaoyi:fansi_3:0.5.0 +[info] | | | +-com.lihaoyi:sourcecode_3:0.4.0 (evicted by: 0.4.2) +[info] | | | +-com.lihaoyi:sourcecode_3:0.4.2 +[info] | | | | +-org.scala-lang:scala3-library_3:3.3.1 (evicted by: 3.4.2) +[info] | | | | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | | | | +[info] | | | +-org.scala-lang:scala3-library_3:3.3.1 (evicted by: 3.4.2) +[info] | | | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | | | +[info] | | +-com.lihaoyi:sourcecode_3:0.2.8 (evicted by: 0.4.2) +[info] | | +-com.lihaoyi:sourcecode_3:0.4.2 +[info] | | | +-org.scala-lang:scala3-library_3:3.3.1 (evicted by: 3.4.2) +[info] | | | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | | | +[info] | | +-org.scala-lang:scala3-library_3:3.0.2 (evicted by: 3.4.2) +[info] | | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | | +[info] | +-com.thoughtworks.qdox:qdox:2.1.0 +[info] | +-io.get-coursier:interface:1.0.19 +[info] | | +-org.slf4j:slf4j-api:1.7.36 (evicted by: 2.0.13) +[info] | | +-org.slf4j:slf4j-api:2.0.13 +[info] | | +[info] | +-org.jsoup:jsoup:1.18.1 +[info] | +-org.lz4:lz4-java:1.8.0 +[info] | +-org.scala-lang.modules:scala-java8-compat_3:1.0.2 +[info] | | +-org.scala-lang:scala3-library_3:3.0.2 (evicted by: 3.4.2) +[info] | | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | | +[info] | +-org.scala-lang:scala3-compiler_3:3.3.3 +[info] | | +-org.jline:jline-reader:3.19.0 +[info] | | | +-org.jline:jline-terminal:3.19.0 +[info] | | | +[info] | | +-org.jline:jline-terminal-jna:3.19.0 +[info] | | | +-net.java.dev.jna:jna:5.12.0 +[info] | | | +-net.java.dev.jna:jna:5.3.1 (evicted by: 5.12.0) +[info] | | | +-org.jline:jline-terminal:3.19.0 +[info] | | | +[info] | | +-org.jline:jline-terminal:3.19.0 +[info] | | +-org.scala-lang.modules:scala-asm:9.5.0-scala-1 +[info] | | +-org.scala-lang:scala3-interfaces:3.3.3 +[info] | | +-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) +[info] | | | #-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) (cycle) +[info] | | | +[info] | | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | | +-org.scala-lang:tasty-core_3:3.3.3 +[info] | | | +-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) +[info] | | | | #-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) (cyc.. +[info] | | | | +[info] | | | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | | | +[info] | | +-org.scala-sbt:compiler-interface:1.9.3 +[info] | | +-org.scala-sbt:util-interface:1.9.2 +[info] | | +[info] | +-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) +[info] | | #-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) (cycle) +[info] | | +[info] | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | +-org.scalameta:mtags-shared_3.3.3:1.3.6-SNAPSHOT +[info] | | +-com.google.guava:guava:33.2.1-jre +[info] | | | +-com.google.code.findbugs:jsr305:3.0.2 +[info] | | | +-com.google.errorprone:error_prone_annotations:2.26.1 (evicted by: 2... +[info] | | | +-com.google.errorprone:error_prone_annotations:2.27.0 +[info] | | | +-com.google.guava:failureaccess:1.0.2 +[info] | | | +-com.google.guava:listenablefuture:9999.0-empty-to-avoid-conflict-wit.. +[info] | | | +-com.google.j2objc:j2objc-annotations:3.0.0 +[info] | | | +-org.checkerframework:checker-qual:3.42.0 +[info] | | | +[info] | | +-com.google.protobuf:protobuf-java:4.27.3 +[info] | | +-io.get-coursier:interface:1.0.19 +[info] | | | +-org.slf4j:slf4j-api:1.7.36 (evicted by: 2.0.13) +[info] | | | +-org.slf4j:slf4j-api:2.0.13 +[info] | | | +[info] | | +-org.lz4:lz4-java:1.8.0 +[info] | | +-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) +[info] | | | #-org.scala-lang:scala3-library_3:3.3.3 [S] (evicted by: 3.4.2) (cycle) +[info] | | | +[info] | | +-org.scala-lang:scala3-library_3:3.4.2 [S] +[info] | | +-org.scalameta:mtags-interfaces:1.3.6-SNAPSHOT +[info] | | +-org.eclipse.lsp4j:org.eclipse.lsp4j:0.23.1 +[info] | | +-org.eclipse.lsp4j:org.eclipse.lsp4j.jsonrpc:0.23.1 +[info] | | +-com.google.code.gson:gson:2.11.0 +[info] | | | +-com.google.errorprone:error_prone_annotations:2.27.0 +[info] | | | +[info] | | +-com.google.code.gson:gson:[2.9.1,3.0) (evicted by: 2.11.0) +[info] | | +[info] | +-org.scalameta:scalameta_2.13:4.9.9 +[info] | | +-org.scala-lang:scalap:2.13.11 +[info] | | +-org.scalameta:parsers_2.13:4.9.9 [S] +[info] | | +-org.scalameta:trees_2.13:4.9.9 [S] +[info] | | +-org.scalameta:common_2.13:4.9.9 [S] +[info] | | +-com.lihaoyi:sourcecode_2.13:0.4.2 [S] +[info] | | +[info] | +-org.scalameta:semanticdb-shared_2.13.14:4.9.9 +[info] | +-com.thesamet.scalapb:scalapb-runtime_2.13:0.11.17 +[info] | | +-com.google.protobuf:protobuf-java:3.19.6 (evicted by: 4.27.3) +[info] | | +-com.google.protobuf:protobuf-java:4.27.3 +[info] | | +-com.thesamet.scalapb:lenses_2.13:0.11.17 +[info] | | +[info] | +-org.scalameta:scalameta_2.13:4.9.9 +[info] | +-org.scala-lang:scalap:2.13.11 +[info] | +-org.scalameta:parsers_2.13:4.9.9 [S] +[info] | +-org.scalameta:trees_2.13:4.9.9 [S] +[info] | +-org.scalameta:common_2.13:4.9.9 [S] +[info] | +-com.lihaoyi:sourcecode_2.13:0.4.2 [S] +[info] | +[info] +-org.scalameta:scalafmt-dynamic_2.13:3.7.15 [S] +[info] | +-com.typesafe:config:1.4.2 +[info] | +-io.get-coursier:interface:0.0.17 (evicted by: 1.0.19) +[info] | +-io.get-coursier:interface:1.0.19 +[info] | | +-org.slf4j:slf4j-api:1.7.36 (evicted by: 2.0.13) +[info] | | +-org.slf4j:slf4j-api:2.0.13 +[info] | | +[info] | +-org.scalameta:scalafmt-interfaces:3.7.15 +[info] | +[info] +-org.scalameta:scalameta_2.13:4.9.9 +[info] | +-org.scala-lang:scalap:2.13.11 +[info] | +-org.scalameta:parsers_2.13:4.9.9 [S] +[info] | +-org.scalameta:trees_2.13:4.9.9 [S] +[info] | +-org.scalameta:common_2.13:4.9.9 [S] +[info] | +-com.lihaoyi:sourcecode_2.13:0.4.2 [S] +[info] | +[info] +-org.scalameta:semanticdb-metap_2.13.14:4.9.9 +[info] | +-org.scalameta:semanticdb-shared_2.13.14:4.9.9 +[info] | +-com.thesamet.scalapb:scalapb-runtime_2.13:0.11.17 +[info] | | +-com.google.protobuf:protobuf-java:3.19.6 (evicted by: 4.27.3) +[info] | | +-com.google.protobuf:protobuf-java:4.27.3 +[info] | | +-com.thesamet.scalapb:lenses_2.13:0.11.17 +[info] | | +[info] | +-org.scalameta:scalameta_2.13:4.9.9 +[info] | +-org.scala-lang:scalap:2.13.11 +[info] | +-org.scalameta:parsers_2.13:4.9.9 [S] +[info] | +-org.scalameta:trees_2.13:4.9.9 [S] +[info] | +-org.scalameta:common_2.13:4.9.9 [S] +[info] | +-com.lihaoyi:sourcecode_2.13:0.4.2 [S] +[info] | +[info] +-org.scalameta:semanticdb-shared_2.13.14:4.9.9 +[info] | +-com.thesamet.scalapb:scalapb-runtime_2.13:0.11.17 +[info] | | +-com.google.protobuf:protobuf-java:3.19.6 (evicted by: 4.27.3) +[info] | | +-com.google.protobuf:protobuf-java:4.27.3 +[info] | | +-com.thesamet.scalapb:lenses_2.13:0.11.17 +[info] | | +[info] | +-org.scalameta:scalameta_2.13:4.9.9 +[info] | +-org.scala-lang:scalap:2.13.11 +[info] | +-org.scalameta:parsers_2.13:4.9.9 [S] +[info] | +-org.scalameta:trees_2.13:4.9.9 [S] +[info] | +-org.scalameta:common_2.13:4.9.9 [S] +[info] | +-com.lihaoyi:sourcecode_2.13:0.4.2 [S] +[info] | +[info] +-org.virtuslab.scala-cli:scala-cli-bsp:1.4.3 +[info] +[success] Total time: 1 s, completed Aug 16, 2024, 6:21:36 PM diff --git a/metals-bench/src/main/scala/bench/MetalsBench.scala b/metals-bench/src/main/scala/bench/MetalsBench.scala index abdd2321ff6..d1e038739a8 100644 --- a/metals-bench/src/main/scala/bench/MetalsBench.scala +++ b/metals-bench/src/main/scala/bench/MetalsBench.scala @@ -1,11 +1,6 @@ package bench -import scala.reflect.internal.util.BatchSourceFile -import scala.reflect.io.VirtualFile -import scala.tools.nsc.interactive.Global - import scala.meta.dialects -import scala.meta.interactive.InteractiveSemanticdb import scala.meta.internal.metals.EmptyReportContext import scala.meta.internal.metals.IdentifierIndex import scala.meta.internal.metals.JdkSources @@ -23,7 +18,6 @@ import scala.meta.internal.mtags.SemanticdbClasspath import scala.meta.internal.parsing.Trees import scala.meta.internal.semanticdb.TextDocument import scala.meta.internal.tokenizers.LegacyScanner -import scala.meta.internal.tokenizers.LegacyToken import scala.meta.io.AbsolutePath import scala.meta.io.Classpath @@ -129,22 +123,6 @@ class MetalsBench { } } - @Benchmark - @BenchmarkMode(Array(Mode.SingleShotTime)) - def scalacTokenize(): Unit = { - val g = global - scalaDependencySources.foreach { input => - val unit = new g.CompilationUnit( - new BatchSourceFile(new VirtualFile(input.path), input.chars) - ) - val scanner = g.newUnitScanner(unit) - scanner.init() - while (scanner.token != LegacyToken.EOF) { - scanner.nextToken() - } - } - } - @Benchmark @BenchmarkMode(Array(Mode.SingleShotTime)) def scalametaParse(): Unit = { @@ -154,27 +132,6 @@ class MetalsBench { } } - lazy val global: Global = InteractiveSemanticdb.newCompiler() - - @Benchmark - @BenchmarkMode(Array(Mode.SingleShotTime)) - def scalacParse(): Unit = { - val g = global - scalaDependencySources.foreach { input => - val unit = new g.CompilationUnit( - new BatchSourceFile(new VirtualFile(input.path), input.chars) - ) - val tree = g.newUnitParser(unit).parse() - var i = 0 - new g.Traverser { - override def apply[T <: g.Tree](tree: T): T = { - i += 1 - super.apply(tree) - } - }.traverse(tree) - } - } - @Benchmark @BenchmarkMode(Array(Mode.SingleShotTime)) def mtagsJavaParse(): Unit = { diff --git a/metals/src/main/scala/scala/meta/internal/bsp/BspConfigGenerator.scala b/metals/src/main/scala/scala/meta/internal/bsp/BspConfigGenerator.scala index b4f98558b78..1a8c9bae03b 100644 --- a/metals/src/main/scala/scala/meta/internal/bsp/BspConfigGenerator.scala +++ b/metals/src/main/scala/scala/meta/internal/bsp/BspConfigGenerator.scala @@ -12,9 +12,9 @@ import scala.meta.internal.builds.BuildServerProvider import scala.meta.internal.builds.ShellRunner import scala.meta.internal.metals.Directories import scala.meta.internal.metals.Messages.BspProvider -import scala.meta.internal.metals.MetalsEnrichments._ -import scala.meta.internal.metals.StatusBar import scala.meta.internal.metals.UserConfiguration +import scala.meta.internal.metals.StatusBar +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.clients.language.MetalsLanguageClient import scala.meta.io.AbsolutePath diff --git a/metals/src/main/scala/scala/meta/internal/bsp/BspConnector.scala b/metals/src/main/scala/scala/meta/internal/bsp/BspConnector.scala index bdd3c70dbf5..f994b92f565 100644 --- a/metals/src/main/scala/scala/meta/internal/bsp/BspConnector.scala +++ b/metals/src/main/scala/scala/meta/internal/bsp/BspConnector.scala @@ -18,8 +18,8 @@ import scala.meta.internal.metals.CreateSession import scala.meta.internal.metals.GenerateBspConfigAndConnect import scala.meta.internal.metals.Messages import scala.meta.internal.metals.Messages.BspSwitch -import scala.meta.internal.metals.MetalsEnrichments._ import scala.meta.internal.metals.SlowConnect +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.StatusBar import scala.meta.internal.metals.Tables import scala.meta.internal.metals.UserConfiguration @@ -192,7 +192,7 @@ class BspConnector( None, ) for { - Some(item) <- client + case Some(item) <- client .showMessageRequest(query.params) .asScala .map(item => diff --git a/metals/src/main/scala/scala/meta/internal/builds/BloopInstall.scala b/metals/src/main/scala/scala/meta/internal/builds/BloopInstall.scala index 44fed0a0699..e0a16b0dfac 100644 --- a/metals/src/main/scala/scala/meta/internal/builds/BloopInstall.scala +++ b/metals/src/main/scala/scala/meta/internal/builds/BloopInstall.scala @@ -10,7 +10,7 @@ import scala.meta.internal.builds.Digest.Status import scala.meta.internal.metals.BuildInfo import scala.meta.internal.metals.Confirmation import scala.meta.internal.metals.Messages._ -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.Tables import scala.meta.internal.metals.UserConfiguration import scala.meta.internal.metals.clients.language.MetalsLanguageClient diff --git a/metals/src/main/scala/scala/meta/internal/builds/BspOnly.scala b/metals/src/main/scala/scala/meta/internal/builds/BspOnly.scala index 0afb015a63d..7a624bc0e90 100644 --- a/metals/src/main/scala/scala/meta/internal/builds/BspOnly.scala +++ b/metals/src/main/scala/scala/meta/internal/builds/BspOnly.scala @@ -2,7 +2,6 @@ package scala.meta.internal.builds import java.security.MessageDigest -import scala.meta.internal.builds.Digest import scala.meta.internal.mtags.MD5 import scala.meta.io.AbsolutePath diff --git a/metals/src/main/scala/scala/meta/internal/builds/BuildToolSelector.scala b/metals/src/main/scala/scala/meta/internal/builds/BuildToolSelector.scala index 7e5972614b0..669d52df777 100644 --- a/metals/src/main/scala/scala/meta/internal/builds/BuildToolSelector.scala +++ b/metals/src/main/scala/scala/meta/internal/builds/BuildToolSelector.scala @@ -5,7 +5,7 @@ import scala.concurrent.Future import scala.meta.internal.metals.Messages import scala.meta.internal.metals.Messages.ChooseBuildTool -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.Tables import scala.meta.internal.metals.clients.language.MetalsLanguageClient diff --git a/metals/src/main/scala/scala/meta/internal/builds/BuildTools.scala b/metals/src/main/scala/scala/meta/internal/builds/BuildTools.scala index cd8a1891be5..8e6f4591241 100644 --- a/metals/src/main/scala/scala/meta/internal/builds/BuildTools.scala +++ b/metals/src/main/scala/scala/meta/internal/builds/BuildTools.scala @@ -11,7 +11,7 @@ import scala.meta.internal.bsp.ScalaCliBspScope import scala.meta.internal.io.PathIO import scala.meta.internal.metals.BloopServers import scala.meta.internal.metals.Directories -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.UserConfiguration import scala.meta.internal.metals.scalacli.ScalaCli import scala.meta.io.AbsolutePath diff --git a/metals/src/main/scala/scala/meta/internal/builds/Digest.scala b/metals/src/main/scala/scala/meta/internal/builds/Digest.scala index e97b1584161..43af138e6dd 100644 --- a/metals/src/main/scala/scala/meta/internal/builds/Digest.scala +++ b/metals/src/main/scala/scala/meta/internal/builds/Digest.scala @@ -14,7 +14,7 @@ import scala.meta.XtensionDialectApply import scala.meta.XtensionTokenizeDialectInput import scala.meta.internal.builds.Digest.Status import scala.meta.internal.io.PathIO -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.mtags.MD5 import scala.meta.internal.parsing.Trees import scala.meta.io.AbsolutePath @@ -185,7 +185,7 @@ object Digest { ): Boolean = { try { val input = file.toInput - val tokens = Trees.defaultTokenizerDialect(input).tokenize.get + val tokens = Trees.defaultTokenizerDialect.apply(input).tokenize.get tokens.foreach { case token if token.isWhiteSpaceOrComment => // Do nothing case token => diff --git a/metals/src/main/scala/scala/meta/internal/builds/GradleDigest.scala b/metals/src/main/scala/scala/meta/internal/builds/GradleDigest.scala index b66999bb77e..bb90d9195b6 100644 --- a/metals/src/main/scala/scala/meta/internal/builds/GradleDigest.scala +++ b/metals/src/main/scala/scala/meta/internal/builds/GradleDigest.scala @@ -2,7 +2,7 @@ package scala.meta.internal.builds import java.security.MessageDigest -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.io.AbsolutePath object GradleDigest extends Digestable { diff --git a/metals/src/main/scala/scala/meta/internal/builds/MavenBuildTool.scala b/metals/src/main/scala/scala/meta/internal/builds/MavenBuildTool.scala index ba655d9f601..b7ba2bb37f9 100644 --- a/metals/src/main/scala/scala/meta/internal/builds/MavenBuildTool.scala +++ b/metals/src/main/scala/scala/meta/internal/builds/MavenBuildTool.scala @@ -2,7 +2,7 @@ package scala.meta.internal.builds import scala.meta.internal.metals.BuildInfo import scala.meta.internal.metals.JavaBinary -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.UserConfiguration import scala.meta.io.AbsolutePath diff --git a/metals/src/main/scala/scala/meta/internal/builds/MavenDigest.scala b/metals/src/main/scala/scala/meta/internal/builds/MavenDigest.scala index 513bcad9dae..c1515028e7d 100644 --- a/metals/src/main/scala/scala/meta/internal/builds/MavenDigest.scala +++ b/metals/src/main/scala/scala/meta/internal/builds/MavenDigest.scala @@ -2,7 +2,7 @@ package scala.meta.internal.builds import java.security.MessageDigest -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.io.AbsolutePath object MavenDigest extends Digestable { diff --git a/metals/src/main/scala/scala/meta/internal/builds/NewProjectProvider.scala b/metals/src/main/scala/scala/meta/internal/builds/NewProjectProvider.scala index ad0dcb6fdbe..1628e4387b6 100644 --- a/metals/src/main/scala/scala/meta/internal/builds/NewProjectProvider.scala +++ b/metals/src/main/scala/scala/meta/internal/builds/NewProjectProvider.scala @@ -12,7 +12,7 @@ import scala.meta.internal.metals.ClientCommands import scala.meta.internal.metals.ClientConfiguration import scala.meta.internal.metals.Icons import scala.meta.internal.metals.Messages._ -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.WorkDoneProgress import scala.meta.internal.metals.clients.language.MetalsInputBoxParams import scala.meta.internal.metals.clients.language.MetalsLanguageClient diff --git a/metals/src/main/scala/scala/meta/internal/builds/SbtBuildTool.scala b/metals/src/main/scala/scala/meta/internal/builds/SbtBuildTool.scala index 162ed3a7b0b..04f861f5645 100644 --- a/metals/src/main/scala/scala/meta/internal/builds/SbtBuildTool.scala +++ b/metals/src/main/scala/scala/meta/internal/builds/SbtBuildTool.scala @@ -11,7 +11,7 @@ import scala.concurrent.Future import scala.concurrent.Promise import scala.meta.inputs.Input -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals._ import scala.meta.internal.semver.SemVer import scala.meta.internal.semver.SemVer.isCompatibleVersion @@ -307,7 +307,7 @@ object SbtBuildTool { writtenPlugin || writtenMeta } - private case class PluginDetails( + case class PluginDetails( description: Seq[String], artifact: String, resolver: Option[String], diff --git a/metals/src/main/scala/scala/meta/internal/builds/SbtDigest.scala b/metals/src/main/scala/scala/meta/internal/builds/SbtDigest.scala index f129711ab95..5ab7089841f 100644 --- a/metals/src/main/scala/scala/meta/internal/builds/SbtDigest.scala +++ b/metals/src/main/scala/scala/meta/internal/builds/SbtDigest.scala @@ -3,7 +3,7 @@ package scala.meta.internal.builds import java.security.MessageDigest import scala.meta.internal.builds.Digest.digestScala -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.io.AbsolutePath object SbtDigest extends Digestable { diff --git a/metals/src/main/scala/scala/meta/internal/builds/ShellRunner.scala b/metals/src/main/scala/scala/meta/internal/builds/ShellRunner.scala index 2e180f42d08..39c774f1086 100644 --- a/metals/src/main/scala/scala/meta/internal/builds/ShellRunner.scala +++ b/metals/src/main/scala/scala/meta/internal/builds/ShellRunner.scala @@ -13,7 +13,7 @@ import scala.util.Properties import scala.meta.internal.metals.Cancelable import scala.meta.internal.metals.JavaBinary import scala.meta.internal.metals.JdkSources -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.MutableCancelable import scala.meta.internal.metals.Time import scala.meta.internal.metals.Timer diff --git a/metals/src/main/scala/scala/meta/internal/builds/WorkspaceReload.scala b/metals/src/main/scala/scala/meta/internal/builds/WorkspaceReload.scala index c2b8338838a..b85d0ea3475 100644 --- a/metals/src/main/scala/scala/meta/internal/builds/WorkspaceReload.scala +++ b/metals/src/main/scala/scala/meta/internal/builds/WorkspaceReload.scala @@ -7,7 +7,7 @@ import scala.meta.internal.builds.Digest.Status import scala.meta.internal.metals.Confirmation import scala.meta.internal.metals.Messages.ImportBuildChanges import scala.meta.internal.metals.Messages.dontShowAgain -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.Tables import scala.meta.internal.metals.clients.language.MetalsLanguageClient import scala.meta.io.AbsolutePath diff --git a/metals/src/main/scala/scala/meta/internal/implementation/ImplementationProvider.scala b/metals/src/main/scala/scala/meta/internal/implementation/ImplementationProvider.scala index 7174d333902..e864478e8fa 100644 --- a/metals/src/main/scala/scala/meta/internal/implementation/ImplementationProvider.scala +++ b/metals/src/main/scala/scala/meta/internal/implementation/ImplementationProvider.scala @@ -14,8 +14,8 @@ import scala.meta.internal.metals.Buffers import scala.meta.internal.metals.BuildTargets import scala.meta.internal.metals.Compilers import scala.meta.internal.metals.DefinitionProvider -import scala.meta.internal.metals.MetalsEnrichments._ import scala.meta.internal.metals.Report +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.ReportContext import scala.meta.internal.metals.ScalaVersionSelector import scala.meta.internal.metals.ScalaVersions diff --git a/metals/src/main/scala/scala/meta/internal/implementation/Supermethods.scala b/metals/src/main/scala/scala/meta/internal/implementation/Supermethods.scala index 2bef1344c08..2f2b9538508 100644 --- a/metals/src/main/scala/scala/meta/internal/implementation/Supermethods.scala +++ b/metals/src/main/scala/scala/meta/internal/implementation/Supermethods.scala @@ -6,7 +6,7 @@ import scala.concurrent.Future import scala.meta.internal.implementation.Supermethods.formatMethodSymbolForQuickPick import scala.meta.internal.metals.ClientCommands import scala.meta.internal.metals.DefinitionProvider -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.ReportContext import scala.meta.internal.metals.clients.language.MetalsLanguageClient import scala.meta.internal.metals.clients.language.MetalsQuickPickItem @@ -81,6 +81,7 @@ class Supermethods( filePath, textDocument, ) + // TODO fallback to compilers symbolInformation <- findSymbol(symbolOcc.symbol) gotoSymbol <- { if (symbolOcc.role.isDefinition) { diff --git a/metals/src/main/scala/scala/meta/internal/metals/ActiveFiles.scala b/metals/src/main/scala/scala/meta/internal/metals/ActiveFiles.scala index e588e0e8302..459fd40dedc 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/ActiveFiles.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/ActiveFiles.scala @@ -2,7 +2,7 @@ package scala.meta.internal.metals import java.util.concurrent.ConcurrentLinkedQueue -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.io.AbsolutePath /** diff --git a/metals/src/main/scala/scala/meta/internal/metals/AdjustLspData.scala b/metals/src/main/scala/scala/meta/internal/metals/AdjustLspData.scala index 1470ccfa8d1..2d1d8dd0d78 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/AdjustLspData.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/AdjustLspData.scala @@ -2,8 +2,8 @@ package scala.meta.internal.metals import java.{util => ju} -import scala.meta.internal.metals.MetalsEnrichments._ import scala.meta.pc +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.pc.AutoImportsResult import scala.meta.pc.HoverSignature @@ -76,8 +76,7 @@ trait AdjustLspData { ): ju.List[Location] def adjustHoverResp(hover: Hover): Hover = - if (hover.getRange == null) - hover + if (hover.getRange == null) hover else { val newRange = adjustRange(hover.getRange) val newHover = new Hover diff --git a/metals/src/main/scala/scala/meta/internal/metals/BatchedFunction.scala b/metals/src/main/scala/scala/meta/internal/metals/BatchedFunction.scala index 3070cccbf25..8ba060bd332 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/BatchedFunction.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/BatchedFunction.scala @@ -182,7 +182,7 @@ object BatchedFunction { ec: ExecutionContext ): BatchedFunction[A, B] = new BatchedFunction( - fn.andThen(CancelableFuture(_)), + fn.andThen(CancelableFuture(_, Cancelable.empty)), functionId, shouldLogQueue, default, diff --git a/metals/src/main/scala/scala/meta/internal/metals/BloopServers.scala b/metals/src/main/scala/scala/meta/internal/metals/BloopServers.scala index 9cff74bc70f..66f3079d10d 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/BloopServers.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/BloopServers.scala @@ -27,7 +27,7 @@ import scala.meta.internal.bsp.BuildChange import scala.meta.internal.bsp.ConnectionBspStatus import scala.meta.internal.builds.ShellRunner import scala.meta.internal.metals.Messages.OldBloopVersionRunning -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.clients.language.MetalsLanguageClient import scala.meta.io.AbsolutePath @@ -59,6 +59,16 @@ final class BloopServers( sh: ScheduledExecutorService, )(implicit ec: ExecutionContextExecutorService) { + class BloopOutputStream extends OutputStream { + private lazy val b = new StringBuilder + + override def write(byte: Int): Unit = byte.toChar match { + case c => b.append(c) + } + + def logs = b.result.linesIterator + } + import BloopServers._ private def metalsJavaHome = sys.props.get("java.home") diff --git a/metals/src/main/scala/scala/meta/internal/metals/Buffers.scala b/metals/src/main/scala/scala/meta/internal/metals/Buffers.scala index 4ac56b33a5f..0f8ad5e8ed8 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/Buffers.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/Buffers.scala @@ -3,7 +3,7 @@ package scala.meta.internal.metals import scala.collection.concurrent.TrieMap import scala.meta.inputs.Input -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.parsing.TokenEditDistance import scala.meta.internal.parsing.Trees import scala.meta.io.AbsolutePath diff --git a/metals/src/main/scala/scala/meta/internal/metals/BuildServerConnection.scala b/metals/src/main/scala/scala/meta/internal/metals/BuildServerConnection.scala index 578a8140208..8e37e87ce70 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/BuildServerConnection.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/BuildServerConnection.scala @@ -26,7 +26,7 @@ import scala.meta.internal.bsp.ConnectionBspStatus import scala.meta.internal.builds.BazelBuildTool import scala.meta.internal.builds.MillBuildTool import scala.meta.internal.builds.SbtBuildTool -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.ammonite.Ammonite import scala.meta.internal.metals.clients.language.MetalsLanguageClient import scala.meta.internal.metals.scalacli.ScalaCli diff --git a/metals/src/main/scala/scala/meta/internal/metals/BuildTargetInfo.scala b/metals/src/main/scala/scala/meta/internal/metals/BuildTargetInfo.scala index 24ba74763c1..f466a17638e 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/BuildTargetInfo.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/BuildTargetInfo.scala @@ -2,7 +2,7 @@ package scala.meta.internal.metals import scala.collection.mutable.ListBuffer -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.mtags.URIEncoderDecoder import scala.meta.io.AbsolutePath diff --git a/metals/src/main/scala/scala/meta/internal/metals/BuildTargets.scala b/metals/src/main/scala/scala/meta/internal/metals/BuildTargets.scala index 9226f663cff..0c3eb0f2267 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/BuildTargets.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/BuildTargets.scala @@ -13,7 +13,7 @@ import scala.concurrent.Promise import scala.util.control.NonFatal import scala.meta.internal.io.PathIO -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.mtags.Symbol import scala.meta.internal.semver.SemVer.Version import scala.meta.io.AbsolutePath diff --git a/metals/src/main/scala/scala/meta/internal/metals/CancelableFuture.scala b/metals/src/main/scala/scala/meta/internal/metals/CancelableFuture.scala index 984437b8f77..c108429f245 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/CancelableFuture.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/CancelableFuture.scala @@ -26,7 +26,7 @@ object CancelableFuture { CancelableFuture(Future(thunk), Cancelable.empty) } def successful[T](value: T): CancelableFuture[T] = - CancelableFuture(Future.successful(value)) + CancelableFuture(Future.successful(value), Cancelable.empty) def sequence[T]( futures: Seq[CancelableFuture[T]] )(implicit ec: ExecutionContext): CancelableFuture[Seq[T]] = diff --git a/metals/src/main/scala/scala/meta/internal/metals/ClientConfiguration.scala b/metals/src/main/scala/scala/meta/internal/metals/ClientConfiguration.scala index fa676c7262e..efb57a805f5 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/ClientConfiguration.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/ClientConfiguration.scala @@ -158,7 +158,7 @@ final class ClientConfiguration( for { capabilities <- clientCapabilities textDocumentCapabilities <- Option(capabilities.getTextDocument()) - inlayHintsCapabilities <- Option(textDocumentCapabilities.getInlayHint()) + _ <- Option(textDocumentCapabilities.getInlayHint()) } yield true }.getOrElse(false) diff --git a/metals/src/main/scala/scala/meta/internal/metals/Command.scala b/metals/src/main/scala/scala/meta/internal/metals/Command.scala index b7fc310e42b..5def4914db7 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/Command.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/Command.scala @@ -4,7 +4,7 @@ import scala.reflect.ClassTag import scala.util.matching.Regex import scala.meta.internal.metals.JsonParser._ -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import org.eclipse.{lsp4j => l} diff --git a/metals/src/main/scala/scala/meta/internal/metals/Compilations.scala b/metals/src/main/scala/scala/meta/internal/metals/Compilations.scala index 31134a6ccc1..7a8528d289e 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/Compilations.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/Compilations.scala @@ -11,7 +11,7 @@ import scala.util.Failure import scala.util.Success import scala.util.Try -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.clients.language.MetalsLanguageClient import scala.meta.internal.metals.debug.BuildTargetClasses import scala.meta.internal.metals.utils.Timeout @@ -108,6 +108,7 @@ final class Compilations( def compileFile(path: AbsolutePath): Future[b.CompileResult] = { def empty = new b.CompileResult(b.StatusCode.CANCELLED) + for { targetOpt <- expand(path) result <- targetOpt match { @@ -208,8 +209,7 @@ final class Compilations( } targetOpt - } else - Future.successful(None) + } else Future.successful(None) } def expand(paths: Seq[AbsolutePath]): Future[Seq[b.BuildTargetIdentifier]] = { diff --git a/metals/src/main/scala/scala/meta/internal/metals/CompilerPlugins.scala b/metals/src/main/scala/scala/meta/internal/metals/CompilerPlugins.scala index 908e8d42e80..4c25bc4136f 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/CompilerPlugins.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/CompilerPlugins.scala @@ -7,7 +7,7 @@ import scala.util.control.NonFatal import scala.xml.XML import scala.meta.internal.io.FileIO -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.io.AbsolutePath /** diff --git a/metals/src/main/scala/scala/meta/internal/metals/Compilers.scala b/metals/src/main/scala/scala/meta/internal/metals/Compilers.scala index dab4cbae11c..50438e12b92 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/Compilers.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/Compilers.scala @@ -17,10 +17,8 @@ import scala.meta.inputs.Input import scala.meta.inputs.Position import scala.meta.internal import scala.meta.internal.builds.SbtBuildTool -import scala.meta.internal.metals.CompilerOffsetParamsUtils -import scala.meta.internal.metals.CompilerRangeParamsUtils import scala.meta.internal.metals.Compilers.PresentationCompilerKey -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.mtags.MD5 import scala.meta.internal.parsing.Trees import scala.meta.internal.pc.LogMessages diff --git a/metals/src/main/scala/scala/meta/internal/metals/ConnectionProvider.scala b/metals/src/main/scala/scala/meta/internal/metals/ConnectionProvider.scala index 91debfe58dd..d145f9af8c6 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/ConnectionProvider.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/ConnectionProvider.scala @@ -240,7 +240,8 @@ class ConnectionProvider( case _ if !session.canReloadWorkspace => connect(CreateSession()) case _ => - session.workspaceReload + session + .workspaceReload() .flatMap(_ => connect(new ImportBuildAndIndex(session))) .map { _ => scribe.info("Correctly reloaded workspace") diff --git a/metals/src/main/scala/scala/meta/internal/metals/DefinitionProvider.scala b/metals/src/main/scala/scala/meta/internal/metals/DefinitionProvider.scala index a185aecd7ac..f4f17ac888a 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/DefinitionProvider.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/DefinitionProvider.scala @@ -7,7 +7,7 @@ import scala.concurrent.Future import scala.meta.inputs.Input import scala.meta.inputs.Position.Range -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.mtags.GlobalSymbolIndex import scala.meta.internal.mtags.Mtags import scala.meta.internal.mtags.Semanticdbs @@ -418,8 +418,7 @@ class DestinationProvider( allowedBuildTargets: Set[BuildTargetIdentifier], ): Option[SymbolDefinition] = { val definitions = index.definitions(Symbol(symbol)).filter(_.path.exists) - if (allowedBuildTargets.isEmpty) - definitions.headOption + if (allowedBuildTargets.isEmpty) definitions.headOption else { val matched = definitions.find { defn => sourceBuildTargets(defn.path).exists(id => diff --git a/metals/src/main/scala/scala/meta/internal/metals/Diagnostics.scala b/metals/src/main/scala/scala/meta/internal/metals/Diagnostics.scala index 5a1f0e1a12d..4c04dce04bd 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/Diagnostics.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/Diagnostics.scala @@ -9,9 +9,9 @@ import scala.collection.mutable import scala.util.Try import scala.meta.inputs.Input -import scala.meta.internal.metals.JsonParser._ -import scala.meta.internal.metals.MetalsEnrichments._ -import scala.meta.internal.metals.PositionSyntax._ +import scala.meta.internal.metals.MetalsEnrichments.given +import scala.meta.internal.metals.PositionSyntax.given +import scala.meta.internal.metals.JsonParser.given import scala.meta.internal.parsing.TokenEditDistance import scala.meta.internal.parsing.Trees import scala.meta.io.AbsolutePath diff --git a/metals/src/main/scala/scala/meta/internal/metals/Embedded.scala b/metals/src/main/scala/scala/meta/internal/metals/Embedded.scala index 4cf8f568ad8..5d98f2a6a5e 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/Embedded.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/Embedded.scala @@ -7,7 +7,7 @@ import java.util.ServiceLoader import scala.collection.concurrent.TrieMap import scala.util.Properties -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.pc.ScalaPresentationCompiler import scala.meta.internal.worksheets.MdocClassLoader import scala.meta.io.Classpath diff --git a/metals/src/main/scala/scala/meta/internal/metals/FallbackMetalsLspService.scala b/metals/src/main/scala/scala/meta/internal/metals/FallbackMetalsLspService.scala index b607f255433..f50ad66382a 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/FallbackMetalsLspService.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/FallbackMetalsLspService.scala @@ -69,7 +69,7 @@ class FallbackMetalsLspService( parseTrees :: compilations.pauseables ) - override protected val semanticdbs: Semanticdbs = interactiveSemanticdbs + override protected def semanticdbs(): Semanticdbs = interactiveSemanticdbs override val fileWatcher: FileWatcher = NoopFileWatcher override val projectInfo: MetalsServiceInfo = MetalsServiceInfo.FallbackService diff --git a/metals/src/main/scala/scala/meta/internal/metals/FileDecoderProvider.scala b/metals/src/main/scala/scala/meta/internal/metals/FileDecoderProvider.scala index c24501c421d..6c1ddb70fc1 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/FileDecoderProvider.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/FileDecoderProvider.scala @@ -461,8 +461,9 @@ final class FileDecoderProvider( .metalsQuickPick(quickPickParams) .asScala .mapOptionInside(_.itemId) - } else + } else { Future.successful(Some(classes.head.resourcePath)) + } private def findSemanticDbPathInfo( sourceFile: AbsolutePath diff --git a/metals/src/main/scala/scala/meta/internal/metals/FileSystemSemanticdbs.scala b/metals/src/main/scala/scala/meta/internal/metals/FileSystemSemanticdbs.scala index 4e799cb9fa8..2ea9c196b38 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/FileSystemSemanticdbs.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/FileSystemSemanticdbs.scala @@ -2,8 +2,8 @@ package scala.meta.internal.metals import java.nio.charset.Charset -import scala.meta.internal.metals.MetalsEnrichments._ import scala.meta.internal.metals.scalacli.ScalaCliServers +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.mtags.Md5Fingerprints import scala.meta.internal.mtags.SemanticdbClasspath import scala.meta.internal.mtags.Semanticdbs diff --git a/metals/src/main/scala/scala/meta/internal/metals/Fingerprints.scala b/metals/src/main/scala/scala/meta/internal/metals/Fingerprints.scala index 09d82a3be9c..e5808ace82e 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/Fingerprints.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/Fingerprints.scala @@ -4,7 +4,6 @@ import java.nio.file.Paths import java.sql.Connection import java.sql.PreparedStatement -import scala.meta.internal.metals.Fingerprint import scala.meta.internal.metals.JdbcEnrichments._ import scala.meta.io.AbsolutePath diff --git a/metals/src/main/scala/scala/meta/internal/metals/FormattingProvider.scala b/metals/src/main/scala/scala/meta/internal/metals/FormattingProvider.scala index 3f4bcdfd806..270c8c08960 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/FormattingProvider.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/FormattingProvider.scala @@ -24,7 +24,7 @@ import scala.meta.internal.io.FileIO import scala.meta.internal.metals.Messages.MissingScalafmtConf import scala.meta.internal.metals.Messages.MissingScalafmtVersion import scala.meta.internal.metals.Messages.UpdateScalafmtConf -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.clients.language.MetalsLanguageClient import scala.meta.internal.semver.SemVer import scala.meta.io.AbsolutePath @@ -190,7 +190,7 @@ final class FormattingProvider( private def askScalafmtVersion(): Future[Option[String]] = { if (!tables.dismissedNotifications.ChangeScalafmtVersion.isDismissed) { - if (clientConfig.isInputBoxEnabled) { + if (clientConfig.isInputBoxEnabled()) { client .metalsInputBox(MissingScalafmtVersion.inputBox()) .asScala diff --git a/metals/src/main/scala/scala/meta/internal/metals/ForwardingMetalsBuildClient.scala b/metals/src/main/scala/scala/meta/internal/metals/ForwardingMetalsBuildClient.scala index 7b96836f554..9809f45d5bc 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/ForwardingMetalsBuildClient.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/ForwardingMetalsBuildClient.scala @@ -15,7 +15,8 @@ import scala.meta.internal.metals.ClientConfiguration import scala.meta.internal.metals.ConcurrentHashSet import scala.meta.internal.metals.Diagnostics import scala.meta.internal.metals.MetalsBuildClient -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given +import scala.meta.internal.metals.MetalsEnrichments import scala.meta.internal.metals.StatusBar import scala.meta.internal.metals.TaskProgress import scala.meta.internal.metals.Time @@ -129,7 +130,8 @@ final class ForwardingMetalsBuildClient( def onBuildLogMessage(params: l.MessageParams): Unit = { // NOTE: BazelBsp adds coloring to the log message after `workspaceBuildTargets` request - val noANSICodes = filterANSIColorCodes(params.getMessage).trim() + val noANSICodes = + MetalsEnrichments.filterANSIColorCodes(params.getMessage).trim() if (noANSICodes.nonEmpty) { params.getType match { case l.MessageType.Error => diff --git a/metals/src/main/scala/scala/meta/internal/metals/ImportedBuild.scala b/metals/src/main/scala/scala/meta/internal/metals/ImportedBuild.scala index b08d7049ba3..971b7b3746b 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/ImportedBuild.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/ImportedBuild.scala @@ -7,7 +7,7 @@ import scala.build.bsp.WrappedSourcesResult import scala.concurrent.ExecutionContext import scala.concurrent.Future -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import ch.epfl.scala.bsp4j._ diff --git a/metals/src/main/scala/scala/meta/internal/metals/Indexer.scala b/metals/src/main/scala/scala/meta/internal/metals/Indexer.scala index d9d8dcfa93b..aee740bf9f3 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/Indexer.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/Indexer.scala @@ -18,7 +18,7 @@ import scala.meta.dialects._ import scala.meta.inputs.Input import scala.meta.internal.bsp.BspSession import scala.meta.internal.builds.WorkspaceReload -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.mtags.IndexingResult import scala.meta.internal.semanticdb.Scala._ import scala.meta.io.AbsolutePath diff --git a/metals/src/main/scala/scala/meta/internal/metals/InitializationOptions.scala b/metals/src/main/scala/scala/meta/internal/metals/InitializationOptions.scala index 3b6cea590d5..d414cf74b8c 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/InitializationOptions.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/InitializationOptions.scala @@ -228,7 +228,7 @@ object CommandHTMLFormat { // The lib used to convert markdown to html in sublime doesn't properly // recognize URL encoding so we have to use hexadecimal html encoding args.flatMap { - case char if toEscape.contains(char) => s"&#x${char.toHexString};" + case char if toEscape.contains(char) => s"&#x${char.toInt.toHexString};" case char => char.toString } } diff --git a/metals/src/main/scala/scala/meta/internal/metals/InteractiveSemanticdbs.scala b/metals/src/main/scala/scala/meta/internal/metals/InteractiveSemanticdbs.scala index 65b4c561500..128ac01212c 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/InteractiveSemanticdbs.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/InteractiveSemanticdbs.scala @@ -6,7 +6,7 @@ import java.util.Collections import scala.util.Success import scala.util.Try -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.scalacli.ScalaCliServers import scala.meta.internal.mtags.MD5 import scala.meta.internal.mtags.Semanticdbs diff --git a/metals/src/main/scala/scala/meta/internal/metals/JarTopLevels.scala b/metals/src/main/scala/scala/meta/internal/metals/JarTopLevels.scala index e09e59858f6..df8b522b3ac 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/JarTopLevels.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/JarTopLevels.scala @@ -12,7 +12,7 @@ import java.util.zip.ZipException import scala.meta.internal.io.PlatformFileIO import scala.meta.internal.metals.JarTopLevels.getFileSystem import scala.meta.internal.metals.JdbcEnrichments._ -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.mtags.MD5 import scala.meta.internal.mtags.OverriddenSymbol import scala.meta.internal.mtags.ResolvedOverriddenSymbol diff --git a/metals/src/main/scala/scala/meta/internal/metals/JavaFormattingProvider.scala b/metals/src/main/scala/scala/meta/internal/metals/JavaFormattingProvider.scala index a9231476f11..af572528ad5 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/JavaFormattingProvider.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/JavaFormattingProvider.scala @@ -10,7 +10,7 @@ import scala.util.Try import scala.xml.Node import scala.meta._ -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.io.AbsolutePath import scala.meta.{inputs => m} @@ -64,8 +64,7 @@ final class JavaFormattingProvider( else scribe.error(s"Java formatting profile ${profileName.get} not found") defaultSettings - } else - decodeProfile(profiles.head) + } else decodeProfile(profiles.head) } } diff --git a/metals/src/main/scala/scala/meta/internal/metals/JavaInteractiveSemanticdb.scala b/metals/src/main/scala/scala/meta/internal/metals/JavaInteractiveSemanticdb.scala index 80a84d2fa4e..7a86840c28c 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/JavaInteractiveSemanticdb.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/JavaInteractiveSemanticdb.scala @@ -13,7 +13,7 @@ import scala.util.Properties import scala.util.Try import scala.meta.internal.builds.ShellRunner -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.mtags.MD5 import scala.meta.internal.pc.JavaMetalsGlobal import scala.meta.internal.{semanticdb => s} diff --git a/metals/src/main/scala/scala/meta/internal/metals/JavaTarget.scala b/metals/src/main/scala/scala/meta/internal/metals/JavaTarget.scala index e77b149cb05..747dea1c87d 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/JavaTarget.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/JavaTarget.scala @@ -1,7 +1,7 @@ package scala.meta.internal.metals import scala.meta.internal.builds.MillBuildTool -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.semver.SemVer import scala.meta.io.AbsolutePath diff --git a/metals/src/main/scala/scala/meta/internal/metals/MetalsEnrichments.scala b/metals/src/main/scala/scala/meta/internal/metals/MetalsEnrichments.scala index 63e1a9914dd..c53ca3e4a10 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/MetalsEnrichments.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/MetalsEnrichments.scala @@ -68,7 +68,7 @@ import org.eclipse.{lsp4j => l} * One stop shop for all extension methods that are used in the metals build. * * Usage: {{{ - * import scala.meta.internal.metals.MetalsEnrichments._ + * import scala.meta.internal.metals.MetalsEnrichments.given * List(1).asJava * Future(1).asJava * // ... @@ -232,7 +232,7 @@ object MetalsEnrichments implicit class XtensionScalaFuture[A](future: Future[A]) { def asCancelable: CancelableFuture[A] = - CancelableFuture(future) + CancelableFuture(future, Cancelable.empty) def asJava: CompletableFuture[A] = FutureConverters.toJava(future).toCompletableFuture @@ -460,8 +460,7 @@ object MetalsEnrichments def toRelativeInside(prefix: AbsolutePath): Option[RelativePath] = { // windows throws an exception on toRelative when on different drives - if (path.toNIO.getRoot() != prefix.toNIO.getRoot()) - None + if (path.toNIO.getRoot() != prefix.toNIO.getRoot()) None else { val relative = path.toRelative(prefix) if (relative.toNIO.getName(0).filename != "..") Some(relative) @@ -789,16 +788,13 @@ object MetalsEnrichments def replaceAllBetween(start: String, end: String)( replacement: String ): String = - if (start.isEmpty || end.isEmpty) - value + if (start.isEmpty || end.isEmpty) value else { val startIdx = value.indexOf(start) - if (startIdx < 0) - value + if (startIdx < 0) value else { val endIdx = value.indexOf(end, startIdx + start.length) - if (endIdx < 0) - value + if (endIdx < 0) value else { val b = new java.lang.StringBuilder b.append(value, 0, startIdx) @@ -1349,8 +1345,8 @@ object MetalsEnrichments .toRight(cannotDecode(className)) case b.TestParamsDataKind.SCALA_TEST_SUITES => (for ( - tests <- decodeJson(params.getData(), classOf[util.List[String]]) - ) + tests <- decodeJson(params.getData(), classOf[util.List[String]]) + ) yield { val suites = tests.map(new b.ScalaTestSuiteSelection(_, Nil.asJava)) diff --git a/metals/src/main/scala/scala/meta/internal/metals/MetalsHttpServer.scala b/metals/src/main/scala/scala/meta/internal/metals/MetalsHttpServer.scala index 137820cc11b..99b8fd1a7c1 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/MetalsHttpServer.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/MetalsHttpServer.scala @@ -15,7 +15,7 @@ import scala.util.Success import scala.util.control.NonFatal import scala.meta.internal.io.InputStreamIO -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import io.undertow.Handlers.path import io.undertow.Handlers.websocket diff --git a/metals/src/main/scala/scala/meta/internal/metals/MetalsLspService.scala b/metals/src/main/scala/scala/meta/internal/metals/MetalsLspService.scala index dc3cbb0f0ac..dd19874f11c 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/MetalsLspService.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/MetalsLspService.scala @@ -26,8 +26,7 @@ import scala.meta.internal.builds.ShellRunner import scala.meta.internal.implementation.ImplementationProvider import scala.meta.internal.implementation.Supermethods import scala.meta.internal.io.FileIO -import scala.meta.internal.metals.MetalsEnrichments._ -import scala.meta.internal.metals.StdReportContext +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.callHierarchy.CallHierarchyProvider import scala.meta.internal.metals.clients.language.ConfiguredLanguageClient import scala.meta.internal.metals.clients.language.ForwardingMetalsBuildClient @@ -1186,7 +1185,7 @@ abstract class MetalsLspService( item: CompletionItem ): CompletableFuture[CompletionItem] = CancelTokens.future { _ => - if (clientConfig.isCompletionItemResolve) { + if (clientConfig.isCompletionItemResolve()) { compilers.completionItemResolve(item) } else { Future.successful(item) diff --git a/metals/src/main/scala/scala/meta/internal/metals/MetalsServerInputs.scala b/metals/src/main/scala/scala/meta/internal/metals/MetalsServerInputs.scala index 50adbbc106c..b35f887de93 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/MetalsServerInputs.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/MetalsServerInputs.scala @@ -4,13 +4,6 @@ import java.nio.charset.Charset import java.nio.charset.StandardCharsets import scala.meta.internal.bsp.BspServers -import scala.meta.internal.metals.Buffers -import scala.meta.internal.metals.ClasspathSearch -import scala.meta.internal.metals.MetalsServerConfig -import scala.meta.internal.metals.MtagsResolver -import scala.meta.internal.metals.ProgressTicks -import scala.meta.internal.metals.Time -import scala.meta.internal.metals.UserConfiguration import scala.meta.io.AbsolutePath /** diff --git a/metals/src/main/scala/scala/meta/internal/metals/MetalsSymbolSearch.scala b/metals/src/main/scala/scala/meta/internal/metals/MetalsSymbolSearch.scala index c62598657c8..b701993b12c 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/MetalsSymbolSearch.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/MetalsSymbolSearch.scala @@ -6,7 +6,7 @@ import java.{util => ju} import scala.collection.concurrent.TrieMap -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.mtags.Mtags import scala.meta.io.AbsolutePath import scala.meta.pc.ContentType diff --git a/metals/src/main/scala/scala/meta/internal/metals/MtagsResolver.scala b/metals/src/main/scala/scala/meta/internal/metals/MtagsResolver.scala index a234cc502ff..34d505b488b 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/MtagsResolver.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/MtagsResolver.scala @@ -8,7 +8,6 @@ import scala.concurrent.Future import scala.concurrent.duration._ import scala.util.control.NonFatal -import scala.meta.internal.metals.BuildInfo import scala.meta.internal.semver.SemVer trait MtagsResolver { @@ -198,7 +197,6 @@ object MtagsResolver { s"Failed to resolve Scala 3 presentation compiler for $scalaVersion" } scribe.error(errorMsg, fail.exception) - case _ => } state } diff --git a/metals/src/main/scala/scala/meta/internal/metals/PackageProvider.scala b/metals/src/main/scala/scala/meta/internal/metals/PackageProvider.scala index 7a5e0ede4f5..4301f1ca964 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/PackageProvider.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/PackageProvider.scala @@ -6,10 +6,10 @@ import scala.concurrent.Future import scala.{meta => m} import scala.meta._ -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.newScalaFile.NewFileTemplate +import scala.meta.internal.mtags.KeywordWrapper import scala.meta.internal.parsing.Trees -import scala.meta.internal.pc.Identifier import scala.meta.internal.semanticdb.Scala._ import scala.meta.internal.semanticdb.XtensionSemanticdbSymbolInformation import scala.meta.internal.{semanticdb => s} @@ -795,12 +795,14 @@ class PackageProvider( case _ => acc } tree match { - case Source(List(pk: Pkg)) => extractOuterPackage(pk).reverse + case Source(List(pk: Pkg)) => extractOuterPackage(pk).reverse() case _ => PackagesStructure.empty } } - private def wrap(str: String): String = Identifier.backtickWrap(str) + // TODO wrap with correct dialect + private def wrap(str: String): String = + KeywordWrapper.Scala2.backtickWrap(str) private def workspaceEdit( path: AbsolutePath, @@ -891,7 +893,10 @@ class PackageProvider( oldPath: AbsoluteFile, ): WorkspaceEdit = { val extend: (Int, Int) => (Int, Int) = - extendRangeToIncludeWhiteCharsAndTheFollowingNewLine(source, List(':')) + MetalsEnrichments.extendRangeToIncludeWhiteCharsAndTheFollowingNewLine( + source, + List(':'), + ) edits.flatMap { // delete package declaration case PackageEdit(pkg, Nil) => @@ -975,7 +980,7 @@ object PackageProvider { PackagesStructure(pkgs.reverse, pkgObject) def allPackagesParts(): List[List[String]] = pkgs.map(_.name) ++ pkgObject.map(obj => List(obj.name.value)).toList - def allParts(): List[String] = allPackagesParts.flatten + def allParts(): List[String] = allPackagesParts().flatten } object PackagesStructure { diff --git a/metals/src/main/scala/scala/meta/internal/metals/PopupChoiceReset.scala b/metals/src/main/scala/scala/meta/internal/metals/PopupChoiceReset.scala index 746e81205ce..a5641188008 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/PopupChoiceReset.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/PopupChoiceReset.scala @@ -4,7 +4,7 @@ import scala.concurrent.ExecutionContext import scala.concurrent.Future import scala.meta.internal.bsp.BuildChange -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.clients.language.MetalsLanguageClient import org.eclipse.lsp4j.MessageActionItem diff --git a/metals/src/main/scala/scala/meta/internal/metals/ProjectMetalsLspService.scala b/metals/src/main/scala/scala/meta/internal/metals/ProjectMetalsLspService.scala index 26fd22aa5ff..68c439e767a 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/ProjectMetalsLspService.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/ProjectMetalsLspService.scala @@ -136,7 +136,7 @@ class ProjectMetalsLspService( folder, buildTargets, statusBar, - clientConfig.icons, + clientConfig.icons(), buildTools, compilations.isCurrentlyCompiling, ) @@ -192,13 +192,15 @@ class ProjectMetalsLspService( compilations.pauseables ) - protected val semanticdbs: Semanticdbs = AggregateSemanticdbs( + private val agregateSemanticdbs: AggregateSemanticdbs = AggregateSemanticdbs( List( fileSystemSemanticdbs, interactiveSemanticdbs, ) ) + protected def semanticdbs(): Semanticdbs = agregateSemanticdbs + val gitHubIssueFolderInfo: GitHubIssueFolderInfo = new GitHubIssueFolderInfo( () => tables.buildTool.selectedBuildTool(), buildTargets, @@ -531,7 +533,7 @@ class ProjectMetalsLspService( ).ignoreValue case buildTools => for { - Some(buildTool) <- bspConfigGenerator.chooseBuildServerProvider( + case Some(buildTool) <- bspConfigGenerator.chooseBuildServerProvider( buildTools ) _ <- connect( diff --git a/metals/src/main/scala/scala/meta/internal/metals/ReferenceProvider.scala b/metals/src/main/scala/scala/meta/internal/metals/ReferenceProvider.scala index 6ca106c9466..93b52ac8f09 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/ReferenceProvider.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/ReferenceProvider.scala @@ -13,8 +13,8 @@ import scala.util.control.NonFatal import scala.util.matching.Regex import scala.meta.Importee +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.MetalsEnrichments._ -import scala.meta.internal.metals.ResolvedSymbolOccurrence import scala.meta.internal.mtags.DefinitionAlternatives.GlobalSymbol import scala.meta.internal.mtags.Semanticdbs import scala.meta.internal.mtags.Symbol diff --git a/metals/src/main/scala/scala/meta/internal/metals/ScalaTarget.scala b/metals/src/main/scala/scala/meta/internal/metals/ScalaTarget.scala index 1f2f33650c7..fedd554845a 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/ScalaTarget.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/ScalaTarget.scala @@ -7,7 +7,7 @@ import scala.meta.Dialect import scala.meta.dialects._ import scala.meta.internal.builds.BazelBuildTool import scala.meta.internal.builds.MillBuildTool -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.semver.SemVer import scala.meta.io.AbsolutePath diff --git a/metals/src/main/scala/scala/meta/internal/metals/ScalaVersionSelector.scala b/metals/src/main/scala/scala/meta/internal/metals/ScalaVersionSelector.scala index 22666a220f3..b4bf5f8c65d 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/ScalaVersionSelector.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/ScalaVersionSelector.scala @@ -1,7 +1,7 @@ package scala.meta.internal.metals import scala.meta._ -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.semver.SemVer import scala.meta.io.AbsolutePath diff --git a/metals/src/main/scala/scala/meta/internal/metals/ScalafixProvider.scala b/metals/src/main/scala/scala/meta/internal/metals/ScalafixProvider.scala index eb50da5ee0f..df66008d8bd 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/ScalafixProvider.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/ScalafixProvider.scala @@ -17,7 +17,7 @@ import scala.util.Try import scala.util.control.NonFatal import scala.meta._ -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.clients.language.MetalsLanguageClient import scala.meta.internal.metals.clients.language.MetalsQuickPickItem import scala.meta.internal.metals.clients.language.MetalsQuickPickParams diff --git a/metals/src/main/scala/scala/meta/internal/metals/SemanticdbIndexer.scala b/metals/src/main/scala/scala/meta/internal/metals/SemanticdbIndexer.scala index 75740ec7cc2..14a0ff226be 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/SemanticdbIndexer.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/SemanticdbIndexer.scala @@ -6,7 +6,7 @@ import java.nio.file.Path import scala.util.control.NonFatal -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.mtags.SemanticdbClasspath import scala.meta.internal.mtags.SemanticdbPath import scala.meta.internal.semanticdb.TextDocument @@ -59,11 +59,7 @@ class SemanticdbIndexer( * In case of a null path, we re-index `META-INF/semanticdb` for all targets */ def onOverflow(path: SemanticdbPath): Unit = { - if (path == null) { - onTargetRoots() - } else { - path.semanticdbRoot.foreach(onChangeDirectory(_)) - } + path.semanticdbRoot.foreach(onChangeDirectory(_)) } private def onChangeDirectory(dir: Path): Unit = { diff --git a/metals/src/main/scala/scala/meta/internal/metals/ServerCommands.scala b/metals/src/main/scala/scala/meta/internal/metals/ServerCommands.scala index 6b0c84d06b4..eebb80bd088 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/ServerCommands.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/ServerCommands.scala @@ -1,6 +1,5 @@ package scala.meta.internal.metals -import java.{util => ju} import javax.annotation.Nullable import scala.meta.internal.metals.newScalaFile.NewFileTypes @@ -649,7 +648,7 @@ object ServerCommands { final case class ConvertToNamedArgsRequest( position: TextDocumentPositionParams, - argIndices: ju.List[Integer], + argIndices: Array[Integer], ) val ConvertToNamedArguments = new ParametrizedCommand[ConvertToNamedArgsRequest]( diff --git a/metals/src/main/scala/scala/meta/internal/metals/SourceMapper.scala b/metals/src/main/scala/scala/meta/internal/metals/SourceMapper.scala index 2501ac1360f..dc36dcb0cb2 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/SourceMapper.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/SourceMapper.scala @@ -2,7 +2,7 @@ package scala.meta.internal.metals import scala.meta.inputs.Input import scala.meta.internal.builds.SbtBuildTool -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.worksheets.WorksheetProvider import scala.meta.io.AbsolutePath diff --git a/metals/src/main/scala/scala/meta/internal/metals/SqlSharedIndices.scala b/metals/src/main/scala/scala/meta/internal/metals/SqlSharedIndices.scala index 1a642a590a1..8bc24ea222f 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/SqlSharedIndices.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/SqlSharedIndices.scala @@ -12,5 +12,5 @@ class SqlSharedIndices migrations = "/shared-db/migration", ) { - val jvmTypeHierarchy: JarTypeHierarchy = new JarTypeHierarchy(() => connect) + val jvmTypeHierarchy: JarTypeHierarchy = new JarTypeHierarchy(() => connect()) } diff --git a/metals/src/main/scala/scala/meta/internal/metals/StacktraceAnalyzer.scala b/metals/src/main/scala/scala/meta/internal/metals/StacktraceAnalyzer.scala index 3337498fad8..a78256a7004 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/StacktraceAnalyzer.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/StacktraceAnalyzer.scala @@ -5,7 +5,7 @@ import java.io.FileWriter import scala.util.Try import scala.util.matching.Regex -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.StacktraceAnalyzer._ import scala.meta.io.AbsolutePath diff --git a/metals/src/main/scala/scala/meta/internal/metals/StandaloneSymbolSearch.scala b/metals/src/main/scala/scala/meta/internal/metals/StandaloneSymbolSearch.scala index c9f257dabe1..9fca21e0cd5 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/StandaloneSymbolSearch.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/StandaloneSymbolSearch.scala @@ -6,7 +6,7 @@ import java.{util => ju} import scala.collection.concurrent.TrieMap -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.mtags.Mtags import scala.meta.internal.mtags.OnDemandSymbolIndex import scala.meta.internal.parsing.Trees diff --git a/metals/src/main/scala/scala/meta/internal/metals/StatusBar.scala b/metals/src/main/scala/scala/meta/internal/metals/StatusBar.scala index 523ee4c9147..4d96408b813 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/StatusBar.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/StatusBar.scala @@ -7,7 +7,7 @@ import java.util.concurrent.TimeUnit import scala.util.control.NonFatal -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.clients.language.MetalsLanguageClient import scala.meta.internal.metals.clients.language.MetalsStatusParams diff --git a/metals/src/main/scala/scala/meta/internal/metals/Tables.scala b/metals/src/main/scala/scala/meta/internal/metals/Tables.scala index 7f3d7969ad8..9e906ad2ec1 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/Tables.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/Tables.scala @@ -5,6 +5,7 @@ import java.sql.Connection import scala.util.control.NonFatal import scala.meta.internal.builds.Digests +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.io.AbsolutePath final class Tables( diff --git a/metals/src/main/scala/scala/meta/internal/metals/TargetData.scala b/metals/src/main/scala/scala/meta/internal/metals/TargetData.scala index b3ee4f757f5..315d46ef090 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/TargetData.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/TargetData.scala @@ -15,7 +15,7 @@ import scala.concurrent.Promise import scala.util.Properties import scala.meta.inputs.Input -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.io.AbsolutePath import ch.epfl.scala.bsp4j.BuildTarget diff --git a/metals/src/main/scala/scala/meta/internal/metals/Warnings.scala b/metals/src/main/scala/scala/meta/internal/metals/Warnings.scala index a3e77c8d819..f6d40f6cae2 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/Warnings.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/Warnings.scala @@ -1,7 +1,7 @@ package scala.meta.internal.metals import scala.meta.internal.builds.BuildTools -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.ScalaVersions._ import scala.meta.internal.metals.clients.language.MetalsStatusParams import scala.meta.internal.metals.logging.MetalsLogger.{silentInTests => logger} diff --git a/metals/src/main/scala/scala/meta/internal/metals/WorksheetDependencySources.scala b/metals/src/main/scala/scala/meta/internal/metals/WorksheetDependencySources.scala index a374f6c879f..c204c643175 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/WorksheetDependencySources.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/WorksheetDependencySources.scala @@ -3,7 +3,7 @@ package scala.meta.internal.metals import java.sql.Connection import scala.meta.internal.metals.JdbcEnrichments._ -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.io.AbsolutePath final class WorksheetDependencySources(conn: () => Connection) { diff --git a/metals/src/main/scala/scala/meta/internal/metals/WorkspaceLspService.scala b/metals/src/main/scala/scala/meta/internal/metals/WorkspaceLspService.scala index 0edc1ff5375..17607b9fc9e 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/WorkspaceLspService.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/WorkspaceLspService.scala @@ -15,11 +15,7 @@ import scala.util.control.NonFatal import scala.meta.internal.bsp.BuildChange import scala.meta.internal.builds.NewProjectProvider import scala.meta.internal.builds.ShellRunner -import scala.meta.internal.metals.DidFocusResult -import scala.meta.internal.metals.HoverExtParams import scala.meta.internal.metals.MetalsEnrichments._ -import scala.meta.internal.metals.MetalsLspService -import scala.meta.internal.metals.WindowStateDidChangeParams import scala.meta.internal.metals.clients.language.ConfiguredLanguageClient import scala.meta.internal.metals.clients.language.MetalsLanguageClient import scala.meta.internal.metals.config.StatusBarState diff --git a/metals/src/main/scala/scala/meta/internal/metals/WorkspaceSearchVisitor.scala b/metals/src/main/scala/scala/meta/internal/metals/WorkspaceSearchVisitor.scala index 8652ed785f7..48e1643976a 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/WorkspaceSearchVisitor.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/WorkspaceSearchVisitor.scala @@ -5,7 +5,7 @@ import java.{util => ju} import scala.collection.mutable -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.mtags.GlobalSymbolIndex import scala.meta.internal.mtags.Symbol import scala.meta.internal.mtags.SymbolDefinition diff --git a/metals/src/main/scala/scala/meta/internal/metals/ammonite/Ammonite.scala b/metals/src/main/scala/scala/meta/internal/metals/ammonite/Ammonite.scala index fe53e2d40d4..50e678aa32e 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/ammonite/Ammonite.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/ammonite/Ammonite.scala @@ -20,7 +20,7 @@ import scala.util.control.NonFatal import scala.meta.inputs.Input import scala.meta.internal.bsp.BuildChange -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals._ import scala.meta.internal.metals.ammonite.Ammonite.AmmoniteMetalsException import scala.meta.internal.metals.clients.language.ForwardingMetalsBuildClient diff --git a/metals/src/main/scala/scala/meta/internal/metals/callHierarchy/OutgoingCallsFinder.scala b/metals/src/main/scala/scala/meta/internal/metals/callHierarchy/OutgoingCallsFinder.scala index 800373e71f9..33660b30fb3 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/callHierarchy/OutgoingCallsFinder.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/callHierarchy/OutgoingCallsFinder.scala @@ -74,7 +74,7 @@ class OutgoingCallsFinder( range.toLsp ) ) - case _ => false + case null => false } } diff --git a/metals/src/main/scala/scala/meta/internal/metals/clients/language/ConfiguredLanguageClient.scala b/metals/src/main/scala/scala/meta/internal/metals/clients/language/ConfiguredLanguageClient.scala index 1c11679a178..ed7131fbe49 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/clients/language/ConfiguredLanguageClient.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/clients/language/ConfiguredLanguageClient.scala @@ -8,9 +8,9 @@ import scala.concurrent.ExecutionContext import scala.meta.internal.decorations.PublishDecorationsParams import scala.meta.internal.metals.ClientCommands import scala.meta.internal.metals.ClientConfiguration -import scala.meta.internal.metals.MetalsEnrichments._ -import scala.meta.internal.metals.ServerCommands +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.WorkspaceLspService +import scala.meta.internal.metals.ServerCommands import scala.meta.internal.metals.config.StatusBarState import scala.meta.internal.metals.config.StatusBarState.LogMessage import scala.meta.internal.metals.config.StatusBarState.On diff --git a/metals/src/main/scala/scala/meta/internal/metals/clients/language/MetalsHttpClient.scala b/metals/src/main/scala/scala/meta/internal/metals/clients/language/MetalsHttpClient.scala index 4d06f3ab2a9..51e006e5af0 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/clients/language/MetalsHttpClient.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/clients/language/MetalsHttpClient.scala @@ -10,7 +10,7 @@ import scala.util.Try import scala.meta.internal.decorations.PublishDecorationsParams import scala.meta.internal.io.PathIO -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.clients.language.DelegatingLanguageClient import scala.meta.internal.metals.clients.language.MetalsLanguageClient import scala.meta.internal.metals.clients.language.MetalsStatusParams diff --git a/metals/src/main/scala/scala/meta/internal/metals/codeactions/CodeAction.scala b/metals/src/main/scala/scala/meta/internal/metals/codeactions/CodeAction.scala index 9a1d59c2a39..4e23ef95845 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/codeactions/CodeAction.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/codeactions/CodeAction.scala @@ -1,10 +1,9 @@ package scala.meta.internal.metals.codeactions -import scala.annotation.nowarn import scala.concurrent.ExecutionContext import scala.concurrent.Future -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.ParametrizedCommand import scala.meta.pc.CancelToken @@ -22,7 +21,6 @@ trait CodeAction { type ActionCommand = ParametrizedCommand[CommandData] def command: Option[ActionCommand] = None - @nowarn def handleCommand(data: CommandData, token: CancelToken)(implicit ec: ExecutionContext ): Future[Unit] = Future.unit diff --git a/metals/src/main/scala/scala/meta/internal/metals/codeactions/CodeActionProvider.scala b/metals/src/main/scala/scala/meta/internal/metals/codeactions/CodeActionProvider.scala index 664f9b884ef..224e41b6466 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/codeactions/CodeActionProvider.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/codeactions/CodeActionProvider.scala @@ -6,7 +6,6 @@ import scala.jdk.CollectionConverters._ import scala.meta.internal.metals._ import scala.meta.internal.metals.clients.language.MetalsLanguageClient -import scala.meta.internal.metals.codeactions.CodeAction import scala.meta.internal.parsing.Trees import scala.meta.pc.CancelToken diff --git a/metals/src/main/scala/scala/meta/internal/metals/codeactions/ConvertCommentCodeAction.scala b/metals/src/main/scala/scala/meta/internal/metals/codeactions/ConvertCommentCodeAction.scala index b7240872a11..c4e773bbe75 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/codeactions/ConvertCommentCodeAction.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/codeactions/ConvertCommentCodeAction.scala @@ -7,7 +7,7 @@ import scala.meta.XtensionDialectApply import scala.meta.XtensionTokenizeDialectInput import scala.meta.internal.metals.Buffers import scala.meta.internal.metals.MetalsEnrichments._ -import scala.meta.internal.metals.codeactions.CodeAction +import scala.meta._ import scala.meta.internal.metals.codeactions.MillifyScalaCliDependencyCodeAction._ import scala.meta.internal.parsing.Trees import scala.meta.io.AbsolutePath diff --git a/metals/src/main/scala/scala/meta/internal/metals/codeactions/ConvertToNamedArguments.scala b/metals/src/main/scala/scala/meta/internal/metals/codeactions/ConvertToNamedArguments.scala index 69180711dff..03399ff54e5 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/codeactions/ConvertToNamedArguments.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/codeactions/ConvertToNamedArguments.scala @@ -11,8 +11,6 @@ import scala.meta.internal.metals.Compilers import scala.meta.internal.metals.MetalsEnrichments._ import scala.meta.internal.metals.ServerCommands import scala.meta.internal.metals.clients.language.MetalsLanguageClient -import scala.meta.internal.metals.codeactions.CodeAction -import scala.meta.internal.metals.codeactions.CodeActionBuilder import scala.meta.internal.metals.logging import scala.meta.internal.parsing.Trees import scala.meta.pc.CancelToken @@ -42,12 +40,12 @@ class ConvertToNamedArguments( for { edits <- compilers.convertToNamedArguments( data.position, - data.argIndices, + data.argIndices.toList.asJava, token, ) _ = logging.logErrorWhen( edits.isEmpty(), - s"Could not find the correct names for arguments at ${data.position} with indices ${data.argIndices.asScala + s"Could not find the correct names for arguments at ${data.position} with indices ${data.argIndices.toList .mkString(",")}", ) workspaceEdit = new l.WorkspaceEdit(Map(uri -> edits).asJava) @@ -151,7 +149,7 @@ class ConvertToNamedArguments( ServerCommands .ConvertToNamedArgsRequest( position, - apply.argIndices.map(Integer.valueOf).asJava, + apply.argIndices.map(Integer.valueOf).toArray, ) ) diff --git a/metals/src/main/scala/scala/meta/internal/metals/codeactions/CreateCompanionObjectCodeAction.scala b/metals/src/main/scala/scala/meta/internal/metals/codeactions/CreateCompanionObjectCodeAction.scala index edc1b248e96..40127f1c8f4 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/codeactions/CreateCompanionObjectCodeAction.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/codeactions/CreateCompanionObjectCodeAction.scala @@ -9,10 +9,8 @@ import scala.meta.Term import scala.meta.Tree import scala.meta.inputs.Position import scala.meta.internal.metals.Buffers -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.ServerCommands -import scala.meta.internal.metals.codeactions.CodeAction -import scala.meta.internal.metals.codeactions.CodeActionBuilder import scala.meta.internal.parsing.Trees import scala.meta.io.AbsolutePath import scala.meta.pc.CancelToken diff --git a/metals/src/main/scala/scala/meta/internal/metals/codeactions/CreateNewSymbol.scala b/metals/src/main/scala/scala/meta/internal/metals/codeactions/CreateNewSymbol.scala index ad143dfa7c5..15b03b040fc 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/codeactions/CreateNewSymbol.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/codeactions/CreateNewSymbol.scala @@ -3,10 +3,10 @@ package scala.meta.internal.metals.codeactions import scala.concurrent.ExecutionContext import scala.concurrent.Future -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.ScalacDiagnostic import scala.meta.internal.metals.ServerCommands -import scala.meta.internal.metals.codeactions.CodeAction +import scala.meta.internal.metals._ import scala.meta.pc.CancelToken import org.eclipse.{lsp4j => l} diff --git a/metals/src/main/scala/scala/meta/internal/metals/codeactions/ExtractRenameMember.scala b/metals/src/main/scala/scala/meta/internal/metals/codeactions/ExtractRenameMember.scala index 318d3518672..1c156aa1856 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/codeactions/ExtractRenameMember.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/codeactions/ExtractRenameMember.scala @@ -17,18 +17,17 @@ import scala.meta.Type import scala.meta.XtensionCollectionLikeUI import scala.meta.XtensionDialectApply import scala.meta.XtensionTokenizeDialectInput -import scala.meta.inputs.Position -import scala.meta.internal.metals.Buffers import scala.meta.internal.metals.ClientCommands -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.ServerCommands +import scala.meta.internal.metals.Buffers import scala.meta.internal.metals.clients.language.MetalsLanguageClient -import scala.meta.internal.metals.codeactions.CodeAction import scala.meta.internal.metals.codeactions.ExtractRenameMember.CodeActionCommandNotFoundException import scala.meta.internal.metals.codeactions.ExtractRenameMember.getMemberType import scala.meta.internal.parsing.Trees import scala.meta.io.AbsolutePath import scala.meta.pc.CancelToken +import scala.meta.Position import scala.meta.tokens.Token import scala.meta.transversers.SimpleTraverser diff --git a/metals/src/main/scala/scala/meta/internal/metals/codeactions/ExtractValueCodeAction.scala b/metals/src/main/scala/scala/meta/internal/metals/codeactions/ExtractValueCodeAction.scala index a590063f2a4..6d42409d34e 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/codeactions/ExtractValueCodeAction.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/codeactions/ExtractValueCodeAction.scala @@ -12,9 +12,7 @@ import scala.meta.Tree import scala.meta.XtensionClassifiable import scala.meta.inputs.Position import scala.meta.internal.metals.Buffers -import scala.meta.internal.metals.MetalsEnrichments._ -import scala.meta.internal.metals.codeactions.CodeAction -import scala.meta.internal.metals.codeactions.CodeActionBuilder +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.parsing.Trees import scala.meta.pc.CancelToken import scala.meta.tokens.Token diff --git a/metals/src/main/scala/scala/meta/internal/metals/codeactions/FlatMapToForComprehensionCodeAction.scala b/metals/src/main/scala/scala/meta/internal/metals/codeactions/FlatMapToForComprehensionCodeAction.scala index 43752c30a52..87e98644376 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/codeactions/FlatMapToForComprehensionCodeAction.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/codeactions/FlatMapToForComprehensionCodeAction.scala @@ -17,8 +17,6 @@ import scala.meta.XtensionSyntax import scala.meta.inputs.Position import scala.meta.internal.metals.Buffers import scala.meta.internal.metals.MetalsEnrichments._ -import scala.meta.internal.metals.codeactions.CodeAction -import scala.meta.internal.metals.codeactions.CodeActionBuilder import scala.meta.internal.parsing.Trees import scala.meta.io.AbsolutePath import scala.meta.pc.CancelToken diff --git a/metals/src/main/scala/scala/meta/internal/metals/codeactions/ImplementAbstractMembers.scala b/metals/src/main/scala/scala/meta/internal/metals/codeactions/ImplementAbstractMembers.scala index e19519db98a..b48ce153d5f 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/codeactions/ImplementAbstractMembers.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/codeactions/ImplementAbstractMembers.scala @@ -4,9 +4,9 @@ import scala.concurrent.ExecutionContext import scala.concurrent.Future import scala.meta.internal.metals.Compilers -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.ScalacDiagnostic -import scala.meta.internal.metals.codeactions.CodeAction +import scala.meta.internal.metals._ import scala.meta.pc.CancelToken import org.eclipse.{lsp4j => l} diff --git a/metals/src/main/scala/scala/meta/internal/metals/codeactions/ImportMissingSymbol.scala b/metals/src/main/scala/scala/meta/internal/metals/codeactions/ImportMissingSymbol.scala index 2b192473917..23d91ae192b 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/codeactions/ImportMissingSymbol.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/codeactions/ImportMissingSymbol.scala @@ -5,10 +5,9 @@ import scala.concurrent.Future import scala.meta.internal.metals.BuildTargets import scala.meta.internal.metals.Compilers -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.ScalaVersions import scala.meta.internal.metals.ScalacDiagnostic -import scala.meta.internal.metals.codeactions.CodeAction import scala.meta.pc.CancelToken import org.eclipse.{lsp4j => l} diff --git a/metals/src/main/scala/scala/meta/internal/metals/codeactions/InlineValueCodeAction.scala b/metals/src/main/scala/scala/meta/internal/metals/codeactions/InlineValueCodeAction.scala index 30350144479..1ded0884df2 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/codeactions/InlineValueCodeAction.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/codeactions/InlineValueCodeAction.scala @@ -12,7 +12,6 @@ import scala.meta.internal.metals.Compilers import scala.meta.internal.metals.MetalsEnrichments._ import scala.meta.internal.metals.ServerCommands import scala.meta.internal.metals.clients.language.MetalsLanguageClient -import scala.meta.internal.metals.codeactions.CodeAction import scala.meta.internal.parsing.Trees import scala.meta.io.AbsolutePath import scala.meta.pc.CancelToken diff --git a/metals/src/main/scala/scala/meta/internal/metals/codeactions/InsertInferredType.scala b/metals/src/main/scala/scala/meta/internal/metals/codeactions/InsertInferredType.scala index b48cb37b498..0b4e762ff82 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/codeactions/InsertInferredType.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/codeactions/InsertInferredType.scala @@ -8,12 +8,10 @@ import scala.meta.Enumerator import scala.meta.Pat import scala.meta.Term import scala.meta.internal.metals.Compilers -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.ScalacDiagnostic import scala.meta.internal.metals.ServerCommands import scala.meta.internal.metals.clients.language.MetalsLanguageClient -import scala.meta.internal.metals.codeactions.CodeAction -import scala.meta.internal.metals.codeactions.CodeActionBuilder import scala.meta.internal.parsing.Trees import scala.meta.pc.CancelToken diff --git a/metals/src/main/scala/scala/meta/internal/metals/codeactions/MillifyDependencyCodeAction.scala b/metals/src/main/scala/scala/meta/internal/metals/codeactions/MillifyDependencyCodeAction.scala index 7a8af7ce431..9c49b8a1c44 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/codeactions/MillifyDependencyCodeAction.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/codeactions/MillifyDependencyCodeAction.scala @@ -6,8 +6,7 @@ import scala.concurrent.Future import scala.meta.XtensionDialectApply import scala.meta.XtensionTokenizeDialectInput import scala.meta.internal.metals.Buffers -import scala.meta.internal.metals.MetalsEnrichments._ -import scala.meta.internal.metals.codeactions.CodeAction +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.parsing.Trees import scala.meta.pc.CancelToken import scala.meta.tokens.Token._ diff --git a/metals/src/main/scala/scala/meta/internal/metals/codeactions/MillifyScalaCliDependencyCodeAction.scala b/metals/src/main/scala/scala/meta/internal/metals/codeactions/MillifyScalaCliDependencyCodeAction.scala index 7f28a570221..b23675d0b33 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/codeactions/MillifyScalaCliDependencyCodeAction.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/codeactions/MillifyScalaCliDependencyCodeAction.scala @@ -5,7 +5,6 @@ import scala.concurrent.Future import scala.meta.internal.metals.Buffers import scala.meta.internal.metals.MetalsEnrichments._ -import scala.meta.internal.metals.codeactions.CodeAction import scala.meta.internal.metals.codeactions.MillifyScalaCliDependencyCodeAction._ import scala.meta.internal.parsing.Trees import scala.meta.io.AbsolutePath diff --git a/metals/src/main/scala/scala/meta/internal/metals/codeactions/OrganizeImports.scala b/metals/src/main/scala/scala/meta/internal/metals/codeactions/OrganizeImports.scala index 818da536ef3..515b9d45b92 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/codeactions/OrganizeImports.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/codeactions/OrganizeImports.scala @@ -10,8 +10,6 @@ import scala.meta.internal.metals.ScalaTarget import scala.meta.internal.metals.ScalacDiagnostic import scala.meta.internal.metals.ScalafixProvider import scala.meta.internal.metals.clients.language.MetalsLanguageClient -import scala.meta.internal.metals.codeactions.CodeAction -import scala.meta.internal.metals.codeactions.CodeActionBuilder import scala.meta.io.AbsolutePath import scala.meta.pc.CancelToken diff --git a/metals/src/main/scala/scala/meta/internal/metals/codeactions/PatternMatchRefactor.scala b/metals/src/main/scala/scala/meta/internal/metals/codeactions/PatternMatchRefactor.scala index ce3802dbb57..13772740bcd 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/codeactions/PatternMatchRefactor.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/codeactions/PatternMatchRefactor.scala @@ -4,9 +4,7 @@ import scala.concurrent.ExecutionContext import scala.concurrent.Future import scala.meta.Term -import scala.meta.internal.metals.MetalsEnrichments._ -import scala.meta.internal.metals.codeactions.CodeAction -import scala.meta.internal.metals.codeactions.CodeActionBuilder +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.parsing.Trees import scala.meta.io.AbsolutePath import scala.meta.pc.CancelToken diff --git a/metals/src/main/scala/scala/meta/internal/metals/codeactions/RewriteBracesParensCodeAction.scala b/metals/src/main/scala/scala/meta/internal/metals/codeactions/RewriteBracesParensCodeAction.scala index e9f022dfc03..e7da6622ccf 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/codeactions/RewriteBracesParensCodeAction.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/codeactions/RewriteBracesParensCodeAction.scala @@ -5,9 +5,7 @@ import scala.concurrent.Future import scala.reflect.ClassTag import scala.meta.Term -import scala.meta.internal.metals.MetalsEnrichments._ -import scala.meta.internal.metals.codeactions.CodeAction -import scala.meta.internal.metals.codeactions.CodeActionBuilder +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.parsing.Trees import scala.meta.io.AbsolutePath import scala.meta.pc.CancelToken @@ -65,7 +63,7 @@ class RewriteBracesParensCodeAction( .getOrElse(Nil) } - private def switchFrom[L: ClassTag, R: ClassTag]( + private def switchFrom[L <: Token: ClassTag, R <: Token: ClassTag]( path: AbsolutePath, appl: Term.Apply, ): Seq[l.CodeAction] = { diff --git a/metals/src/main/scala/scala/meta/internal/metals/codeactions/StringActions.scala b/metals/src/main/scala/scala/meta/internal/metals/codeactions/StringActions.scala index 489770bb155..80abf1d1225 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/codeactions/StringActions.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/codeactions/StringActions.scala @@ -7,9 +7,7 @@ import scala.meta.XtensionClassifiable import scala.meta.XtensionDialectApply import scala.meta.XtensionTokenizeDialectInput import scala.meta.internal.metals.Buffers -import scala.meta.internal.metals.MetalsEnrichments._ -import scala.meta.internal.metals.codeactions.CodeAction -import scala.meta.internal.metals.codeactions.CodeActionBuilder +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.parsing.Trees import scala.meta.pc.CancelToken import scala.meta.tokens.Token @@ -33,7 +31,7 @@ class StringActions(buffers: Buffers) extends CodeAction { val tokenized = buffers .get(path) .flatMap(source => - Trees.defaultTokenizerDialect(source).tokenize.toOption + Trees.defaultTokenizerDialect.apply(source).tokenize.toOption ) tokenized match { case Some(tokens) => { diff --git a/metals/src/main/scala/scala/meta/internal/metals/codelenses/RunTestCodeLens.scala b/metals/src/main/scala/scala/meta/internal/metals/codelenses/RunTestCodeLens.scala index bf0e3f78976..5cef97eab14 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/codelenses/RunTestCodeLens.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/codelenses/RunTestCodeLens.scala @@ -15,7 +15,7 @@ import scala.meta.internal.metals.ClientConfiguration import scala.meta.internal.metals.Diagnostics import scala.meta.internal.metals.JavaBinary import scala.meta.internal.metals.JsonParser._ -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.TestUserInterfaceKind import scala.meta.internal.metals.UserConfiguration import scala.meta.internal.metals.debug.BuildTargetClasses diff --git a/metals/src/main/scala/scala/meta/internal/metals/codelenses/SuperMethodCodeLens.scala b/metals/src/main/scala/scala/meta/internal/metals/codelenses/SuperMethodCodeLens.scala index 49d8311fea5..a8d5c0966ab 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/codelenses/SuperMethodCodeLens.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/codelenses/SuperMethodCodeLens.scala @@ -7,7 +7,7 @@ import scala.meta.internal.implementation.SuperMethodProvider import scala.meta.internal.implementation.TextDocumentWithPath import scala.meta.internal.metals.Buffers import scala.meta.internal.metals.ClientConfiguration -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.ServerCommands import scala.meta.internal.metals.UserConfiguration import scala.meta.internal.parsing.Trees @@ -91,13 +91,13 @@ final class SuperMethodCodeLens( ) => val location = new l.Location(path.toURI.toString(), range.toLsp) val command = ServerCommands.GotoPosition.toLsp(location) - command.setTitle(s"${clientConfig.icons.findsuper} ${name}") + command.setTitle(s"${clientConfig.icons().findsuper} ${name}") command } else Some { val command = ServerCommands.GotoSymbol.toLsp(symbol) - command.setTitle(s"${clientConfig.icons.findsuper} ${name}") + command.setTitle(s"${clientConfig.icons().findsuper} ${name}") command } } diff --git a/metals/src/main/scala/scala/meta/internal/metals/codelenses/WorksheetCodeLens.scala b/metals/src/main/scala/scala/meta/internal/metals/codelenses/WorksheetCodeLens.scala index 52e661dbab8..00e24f80e53 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/codelenses/WorksheetCodeLens.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/codelenses/WorksheetCodeLens.scala @@ -5,7 +5,7 @@ import scala.concurrent.Future import scala.meta.internal.metals.ClientCommands.CopyWorksheetOutput import scala.meta.internal.metals.ClientConfiguration -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.io.AbsolutePath import org.eclipse.{lsp4j => l} @@ -14,7 +14,7 @@ class WorksheetCodeLens(clientConfig: ClientConfiguration)(implicit val ec: ExecutionContext ) extends CodeLens { - override def isEnabled: Boolean = clientConfig.isCopyWorksheetOutputProvider + override def isEnabled: Boolean = clientConfig.isCopyWorksheetOutputProvider() override def codeLenses( path: AbsolutePath diff --git a/metals/src/main/scala/scala/meta/internal/metals/debug/BuildTargetClasses.scala b/metals/src/main/scala/scala/meta/internal/metals/debug/BuildTargetClasses.scala index 67f8232ba43..95938a99a58 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/debug/BuildTargetClasses.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/debug/BuildTargetClasses.scala @@ -6,7 +6,7 @@ import scala.concurrent.Future import scala.meta.internal.metals.BatchedFunction import scala.meta.internal.metals.BuildTargets -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.debug.BuildTargetClasses.Classes import scala.meta.internal.metals.debug.BuildTargetClasses.TestSymbolInfo import scala.meta.internal.semanticdb.Scala.Descriptor diff --git a/metals/src/main/scala/scala/meta/internal/metals/debug/BuildTargetClassesFinder.scala b/metals/src/main/scala/scala/meta/internal/metals/debug/BuildTargetClassesFinder.scala index 3f39ba88082..9ba9e95bc87 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/debug/BuildTargetClassesFinder.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/debug/BuildTargetClassesFinder.scala @@ -34,7 +34,7 @@ class BuildTargetClassesFinder( .classesOf(_) .mainClasses .values, - { (clazz: b.ScalaMainClass) => clazz.getClassName }, + { (clazz: b.ScalaMainClass) => clazz.getClassName() }, ).recoverWith { case ex => val found = ex match { // We check whether there is a main in dependencies that is not reported via BSP diff --git a/metals/src/main/scala/scala/meta/internal/metals/debug/ClientConfigurationAdapter.scala b/metals/src/main/scala/scala/meta/internal/metals/debug/ClientConfigurationAdapter.scala index 8f285ca7c15..aeba2d381f2 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/debug/ClientConfigurationAdapter.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/debug/ClientConfigurationAdapter.scala @@ -4,7 +4,7 @@ import java.nio.file.Paths import scala.util.control.NonFatal -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.SourceMapper import scala.meta.io.AbsolutePath diff --git a/metals/src/main/scala/scala/meta/internal/metals/debug/DebugDiscovery.scala b/metals/src/main/scala/scala/meta/internal/metals/debug/DebugDiscovery.scala index 9599e26a86f..379b6596c57 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/debug/DebugDiscovery.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/debug/DebugDiscovery.scala @@ -326,7 +326,7 @@ class DebugDiscovery( .flatMap(scalaTarget => JavaBinary.javaBinaryFromPath(scalaTarget.jvmHome) ) - .orElse(userConfig().usedJavaBinary) + .orElse(userConfig().usedJavaBinary()) buildTargetClasses .jvmRunEnvironment(params.getTargets().get(0)) .map { envItem => diff --git a/metals/src/main/scala/scala/meta/internal/metals/debug/DebugProtocol.scala b/metals/src/main/scala/scala/meta/internal/metals/debug/DebugProtocol.scala index ce9399b1ed9..1786450761c 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/debug/DebugProtocol.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/debug/DebugProtocol.scala @@ -5,7 +5,7 @@ import scala.util.Failure import scala.util.Success import scala.util.Try -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.debug.DebugProxy.DebugMode import com.google.gson.JsonElement diff --git a/metals/src/main/scala/scala/meta/internal/metals/debug/DebugProvider.scala b/metals/src/main/scala/scala/meta/internal/metals/debug/DebugProvider.scala index 6a58a5d6b55..4066e4dd5e4 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/debug/DebugProvider.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/debug/DebugProvider.scala @@ -32,7 +32,7 @@ import scala.meta.internal.metals.JvmOpts import scala.meta.internal.metals.Messages import scala.meta.internal.metals.Messages.UnresolvedDebugSessionParams import scala.meta.internal.metals.MetalsBuildClient -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.MutableCancelable import scala.meta.internal.metals.ScalaTestSuites import scala.meta.internal.metals.ScalaTestSuitesDebugRequest @@ -451,7 +451,7 @@ class DebugProvider( debugParams: DebugSessionParams )(implicit ec: ExecutionContext): Future[DebugSession] = { for { - server <- start(debugParams), + server <- start(debugParams) } yield { statusBar.addMessage("Started debug server!") DebugSession(server.sessionName, server.uri.toString) diff --git a/metals/src/main/scala/scala/meta/internal/metals/debug/DebugProxy.scala b/metals/src/main/scala/scala/meta/internal/metals/debug/DebugProxy.scala index f1c4b2a8778..5b71c346555 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/debug/DebugProxy.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/debug/DebugProxy.scala @@ -18,7 +18,8 @@ import scala.meta.internal.metals.Compilations import scala.meta.internal.metals.Compilers import scala.meta.internal.metals.EmptyCancelToken import scala.meta.internal.metals.JsonParser._ -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.SourceMapper import scala.meta.internal.metals.StacktraceAnalyzer import scala.meta.internal.metals.Trace @@ -275,7 +276,7 @@ private[debug] final class DebugProxy( case message @ OutputNotification(output) if stripColor => val raw = output.getOutput() - val msgWithoutColorCodes = filterANSIColorCodes(raw) + val msgWithoutColorCodes = MetalsEnrichments.filterANSIColorCodes(raw) output.setOutput(msgWithoutColorCodes) message.setParams(output) client.consume(message) diff --git a/metals/src/main/scala/scala/meta/internal/metals/debug/DotEnvFileParser.scala b/metals/src/main/scala/scala/meta/internal/metals/debug/DotEnvFileParser.scala index 4d307cd202d..b04bc4428f9 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/debug/DotEnvFileParser.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/debug/DotEnvFileParser.scala @@ -8,7 +8,7 @@ import scala.util.matching.Regex import scala.util.matching.Regex.Groups import scala.meta.internal.io.FileIO -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.io.AbsolutePath object DotEnvFileParser { diff --git a/metals/src/main/scala/scala/meta/internal/metals/debug/EndpointLogger.scala b/metals/src/main/scala/scala/meta/internal/metals/debug/EndpointLogger.scala index 67febe12dc5..ab0e99ad946 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/debug/EndpointLogger.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/debug/EndpointLogger.scala @@ -60,8 +60,8 @@ final class EndpointLogger(endpoint: RemoteEndpoint, logger: PrintWriter) object EndpointLogger { sealed trait Direction - final case object Received extends Direction - final case object Sent extends Direction + case object Received extends Direction + case object Sent extends Direction private def serializer: MessageJsonHandler = { val configure: Consumer[GsonBuilder] = { gson => gson.setPrettyPrinting() } diff --git a/metals/src/main/scala/scala/meta/internal/metals/debug/SourcePathAdapter.scala b/metals/src/main/scala/scala/meta/internal/metals/debug/SourcePathAdapter.scala index 56b89cf2ced..90929d60b0e 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/debug/SourcePathAdapter.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/debug/SourcePathAdapter.scala @@ -5,7 +5,7 @@ import java.net.URI import scala.meta.internal.io.FileIO import scala.meta.internal.metals.BuildTargets import scala.meta.internal.metals.Directories -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.io.AbsolutePath import ch.epfl.scala.bsp4j.BuildTargetIdentifier diff --git a/metals/src/main/scala/scala/meta/internal/metals/doctor/Doctor.scala b/metals/src/main/scala/scala/meta/internal/metals/doctor/Doctor.scala index 11be0b5ec16..7fd7d3d840f 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/doctor/Doctor.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/doctor/Doctor.scala @@ -29,7 +29,7 @@ import scala.meta.internal.metals.Icons import scala.meta.internal.metals.JavaInfo import scala.meta.internal.metals.JavaTarget import scala.meta.internal.metals.Messages.CheckDoctor -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.MtagsResolver import scala.meta.internal.metals.PopupChoiceReset import scala.meta.internal.metals.Report @@ -337,7 +337,7 @@ final class Doctor( selectedBuildToolMessage().foreach { case (msg, explicitChoice) => html.element("p")( _.text(msg) - .optionally(!clientConfig.isHttpEnabled && explicitChoice)( + .optionally(!clientConfig.isHttpEnabled() && explicitChoice)( _.text(" (") .link(resetChoiceCommand(PopupChoiceReset.BuildTool), "Reset") .text(")") @@ -348,7 +348,7 @@ final class Doctor( selectedImportBuildMessage().foreach { msg => html.element("p")( _.text(msg) - .optionally(!clientConfig.isHttpEnabled)( + .optionally(!clientConfig.isHttpEnabled())( _.text(" (") .link(resetChoiceCommand(PopupChoiceReset.BuildImport), "Reset") .text(")") @@ -365,7 +365,7 @@ final class Doctor( if (explicitChoice) { html.element("p")( _.text(message) - .optionally(!clientConfig.isHttpEnabled)( + .optionally(!clientConfig.isHttpEnabled())( _.text(" (") .link(resetChoiceCommand(PopupChoiceReset.BuildServer), "Reset") .text(")") diff --git a/metals/src/main/scala/scala/meta/internal/metals/doctor/HeadDoctor.scala b/metals/src/main/scala/scala/meta/internal/metals/doctor/HeadDoctor.scala index 8b6b974ab13..6d1b4343fe5 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/doctor/HeadDoctor.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/doctor/HeadDoctor.scala @@ -73,9 +73,10 @@ class HeadDoctor( val shouldDisplay = isVisibilityProvider && isVisible.get() if (shouldDisplay || !isVisibilityProvider) { if ( - clientConfig.isExecuteClientCommandProvider && !clientConfig.isHttpEnabled + clientConfig.isExecuteClientCommandProvider() && !clientConfig + .isHttpEnabled() ) { - val output = clientConfig.doctorFormat match { + val output = clientConfig.doctorFormat() match { case DoctorFormat.Json => buildTargetsJson() case DoctorFormat.Html => buildTargetsHtml() } diff --git a/metals/src/main/scala/scala/meta/internal/metals/doctor/ProblemResolver.scala b/metals/src/main/scala/scala/meta/internal/metals/doctor/ProblemResolver.scala index 91252d82909..2bfcb3f7bc9 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/doctor/ProblemResolver.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/doctor/ProblemResolver.scala @@ -11,7 +11,7 @@ import scala.meta.internal.metals.JavaTarget import scala.meta.internal.metals.JdkSources import scala.meta.internal.metals.JdkVersion import scala.meta.internal.metals.Messages -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.MtagsResolver import scala.meta.internal.metals.ScalaTarget import scala.meta.internal.metals.ScalaVersions diff --git a/metals/src/main/scala/scala/meta/internal/metals/findfiles/FindTextInDependencyJars.scala b/metals/src/main/scala/scala/meta/internal/metals/findfiles/FindTextInDependencyJars.scala index a3562f396e5..3fd895bf15f 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/findfiles/FindTextInDependencyJars.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/findfiles/FindTextInDependencyJars.scala @@ -11,7 +11,7 @@ import scala.util.control.NonFatal import scala.meta.internal.io.FileIO import scala.meta.internal.metals.BuildTargets -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.PathMatcher.Nio import scala.meta.internal.metals.clients.language.MetalsInputBoxParams import scala.meta.internal.metals.clients.language.MetalsLanguageClient diff --git a/metals/src/main/scala/scala/meta/internal/metals/formatting/IndentOnPaste.scala b/metals/src/main/scala/scala/meta/internal/metals/formatting/IndentOnPaste.scala index 9756eb6aa66..ebcfc825983 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/formatting/IndentOnPaste.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/formatting/IndentOnPaste.scala @@ -1,7 +1,7 @@ package scala.meta.internal.metals.formatting import scala.util.matching.Regex -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.UserConfiguration import org.eclipse.lsp4j.Position diff --git a/metals/src/main/scala/scala/meta/internal/metals/formatting/OnTypeFormattingProvider.scala b/metals/src/main/scala/scala/meta/internal/metals/formatting/OnTypeFormattingProvider.scala index a4bad0f0366..bf9fff2d2df 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/formatting/OnTypeFormattingProvider.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/formatting/OnTypeFormattingProvider.scala @@ -2,7 +2,7 @@ package scala.meta.internal.metals.formatting import scala.meta.inputs.Input import scala.meta.internal.metals.Buffers -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.UserConfiguration import scala.meta.internal.parsing.Trees import scala.meta.tokens.Tokens diff --git a/metals/src/main/scala/scala/meta/internal/metals/formatting/RangeFormattingProvider.scala b/metals/src/main/scala/scala/meta/internal/metals/formatting/RangeFormattingProvider.scala index 57d2b0f33ba..ae73173b834 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/formatting/RangeFormattingProvider.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/formatting/RangeFormattingProvider.scala @@ -2,7 +2,7 @@ package scala.meta.internal.metals.formatting import scala.meta.inputs.Input import scala.meta.internal.metals.Buffers -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.UserConfiguration import scala.meta.internal.parsing.Trees import scala.meta.tokens.Tokens diff --git a/metals/src/main/scala/scala/meta/internal/metals/newScalaFile/NewFileProvider.scala b/metals/src/main/scala/scala/meta/internal/metals/newScalaFile/NewFileProvider.scala index 99c8391b48e..383fea111b8 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/newScalaFile/NewFileProvider.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/newScalaFile/NewFileProvider.scala @@ -12,7 +12,7 @@ import scala.meta.internal.builds.NewProjectProvider import scala.meta.internal.metals.ClientCommands import scala.meta.internal.metals.Icons import scala.meta.internal.metals.Messages.NewScalaFile -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.PackageProvider import scala.meta.internal.metals.ScalaVersionSelector import scala.meta.internal.metals.ScalaVersions @@ -20,7 +20,7 @@ import scala.meta.internal.metals.clients.language.MetalsInputBoxParams import scala.meta.internal.metals.clients.language.MetalsLanguageClient import scala.meta.internal.metals.clients.language.MetalsQuickPickParams import scala.meta.internal.metals.newScalaFile.NewFileTypes._ -import scala.meta.internal.pc.Identifier +import scala.meta.internal.mtags.KeywordWrapper import scala.meta.io.AbsolutePath import org.eclipse.lsp4j.Location @@ -191,7 +191,8 @@ class NewFileProvider( ): Future[(AbsolutePath, Range)] = { val path = directory.resolve(name + ext) // name can be actually be "foo/Name", where "foo" is a folder to create - val className = Identifier.backtickWrap( + // TODO use correct wrapper + val className = KeywordWrapper.Scala2.backtickWrap( directory.resolve(name).filename ) val template = kind match { diff --git a/metals/src/main/scala/scala/meta/internal/metals/scalacli/ScalaCliServers.scala b/metals/src/main/scala/scala/meta/internal/metals/scalacli/ScalaCliServers.scala index 9fd739544bd..d085fe893ac 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/scalacli/ScalaCliServers.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/scalacli/ScalaCliServers.scala @@ -117,7 +117,7 @@ class ScalaCliServers( def cancel(): Unit = { val servers = serversRef.getAndSet(Queue.empty) servers.foreach(_.cancel()) - servers.foreach(_.customWorkspace.foreach(_.deleteRecursively)) + servers.foreach(_.customWorkspace.foreach(_.deleteRecursively())) } def loaded(path: AbsolutePath): Boolean = @@ -141,12 +141,12 @@ class ScalaCliServers( AbsolutePath( Files.createTempDirectory(s"metals-scala-cli") ) - val Some(workspace) = + val workspace = scalaCliBuildDirectory.updateAndGet { case None => Some(tmpFile) case some => some } - workspace + workspace.get } // When path and workspace have different roots on Windows `scala-cli` throws an error, diff --git a/metals/src/main/scala/scala/meta/internal/metals/testProvider/BuildTargetUpdate.scala b/metals/src/main/scala/scala/meta/internal/metals/testProvider/BuildTargetUpdate.scala index b23cf4ccb14..64d54a20df5 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/testProvider/BuildTargetUpdate.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/testProvider/BuildTargetUpdate.scala @@ -1,6 +1,6 @@ package scala.meta.internal.metals.testProvider -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.io.AbsolutePath import ch.epfl.scala.bsp4j.BuildTarget diff --git a/metals/src/main/scala/scala/meta/internal/metals/testProvider/TestSuitesProvider.scala b/metals/src/main/scala/scala/meta/internal/metals/testProvider/TestSuitesProvider.scala index aa50dbd832b..6b7232eb4a6 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/testProvider/TestSuitesProvider.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/testProvider/TestSuitesProvider.scala @@ -13,7 +13,7 @@ import scala.meta.internal.metals.BuildTargets import scala.meta.internal.metals.ClientCommands import scala.meta.internal.metals.ClientConfiguration import scala.meta.internal.metals.JsonParser._ -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.ScalaTestSuiteSelection import scala.meta.internal.metals.ScalaTestSuites import scala.meta.internal.metals.SemanticdbFeatureProvider @@ -366,7 +366,7 @@ final class TestSuitesProvider( // filter out sbt builds .filterNot(_.isSbtBuild) .map { buildTarget => - SymbolsPerTarget( + SymbolsPerTarget.apply( buildTarget, buildTargetClasses.classesOf(buildTarget.getId).testClasses, ) diff --git a/metals/src/main/scala/scala/meta/internal/metals/testProvider/frameworks/JunitTestFinder.scala b/metals/src/main/scala/scala/meta/internal/metals/testProvider/frameworks/JunitTestFinder.scala index da6ea3ebae7..4a1748ed04c 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/testProvider/frameworks/JunitTestFinder.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/testProvider/frameworks/JunitTestFinder.scala @@ -2,7 +2,7 @@ package scala.meta.internal.metals.testProvider.frameworks import scala.reflect.NameTransformer -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.testProvider.TestCaseEntry import scala.meta.internal.mtags import scala.meta.internal.semanticdb.SymbolInformation diff --git a/metals/src/main/scala/scala/meta/internal/metals/testProvider/frameworks/MunitTestFinder.scala b/metals/src/main/scala/scala/meta/internal/metals/testProvider/frameworks/MunitTestFinder.scala index f835e5a055a..2fce9633eef 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/testProvider/frameworks/MunitTestFinder.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/testProvider/frameworks/MunitTestFinder.scala @@ -9,7 +9,7 @@ import scala.meta.Lit import scala.meta.Template import scala.meta.Term import scala.meta.Tree -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.testProvider.FullyQualifiedName import scala.meta.internal.metals.testProvider.TestCaseEntry import scala.meta.internal.metals.testProvider.frameworks.TreeUtils._ diff --git a/metals/src/main/scala/scala/meta/internal/metals/testProvider/frameworks/ScalatestTestFinder.scala b/metals/src/main/scala/scala/meta/internal/metals/testProvider/frameworks/ScalatestTestFinder.scala index 633c7857420..4ab8e49b0b9 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/testProvider/frameworks/ScalatestTestFinder.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/testProvider/frameworks/ScalatestTestFinder.scala @@ -5,12 +5,11 @@ import scala.meta.Stat import scala.meta.Template import scala.meta.Term import scala.meta.Tree -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.testProvider.FullyQualifiedName import scala.meta.internal.metals.testProvider.TestCaseEntry import scala.meta.internal.metals.testProvider.frameworks.ScalatestStyle._ import scala.meta.internal.metals.testProvider.frameworks.ScalatestTestFinder._ -import scala.meta.internal.metals.testProvider.frameworks.TreeUtils import scala.meta.internal.mtags import scala.meta.internal.parsing.Trees import scala.meta.internal.semanticdb.ClassSignature @@ -114,10 +113,10 @@ object ScalatestTestFinder { ): Vector[TestCaseEntry] = { // collect all entries like test("testname") { ... } template.stats.collect { - // format: off - case Term.Apply(appl @ Term.Apply(Term.Name(funName), Lit.String(testname) :: _), _) - if style.leafMethods.contains(funName) => - // format: on + case Term.Apply( + appl @ Term.Apply(Term.Name(funName), Lit.String(testname) :: _), + _, + ) if style.leafMethods.contains(funName) => TestCaseEntry(testname, appl.pos.toLsp.toLocation(path.toURI)) }.toVector } diff --git a/metals/src/main/scala/scala/meta/internal/parsing/ClassFinder.scala b/metals/src/main/scala/scala/meta/internal/parsing/ClassFinder.scala index 8c041b7f9a1..5dc0dbd9231 100644 --- a/metals/src/main/scala/scala/meta/internal/parsing/ClassFinder.scala +++ b/metals/src/main/scala/scala/meta/internal/parsing/ClassFinder.scala @@ -12,8 +12,7 @@ import scala.meta.Self import scala.meta.Tree import scala.meta.Type import scala.meta.XtensionClassifiable -import scala.meta.internal.metals.MetalsEnrichments._ -import scala.meta.internal.parsing.Trees +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.parsing.finder.ClassKind import scala.meta.internal.parsing.finder.MangledClassName import scala.meta.internal.parsing.finder.ShortClassName diff --git a/metals/src/main/scala/scala/meta/internal/parsing/DocumentSymbolProvider.scala b/metals/src/main/scala/scala/meta/internal/parsing/DocumentSymbolProvider.scala index 836cbafe4b2..63917a2a18c 100644 --- a/metals/src/main/scala/scala/meta/internal/parsing/DocumentSymbolProvider.scala +++ b/metals/src/main/scala/scala/meta/internal/parsing/DocumentSymbolProvider.scala @@ -3,7 +3,7 @@ package scala.meta.internal.parsing import java.util import scala.meta._ -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.transversers.SimpleTraverser import scala.meta.trees.Origin diff --git a/metals/src/main/scala/scala/meta/internal/parsing/FoldingRangeExtractor.scala b/metals/src/main/scala/scala/meta/internal/parsing/FoldingRangeExtractor.scala index f393754c6d1..e4d7bead04d 100644 --- a/metals/src/main/scala/scala/meta/internal/parsing/FoldingRangeExtractor.scala +++ b/metals/src/main/scala/scala/meta/internal/parsing/FoldingRangeExtractor.scala @@ -7,8 +7,8 @@ import scala.collection.mutable import scala.reflect.ClassTag import scala.meta._ -import scala.meta.internal.metals.MetalsEnrichments._ -import scala.meta.internal.metals.PositionSyntax._ +import scala.meta.internal.metals.MetalsEnrichments.given +import scala.meta.internal.metals.PositionSyntax.given import scala.meta.tokens.Token import org.eclipse.lsp4j.FoldingRange @@ -332,7 +332,7 @@ final class FoldingRangeExtractor( } } - private def findTermFoldStartAndAdjustment[T: ClassTag]( + private def findTermFoldStartAndAdjustment[T <: Token: ClassTag]( trailingTokens: Iterator[Token], startFoldIfEOL: Boolean, ): Option[(Int, Boolean)] = { @@ -360,7 +360,7 @@ final class FoldingRangeExtractor( } } - private def getFoldingRangeForBlockAfterKeyword[T: ClassTag]( + private def getFoldingRangeForBlockAfterKeyword[T <: Token: ClassTag]( block: Term.Block ): Option[Position] = { val firstToken = block.leadingTokens diff --git a/metals/src/main/scala/scala/meta/internal/parsing/FoldingRangeProvider.scala b/metals/src/main/scala/scala/meta/internal/parsing/FoldingRangeProvider.scala index 762e11cb607..1fe4bfea377 100644 --- a/metals/src/main/scala/scala/meta/internal/parsing/FoldingRangeProvider.scala +++ b/metals/src/main/scala/scala/meta/internal/parsing/FoldingRangeProvider.scala @@ -6,7 +6,7 @@ import java.util.Collections import scala.meta.inputs.Input import scala.meta.inputs.Position import scala.meta.internal.metals.Buffers -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.parsing.FoldingRangeProvider._ import scala.meta.io.AbsolutePath diff --git a/metals/src/main/scala/scala/meta/internal/parsing/JavaFoldingRangeExtractor.scala b/metals/src/main/scala/scala/meta/internal/parsing/JavaFoldingRangeExtractor.scala index b4d8ee7c722..da4396abe41 100644 --- a/metals/src/main/scala/scala/meta/internal/parsing/JavaFoldingRangeExtractor.scala +++ b/metals/src/main/scala/scala/meta/internal/parsing/JavaFoldingRangeExtractor.scala @@ -19,7 +19,7 @@ import com.sun.source.util.Trees import org.eclipse.lsp4j.FoldingRange import org.eclipse.lsp4j.FoldingRangeKind -final object JavaFoldingRangeExtractor { +object JavaFoldingRangeExtractor { private val spanThreshold = 2 private case class Range( diff --git a/metals/src/main/scala/scala/meta/internal/parsing/TokenEditDistance.scala b/metals/src/main/scala/scala/meta/internal/parsing/TokenEditDistance.scala index e3fda760469..c078a9c38b9 100644 --- a/metals/src/main/scala/scala/meta/internal/parsing/TokenEditDistance.scala +++ b/metals/src/main/scala/scala/meta/internal/parsing/TokenEditDistance.scala @@ -10,7 +10,7 @@ import scala.util.Success import scala.meta.Input import scala.meta.Position -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.parsing.TokenOps.syntax._ import scala.meta.internal.{semanticdb => s} import scala.meta.tokenizers.Tokenized diff --git a/metals/src/main/scala/scala/meta/internal/parsing/Trees.scala b/metals/src/main/scala/scala/meta/internal/parsing/Trees.scala index 256c7980d4f..bda4d4afcb9 100644 --- a/metals/src/main/scala/scala/meta/internal/parsing/Trees.scala +++ b/metals/src/main/scala/scala/meta/internal/parsing/Trees.scala @@ -7,7 +7,7 @@ import scala.meta._ import scala.meta.inputs.Input import scala.meta.inputs.Position import scala.meta.internal.metals.Buffers -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.Report import scala.meta.internal.metals.ReportContext import scala.meta.internal.metals.ScalaVersionSelector diff --git a/metals/src/main/scala/scala/meta/internal/rename/RenameProvider.scala b/metals/src/main/scala/scala/meta/internal/rename/RenameProvider.scala index 8c8043eb118..60e65596a13 100644 --- a/metals/src/main/scala/scala/meta/internal/rename/RenameProvider.scala +++ b/metals/src/main/scala/scala/meta/internal/rename/RenameProvider.scala @@ -15,13 +15,13 @@ import scala.meta.internal.metals.ClientConfiguration import scala.meta.internal.metals.Compilations import scala.meta.internal.metals.Compilers import scala.meta.internal.metals.DefinitionProvider -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.ReferenceProvider import scala.meta.internal.metals.ReportContext import scala.meta.internal.metals.TextEdits import scala.meta.internal.metals.clients.language.MetalsLanguageClient +import scala.meta.internal.mtags.KeywordWrapper import scala.meta.internal.parsing.Trees -import scala.meta.internal.pc.Identifier import scala.meta.internal.search.SymbolHierarchyOps import scala.meta.internal.semanticdb.Scala._ import scala.meta.internal.semanticdb.SelectTree @@ -50,6 +50,7 @@ import org.eclipse.lsp4j.VersionedTextDocumentIdentifier import org.eclipse.lsp4j.WorkspaceEdit import org.eclipse.lsp4j.jsonrpc.messages.{Either => LSPEither} import org.eclipse.lsp4j.{Range => LSPRange} +import scala.meta.internal.pc.PcSymbolInformation final class RenameProvider( referenceProvider: ReferenceProvider, @@ -117,6 +118,7 @@ final class RenameProvider( token: CancelToken, ): Future[WorkspaceEdit] = { val source = params.getTextDocument.getUri.toAbsolutePath + // val scalaVersion = val localRename = compilers .rename(params, token) .map(_.asScala.toList) @@ -164,7 +166,8 @@ final class RenameProvider( if (suggestedName.isBackticked) suggestedName.stripBackticks else suggestedName - val newName = Identifier.backtickWrap(withoutBackticks) + val newName = + KeywordWrapper.Scala3().backtickWrap(withoutBackticks) def isNotRenamedSymbol( textDocument: TextDocument, @@ -179,15 +182,6 @@ final class RenameProvider( foundName.contains(realName) } - def shouldCheckImplementation( - symbol: String, - path: AbsolutePath, - textDocument: TextDocument, - ) = - !symbol.desc.isType && !(symbol.isLocal && symbolHierarchyOps - .defaultSymbolSearch(path, textDocument)(symbol) - .exists(info => info.isTrait || info.isClass)) - val allReferences = for { (occurence, semanticDb) <- symbolOccurrence.toIterable @@ -235,13 +229,14 @@ final class RenameProvider( source, newName, ) + shouldCheckImplementationFut = shouldCheckImplementation( + occurence.symbol, + source, + semanticDb, + ) implReferences = implementations( txtParams, - shouldCheckImplementation( - occurence.symbol, - source, - semanticDb, - ), + shouldCheckImplementationFut, newName, ) } yield Future @@ -327,6 +322,32 @@ final class RenameProvider( Future.sequence(all.map(waiting => waiting())).ignoreValue } + private def shouldCheckImplementation( + symbol: String, + path: AbsolutePath, + textDocument: TextDocument, + ): Future[Boolean] = { + val notLocalAndType = !symbol.desc.isType && !symbol.isLocal + + if (notLocalAndType) Future.successful(true) + else if (!symbol.isLocal) Future.successful(false) + else + symbolHierarchyOps + .defaultSymbolSearch(path, textDocument)(symbol) + .match { + case Some(info) => + Future.successful(info.isTrait || info.isClass) + case None => + compilers.info(path, symbol).map { + case None => false + case Some(value) => + value.kind.getValue() == 13 || + value.kind.getValue() == 14 + } + + } + } + /** * In case of import renames, we can only rename the symbol in file. * Global rename will not return any results, so this method will be used as @@ -466,31 +487,32 @@ final class RenameProvider( private def implementations( textParams: TextDocumentPositionParams, - shouldCheckImplementation: Boolean, + shouldCheckImplementationFut: Future[Boolean], newName: String, - ): Future[Seq[Location]] = { - if (shouldCheckImplementation) { - for { - implLocs <- implementationProvider.implementations(textParams) - result <- { - val result = for { - implLoc <- implLocs - locParams = toReferenceParams(implLoc, includeDeclaration = true) - } yield { - referenceProvider - .references( - locParams, - findRealRange = AdjustRange(findRealRange(newName)), - includeSynthetic, - ) - .map(_.flatMap(_.locations)) + ): Future[Seq[Location]] = shouldCheckImplementationFut.flatMap { + shouldCheckImplementation => + if (shouldCheckImplementation) { + for { + implLocs <- implementationProvider.implementations(textParams) + result <- { + val result = for { + implLoc <- implLocs + locParams = toReferenceParams(implLoc, includeDeclaration = true) + } yield { + referenceProvider + .references( + locParams, + findRealRange = AdjustRange(findRealRange(newName)), + includeSynthetic, + ) + .map(_.flatMap(_.locations)) + } + Future.sequence(result) } - Future.sequence(result) - } - } yield result.flatten - } else { - Future.successful(Nil) - } + } yield result.flatten + } else { + Future.successful(Nil) + } } private def canRenameSymbol( diff --git a/metals/src/main/scala/scala/meta/internal/search/GlobalClassTable.scala b/metals/src/main/scala/scala/meta/internal/search/GlobalClassTable.scala deleted file mode 100644 index f74aad8e946..00000000000 --- a/metals/src/main/scala/scala/meta/internal/search/GlobalClassTable.scala +++ /dev/null @@ -1,33 +0,0 @@ -package scala.meta.internal.search -import scala.collection.concurrent.TrieMap - -import scala.meta.internal.metals.BuildTargets -import scala.meta.internal.symtab.GlobalSymbolTable -import scala.meta.io.AbsolutePath -import scala.meta.io.Classpath - -import ch.epfl.scala.bsp4j.BuildTargetIdentifier - -final class GlobalClassTable( - buildTargets: BuildTargets -) { - private val buildTargetsIndexes = - TrieMap.empty[BuildTargetIdentifier, GlobalSymbolTable] - - def globalSymbolTableFor( - source: AbsolutePath - ): Option[GlobalSymbolTable] = - synchronized { - for { - buildTargetId <- buildTargets.inverseSources(source) - jarClasspath <- buildTargets.targetJarClasspath(buildTargetId) - classpath = new Classpath(jarClasspath) - } yield { - buildTargetsIndexes.getOrElseUpdate( - buildTargetId, - GlobalSymbolTable(classpath, includeJdk = true), - ) - } - } - -} diff --git a/metals/src/main/scala/scala/meta/internal/search/SymbolHierarchyOps.scala b/metals/src/main/scala/scala/meta/internal/search/SymbolHierarchyOps.scala index 813b5d0ef9b..b4f4340c4bf 100644 --- a/metals/src/main/scala/scala/meta/internal/search/SymbolHierarchyOps.scala +++ b/metals/src/main/scala/scala/meta/internal/search/SymbolHierarchyOps.scala @@ -22,7 +22,6 @@ import scala.meta.internal.semanticdb.SymbolOccurrence import scala.meta.internal.semanticdb.TextDocument import scala.meta.internal.semanticdb.TypeRef import scala.meta.internal.semanticdb.XtensionSemanticdbSymbolInformation -import scala.meta.internal.symtab.GlobalSymbolTable import scala.meta.io.AbsolutePath import org.eclipse.lsp4j.Location @@ -36,18 +35,14 @@ class SymbolHierarchyOps( buffer: Buffers, trees: Trees, ) { - private val globalTable = new GlobalClassTable(buildTargets) def defaultSymbolSearch( anyWorkspacePath: AbsolutePath, textDocument: TextDocument, - ): String => Option[SymbolInformation] = { - lazy val global = - globalTable.globalSymbolTableFor(anyWorkspacePath) - symbol => { + ): String => Option[SymbolInformation] = { symbol => + { textDocument.symbols .find(_.symbol == symbol) .orElse(findSymbolInformation(symbol)) - .orElse(global.flatMap(_.safeInfo(symbol))) } } @@ -195,15 +190,6 @@ object SymbolHierarchyOps { .find(sym => sym.symbol == symbol) } - implicit class XtensionGlobalSymbolTable(symtab: GlobalSymbolTable) { - def safeInfo(symbol: String): Option[SymbolInformation] = - try { - symtab.info(symbol) - } catch { - case NonFatal(_) => None - } - } - def isClassLike(info: SymbolInformation): Boolean = info.isObject || info.isClass || info.isTrait || info.isInterface diff --git a/metals/src/main/scala/scala/meta/internal/tvp/ClasspathTreeView.scala b/metals/src/main/scala/scala/meta/internal/tvp/ClasspathTreeView.scala index f94ea152f67..26cb95f725d 100644 --- a/metals/src/main/scala/scala/meta/internal/tvp/ClasspathTreeView.scala +++ b/metals/src/main/scala/scala/meta/internal/tvp/ClasspathTreeView.scala @@ -1,7 +1,7 @@ package scala.meta.internal.tvp import scala.meta.internal.metals.Folder -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.mtags.GlobalSymbolIndex import scala.meta.internal.mtags.Symbol import scala.meta.internal.semanticdb.Scala._ diff --git a/metals/src/main/scala/scala/meta/internal/tvp/MetalsTreeViewProvider.scala b/metals/src/main/scala/scala/meta/internal/tvp/MetalsTreeViewProvider.scala index 7ffb0429971..866a85b6ec3 100644 --- a/metals/src/main/scala/scala/meta/internal/tvp/MetalsTreeViewProvider.scala +++ b/metals/src/main/scala/scala/meta/internal/tvp/MetalsTreeViewProvider.scala @@ -7,7 +7,7 @@ import scala.collection.concurrent.TrieMap import scala.meta.Dialect import scala.meta.dialects -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.ReportContext import scala.meta.internal.metals._ import scala.meta.internal.metals.clients.language.MetalsLanguageClient @@ -198,7 +198,7 @@ class MetalsTreeViewProvider( if (params.visible) { params.viewId match { case TreeViewProvider.Project => - val toUpdate = trees.map(_.flushPendingProjectUpdates).collect { + val toUpdate = trees.map(_.flushPendingProjectUpdates()).collect { case Some(value) => value } if (toUpdate.nonEmpty) { diff --git a/metals/src/main/scala/scala/meta/internal/tvp/ScalacpCopyPaste.scala b/metals/src/main/scala/scala/meta/internal/tvp/ScalacpCopyPaste.scala deleted file mode 100644 index 1129a168fd1..00000000000 --- a/metals/src/main/scala/scala/meta/internal/tvp/ScalacpCopyPaste.scala +++ /dev/null @@ -1,498 +0,0 @@ -package scala.meta.internal.tvp - -import java.{util => ju} - -import scala.collection.mutable -import scala.reflect.NameTransformer -import scala.tools.scalap.scalax.rules.scalasig._ - -import scala.meta.internal.scalacp._ -import scala.meta.internal.semanticdb.Scala._ -import scala.meta.internal.semanticdb.Scala.{Descriptor => d} -import scala.meta.internal.semanticdb.Scala.{DisplayNames => dn} -import scala.meta.internal.semanticdb.Scala.{Names => n} -import scala.meta.internal.semanticdb.SymbolInformation.{Kind => k} -import scala.meta.internal.semanticdb.SymbolInformation.{Property => p} -import scala.meta.internal.semanticdb.{Language => l} -import scala.meta.internal.{semanticdb => s} - -/** - * This class contains copy-pasted code from scala.meta.internal.scalacp with minor changes. - * - * If the `Scalacp` class was not final then we could avoid this copy-pasting. Changes are - * documented with "// scalacp deviation" comments. - */ -object ScalacpCopyPaste { - lazy val symbolCache = new ju.HashMap[Symbol, String] - implicit class XtensionSymbolSSymbol(sym: Symbol) { - def toSemantic: String = { - def uncached(sym: Symbol): String = { - if (sym.isSemanticdbGlobal) Symbols.Global(sym.owner, sym.descriptor) - else freshSymbol() - } - val ssym = symbolCache.get(sym) - if (ssym != null) { - ssym - } else { - val ssym = uncached(sym) - symbolCache.put(sym, ssym) - ssym - } - } - } - - implicit class XtensionSymbolSSpec(sym: Symbol) { - def isSemanticdbGlobal: Boolean = !isSemanticdbLocal - def isSemanticdbLocal: Boolean = { - val owner = sym.parent.getOrElse(NoSymbol) - def definitelyGlobal = sym.isPackage - def definitelyLocal = - sym == NoSymbol || - (owner.isInstanceOf[MethodSymbol] && !sym.isParam) || - ((owner.isAlias || (owner.isType && owner.isDeferred)) && !sym.isParam) || - // NOTE: Scalap doesn't expose locals. - // sym.isSelfParameter || - // sym.isLocalDummy || - sym.isRefinementClass || - sym.isAnonymousClass || - sym.isAnonymousFunction || - (sym.isInstanceOf[TypeSymbol] && sym.isExistential) - def ownerLocal = sym.parent.map(_.isSemanticdbLocal).getOrElse(false) - !definitelyGlobal && (definitelyLocal || ownerLocal) - } - def owner: String = { - if (sym.isRootPackage) Symbols.None - else if (sym.isEmptyPackage) Symbols.RootPackage - else if (sym.isToplevelPackage) Symbols.RootPackage - else { - sym.parent match { - case Some(NoSymbol) => "" - case Some(parent) => parent.ssym - case None => sys.error(s"unsupported symbol $sym") - } - } - } - def symbolName: String = { - if (sym.isRootPackage) n.RootPackage.value - else if (sym.isEmptyPackage) n.EmptyPackage.value - else if (sym.isConstructor) n.Constructor.value - else { - def loop(value: String): String = { - val i = value.lastIndexOf("$$") - if (i > 0) loop(value.substring(i + 2)) - else NameTransformer.decode(value).stripSuffix(" ") - } - loop(sym.name) - } - } - def descriptor: Descriptor = { - sym match { - case sym: SymbolInfoSymbol => - sym.kind match { - case k.LOCAL | k.OBJECT | k.PACKAGE_OBJECT => - d.Term(symbolName) - case k.METHOD if sym.isValMethod => - d.Term(symbolName) - case k.METHOD | k.CONSTRUCTOR | k.MACRO => - val overloads = { - val peers = sym.parent.get.semanticdbDecls.syms - peers.filter { - case peer: MethodSymbol => - peer.symbolName == sym.symbolName && !peer.isValMethod - case _ => false - } - } - val disambiguator = { - if (overloads.lengthCompare(1) == 0) "()" - else { - val index = overloads.indexOf(sym) - if (index <= 0) "()" - else s"(+${index})" - } - } - d.Method(symbolName, disambiguator) - case k.TYPE | k.CLASS | k.TRAIT => - d.Type(symbolName) - case k.PACKAGE => - d.Package(symbolName) - case k.PARAMETER => - d.Parameter(symbolName) - case k.TYPE_PARAMETER => - d.TypeParameter(symbolName) - case skind => - sys.error(s"unsupported kind $skind for symbol $sym") - } - case sym: ExternalSymbol => - // scalacp deviation: since we are only interested in definitions (not - // signatures) it's safe to emit `d.Package` for all term references. - if (sym.entry.entryType == 9) d.Type(symbolName) - else if (sym.entry.entryType == 10) d.Package(symbolName) - else d.Type(symbolName) - case NoSymbol => - d.None - } - } - def semanticdbDecls: SemanticdbDecls = { - val decls = - sym.children.filter(decl => decl.isUseful && !decl.isTypeParam) - SemanticdbDecls(decls.toList) - } - } - - implicit class XtensionSymbolsSSpec(syms: Seq[Symbol]) { - def semanticdbDecls: SemanticdbDecls = { - SemanticdbDecls(syms.filter(_.isUseful)) - } - - def sscope(linkMode: LinkMode): s.Scope = { - linkMode match { - case SymlinkChildren => - s.Scope(symlinks = syms.map(_.ssym)) - case HardlinkChildren => - syms.map(registerHardlink) - val hardlinks = syms.map { - case sym: SymbolInfoSymbol => - sym.toSymbolInformation(HardlinkChildren) - case sym => sys.error(s"unsupported symbol $sym") - } - s.Scope(hardlinks = hardlinks) - } - } - } - - case class SemanticdbDecls(syms: Seq[Symbol]) { - def sscope(linkMode: LinkMode): s.Scope = { - linkMode match { - case SymlinkChildren => - val sbuf = List.newBuilder[String] - syms.foreach { sym => - val ssym = sym.ssym - sbuf += ssym - if (sym.isUsefulField && sym.isMutable) { - val setterSymbolName = ssym.desc.name.toString + "_=" - val setterSym = - Symbols.Global(ssym.owner, d.Method(setterSymbolName, "()")) - sbuf += setterSym - } - } - s.Scope(sbuf.result()) - case HardlinkChildren => - val sbuf = List.newBuilder[s.SymbolInformation] - syms.foreach { sym => - registerHardlink(sym) - val sinfo = sym match { - case sym: SymbolInfoSymbol => - sym.toSymbolInformation(HardlinkChildren) - case sym => sys.error(s"unsupported symbol $sym") - } - sbuf += sinfo - if (sym.isUsefulField && sym.isMutable) { - Synthetics.setterInfos(sinfo, HardlinkChildren).foreach(sbuf.+=) - } - } - s.Scope(hardlinks = sbuf.result()) - } - } - } - - implicit class XtensionSymbol(sym: Symbol) { - def ssym: String = sym.toSemantic - def self: Type = - sym match { - case sym: ClassSymbol => - sym.selfType - .map { - case RefinedType(_, List(_, self)) => self - case _ => NoType - } - .getOrElse(NoType) - case _ => - NoType - } - def isRootPackage: Boolean = sym.path == "" - def isEmptyPackage: Boolean = sym.path == "" - def isToplevelPackage: Boolean = sym.parent.isEmpty - def isModuleClass: Boolean = sym.isInstanceOf[ClassSymbol] && sym.isModule - def moduleClass: Symbol = - sym match { - case sym: SymbolInfoSymbol if sym.isModule => - sym.infoType match { - case TypeRefType(_, moduleClass, _) => moduleClass - case _ => NoSymbol - } - case _ => - NoSymbol - } - def isClass: Boolean = sym.isInstanceOf[ClassSymbol] && !sym.isModule - def isObject: Boolean = sym.isInstanceOf[ObjectSymbol] - def isType: Boolean = sym.isInstanceOf[TypeSymbol] - def isAlias: Boolean = sym.isInstanceOf[AliasSymbol] - def isMacro: Boolean = sym.isMethod && sym.hasFlag(0x00008000) - def isConstructor: Boolean = - sym.isMethod && (sym.name == "" || sym.name == "$init$") - def isPackageObject: Boolean = sym.name == "package" - def isTypeParam: Boolean = sym.isType && sym.isParam - def isAnonymousClass: Boolean = sym.name.contains("$anon") - def isAnonymousFunction: Boolean = sym.name.contains("$anonfun") - def isSyntheticConstructor: Boolean = - sym match { - case sym: SymbolInfoSymbol => - val owner = sym.symbolInfo.owner - sym.isConstructor && (owner.isModuleClass || owner.isTrait) - case _ => - false - } - def isLocalChild: Boolean = sym.name == "" - def isExtensionMethod: Boolean = sym.name.contains("$extension") - def isSyntheticValueClassCompanion: Boolean = { - sym match { - case sym: SymbolInfoSymbol => - if (sym.isModuleClass) { - sym.infoType match { - case ClassInfoType(_, List(TypeRefType(_, _, _))) => - sym.isSynthetic && sym.semanticdbDecls.syms.isEmpty - case _ => - false - } - } else if (sym.isModule) { - sym.moduleClass.isSyntheticValueClassCompanion - } else { - false - } - case _ => - false - } - } - def isValMethod: Boolean = { - sym match { - case sym: SymbolInfoSymbol => - sym.kind.isMethod && { - (sym.isAccessor && sym.isStable) || - (isUsefulField && !sym.isMutable) - } - case _ => - false - } - } - def isScalacField: Boolean = { - val isField = sym - .isInstanceOf[MethodSymbol] && !sym.isMethod && !sym.isParam - val isJavaDefined = sym.isJava - isField && !isJavaDefined - } - def isUselessField: Boolean = { - val peers = sym.parent.map(_.children.toList).getOrElse(Nil) - val getter = - peers.find(m => m.isAccessor && m.name == sym.name.stripSuffix(" ")) - sym.isScalacField && getter.nonEmpty - } - def isUsefulField: Boolean = { - sym.isScalacField && !sym.isUselessField - } - def isSyntheticCaseAccessor: Boolean = { - sym.isCaseAccessor && sym.name.contains("$") - } - def isRefinementClass: Boolean = { - sym.name == "" - } - def isUseless: Boolean = { - sym == NoSymbol || - sym.isAnonymousClass || - sym.isSyntheticConstructor || - sym.isModuleClass || - sym.isLocalChild || - sym.isExtensionMethod || - sym.isSyntheticValueClassCompanion || - sym.isUselessField || - sym.isSyntheticCaseAccessor || - sym.isRefinementClass - } - def isUseful: Boolean = !sym.isUseless - def isDefaultParameter: Boolean = { - sym.hasFlag(0x02000000) && sym.isParam - } - } - - private var nextId = 0 - private def freshSymbol(): String = { - val result = Symbols.Local(nextId.toString) - nextId += 1 - result - } - - lazy val hardlinks = new ju.HashSet[String] - private def registerHardlink(sym: Symbol): Unit = { - hardlinks.add(sym.ssym) - } - - private val primaryCtors = mutable.Map[String, Int]() - implicit class XtensionGSymbolSSymbolInformation(sym: SymbolInfoSymbol) { - private def language: s.Language = { - // NOTE: We have no way to figure out whether an external symbol - // comes from Java or Scala. Moreover, we can't even find out - // whether it's a package or an object. Therefore, we default to l.SCALA. - l.SCALA - } - - private[meta] def kind: s.SymbolInformation.Kind = { - sym match { - // NOTE: Scalacp doesn't care about self parameters - // because they are local, i.e. not saved in scala signatures. - // case _ if sym.isSelfParameter => - // k.SELF_PARAMETER - case sym: MethodSymbol if sym.isMethod => - if (sym.isConstructor) k.CONSTRUCTOR - else if (sym.isMacro) k.MACRO - // NOTE: Scalap doesn't expose locals. - // else if (sym.isGetter && sym.isLazy && sym.isLocalToBlock) k.LOCAL - else k.METHOD - case _: ObjectSymbol | _: ClassSymbol if sym.isModule => - if (sym.isPackage) k.PACKAGE - else if (sym.isPackageObject) k.PACKAGE_OBJECT - else k.OBJECT - case sym: MethodSymbol => - // NOTE: This is craziness. In scalap, parameters, val and vars - // are also modelled with method symbols. - if (sym.isParam) k.PARAMETER - // NOTE: Scalap doesn't expose locals. - // else if (gsym.isLocalToBlock) k.LOCAL - // NOTE: Scalap doesn't expose JAVA_ENUM. - else if (sym.isJava /* || sym.isJavaEnum */ ) k.FIELD - else k.METHOD - case sym: ClassSymbol if !sym.isModule => - if (sym.isTrait && sym.isJava) k.INTERFACE - else if (sym.isTrait) k.TRAIT - else k.CLASS - case _: TypeSymbol | _: AliasSymbol => - if (sym.isParam) k.TYPE_PARAMETER - else k.TYPE - case _ => - sys.error(s"unsupported symbol $sym") - } - } - - private[meta] def properties: Int = { - var flags = 0 - def flip(sprop: s.SymbolInformation.Property) = flags |= sprop.value - def isAbstractClass = sym.isClass && sym.isAbstract && !sym.isTrait - def isAbstractMethod = sym.isMethod && sym.isDeferred - def isAbstractType = sym.isType && !sym.isParam && sym.isDeferred - if (sym.isPackage) { - () - } else if (sym.isJava) { - if (isAbstractClass || kind.isInterface || isAbstractMethod) - flip(p.ABSTRACT) - // NOTE: Scalap doesn't expose JAVA_ENUM. - if (sym.isFinal /* || sym.isJavaEnum */ ) flip(p.FINAL) - // NOTE: Scalap doesn't expose JAVA_ENUM. - // if (sym.isJavaEnum) flip(p.ENUM) - if (sym.isStatic) flip(p.STATIC) - ??? - } else { - if (isAbstractClass || isAbstractMethod || isAbstractType) - flip(p.ABSTRACT) - if (sym.isFinal || sym.isModule) flip(p.FINAL) - if (sym.isSealed) flip(p.SEALED) - if (sym.isImplicit) flip(p.IMPLICIT) - if (sym.isLazy) flip(p.LAZY) - if (sym.isCase && (sym.isClass || sym.isModule)) flip(p.CASE) - if (sym.isType && sym.isCovariant) flip(p.COVARIANT) - if (sym.isType && sym.isContravariant) flip(p.CONTRAVARIANT) - // NOTE: Scalap doesn't expose locals. - if (/*kind.isLocal ||*/ sym.isUsefulField) { - if (sym.isMutable) flip(p.VAR) - else flip(p.VAL) - } - if (sym.isAccessor) { - if (sym.isStable) flip(p.VAL) - else flip(p.VAR) - } - if (sym.isParam) { - sym.parent.foreach { - case parent: SymbolInfoSymbol => - if ((parent.properties & p.PRIMARY.value) != 0) { - parent.parent.foreach { grandParent => - val classMembers = grandParent.children - val accessor = - classMembers.find(m => - m.isParamAccessor && m.symbolName == sym.symbolName - ) - accessor.foreach { accessor => - val isStable = { - if (accessor.isMethod) accessor.isStable - else !accessor.isMutable - } - if (!isStable) flip(p.VAR) - else if (accessor.isMethod) flip(p.VAL) - else () - } - } - } - case _ => - () - } - } - if (sym.isConstructor) { - val primaryIndex = - primaryCtors.getOrElseUpdate(sym.path, sym.entry.index) - if (sym.entry.index == primaryIndex) flip(p.PRIMARY) - } - if (sym.isDefaultParameter) flip(p.DEFAULT) - } - flags - } - - private def displayName: String = { - if (sym.isRootPackage) dn.RootPackage - else if (sym.isEmptyPackage) dn.EmptyPackage - else if (sym.isConstructor) dn.Constructor - else if (sym.name.startsWith("_$")) dn.Anonymous - else if (sym.isPackageObject) sym.ssym.owner.desc.value - else sym.symbolName - } - - private def sig(linkMode: LinkMode): s.Signature = - s.NoSignature // scalacp deviation - - private def annotations: List[s.Annotation] = { - Nil // scalacp deviation - } - - private def access: s.Access = { - kind match { - case k.LOCAL | k.PARAMETER | k.SELF_PARAMETER | k.TYPE_PARAMETER | - k.PACKAGE | k.PACKAGE_OBJECT => - s.NoAccess - case _ => - sym.symbolInfo.privateWithin match { - case None => - if (sym.isPrivate && sym.isLocal) s.PrivateThisAccess() - else if (sym.isPrivate) s.PrivateAccess() - else if (sym.isProtected && sym.isLocal) s.ProtectedThisAccess() - else if (sym.isProtected) s.ProtectedAccess() - else s.PublicAccess() - case Some(privateWithin: Symbol) => - val ssym = privateWithin.ssym - if (sym.isProtected) s.ProtectedWithinAccess(ssym) - else s.PrivateWithinAccess(ssym) - case Some(other) => - sys.error(s"unsupported privateWithin: ${other.getClass} $other") - } - } - } - - def toSymbolInformation(linkMode: LinkMode): s.SymbolInformation = { - s.SymbolInformation( - symbol = sym.ssym, - language = language, - kind = kind, - properties = properties, - displayName = displayName, - signature = sig(linkMode), - annotations = annotations, - access = access, - ) - } - } - -} diff --git a/metals/src/main/scala/scala/meta/internal/worksheets/DecorationWorksheetPublisher.scala b/metals/src/main/scala/scala/meta/internal/worksheets/DecorationWorksheetPublisher.scala index 1445c8f0693..2811b87c842 100644 --- a/metals/src/main/scala/scala/meta/internal/worksheets/DecorationWorksheetPublisher.scala +++ b/metals/src/main/scala/scala/meta/internal/worksheets/DecorationWorksheetPublisher.scala @@ -4,7 +4,7 @@ import scala.meta.internal.decorations.DecorationOptions import scala.meta.internal.decorations.PublishDecorationsParams import scala.meta.internal.decorations.ThemableDecorationAttachmentRenderOptions import scala.meta.internal.decorations.ThemableDecorationInstanceRenderOptions -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.clients.language.MetalsLanguageClient import scala.meta.internal.pc.HoverMarkup import scala.meta.internal.worksheets.MdocEnrichments._ diff --git a/metals/src/main/scala/scala/meta/internal/worksheets/MdocEnrichments.scala b/metals/src/main/scala/scala/meta/internal/worksheets/MdocEnrichments.scala index d8ae80113a3..2a039bec292 100644 --- a/metals/src/main/scala/scala/meta/internal/worksheets/MdocEnrichments.scala +++ b/metals/src/main/scala/scala/meta/internal/worksheets/MdocEnrichments.scala @@ -45,7 +45,6 @@ object MdocEnrichments { case i.DiagnosticSeverity.Info => l.DiagnosticSeverity.Information case i.DiagnosticSeverity.Warning => l.DiagnosticSeverity.Warning case i.DiagnosticSeverity.Error => l.DiagnosticSeverity.Error - case _ => l.DiagnosticSeverity.Error }, "mdoc", ) diff --git a/metals/src/main/scala/scala/meta/internal/worksheets/WorksheetProvider.scala b/metals/src/main/scala/scala/meta/internal/worksheets/WorksheetProvider.scala index 66c5110d320..a29830332a2 100644 --- a/metals/src/main/scala/scala/meta/internal/worksheets/WorksheetProvider.scala +++ b/metals/src/main/scala/scala/meta/internal/worksheets/WorksheetProvider.scala @@ -27,7 +27,7 @@ import scala.meta.internal.metals.Compilations import scala.meta.internal.metals.Diagnostics import scala.meta.internal.metals.Embedded import scala.meta.internal.metals.Messages -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.MetalsServerConfig import scala.meta.internal.metals.MutableCancelable import scala.meta.internal.metals.ScalaVersionSelector diff --git a/metals/src/main/scala/scala/meta/internal/worksheets/WorkspaceEditWorksheetPublisher.scala b/metals/src/main/scala/scala/meta/internal/worksheets/WorkspaceEditWorksheetPublisher.scala index 3bafadd3d7a..04704b11192 100644 --- a/metals/src/main/scala/scala/meta/internal/worksheets/WorkspaceEditWorksheetPublisher.scala +++ b/metals/src/main/scala/scala/meta/internal/worksheets/WorkspaceEditWorksheetPublisher.scala @@ -2,7 +2,7 @@ package scala.meta.internal.worksheets import scala.meta.inputs.Input import scala.meta.internal.metals.Buffers -import scala.meta.internal.metals.MetalsEnrichments._ +import scala.meta.internal.metals.MetalsEnrichments.given import scala.meta.internal.metals.clients.language.MetalsLanguageClient import scala.meta.internal.parsing.Trees import scala.meta.internal.pc.HoverMarkup diff --git a/mtags-java/src/main/scala/scala/meta/internal/pc/JavaHover.scala b/mtags-java/src/main/scala/scala/meta/internal/pc/JavaHover.scala index 3e1bb16e996..fbc708ee214 100644 --- a/mtags-java/src/main/scala/scala/meta/internal/pc/JavaHover.scala +++ b/mtags-java/src/main/scala/scala/meta/internal/pc/JavaHover.scala @@ -2,7 +2,7 @@ package scala.meta.internal.pc import java.util.Optional -import scala.meta.internal.mtags.CommonMtagsEnrichments._ +import scala.meta.internal.mtags.CommonMtagsEnrichments.given import scala.meta.pc.ContentType import scala.meta.pc.ContentType.MARKDOWN import scala.meta.pc.HoverSignature diff --git a/mtags/src/main/scala-2/scala/meta/internal/mtags/MtagsEnrichments.scala b/mtags/src/main/scala-2/scala/meta/internal/mtags/MtagsEnrichments.scala index 63c29f3b390..fd38998632d 100644 --- a/mtags/src/main/scala-2/scala/meta/internal/mtags/MtagsEnrichments.scala +++ b/mtags/src/main/scala-2/scala/meta/internal/mtags/MtagsEnrichments.scala @@ -1,44 +1,15 @@ package scala.meta.internal.mtags -import java.net.URI -import java.net.URLDecoder -import java.nio.file.FileSystemNotFoundException -import java.nio.file.NoSuchFileException -import java.nio.file.Paths -import java.util.concurrent.CancellationException - import scala.collection.mutable import scala.reflect.internal.util.Position -import scala.util.Failure -import scala.util.Properties -import scala.util.Success -import scala.util.Try -import scala.{meta => m} -import scala.meta.internal.semanticdb.SymbolInformation.{Property => p} -import scala.meta.io.AbsolutePath import scala.meta.pc.OffsetParams import scala.meta.pc.RangeParams import scala.meta.tokens.Token -import org.eclipse.lsp4j.jsonrpc.CancelChecker -import org.eclipse.{lsp4j => l} - object MtagsEnrichments extends MtagsEnrichments trait MtagsEnrichments extends ScalametaCommonEnrichments { - implicit class XtensionIteratorCollection[T](it: Iterator[T]) { - def headOption: Option[T] = { - if (it.hasNext) Some(it.next()) - else None - } - def lastOption: Option[T] = { - it.foldLeft(Option.empty[T]) { case (_, e) => - Some(e) - } - } - } - implicit class XtensionOffsetParams(params: OffsetParams) { def isDelimiter: Boolean = { params.offset() < 0 || @@ -84,148 +55,6 @@ trait MtagsEnrichments extends ScalametaCommonEnrichments { buf.result() } } - implicit class XtensionCancelChecker(token: CancelChecker) { - def isCancelled: Boolean = - try { - token.checkCanceled() - false - } catch { - case _: CancellationException => - true - } - } - implicit class XtensionSemanticdbProperties(properties: Int) { - def isEnum: Boolean = (properties & p.ENUM.value) != 0 - def isVar: Boolean = (properties & p.VAR.value) != 0 - def isVal: Boolean = (properties & p.VAL.value) != 0 - } - - implicit class XtensionToken(token: Token) { - def isWhiteSpaceOrComment: Boolean = - token match { - case _: Token.Whitespace | _: Token.Comment => - true - case _ => false - } - } - - implicit class XtensionURIMtags(value: URI) { - def toAbsolutePath: AbsolutePath = toAbsolutePath(followSymlink = true) - def toAbsolutePath(followSymlink: Boolean): AbsolutePath = { - val path = - if (value.getScheme() == "jar") - Try { - AbsolutePath(Paths.get(value)) - } match { - case Success(path) => path - case Failure(_) => - // don't close - put up with the resource staying open so all AbsolutePath methods don't have to be wrapped - m.internal.io.PlatformFileIO.newFileSystem( - value, - new java.util.HashMap[String, String]() - ) - AbsolutePath(Paths.get(value)) - } - else - AbsolutePath(Paths.get(value)) - if (followSymlink) - path.dealias - else - path - } - } - - implicit class XtensionStringMtags(value: String) { - - def stripBackticks: String = value.stripPrefix("`").stripSuffix("`") - def isBackticked: Boolean = - value.size > 1 && value.head == '`' && value.last == '`' - def toAbsolutePath: AbsolutePath = toAbsolutePath(true) - def toAbsolutePath(followSymlink: Boolean): AbsolutePath = { - - /* Windows sometimes treats % literally, but not sure if it's always the case. - * https://learn.microsoft.com/en-us/troubleshoot/windows-client/networking/url-encoding-unc-paths-not-url-decoded - * This function tries to apply different heuristics to get the proper file system. - */ - def withTryDecode(value: String)(f: String => AbsolutePath) = { - try { - if (Properties.isWin) f(URLDecoder.decode(value, "UTF-8")) - else f(value) - } catch { - // fallback to try without decoding - case _: NoSuchFileException | _: FileSystemNotFoundException - if Properties.isWin => - f(value) - // prevents infinity recursion and double check for double escaped % - case _: NoSuchFileException | _: FileSystemNotFoundException - if value.contains("%25") => - f(URLDecoder.decode(value, "UTF-8")) - } - } - - // jar schemes must have "jar:file:"" instead of "jar:file%3A" or jar file system won't recognise the URI. - // but don't overdecode as URIs may not be recognised e.g. "com-microsoft-java-debug-core-0.32.0%2B1.jar" is correct - if (value.toUpperCase.startsWith("JAR%3AFILE")) - withTryDecode(value)( - URLDecoder.decode(_, "UTF-8").toAbsolutePath(followSymlink) - ) - else if (value.toUpperCase.startsWith("JAR:FILE%3A")) - withTryDecode(value)( - URLDecoder.decode(_, "UTF-8").toAbsolutePath(followSymlink) - ) - else if (value.toUpperCase.startsWith("JAR")) { - try URI.create(value).toAbsolutePath(followSymlink) - catch { - case _: NoSuchFileException | _: FileSystemNotFoundException => - withTryDecode(value.stripPrefix("jar:"))( - new URI("jar", _, null).toAbsolutePath(followSymlink) - ) - } - } else { - val stripped = value.stripPrefix("metals:") - val percentEncoded = URIEncoderDecoder.encode(stripped) - URI.create(percentEncoded).toAbsolutePath(followSymlink) - } - } - def lastIndexBetween( - char: Char, - lowerBound: Int, - upperBound: Int - ): Int = { - val safeLowerBound = Math.max(0, lowerBound) - var index = upperBound - while (index >= safeLowerBound && value(index) != char) { - index -= 1 - } - if (index < safeLowerBound) -1 else index - } - } - - implicit class XtensionRangeLspInverse(range: l.Range) { - def toLocation(uri: URI): l.Location = new l.Location(uri.toString(), range) - } - - implicit class XtensionPositionLspInverse(pos: l.Position) { - - /** - * LSP position translated to scalameta position. Might return None if - * pos is not contained in input - * - * @param input file input the position relates to - * @return scalameta position with offset if the pos is contained in the file - */ - def toMeta(input: m.Input): Option[m.Position] = { - Try( - m.Position.Range( - input, - pos.getLine, - pos.getCharacter, - pos.getLine, - pos.getCharacter - ) - ).toOption - } - } implicit class XtensionPositionMtags(pos: Position) { def encloses(other: Position): Boolean = diff --git a/mtags/src/main/scala-3/scala/meta/internal/mtags/MtagsEnrichments.scala b/mtags/src/main/scala-3/scala/meta/internal/mtags/MtagsEnrichments.scala index fa70710f208..b2bf24e3975 100644 --- a/mtags/src/main/scala-3/scala/meta/internal/mtags/MtagsEnrichments.scala +++ b/mtags/src/main/scala-3/scala/meta/internal/mtags/MtagsEnrichments.scala @@ -33,7 +33,8 @@ import dotty.tools.dotc.util.Spans import dotty.tools.dotc.util.Spans.Span import org.eclipse.lsp4j as l -object MtagsEnrichments extends ScalametaCommonEnrichments: +object MtagsEnrichments extends MtagsEnrichments +trait MtagsEnrichments extends ScalametaCommonEnrichments: extension (driver: InteractiveDriver) diff --git a/mtags/src/main/scala-2/scala/meta/internal/metals/PositionSyntax.scala b/mtags/src/main/scala/scala/meta/internal/metals/PositionSyntax.scala similarity index 99% rename from mtags/src/main/scala-2/scala/meta/internal/metals/PositionSyntax.scala rename to mtags/src/main/scala/scala/meta/internal/metals/PositionSyntax.scala index 49c48e04757..79a4ccb1dff 100644 --- a/mtags/src/main/scala-2/scala/meta/internal/metals/PositionSyntax.scala +++ b/mtags/src/main/scala/scala/meta/internal/metals/PositionSyntax.scala @@ -67,7 +67,7 @@ object PositionSyntax { .append("\n") .append(pos.lineContent) .append("\n") - .append(pos.lineCaret) + .append(lineCaret) .toString() } def multilines: String = { diff --git a/mtags/src/main/scala-2/scala/meta/internal/metals/URIEncoderDecoder.scala b/mtags/src/main/scala/scala/meta/internal/metals/URIEncoderDecoder.scala similarity index 95% rename from mtags/src/main/scala-2/scala/meta/internal/metals/URIEncoderDecoder.scala rename to mtags/src/main/scala/scala/meta/internal/metals/URIEncoderDecoder.scala index 091fcad4497..db34109fd65 100644 --- a/mtags/src/main/scala-2/scala/meta/internal/metals/URIEncoderDecoder.scala +++ b/mtags/src/main/scala/scala/meta/internal/metals/URIEncoderDecoder.scala @@ -6,7 +6,7 @@ object URIEncoderDecoder { // Currently Metals doesn't encode `:` but does decode it private val toEscape: Map[Char, String] = Set('"', '<', '>', '&', '\'', '[', ']', '{', '}', ' ', '+', '!') - .map(char => char -> ("%" + char.toHexString)) + .map(char => char -> ("%" + char.toInt.toHexString)) .toMap private val toDecode: Map[String, Char] = toEscape.map { case (k, v) => diff --git a/mtags/src/main/scala/scala/meta/internal/mtags/ScalametaCommonEnrichments.scala b/mtags/src/main/scala/scala/meta/internal/mtags/ScalametaCommonEnrichments.scala index 50d5c12a218..ff97cbc15a7 100644 --- a/mtags/src/main/scala/scala/meta/internal/mtags/ScalametaCommonEnrichments.scala +++ b/mtags/src/main/scala/scala/meta/internal/mtags/ScalametaCommonEnrichments.scala @@ -1,18 +1,23 @@ package scala.meta.internal.mtags import java.net.URI +import java.net.URLDecoder import java.nio.charset.Charset import java.nio.charset.StandardCharsets +import java.nio.file.FileSystemNotFoundException import java.nio.file.Files +import java.nio.file.NoSuchFileException import java.nio.file.Path import java.nio.file.Paths import java.nio.file.StandardCopyOption import java.nio.file.StandardOpenOption +import java.util.concurrent.CancellationException import java.util.logging.Level import java.util.logging.Logger import scala.annotation.tailrec import scala.util.Failure +import scala.util.Properties import scala.util.Success import scala.util.Try import scala.util.control.NonFatal @@ -24,6 +29,7 @@ import scala.meta.internal.io.FileIO import scala.meta.internal.io.PathIO import scala.meta.internal.semanticdb.Language import scala.meta.internal.semanticdb.SymbolInformation.{Kind => k} +import scala.meta.internal.semanticdb.SymbolInformation.{Property => p} import scala.meta.internal.{semanticdb => s} import scala.meta.io.AbsolutePath import scala.meta.io.RelativePath @@ -586,4 +592,163 @@ trait ScalametaCommonEnrichments extends CommonMtagsEnrichments { } + implicit class XtensionToken(token: m.Token) { + def isWhiteSpaceOrComment: Boolean = + token match { + case _: m.Token.Space | _: m.Token.Tab | _: m.Token.CR | _: m.Token.LF | + _: m.Token.LFLF | _: m.Token.FF | _: m.Token.Comment | + _: m.Token.BOF | _: m.Token.EOF => + true + case _ => false + } + } + + implicit class XtensionURIMtags(value: URI) { + def toAbsolutePath: AbsolutePath = toAbsolutePath(followSymlink = true) + def toAbsolutePath(followSymlink: Boolean): AbsolutePath = { + val path = + if (value.getScheme() == "jar") + Try { + AbsolutePath(Paths.get(value)) + } match { + case Success(path) => path + case Failure(_) => + // don't close - put up with the resource staying open so all AbsolutePath methods don't have to be wrapped + m.internal.io.PlatformFileIO.newFileSystem( + value, + new java.util.HashMap[String, String]() + ) + AbsolutePath(Paths.get(value)) + } + else + AbsolutePath(Paths.get(value)) + if (followSymlink) + path.dealias + else + path + } + } + + implicit class XtensionIteratorCollection[T](it: Iterator[T]) { + def headOption: Option[T] = { + if (it.hasNext) Some(it.next()) + else None + } + def lastOption: Option[T] = { + it.foldLeft(Option.empty[T]) { case (_, e) => + Some(e) + } + } + } + + implicit class XtensionSemanticdbProperties(properties: Int) { + def isEnum: Boolean = (properties & p.ENUM.value) != 0 + def isVar: Boolean = (properties & p.VAR.value) != 0 + def isVal: Boolean = (properties & p.VAL.value) != 0 + } + + implicit class XtensionStringMtags(value: String) { + + def stripBackticks: String = value.stripPrefix("`").stripSuffix("`") + def isBackticked: Boolean = + value.size > 1 && value.head == '`' && value.last == '`' + def toAbsolutePath: AbsolutePath = toAbsolutePath(true) + def toAbsolutePath(followSymlink: Boolean): AbsolutePath = { + + /* Windows sometimes treats % literally, but not sure if it's always the case. + * https://learn.microsoft.com/en-us/troubleshoot/windows-client/networking/url-encoding-unc-paths-not-url-decoded + * This function tries to apply different heuristics to get the proper file system. + */ + def withTryDecode(value: String)(f: String => AbsolutePath) = { + try { + if (Properties.isWin) f(URLDecoder.decode(value, "UTF-8")) + else f(value) + } catch { + // fallback to try without decoding + case _: FileSystemNotFoundException if Properties.isWin => + f(value) + // prevents infinity recursion and double check for double escaped % + case _: NoSuchFileException | _: FileSystemNotFoundException + if value.contains("%25") => + f(URLDecoder.decode(value, "UTF-8")) + } + } + + // jar schemes must have "jar:file:"" instead of "jar:file%3A" or jar file system won't recognise the URI. + // but don't overdecode as URIs may not be recognised e.g. "com-microsoft-java-debug-core-0.32.0%2B1.jar" is correct + if (value.toUpperCase.startsWith("JAR%3AFILE")) + withTryDecode(value)( + URLDecoder.decode(_, "UTF-8").toAbsolutePath(followSymlink) + ) + else if (value.toUpperCase.startsWith("JAR:FILE%3A")) + withTryDecode(value)( + URLDecoder.decode(_, "UTF-8").toAbsolutePath(followSymlink) + ) + else if (value.toUpperCase.startsWith("JAR")) { + try URI.create(value).toAbsolutePath(followSymlink) + catch { + case _: NoSuchFileException | _: FileSystemNotFoundException => + withTryDecode(value.stripPrefix("jar:"))( + new URI("jar", _, null).toAbsolutePath(followSymlink) + ) + } + } else { + val stripped = value.stripPrefix("metals:") + val percentEncoded = URIEncoderDecoder.encode(stripped) + URI.create(percentEncoded).toAbsolutePath(followSymlink) + } + } + def lastIndexBetween( + char: Char, + lowerBound: Int, + upperBound: Int + ): Int = { + val safeLowerBound = Math.max(0, lowerBound) + var index = upperBound + while (index >= safeLowerBound && value(index) != char) { + index -= 1 + } + if (index < safeLowerBound) -1 else index + } + } + + implicit class XtensionPositionLspInverse(pos: l.Position) { + + /** + * LSP position translated to scalameta position. Might return None if + * pos is not contained in input + * + * @param input file input the position relates to + * @return scalameta position with offset if the pos is contained in the file + */ + def toMeta(input: m.Input): Option[m.Position] = { + Try( + m.Position.Range( + input, + pos.getLine, + pos.getCharacter, + pos.getLine, + pos.getCharacter + ) + ).toOption + } + } + + // TODO make sure everything was ported + + implicit class XtensionRangeLspInverse(range: l.Range) { + def toLocation(uri: URI): l.Location = new l.Location(uri.toString(), range) + } + + implicit class XtensionCancelChecker(token: l.jsonrpc.CancelChecker) { + def isCancelled: Boolean = + try { + token.checkCanceled() + false + } catch { + case _: CancellationException => + true + } + } + } diff --git a/mtags/src/main/scala-2/scala/meta/internal/pc/LogMessages.scala b/mtags/src/main/scala/scala/meta/internal/pc/LogMessages.scala similarity index 100% rename from mtags/src/main/scala-2/scala/meta/internal/pc/LogMessages.scala rename to mtags/src/main/scala/scala/meta/internal/pc/LogMessages.scala diff --git a/project/JavaPcSettings.scala b/project/JavaPcSettings.scala index 54ae3b9d89d..372ddbe58a5 100644 --- a/project/JavaPcSettings.scala +++ b/project/JavaPcSettings.scala @@ -12,7 +12,7 @@ object JavaPcSettings { prj.settings( sharedSettings, moduleName := "mtags-java", - scalaVersion := V.scala213, + scalaVersion := V.scala3, currentJavaHome := file(System.getProperty("java.home")), currentJavaVersion := { val version = System.getProperty("java.version") diff --git a/tests/cross/src/main/scala/tests/BaseExtractMethodSuite.scala b/tests/cross/src/main/scala/tests/BaseExtractMethodSuite.scala index 480bc0125f1..320ca0e3471 100644 --- a/tests/cross/src/main/scala/tests/BaseExtractMethodSuite.scala +++ b/tests/cross/src/main/scala/tests/BaseExtractMethodSuite.scala @@ -10,7 +10,6 @@ import scala.meta.internal.metals.TextEdits import munit.Location import munit.TestOptions import org.eclipse.{lsp4j => l} -import tests.BaseCodeActionSuite class BaseExtractMethodSuite extends BaseCodeActionSuite { def checkEdit( diff --git a/tests/slow/src/test/scala/tests/feature/InlayHintsScala3ExpectSuite.scala b/tests/slow/src/test/scala/tests/feature/InlayHintsScala2ExpectSuite.scala similarity index 80% rename from tests/slow/src/test/scala/tests/feature/InlayHintsScala3ExpectSuite.scala rename to tests/slow/src/test/scala/tests/feature/InlayHintsScala2ExpectSuite.scala index 1af8ead0daf..8f4143b7f7d 100644 --- a/tests/slow/src/test/scala/tests/feature/InlayHintsScala3ExpectSuite.scala +++ b/tests/slow/src/test/scala/tests/feature/InlayHintsScala2ExpectSuite.scala @@ -5,15 +5,15 @@ import scala.meta.pc.PresentationCompiler import tests.BaseInlayHintsExpectSuite import tests.InputProperties -import tests.TestScala3Compiler +import tests.TestScala2Compiler -class InlayHintsScala3ExpectSuite( +class InlayHintsScala2ExpectSuite( ) extends BaseInlayHintsExpectSuite( "inlayHints3", InputProperties.scala3(), ) { override val compiler: PresentationCompiler = { - TestScala3Compiler.compiler("inlayHints", input)( + TestScala2Compiler.compiler("inlayHints", input)( munitExecutionContext ) match { case Some(pc) => pc diff --git a/tests/slow/src/test/scala/tests/feature/RenameCrossLspSuite.scala b/tests/slow/src/test/scala/tests/feature/RenameCrossLspSuite.scala index 4f018c19673..3e0f4a007db 100644 --- a/tests/slow/src/test/scala/tests/feature/RenameCrossLspSuite.scala +++ b/tests/slow/src/test/scala/tests/feature/RenameCrossLspSuite.scala @@ -7,45 +7,47 @@ import tests.BaseRenameLspSuite class RenameCrossLspSuite extends BaseRenameLspSuite("rename-cross") { renamed( - "scala3-outer", + "macro", """|/a/src/main/scala/a/Main.scala - | - |@main def run() = { - | <>("Mark") - | <>("Anne") - |} - |def <>(name : String) : Unit = { - | println(s"Hello $name") + |package a + |import io.circe.generic.JsonCodec + |trait LivingBeing + |@JsonCodec sealed trait <> extends LivingBeing + |object <> { + | case object Dog extends <> + | case object Cat extends <> |} |""".stripMargin, - newName = "greeting", - scalaVersion = Some(V.scala3), + "Tree", + scalaVersion = Some(V.scala213), ) renamed( - "scala3-extension-params", + "macro1", """|/a/src/main/scala/a/Main.scala - | - |extension (<>: String) - | def double = <> + <> - | def double2 = <> + <> - |end extension + |package a + |import io.circe.generic.JsonCodec + |trait <> + |@JsonCodec sealed trait Animal extends <> + |object Animal { + | case object Dog extends Animal + | case object Cat extends Animal + |} |""".stripMargin, - newName = "greeting", - scalaVersion = Some(V.scala3), + "Tree", + scalaVersion = Some(V.scala213), ) renamed( - "scala3-extension-params-ref", + "macro2", """|/a/src/main/scala/a/Main.scala - | - |extension (<>: String) - | def double = <> + <> - | def double2 = <> + <> - |end extension + |package a + |import io.circe.generic.JsonCodec + |@JsonCodec + |final case class <>(name: String) |""".stripMargin, - newName = "greeting", - scalaVersion = Some(V.scala3), + "Tree", + scalaVersion = Some(V.scala213), ) renamed( @@ -65,4 +67,60 @@ class RenameCrossLspSuite extends BaseRenameLspSuite("rename-cross") { scalaVersion = Some(V.scala3), ) + renamed( + "macro3", + """|/a/src/main/scala/a/Main.scala + |package a + |import io.circe.generic.JsonCodec + |trait LivingBeing + |@JsonCodec sealed trait <> extends LivingBeing + |object <>{ + | case object Dog extends <> + | case object Cat extends <> + |} + |/a/src/main/scala/a/Use.scala + |package a + |object Use { + | val dog : <> = <>.Dog + |} + |""".stripMargin, + "Tree", + scalaVersion = Some(V.scala213), + ) + + renamed( + "colon-good", + """|/a/src/main/scala/a/Main.scala + |package a + |class User{ + | def <<:@@:>>(name : String) = name + |} + |object Main{ + | val user = new User() + | "" <<::>> user + |} + |""".stripMargin, + newName = "+++:", + ) + + renamed( + "apply", + """|/a/src/main/scala/a/Main.scala + |package a + |object User{ + | def <>(name : String) = name + | def apply(name : String, age: Int) = name + |} + |object Main{ + | val toRename = User##.##<<>>("abc") + |} + |""".stripMargin, + newName = "name", + ) + + override protected def libraryDependencies: List[String] = + List("org.scalatest::scalatest:3.2.12", "io.circe::circe-generic:0.14.1") + + override def scalacOptions: List[String] = List("-Ymacro-annotations") + } diff --git a/tests/slow/src/test/scala/tests/feature/SemanticTokensScala3ExpectSuite.scala b/tests/slow/src/test/scala/tests/feature/SemanticTokensScala3ExpectSuite.scala index bcfd4a69157..5a354e3b33d 100644 --- a/tests/slow/src/test/scala/tests/feature/SemanticTokensScala3ExpectSuite.scala +++ b/tests/slow/src/test/scala/tests/feature/SemanticTokensScala3ExpectSuite.scala @@ -9,16 +9,17 @@ import scala.meta.internal.metals.{BuildInfo => V} import tests.DirectoryExpectSuite import tests.ExpectTestCase import tests.InputProperties -import tests.TestScala3Compiler +import tests.TestScala2Compiler import tests.TestSemanticTokens -class SemanticTokensScala3ExpectSuite( -) extends DirectoryExpectSuite("semanticTokens3") { - override lazy val input: InputProperties = InputProperties.scala3() +class SemanticTokensScala2ExpectSuite( +) extends DirectoryExpectSuite("semanticTokens") { + override lazy val input: InputProperties = InputProperties.scala2() + private val compiler = - TestScala3Compiler.compiler("tokens", input)(munitExecutionContext) match { + TestScala2Compiler.compiler("tokens", input)(munitExecutionContext) match { case Some(pc) => pc - case _ => fail(s"Could not load ${V.scala3} presentation compiler") + case _ => fail(s"Could not load ${V.scala213} presentation compiler") } override def testCases(): List[ExpectTestCase] = { @@ -36,7 +37,7 @@ class SemanticTokensScala3ExpectSuite( val tokens = SemanticTokensProvider.provide( nodes, params, - isScala3 = true, + isScala3 = false, ) TestSemanticTokens.semanticString( diff --git a/tests/slow/src/test/scala/tests/feature/SlowSaveExpect.scala b/tests/slow/src/test/scala/tests/feature/SlowSaveExpect.scala index 8a3d55a40aa..17a2549aea2 100644 --- a/tests/slow/src/test/scala/tests/feature/SlowSaveExpect.scala +++ b/tests/slow/src/test/scala/tests/feature/SlowSaveExpect.scala @@ -5,8 +5,8 @@ import tests.BaseExpectSuite object SlowSaveExpect { def main(args: Array[String]): Unit = { List[BaseExpectSuite]( - new SemanticTokensScala3ExpectSuite(), - new InlayHintsScala3ExpectSuite(), + new SemanticTokensScala2ExpectSuite(), + new InlayHintsScala2ExpectSuite(), ).foreach { suite => val header = suite.suiteName.length + 2 println("=" * header) diff --git a/tests/slow/src/test/scala/tests/feature/WorksheetCrossLspSuite.scala b/tests/slow/src/test/scala/tests/feature/WorksheetCrossLspSuite.scala index 822c8eaa0f7..218c1ee8d14 100644 --- a/tests/slow/src/test/scala/tests/feature/WorksheetCrossLspSuite.scala +++ b/tests/slow/src/test/scala/tests/feature/WorksheetCrossLspSuite.scala @@ -8,15 +8,6 @@ import coursierapi.Complete class Worksheet211LspSuite extends tests.BaseWorksheetLspSuite(V.scala211) -class Worksheet3LspSuite extends tests.BaseWorksheetLspSuite(V.scala3) { - override def versionSpecificCodeToValidate: String = - """given str: String = """"" - - override def versionSpecificScalacOptionsToValidate: List[String] = List( - "-Ycheck-reentrant" - ) -} - class LatestWorksheet3LspSuite extends tests.BaseWorksheetLspSuite( V.supportedScala3Versions @@ -53,3 +44,59 @@ object Worksheet3NextSuite { } class Worksheet212LspSuite extends tests.BaseWorksheetLspSuite(V.scala212) + +class Worksheet213LspSuite extends tests.BaseWorksheetLspSuite(V.scala213) { + + test("akka") { + cleanWorkspace() + val path = "hi.worksheet.sc" + for { + _ <- initialize( + s""" + |/metals.json + |{ + | "a": {} + |} + |/${path} + |import $$dep.`com.typesafe.akka::akka-stream:2.6.13` + | + |import akka.actor.ActorSystem + |import akka.NotUsed + |import akka.stream.scaladsl.Source + |import akka.stream.scaladsl.Sink + |import java.io.File + |import scala.concurrent.Await + |import scala.concurrent.duration.DurationInt + | + | + |implicit val system: ActorSystem = ActorSystem("QuickStart") + |val source: Source[Int, NotUsed] = Source(1 to 2) + |val future = source.runWith(Sink.foreach(_ => ())) + |Await.result(future, 3.seconds) + | + |""".stripMargin + ) + _ <- server.didOpen(path) + _ = assertNoDiff( + // it seems that part of the string is always different, so let's remove it + client.workspaceDecorations(path).replaceAll(".out\\(.*", ".out(..."), + """|import $dep.`com.typesafe.akka::akka-stream:2.6.13` + | + |import akka.actor.ActorSystem + |import akka.NotUsed + |import akka.stream.scaladsl.Source + |import akka.stream.scaladsl.Sink + |import java.io.File + |import scala.concurrent.Await + |import scala.concurrent.duration.DurationInt + | + | + |implicit val system: ActorSystem = ActorSystem("QuickStart") // : ActorSystem = akka://QuickStart + |val source: Source[Int, NotUsed] = Source(1 to 2) // : Source[Int, NotUsed] = Source(SourceShape(StatefulMapConcat.out(... + |val future = source.runWith(Sink.foreach(_ => ())) // : concurrent.Future[akka.Done] = Future(Success(Done)) + |Await.result(future, 3.seconds) // : akka.Done = Done + |""".stripMargin, + ) + } yield () + } +} diff --git a/tests/unit/src/main/scala/bill/Bill.scala b/tests/unit/src/main/scala/bill/Bill.scala index 6911afb5059..781a9d2aeb4 100644 --- a/tests/unit/src/main/scala/bill/Bill.scala +++ b/tests/unit/src/main/scala/bill/Bill.scala @@ -20,12 +20,6 @@ import scala.concurrent.Await import scala.concurrent.ExecutionContext.Implicits.global import scala.concurrent.Future import scala.concurrent.duration.Duration -import scala.reflect.internal.util.BatchSourceFile -import scala.reflect.internal.{util => r} -import scala.reflect.io.AbstractFile -import scala.reflect.io.VirtualFile -import scala.tools.nsc -import scala.tools.nsc.reporters.StoreReporter import scala.util.Try import scala.util.control.NonFatal @@ -36,6 +30,7 @@ import scala.meta.internal.metals.MetalsEnrichments._ import scala.meta.internal.metals.PositionSyntax._ import scala.meta.internal.metals.RecursivelyDelete import scala.meta.internal.mtags +import scala.meta.internal.pc.ScalaPresentationCompiler import scala.meta.io.AbsolutePath import ch.epfl.scala.bsp4j._ @@ -43,6 +38,12 @@ import ch.epfl.scala.{bsp4j => b} import com.google.gson.GsonBuilder import coursierapi.Dependency import coursierapi.Fetch +import dotty.tools.dotc.interfaces.Diagnostic as DottyDiagnostic +import dotty.tools.dotc.reporting.StoreReporter +import dotty.tools.dotc.util.SourceFile +import dotty.tools.dotc.util.SourcePosition +import dotty.tools.dotc.util.Spans +import dotty.tools.io.AbstractFile import org.eclipse.lsp4j.jsonrpc.Launcher /** @@ -147,17 +148,11 @@ object Bill { result.setDataKind("scala") result } - val reporter = new StoreReporter val out: AbsolutePath = AbsolutePath(workspace.resolve("out.jar")) Files.createDirectories(out.toNIO.getParent()) - lazy val g: nsc.Global = { - val settings = new nsc.Settings() - settings.classpath.value = - myClasspath.map(_.toString).mkString(File.pathSeparator) - settings.Yrangepos.value = true - settings.d.value = out.toString - new nsc.Global(settings, reporter) - } + lazy val driver = + ScalaPresentationCompiler(classpath = myClasspath).newDriver + val reporter = new StoreReporter() override def buildInitialize( params: InitializeBuildParams @@ -236,7 +231,7 @@ object Bill { val scalaLib = Dependency.of( "org.scala-lang", "scala-library", - mtags.BuildInfo.scalaCompilerVersion, + BuildInfo.scala213, ) CompletableFuture.completedFuture { @@ -264,12 +259,15 @@ object Bill { private val hasError = mutable.Set.empty[AbstractFile] def publishDiagnostics(): Unit = { - val byFile = reporter.infos.groupBy(_.pos.source.file) + val byFile = reporter + .pendingMessages(using driver.currentCtx) + .groupBy(_.pos.source.file) + val fixedErrors = hasError.filterNot(byFile.contains) fixedErrors.foreach { file => client.onBuildPublishDiagnostics( new PublishDiagnosticsParams( - new TextDocumentIdentifier(file.name), + new TextDocumentIdentifier(file.path), target.getId, List().asJava, true, @@ -278,32 +276,33 @@ object Bill { } hasError --= fixedErrors byFile.foreach { case (file, infos) => - def toBspPos(pos: r.Position, offset: Int): b.Position = { + def toBspPos(pos: SourcePosition, offset: Int): b.Position = { val line = pos.source.offsetToLine(offset) val column0 = pos.source.lineToOffset(line) val column = offset - column0 new b.Position(line, column) } val diagnostics = infos.iterator - .filter(_.pos.isDefined) + .filter(_.pos.span != Spans.NoSpan) .map { info => val p = info.pos val start = - toBspPos(info.pos, if (p.isRange) p.start else p.point) + toBspPos(info.pos, if (p.span.isZeroExtent) p.point else p.start) val end = - toBspPos(info.pos, if (p.isRange) p.end else p.point) - val severity = info.severity match { - case reporter.ERROR => DiagnosticSeverity.ERROR - case reporter.WARNING => DiagnosticSeverity.WARNING - case reporter.INFO => DiagnosticSeverity.INFORMATION + toBspPos(info.pos, if (p.span.isZeroExtent) p.point else p.end) + val severity = info.level match { + case DottyDiagnostic.ERROR => DiagnosticSeverity.ERROR + case DottyDiagnostic.WARNING => DiagnosticSeverity.WARNING + case DottyDiagnostic.INFO => DiagnosticSeverity.INFORMATION case _ => DiagnosticSeverity.HINT } - val diagnostic = new Diagnostic(new b.Range(start, end), info.msg) + val diagnostic = + new Diagnostic(new b.Range(start, end), info.message) diagnostic.setSeverity(severity) diagnostic } .toList - val uri = file.name + val uri = file.path val params = new PublishDiagnosticsParams( new TextDocumentIdentifier(uri), @@ -325,27 +324,22 @@ object Bill { ) } CompletableFuture.completedFuture { - reporter.reset() - val run = new g.Run() - val sources: List[BatchSourceFile] = - if (Files.isDirectory(src)) { - Files - .walk(src) - .collect(Collectors.toList()) - .asScala - .iterator - .filter(_.getFileName.toString.endsWith(".scala")) - .map(path => { - val text = - new String(Files.readAllBytes(path), StandardCharsets.UTF_8) - val chars = text.toCharArray - new BatchSourceFile(new VirtualFile(path.toUri.toString), chars) - }) - .toList - } else { - Nil - } - run.compileSources(sources) + if (Files.isDirectory(src)) { + Files + .walk(src) + .collect(Collectors.toList()) + .asScala + .iterator + .filter(_.getFileName.toString.endsWith(".scala")) + .foreach(path => { + val text = + new String(Files.readAllBytes(path), StandardCharsets.UTF_8) + val source = SourceFile.virtual(path.toUri().toString, text) + + val diags = driver.run(path.toUri, source) + diags.foreach(reporter.doReport(_)(using driver.currentCtx)) + }) + } publishDiagnostics() val exit = if (reporter.hasErrors) StatusCode.ERROR @@ -387,6 +381,7 @@ object Bill { ) } } + override def buildTargetScalaTestClasses( params: ScalaTestClassesParams ): CompletableFuture[ScalaTestClassesResult] = diff --git a/tests/unit/src/main/scala/scala/meta/internal/metals/debug/Debugger.scala b/tests/unit/src/main/scala/scala/meta/internal/metals/debug/Debugger.scala index cba3e10bd73..b38b4795d9d 100644 --- a/tests/unit/src/main/scala/scala/meta/internal/metals/debug/Debugger.scala +++ b/tests/unit/src/main/scala/scala/meta/internal/metals/debug/Debugger.scala @@ -127,9 +127,6 @@ final class Debugger(server: RemoteServer)(implicit ec: ExecutionContext) { callback(completions) step(threadId, DebugStep.Continue) } - case cause => - val error = s"Unsupported debug step $cause" - Future.failed(new IllegalStateException(error)) } } diff --git a/tests/unit/src/main/scala/tests/BaseAnalyzeStacktraceSuite.scala b/tests/unit/src/main/scala/tests/BaseAnalyzeStacktraceSuite.scala index fde1cab9837..7bd910d7282 100644 --- a/tests/unit/src/main/scala/tests/BaseAnalyzeStacktraceSuite.scala +++ b/tests/unit/src/main/scala/tests/BaseAnalyzeStacktraceSuite.scala @@ -34,7 +34,7 @@ abstract class BaseAnalyzeStacktraceSuite(name: String) code: String, stacktrace: String, filename: String = "Main.scala", - scalaVersion: String = V.scala213, + scalaVersion: String = V.scala3, dependency: String = "", )(implicit loc: munit.Location): Unit = { val locationParser = new JsonParser.Of[l.Location] diff --git a/tests/unit/src/main/scala/tests/BaseInlayHintsLspSuite.scala b/tests/unit/src/main/scala/tests/BaseInlayHintsLspSuite.scala index e5de66e1533..b8730b7ce06 100644 --- a/tests/unit/src/main/scala/tests/BaseInlayHintsLspSuite.scala +++ b/tests/unit/src/main/scala/tests/BaseInlayHintsLspSuite.scala @@ -2,8 +2,6 @@ package tests import munit.Location import munit.TestOptions -import tests.BaseLspSuite -import tests.TestInlayHints abstract class BaseInlayHintsLspSuite(name: String, scalaVersion: String) extends BaseLspSuite(name) { diff --git a/tests/unit/src/main/scala/tests/BaseLspSuite.scala b/tests/unit/src/main/scala/tests/BaseLspSuite.scala index f8ba9ee1d37..27f37a8e969 100644 --- a/tests/unit/src/main/scala/tests/BaseLspSuite.scala +++ b/tests/unit/src/main/scala/tests/BaseLspSuite.scala @@ -124,16 +124,16 @@ abstract class BaseLspSuite( } } if (withoutVirtualDocs) { - test(testOpts.withName(s"${testOpts.name}-readonly")) { + super.test(testOpts.withName(s"${testOpts.name}-readonly")) { functionRetry(maxRetry) } - test( + super.test( testOpts .withName(s"${testOpts.name}-virtualdoc") .withTags(Set(TestingServer.virtualDocTag)) ) { functionRetry(maxRetry) } } else { - test(testOpts)(functionRetry(maxRetry)) + super.test(testOpts)(functionRetry(maxRetry)) } } @@ -177,12 +177,15 @@ abstract class BaseLspSuite( } override def beforeEach(context: BeforeEach): Unit = { - cancelServer() if (context.test.tags.contains(Ignore)) return useVirtualDocs = context.test.tags.contains(TestingServer.virtualDocTag) newServer(context.test.name) } + override def afterEach(context: AfterEach): Unit = { + cancelServer() + } + protected def createWorkspace(name: String): AbsolutePath = { val pathToSuite = PathIO.workingDirectory .resolve("target") diff --git a/tests/unit/src/main/scala/tests/BaseRenameLspSuite.scala b/tests/unit/src/main/scala/tests/BaseRenameLspSuite.scala index f6900414300..83f587e050e 100644 --- a/tests/unit/src/main/scala/tests/BaseRenameLspSuite.scala +++ b/tests/unit/src/main/scala/tests/BaseRenameLspSuite.scala @@ -2,7 +2,8 @@ package tests import scala.concurrent.Future -import scala.meta.internal.pc.Identifier +import scala.meta.internal.metals.ScalaVersions +import scala.meta.internal.mtags.KeywordWrapper import munit.Location import munit.TestOptions @@ -11,6 +12,7 @@ abstract class BaseRenameLspSuite(name: String) extends BaseLspSuite(name) { protected def libraryDependencies: List[String] = Nil protected def compilerPlugins: List[String] = Nil + protected def scalacOptions: List[String] = Nil def same( name: String, @@ -64,7 +66,12 @@ abstract class BaseRenameLspSuite(name: String) extends BaseLspSuite(name) { cleanWorkspace() val allMarkersRegex = "(<<|>>|@@|##.*##)" val files = FileLayout.mapFromString(input) - val expectedName = Identifier.backtickWrap(newName) + val actualScalaVersion = scalaVersion.getOrElse(BuildInfo.scalaVersion) + val expectedName = + if (ScalaVersions.isScala3Version(actualScalaVersion)) + KeywordWrapper.Scala3.backtickWrap(newName) + else + KeywordWrapper.Scala2.backtickWrap(newName) val expectedFiles = files.map { case (file, code) => fileRenames.getOrElse(file, file) -> { val expected = if (!notRenamed) { @@ -128,7 +135,7 @@ abstract class BaseRenameLspSuite(name: String) extends BaseLspSuite(name) { | "scalaVersion": "$actualScalaVersion", | "compilerPlugins": ${toJsonArray(compilerPlugins)}, | "libraryDependencies": ${toJsonArray(libraryDependencies)}, - | "scalacOptions" : ["-Ymacro-annotations"] + | "scalacOptions" : ${toJsonArray(scalacOptions)} | }, | "b" : { | "scalaVersion": "$actualScalaVersion", diff --git a/tests/unit/src/main/scala/tests/BaseWorksheetLspSuite.scala b/tests/unit/src/main/scala/tests/BaseWorksheetLspSuite.scala index be6ffbfb91e..59e03a0c679 100644 --- a/tests/unit/src/main/scala/tests/BaseWorksheetLspSuite.scala +++ b/tests/unit/src/main/scala/tests/BaseWorksheetLspSuite.scala @@ -731,11 +731,11 @@ abstract class BaseWorksheetLspSuite( ) _ <- server.didOpen("a/src/main/scala/foo/Main.worksheet.sc") _ <- server.didSave("a/src/main/scala/foo/Main.worksheet.sc")(identity) - export = server.exportEvaluation( + exportedEvaluation = server.exportEvaluation( "a/src/main/scala/foo/Main.worksheet.sc" ) _ = assertEquals( - export, + exportedEvaluation, Some( getExpected( """| @@ -780,11 +780,11 @@ abstract class BaseWorksheetLspSuite( "Hi(7, 8, 9)", ) ) - export = server.exportEvaluation( + exportedEvaluation = server.exportEvaluation( "a/src/main/scala/foo/Main.worksheet.sc" ) _ = assertEquals( - export, + exportedEvaluation, Some( getExpected( """| diff --git a/tests/unit/src/main/scala/tests/BuildServerInitializer.scala b/tests/unit/src/main/scala/tests/BuildServerInitializer.scala index 6b72e24ef1b..c8eb064f92c 100644 --- a/tests/unit/src/main/scala/tests/BuildServerInitializer.scala +++ b/tests/unit/src/main/scala/tests/BuildServerInitializer.scala @@ -34,7 +34,6 @@ sealed trait BuildServerInitializer { * This will take your `metals.json` file and quickly produce `.bloop/` files from it. */ object QuickBuildInitializer extends BuildServerInitializer { - this: BaseLspSuite => override def initialize( workspace: AbsolutePath, server: TestingServer, @@ -65,7 +64,6 @@ object QuickBuildInitializer extends BuildServerInitializer { * run Bloop Install via the build tool being used. */ object BloopImportInitializer extends BuildServerInitializer { - this: BaseLspSuite => override def initialize( workspace: AbsolutePath, server: TestingServer, @@ -93,7 +91,6 @@ object BloopImportInitializer extends BuildServerInitializer { * with sbt as the build server. */ object SbtServerInitializer extends BuildServerInitializer { - this: BaseLspSuite => override def initialize( workspace: AbsolutePath, server: TestingServer, @@ -173,7 +170,6 @@ object SbtServerInitializer extends BuildServerInitializer { } object MillServerInitializer extends BuildServerInitializer { - this: BaseLspSuite => override def initialize( workspace: AbsolutePath, server: TestingServer, @@ -197,7 +193,6 @@ object MillServerInitializer extends BuildServerInitializer { } object BazelServerInitializer extends BuildServerInitializer { - this: BaseLspSuite => override def initialize( workspace: AbsolutePath, server: TestingServer, diff --git a/tests/unit/src/main/scala/tests/Library.scala b/tests/unit/src/main/scala/tests/Library.scala index 2f5daa8b16a..d7f9a425d39 100644 --- a/tests/unit/src/main/scala/tests/Library.scala +++ b/tests/unit/src/main/scala/tests/Library.scala @@ -5,7 +5,7 @@ import scala.jdk.CollectionConverters._ import scala.meta.internal.metals.JdkSources import scala.meta.internal.metals.PackageIndex import scala.meta.internal.metals.ScalaVersions -import scala.meta.internal.mtags +import scala.meta.internal.metals.{BuildInfo => V} import scala.meta.io.AbsolutePath import scala.meta.io.Classpath @@ -63,7 +63,6 @@ object Library { .filter(_.toString.endsWith("bindings-rxjava-2.0.0-sources.jar")) def allScala2: List[Library] = { - import mtags.BuildInfo.scalaCompilerVersion val dependencies = List( Dependency.of("com.lihaoyi", "acyclic_2.12", "0.1.8"), @@ -78,7 +77,7 @@ object Library { Dependency.of("org.apache.spark", "spark-sql_2.11", "2.2.1"), Dependency.of("org.eclipse.jetty", "jetty-servlet", "9.3.11.v20160721"), Dependency.of("org.scalameta", "scalameta_2.12", "4.1.4"), - Dependency.of("org.scala-lang", "scala-compiler", scalaCompilerVersion), + Dependency.of("org.scala-lang", "scala-compiler", V.scala213), ) List(fetchSources("scala2-suite", dependencies)) } diff --git a/tests/unit/src/main/scala/tests/QuickBuild.scala b/tests/unit/src/main/scala/tests/QuickBuild.scala index 8b8fa726763..11e25a7225d 100644 --- a/tests/unit/src/main/scala/tests/QuickBuild.scala +++ b/tests/unit/src/main/scala/tests/QuickBuild.scala @@ -76,7 +76,7 @@ case class QuickBuild( def withId(id: String): QuickBuild = QuickBuild( id, - if (scalaVersion == null) V.scala213 + if (scalaVersion == null) V.scala3 else scalaVersion, orEmpty(libraryDependencies), orEmpty(compilerPlugins), @@ -371,7 +371,7 @@ object QuickBuild { val newDigest = { val digest = MessageDigest.getInstance("MD5") digest.update(version.getBytes(StandardCharsets.UTF_8)) - digest.update(V.scala213.getBytes(StandardCharsets.UTF_8)) + digest.update(V.scala3.getBytes(StandardCharsets.UTF_8)) def update(file: AbsolutePath): Unit = { if (file.isFile) { digest.update(file.readAllBytes) diff --git a/tests/unit/src/main/scala/tests/TestScala3Compiler.scala b/tests/unit/src/main/scala/tests/TestScala3Compiler.scala index 0c47cfda507..cb004bfb3d8 100644 --- a/tests/unit/src/main/scala/tests/TestScala3Compiler.scala +++ b/tests/unit/src/main/scala/tests/TestScala3Compiler.scala @@ -11,16 +11,12 @@ import scala.meta.internal.metals.WorkDoneProgress import scala.meta.internal.metals.{BuildInfo => V} import scala.meta.pc.PresentationCompiler -import tests.InputProperties -import tests.TestMtagsResolver -import tests.TestingClient - -object TestScala3Compiler { +object TestScala2Compiler { def compiler(name: String, input: InputProperties)(implicit ec: ExecutionContext ): Option[PresentationCompiler] = { val resolver = new TestMtagsResolver(checkCoursier = true) - resolver.resolve(V.scala3) match { + resolver.resolve(V.scala213) match { case Some(mtags: MtagsBinaries.Artifacts) => val time = new FakeTime val client = new TestingClient(PathIO.workingDirectory, Buffers()) diff --git a/tests/unit/src/main/scala/tests/TestingClient.scala b/tests/unit/src/main/scala/tests/TestingClient.scala index 424a4d1175a..bb0a1c4b5da 100644 --- a/tests/unit/src/main/scala/tests/TestingClient.scala +++ b/tests/unit/src/main/scala/tests/TestingClient.scala @@ -357,7 +357,7 @@ class TestingClient(workspace: AbsolutePath, val buffers: Buffers) showMessageRequestHandler(params).getOrElse { if (isSameMessage(ImportBuildChanges.params)) { importBuildChanges - } else if (isSameGenerateBspAndConnectMessage) { + } else if (isSameGenerateBspAndConnectMessage()) { generateBspAndConnect } else if (isSameMessage(ImportBuild.params)) { importBuild diff --git a/tests/unit/src/main/scala/tests/codeactions/BaseCodeActionLspSuite.scala b/tests/unit/src/main/scala/tests/codeactions/BaseCodeActionLspSuite.scala index 6350030fa41..a4c0492a3b0 100644 --- a/tests/unit/src/main/scala/tests/codeactions/BaseCodeActionLspSuite.scala +++ b/tests/unit/src/main/scala/tests/codeactions/BaseCodeActionLspSuite.scala @@ -15,7 +15,7 @@ abstract class BaseCodeActionLspSuite( suiteName: String ) extends BaseLspSuite(suiteName) { - protected val scalaVersion: String = V.scala213 + protected val scalaVersion: String = V.scala3 def checkNoAction( name: TestOptions, diff --git a/tests/unit/src/main/scala/tests/debug/BaseStackFrameDapSuite.scala b/tests/unit/src/main/scala/tests/debug/BaseStackFrameDapSuite.scala index 1aff518ed63..f9be84cefce 100644 --- a/tests/unit/src/main/scala/tests/debug/BaseStackFrameDapSuite.scala +++ b/tests/unit/src/main/scala/tests/debug/BaseStackFrameDapSuite.scala @@ -134,13 +134,17 @@ abstract class BaseStackFrameDapSuite( | } |}""".stripMargin, expectedFrames = List( + inScopeLocal( + assertNoDiff(_, "args: String[]"), + assertNoDiff(_, "this: Main$"), + ), inScopeLocal( assertNoDiff(_, "value: int = 1"), - assertNoDiff(_, "MODULE$: Main$"), + assertNoDiff(_, "this: Main$"), ), inScopeLocal( assertNoDiff(_, "value: int = 2"), - assertNoDiff(_, "MODULE$: Main$"), + assertNoDiff(_, "this: Main$"), ), ), ) @@ -158,23 +162,28 @@ abstract class BaseStackFrameDapSuite( |} |""".stripMargin, expectedFrames = List( + inScopeLocal( + assertNoDiff(_, "args: String[]"), + assertNoDiff(_, "this: Main$"), + ), // before calculating `z` inScopeLocal( assertNoDiff(_, "x: int = 1"), - assertNoDiff(_, "MODULE$: Main$"), + assertNoDiff(_, "this: Main$"), ), // after calculating `z` inScopeLocal( assertNoDiff(_, "x: int = 1"), assertNoDiff(_, "z: int = 3"), - assertNoDiff(_, "MODULE$: Main$"), + assertNoDiff(_, "this: Main$"), ), inScopeLocal( v => { assert(v.contains("x$1: Tuple2$mcII$sp")) assert(v.contains("\"(1,3)\"")) }, - assertNoDiff(_, "MODULE$: Main$"), + assertNoDiff(_, "x: int = 1"), + assertNoDiff(_, "this: Main$"), ), ), ) diff --git a/tests/unit/src/test/scala/tests/BillLspSuite.scala b/tests/unit/src/test/scala/tests/BillLspSuite.scala index 3ee4e79973a..f23cfc82b9b 100644 --- a/tests/unit/src/test/scala/tests/BillLspSuite.scala +++ b/tests/unit/src/test/scala/tests/BillLspSuite.scala @@ -30,13 +30,11 @@ class BillLspSuite extends BaseLspSuite("bill") { _ <- server.didOpen("src/com/App.scala") _ = assertNoDiff( client.workspaceDiagnostics, - """ - |src/com/App.scala:2:16: error: type mismatch; - | found : String("") - | required: Int - | val x: Int = "" - | ^^ - """.stripMargin, + """|src/com/App.scala:2:16: error: Found: ("" : String) + |Required: Int + | val x: Int = "" + | ^^ + |""".stripMargin, ) _ <- server.didSave("src/com/App.scala")(_ => "object App") _ = assertNoDiff( diff --git a/tests/unit/src/test/scala/tests/BuildTargetsLspSuite.scala b/tests/unit/src/test/scala/tests/BuildTargetsLspSuite.scala index 3fe7d8b7c2c..339c1a21cfe 100644 --- a/tests/unit/src/test/scala/tests/BuildTargetsLspSuite.scala +++ b/tests/unit/src/test/scala/tests/BuildTargetsLspSuite.scala @@ -18,7 +18,7 @@ class BuildTargetsLspSuite | }, | "b": { | "scalaVersion": "${BuildInfo.scalaVersion}", - | "libraryDependencies": ["com.lihaoyi::sourcecode:0.1.7"], + | "libraryDependencies": ["com.lihaoyi::sourcecode:0.2.7"], | "additionalSources": [ "shared/Main.scala" ] | } |} diff --git a/tests/unit/src/test/scala/tests/CascadeLspSuite.scala b/tests/unit/src/test/scala/tests/CascadeLspSuite.scala index 160ddeb4899..38bafcbcfee 100644 --- a/tests/unit/src/test/scala/tests/CascadeLspSuite.scala +++ b/tests/unit/src/test/scala/tests/CascadeLspSuite.scala @@ -37,12 +37,11 @@ class CascadeLspSuite extends BaseLspSuite("cascade") { // but not independent project "c". _ = assertNoDiff( client.workspaceDiagnostics, - """|b/src/main/scala/b/B.scala:3:19: error: type mismatch; - | found : Int - | required: String + """|b/src/main/scala/b/B.scala:3:19: error: Found: (a.A.n : Int) + |Required: String | val n: String = a.A.n | ^^^^^ - """.stripMargin, + |""".stripMargin, ) } yield () } diff --git a/tests/unit/src/test/scala/tests/CodeLensLspSuite.scala b/tests/unit/src/test/scala/tests/CodeLensLspSuite.scala index 17375fbc62a..36b33a3ad29 100644 --- a/tests/unit/src/test/scala/tests/CodeLensLspSuite.scala +++ b/tests/unit/src/test/scala/tests/CodeLensLspSuite.scala @@ -72,7 +72,7 @@ class CodeLensLspSuite extends BaseCodeLensLspSuite("codeLenses") { check( "test-suite-object", - library = Some("com.lihaoyi::utest:0.7.3"), + library = Some("com.lihaoyi::utest:0.8.1"), minExpectedLenses = 3, )( """|package foo.bar diff --git a/tests/unit/src/test/scala/tests/CompletionLspSuite.scala b/tests/unit/src/test/scala/tests/CompletionLspSuite.scala index f5dab5f2f34..e8180e6173f 100644 --- a/tests/unit/src/test/scala/tests/CompletionLspSuite.scala +++ b/tests/unit/src/test/scala/tests/CompletionLspSuite.scala @@ -11,7 +11,7 @@ class CompletionLspSuite extends BaseCompletionLspSuite("completion") { override def munitIgnore: Boolean = isWindows test("basic-213") { - basicTest(V.scala213) + basicTest(V.scala3) } test("workspace".flaky) { diff --git a/tests/unit/src/test/scala/tests/DiagnosticsLspSuite.scala b/tests/unit/src/test/scala/tests/DiagnosticsLspSuite.scala index 8dfab761903..bb283203023 100644 --- a/tests/unit/src/test/scala/tests/DiagnosticsLspSuite.scala +++ b/tests/unit/src/test/scala/tests/DiagnosticsLspSuite.scala @@ -14,12 +14,12 @@ class DiagnosticsLspSuite extends BaseLspSuite("diagnostics") { |{ | "a": { | "scalacOptions": [ - | "-Ywarn-unused" + | "-Wunused:all" | ] | }, | "b": { | "scalacOptions": [ - | "-Ywarn-unused" + | "-Wunused:all" | ] | } |} @@ -43,21 +43,21 @@ class DiagnosticsLspSuite extends BaseLspSuite("diagnostics") { _ = assertNoDiff(client.workspaceDiagnostics, "") _ <- server.didOpen("a/src/main/scala/a/Main.scala") exampleDiagnostics = { - """|a/src/main/scala/a/Example.scala:2:1: warning: Unused import + """|a/src/main/scala/a/Example.scala:2:29: warning: unused import |import java.util.concurrent.Future // unused - |^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ - |a/src/main/scala/a/Example.scala:3:1: warning: Unused import + | ^^^^^^ + |a/src/main/scala/a/Example.scala:3:19: warning: unused import |import scala.util.Failure // unused - |^^^^^^^^^^^^^^^^^^^^^^^^^ + | ^^^^^^^ |""".stripMargin } mainDiagnostics = { - """|a/src/main/scala/a/Main.scala:2:1: warning: Unused import + """|a/src/main/scala/a/Main.scala:2:29: warning: unused import |import java.util.concurrent.Future // unused - |^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ - |a/src/main/scala/a/Main.scala:3:1: warning: Unused import + | ^^^^^^ + |a/src/main/scala/a/Main.scala:3:19: warning: unused import |import scala.util.Failure // unused - |^^^^^^^^^^^^^^^^^^^^^^^^^ + | ^^^^^^^ |""".stripMargin } _ = assertNoDiff( @@ -66,12 +66,12 @@ class DiagnosticsLspSuite extends BaseLspSuite("diagnostics") { ) _ <- server.didOpen("b/src/main/scala/a/MainSuite.scala") testDiagnostics = { - """|b/src/main/scala/a/MainSuite.scala:2:1: warning: Unused import + """|b/src/main/scala/a/MainSuite.scala:2:29: warning: unused import |import java.util.concurrent.Future // unused - |^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ - |b/src/main/scala/a/MainSuite.scala:3:1: warning: Unused import + | ^^^^^^ + |b/src/main/scala/a/MainSuite.scala:3:19: warning: unused import |import scala.util.Failure // unused - |^^^^^^^^^^^^^^^^^^^^^^^^^ + | ^^^^^^^ |""".stripMargin } _ = assertNoDiff( @@ -79,17 +79,17 @@ class DiagnosticsLspSuite extends BaseLspSuite("diagnostics") { testDiagnostics, ) // This seems to be currently broken on CI - diagnostics not being refreshed - // _ <- server.didSave("b/src/main/scala/a/MainSuite.scala")( - // _.linesIterator.filterNot(_.startsWith("import")).mkString("\n") - // ) - // _ = assertNoDiff( - // client.workspaceDiagnostics, - // exampleDiagnostics + mainDiagnostics - // ) - // _ <- server.didSave("a/src/main/scala/a/Main.scala")( - // _.linesIterator.filterNot(_.startsWith("import")).mkString("\n") - // ) - // _ = assertNoDiff(client.workspaceDiagnostics, exampleDiagnostics) + _ <- server.didSave("b/src/main/scala/a/MainSuite.scala")( + _.linesIterator.filterNot(_.startsWith("import")).mkString("\n") + ) + _ = assertNoDiff( + client.workspaceDiagnostics, + exampleDiagnostics + mainDiagnostics, + ) + _ <- server.didSave("a/src/main/scala/a/Main.scala")( + _.linesIterator.filterNot(_.startsWith("import")).mkString("\n") + ) + _ = assertNoDiff(client.workspaceDiagnostics, exampleDiagnostics) } yield () } @@ -179,7 +179,10 @@ class DiagnosticsLspSuite extends BaseLspSuite("diagnostics") { _ <- server.didOpen("a/src/main/scala/a/Deprecation.scala") _ = assertNoDiff( client.workspaceDiagnostics, - """|a/src/main/scala/a/Deprecation.scala:3:16: error: value Stream in package scala is deprecated (since 2.13.0): Use LazyList instead of Stream + """|a/src/main/scala/a/Deprecation.scala:3:13: error: class Stream in package scala.collection.immutable is deprecated since 2.13.0: Use LazyList (which is fully lazy) instead of Stream (which has a lazy tail only) + | val stream = Stream.empty + | ^ + |a/src/main/scala/a/Deprecation.scala:3:16: error: getter Stream in package scala is deprecated since 2.13.0: Use LazyList instead of Stream | val stream = Stream.empty | ^^^^^^ |""".stripMargin, @@ -248,9 +251,8 @@ class DiagnosticsLspSuite extends BaseLspSuite("diagnostics") { _ <- server.didOpen("a/src/main/scala/a/B.scala") _ = assertNoDiff( client.workspaceDiagnostics, - """|a/src/main/scala/a/B.scala:3:19: error: type mismatch; - | found : Int(42) - | required: String + """|a/src/main/scala/a/B.scala:3:19: error: Found: (42 : Int) + |Required: String | val x: String = 42 | ^^ |""".stripMargin, @@ -287,9 +289,8 @@ class DiagnosticsLspSuite extends BaseLspSuite("diagnostics") { _ <- server.didOpen("a/src/main/scala/a/A.scala") _ = assertNoDiff( client.workspaceDiagnostics, - """|a/src/main/scala/a/B.scala:2:19: error: type mismatch; - | found : Int(2) - | required: String + """|a/src/main/scala/a/B.scala:2:19: error: Found: (2 : Int) + |Required: String | val a: String = 2 | ^ |""".stripMargin, @@ -320,9 +321,8 @@ class DiagnosticsLspSuite extends BaseLspSuite("diagnostics") { _ <- server.didOpen("a/weird/path/A.scala") _ = assertNoDiff( client.workspaceDiagnostics, - """|a/weird/path/A.scala:2:16: error: type mismatch; - | found : String("") - | required: Int + """|a/weird/path/A.scala:2:16: error: Found: ("" : String) + |Required: Int | val n: Int = "" | ^^ |""".stripMargin, @@ -348,9 +348,8 @@ class DiagnosticsLspSuite extends BaseLspSuite("diagnostics") { _ <- server.didOpen("a/src/main/scala/a/A.scala") _ = assertNoDiff( client.workspaceDiagnostics, - """|a/src/main/scala/a/A.scala:2:16: error: type mismatch; - | found : String("") - | required: Int + """|a/src/main/scala/a/A.scala:2:16: error: Found: ("" : String) + |Required: Int | val n: Int = "" | ^^ |""".stripMargin, diff --git a/tests/unit/src/test/scala/tests/DidFocusLspSuite.scala b/tests/unit/src/test/scala/tests/DidFocusLspSuite.scala index 82028556f37..f18cc4338ae 100644 --- a/tests/unit/src/test/scala/tests/DidFocusLspSuite.scala +++ b/tests/unit/src/test/scala/tests/DidFocusLspSuite.scala @@ -177,9 +177,8 @@ class DidFocusWhileCompilingLspSuite _ <- server.didOpen("b/src/main/scala/b/B.scala") _ = assertNoDiagnostics() xMismatch = { - """|a/src/main/scala/a/A.scala:3:16: error: type mismatch; - | found : String("") - | required: Int + """|a/src/main/scala/a/A.scala:3:16: error: Found: ("" : String) + |Required: Int | val x: Int = "" | ^^ |""".stripMargin @@ -204,9 +203,8 @@ class DidFocusWhileCompilingLspSuite ) _ = assertNoDiff( client.workspaceDiagnostics, - """|b/src/main/scala/b/B.scala:3:16: error: type mismatch; - | found : String("") - | required: Int + """|b/src/main/scala/b/B.scala:3:16: error: Found: ("" : String) + |Required: Int | val y: Int = "" | ^^ |""".stripMargin, diff --git a/tests/unit/src/test/scala/tests/FindTextInDependencyJarsSuite.scala b/tests/unit/src/test/scala/tests/FindTextInDependencyJarsSuite.scala index cc6acd57d44..5fa609a730f 100644 --- a/tests/unit/src/test/scala/tests/FindTextInDependencyJarsSuite.scala +++ b/tests/unit/src/test/scala/tests/FindTextInDependencyJarsSuite.scala @@ -49,20 +49,19 @@ class FindTextInDependencyJarsSuite assertLocations( akkaLocations, - s"""| - |akka-actor_2.12-${akkaVersion}.jar/reference.conf:96:3: info: result - | jvm-shutdown-hooks = on - | ^^^^^^^^^^^^^^^^^^ - |akka-actor_2.12-${akkaVersion}.jar/reference.conf:1178:41: info: result - | # This property is related to `akka.jvm-shutdown-hooks` above. - | ^^^^^^^^^^^^^^^^^^ - |akka-actor_2.12-${akkaVersion}-sources.jar/reference.conf:96:3: info: result - | jvm-shutdown-hooks = on - | ^^^^^^^^^^^^^^^^^^ - |akka-actor_2.12-${akkaVersion}-sources.jar/reference.conf:1178:41: info: result - | # This property is related to `akka.jvm-shutdown-hooks` above. - | ^^^^^^^^^^^^^^^^^^ - |""".stripMargin, + """|akka-actor_2.12-2.6.16.jar/reference.conf:96:3: info: result + | jvm-shutdown-hooks = on + | ^^^^^^^^^^^^^^^^^^ + |akka-actor_2.12-2.6.16.jar/reference.conf:1178:41: info: result + | # This property is related to `akka.jvm-shutdown-hooks` above. + | ^^^^^^^^^^^^^^^^^^ + |akka-actor_2.12-2.6.16-sources.jar/reference.conf:96:3: info: result + | jvm-shutdown-hooks = on + | ^^^^^^^^^^^^^^^^^^ + |akka-actor_2.12-2.6.16-sources.jar/reference.conf:1178:41: info: result + | # This property is related to `akka.jvm-shutdown-hooks` above. + | ^^^^^^^^^^^^^^^^^^ + |""".stripMargin, ) assertLocations( diff --git a/tests/unit/src/test/scala/tests/HoverLspSuite.scala b/tests/unit/src/test/scala/tests/HoverLspSuite.scala index 961440772e2..baea86a6d2a 100644 --- a/tests/unit/src/test/scala/tests/HoverLspSuite.scala +++ b/tests/unit/src/test/scala/tests/HoverLspSuite.scala @@ -72,7 +72,7 @@ class HoverLspSuite extends BaseLspSuite("hover-") with TestHovers { for { _ <- initialize( s"""|/metals.json - |{"a":{"scalaVersion" : ${V.scala213}}} + |{"a":{"scalaVersion" : ${V.scala3}}} |/Main.scala |object Main extends App { | // @@ diff --git a/tests/unit/src/test/scala/tests/NewFileLspSuite.scala b/tests/unit/src/test/scala/tests/NewFileLspSuite.scala index 4d12ddc008f..efe1c65a4df 100644 --- a/tests/unit/src/test/scala/tests/NewFileLspSuite.scala +++ b/tests/unit/src/test/scala/tests/NewFileLspSuite.scala @@ -583,7 +583,7 @@ class NewFileLspSuite extends BaseLspSuite("new-file") { scalaVersion: Option[String], )(implicit loc: Location): Unit = test(testName) { - val localScalaVersion = scalaVersion.getOrElse(V.scala213) + val localScalaVersion = scalaVersion.getOrElse(V.scala3) val directoryUri = directory.fold(null.asInstanceOf[String])( workspace.resolve(_).toURI.toString() ) diff --git a/tests/unit/src/test/scala/tests/RenameLspSuite.scala b/tests/unit/src/test/scala/tests/RenameLspSuite.scala index a2d0f1af639..ef2cf538690 100644 --- a/tests/unit/src/test/scala/tests/RenameLspSuite.scala +++ b/tests/unit/src/test/scala/tests/RenameLspSuite.scala @@ -1,6 +1,7 @@ package tests import scala.meta.internal.metals.InitializationOptions +import scala.meta.internal.metals.{BuildInfo => V} class RenameLspSuite extends BaseRenameLspSuite(s"rename") { @@ -296,8 +297,9 @@ class RenameLspSuite extends BaseRenameLspSuite(s"rename") { |""".stripMargin, ) + // https://github.com/lampepfl/dotty/issues/18389 renamed( - "colon-good", + "colon-good".ignore, """|/a/src/main/scala/a/Main.scala |package a |class User{ @@ -521,67 +523,6 @@ class RenameLspSuite extends BaseRenameLspSuite(s"rename") { expectedError = true, ) - renamed( - "macro", - """|/a/src/main/scala/a/Main.scala - |package a - |import io.circe.generic.JsonCodec - |trait LivingBeing - |@JsonCodec sealed trait <> extends LivingBeing - |object <> { - | case object Dog extends <> - | case object Cat extends <> - |} - |""".stripMargin, - "Tree", - ) - - renamed( - "macro1", - """|/a/src/main/scala/a/Main.scala - |package a - |import io.circe.generic.JsonCodec - |trait <> - |@JsonCodec sealed trait Animal extends <> - |object Animal { - | case object Dog extends Animal - | case object Cat extends Animal - |} - |""".stripMargin, - "Tree", - ) - - renamed( - "macro2", - """|/a/src/main/scala/a/Main.scala - |package a - |import io.circe.generic.JsonCodec - |@JsonCodec - |final case class <>(name: String) - |""".stripMargin, - "Tree", - ) - - renamed( - "macro3", - """|/a/src/main/scala/a/Main.scala - |package a - |import io.circe.generic.JsonCodec - |trait LivingBeing - |@JsonCodec sealed trait <> extends LivingBeing - |object <>{ - | case object Dog extends <> - | case object Cat extends <> - |} - |/a/src/main/scala/a/Use.scala - |package a - |object Use { - | val dog : <> = <>.Dog - |} - |""".stripMargin, - "Tree", - ) - renamed( "implicit-param", """|/a/src/main/scala/a/Main.scala @@ -922,6 +863,48 @@ class RenameLspSuite extends BaseRenameLspSuite(s"rename") { nonOpened = Set("b/src/main/scala/b/B.scala"), ) + renamed( + "scala3-outer", + """|/a/src/main/scala/a/Main.scala + | + |@main def run() = { + | <>("Mark") + | <>("Anne") + |} + |def <>(name : String) : Unit = { + | println(s"Hello $name") + |} + |""".stripMargin, + newName = "greeting", + scalaVersion = Some(V.scala3), + ) + + renamed( + "scala3-extension-params", + """|/a/src/main/scala/a/Main.scala + | + |extension (<>: String) + | def double = <> + <> + | def double2 = <> + <> + |end extension + |""".stripMargin, + newName = "greeting", + scalaVersion = Some(V.scala3), + ) + + renamed( + "scala3-extension-params-ref", + """|/a/src/main/scala/a/Main.scala + | + |extension (<>: String) + | def double = <> + <> + | def double2 = <> + <> + |end extension + |""".stripMargin, + newName = "greeting", + scalaVersion = Some(V.scala3), + ) + override protected def libraryDependencies: List[String] = List("org.scalatest::scalatest:3.2.12", "io.circe::circe-generic:0.14.1") diff --git a/tests/unit/src/test/scala/tests/ResetWorkspaceLspSuite.scala b/tests/unit/src/test/scala/tests/ResetWorkspaceLspSuite.scala index df388220557..35cc545ee8a 100644 --- a/tests/unit/src/test/scala/tests/ResetWorkspaceLspSuite.scala +++ b/tests/unit/src/test/scala/tests/ResetWorkspaceLspSuite.scala @@ -58,9 +58,8 @@ class ResetWorkspaceLspSuite extends BaseLspSuite(s"reset-workspace") { ) _ = assertNoDiff( client.workspaceDiagnostics, - """|a/src/main/scala/b/B.scala:4:19: error: type mismatch; - | found : Int(42) - | required: String + """|a/src/main/scala/b/B.scala:4:19: error: Found: (42 : Int) + |Required: String | val x: String = 42 | ^^ |""".stripMargin, diff --git a/tests/unit/src/test/scala/tests/SemanticTokensExpectSuite.scala b/tests/unit/src/test/scala/tests/SemanticTokensExpectSuite.scala index f554da1d439..ca97601441e 100644 --- a/tests/unit/src/test/scala/tests/SemanticTokensExpectSuite.scala +++ b/tests/unit/src/test/scala/tests/SemanticTokensExpectSuite.scala @@ -6,9 +6,10 @@ import scala.meta.internal.metals.MetalsEnrichments._ import scala.meta.internal.metals.SemanticTokensProvider import scala.meta.internal.pc.ScalaPresentationCompiler -class SemanticTokensExpectSuite extends DirectoryExpectSuite("semanticTokens") { +class SemanticTokensExpectSuite + extends DirectoryExpectSuite("semanticTokens3") { - override lazy val input: InputProperties = InputProperties.scala2() + override lazy val input: InputProperties = InputProperties.scala3() private val compiler = new ScalaPresentationCompiler( classpath = input.classpath.entries.map(_.toNIO) ) @@ -27,7 +28,7 @@ class SemanticTokensExpectSuite extends DirectoryExpectSuite("semanticTokens") { val tokens = SemanticTokensProvider.provide( nodes, params, - isScala3 = false, + isScala3 = true, ) TestSemanticTokens.semanticString( diff --git a/tests/unit/src/test/scala/tests/SuperHierarchyLspSuite.scala b/tests/unit/src/test/scala/tests/SuperHierarchyLspSuite.scala index 5d021d81e63..4e867c6b7f8 100644 --- a/tests/unit/src/test/scala/tests/SuperHierarchyLspSuite.scala +++ b/tests/unit/src/test/scala/tests/SuperHierarchyLspSuite.scala @@ -82,22 +82,26 @@ class SuperHierarchyLspSuite extends BaseLspSuite("super-method-hierarchy") { val code = """ |package a - |import io.circe.Decoder + |import java.nio.file.FileSystem + |import java.nio.file.FileStore | - |trait CustomDecoder[X] extends Decoder[String] { - | override def <<1>>apply(c: io.circe.HCursor): Decoder.Result[String] = ??? - |} + |trait CustomFileSystem extends FileSystem { + | override def <<1>>close(): Unit = ??? | - |class CustomXDecoder extends CustomDecoder[Unit] { - | override def <<2>>apply(c: io.circe.HCursor): Decoder.Result[String] = ??? + | override def <<2>>getFileStores(): java.lang.Iterable[FileStore] = ??? |} | + | |""".stripMargin checkHierarchy( code, Map( - 1 -> List("io.circe.Decoder#apply"), - 2 -> List("a.CustomDecoder#apply", "io.circe.Decoder#apply"), + 1 -> List( + "java.nio.file.FileSystem#close", + "java.io.Closeable#close", + "java.lang.AutoCloseable#close", + ), + 2 -> List("java.nio.file.FileSystem#getFileStores"), ), ) } @@ -110,9 +114,7 @@ class SuperHierarchyLspSuite extends BaseLspSuite("super-method-hierarchy") { |/metals.json |{ | "a": { - | "libraryDependencies": [ - | "io.circe::circe-generic:0.12.0" - | ] + | "libraryDependencies": [] | } |} |/a/src/main/scala/a/A.scala diff --git a/tests/unit/src/test/scala/tests/SuperMethodLspSuite.scala b/tests/unit/src/test/scala/tests/SuperMethodLspSuite.scala index 42c632a62e0..f5f0e6373c0 100644 --- a/tests/unit/src/test/scala/tests/SuperMethodLspSuite.scala +++ b/tests/unit/src/test/scala/tests/SuperMethodLspSuite.scala @@ -217,10 +217,11 @@ class SuperMethodLspSuite extends BaseLspSuite("gotosupermethod") { val code = """ |package a - |import io.circe.Decoder | - |trait CustomDecoder extends Decoder[String] { - | override def <<1->50>>apply(c: io.circe.HCursor): Decoder.Result[String] = ??? + |import java.nio.file.FileSystem + | + |trait CustomFileSystem extends FileSystem { + | override def <<4->50>>close(): Unit = ??? |} | |""".stripMargin @@ -270,7 +271,6 @@ class SuperMethodLspSuite extends BaseLspSuite("gotosupermethod") { |{ | "a": { | "libraryDependencies": [ - | "io.circe::circe-generic:0.12.0" | ] | } |} diff --git a/tests/unit/src/test/scala/tests/TreeViewLspSuite.scala b/tests/unit/src/test/scala/tests/TreeViewLspSuite.scala index 994631ee87e..2e049c480db 100644 --- a/tests/unit/src/test/scala/tests/TreeViewLspSuite.scala +++ b/tests/unit/src/test/scala/tests/TreeViewLspSuite.scala @@ -7,6 +7,7 @@ import scala.util.Properties import scala.meta.internal.metals.InitializationOptions import scala.meta.internal.metals.JdkVersion +import scala.meta.internal.metals.BuildInfo as V import scala.meta.internal.metals.UserConfiguration import scala.meta.internal.tvp.TreeViewProvider import scala.meta.io.AbsolutePath @@ -203,18 +204,19 @@ class TreeViewLspSuite extends BaseLspSuite("tree-view") { test("libraries", withoutVirtualDocs = true) { for { _ <- initialize( - """ - |/metals.json - |{ - | "a": { - | "libraryDependencies": [ - | "io.circe::circe-core:0.14.0", - | "org.eclipse.lsp4j:org.eclipse.lsp4j:0.5.0", - | "com.lihaoyi::sourcecode:0.1.7" - | ] - | } - |} - |""".stripMargin + s""" + |/metals.json + |{ + | "a": { + | "scalaVersion" : "${V.scala213}", + | "libraryDependencies": [ + | "io.circe::circe-core:0.14.0", + | "org.eclipse.lsp4j:org.eclipse.lsp4j:0.5.0", + | "com.lihaoyi::sourcecode:0.1.7" + | ] + | } + |} + |""".stripMargin ) folder = server.server.path _ = { @@ -572,22 +574,22 @@ class TreeViewLspSuite extends BaseLspSuite("tree-view") { cleanWorkspace() for { _ <- initialize( - """ - |/metals.json - |{ - | "a": {}, - | "b": {} - |} - |/a/src/main/scala/a/First.scala - |package a - |class First - |/b/src/main/scala/b/Second.scala - |package b - |class Second { - | def a = 1 - | val b = 2 - |} - |""".stripMargin + s""" + |/metals.json + |{ + | "a": {"scalaVersion" : "${V.scala213}"}, + | "b": {"scalaVersion" : "${V.scala213}"} + |} + |/a/src/main/scala/a/First.scala + |package a + |class First + |/b/src/main/scala/b/Second.scala + |package b + |class Second { + | def a = 1 + | val b = 2 + |} + |""".stripMargin ) folder = server.server.path // Trigger a compilation of Second.scala diff --git a/tests/unit/src/test/scala/tests/WarningsLspSuite.scala b/tests/unit/src/test/scala/tests/WarningsLspSuite.scala index 15acf31ec39..29143f147f7 100644 --- a/tests/unit/src/test/scala/tests/WarningsLspSuite.scala +++ b/tests/unit/src/test/scala/tests/WarningsLspSuite.scala @@ -13,13 +13,13 @@ class WarningsLspSuite extends BaseLspSuite("warnings") { deprecatedScala212Versions.size > 0, "No deprecated Scala 2.12 versions to test.", ) - val using = deprecatedScala212Versions.head + val usingVersion = deprecatedScala212Versions.head for { _ <- initialize( s"""/metals.json |{ | "a": { - | "scalaVersion": "${using}" + | "scalaVersion": "${usingVersion}" | } |} |/a/src/main/scala/a/Main.scala @@ -30,7 +30,7 @@ class WarningsLspSuite extends BaseLspSuite("warnings") { _ = assertNoDiff( client.workspaceMessageRequests, Messages.DeprecatedScalaVersion.message( - Set(using) + Set(usingVersion) ), ) } yield () @@ -44,14 +44,14 @@ class WarningsLspSuite extends BaseLspSuite("warnings") { deprecatedScala212Versions.size > 0, "No deprecated Scala 2.12 versions to test.", ) - val using = deprecatedScala212Versions.head + val usingVersion = deprecatedScala212Versions.head val older = "2.12.4" for { _ <- initialize( s"""/metals.json |{ | "a": { - | "scalaVersion": "${using}" + | "scalaVersion": "${usingVersion}" | }, | "b": { | "scalaVersion" : "$older" @@ -71,13 +71,13 @@ class WarningsLspSuite extends BaseLspSuite("warnings") { test("deprecated-scala-211") { cleanWorkspace() - val using = V.scala211 + val usingVersion = V.scala211 for { _ <- initialize( s"""/metals.json |{ | "a": { - | "scalaVersion": "${using}" + | "scalaVersion": "${usingVersion}" | } |} |/a/src/main/scala/a/Main.scala @@ -87,20 +87,20 @@ class WarningsLspSuite extends BaseLspSuite("warnings") { ) _ = assertNoDiff( client.workspaceMessageRequests, - Messages.DeprecatedScalaVersion.message(Set(using)), + Messages.DeprecatedScalaVersion.message(Set(usingVersion)), ) } yield () } test("unsupported-scala-212") { cleanWorkspace() - val using = "2.12.4" + val usingVersion = "2.12.4" for { _ <- initialize( s"""/metals.json |{ | "a": { - | "scalaVersion": "${using}" + | "scalaVersion": "${usingVersion}" | } |} |/a/src/main/scala/a/Main.scala @@ -110,7 +110,7 @@ class WarningsLspSuite extends BaseLspSuite("warnings") { ) _ = assertNoDiff( client.workspaceMessageRequests, - Messages.UnsupportedScalaVersion.message(Set(using)), + Messages.UnsupportedScalaVersion.message(Set(usingVersion)), ) } yield () } @@ -123,13 +123,13 @@ class WarningsLspSuite extends BaseLspSuite("warnings") { "No deprecated Scala 2.13 versionsto test.", ) cleanWorkspace() - val using = deprecatedScala213Versions.head + val usingVersion = deprecatedScala213Versions.head for { _ <- initialize( s"""/metals.json |{ | "a": { - | "scalaVersion": "${using}" + | "scalaVersion": "${usingVersion}" | } |} |/a/src/main/scala/a/Main.scala @@ -139,20 +139,20 @@ class WarningsLspSuite extends BaseLspSuite("warnings") { ) _ = assertNoDiff( client.workspaceMessageRequests, - Messages.DeprecatedScalaVersion.message(Set(using)), + Messages.DeprecatedScalaVersion.message(Set(usingVersion)), ) } yield () } test("no-warnings-scala-3") { cleanWorkspace() - val using = V.scala3 + val usingVersion = V.scala3 for { _ <- initialize( s"""/metals.json |{ | "a": { - | "scalaVersion": "${using}" + | "scalaVersion": "${usingVersion}" | } |} |/a/src/main/scala/a/Main.scala diff --git a/tests/unit/src/test/scala/tests/WorkspaceFoldersSuite.scala b/tests/unit/src/test/scala/tests/WorkspaceFoldersSuite.scala index b50fce462c0..a1f73c01ab1 100644 --- a/tests/unit/src/test/scala/tests/WorkspaceFoldersSuite.scala +++ b/tests/unit/src/test/scala/tests/WorkspaceFoldersSuite.scala @@ -12,14 +12,14 @@ class WorkspaceFoldersSuite Map( "testFolder" -> s"""|/metals.json - |{"a":{"scalaVersion" : ${V.scala213}}} + |{"a":{"scalaVersion" : ${V.scala3}}} |/a/src/main/scala/a/A.scala |package a |case class MyObjectA() |""".stripMargin, "otherTestFolder" -> s"""|/metals.json - |{"a":{"scalaVersion" : ${V.scala213}}} + |{"a":{"scalaVersion" : ${V.scala3}}} |/a/src/main/scala/a/B.scala |package a |case class MyObjectB() diff --git a/tests/unit/src/test/scala/tests/classFinder/ClassBreakpointSuite.scala b/tests/unit/src/test/scala/tests/classFinder/ClassBreakpointSuite.scala index d754950bbc5..4db59e879c4 100644 --- a/tests/unit/src/test/scala/tests/classFinder/ClassBreakpointSuite.scala +++ b/tests/unit/src/test/scala/tests/classFinder/ClassBreakpointSuite.scala @@ -163,7 +163,7 @@ class ClassBreakpointSuite extends BaseClassFinderSuite { name: TestOptions, original: String, expected: String, - scalaVersion: String = V.scala213, + scalaVersion: String = V.scala3, ): Unit = test(name) { val (buffers, classFinder) = init(scalaVersion) diff --git a/tests/unit/src/test/scala/tests/classFinder/FindAllClassesSuite.scala b/tests/unit/src/test/scala/tests/classFinder/FindAllClassesSuite.scala index b9f84dae1d8..db87ac63871 100644 --- a/tests/unit/src/test/scala/tests/classFinder/FindAllClassesSuite.scala +++ b/tests/unit/src/test/scala/tests/classFinder/FindAllClassesSuite.scala @@ -129,7 +129,7 @@ class FindAllClassesSuite extends BaseClassFinderSuite { "Class FooOps a.Foo$FooOps.class", "Object FooOps a.Foo$FooOps$.class", ), - scalaVersion = V.scala213, + scalaVersion = V.scala3, searchGranularity = ClassFinderGranularity.ClassFiles, ) @@ -142,7 +142,7 @@ class FindAllClassesSuite extends BaseClassFinderSuite { "Class Foo a.Foo.class", "Object Foo a.Foo$.class", ), - scalaVersion = V.scala213, + scalaVersion = V.scala3, searchGranularity = ClassFinderGranularity.ClassFiles, ) @@ -152,7 +152,7 @@ class FindAllClassesSuite extends BaseClassFinderSuite { expected: Vector[String], searchGranularity: ClassFinderGranularity, filename: String = "Main.scala", - scalaVersion: String = V.scala213, + scalaVersion: String = V.scala3, )(implicit loc: Location): Unit = test(name) { val (buffers, classFinder) = init(scalaVersion) diff --git a/tests/unit/src/test/scala/tests/classFinder/TastyNameResolverSuite.scala b/tests/unit/src/test/scala/tests/classFinder/TastyNameResolverSuite.scala index 5d27716c0cf..124daa19b09 100644 --- a/tests/unit/src/test/scala/tests/classFinder/TastyNameResolverSuite.scala +++ b/tests/unit/src/test/scala/tests/classFinder/TastyNameResolverSuite.scala @@ -135,7 +135,7 @@ class ClassNameResolverSuite extends BaseClassFinderSuite { original: String, expected: String, filename: String = "Main.scala", - scalaVersion: String = V.scala213, + scalaVersion: String = V.scala3, ): Unit = test(name) { val (buffers, classFinder) = init(scalaVersion) diff --git a/tests/unit/src/test/scala/tests/codeactions/ExtractRenameMemberLspSuite.scala b/tests/unit/src/test/scala/tests/codeactions/ExtractRenameMemberLspSuite.scala index b494a70e62d..33acda93457 100644 --- a/tests/unit/src/test/scala/tests/codeactions/ExtractRenameMemberLspSuite.scala +++ b/tests/unit/src/test/scala/tests/codeactions/ExtractRenameMemberLspSuite.scala @@ -465,7 +465,7 @@ class ExtractRenameMemberLspSuite name: TestOptions, original: String, codeActionExpected: Boolean = true, - scalaVersion: String = V.scala213, + scalaVersion: String = V.scala3, fileName: String = "A.scala", ): Unit = test(name) { diff --git a/tests/unit/src/test/scala/tests/codeactions/ExtractValueLspSuite.scala b/tests/unit/src/test/scala/tests/codeactions/ExtractValueLspSuite.scala index 404b9793e77..2029a79deef 100644 --- a/tests/unit/src/test/scala/tests/codeactions/ExtractValueLspSuite.scala +++ b/tests/unit/src/test/scala/tests/codeactions/ExtractValueLspSuite.scala @@ -347,7 +347,7 @@ class ExtractValueLspSuite "extract-new", """|class Car(age: Int) |object Main{ - | new Car(age = <<1>>) + | val car = new Car(age = <<1>>) |} |""".stripMargin, s"""|${ExtractValueCodeAction.title("1")} @@ -355,7 +355,7 @@ class ExtractValueLspSuite """|class Car(age: Int) |object Main{ | val newValue = 1 - | new Car(age = newValue) + | val car = new Car(age = newValue) |} |""".stripMargin, ) diff --git a/tests/unit/src/test/scala/tests/codeactions/FlatMapToForComprehensionSuite.scala b/tests/unit/src/test/scala/tests/codeactions/FlatMapToForComprehensionSuite.scala index 58588abb564..616d05f3f41 100644 --- a/tests/unit/src/test/scala/tests/codeactions/FlatMapToForComprehensionSuite.scala +++ b/tests/unit/src/test/scala/tests/codeactions/FlatMapToForComprehensionSuite.scala @@ -53,6 +53,7 @@ class FlatMapToForComprehensionSuite |} |""".stripMargin, selectedActionIndex = 1, + expectNoDiagnostics = false, ) check( diff --git a/tests/unit/src/test/scala/tests/debug/CompletionDapSuite.scala b/tests/unit/src/test/scala/tests/debug/CompletionDapSuite.scala index 80aa43ac79c..8290e8ee8ca 100644 --- a/tests/unit/src/test/scala/tests/debug/CompletionDapSuite.scala +++ b/tests/unit/src/test/scala/tests/debug/CompletionDapSuite.scala @@ -20,11 +20,6 @@ class CompletionDapSuite "basic", expression = "1.toS@@", expectedCompletions = """|toShort: Short - |toBinaryString: String - |toDegrees: Double - |toHexString: String - |toOctalString: String - |toRadians: Double |toString(): String |""".stripMargin, expectedEdit = "1.toShort", @@ -71,12 +66,11 @@ class CompletionDapSuite assertCompletion( "advanced-snippet", expression = "1.until@@", - expectedCompletions = - """|until(end: Long): NumericRange.Exclusive[Long] - |until(end: Long, step: Long): NumericRange.Exclusive[Long] - |until(end: Int): Range - |until(end: Int, step: Int): Range - |""".stripMargin, + expectedCompletions = """|until(end: T): Exclusive[T] + |until(end: T, step: T): Exclusive[T] + |until(end: Int): Range + |until(end: Int, step: Int): Range + |""".stripMargin, expectedEdit = "1.until(@@)", topLines = Some(4), )( @@ -121,13 +115,10 @@ class CompletionDapSuite "multiline", expression = """|val a = 123 |a.toStri@@""".stripMargin, - expectedCompletions = """|toBinaryString: String - |toHexString: String - |toOctalString: String - |toString(): String + expectedCompletions = """|toString(): String |""".stripMargin, expectedEdit = """|val a = 123 - |a.toBinaryString""".stripMargin, + |a.toString()""".stripMargin, topLines = Some(4), )( """|/a/src/main/scala/a/Main.scala @@ -152,16 +143,13 @@ class CompletionDapSuite |val d = 111 |a.toStri@@ |1 + 234""".stripMargin, - expectedCompletions = """|toBinaryString: String - |toHexString: String - |toOctalString: String - |toString(): String + expectedCompletions = """|toString(): String |""".stripMargin, expectedEdit = """|val a = 123 |val b = 111 |val c = 111 |val d = 111 - |a.toBinaryString + |a.toString() |1 + 234 |""".stripMargin, topLines = Some(4), @@ -184,8 +172,8 @@ class CompletionDapSuite "single-dot", expression = "Main.@@", expectedCompletions = """|name: Option[String] - |args: Array[String] |executionStart: Long + |args: Array[String] |main(args: Array[String]): Unit |""".stripMargin, expectedEdit = "Main.name", diff --git a/tests/unit/src/test/scala/tests/scalafix/ScalafixProviderLspSuite.scala b/tests/unit/src/test/scala/tests/scalafix/ScalafixProviderLspSuite.scala index 32764248f4f..fc9f6a9be88 100644 --- a/tests/unit/src/test/scala/tests/scalafix/ScalafixProviderLspSuite.scala +++ b/tests/unit/src/test/scala/tests/scalafix/ScalafixProviderLspSuite.scala @@ -120,8 +120,7 @@ class ScalafixProviderLspSuite extends BaseLspSuite("scalafix-provider") { | |} |""".stripMargin, - ), - + ) } yield () } diff --git a/tests/unit/src/test/scala/tests/testProvider/TestSuitesProviderSuite.scala b/tests/unit/src/test/scala/tests/testProvider/TestSuitesProviderSuite.scala index 943feecc5cf..e6a89051f8a 100644 --- a/tests/unit/src/test/scala/tests/testProvider/TestSuitesProviderSuite.scala +++ b/tests/unit/src/test/scala/tests/testProvider/TestSuitesProviderSuite.scala @@ -575,7 +575,7 @@ class TestSuitesProviderSuite extends BaseLspSuite("testSuitesFinderSuite") { TestCaseEntry( "test$minusbacktick", "test-backtick", - QuickLocation(classUriFor(file), (3, 6, 3, 21)).toLsp, + QuickLocation(classUriFor(file), (3, 7, 3, 20)).toLsp, ) ).asJava, ), diff --git a/tests/unit/src/test/scala/tests/worksheets/WorksheetLspSuite.scala b/tests/unit/src/test/scala/tests/worksheets/WorksheetLspSuite.scala index fde4bd34571..cc98d73af28 100644 --- a/tests/unit/src/test/scala/tests/worksheets/WorksheetLspSuite.scala +++ b/tests/unit/src/test/scala/tests/worksheets/WorksheetLspSuite.scala @@ -4,8 +4,14 @@ import scala.meta.internal.metals.{BuildInfo => V} import munit.TestOptions -class WorksheetLspSuite extends tests.BaseWorksheetLspSuite(V.scala213) { +class WorksheetLspSuite extends tests.BaseWorksheetLspSuite(V.scala3) { + override def versionSpecificCodeToValidate: String = + """given str: String = """"" + + override def versionSpecificScalacOptionsToValidate: List[String] = List( + "-Ycheck-reentrant" + ) checkWorksheetDeps( "imports-inside", "a/src/main/scala/foo/Main.worksheet.sc", @@ -24,7 +30,7 @@ class WorksheetLspSuite extends tests.BaseWorksheetLspSuite(V.scala213) { | "a": {} |} |/$path - |import $$dep.`com.lihaoyi::scalatags:0.9.0` + |import $$dep.`com.lihaoyi::scalatags:0.12.0` |import scalatags.Text.all._ |val htmlFile = html( | body( @@ -43,11 +49,11 @@ class WorksheetLspSuite extends tests.BaseWorksheetLspSuite(V.scala213) { _ = assertNoDiff( server.workspaceDefinitions, s"""|/$path - |import $$dep/**/.`com.lihaoyi::scalatags:0.9.0`/**/ + |import $$dep/**/.`com.lihaoyi::scalatags:0.12.0`/**/ |import scalatags.Text/*Text.scala*/.all/*Text.scala*/._ - |val htmlFile/*L2*/ = html/*Text.scala*/( - | body/*Text.scala*/( - | p/*Text.scala*/("This is a big paragraph of text") + |val htmlFile/*L2*/ = html/*Tags.scala*/( + | body/*Tags.scala*/( + | p/*Tags.scala*/("This is a big paragraph of text") | ) |) |htmlFile/*L2*/.render/*Text.scala*/ @@ -58,7 +64,7 @@ class WorksheetLspSuite extends tests.BaseWorksheetLspSuite(V.scala213) { _ = assertNoDiagnostics() _ = assertNoDiff( client.workspaceDecorations(path), - """|import $dep.`com.lihaoyi::scalatags:0.9.0` + """|import $dep.`com.lihaoyi::scalatags:0.12.0` |import scalatags.Text.all._ |val htmlFile = html( | body( @@ -89,7 +95,7 @@ class WorksheetLspSuite extends tests.BaseWorksheetLspSuite(V.scala213) { _ <- server.didOpen(path) _ = assertNoDiff( client.workspaceErrorShowMessages, - "Error downloading com.lihaoyi:scalatags_2.13:0.999.0", + "Error downloading com.lihaoyi:scalatags_3:0.999.0", ) } yield () } @@ -113,7 +119,7 @@ class WorksheetLspSuite extends tests.BaseWorksheetLspSuite(V.scala213) { _ <- server.didOpen(path) _ = assertNoDiff( client.syntheticDecorations, - "new java.sql.Date(100L) // : java.sql.Date = 1970-01-01", + "new java.sql.Date(100L) // : Date = 1970-01-01", ) } yield () } diff --git a/tests/unit/src/test/scala/tests/worksheets/WorksheetNoDecorationsLspSuite.scala b/tests/unit/src/test/scala/tests/worksheets/WorksheetNoDecorationsLspSuite.scala index e5af14318f5..c794d69a0af 100644 --- a/tests/unit/src/test/scala/tests/worksheets/WorksheetNoDecorationsLspSuite.scala +++ b/tests/unit/src/test/scala/tests/worksheets/WorksheetNoDecorationsLspSuite.scala @@ -32,7 +32,7 @@ class WorksheetNoDecorationsLspSuite workspace.resolve("a/src/main/scala/foo/Main.worksheet.sc").readText, """ |val x = 1 /*> : Int = 1 */ - |val foo = "bar" /*> : String = "bar" */ + |val foo = "bar" /*> : String = bar */ |println("metals") /*> metals */ |""".stripMargin, ) @@ -40,11 +40,11 @@ class WorksheetNoDecorationsLspSuite "a/src/main/scala/foo/Main.worksheet.sc", """ |val x = 1 /*> : Int@@ = 1 */ - |val foo = "bar" /*> : @@String = "bar" */ + |val foo = "bar" /*> : @@String = bar */ |println("metals") /*> @@metals */ |""".stripMargin, """x: Int = 1""".hover, - """foo: String = "bar"""".hover, + """foo: String = bar""".hover, """// metals""".hover, ) } yield () @@ -70,7 +70,7 @@ class WorksheetNoDecorationsLspSuite workspace.resolve("a/src/main/scala/foo/Main.worksheet.sc").readText, """ |val x = 2 /*> : Int = 2 */ - |val foo = "baz" /*> : String = "baz" */ + |val foo = "baz" /*> : String = baz */ |println("meta ls") /*> meta ls */ |""".stripMargin, ) @@ -78,11 +78,11 @@ class WorksheetNoDecorationsLspSuite "a/src/main/scala/foo/Main.worksheet.sc", """ |val x = 2 /*> : Int @@= 2 */ - |val foo = "baz" /*> : String = "baz"@@ */ + |val foo = "baz" /*> : String = baz@@ */ |println("meta ls") /*> meta@@ ls */ |""".stripMargin, """x: Int = 2""".hover, - """foo: String = "baz"""".hover, + """foo: String = baz""".hover, """// meta ls""".hover, ) } yield ()