<pre style='margin:0'>
Perry E. Metzger (pmetzger) pushed a commit to branch master
in repository macports-ports.
</pre>
<p><a href="https://github.com/macports/macports-ports/commit/abe4479226ddaaa1f4ad5411a7c290c32000476b">https://github.com/macports/macports-ports/commit/abe4479226ddaaa1f4ad5411a7c290c32000476b</a></p>
<pre style="white-space: pre; background: #F8F8F8">The following commit(s) were added to refs/heads/master by this push:
<span style='display:block; white-space:pre;color:#404040;'> new abe4479226d clojure-lsp: new port
</span>abe4479226d is described below
<span style='display:block; white-space:pre;color:#808000;'>commit abe4479226ddaaa1f4ad5411a7c290c32000476b
</span>Author: kakuhen <kakuhen@ucla.edu>
AuthorDate: Thu Sep 29 19:51:57 2022 -0700
<span style='display:block; white-space:pre;color:#404040;'> clojure-lsp: new port
</span>---
devel/clojure-lsp/Portfile | 76 +++++++++++++++++++++++++
devel/clojure-lsp/files/create-basis-patch.diff | 11 ++++
2 files changed, 87 insertions(+)
<span style='display:block; white-space:pre;color:#808080;'>diff --git a/devel/clojure-lsp/Portfile b/devel/clojure-lsp/Portfile
</span>new file mode 100644
<span style='display:block; white-space:pre;color:#808080;'>index 00000000000..23d303062c9
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>--- /dev/null
</span><span style='display:block; white-space:pre;background:#e0e0ff;'>+++ b/devel/clojure-lsp/Portfile
</span><span style='display:block; white-space:pre;background:#e0e0e0;'>@@ -0,0 +1,76 @@
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# -*- coding: utf-8; mode: tcl; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- vim:fenc=utf-8:ft=tcl:et:sw=4:ts=4:sts=4
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+PortSystem 1.0
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+PortGroup github 1.0
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+github.setup clojure-lsp clojure-lsp 2022.09.01-15.27.31
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+github.tarball_from archive
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+revision 0
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+categories devel
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+license MIT
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+maintainers {@kakuhen} openmaintainer
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+platforms darwin
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+description Clojure & ClojureScript Language Server (LSP) implementation
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+long_description The goal of this project is to bring great editing tools \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ for Clojure/Clojurescript to all editors. It aims to work alongside you to \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ help you navigate, identify and fix errors, perform refactors and much more!
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+checksums rmd160 905e04543949452df56c83bdfb093c39941ae4f9 \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ sha256 13b845d469119510e7b79ffa703f6754e332129e06dd355a2ed7d0cf6054e1f1 \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ size 4220005
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+depends_lib port:clojure
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+variant jdk17 conflicts jdk11 description {Build using JDK 17} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ depends_build-append port:openjdk17-graalvm-native-image
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+variant jdk11 conflicts jdk17 description {Build using the older JDK 11} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ depends_build-append port:openjdk11-graalvm-native-image
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+default_variants +jdk17
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+use_configure no
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# Patching cli/build.clj so that clojure.tools.build can pick up a local Maven
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# repository we will use later.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+patchfiles create-basis-patch.diff
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# Leaving this stub since we cannot declare global variables in the scope of pre-fetch
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+set graalvm_home /Library/Java/JavaVirtualMachines
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+pre-fetch {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ if {![variant_isset jdk11] && ![variant_isset jdk17]} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ error "Either +jdk11 or +jdk17 is required"
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+post-patch {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ reinplace "s|%%WORKSRCPATH%%|${worksrcpath}|g" ${worksrcpath}/cli/build.clj
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# We need to set up a local Maven repository within the source directory.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+set gitlibs ${worksrcpath}/.gitlibs
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+set repo_args "'\{:mvn/local-repo \"${worksrcpath}/.m2/repository\"\}'"
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# NOTE: upstream recommends running babashka scripts to install, but there is
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# absolutely no need to do this. Assuming you know some Clojure, you can read
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# the source for #'make/native-cli. Running `bb native-cli` simply runs this.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# I replicate the behavior of this function below and install the binary.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+build {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ if {[variant_isset jdk17]} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ set graalvm_home ${graalvm_home}/openjdk17-graalvm
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ } elseif {[variant_isset jdk11]} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ set graalvm_home ${graalvm_home}/openjdk11-graalvm
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # NOTE: This ultimately calls #'build/native-cli. Refer to the source of
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # that function if you are curious on how native-image is invoked.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ system -W ${worksrcpath}/cli \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ "GITLIBS=${gitlibs} GRAALVM_HOME=${graalvm_home}/Contents/Home clojure -Sdeps ${repo_args} -T:build native-cli"
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+destroot {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ xinstall -m 755 ${worksrcpath}/cli/clojure-lsp ${destroot}${prefix}/bin
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+}
</span><span style='display:block; white-space:pre;color:#808080;'>diff --git a/devel/clojure-lsp/files/create-basis-patch.diff b/devel/clojure-lsp/files/create-basis-patch.diff
</span>new file mode 100644
<span style='display:block; white-space:pre;color:#808080;'>index 00000000000..ddbe5763a5a
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>--- /dev/null
</span><span style='display:block; white-space:pre;background:#e0e0ff;'>+++ b/devel/clojure-lsp/files/create-basis-patch.diff
</span><span style='display:block; white-space:pre;background:#e0e0e0;'>@@ -0,0 +1,11 @@
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+--- cli/build.clj.orig 2022-09-29 18:43:01.000000000 -0700
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++++ cli/build.clj 2022-09-29 18:42:48.000000000 -0700
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+@@ -11,7 +11,7 @@
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ (def clojars-lib 'com.github.clojure-lsp/clojure-lsp-standalone)
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ (def current-version (string/trim (slurp (io/resource "CLOJURE_LSP_VERSION"))))
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ (def class-dir "target/classes")
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+-(def basis {:project "deps.edn"})
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++(def basis {:project "deps.edn" :extra {:mvn/local-repo "%%WORKSRCPATH%%/.m2/repository"}})
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ (def uber-file (format "target/%s-standalone.jar" (name lib)))
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ (defn clean [_]
</span></pre><pre style='margin:0'>
</pre>