<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>