From e65355a4ec122d82eecbfb21bfab21a5da53060f Mon Sep 17 00:00:00 2001 From: Miles Ziemer <45497130+milesziemer@users.noreply.github.com> Date: Mon, 29 Jul 2024 13:57:12 -0400 Subject: [PATCH 1/7] use jreleaser for maven publish (#154) --- build.gradle | 77 ++++++++++++++++++++++++++++++++++------------------ 1 file changed, 50 insertions(+), 27 deletions(-) diff --git a/build.gradle b/build.gradle index e1626336..88ea6807 100644 --- a/build.gradle +++ b/build.gradle @@ -34,9 +34,9 @@ plugins { id "maven-publish" id "signing" - id "io.codearte.nexus-staging" version "0.30.0" id "com.palantir.git-version" version "0.12.3" id "checkstyle" + id "org.jreleaser" version "1.13.0" } @@ -73,6 +73,8 @@ ext { println "Smithy Language Server version: '${libraryVersion}'" +def stagingDirectory = rootProject.layout.buildDirectory.dir("staging") + allprojects { apply plugin: "java" apply plugin: "maven-publish" @@ -89,14 +91,9 @@ repositories { publishing { repositories { - mavenCentral { - url = uri("https://aws.oss.sonatype.org/service/local/staging/deploy/maven2/") - if (project.hasProperty("sonatypeUser")) { - credentials { - username = project.property("sonatypeUser") - password = project.property("sonatypePassword") - } - } + maven { + name = "localStaging" + url = stagingDirectory } } @@ -118,7 +115,7 @@ publishing { pom { name.set("Smithy Language Server") description.set(project.description) - url.set("https://github.com/awslabs/smithy-language-server") + url.set("https://github.com/smithy-lang/smithy-language-server") licenses { license { name.set("Apache License 2.0") @@ -136,7 +133,7 @@ publishing { } } scm { - url.set("https://github.com/awslabs/smithy-language-server.git") + url.set("https://github.com/smithy-lang/smithy-language-server.git") } } } @@ -233,21 +230,47 @@ jar { } } -/* - * Sonatype Staging Finalization - * ==================================================== - * - * When publishing to Maven Central, we need to close the staging - * repository and release the artifacts after they have been - * validated. This configuration is for the root project because - * it operates at the "group" level. - */ -if (project.hasProperty("sonatypeUser") && project.hasProperty("sonatypePassword")) { - apply plugin: "io.codearte.nexus-staging" - nexusStaging { - packageGroup = "software.amazon" - stagingProfileId = "e789115b6c941" - username = project.property("sonatypeUser") - password = project.property("sonatypePassword") +jreleaser { + dryrun = false + + // Used for creating a tagged release, uploading files and generating changelog. + // In the future we can set this up to push release tags to GitHub, but for now it's + // set up to do nothing. + // https://jreleaser.org/guide/latest/reference/release/index.html + release { + generic { + enabled = true + skipRelease = true + } + } + + // Used to announce a release to configured announcers. + // https://jreleaser.org/guide/latest/reference/announce/index.html + announce { + active = "NEVER" + } + + // Signing configuration. + // https://jreleaser.org/guide/latest/reference/signing.html + signing { + active = "ALWAYS" + armored = true + } + + // Configuration for deploying to Maven Central. + // https://jreleaser.org/guide/latest/examples/maven/maven-central.html#_gradle + deploy { + maven { + nexus2 { + "maven-central" { + active = "ALWAYS" + url = "https://aws.oss.sonatype.org/service/local" + snapshotUrl = "https://aws.oss.sonatype.org/content/repositories/snapshots" + closeRepository = true + releaseRepository = true + stagingRepository(stagingDirectory.get().toString()) + } + } + } } } From 028d4a841ee50e8b39931b3b1e6633e2ef90962b Mon Sep 17 00:00:00 2001 From: smithy-automation <127955164+smithy-automation@users.noreply.github.com> Date: Mon, 29 Jul 2024 11:06:34 -0700 Subject: [PATCH 2/7] Update Smithy Version (#152) Co-authored-by: Smithy Automation --- gradle.properties | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/gradle.properties b/gradle.properties index 56c5fc41..23bea553 100644 --- a/gradle.properties +++ b/gradle.properties @@ -1 +1 @@ -smithyVersion=1.46.0 +smithyVersion=1.50.0 From 76c01cedb60b7f0686140da6ca7f58644536010b Mon Sep 17 00:00:00 2001 From: Miles Ziemer <45497130+milesziemer@users.noreply.github.com> Date: Mon, 29 Jul 2024 14:08:17 -0400 Subject: [PATCH 3/7] Add 0.3.0 changelog (#155) --- CHANGELOG.md | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index d6e5b4df..425698b9 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,21 @@ # Smithy Language Server Changelog +## 0.3.0 (2024-07-29) + +### Features +* Made various performance improvements ([#146](https://github.com/smithy-lang/smithy-language-server/pull/146)) +* Added support for using build-system agnostic .smithy-project.json to tell the server where project files and locally dependencies are ([#146](https://github.com/smithy-lang/smithy-language-server/pull/146)) +* Added configuration option for minimum severity of validation events ([#146](https://github.com/smithy-lang/smithy-language-server/pull/146)) +* Switched to smithy-syntax formatter ([#146](https://github.com/smithy-lang/smithy-language-server/pull/146)) +* Added progress reporting on load ([#146](https://github.com/smithy-lang/smithy-language-server/pull/146)) + +### Removed/Replaced +* Removed generation of smithy.lsp.log file in favor of smithyLsp.trace.server and sending client logMessage notifications ([#146](https://github.com/smithy-lang/smithy-language-server/pull/146)) +* Removed loading of every .smithy file found in all subdirectories of root path. Instead, server loads single files as separate models, or any files specified in smithy-build.json as a project ([#146](https://github.com/smithy-lang/smithy-language-server/pull/146)) + +### Bug fixes +* Fixed erroneously loading files in build directories, which could cause conflicting shape definitions ([#146](https://github.com/smithy-lang/smithy-language-server/pull/146)) + ## 0.2.4 (2024-11-08) ### Features From 1109260fd6b8c599928d32c054d40704b01edab6 Mon Sep 17 00:00:00 2001 From: Miles Ziemer <45497130+milesziemer@users.noreply.github.com> Date: Tue, 30 Jul 2024 12:07:43 -0400 Subject: [PATCH 4/7] Upgrade dependencies and jdk to 21 (#157) * Upgrade dependencies and jdk to 21 A few minor code changes were made for the upgrade, including removing LspLog (which should have already been removed). I didn't make any larger changes to make use of java 21 features - that can be done later. The primary motivation of this commit is to update our dependency on lsp4j, which outdated and depended on a version of guava with two CVEs out: CVE-2023-2976, CVE-2020-8908. In order to do so, a jdk upgrade was required since newer versions of lsp4j are past jdk 8. We were going to upgrade the jdk soon anways. Also got rid of an extra signing block in the publishing task, which is taken care of by jreleaser. --- .github/workflows/ci.yml | 2 +- build.gradle | 21 +-- .../amazon/smithy/lsp/SelectorParams.java | 2 +- .../smithy/lsp/SmithyLanguageServer.java | 7 - .../amazon/smithy/lsp/ext/LspLog.java | 137 ------------------ .../lsp/project/SmithyBuildExtensions.java | 8 +- 6 files changed, 14 insertions(+), 163 deletions(-) delete mode 100644 src/main/java/software/amazon/smithy/lsp/ext/LspLog.java diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 1a32c55d..7a191df4 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -14,7 +14,7 @@ jobs: strategy: fail-fast: false matrix: - java: [8, 11, 17] + java: [21] os: [ubuntu-latest, windows-latest, macos-latest] steps: diff --git a/build.gradle b/build.gradle index 88ea6807..339f1131 100644 --- a/build.gradle +++ b/build.gradle @@ -139,28 +139,18 @@ publishing { } } } - - // Don't sign the artifacts if we didn't get a key and password to use. - if (project.hasProperty("signingKey") && project.hasProperty("signingPassword")) { - signing { - useInMemoryPgpKeys( - (String) project.property("signingKey"), - (String) project.property("signingPassword")) - sign(publishing.publications["mavenJava"]) - } - } } dependencies { - implementation "org.eclipse.lsp4j:org.eclipse.lsp4j:0.20.0" + implementation "org.eclipse.lsp4j:org.eclipse.lsp4j:0.23.1" implementation "software.amazon.smithy:smithy-build:[smithyVersion, 2.0[" implementation "software.amazon.smithy:smithy-cli:[smithyVersion, 2.0[" implementation "software.amazon.smithy:smithy-model:[smithyVersion, 2.0[" implementation "software.amazon.smithy:smithy-syntax:[smithyVersion, 2.0[" testImplementation "org.junit.jupiter:junit-jupiter:5.10.0" - testImplementation "org.hamcrest:hamcrest:2.1" + testImplementation "org.hamcrest:hamcrest:2.2" testRuntimeOnly "org.junit.platform:junit-platform-launcher" } @@ -209,8 +199,9 @@ tasks.named("checkstyleTest") { } java { - sourceCompatibility = JavaVersion.VERSION_1_8 - targetCompatibility = JavaVersion.VERSION_1_8 + toolchain { + languageVersion = JavaLanguageVersion.of(21) + } } jar { @@ -224,6 +215,8 @@ jar { exclude "META-INF/*.DSA" exclude "META-INF/*.RSA" exclude "reflect.properties" + // Included by dependencies in later versions of java, causes duplicate entries in the output jar + exclude "**/module-info.class" } manifest { attributes("Main-Class": "software.amazon.smithy.lsp.Main") diff --git a/src/main/java/software/amazon/smithy/lsp/SelectorParams.java b/src/main/java/software/amazon/smithy/lsp/SelectorParams.java index 18772a4c..e285b5ee 100644 --- a/src/main/java/software/amazon/smithy/lsp/SelectorParams.java +++ b/src/main/java/software/amazon/smithy/lsp/SelectorParams.java @@ -15,8 +15,8 @@ package software.amazon.smithy.lsp; +import org.eclipse.lsp4j.jsonrpc.util.Preconditions; import org.eclipse.lsp4j.jsonrpc.validation.NonNull; -import org.eclipse.lsp4j.util.Preconditions; public class SelectorParams { @NonNull diff --git a/src/main/java/software/amazon/smithy/lsp/SmithyLanguageServer.java b/src/main/java/software/amazon/smithy/lsp/SmithyLanguageServer.java index 61b7ff16..fbf65c64 100644 --- a/src/main/java/software/amazon/smithy/lsp/SmithyLanguageServer.java +++ b/src/main/java/software/amazon/smithy/lsp/SmithyLanguageServer.java @@ -95,7 +95,6 @@ import software.amazon.smithy.lsp.document.Document; import software.amazon.smithy.lsp.document.DocumentParser; import software.amazon.smithy.lsp.document.DocumentShape; -import software.amazon.smithy.lsp.ext.LspLog; import software.amazon.smithy.lsp.ext.serverstatus.OpenProject; import software.amazon.smithy.lsp.ext.serverstatus.ServerStatus; import software.amazon.smithy.lsp.handler.CompletionHandler; @@ -197,12 +196,6 @@ public CompletableFuture initialize(InitializeParams params) { Object initializationOptions = params.getInitializationOptions(); if (initializationOptions instanceof JsonObject) { JsonObject jsonObject = (JsonObject) initializationOptions; - if (jsonObject.has("logToFile")) { - String setting = jsonObject.get("logToFile").getAsString(); - if (setting.equals("enabled")) { - LspLog.enable(); - } - } if (jsonObject.has("diagnostics.minimumSeverity")) { String configuredMinimumSeverity = jsonObject.get("diagnostics.minimumSeverity").getAsString(); Optional severity = Severity.fromString(configuredMinimumSeverity); diff --git a/src/main/java/software/amazon/smithy/lsp/ext/LspLog.java b/src/main/java/software/amazon/smithy/lsp/ext/LspLog.java deleted file mode 100644 index a5305b1e..00000000 --- a/src/main/java/software/amazon/smithy/lsp/ext/LspLog.java +++ /dev/null @@ -1,137 +0,0 @@ -/* - * Copyright 2022 Amazon.com, Inc. or its affiliates. All Rights Reserved. - * - * Licensed under the Apache License, Version 2.0 (the "License"). - * You may not use this file except in compliance with the License. - * A copy of the License is located at - * - * http://aws.amazon.com/apache2.0 - * - * or in the "license" file accompanying this file. This file is distributed - * on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either - * express or implied. See the License for the specific language governing - * permissions and limitations under the License. - */ - -package software.amazon.smithy.lsp.ext; - -import java.io.File; -import java.io.FileWriter; -import java.io.IOException; -import java.io.PrintWriter; -import java.io.StringWriter; -import java.nio.file.Paths; -import java.time.LocalTime; -import java.time.format.DateTimeFormatter; -import java.util.ArrayList; -import java.util.Collections; -import java.util.List; -import java.util.Optional; -import software.amazon.smithy.utils.ListUtils; - -/** - * This log interface buffers the messages until the server receives information - * about workspace root. - *

- * This places the log messages into a file in the workspace, rather than - * pre-defined location on filesystem. - */ -public final class LspLog { - private static FileWriter fw = null; - private static Optional> buffer = Optional.of(new ArrayList<>()); - private static boolean enabled = false; - - private LspLog() { - } - - /** - * Clears out the buffered messages. - */ - public static void clearBuffer() { - synchronized (buffer) { - buffer.ifPresent(List::clear); - } - } - - /** - * Produces a snapshot of the current log buffer. - * - * @return a copy of the messages currently in the buffer - */ - public static List getBuffer() { - return ListUtils.copyOf(buffer.orElse(Collections.emptyList())); - } - - /** - * Sets workspace folder for the logger. - *

- * All the pending messages in the buffer will be flushed to the file created in - * the workspace - * - * @param folder workspace folder where log file will be created - */ - public static void setWorkspaceFolder(File folder) { - if (!enabled) { - return; - } - - try { - fw = new FileWriter(Paths.get(folder.getAbsolutePath(), "/.smithy.lsp.log").toFile()); - synchronized (buffer) { - buffer.ifPresent(buf -> buf.forEach(LspLog::println)); - buffer = Optional.empty(); - } - } catch (IOException e) { - // TODO: handle exception - } - - } - - /** - * Enables writing LspLog to a file. - */ - public static void enable() { - enabled = true; - } - - private static String currentTime() { - return LocalTime.now().withNano(0).format(DateTimeFormatter.ISO_LOCAL_TIME); - } - - /** - * Write a line to the log. - * - * @param message object to write, will be converted to String - */ - public static void println(Object message) { - if (!enabled) { - return; - } - String sanitizedMessage = getStringifiedMessage(message); - String timestamped = "[" + currentTime() + "] " + sanitizedMessage; - try { - if (fw != null) { - fw.append(timestamped + "\n").flush(); - } else { - synchronized (buffer) { - buffer.ifPresent(buf -> buf.add(sanitizedMessage)); - } - } - } catch (Exception e) { - - } - } - - private static String getStringifiedMessage(Object message) { - if (message == null) { - return "null"; - } else if (message instanceof Throwable) { - StringWriter sw = new StringWriter(); - PrintWriter pw = new PrintWriter(sw); - ((Throwable) message).printStackTrace(pw); - return sw.toString(); - } else { - return message.toString(); - } - } -} diff --git a/src/main/java/software/amazon/smithy/lsp/project/SmithyBuildExtensions.java b/src/main/java/software/amazon/smithy/lsp/project/SmithyBuildExtensions.java index 35e2a576..211a9086 100644 --- a/src/main/java/software/amazon/smithy/lsp/project/SmithyBuildExtensions.java +++ b/src/main/java/software/amazon/smithy/lsp/project/SmithyBuildExtensions.java @@ -18,11 +18,11 @@ import java.util.ArrayList; import java.util.Collection; import java.util.List; +import java.util.logging.Logger; import java.util.stream.Collectors; import software.amazon.smithy.build.model.MavenConfig; import software.amazon.smithy.build.model.MavenRepository; import software.amazon.smithy.build.model.SmithyBuildConfig; -import software.amazon.smithy.lsp.ext.LspLog; import software.amazon.smithy.utils.ListUtils; import software.amazon.smithy.utils.SmithyBuilder; import software.amazon.smithy.utils.ToSmithyBuilder; @@ -32,6 +32,8 @@ * top-level {@code mavenRepositories} and {@code mavenDependencies} properties. */ public final class SmithyBuildExtensions implements ToSmithyBuilder { + private static final Logger LOGGER = Logger.getLogger(SmithyBuildExtensions.class.getName()); + private final List imports; private final List mavenRepositories; private final List mavenDependencies; @@ -157,7 +159,7 @@ public Builder mavenRepositories(Collection mavenRepositories) { .map(repo -> MavenRepository.builder().url(repo).build()) .collect(Collectors.toList())) .build(); - LspLog.println("Read deprecated `mavenRepositories` in smithy-build.json. Update smithy-build.json to " + LOGGER.warning("Read deprecated `mavenRepositories` in smithy-build.json. Update smithy-build.json to " + "{\"maven\": {\"repositories\": [{\"url\": \"repo url\"}]}}"); } @@ -181,7 +183,7 @@ public Builder mavenDependencies(Collection mavenDependencies) { config = config.toBuilder() .dependencies(mavenDependencies) .build(); - LspLog.println("Read deprecated `mavenDependencies` in smithy-build.json. Update smithy-build.json to " + LOGGER.warning("Read deprecated `mavenDependencies` in smithy-build.json. Update smithy-build.json to " + "{\"maven\": {\"dependencies\": [\"dependencyA\", \"dependencyB\"]}}"); } this.maven = config; From 779ef70a1842aa48b77dc29be706e1c096501f43 Mon Sep 17 00:00:00 2001 From: Miles Ziemer <45497130+milesziemer@users.noreply.github.com> Date: Tue, 30 Jul 2024 13:04:59 -0400 Subject: [PATCH 5/7] Bump version to 0.4.0 (#158) This version includes the same features as 0.3.0, but includes the JDK upgrade and lsp4j dependency upgrade from #157. --- CHANGELOG.md | 5 ++++- VERSION | 2 +- 2 files changed, 5 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 425698b9..d777b467 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,6 +1,9 @@ # Smithy Language Server Changelog -## 0.3.0 (2024-07-29) +## 0.4.0 (2024-07-30) + +### Breaking +* Upgraded JDK version to 21 ([#157](https://github.com/smithy-lang/smithy-language-server/pull/157)) ### Features * Made various performance improvements ([#146](https://github.com/smithy-lang/smithy-language-server/pull/146)) diff --git a/VERSION b/VERSION index 0d91a54c..1d0ba9ea 100644 --- a/VERSION +++ b/VERSION @@ -1 +1 @@ -0.3.0 +0.4.0 From adde7ee1bd3a97fa8cc1f3a34ebf6b32cea22247 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jakub=20Koz=C5=82owski?= Date: Mon, 19 Aug 2024 23:30:34 +0200 Subject: [PATCH 6/7] bump libraries --- build.sc | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/build.sc b/build.sc index 20246a0f..886c2505 100644 --- a/build.sc +++ b/build.sc @@ -8,11 +8,11 @@ object lsp extends MavenModule with PublishModule { def millSourcePath: os.Path = os.pwd def ivyDeps = Agg( - ivy"org.eclipse.lsp4j:org.eclipse.lsp4j:0.20.0", - ivy"software.amazon.smithy:smithy-build:1.46.0", - ivy"software.amazon.smithy:smithy-cli:1.46.0", - ivy"software.amazon.smithy:smithy-model:1.46.0", - ivy"software.amazon.smithy:smithy-syntax:1.46.0" + ivy"org.eclipse.lsp4j:org.eclipse.lsp4j:0.23.1", + ivy"software.amazon.smithy:smithy-build:1.50.0", + ivy"software.amazon.smithy:smithy-cli:1.50.0", + ivy"software.amazon.smithy:smithy-model:1.50.0", + ivy"software.amazon.smithy:smithy-syntax:1.50.0" ) def publishVersion = T { gitVersion() } From a0224e04d9363bc0951b5a7d4f58d06400bcb74a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jakub=20Koz=C5=82owski?= Date: Mon, 19 Aug 2024 23:32:08 +0200 Subject: [PATCH 7/7] bump to jdk 21 --- .github/workflows/ci.yml | 6 +++--- build.sc | 4 ++-- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 2ce443dd..725b2dd5 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -12,8 +12,8 @@ jobs: strategy: fail-fast: false matrix: - java: [8, 11, 17, 21] - os: [ubuntu-latest, windows-latest, macos-13] + java: [21] + os: [ubuntu-latest, windows-latest, macos-latest] runs-on: ${{ matrix.os }} name: Java ${{ matrix.java }} ${{ matrix.os }} @@ -32,7 +32,7 @@ jobs: publish: strategy: matrix: - java: [11] + java: [21] os: [ubuntu-latest] name: Publish diff --git a/build.sc b/build.sc index 886c2505..18089bd4 100644 --- a/build.sc +++ b/build.sc @@ -20,9 +20,9 @@ object lsp extends MavenModule with PublishModule { def javacOptions = T { super.javacOptions() ++ Seq( "-source", - "1.8", + "21", "-target", - "1.8" + "21" ) }