~ruther/guix-local

8df1faa047870c51954275664e8e7efc94e6fc56 — Julien Lepiller 8 years ago 4d6801b
guix: ant-build-system: Add main-class support.

* guix/build-system/ant.scm: New #:main-class argument
* guix/build/ant-build-system.scm: Generate a manifest file with
additional properties.
* doc/guix.texi (Build Systems): Document it.
3 files changed, 28 insertions(+), 5 deletions(-)

M doc/guix.texi
M guix/build-system/ant.scm
M guix/build/ant-build-system.scm
M doc/guix.texi => doc/guix.texi +4 -0
@@ 3479,6 3479,10 @@ build file @file{build.xml} with tasks to build the specified jar
archive.  In this case the parameter @code{#:source-dir} can be used to
specify the source sub-directory, defaulting to ``src''.

The @code{#:main-class} parameter can be used with the minimal ant 
buildfile to specify the main class of the resulting jar.  This makes the 
jar file executable.

The parameter @code{#:build-target} can be used to specify the Ant task
that should be run during the @code{build} phase.  By default the
``jar'' task will be run.

M guix/build-system/ant.scm => guix/build-system/ant.scm +2 -0
@@ 99,6 99,7 @@
                    (make-flags ''())
                    (build-target "jar")
                    (jar-name #f)
                    (main-class #f)
                    (source-dir "src")
                    (test-dir "src/test")
                    (phases '(@ (guix build ant-build-system)


@@ 130,6 131,7 @@
                  #:test-target ,test-target
                  #:build-target ,build-target
                  #:jar-name ,jar-name
                  #:main-class ,main-class
                  #:source-dir ,source-dir
                  #:test-dir ,test-dir
                  #:phases ,phases

M guix/build/ant-build-system.scm => guix/build/ant-build-system.scm +22 -5
@@ 36,7 36,7 @@
;; Code:

(define* (default-build.xml jar-name prefix #:optional
                            (source-dir ".") (test-dir "./test"))
                            (source-dir ".") (test-dir "./test") (main-class #f))
  "Create a simple build.xml with standard targets for Ant."
  (call-with-output-file "build.xml"
    (lambda (port)


@@ 44,6 44,10 @@
       `(project (@ (basedir "."))
                 (property (@ (name "classes.dir")
                              (value "${basedir}/build/classes")))
                 (property (@ (name "manifest.dir")
                              (value "${basedir}/build/manifest")))
                 (property (@ (name "manifest.file")
                              (value "${manifest.dir}/MANIFEST.MF")))
                 (property (@ (name "jar.dir")
                              (value "${basedir}/build/jar")))
                 (property (@ (name "dist.dir")


@@ 60,6 64,17 @@
                 (path (@ (id "classpath"))
                       (pathelement (@ (location "${env.CLASSPATH}"))))

                 (target (@ (name "manifest"))
                         (mkdir (@ (dir "${manifest.dir}")))
                         (echo (@ (file "${manifest.file}")
                                  (message ,(string-append
                                              (if main-class
                                                (string-append
                                                  "Main-Class: " main-class
                                                  "${line.separator}")
                                                "")
                                              "")))))

                 (target (@ (name "compile"))
                         (mkdir (@ (dir "${classes.dir}")))
                         (javac (@ (includeantruntime "false")


@@ 97,10 112,11 @@
                                                    (include (@ (name "**/*Test.java" )))))))

                 (target (@ (name "jar")
                            (depends "compile"))
                            (depends "compile, manifest"))
                         (mkdir (@ (dir "${jar.dir}")))
                         (exec (@ (executable "jar"))
                               (arg (@ (line ,(string-append "-cf ${jar.dir}/" jar-name
                               (arg (@ (line ,(string-append "-cmf ${manifest.file} "
                                                             "${jar.dir}/" jar-name
                                                             " -C ${classes.dir} ."))))))

                 (target (@ (name "install"))


@@ 133,12 149,13 @@ to the default GNU unpack strategy."

(define* (configure #:key inputs outputs (jar-name #f)
                    (source-dir "src")
                    (test-dir "src/test") #:allow-other-keys)
                    (test-dir "src/test")
                    (main-class #f) #:allow-other-keys)
  (when jar-name
    (default-build.xml jar-name
                       (string-append (assoc-ref outputs "out")
                                      "/share/java")
                       source-dir test-dir))
                       source-dir test-dir main-class))
  (setenv "JAVA_HOME" (assoc-ref inputs "jdk"))
  (setenv "CLASSPATH" (generate-classpath inputs)))