guix-patches
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[bug#32947] [PATCH 3/3] gnu: Add java-xalan.


From: Julien Lepiller
Subject: [bug#32947] [PATCH 3/3] gnu: Add java-xalan.
Date: Fri, 05 Oct 2018 17:46:47 +0200
User-agent: Roundcube Webmail/1.3.6

Le 2018-10-05 17:20, Danny Milosavljevic a écrit :
* gnu/packages/java.scm (java-xalan): New variable.
---
 gnu/packages/java.scm | 54 +++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 54 insertions(+)

diff --git a/gnu/packages/java.scm b/gnu/packages/java.scm
index 863a4b79c..02a8f65e8 100644
--- a/gnu/packages/java.scm
+++ b/gnu/packages/java.scm
@@ -9709,6 +9709,60 @@ the DOM level 3 load/save API's are in use.")
 for Java.")
     (license license:asl2.0)))

+(define-public java-xalan
+  (package
+    (name "java-xalan")
+    (version "2.7.2")
+    (source
+      (origin
+        (method url-fetch)
+        (uri (string-append
"https://archive.apache.org/dist/xalan/xalan-j/source/";
+                            "xalan-j_" (string-join (string-split
version #\.) "_")
+                            "-src.tar.gz"))

Could you use mirror://apache/xalan/xalan-j/source/...?

+        (sha256
+         (base32
+          "166vg9i11qzi0vbv09abfb50q8caq8wr6zrwg0cwqws9k394l62w"))))
+    (build-system ant-build-system)
+    (arguments
+     `(#:build-target "jar"
+       #:phases
+       (modify-phases %standard-phases
+         (add-after 'unpack 'patch-classpath
+           (lambda _
+             (substitute* "src/MANIFEST.MF"
+              (("^Class-Path: .*$") "\n"))
+             #t))
+         (add-after 'unpack 'replace-prebuilt-jars
+           (lambda* (#:key inputs #:allow-other-keys)
+             (for-each delete-file
+                       (find-files "." "\\.jar$"))

I think it's better to remove these files in a snippet. Also, there are .tar.gz files in the source archive that we could remove.

+ (symlink (string-append (assoc-ref inputs "java-commons-bcel")
+                                     "/share/java/bcel.jar")
+                      "lib/BCEL.jar")
+             (symlink (string-append (assoc-ref inputs "java-cup")
+ "/share/java/java-cup-11b-runtime.jar")
+                      "lib/runtime.jar")
+ (symlink (string-append (assoc-ref inputs "java-jakarta-regexp") + "/share/java/jakarta-regexp-1.5.jar")
+                      "lib/regexp.jar")

maybe something like
(let ((regexp (assoc-ref inputs "java-jakarta-regexp")))
(symlink (string-append regexp "/share/java/javakarta-regexp-" (package-version regexp) ".jar")
           "lib/regexp.jar"))

would be more future-proof in case we update regexp? Same with the other dependencies.

+             #t))
+          (replace 'install
+            (lambda* (#:key outputs #:allow-other-keys)
+              (let* ((out (assoc-ref outputs "out"))
+                     (out-share (string-append out "/share/java")))
+                (mkdir-p out-share)
+                (install-file "build/xalan.jar" out-share)
+                #t))))))
+    (propagated-inputs
+     `(("java-commons-bcel" ,java-commons-bcel)
+       ("java-cup" ,java-cup)
+       ("java-jakarta-regexp" ,java-jakarta-regexp)
+       ("java-xerces" ,java-xerces)))
+    (home-page "https://xml.apache.org/xalan-j/";)
+    (synopsis "XSLT processor for Java")
+    (description "@code{xalan} is an XSLT processor for Java.")
+    (license license:asl2.0)))
+
 (define-public java-jline
   (package
     (name "java-jline")





reply via email to

[Prev in Thread] Current Thread [Next in Thread]