all messages for Guix-related lists mirrored at yhetil.org
 help / color / mirror / code / Atom feed
From: Roel Janssen <roel@gnu.org>
To: Ricardo Wurmus <rekado@elephly.net>
Cc: Hartmut Goebel <h.goebel@crazy-compilers.com>, 26803@debbugs.gnu.org
Subject: bug#26803: [PATCH 03/36] guix: Add java-utils.
Date: Sat, 06 May 2017 22:31:02 +0200	[thread overview]
Message-ID: <87poflk9rt.fsf@gnu.org> (raw)
In-Reply-To: <20170506153617.3074-3-rekado@elephly.net>


Ricardo Wurmus writes:

> From: Hartmut Goebel <h.goebel@crazy-compilers.com>
>
> * guix/build/java-utils.scm: New file.
> * guix/build-system/ant.scm: Use it.
> * Makefile.am (MODULES): Add it.
>
> Co-authored-by: Ricardo Wurmus <rekado@elephly.net>
> ---
>  Makefile.am               |  1 +
>  guix/build-system/ant.scm |  2 ++
>  guix/build/java-utils.scm | 55 +++++++++++++++++++++++++++++++++++++++++++++++
>  3 files changed, 58 insertions(+)
>  create mode 100644 guix/build/java-utils.scm
>
> diff --git a/Makefile.am b/Makefile.am
> index 8fe9e350c..b09180ba2 100644
> --- a/Makefile.am
> +++ b/Makefile.am
> @@ -124,6 +124,7 @@ MODULES =					\
>    guix/build/syscalls.scm                       \
>    guix/build/gremlin.scm			\
>    guix/build/emacs-utils.scm			\
> +  guix/build/java-utils.scm			\
>    guix/build/lisp-utils.scm			\
>    guix/build/graft.scm				\
>    guix/build/bournish.scm			\
> diff --git a/guix/build-system/ant.scm b/guix/build-system/ant.scm
> index bf2f3b411..228b4e60d 100644
> --- a/guix/build-system/ant.scm
> +++ b/guix/build-system/ant.scm
> @@ -39,6 +39,7 @@
>  (define %ant-build-system-modules
>    ;; Build-side modules imported by default.
>    `((guix build ant-build-system)
> +    (guix build java-utils)
>      (guix build syscalls)
>      ,@%gnu-build-system-modules))
>  
> @@ -108,6 +109,7 @@
>                      (guile #f)
>                      (imported-modules %ant-build-system-modules)
>                      (modules '((guix build ant-build-system)
> +                               (guix build java-utils)
>                                 (guix build utils))))
>    "Build SOURCE with INPUTS."
>    (define builder
> diff --git a/guix/build/java-utils.scm b/guix/build/java-utils.scm
> new file mode 100644
> index 000000000..402d377bf
> --- /dev/null
> +++ b/guix/build/java-utils.scm
> @@ -0,0 +1,55 @@
> +;;; GNU Guix --- Functional package management for GNU
> +;;; Copyright © 2016 Hartmut Goebel <h.goebel@crazy-compilers.com>
> +;;; Copyright © 2016 Ricardo Wurmus <rekado@elephly.net>
> +;;;
> +;;; This file is part of GNU Guix.
> +;;;
> +;;; GNU Guix is free software; you can redistribute it and/or modify it
> +;;; under the terms of the GNU General Public License as published by
> +;;; the Free Software Foundation; either version 3 of the License, or (at
> +;;; your option) any later version.
> +;;;
> +;;; GNU Guix is distributed in the hope that it will be useful, but
> +;;; WITHOUT ANY WARRANTY; without even the implied warranty of
> +;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
> +;;; GNU General Public License for more details.
> +;;;
> +;;; You should have received a copy of the GNU General Public License
> +;;; along with GNU Guix.  If not, see <http://www.gnu.org/licenses/>.
> +
> +(define-module (guix build java-utils)
> +  #:use-module (guix build utils)
> +  #:export (ant-build-javadoc
> +            install-jars
> +            install-javadoc))
> +
> +;; Copied from haskell-build-system.scm
> +(define (package-name-version store-dir)
> +  "Given a store directory STORE-DIR return 'name-version' of the package."
> +  (let* ((base (basename store-dir)))
> +    (string-drop base (+ 1 (string-index base #\-)))))
> +
> +(define* (ant-build-javadoc #:key (target "javadoc") (make-flags '())
> +                            #:allow-other-keys)
> +  (zero? (apply system* `("ant" ,target ,@make-flags))))
> +
> +(define* (install-jars jar-directory)
> +  "Install jar files from JAR-DIRECTORY to the default target directory.  This

(nitpick
  "jar" or "JAR")

> +is used in case the build.xml does not include an install target."
> +  (lambda* (#:key outputs #:allow-other-keys)
> +    (let ((share (string-append (assoc-ref outputs "out")
> +                                "/share/java")))
> +      (for-each (lambda (f) (install-file f share))
> +                (find-files jar-directory "\\.jar$"))
> +      #t)))
> +
> +(define* (install-javadoc apidoc-directory)
> +  "Install the APIDOC-DIRECTORY to the target directory.  This is used to
> +install javadocs when this is not done by the install target."
> +  (lambda* (#:key outputs #:allow-other-keys)
> +    (let* ((out (assoc-ref outputs "out"))
> +           (docs (string-append (or (assoc-ref outputs "doc") out)
> +                                "/share/doc/" (package-name-version out) "/")))
> +      (mkdir-p docs)
> +      (copy-recursively apidoc-directory docs)
> +      #t)))

(nitpick
  "javadocs" or "Javadocs")

Either way, LGTM!

Kind regards,
Roel Janssen

  reply	other threads:[~2017-05-06 20:32 UTC|newest]

Thread overview: 103+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2017-05-06 14:01 bug#26803: Java things Ricardo Wurmus
2017-05-06 15:35 ` bug#26803: [PATCH 01/36] ant-build-system: Allow specifying source directory Ricardo Wurmus
2017-05-06 15:35   ` bug#26803: [PATCH 02/36] ant-build-system: Add default "check" target Ricardo Wurmus
2017-05-06 20:28     ` Roel Janssen
2017-05-06 15:35   ` bug#26803: [PATCH 03/36] guix: Add java-utils Ricardo Wurmus
2017-05-06 20:31     ` Roel Janssen [this message]
2017-05-06 15:35   ` bug#26803: [PATCH 04/36] gnu: Add java-plexus-utils Ricardo Wurmus
2017-05-06 20:34     ` Roel Janssen
2017-05-06 15:35   ` bug#26803: [PATCH 05/36] gnu: Add java-plexus-interpolation Ricardo Wurmus
2017-05-06 20:36     ` Roel Janssen
2017-05-10 10:44       ` Ricardo Wurmus
2017-05-06 15:35   ` bug#26803: [PATCH 06/36] gnu: Add java-asm Ricardo Wurmus
2017-05-06 20:39     ` Roel Janssen
2017-05-10 13:58       ` Ricardo Wurmus
2017-05-06 15:35   ` bug#26803: [PATCH 07/36] gnu: Add java-cglib Ricardo Wurmus
2017-05-06 20:40     ` Roel Janssen
2017-05-06 20:49       ` Ricardo Wurmus
2017-05-06 15:35   ` bug#26803: [PATCH 08/36] gnu: Add java-objenesis Ricardo Wurmus
2017-05-06 20:41     ` Roel Janssen
2017-05-06 15:35   ` bug#26803: [PATCH 09/36] gnu: Add java-easymock Ricardo Wurmus
2017-05-06 21:28     ` Roel Janssen
2017-05-06 15:35   ` bug#26803: [PATCH 10/36] gnu: Add java-jopt-simple Ricardo Wurmus
2017-05-06 21:31     ` Roel Janssen
2017-05-06 15:35   ` bug#26803: [PATCH 11/36] gnu: java-hamcrest-core: Install all jars without version suffix Ricardo Wurmus
2017-05-06 21:39     ` Roel Janssen
2017-05-10 14:00       ` Ricardo Wurmus
2017-05-06 15:35   ` bug#26803: [PATCH 12/36] gnu: Add java-commons-math3 Ricardo Wurmus
2017-05-06 21:43     ` Roel Janssen
2017-05-10 14:01       ` Ricardo Wurmus
2017-05-06 15:35   ` bug#26803: [PATCH 13/36] gnu: Add java-jmh Ricardo Wurmus
2017-05-07 19:13     ` Roel Janssen
2017-05-06 15:35   ` bug#26803: [PATCH 14/36] gnu: Add java-commons-collections4 Ricardo Wurmus
2017-05-07 19:16     ` Roel Janssen
2017-05-06 15:35   ` bug#26803: [PATCH 15/36] gnu: Add java-commons-io Ricardo Wurmus
2017-05-08 10:41     ` Roel Janssen
2017-05-10 14:10       ` Ricardo Wurmus
2017-05-10 14:24         ` Roel Janssen
2017-05-10 14:34           ` Ricardo Wurmus
2017-05-06 15:35   ` bug#26803: [PATCH 16/36] gnu: Add java-commons-lang Ricardo Wurmus
2017-05-08 10:46     ` Roel Janssen
2017-05-10 14:13       ` Ricardo Wurmus
2017-05-10 14:23         ` Roel Janssen
2017-05-06 15:35   ` bug#26803: [PATCH 17/36] gnu: Add java-commons-lang3 Ricardo Wurmus
2017-05-08 11:20     ` Roel Janssen
2017-05-10 14:23       ` Ricardo Wurmus
2017-05-06 15:35   ` bug#26803: [PATCH 18/36] gnu: Add java-commons-cli Ricardo Wurmus
2017-05-08 14:13     ` Roel Janssen
2017-05-06 15:36   ` bug#26803: [PATCH 19/36] gnu: Add java-commons-codec Ricardo Wurmus
2017-05-10 10:09     ` Roel Janssen
2017-05-10 14:25       ` Ricardo Wurmus
2017-05-06 15:36   ` bug#26803: [PATCH 20/36] gnu: Add java-commons-daemon Ricardo Wurmus
2017-05-10 10:12     ` Roel Janssen
2017-05-10 16:03       ` Ricardo Wurmus
2017-05-06 15:36   ` bug#26803: [PATCH 21/36] gnu: Add java-jmock-1 Ricardo Wurmus
2017-05-10 10:15     ` Roel Janssen
2017-05-10 16:00       ` Ricardo Wurmus
2017-05-06 15:36   ` bug#26803: [PATCH 22/36] gnu: java-hamcrest-core: Declare test target Ricardo Wurmus
2017-05-10 10:15     ` Roel Janssen
2017-05-10 16:04       ` Ricardo Wurmus
2017-05-06 15:36   ` bug#26803: [PATCH 23/36] gnu: Add java-hamcrest-all Ricardo Wurmus
2017-05-10 18:02     ` Roel Janssen
2017-05-06 15:36   ` bug#26803: [PATCH 24/36] gnu: Add java-jsr305 Ricardo Wurmus
2017-05-10 18:04     ` Roel Janssen
2017-05-11  9:27       ` julien lepiller
2017-05-06 15:36   ` bug#26803: [PATCH 25/36] gnu: Add java-guava Ricardo Wurmus
2017-05-10 18:06     ` Roel Janssen
2017-05-10 19:43       ` Ricardo Wurmus
2017-05-11  9:38     ` julien lepiller
2017-05-06 15:36   ` bug#26803: [PATCH 26/36] gnu: Add java-commons-logging-minimal Ricardo Wurmus
2017-05-10 18:09     ` Roel Janssen
2017-05-10 19:46       ` Ricardo Wurmus
2017-05-06 15:36   ` bug#26803: [PATCH 27/36] gnu: Add java-mockito-1 Ricardo Wurmus
2017-05-11  8:13     ` Roel Janssen
2017-05-11  8:22       ` Ricardo Wurmus
2017-05-11  8:57         ` Roel Janssen
2017-05-06 15:36   ` bug#26803: [PATCH 28/36] gnu: Add java-httpcomponents-httpcore Ricardo Wurmus
2017-05-11  8:16     ` Roel Janssen
2017-05-06 15:36   ` bug#26803: [PATCH 29/36] gnu: Add java-httpcomponents-httpcore-nio Ricardo Wurmus
2017-05-11  8:18     ` Roel Janssen
2017-05-06 15:36   ` bug#26803: [PATCH 30/36] gnu: Add java-httpcomponents-httpcore-ab Ricardo Wurmus
2017-05-11  8:30     ` Roel Janssen
2017-05-06 15:36   ` bug#26803: [PATCH 31/36] gnu: Add java-httpcomponents-httpclient Ricardo Wurmus
2017-05-11  8:32     ` Roel Janssen
2017-05-15 19:44       ` Ricardo Wurmus
2017-05-15 21:26         ` Roel Janssen
2017-05-06 15:36   ` bug#26803: [PATCH 32/36] gnu: Add java-httpcomponents-httpmime Ricardo Wurmus
2017-05-11  8:32     ` Roel Janssen
2017-05-06 15:36   ` bug#26803: [PATCH 33/36] gnu: Add java-commons-httpclient Ricardo Wurmus
2017-05-11  8:35     ` Roel Janssen
2017-05-15 19:50       ` Ricardo Wurmus
2017-05-06 15:36   ` bug#26803: [PATCH 34/36] gnu: Add java-commons-net Ricardo Wurmus
2017-05-11  8:40     ` Roel Janssen
2017-05-15 19:53       ` Ricardo Wurmus
2017-05-06 15:36   ` bug#26803: [PATCH 35/36] gnu: Add java-jsch Ricardo Wurmus
2017-05-11  8:41     ` Roel Janssen
2017-05-15 19:54       ` Ricardo Wurmus
2017-05-06 15:36   ` bug#26803: [PATCH 36/36] gnu: Add java-commons-compress Ricardo Wurmus
2017-05-11  8:53     ` Roel Janssen
2017-05-15 19:56       ` Ricardo Wurmus
2017-05-06 20:22   ` bug#26803: [PATCH 01/36] ant-build-system: Allow specifying source directory Roel Janssen
2017-05-07 10:34 ` bug#26803: Java things Hartmut Goebel
2017-05-07 11:47   ` Ricardo Wurmus
2017-05-08  8:18     ` Hartmut Goebel

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=87poflk9rt.fsf@gnu.org \
    --to=roel@gnu.org \
    --cc=26803@debbugs.gnu.org \
    --cc=h.goebel@crazy-compilers.com \
    --cc=rekado@elephly.net \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
Code repositories for project(s) associated with this external index

	https://git.savannah.gnu.org/cgit/guix.git

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.