X-Git-Url: http://git.hcoop.net/jackhill/guix/guix.git/blobdiff_plain/94261e7ce2c640a074e25a0c976bb5ac546ff429..f928abac369f699f425ddee925d0d0c2dc0a635d:/gnu/packages/maven.scm diff --git a/gnu/packages/maven.scm b/gnu/packages/maven.scm index 0eb5db3c13..b7794c4e89 100644 --- a/gnu/packages/maven.scm +++ b/gnu/packages/maven.scm @@ -1,8 +1,9 @@ ;;; GNU Guix --- Functional package management for GNU -;;; Copyright © 2018 Julien Lepiller +;;; Copyright © 2018-2022 Julien Lepiller ;;; Copyright © 2019 Tobias Geerinckx-Rice ;;; Copyright © 2019 Björn Höfling ;;; Copyright © 2020 Efraim Flashner +;;; Copyright © 2022 Artyom V. Poptsov ;;; ;;; This file is part of GNU Guix. ;;; @@ -26,6 +27,7 @@ #:use-module (guix git-download) #:use-module (guix utils) #:use-module (guix build-system ant) + #:use-module (guix gexp) #:use-module (gnu packages) #:use-module (gnu packages base) #:use-module (gnu packages compression) @@ -35,55 +37,10 @@ #:use-module (gnu packages xml) #:use-module (ice-9 match)) -(define-public java-plexus-component-metadata - (package - (inherit java-plexus-container-default) - (name "java-plexus-component-metadata") - (arguments - `(#:jar-name "plexus-component-metadata.jar" - #:source-dir "src/main/java" - #:test-dir "src/test" - #:jdk ,icedtea-8 - #:phases - (modify-phases %standard-phases - (add-before 'configure 'chdir - (lambda _ - (chdir "plexus-component-metadata") - #t)) - (add-before 'build 'copy-resources - (lambda _ - (copy-recursively "src/main/resources" - "build/classes/") - #t))))) - (propagated-inputs - `(("java-plexus-container-default" ,java-plexus-container-default) - ("java-plexu-component-annotations" ,java-plexus-component-annotations) - ("java-plexus-utils" ,java-plexus-utils) - ("java-plexus-cli" ,java-plexus-cli) - ("java-plexus-classworlds" ,java-plexus-classworlds) - ("maven-plugin-api" ,maven-plugin-api) - ("maven-plugin-annotations" ,maven-plugin-annotations) - ("maven-core-bootstrap" ,maven-core-bootstrap) - ("maven-model" ,maven-model) - ("java-commons-cli" ,java-commons-cli) - ("java-qdox" ,java-qdox) - ("java-jdom2" ,java-jdom2) - ("java-asm" ,java-asm))) - (native-inputs - `(("java-junit" ,java-junit) - ("java-guava" ,java-guava) - ("java-geronimo-xbean-reflect" ,java-geronimo-xbean-reflect))) - (synopsis "Inversion-of-control container for Maven") - (description "The Plexus project provides a full software stack for creating -and executing software projects. Based on the Plexus container, the -applications can utilise component-oriented programming to build modular, -reusable components that can easily be assembled and reused. This package -provides the Maven plugin generating the component metadata."))) - (define-public maven-resolver-api (package (name "maven-resolver-api") - (version "1.3.1") + (version "1.6.3") (source (origin (method git-fetch) (uri (git-reference @@ -92,7 +49,7 @@ provides the Maven plugin generating the component metadata."))) (file-name (git-file-name name version)) (sha256 (base32 - "1x1gll8nkfl6zgnab78fxxvvhg42b2grxgdh1wp2h4qxsjkxg93d")))) + "0hbbbxj14qyq8pccyab96pjqq90jnjmid1pml9kx55c5smfpjn37")))) (build-system ant-build-system) (arguments `(#:jar-name "maven-resolver-api.jar" @@ -103,14 +60,14 @@ provides the Maven plugin generating the component metadata."))) (replace 'install (install-from-pom "maven-resolver-api/pom.xml"))))) (native-inputs - `(("java-asm" ,java-asm) + `(("java-asm-8" ,java-asm-8) ("java-cglib" ,java-cglib) ("java-hamcrest-core" ,java-hamcrest-core) ("java-junit" ,java-junit) ("java-mockito-1" ,java-mockito-1) ("java-objenesis" ,java-objenesis))) (propagated-inputs - `(("maven-resolver-parent-pom" ,maven-resolver-parent-pom))) + (list maven-resolver-parent-pom)) (home-page "https://github.com/apache/maven-resolver") (synopsis "Maven repository system API") (description "This package contains the API for the maven repository system.") @@ -148,7 +105,7 @@ provides the Maven plugin generating the component metadata."))) (replace 'install (install-from-pom "maven-resolver-spi/pom.xml"))))) (propagated-inputs - `(("maven-resolver-api" ,maven-resolver-api))) + (list maven-resolver-api)) (synopsis "Maven repository system SPI") (description "This package contains the service provider interface (SPI) for repository system implementations and repository connectors."))) @@ -163,8 +120,7 @@ for repository system implementations and repository connectors."))) #:test-dir "maven-resolver-test-util/src/test" #:jdk ,icedtea-8)) (inputs - `(("maven-resolver-api" ,maven-resolver-api) - ("maven-resolver-spi" ,maven-resolver-spi))) + (list maven-resolver-api maven-resolver-spi)) (synopsis "Utility classes for testing the maven repository system") (description "This package contains a collection of utility classes to ease testing of the repository system."))) @@ -182,11 +138,9 @@ ease testing of the repository system."))) (replace 'install (install-from-pom "maven-resolver-util/pom.xml"))))) (propagated-inputs - `(("maven-resolver-api" ,maven-resolver-api))) + (list maven-resolver-api)) (native-inputs - `(("java-junit" ,java-junit) - ("java-hamcrest-core" ,java-hamcrest-core) - ("maven-resolver-test-util" ,maven-resolver-test-util))) + (list java-junit java-hamcrest-core maven-resolver-test-util)) (synopsis "Utility classes for the maven repository system") (description "This package contains a collection of utility classes to ease usage of the repository system."))) @@ -212,14 +166,10 @@ ease usage of the repository system."))) (replace 'install (install-from-pom "maven-resolver-connector-basic/pom.xml"))))) (propagated-inputs - `(("maven-resolver-api" ,maven-resolver-api) - ("maven-resolver-spi" ,maven-resolver-spi) - ("maven-resolver-util" ,maven-resolver-util) - ("java-slf4j-api" ,java-slf4j-api))) + (list maven-resolver-api maven-resolver-spi maven-resolver-util + java-slf4j-api)) (native-inputs - `(("java-javax-inject" ,java-javax-inject) - ("java-junit" ,java-junit) - ("maven-resolver-test-util" ,maven-resolver-test-util))) + (list java-javax-inject java-junit maven-resolver-test-util)) (synopsis "Maven repository connector implementation") (description "This package contains a repository connector implementation for repositories using URI-based layouts."))) @@ -269,17 +219,17 @@ for repositories using URI-based layouts."))) (replace 'install (install-from-pom "maven-resolver-impl/pom.xml"))))) (propagated-inputs - `(("maven-resolver-api" ,maven-resolver-api) - ("maven-resolver-spi" ,maven-resolver-spi) - ("maven-resolver-util" ,maven-resolver-util) - ("java-eclipse-sisu-inject" ,java-eclipse-sisu-inject) - ("java-javax-inject" ,java-javax-inject) - ("java-guice" ,java-guice) - ("java-slf4j-api" ,java-slf4j-api) - ("maven-resolver-parent-pom" ,maven-resolver-parent-pom))) + (list maven-resolver-api + maven-resolver-spi + maven-resolver-util + java-commons-lang3 + java-eclipse-sisu-inject + java-javax-inject + java-guice + java-slf4j-api + maven-resolver-parent-pom)) (native-inputs - `(("java-junit" ,java-junit) - ("maven-resolver-test-util" ,maven-resolver-test-util))))) + (list java-junit maven-resolver-test-util)))) (define-public maven-resolver-transport-wagon (package @@ -346,25 +296,121 @@ for repositories using URI-based layouts."))) ("maven-resolver-util" ,maven-resolver-util) ("java-javax-inject" ,java-javax-inject) ("mavne-wagon-provider-api" ,maven-wagon-provider-api) - ("java-plexus-component-annotation" ,java-plexus-component-annotations) + ("java-plexus-component-annotation" ,java-plexus-component-annotations-1.7) ("java-plexus-classworld" ,java-plexus-classworlds) ("java-plexus-plexus-util" ,java-plexus-utils) ("java-slf4j-api" ,java-slf4j-api) ("java-eclipse-sisu-inject" ,java-eclipse-sisu-inject) ("java-eclipse-sisu-plexus" ,java-eclipse-sisu-plexus))) (native-inputs - `(("java-junit" ,java-junit) - ("java-hamcrest-core" ,java-hamcrest-core) - ("maven-resolver-test-util" ,maven-resolver-test-util) - ("java-guava" ,java-guava) - ("java-cglib" ,java-cglib) - ("java-asm" ,java-asm) - ("java-aopalliance" ,java-aopalliance) - ("java-guice" ,java-guice))) + (list java-junit + java-hamcrest-core + maven-resolver-test-util + java-guava + java-cglib + java-aopalliance + java-guice)) (synopsis "Transport implementation for Maven") (description "This package contains a transport implementation based on Maven Wagon, for use in Maven."))) +(define-public maven-resolver-transport-file + (package + (inherit maven-resolver-api) + (name "maven-resolver-transport-file") + (arguments + `(#:jar-name "maven-resolver-transport-file.jar" + #:source-dir "maven-resolver-transport-file/src/main/java" + #:test-dir "maven-resolver-transport-file/src/test" + #:jdk ,icedtea-8 + #:phases + (modify-phases %standard-phases + (add-before 'build 'generate-sisu + (lambda _ + (mkdir-p "build/classes/META-INF/sisu") + (with-output-to-file "build/classes/META-INF/sisu/javax.inject.Named" + (lambda _ + (display "org.eclipse.aether.transport.file.FileTransporterFactory\n")))))))) + (inputs + (list java-eclipse-sisu-inject + java-eclipse-sisu-plexus + java-javax-inject + java-plexus-classworlds + java-plexus-component-annotations + java-plexus-utils + java-slf4j-api + maven-resolver-api + maven-resolver-spi + maven-resolver-util + maven-wagon-provider-api)) + (native-inputs + (list java-asm + java-aopalliance + java-cglib + java-guava + java-guice + java-hamcrest-core + java-junit + maven-resolver-test-util)) + (synopsis "Transport implementation for Maven") + (description "This package contains a transport implementation based on +files, for use in Maven."))) + +(define-public maven-resolver-transport-http + (package + (inherit maven-resolver-api) + (name "maven-resolver-transport-http") + (arguments + `(#:jar-name "maven-resolver-transport-http.jar" + #:source-dir "maven-resolver-transport-http/src/main/java" + #:test-dir "maven-resolver-transport-http/src/test" + #:jdk ,icedtea-8 + ;; Tests all fail because + ;; org.eclipse.aether.transport.http.SslSocketFactory is not available. + #:tests? #f + #:phases + (modify-phases %standard-phases + (add-before 'build 'generate-sisu + (lambda _ + (mkdir-p "build/classes/META-INF/sisu") + (with-output-to-file "build/classes/META-INF/sisu/javax.inject.Named" + (lambda _ + (display "org.eclipse.aether.transport.http.HttpTransporterFactory\n")))))))) + (inputs + (list java-eclipse-sisu-inject + java-eclipse-sisu-plexus + java-javax-inject + java-plexus-classworlds + java-plexus-component-annotations + java-plexus-utils + java-slf4j-api + maven-resolver-api + maven-resolver-spi + maven-resolver-util + maven-wagon-provider-api)) + (propagated-inputs + (list java-httpcomponents-httpclient + java-httpcomponents-httpcore)) + (native-inputs + (list java-aopalliance + java-asm + java-cglib + java-eclipse-aether-api + java-eclipse-jetty-http + java-eclipse-jetty-io + java-eclipse-jetty-server + java-eclipse-jetty-servlet + java-eclipse-jetty-util + java-guava + java-guice + java-hamcrest-core + java-javaee-servletapi + java-junit + maven-resolver-test-util)) + (synopsis "Transport implementation for Maven") + (description "This package contains a transport implementation based on +HTTP, for use in Maven."))) + ;; aether is the parent project that was forked into maven-resolver. It used ;; to be used with older versions of Maven, and is still required for some ;; plugins and their dependencies. This version is required for the plugins, @@ -392,8 +438,8 @@ Maven Wagon, for use in Maven."))) (add-before 'install 'install-parent (install-pom-file "pom.xml")) (replace 'install (install-from-pom "aether-api/pom.xml"))))) (propagated-inputs - `(("java-sonatype-forge-parent-pom" ,java-sonatype-forge-parent-pom-6))) - (native-inputs `(("java-junit" ,java-junit))) + (list java-sonatype-forge-parent-pom-6)) + (native-inputs (list java-junit)) (home-page "https://github.com/sonatype/sonatype-aether") (synopsis "Maven repository system API") (description "This package contains the API for the maven repository system.") @@ -411,7 +457,7 @@ Maven Wagon, for use in Maven."))) (modify-phases %standard-phases (replace 'install (install-from-pom "aether-spi/pom.xml"))))) (propagated-inputs - `(("java-sonatype-aether-api" ,java-sonatype-aether-api))) + (list java-sonatype-aether-api)) (synopsis "Maven repository system SPI") (description "This package contains the service provider interface (SPI) for repository system implementations and repository connectors."))) @@ -425,8 +471,7 @@ for repository system implementations and repository connectors."))) #:source-dir "aether-test-util/src/main/java" #:test-dir "aether-test-util/src/test")) (inputs - `(("java-sonatype-aether-api" ,java-sonatype-aether-api) - ("java-sonatype-aether-spi" ,java-sonatype-aether-spi))) + (list java-sonatype-aether-api java-sonatype-aether-spi)) (synopsis "Utility classes for testing the maven repository system") (description "This package contains a collection of utility classes to ease testing of the repository system."))) @@ -443,10 +488,9 @@ ease testing of the repository system."))) (modify-phases %standard-phases (replace 'install (install-from-pom "aether-util/pom.xml"))))) (propagated-inputs - `(("java-sonatype-aether-api" ,java-sonatype-aether-api))) + (list java-sonatype-aether-api)) (native-inputs - `(("java-junit" ,java-junit) - ("java-sonatype-aether-test-util" ,java-sonatype-aether-test-util))) + (list java-junit java-sonatype-aether-test-util)) (synopsis "Utility classes for the maven repository system") (description "This package contains a collection of utility classes to ease usage of the repository system."))) @@ -482,16 +526,98 @@ ease usage of the repository system."))) #t)) (replace 'install (install-from-pom "aether-impl/pom.xml"))))) (propagated-inputs - `(("java-sonatype-aether-api" ,java-sonatype-aether-api) - ("java-sonatype-aether-spi" ,java-sonatype-aether-spi) - ("java-sonatype-aether-util" ,java-sonatype-aether-util) - ("java-plexus-component-annotations" ,java-plexus-component-annotations) - ("java-plexus-container-default" ,java-plexus-container-default) - ("java-slf4j-api" ,java-slf4j-api))) + (list java-sonatype-aether-api + java-sonatype-aether-spi + java-sonatype-aether-util + java-plexus-component-annotations + java-plexus-container-default + java-slf4j-api)) + (native-inputs + (list java-junit java-plexus-component-metadata + java-sonatype-aether-test-util)))) + +;; This slightly newer version is also required by some plugins +(define-public java-sonatype-aether-api-1.13 + (package + (name "java-sonatype-aether-api") + (version "1.13.1") + (source (origin + (method git-fetch) + (uri (git-reference + (url "https://github.com/sonatype/sonatype-aether") + (commit (string-append "aether-" version)))) + (file-name (git-file-name name version)) + (sha256 + (base32 + "1yl34dqhm6ykb7h63gkssyrdxv3dsa3n5b8d8cvy8rh4qsm6p2yb")))) + (build-system ant-build-system) + (arguments + `(#:jar-name "aether-api.jar" + #:source-dir "aether-api/src/main/java" + #:test-dir "aether-api/src/test" + #:phases + (modify-phases %standard-phases + (add-before 'install 'install-parent (install-pom-file "pom.xml")) + (replace 'install (install-from-pom "aether-api/pom.xml"))))) + (propagated-inputs + `(("java-sonatype-forge-parent-pom" ,java-sonatype-forge-parent-pom-10))) + (native-inputs `(("java-junit" ,java-junit))) + (home-page "https://github.com/sonatype/sonatype-aether") + (synopsis "Maven repository system API") + (description "This package contains the API for the maven repository system.") + (license license:asl2.0))) + +(define-public java-sonatype-aether-spi-1.13 + (package + (inherit java-sonatype-aether-api-1.13) + (name "java-sonatype-aether-spi") + (arguments + `(#:jar-name "aether-spi.jar" + #:source-dir "aether-spi/src/main/java" + #:tests? #f; no tests + #:phases + (modify-phases %standard-phases + (replace 'install (install-from-pom "aether-spi/pom.xml"))))) + (propagated-inputs + `(("java-sonatype-aether-api" ,java-sonatype-aether-api-1.13))) + (synopsis "Maven repository system SPI") + (description "This package contains the service provider interface (SPI) +for repository system implementations and repository connectors."))) + +(define-public java-sonatype-aether-test-util-1.13 + (package + (inherit java-sonatype-aether-api-1.13) + (name "java-sonatype-aether-test-util") + (arguments + `(#:jar-name "java-sonatype-aether-test-util.jar" + #:source-dir "aether-test-util/src/main/java" + #:test-dir "aether-test-util/src/test")) + (inputs + `(("java-sonatype-aether-api" ,java-sonatype-aether-api-1.13) + ("java-sonatype-aether-spi" ,java-sonatype-aether-spi-1.13))) + (synopsis "Utility classes for testing the maven repository system") + (description "This package contains a collection of utility classes to +ease testing of the repository system."))) + +(define-public java-sonatype-aether-util-1.13 + (package + (inherit java-sonatype-aether-api-1.13) + (name "java-sonatype-aether-util") + (arguments + `(#:jar-name "aether-util.jar" + #:source-dir "aether-util/src/main/java" + #:test-dir "aether-util/src/test" + #:phases + (modify-phases %standard-phases + (replace 'install (install-from-pom "aether-util/pom.xml"))))) + (propagated-inputs + `(("java-sonatype-aether-api" ,java-sonatype-aether-api-1.13))) (native-inputs `(("java-junit" ,java-junit) - ("java-plexus-component-metadata" ,java-plexus-component-metadata) - ("java-sonatype-aether-test-util" ,java-sonatype-aether-test-util))))) + ("java-sonatype-aether-test-util" ,java-sonatype-aether-test-util-1.13))) + (synopsis "Utility classes for the maven repository system") + (description "This package contains a collection of utility classes to +ease usage of the repository system."))) ;; Again, this old version is required by some maven plugins (define-public java-eclipse-aether-api @@ -516,7 +642,7 @@ ease usage of the repository system."))) (modify-phases %standard-phases (add-before 'install 'install-parent (install-pom-file "pom.xml")) (replace 'install (install-from-pom "aether-api/pom.xml"))))) - (native-inputs `(("java-junit" ,java-junit))) + (native-inputs (list java-junit)) (home-page "https://github.com/sonatype/sonatype-aether") (synopsis "Maven repository system API") (description "This package contains the API for the maven repository system.") @@ -534,7 +660,7 @@ ease usage of the repository system."))) (modify-phases %standard-phases (replace 'install (install-from-pom "aether-spi/pom.xml"))))) (propagated-inputs - `(("java-eclipse-aether-api" ,java-eclipse-aether-api))) + (list java-eclipse-aether-api)) (synopsis "Maven repository system SPI") (description "This package contains the service provider interface (SPI) for repository system implementations and repository connectors."))) @@ -551,8 +677,7 @@ for repository system implementations and repository connectors."))) (modify-phases %standard-phases (replace 'install (install-from-pom "aether-util/pom.xml"))))) (propagated-inputs - `(("java-eclipse-aether-api" ,java-eclipse-aether-api) - ("java-eclipse-aether-spi" ,java-eclipse-aether-spi))) + (list java-eclipse-aether-api java-eclipse-aether-spi)) (synopsis "Utility classes for testing the maven repository system") (description "This package contains a collection of utility classes to ease testing of the repository system."))) @@ -569,10 +694,9 @@ ease testing of the repository system."))) (modify-phases %standard-phases (replace 'install (install-from-pom "aether-util/pom.xml"))))) (propagated-inputs - `(("java-eclipse-aether-api" ,java-eclipse-aether-api))) + (list java-eclipse-aether-api)) (native-inputs - `(("java-eclipse-aether-test-util" ,java-eclipse-aether-test-util) - ("java-junit" ,java-junit))) + (list java-eclipse-aether-test-util java-junit)) (synopsis "Utility classes for the maven repository system") (description "This package contains a collection of utility classes to ease usage of the repository system."))) @@ -589,16 +713,15 @@ ease usage of the repository system."))) (modify-phases %standard-phases (replace 'install (install-from-pom "aether-impl/pom.xml"))))) (propagated-inputs - `(("java-eclipse-aether-api" ,java-eclipse-aether-api) - ("java-eclipse-aether-spi" ,java-eclipse-aether-spi) - ("java-eclipse-aether-util" ,java-eclipse-aether-util) - ("java-javax-inject" ,java-javax-inject) - ("java-eclipse-sisu-inject" ,java-eclipse-sisu-inject) - ("java-guice" ,java-guice) - ("java-slf4j-api" ,java-slf4j-api))) + (list java-eclipse-aether-api + java-eclipse-aether-spi + java-eclipse-aether-util + java-javax-inject + java-eclipse-sisu-inject + java-guice + java-slf4j-api)) (native-inputs - `(("java-eclipse-aether-test-util" ,java-eclipse-aether-test-util) - ("java-junit" ,java-junit))))) + (list java-eclipse-aether-test-util java-junit)))) (define-public maven-shared-utils (package @@ -636,10 +759,7 @@ ease usage of the repository system."))) ("java-plexus-container-default" ,java-plexus-container-default) ("maven-parent-pom-30" ,maven-parent-pom-30))) (native-inputs - `(("unzip" ,unzip) - ("java-junit" ,java-junit) - ("java-hamcrest-core" ,java-hamcrest-core) - ("java-commons-lang3" ,java-commons-lang3))) + (list unzip java-junit java-hamcrest-core java-commons-lang3)) (home-page "https://maven.apache.org/shared/maven-shared-utils/") (synopsis "Plexus-util replacement for maven") (description "This project aims to be a functional replacement for @@ -661,27 +781,45 @@ replacement with improvements.") (arguments `(#:jar-name "maven-plugin-annotations.jar" #:source-dir "maven-plugin-annotations/src/main/java" - #:tests? #f)) - (inputs - `(("maven-artifact" ,maven-artifact))) + #:tests? #f + #:phases + (modify-phases %standard-phases + (replace 'install + (install-from-pom "maven-plugin-annotations/pom.xml"))))) + (propagated-inputs + (list maven-artifact maven-plugin-tools-parent-pom)) (native-inputs - `(("unzip" ,unzip))) + (list unzip)) (home-page "https://maven.apache.org/plugin-tools/maven-plugin-annotations/") (synopsis "Java 5 annotations to use in Mojos") (description "This package contains Java 5 annotations for use in Mojos.") (license license:asl2.0))) +(define maven-plugin-tools-parent-pom + (package + (inherit maven-plugin-annotations) + (name "maven-plugin-tools-parent-pom") + (arguments + `(#:tests? #f + #:phases + (modify-phases %standard-phases + (delete 'configure) + (delete 'build) + (replace 'install + (install-pom-file "pom.xml"))))) + (propagated-inputs '()))) + (define-public maven-wagon-provider-api (package (name "maven-wagon-provider-api") - (version "3.3.4") + (version "3.4.3") (source (origin (method url-fetch) (uri (string-append "https://archive.apache.org/dist/maven/wagon/" "wagon-" version "-source-release.zip")) (sha256 (base32 - "1iq9bilgfklzbxwwhzi3f19mkbaaf9dh9f83h3yz5gbmvypask9a")))) + "1rnviw0yr4g5902fb8pkd1gyvci4bz7hndjvhkqmnkj7ay0y6mf0")))) (build-system ant-build-system) (arguments `(#:jar-name "maven-wagon-provider-api.jar" @@ -695,9 +833,7 @@ replacement with improvements.") `(("java-plexus-utils" ,java-plexus-utils) ("maven-wagon-parent-pom" ,maven-wagon-parent-pom))) (native-inputs - `(("unzip" ,unzip) - ("java-junit" ,java-junit) - ("java-easymock" ,java-easymock))) + (list unzip java-junit java-easymock)) (home-page "https://maven.apache.org/wagon") (synopsis "Transport abstraction for Maven") (description "Maven Wagon is a transport abstraction that is used in Maven's @@ -778,12 +914,11 @@ classes used in multiple maven-wagon components."))) (invoke "ant" "jar") #t))))) (inputs - `(("java-plexus-utils" ,java-plexus-utils) - ("maven-wagon-provider-api" ,maven-wagon-provider-api))) + (list java-plexus-utils maven-wagon-provider-api)) (native-inputs `(("maven-wagon-provider-test" ,maven-wagon-provider-test) - ("java-plexus-component-metadata" ,java-plexus-component-metadata) - ("java-plexus-component-annotations" ,java-plexus-component-annotations) + ("java-plexus-component-metadata" ,java-plexus-component-metadata-1.7) + ("java-plexus-component-annotations" ,java-plexus-component-annotations-1.7) ("java-eclipse-sisu-plexus" ,java-eclipse-sisu-plexus) ("java-eclipse-sisu-inject" ,java-eclipse-sisu-inject) ("java-plexus-classworlds" ,java-plexus-classworlds) @@ -801,7 +936,6 @@ classes used in multiple maven-wagon components."))) ("java-commons-cli" ,java-commons-cli) ("java-qdox" ,java-qdox) ("java-jdom2" ,java-jdom2) - ("java-asm" ,java-asm) ("java-geronimo-xbean-reflect" ,java-geronimo-xbean-reflect) ,@(package-native-inputs maven-wagon-provider-api))) (synopsis "Wagon provider that gets and puts artifacts using the file system") @@ -862,16 +996,16 @@ Test Compatibility Kit."))) (invoke "ant" "jar") #t))))) (inputs - `(("java-plexus-utils" ,java-plexus-utils) - ("java-httpcomponents-httpclient" ,java-httpcomponents-httpclient) - ("java-httpcomponents-httpcore" ,java-httpcomponents-httpcore) - ("java-commons-io" ,java-commons-io) - ("java-jsoup" ,java-jsoup) - ("maven-wagon-provider-api" ,maven-wagon-provider-api))) + (list java-plexus-utils + java-httpcomponents-httpclient + java-httpcomponents-httpcore + java-commons-io + java-jsoup + maven-wagon-provider-api)) (native-inputs `(("maven-wagon-provider-test" ,maven-wagon-provider-test) - ("java-plexus-component-metadata" ,java-plexus-component-metadata) - ("java-plexus-component-annotations" ,java-plexus-component-annotations) + ("java-plexus-component-metadata" ,java-plexus-component-metadata-1.7) + ("java-plexus-component-annotations" ,java-plexus-component-annotations-1.7) ("java-eclipse-sisu-plexus" ,java-eclipse-sisu-plexus) ("java-eclipse-sisu-inject" ,java-eclipse-sisu-inject) ("java-plexus-classworlds" ,java-plexus-classworlds) @@ -889,10 +1023,9 @@ Test Compatibility Kit."))) ("java-commons-cli" ,java-commons-cli) ("java-qdox" ,java-qdox) ("java-jdom2" ,java-jdom2) - ("java-asm" ,java-asm) ("java-geronimo-xbean-reflect" ,java-geronimo-xbean-reflect) ,@(package-native-inputs maven-wagon-provider-api))) - (synopsis "Shared Library for wagon providers supporting HTTP.") + (synopsis "Shared Library for wagon providers supporting HTTP") (description "Maven Wagon is a transport abstraction that is used in Maven's artifact and repository handling code. It uses providers, that are tools to manage artifacts and deployment. This package contains a shared library for @@ -915,6 +1048,8 @@ wagon providers supporting HTTP."))) ;; unable to find valid certification path to requested target "**/HttpsWagonPreemptiveTest.java" "**/HttpsWagonTest.java" + ;; Timeout + "**/HugeFileDownloadTest.java" ;; Injection errors "**/TckTest.java") #:jdk ,icedtea-8 @@ -932,16 +1067,16 @@ wagon providers supporting HTTP."))) (("src/test") "wagon-providers/wagon-http/src/test")) #t))))) (inputs - `(("java-plexus-utils" ,java-plexus-utils) - ("java-httpcomponents-httpclient" ,java-httpcomponents-httpclient) - ("java-httpcomponents-httpcore" ,java-httpcomponents-httpcore) - ("maven-wagon-http-shared" ,maven-wagon-http-shared) - ("maven-wagon-tck-http" ,maven-wagon-tck-http) - ("maven-wagon-provider-api" ,maven-wagon-provider-api))) + (list java-plexus-utils + java-httpcomponents-httpclient + java-httpcomponents-httpcore + maven-wagon-http-shared + maven-wagon-tck-http + maven-wagon-provider-api)) (native-inputs `(("maven-wagon-provider-test" ,maven-wagon-provider-test) - ("java-plexus-component-metadata" ,java-plexus-component-metadata) - ("java-plexus-component-annotations" ,java-plexus-component-annotations) + ("java-plexus-component-metadata" ,java-plexus-component-metadata-1.7) + ("java-plexus-component-annotations" ,java-plexus-component-annotations-1.7) ("java-eclipse-sisu-plexus" ,java-eclipse-sisu-plexus) ("java-plexus-container-default" ,java-plexus-container-default) ("java-eclipse-sisu-inject" ,java-eclipse-sisu-inject) @@ -955,12 +1090,12 @@ wagon providers supporting HTTP."))) ("java-plexus-cli" ,java-plexus-cli) ("maven-plugin-api" ,maven-plugin-api) ("maven-plugin-annotations" ,maven-plugin-annotations) + ("maven-slf4j-provider" ,maven-slf4j-provider) ("maven-core" ,maven-core) ("maven-model" ,maven-model) ("java-commons-cli" ,java-commons-cli) ("java-qdox" ,java-qdox) ("java-jdom2" ,java-jdom2) - ("java-asm" ,java-asm) ("java-geronimo-xbean-reflect" ,java-geronimo-xbean-reflect) ("java-javaee-servletapi" ,java-javaee-servletapi) ("java-eclipse-jetty-util-9.2" ,java-eclipse-jetty-util-9.2) @@ -974,7 +1109,6 @@ wagon providers supporting HTTP."))) ("java-commons-codec" ,java-commons-codec) ("java-commons-io" ,java-commons-io) ("java-jsoup" ,java-jsoup) - ("java-slf4j-simple" ,java-slf4j-simple) ,@(package-native-inputs maven-wagon-provider-api))) (synopsis "Wagon provider that gets and puts artifacts through HTTP(S)") (description "Maven Wagon is a transport abstraction that is used in Maven's @@ -985,13 +1119,13 @@ gets and puts artifacts through HTTP(S) using Apache HttpClient-4.x."))) (define maven-pom (package (name "maven-pom") - (version "3.6.1") + (version "3.8.6") (source (origin (method url-fetch) (uri (string-append "mirror://apache/maven/" "maven-3/" version "/source/" "apache-maven-" version "-src.tar.gz")) - (sha256 (base32 "0grw9zp166ci53rd7qkyy2qmwmik37xhiz1z84jpm0msyvzj2n82")) + (sha256 (base32 "0jszmcaxp597a62ajrc478jxix1qmw4pknhiygsbjdy3kccc7gvj")) (modules '((guix build utils))) (snippet '(begin @@ -1065,7 +1199,7 @@ gets and puts artifacts through HTTP(S) using Apache HttpClient-4.x."))) (replace 'install (install-pom-file "pom.xml"))))) (propagated-inputs - `(("maven-parent-pom-33" ,maven-parent-pom-33))) + (list maven-parent-pom-35)) (home-page "https://maven.apache.org/") (synopsis "Build system") (description "Apache Maven is a software project management and comprehension @@ -1086,11 +1220,9 @@ tool. This package contains the Maven pom file, used by all maven components.") (replace 'install (install-from-pom "maven-artifact/pom.xml"))))) (propagated-inputs - `(("java-plexus-utils" ,java-plexus-utils) - ("java-commons-lang3" ,java-commons-lang3) - ("maven-pom" ,maven-pom))) + (list java-plexus-utils java-commons-lang3 maven-pom)) (native-inputs - `(("java-junit" ,java-junit))) + (list java-junit)) (description "Apache Maven is a software project management and comprehension tool. This package contains the Maven Artifact classes, providing the @code{Artifact} interface, with its @code{DefaultArtifact} implementation. The @@ -1116,34 +1248,33 @@ and compares versions:"))) (let ((file "maven-model/src/main/mdo/maven.mdo")) (modello-single-mode file "4.0.0" "java") (modello-single-mode file "4.0.0" "xpp3-reader") + (modello-single-mode file "4.0.0" "xpp3-extended-reader") (modello-single-mode file "4.0.0" "xpp3-writer") - (modello-single-mode file "4.0.0" "xpp3-extended-reader")) + (modello-single-mode file "4.0.0" "xpp3-extended-writer")) #t)) (replace 'install (install-from-pom "maven-model/pom.xml"))))) (propagated-inputs - `(("java-commons-lang3" ,java-commons-lang3) - ("java-plexus-utils" ,java-plexus-utils) - ("maven-pom" ,maven-pom))) + (list java-commons-lang3 java-plexus-utils maven-pom)) (native-inputs - `(("java-modello-core" ,java-modello-core) - ;; for modello: - ("java-eclipse-sisu-plexus" ,java-eclipse-sisu-plexus) - ("java-plexus-component-annotations" ,java-plexus-component-annotations) - ("java-guice" ,java-guice) - ("java-cglib" ,java-cglib) - ("java-asm" ,java-asm) - ("java-eclipse-sisu-inject" ,java-eclipse-sisu-inject) - ("java-javax-inject" ,java-javax-inject) - ("java-plexus-classworlds" ,java-plexus-classworlds) - ("java-guava" ,java-guava) - ("java-geronimo-xbean-reflect" ,java-geronimo-xbean-reflect) - ("java-sisu-build-api" ,java-sisu-build-api) - ;; modello plugins: - ("java-modello-plugins-java" ,java-modello-plugins-java) - ("java-modello-plugins-xml" ,java-modello-plugins-xml) - ("java-modello-plugins-xpp3" ,java-modello-plugins-xpp3) - ;; for tests - ("java-junit" ,java-junit))) + (list java-modello-core + ;; for modello: + java-eclipse-sisu-plexus + java-plexus-component-annotations + java-guice + java-cglib + java-asm + java-eclipse-sisu-inject + java-javax-inject + java-plexus-classworlds + java-guava + java-geronimo-xbean-reflect + java-plexus-build-api + ;; modello plugins: + java-modello-plugins-java + java-modello-plugins-xml + java-modello-plugins-xpp3 + ;; for tests + java-junit)) (description "Apache Maven is a software project management and comprehension tool. This package contains the model for Maven @dfn{POM} (Project Object Model), so really just plain Java objects."))) @@ -1169,9 +1300,9 @@ so really just plain Java objects."))) #t)) (replace 'install (install-from-pom "maven-builder-support/pom.xml"))))) (propagated-inputs - `(("maven-pom" ,maven-pom))) + (list maven-pom)) (native-inputs - `(("java-junit" ,java-junit))) + (list java-junit)) (description "Apache Maven is a software project management and comprehension tool. This package contains a support library for descriptor builders (model, setting, toolchains)"))) @@ -1193,34 +1324,32 @@ setting, toolchains)"))) file mode "maven-settings/src/main/java" version "false" "true")) (let ((file "maven-settings/src/main/mdo/settings.mdo")) - (modello-single-mode file "1.1.0" "java") - (modello-single-mode file "1.1.0" "xpp3-reader") - (modello-single-mode file "1.1.0" "xpp3-writer")) + (modello-single-mode file "1.2.0" "java") + (modello-single-mode file "1.2.0" "xpp3-reader") + (modello-single-mode file "1.2.0" "xpp3-writer")) #t)) (replace 'install (install-from-pom "maven-settings/pom.xml"))))) (propagated-inputs - `(("java-plexus-utils" ,java-plexus-utils) - ("maven-pom" ,maven-pom))) + (list java-plexus-utils maven-pom)) (native-inputs - `(("java-modello-core" ,java-modello-core) - ;; for modello: - ;("container" ,java-plexus-container-default) - ("java-eclipse-sisu-plexus" ,java-eclipse-sisu-plexus) - ("java-plexus-component-annotations" ,java-plexus-component-annotations) - ("java-guice" ,java-guice) - ("java-cglib" ,java-cglib) - ("java-asm" ,java-asm) - ("java-eclipse-sisu-inject" ,java-eclipse-sisu-inject) - ("java-javax-inject" ,java-javax-inject) - ("java-plexus-classworlds" ,java-plexus-classworlds) - ("java-plexus-utils" ,java-plexus-utils) - ("java-guava" ,java-guava) - ("java-geronimo-xbean-reflect" ,java-geronimo-xbean-reflect) - ("java-sisu-build-api" ,java-sisu-build-api) - ;; modello plugins: - ("java-modello-plugins-java" ,java-modello-plugins-java) - ("java-modello-plugins-xml" ,java-modello-plugins-xml) - ("java-modello-plugins-xpp3" ,java-modello-plugins-xpp3))) + (list java-modello-core + ;; for modello: + ;("container" ,java-plexus-container-default) + java-eclipse-sisu-plexus + java-plexus-component-annotations + java-guice + java-cglib + java-eclipse-sisu-inject + java-javax-inject + java-plexus-classworlds + java-plexus-utils + java-guava + java-geronimo-xbean-reflect + java-plexus-build-api + ;; modello plugins: + java-modello-plugins-java + java-modello-plugins-xml + java-modello-plugins-xpp3)) (description "Apache Maven is a software project management and comprehension tool. This package contains strictly the model for Maven settings, that is simply plain java objects."))) @@ -1236,24 +1365,22 @@ simply plain java objects."))) #:test-dir "maven-settings-builder/src/test" #:phases (modify-phases %standard-phases - (add-before 'build 'generate-components.xml + (add-before 'build 'generate-sisu-named (lambda _ - (mkdir-p "build/classes/META-INF/plexus") - (chmod "components.sh" #o755) - (invoke "./components.sh" "maven-settings-builder/src/main/java" - "build/classes/META-INF/plexus/components.xml") - #t)) + (mkdir-p "build/classes/META-INF/sisu") + (chmod "sisu.sh" #o755) + (invoke "./sisu.sh" "maven-settings-builder/src/main/java" + "build/classes/META-INF/sisu/javax.inject.Named"))) (replace 'install (install-from-pom "maven-settings-builder/pom.xml"))))) (propagated-inputs - `(("java-plexus-utils" ,java-plexus-utils) - ("java-plexus-interpolation" ,java-plexus-interpolation) - ("java-plexus-sec-dispatcher" ,java-plexus-sec-dispatcher) - ("maven-builder-support" ,maven-builder-support) - ("maven-settings" ,maven-settings) - ("maven-pom" ,maven-pom))) + (list java-plexus-utils + java-plexus-interpolation + java-plexus-sec-dispatcher + maven-builder-support + maven-settings + maven-pom)) (native-inputs - `(("java-junit" ,java-junit) - ("java-plexus-component-annotations" ,java-plexus-component-annotations))) + (list java-junit java-javax-inject java-plexus-component-annotations)) (description "Apache Maven is a software project management and comprehension tool. This package contains the effective model builder, with profile activation, inheritance, interpolation, @dots{}"))) @@ -1264,45 +1391,45 @@ inheritance, interpolation, @dots{}"))) (name "maven-model-builder") (arguments `(#:jar-name "maven-model-builder.jar" - #:source-dir "maven-model-builder/src/main/java" + #:source-dir "src/main/java" #:jdk ,icedtea-8 - #:test-dir "maven-model-builder/src/test" + #:test-dir "src/test" #:phases (modify-phases %standard-phases + (add-before 'configure 'chdir + (lambda _ + ;; Required for tests that rely on the package's default + ;; locations, that reference ${basedir}/src/test. + (chdir "maven-model-builder"))) (add-before 'build 'copy-resources (lambda _ - (copy-recursively "maven-model-builder/src/main/resources" + (copy-recursively "src/main/resources" "build/classes") #t)) - (add-before 'build 'generate-components.xml - (lambda _ - (mkdir-p "build/classes/META-INF/plexus") - (chmod "components.sh" #o755) - (invoke "./components.sh" "maven-model-builder/src/main/java" - "build/classes/META-INF/plexus/components.xml") - #t)) - (add-before 'check 'fix-paths + (add-before 'build 'generate-sisu-named (lambda _ - (substitute* (find-files "maven-model-builder/src/test/java" ".*.java") - (("src/test") "maven-model-builder/src/test")) - #t)) + (mkdir-p "build/classes/META-INF/sisu") + (chmod "../sisu.sh" #o755) + (invoke "../sisu.sh" "src/main/java" + "build/classes/META-INF/sisu/javax.inject.Named"))) (replace 'install - (install-from-pom "maven-model-builder/pom.xml"))))) + (install-from-pom "pom.xml"))))) (propagated-inputs - `(("java-plexus-interpolation" ,java-plexus-interpolation) - ("java-plexus-utils" ,java-plexus-utils) - ("maven-artifact" ,maven-artifact) - ("maven-builder-support" ,maven-builder-support) - ("maven-model" ,maven-model) - ("maven-pom" ,maven-pom))) + (list java-plexus-interpolation + java-plexus-utils + maven-artifact + maven-builder-support + maven-model + maven-pom)) (native-inputs `(("java-junit" ,java-junit) ("java-guava" ,java-guava) ("java-eclipse-sisu-plexus" ,java-eclipse-sisu-plexus) ("java-plexus-component-annotations" ,java-plexus-component-annotations) + ("java-powermock-reflect" ,java-powermock-reflect) + ("java-objenesis" ,java-objenesis) ("guice" ,java-guice) ("java-cglib" ,java-cglib) - ("java-asm" ,java-asm) ("sisu-inject" ,java-eclipse-sisu-inject) ("javax-inject" ,java-javax-inject) ("java-xmlunit" ,java-xmlunit) @@ -1338,8 +1465,7 @@ inheritance, interpolation, @dots{}"))) (replace 'install (install-from-pom "maven-repository-metadata/pom.xml"))))) (propagated-inputs - `(("java-plexus-utils" ,java-plexus-utils) - ("maven-pom" ,maven-pom))) + (list java-plexus-utils maven-pom)) (native-inputs `(("modello" ,java-modello-core) ;; for modello: @@ -1354,7 +1480,7 @@ inheritance, interpolation, @dots{}"))) ("java-plexus-classworlds" ,java-plexus-classworlds) ("java-guava" ,java-guava) ("java-geronimo-xbean-reflect" ,java-geronimo-xbean-reflect) - ("java-sisu-build-api" ,java-sisu-build-api) + ("java-plexus-build-api" ,java-plexus-build-api) ;; modello plugins: ("java-modello-plugins-java" ,java-modello-plugins-java) ("java-modello-plugins-xml" ,java-modello-plugins-xml) @@ -1385,18 +1511,18 @@ so really just plain objects."))) (replace 'install (install-from-pom "maven-resolver-provider/pom.xml"))))) (propagated-inputs - `(("maven-model" ,maven-model) - ("maven-model-builder" ,maven-model-builder) - ("maven-resolver-spi" ,maven-resolver-spi) - ("maven-resolver-api" ,maven-resolver-api) - ("maven-resolver-impl" ,maven-resolver-impl) - ("maven-resolver-util" ,maven-resolver-util) - ("maven-builder-support" ,maven-builder-support) - ("maven-repository-metadata" ,maven-repository-metadata) - ("java-plexus-utils" ,java-plexus-utils) - ("java-plexus-component-annotations" ,java-plexus-component-annotations) - ("java-guice" ,java-guice) - ("java-javax-inject" ,java-javax-inject))))) + (list maven-model + maven-model-builder + maven-resolver-spi + maven-resolver-api + maven-resolver-impl + maven-resolver-util + maven-builder-support + maven-repository-metadata + java-plexus-utils + java-plexus-component-annotations + java-guice + java-javax-inject)))) (define-public maven-plugin-api (package @@ -1429,7 +1555,6 @@ so really just plain objects."))) ("java-plexus-component-annotations" ,java-plexus-component-annotations) ("guice" ,java-guice) ("java-cglib" ,java-cglib) - ("java-asm" ,java-asm) ("sisu-inject" ,java-eclipse-sisu-inject) ("javax-inject" ,java-javax-inject) ("utils" ,java-plexus-utils))) @@ -1439,7 +1564,7 @@ so really just plain objects."))) ("classworlds" ,java-plexus-classworlds) ("guava" ,java-guava) ("xbean" ,java-geronimo-xbean-reflect) - ("build-api" ,java-sisu-build-api) + ("build-api" ,java-plexus-build-api) ;; modello plugins: ("java" ,java-modello-plugins-java) ("xml" ,java-modello-plugins-xml) @@ -1453,106 +1578,106 @@ implemented by Mojos -- development. A plugin is described in a @file{META-INF/maven/plugin.xml} plugin descriptor, generally generated from plugin sources using maven-plugin-plugin."))) -(define maven-core-bootstrap - (package - (inherit maven-artifact) - (name "maven-core") - (arguments - `(#:jar-name "maven-core.jar" - #:source-dir "src/main/java" - #:jdk ,icedtea-8 - ;; Tests need maven-compat, which requires maven-core - #:tests? #f - #:phases - (modify-phases %standard-phases - (add-before 'configure 'chdir - (lambda _ - ;; Required for generating components.xml in maven-core - (chdir "maven-core") - #t)) - (add-before 'build 'copy-resources - (lambda _ - (mkdir-p "build/classes/") - (copy-recursively "src/main/resources" "build/classes") - #t)) - (add-after 'copy-resources 'fill-properties - (lambda _ - ;; This file controls the output of some mvn subcommands, such as - ;; mvn -version. - (substitute* "build/classes/org/apache/maven/messages/build.properties" - (("\\$\\{buildNumber\\}") "guix_build") - (("\\$\\{timestamp\\}") "0") - (("\\$\\{project.version\\}") ,(package-version maven-artifact)) - (("\\$\\{distributionId\\}") "apache-maven") - (("\\$\\{distributionShortName\\}") "Maven") - (("\\$\\{distributionName\\}") "Apache Maven")) - #t)) - (add-before 'build 'generate-sisu-named - (lambda _ - (mkdir-p "build/classes/META-INF/sisu") - (chmod "../sisu.sh" #o755) - (invoke "../sisu.sh" "src/main/java" - "build/classes/META-INF/sisu/javax.inject.Named") - #t)) - (add-before 'build 'generate-models - (lambda* (#:key inputs #:allow-other-keys) - (define (modello-single-mode file version mode) - (invoke "java" "org.codehaus.modello.ModelloCli" - file mode "src/main/java" version - "false" "true")) - (let ((file "src/main/mdo/toolchains.mdo")) - (modello-single-mode file "1.1.0" "java") - (modello-single-mode file "1.1.0" "xpp3-reader") - (modello-single-mode file "1.1.0" "xpp3-writer")) - #t)) - (add-before 'install 'fix-pom - (lambda _ - (substitute* "pom.xml" - (("no_aop") "")) - #t)) - (replace 'install - (install-from-pom "pom.xml"))))) - (propagated-inputs - `(("maven-artifact" ,maven-artifact) - ("maven-resolver-provider" ,maven-resolver-provider) - ("maven-builder-support" ,maven-builder-support) - ("maven-model" ,maven-model) - ("maven-model-builder" ,maven-model-builder) - ("maven-settings" ,maven-settings) - ("maven-settings-builder" ,maven-settings-builder) - ("maven-plugin-api" ,maven-plugin-api) - ("maven-repository-metadata" ,maven-repository-metadata) - ("maven-shared-utils" ,maven-shared-utils) - ("java-plexus-component-annotations" ,java-plexus-component-annotations) - ("java-plexus-utils" ,java-plexus-utils) - ("java-commons-lang3" ,java-commons-lang3) - ("java-guava" ,java-guava) - ("java-guice" ,java-guice) - ("maven-resolver-api" ,maven-resolver-api) - ("maven-resolver-spi" ,maven-resolver-spi) - ("maven-resolver-util" ,maven-resolver-util) - ("maven-resolver-impl" ,maven-resolver-impl) - ("java-eclipse-sisu-inject" ,java-eclipse-sisu-inject) - ("java-eclipse-sisu-plexus" ,java-eclipse-sisu-plexus) - ("java-javax-inject" ,java-javax-inject) - ("java-plexus-classworld" ,java-plexus-classworlds))) - (native-inputs - `(("java-modello-core" ,java-modello-core) - ("java-cglib" ,java-cglib) - ("java-asm" ,java-asm) - ("java-plexus-classworlds" ,java-plexus-classworlds) - ("java-geronimo-xbean-reflect" ,java-geronimo-xbean-reflect) - ("java-sisu-build-api" ,java-sisu-build-api) - ("java-modello-plugins-java" ,java-modello-plugins-java) - ("java-modello-plugins-xml" ,java-modello-plugins-xml) - ("java-modello-plugins-xpp3" ,java-modello-plugins-xpp3) - ;; tests - ("java-junit" ,java-junit) - ("java-mockito-1" ,java-mockito-1) - ("java-commons-jxpath" ,java-commons-jxpath))) - (description "Apache Maven is a software project management and comprehension +(define-public maven-core-bootstrap + (hidden-package + (package + (inherit maven-artifact) + (name "maven-core") + (arguments + `(#:jar-name "maven-core.jar" + #:source-dir "src/main/java" + #:jdk ,icedtea-8 + ;; Tests need maven-compat, which requires maven-core + #:tests? #f + #:phases + (modify-phases %standard-phases + (add-before 'configure 'chdir + (lambda _ + ;; Required for generating components.xml in maven-core + (chdir "maven-core") + #t)) + (add-before 'build 'copy-resources + (lambda _ + (mkdir-p "build/classes/") + (copy-recursively "src/main/resources" "build/classes") + #t)) + (add-after 'copy-resources 'fill-properties + (lambda _ + ;; This file controls the output of some mvn subcommands, such as + ;; mvn -version. + (substitute* "build/classes/org/apache/maven/messages/build.properties" + (("\\$\\{buildNumber\\}") "guix_build") + (("\\$\\{timestamp\\}") "0") + (("\\$\\{project.version\\}") ,(package-version maven-artifact)) + (("\\$\\{distributionId\\}") "apache-maven") + (("\\$\\{distributionShortName\\}") "Maven") + (("\\$\\{distributionName\\}") "Apache Maven")) + #t)) + (add-before 'build 'generate-sisu-named + (lambda _ + (mkdir-p "build/classes/META-INF/sisu") + (chmod "../sisu.sh" #o755) + (invoke "../sisu.sh" "src/main/java" + "build/classes/META-INF/sisu/javax.inject.Named") + #t)) + (add-before 'build 'generate-models + (lambda* (#:key inputs #:allow-other-keys) + (define (modello-single-mode file version mode) + (invoke "java" "org.codehaus.modello.ModelloCli" + file mode "src/main/java" version + "false" "true")) + (let ((file "src/main/mdo/toolchains.mdo")) + (modello-single-mode file "1.1.0" "java") + (modello-single-mode file "1.1.0" "xpp3-reader") + (modello-single-mode file "1.1.0" "xpp3-writer")) + #t)) + (add-before 'install 'fix-pom + (lambda _ + (substitute* "pom.xml" + (("no_aop") "")) + #t)) + (replace 'install + (install-from-pom "pom.xml"))))) + (propagated-inputs + `(("maven-artifact" ,maven-artifact) + ("maven-resolver-provider" ,maven-resolver-provider) + ("maven-builder-support" ,maven-builder-support) + ("maven-model" ,maven-model) + ("maven-model-builder" ,maven-model-builder) + ("maven-settings" ,maven-settings) + ("maven-settings-builder" ,maven-settings-builder) + ("maven-plugin-api" ,maven-plugin-api) + ("maven-repository-metadata" ,maven-repository-metadata) + ("maven-shared-utils" ,maven-shared-utils) + ("java-plexus-component-annotations" ,java-plexus-component-annotations-1.7) + ("java-plexus-utils" ,java-plexus-utils) + ("java-commons-lang3" ,java-commons-lang3) + ("java-guava" ,java-guava) + ("java-guice" ,java-guice) + ("maven-resolver-api" ,maven-resolver-api) + ("maven-resolver-spi" ,maven-resolver-spi) + ("maven-resolver-util" ,maven-resolver-util) + ("maven-resolver-impl" ,maven-resolver-impl) + ("java-eclipse-sisu-inject" ,java-eclipse-sisu-inject) + ("java-eclipse-sisu-plexus" ,java-eclipse-sisu-plexus) + ("java-javax-inject" ,java-javax-inject) + ("java-plexus-classworld" ,java-plexus-classworlds))) + (native-inputs + `(("java-modello-core" ,java-modello-core) + ("java-cglib" ,java-cglib) + ("java-plexus-classworlds" ,java-plexus-classworlds) + ("java-geronimo-xbean-reflect" ,java-geronimo-xbean-reflect) + ("java-plexus-build-api" ,java-plexus-build-api) + ("java-modello-plugins-java" ,java-modello-plugins-java) + ("java-modello-plugins-xml" ,java-modello-plugins-xml) + ("java-modello-plugins-xpp3" ,java-modello-plugins-xpp3) + ;; tests + ("java-junit" ,java-junit) + ("java-mockito-1" ,java-mockito-1) + ("java-commons-jxpath" ,java-commons-jxpath))) + (description "Apache Maven is a software project management and comprehension tool. This package contains the maven core classes managing the whole build -process."))) +process.")))) (define-public maven-core (package @@ -1564,7 +1689,9 @@ process."))) (add-before 'build 'modify-metainf (lambda _ (substitute* "build.xml" - (("message=\"\"") "message=\"Implementation-Version: 3.5.4\n\"")) + (("message=\"\"") + (string-append "message=\"Implementation-Version: " + (package-version maven) "\n\""))) #t)) (add-before 'build 'add-maven-files (lambda _ @@ -1613,12 +1740,33 @@ artifactId=maven-core" ,(package-version maven-core-bootstrap)))) default-bindings-xml artifact-handlers-xml))))))) #t)) - (add-after 'generate-metadata 'rebuild + (add-after 'generate-metadata 'fix-plugin-versions + (lambda _ + ;; This file controls the default plugins used by Maven. Ensure + ;; we use the versions we have packaged by default + (substitute* '("build/classes/META-INF/plexus/default-bindings.xml" + "build/classes/META-INF/plexus/components.xml") + (("maven-install-plugin:[0-9.]+") + (string-append "maven-install-plugin:" + ,(package-version maven-install-plugin))) + (("maven-resources-plugin:[0-9.]+") + (string-append "maven-resources-plugin:" + ,(package-version maven-resources-plugin))) + (("maven-compiler-plugin:[0-9.]+") + (string-append "maven-compiler-plugin:" + ,(package-version maven-compiler-plugin))) + (("maven-surefire-plugin:[0-9.]+") + (string-append "maven-surefire-plugin:" + ,(package-version maven-surefire-plugin))) + (("maven-jar-plugin:[0-9.]+") + (string-append "maven-jar-plugin:" + ,(package-version maven-jar-plugin)))))) + (add-after 'fix-plugin-versions 'rebuild (lambda _ (invoke "ant" "jar") #t)))))) (native-inputs - `(("java-plexus-component-metadata" ,java-plexus-component-metadata) + `(("java-plexus-component-metadata" ,java-plexus-component-metadata-1.7) ("java-commons-cli" ,java-commons-cli) ("java-plexus-cli" ,java-plexus-cli) ("java-jdom2" ,java-jdom2) @@ -1626,6 +1774,42 @@ artifactId=maven-core" ,(package-version maven-core-bootstrap)))) ("maven-core-boot" ,maven-core-bootstrap) ,@(package-native-inputs maven-core-bootstrap))))) +(define-public maven-slf4j-provider + (package + (inherit maven-artifact) + (name "maven-slf4j-provider") + (arguments + `(#:jar-name "maven-slf4j-provider.jar" + #:source-dir "maven-slf4j-provider/src/main/java" + #:tests? #f ;no tests + #:phases (modify-phases %standard-phases + (add-after 'unpack 'unpack-slf4j + (lambda* (#:key inputs #:allow-other-keys) + (mkdir-p "generated-sources") + (copy-recursively (assoc-ref inputs + "java-slf4j-simple-source") + "generated-sources") + (with-directory-excursion "generated-sources" + (for-each delete-file + (find-files "." "StaticLoggerBinder.java"))) + (for-each (lambda (simple) + (for-each (lambda (java) + (copy-file java + (string-append + "maven-slf4j-provider/src/main/java/org/slf4j/impl/" + (basename java)))) + (find-files (string-append simple + "/src/main/java/") + "\\.java$"))) + (find-files "generated-sources" "slf4j-simple" + #:directories? #t)))) + (replace 'install + (install-from-pom "maven-slf4j-provider/pom.xml"))))) + (inputs `(("java-slf4j-api" ,java-slf4j-api) + ("java-slf4j-simple-source" ,(package-source java-slf4j-simple)) + ("maven-shared-utils" ,maven-shared-utils))) + (native-inputs (list unzip)))) + (define-public maven-embedder (package (inherit maven-artifact) @@ -1645,6 +1829,10 @@ artifactId=maven-core" ,(package-version maven-core-bootstrap)))) (invoke "./sisu.sh" "maven-embedder/src/main/java" "build/classes/META-INF/sisu/javax.inject.Named") #t)) + (add-before 'build 'copy-resources + (lambda _ + (mkdir-p "build/classes/") + (copy-recursively "maven-embedder/src/main/resources" "build/classes"))) (add-before 'build 'generate-models (lambda* (#:key inputs #:allow-other-keys) (define (modello-single-mode file version mode) @@ -1671,6 +1859,13 @@ artifactId=maven-core" ,(package-version maven-core-bootstrap)))) (("srcdir=\"maven-embedder/src/test\"") "srcdir=\"maven-embedder/src/test/java\"")) #t)) + (add-before 'check 'disable-failing-test + (lambda _ + (delete-file "maven-embedder/src/test/java/org/apache/maven/cli/event/ExecutionEventLoggerTest.java"))) + (add-before 'install 'fix-pom + (lambda _ + (substitute* "maven-embedder/pom.xml" + (("jsr250-api") "javax.annotation-api")))) (replace 'install (install-from-pom "maven-embedder/pom.xml"))))) (propagated-inputs @@ -1683,6 +1878,7 @@ artifactId=maven-core" ,(package-version maven-core-bootstrap)))) ("maven-settings" ,maven-settings) ("maven-settings-builder" ,maven-settings-builder) ("maven-shared-utils" ,maven-shared-utils) + ("maven-slf4j-provider" ,maven-slf4j-provider) ("java-plexus-classworlds" ,java-plexus-classworlds) ("java-plexus-util" ,java-plexus-utils) ("java-eclipse-sisu-plexus" ,java-eclipse-sisu-plexus) @@ -1700,16 +1896,15 @@ artifactId=maven-core" ,(package-version maven-core-bootstrap)))) ("java-guice" ,java-guice) ("java-javax-inject" ,java-javax-inject) ("java-slf4j-api" ,java-slf4j-api) - ("java-slf4j-simple" ,java-slf4j-simple) ("java-jsr250" ,java-jsr250))) (native-inputs - `(("java-modello-core" ,java-modello-core) + `(("java-asm-8" ,java-asm-8) + ("java-modello-core" ,java-modello-core) ("java-geronimo-xbean-reflect" ,java-geronimo-xbean-reflect) - ("java-sisu-build-api" ,java-sisu-build-api) + ("java-plexus-build-api" ,java-plexus-build-api) ("java-eclipse-sisu-plexus" ,java-eclipse-sisu-plexus) ("java-eclipse-sisu-inject" ,java-eclipse-sisu-inject) ("java-cglib" ,java-cglib) - ("java-asm" ,java-asm) ("java-modello-plugins-java" ,java-modello-plugins-java) ("java-modello-plugins-xml" ,java-modello-plugins-xml) ("java-modello-plugins-xpp3" ,java-modello-plugins-xpp3) @@ -1843,6 +2038,10 @@ logging support."))) (modello-single-mode file "1.0.0" "xpp3-reader") (modello-single-mode file "1.0.0" "xpp3-writer")) #t)) + (add-before 'build 'copy-resources + (lambda _ + (mkdir-p "build/classes/") + (copy-recursively "src/main/resources" "build/classes"))) (add-after 'build 'generate-metadata (lambda _ (invoke "java" "-cp" (string-append (getenv "CLASSPATH") ":build/classes") @@ -1867,6 +2066,9 @@ logging support."))) "--classes" "build/test-classes" "--descriptors" "build/test-classes/META-INF") #t)) + (add-before 'check 'disable-failing-test + (lambda _ + (delete-file "src/test/java/org/apache/maven/profiles/manager/DefaultProfileManagerTest.java"))) (add-after 'generate-metadata 'rebuild (lambda _ (invoke "ant" "jar") @@ -1874,27 +2076,27 @@ logging support."))) (replace 'install (install-from-pom "pom.xml"))))) (propagated-inputs - `(("maven-artifact" ,maven-artifact) - ("maven-repository-metadata" ,maven-repository-metadata) - ("maven-builder-support" ,maven-builder-support) - ("maven-model" ,maven-model) - ("maven-model-builder" ,maven-model-builder) - ("maven-settings" ,maven-settings) - ("maven-settings-builder" ,maven-settings-builder) - ("maven-core" ,maven-core) - ("maven-wagon-provider-api" ,maven-wagon-provider-api) - ("maven-wagon-file" ,maven-wagon-file) - ("maven-resolver-api" ,maven-resolver-api) - ("maven-resolver-util" ,maven-resolver-util) - ("maven-resolver-spi" ,maven-resolver-spi) - ("java-plexus-interpolation" ,java-plexus-interpolation))) + (list maven-artifact + maven-repository-metadata + maven-builder-support + maven-model + maven-model-builder + maven-settings + maven-settings-builder + maven-core + maven-wagon-provider-api + maven-wagon-file + maven-resolver-api + maven-resolver-util + maven-resolver-spi + java-plexus-interpolation)) (native-inputs `(("java-modello-core" ,java-modello-core) ("java-plexus-utils" ,java-plexus-utils) - ("java-plexus-component-annotations" ,java-plexus-component-annotations) + ("java-plexus-component-annotations" ,java-plexus-component-annotations-1.7) ("java-plexus-classworlds" ,java-plexus-classworlds) ("java-geronimo-xbean-reflect" ,java-geronimo-xbean-reflect) - ("java-sisu-build-api" ,java-sisu-build-api) + ("java-plexus-build-api" ,java-plexus-build-api) ("java-eclipse-sisu-plexus" ,java-eclipse-sisu-plexus) ("java-exclispe-sisu-inject" ,java-eclipse-sisu-inject) ("java-javax-inject" ,java-javax-inject) @@ -1906,7 +2108,7 @@ logging support."))) ("java-modello-plugins-xml" ,java-modello-plugins-xml) ("java-modello-plugins-xpp3" ,java-modello-plugins-xpp3) ;; metadata - ("java-plexus-component-metadata" ,java-plexus-component-metadata) + ("java-plexus-component-metadata" ,java-plexus-component-metadata-1.7) ("java-commons-cli" ,java-commons-cli) ("java-plexus-cli" ,java-plexus-cli) ("java-jdom2" ,java-jdom2) @@ -1924,8 +2126,8 @@ logging support."))) ("java-commons-lang3" ,java-commons-lang3) ("java-aop" ,java-aopalliance) ("maven-resolver-provider" ,maven-resolver-provider) + ("maven-slf4j-provider" ,maven-slf4j-provider) ("java-slf4j-api" ,java-slf4j-api) - ("java-slf4j-simple" ,java-slf4j-simple) ,@(package-inputs java-slf4j-api))) (description "Apache Maven is a software project management and comprehension tool. This package contains Maven2 classes maintained as compatibility @@ -1963,7 +2165,8 @@ layer for plugins that need to keep Maven2 compatibility."))) "maven-repository-metadata" "maven-shared-utils" "maven-resolver-api" "maven-resolver-spi" "maven-resolver-util" "maven-resolver-impl" "maven-resolver-connector-basic" "maven-resolver-provider" - "maven-resolver-transport-wagon" "maven-wagon-provider-api" + "maven-resolver-transport-wagon" "maven-slf4j-provider" + "maven-wagon-provider-api" "maven-wagon-file" "maven-wagon-http" "java-commons-logging-minimal" "java-httpcomponents-httpclient" "java-httpcomponents-httpcore" "maven-wagon-http-shared" "maven-wagon-tck-http" @@ -1973,8 +2176,7 @@ layer for plugins that need to keep Maven2 compatibility."))) "java-plexus-utils" "java-plexus-interpolation" "java-plexus-sec-dispatcher" "java-plexus-cipher" "java-guava" "java-jansi" "java-jsr250" "java-cdi-api" "java-commons-cli" - "java-commons-io" "java-commons-lang3" "java-slf4j-api" - "java-slf4j-simple")))) + "java-commons-io" "java-commons-lang3" "java-slf4j-api")))) (substitute* "apache-maven/src/bin/mvn" (("cygwin=false;") (string-append @@ -2000,59 +2202,57 @@ layer for plugins that need to keep Maven2 compatibility."))) (copy-recursively "apache-maven/src/conf" conf)) #t))))) (inputs - `(("java-plexus-classworlds" ,java-plexus-classworlds) - ("maven-artifact" ,maven-artifact) - ("maven-embedder" ,maven-embedder) - ("maven-core" ,maven-core) - ("maven-compat" ,maven-compat) - ("maven-builder-support" ,maven-builder-support) - ("maven-model" ,maven-model) - ("maven-model-builder" ,maven-model-builder) - ("maven-settings" ,maven-settings) - ("maven-settings-builder" ,maven-settings-builder) - ("maven-plugin-api" ,maven-plugin-api) - ("maven-repository-metadata" ,maven-repository-metadata) - ("maven-shared-utils" ,maven-shared-utils) - ("maven-resolver-api" ,maven-resolver-api) - ("maven-resolver-spi" ,maven-resolver-spi) - ("maven-resolver-util" ,maven-resolver-util) - ("maven-resolver-impl" ,maven-resolver-impl) - ("maven-resolver-connector-basic" ,maven-resolver-connector-basic) - ("maven-resolver-provider" ,maven-resolver-provider) - ("maven-resolver-transport-wagon" ,maven-resolver-transport-wagon) - ("maven-wagon-provider-api" ,maven-wagon-provider-api) - ("maven-wagon-file" ,maven-wagon-file) - ("maven-wagon-http" ,maven-wagon-http) - ("java-commons-logging-minimal" ,java-commons-logging-minimal) - ("java-httpcomponents-httpclient" ,java-httpcomponents-httpclient) - ("java-httpcomponents-httpcore" ,java-httpcomponents-httpcore) - ("maven-wagon-http-shared" ,maven-wagon-http-shared) - ("maven-wagon-tck-http" ,maven-wagon-tck-http) - ("java-eclipse-sisu-plexus" ,java-eclipse-sisu-plexus) - ("java-guice" ,java-guice) - ("java-aopalliance" ,java-aopalliance) - ("java-cglib" ,java-cglib) - ("java-asm" ,java-asm) - ("java-eclipse-sisu-inject" ,java-eclipse-sisu-inject) - ("java-javax-inject" ,java-javax-inject) - ("java-plexus-component-annotations" ,java-plexus-component-annotations) - ("java-plexus-utils" ,java-plexus-utils) - ("java-plexus-interpolation" ,java-plexus-interpolation) - ("java-plexus-sec-dispatcher" ,java-plexus-sec-dispatcher) - ("java-plexus-cipher" ,java-plexus-cipher) - ("java-guava" ,java-guava) - ("java-jansi" ,java-jansi) - ("java-jsr250" ,java-jsr250) - ("java-cdi-api" ,java-cdi-api) - ("java-commons-cli" ,java-commons-cli) - ("java-commons-io" ,java-commons-io) - ("java-commons-lang3" ,java-commons-lang3) - ("java-slf4j-api" ,java-slf4j-api) - ;; TODO: replace with maven-slf4j-provider - ("java-slf4j-simple" ,java-slf4j-simple))) + (list java-plexus-classworlds + maven-artifact + maven-embedder + maven-core + maven-compat + maven-builder-support + maven-model + maven-model-builder + maven-settings + maven-settings-builder + maven-plugin-api + maven-repository-metadata + maven-shared-utils + maven-resolver-api + maven-resolver-spi + maven-resolver-util + maven-resolver-impl + maven-resolver-connector-basic + maven-resolver-provider + maven-resolver-transport-wagon + maven-slf4j-provider + maven-wagon-provider-api + maven-wagon-file + maven-wagon-http + java-commons-logging-minimal + java-httpcomponents-httpclient + java-httpcomponents-httpcore + maven-wagon-http-shared + maven-wagon-tck-http + java-eclipse-sisu-plexus + java-guice + java-aopalliance + java-cglib + java-asm-8 + java-eclipse-sisu-inject + java-javax-inject + java-plexus-component-annotations + java-plexus-utils + java-plexus-interpolation + java-plexus-sec-dispatcher + java-plexus-cipher + java-guava + java-jansi + java-jsr250 + java-cdi-api + java-commons-cli + java-commons-io + java-commons-lang3 + java-slf4j-api)) (propagated-inputs - `(("coreutils" ,coreutils) - ("which" ,which))) + (list coreutils which)) (description "Apache Maven is a software project management and comprehension tool. Based on the concept of a project object model: builds, dependency management, documentation creation, site publication, and distribution @@ -2170,6 +2370,16 @@ reporting or the build process."))) (inherit maven-settings-builder) (version (package-version maven-3.0-pom)) (source (package-source maven-3.0-pom)) + (arguments + (substitute-keyword-arguments (package-arguments maven-settings-builder) + ((#:phases phases) + `(modify-phases ,phases + (add-before 'build 'generate-components.xml + (lambda _ + (mkdir-p "build/classes/META-INF/plexus") + (chmod "components.sh" #o755) + (invoke "./components.sh" "maven-settings-builder/src/main/java" + "build/classes/META-INF/plexus/components.xml"))))))) (propagated-inputs `(("java-plexus-component-annotations" ,java-plexus-component-annotations) ,@(filter @@ -2180,6 +2390,8 @@ reporting or the build process."))) ("maven-pom" `("maven-pom" ,maven-3.0-pom)) ("maven-settings" `("maven-settings" ,maven-3.0-settings)) ("maven-builder-support" #f) + ("java-plexus-sec-dispatcher" + `("java-plexus-sec-dispatcher" ,java-plexus-sec-dispatcher-1.4)) (_ input))) (package-propagated-inputs maven-settings-builder))))))) @@ -2188,6 +2400,19 @@ reporting or the build process."))) (inherit maven-model-builder) (version (package-version maven-3.0-pom)) (source (package-source maven-3.0-pom)) + (arguments + (substitute-keyword-arguments (package-arguments maven-model-builder) + ((#:phases phases) + `(modify-phases ,phases + (add-before 'build 'generate-components.xml + (lambda _ + (mkdir-p "build/classes/META-INF/plexus") + (chmod "../components.sh" #o755) + (invoke "../components.sh" "src/main/java" + "build/classes/META-INF/plexus/components.xml"))) + (add-before 'check 'remove-failing-test + (lambda _ + (delete-file "src/test/java/org/apache/maven/model/interpolation/StringSearchModelInterpolatorTest.java"))))))) (propagated-inputs `(("java-plexus-component-annotations" ,java-plexus-component-annotations) ,@(filter @@ -2227,8 +2452,8 @@ reporting or the build process."))) (_ input))) (package-propagated-inputs maven-model-builder))) (native-inputs - `(("java-plexus-container-default" ,java-plexus-container-default) - ,@(package-native-inputs maven-plugin-api))))) + (modify-inputs (package-native-inputs maven-plugin-api) + (prepend java-plexus-container-default))))) (define-public maven-3.0-repository-metadata (package @@ -2279,7 +2504,7 @@ reporting or the build process."))) ("java-plexus-utils" ,java-plexus-utils) ("maven-pom" ,maven-3.0-pom))) (native-inputs - `(("java-plexus-component-metadata" ,java-plexus-component-metadata))))) + (list java-plexus-component-metadata)))) (define-public maven-3.0-core (package @@ -2360,23 +2585,23 @@ reporting or the build process."))) (replace 'install (install-from-pom "pom.xml"))))) (propagated-inputs - `(("maven-model" ,maven-3.0-model) - ("maven-settings" ,maven-3.0-settings) - ("maven-settings-builder" ,maven-3.0-settings-builder) - ("maven-repository-metadata" ,maven-3.0-repository-metadata) - ("maven-artifact" ,maven-3.0-artifact) - ("maven-model-builder" ,maven-3.0-model-builder) - ("maven-aether-provider" ,maven-3.0-aether-provider) - ("java-sonatype-aether-impl" ,java-sonatype-aether-impl) - ("java-sonatype-aether-api" ,java-sonatype-aether-api) - ("java-sonatype-aether-util" ,java-sonatype-aether-util) - ("java-plexus-interpolation" ,java-plexus-interpolation) - ("java-plexus-utils" ,java-plexus-utils) - ("java-plexus-classworlds" ,java-plexus-classworlds) - ("java-plexus-component-annotations" ,java-plexus-component-annotations) - ("java-plexus-container-default" ,java-plexus-container-default) - ("java-plexus-sec-dispatcher" ,java-plexus-sec-dispatcher) - ("maven-pom" ,maven-3.0-pom))))) + (list maven-3.0-model + maven-3.0-settings + maven-3.0-settings-builder + maven-3.0-repository-metadata + maven-3.0-artifact + maven-3.0-model-builder + maven-3.0-aether-provider + java-sonatype-aether-impl + java-sonatype-aether-api + java-sonatype-aether-util + java-plexus-interpolation + java-plexus-utils + java-plexus-classworlds + java-plexus-component-annotations + java-plexus-container-default + java-plexus-sec-dispatcher-1.4 + maven-3.0-pom)))) (define-public maven-3.0-compat (package @@ -2396,24 +2621,24 @@ reporting or the build process."))) #t)) (delete 'build-tests)))))) (propagated-inputs - `(("maven-model" ,maven-3.0-model) - ("maven-model-builder" ,maven-3.0-model-builder) - ("maven-settings" ,maven-3.0-settings) - ("maven-settings-builder" ,maven-3.0-settings-builder) - ("maven-artifact" ,maven-3.0-artifact) - ("maven-core" ,maven-3.0-core) - ("maven-aether-provider" ,maven-3.0-aether-provider) - ("maven-repository-metadata" ,maven-3.0-repository-metadata) - ("java-sonatype-aether-api" ,java-sonatype-aether-api) - ("java-sonatype-aether-util" ,java-sonatype-aether-util) - ("java-sonatype-aether-impl" ,java-sonatype-aether-impl) - ("java-plexus-utils" ,java-plexus-utils) - ("java-plexus-interpolation" ,java-plexus-interpolation) - ("java-eclipse-sisu-plexus" ,java-eclipse-sisu-plexus) - ("java-plexus-component-annotations" ,java-plexus-component-annotations) - ("java-plexus-container-default" ,java-plexus-container-default) - ("maven-wagon-provider-api" ,maven-wagon-provider-api) - ("maven-pom" ,maven-3.0-pom))))) + (list maven-3.0-model + maven-3.0-model-builder + maven-3.0-settings + maven-3.0-settings-builder + maven-3.0-artifact + maven-3.0-core + maven-3.0-aether-provider + maven-3.0-repository-metadata + java-sonatype-aether-api + java-sonatype-aether-util + java-sonatype-aether-impl + java-plexus-utils + java-plexus-interpolation + java-eclipse-sisu-plexus + java-plexus-component-annotations + java-plexus-container-default + maven-wagon-provider-api + maven-3.0-pom)))) (define-public maven-shared-utils-3.0 (package @@ -2427,9 +2652,20 @@ reporting or the build process."))) (base32 "0qm8y85kip2hyhnhlkqgj0rhmf83z07s7l7gzsfl5dzl3kvp8nal")))) (propagated-inputs - `(("maven-core" ,maven-3.0-core) - ("maven-components-parent-pom" ,maven-components-parent-pom-21) - ,@(package-propagated-inputs maven-shared-utils))))) + (modify-inputs (package-propagated-inputs maven-shared-utils) + (prepend maven-3.0-core maven-components-parent-pom-21))))) + +(define-public maven-shared-utils-3.1 + (package + (inherit maven-shared-utils) + (version "3.1.0") + (source (origin + (method url-fetch) + (uri (string-append "https://archive.apache.org/dist/maven/shared/" + "maven-shared-utils-" version "-source-release.zip")) + (sha256 + (base32 + "0vfaas4g09ch0agrd1dcxcmhdd3w971ssvfr9mx9gi2lp5nv8w66")))))) (define-public maven-shared-io (package @@ -2458,17 +2694,15 @@ reporting or the build process."))) (replace 'install (install-from-pom "pom.xml"))))) (propagated-inputs - `(("maven-artifact" ,maven-3.0-artifact) - ("maven-compat" ,maven-3.0-compat) - ("maven-plugin-api" ,maven-3.0-plugin-api) - ("maven-shared-utils" ,maven-shared-utils) - ("maven-wagon-provider-api" ,maven-wagon-provider-api) - ("java-plexus-utils" ,java-plexus-utils) - ("maven-components-parent-pom" ,maven-components-parent-pom-22))) + (list maven-3.0-artifact + maven-3.0-compat + maven-3.0-plugin-api + maven-shared-utils + maven-wagon-provider-api + java-plexus-utils + maven-components-parent-pom-22)) (native-inputs - `(("unzip" ,unzip) - ("java-junit" ,java-junit) - ("java-easymock" ,java-easymock))) + (list unzip java-junit java-easymock)) (home-page "https://maven.apache.org/shared/maven-dependency-tree") (synopsis "Tree-based API for resolution of Maven project dependencies") (description "This package provides a tree-based API for resolution of @@ -2512,11 +2746,8 @@ Maven project dependencies.") (replace 'install (install-from-pom "pom.xml"))))) (propagated-inputs - `(("maven-plugin-api" ,maven-3.0-plugin-api) - ("maven-shared-io" ,maven-shared-io) - ("maven-shared-utils" ,maven-shared-utils) - ("java-plexus-utils" ,java-plexus-utils) - ("maven-components-parent-pom" ,maven-components-parent-pom-22))) + (list maven-3.0-plugin-api maven-shared-io maven-shared-utils + java-plexus-utils maven-components-parent-pom-22)) (native-inputs `(("java-modello-core" ,java-modello-core) ;; modello plugins: @@ -2560,9 +2791,7 @@ Maven project dependencies.") ("java-plexus-utils" ,java-plexus-utils) ("maen-parent-pom" ,maven-parent-pom-33))) (native-inputs - `(("java-junit" ,java-junit) - ("java-assertj" ,java-assertj) - ("unzip" ,unzip))) + (list java-junit java-assertj unzip)) (home-page "https://maven.apache.org/shared/maven-dependency-tree") (synopsis "Tree-based API for resolution of Maven project dependencies") (description "This package provides a tree-based API for resolution of @@ -2572,7 +2801,7 @@ Maven project dependencies.") (define-public maven-dependency-tree (package (name "maven-dependency-tree") - (version "3.0.1") + (version "3.1.0") (source (origin (method url-fetch) (uri (string-append "mirror://apache/maven/shared/" @@ -2580,27 +2809,24 @@ Maven project dependencies.") "-source-release.zip")) (sha256 (base32 - "0mxfslxvcmjs13jl30zhcg672j970dzn6ihh79w9ajh6sfqmlds2")))) + "1vhcd3lmbyy8q61c37sqgbllqj4ypkxm344l6pb05mkchlyk5dy5")))) (build-system ant-build-system) (arguments `(#:jar-name "maven-dependency-tree.jar" #:source-dir "src/main/java" + #:tests? #f; no tests #:phases (modify-phases %standard-phases (replace 'install (install-from-pom "pom.xml"))))) (propagated-inputs - `(("maven-core" ,maven-3.0-core) - ("java-plexus-component-annotations" ,java-plexus-component-annotations) - ("maven-parent-pom" ,maven-parent-pom-30))) + (list maven-3.0-core java-plexus-component-annotations + maven-parent-pom-34)) (inputs - `(("java-sonatype-aether-api" ,java-sonatype-aether-api) - ("java-sonatype-aether-util" ,java-sonatype-aether-util) - ("java-eclipse-aether-api" ,java-eclipse-aether-api) - ("java-eclipse-aether-util" ,java-eclipse-aether-util))) + (list java-sonatype-aether-api-1.13 java-sonatype-aether-util-1.13 + java-eclipse-aether-api java-eclipse-aether-util)) (native-inputs - `(("unzip" ,unzip) - ("java-junit" ,java-junit))) + (list unzip java-junit)) (home-page "https://maven.apache.org/shared/maven-dependency-tree") (synopsis "Tree-based API for resolution of Maven project dependencies") (description "This package provides a tree-based API for resolution of @@ -2610,7 +2836,7 @@ Maven project dependencies.") (define-public maven-common-artifact-filters (package (name "maven-common-artifact-filters") - (version "3.1.0") + (version "3.2.0") (source (origin (method url-fetch) (uri (string-append "mirror://apache/maven/shared/" @@ -2618,7 +2844,7 @@ Maven project dependencies.") "-source-release.zip")) (sha256 (base32 - "1cl1qk4r0gp62bjzfm7lml9raz1my2kd4yf0ci0lnfsn0h5qivnb")))) + "1mr92s4zz6gf028wiskjg8rd1znxzdnmskg42ac55ifg9v1p1884")))) (build-system ant-build-system) (arguments `(#:jar-name "maven-common-artifact-filters.jar" @@ -2626,49 +2852,68 @@ Maven project dependencies.") #:tests? #f; require maven-plugin-testing-harness, which requires maven 3.2. #:phases (modify-phases %standard-phases - (add-before 'build 'remove-sisu + (add-before 'build 'fix-aether (lambda _ - ;; Replace sisu with an existing dependency, to prevent a failure - ;; when rewritting dependency versions (substitute* "pom.xml" - (("sisu-inject-plexus") "maven-plugin-api") - (("org.sonatype.sisu") "org.apache.maven")) - #t)) + (("eclipse.aether") "sonatype.aether")) + (substitute* "src/main/java/org/apache/maven/shared/artifact/filter/collection/ArtifactTransitivityFilter.java" + (("eclipse") "sonatype")))) (replace 'install (install-from-pom "pom.xml"))))) (propagated-inputs - `(("maven-artifact" ,maven-3.0-artifact) - ("maven-model" ,maven-3.0-model) - ("maven-core" ,maven-3.0-core) - ("maven-plugin-api" ,maven-3.0-plugin-api) - ("maven-shared-utils" ,maven-shared-utils) - ("maven-parent-pom" ,maven-parent-pom-33) - ("java-sonatype-aether-api" ,java-sonatype-aether-api) - ("java-sonatype-aether-util" ,java-sonatype-aether-util))) + (list maven-3.0-artifact + maven-3.0-model + maven-3.0-core + maven-3.0-plugin-api + maven-shared-utils + maven-parent-pom-33 + java-eclipse-sisu-plexus + java-sonatype-aether-api + java-sonatype-aether-util)) (inputs - `(("maven-resolver-api" ,maven-resolver-api) - ("maven-resolver-util" ,maven-resolver-util))) + (list maven-resolver-api maven-resolver-util)) (native-inputs - `(("unzip" ,unzip))) + (list unzip)) (home-page "https://maven.apache.org/shared/maven-dependency-tree") (synopsis "Tree-based API for resolution of Maven project dependencies") (description "This package provides a tree-based API for resolution of Maven project dependencies.") (license license:asl2.0))) +(define-public maven-common-artifact-filters-3.1.0 + (package + (inherit maven-common-artifact-filters) + (version "3.1.0") + (source (origin + (method url-fetch) + (uri (string-append "mirror://apache/maven/shared/" + "maven-common-artifact-filters-" version + "-source-release.zip")) + (sha256 + (base32 + "1cl1qk4r0gp62bjzfm7lml9raz1my2kd4yf0ci0lnfsn0h5qivnb")))) + (arguments + (substitute-keyword-arguments (package-arguments maven-common-artifact-filters) + ((#:phases phases) + `(modify-phases ,phases + (delete 'fix-aether) + (add-before 'build 'remove-sisu + (lambda _ + (substitute* "pom.xml" + (("sisu-inject-plexus") "maven-plugin-api") + (("org.sonatype.sisu") "org.apache.maven")))))))))) + (define-public maven-enforcer-api (package (name "maven-enforcer-api") - (version "3.0.0-M3") + (version "3.0.0") (source (origin (method url-fetch) (uri (string-append "mirror://apache/maven/enforcer/" "enforcer-" version "-source-release.zip")) (sha256 (base32 - "014cwj0dqa69nnlzcin8pk9wsjmmg71vsbcpb16cibcjpm6h9wjg")) - (patches - (search-patches "maven-enforcer-api-fix-old-dependencies.patch")))) + "1479yp58jv788xc1jc2sbdxpajlbvwlk60639vd2h4s8r6x7naqh")))) (build-system ant-build-system) (arguments `(#:jar-name "maven-enforcer-api.jar" @@ -2679,12 +2924,10 @@ Maven project dependencies.") (replace 'install (install-from-pom "enforcer-api/pom.xml"))))) (propagated-inputs - `(("maven-plugin-api" ,maven-plugin-api) - ("java-plexus-container-default" ,java-plexus-container-default) - ("java-jsr305" ,java-jsr305) - ("maven-enforcer-parent-pom" ,maven-enforcer-parent-pom))) + (list maven-plugin-api java-plexus-container-default java-jsr305 + maven-enforcer-parent-pom)) (native-inputs - `(("unzip" ,unzip))) + (list unzip)) (home-page "https://maven.apache.org/shared/maven-dependency-tree") (synopsis "Tree-based API for resolution of Maven project dependencies") (description "This package provides a tree-based API for resolution of @@ -2701,6 +2944,16 @@ Maven project dependencies.") (modify-phases %standard-phases (delete 'configure) (delete 'build) + (add-before 'install 'fix-pom-versions + (lambda _ + (substitute* "pom.xml" + ((".*") + ,(string-append "" (package-version maven) + "")) + (("2.11.0") ,(package-version java-commons-io)) + (("3.12.0") ,(package-version java-commons-lang3)) + (("1.6.1") ,(package-version maven-resolver-util)) + (("1.15") ,(package-version java-commons-codec))))) (replace 'install (install-pom-file "pom.xml"))))) (propagated-inputs @@ -2719,16 +2972,1043 @@ Maven project dependencies.") (modify-phases %standard-phases (replace 'install (install-from-pom "enforcer-rules/pom.xml"))))) + (propagated-inputs + (list maven-artifact + maven-plugin-api + maven-core + maven-common-artifact-filters + java-commons-codec + java-commons-lang3 + maven-enforcer-api + maven-resolver-util + java-bsh + maven-dependency-tree + maven-3.0-compat + maven-enforcer-parent-pom)))) + +(define-public maven-enforcer-plugin + (package + (inherit maven-enforcer-api) + (name "maven-enforcer-plugin") + (arguments + `(#:tests? #f + #:jar-name "maven-enforcer-plugin.jar" + #:source-dir "maven-enforcer-plugin/src/main/java" + #:phases + (modify-phases %standard-phases + (add-before 'build 'generate-plugin.xml + (generate-plugin.xml "maven-enforcer-plugin/pom.xml" + "enforcer" + "maven-enforcer-plugin/src/main/java/org/apache/maven/plugins/enforcer/" + (list + (list "DisplayInfoMojo.java") + (list "EnforceMojo.java")))) + (replace 'install + (install-from-pom "maven-enforcer-plugin/pom.xml"))))) + (propagated-inputs + (list maven-artifact + maven-plugin-api + maven-core + java-plexus-utils + maven-enforcer-api + maven-enforcer-rules + maven-plugin-annotations + maven-enforcer-parent-pom)))) + +(define-public maven-sisu-plugin + (package + (name "maven-sisu-plugin") + (version "0.3.5") + (source (origin + (method git-fetch) + (uri (git-reference + (url "https://github.com/eclipse/sisu.mojos/") + (commit (string-append "releases/" version)))) + (file-name (git-file-name name version)) + (sha256 + (base32 + "00hb7v6hz8jg0mgkj3cl0nmqz49za4k2a0rbjr4gdhy2m7f34sq3")))) + (build-system ant-build-system) + (arguments + (list #:jar-name "maven-sisu-plugin.jar" + #:source-dir "src" + #:tests? #f ;no tests + #:phases #~(modify-phases %standard-phases + (add-before 'build 'generate-plugin.xml + (generate-plugin.xml "pom.xml" "sisu" + "src/main/java/org/eclipse/sisu/mojos/" + (list (list "IndexMojo.java") + (list "MainIndexMojo.java") + (list "TestIndexMojo.java")))) + (replace 'install + (install-from-pom "pom.xml"))))) + (propagated-inputs (list java-sonatype-oss-parent-pom-9)) + (inputs (list maven-artifact + maven-plugin-api + maven-plugin-annotations + maven-core + maven-common-artifact-filters + java-slf4j-nop + java-eclipse-sisu-inject + java-plexus-utils + java-plexus-build-api + java-slf4j-api)) + (home-page "https://www.eclipse.org/sisu/") + (synopsis "Maven plugin that generates annotation indexes for Sisu") + (description "Maven plugin that generates annotation indexes for Sisu to +avoid classpath scanning at runtime.") + (license license:epl1.0))) + +(define-public maven-artifact-transfer + (package + (name "maven-artifact-transfer") + (version "0.13.1") + (source (origin + (method url-fetch) + (uri (string-append "mirror://apache/maven/shared/" + "maven-artifact-transfer-" version + "-source-release.zip")) + (sha256 + (base32 + "0xl7lkksljacrhmvwf924zb6h0h5zw9494jaz9cz4hll0lrhlpz6")))) + (build-system ant-build-system) + (arguments + `(#:tests? #f; require mockito 2 + #:jar-name "maven-artifact-transfer.jar" + #:source-dir "src/main/java" + #:phases + (modify-phases %standard-phases + (add-after 'build 'generate-metadata + (lambda _ + (invoke "java" "-cp" (string-append (getenv "CLASSPATH") ":build/classes") + "org.codehaus.plexus.metadata.PlexusMetadataGeneratorCli" + "--source" "src/main/java" + "--output" "build/classes/META-INF/plexus/components.xml" + "--classes" "build/classes" + "--descriptors" "build/classes/META-INF") + #t)) + (add-after 'generate-metadata 'rebuild + (lambda _ + (invoke "ant" "jar") + #t)) + (replace 'install + (install-from-pom "pom.xml"))))) + (propagated-inputs + (list java-commons-codec + maven-3.0-artifact + maven-3.0-core + maven-common-artifact-filters-3.1.0 + java-plexus-component-annotations + java-plexus-utils + java-slf4j-api + java-plexus-classworlds + java-sonatype-aether-api + java-eclipse-aether-api + java-eclipse-aether-util + java-eclipse-aether-impl)) + (native-inputs + (list unzip java-plexus-component-metadata)) + (home-page "https://maven.apache.org/shared/maven-artifact-transfer") + (synopsis "API to install, deploy and resolve artifacts in Maven") + (description "This package contains an API to install, deploy and resolve +artifacts in Maven 3.") + (license license:asl2.0))) + +(define-public maven-install-plugin + (package + (name "maven-install-plugin") + (version "3.0.0-M1") + (source (origin + (method url-fetch) + (uri (string-append "mirror://apache/maven/plugins/" + "maven-install-plugin-" version + "-source-release.zip")) + (sha256 + (base32 + "1l9iydxririrair0i5sk2iypn9wspzbb666lc0ddg20yyr8w39dm")))) + (build-system ant-build-system) + (arguments + `(#:tests? #f; require maven-plugin-testing-harness + #:jar-name "maven-install-plugin.jar" + #:source-dir "src/main/java" + #:phases + (modify-phases %standard-phases + (add-before 'build 'fix-pom + (lambda _ + (substitute* "pom.xml" + (("maven-project") "maven-core") + (("maven-artifact-manager") "maven-artifact") + (("2.0.6") "3.0")) + #t)) + (add-before 'build 'generate-plugin.xml + (generate-plugin.xml "pom.xml" + "install" + "src/main/java/org/apache/maven/plugins/install" + (list + (list "AbstractInstallMojo.java" "InstallFileMojo.java") + (list "AbstractInstallMojo.java" "InstallMojo.java")))) + (replace 'install + (install-from-pom "pom.xml"))))) (propagated-inputs `(("maven-artifact" ,maven-artifact) ("maven-plugin-api" ,maven-plugin-api) - ("maven-core" ,maven-core) - ("maven-common-artifact-filters" ,maven-common-artifact-filters) - ("java-commons-codec" ,java-commons-codec) - ("java-commons-lang3" ,java-commons-lang3) - ("maven-enforcer-api" ,maven-enforcer-api) - ("maven-resolver-util" ,maven-resolver-util) - ("java-bsh" ,java-bsh) - ("maven-dependency-tree" ,maven-dependency-tree) - ("maven-compat" ,maven-3.0-compat) - ("maven-enforcer-parent-pom" ,maven-enforcer-parent-pom))))) + ("maven-compat" ,maven-compat) + ("maven-artifact-transfer" ,maven-artifact-transfer) + ("maven-plugins-pom-23" ,maven-plugins-pom-23) + ("java-plexus-digest" ,java-plexus-digest))) + (inputs + (list maven-plugin-annotations java-slf4j-api)) + (native-inputs + (list unzip)) + (home-page "https://maven.apache.org/plugin/maven-install-plugin") + (synopsis "Maven's install plugin") + (description "The Install Plugin is used during the install phase to add +artifact(s) to the local repository. The Install Plugin uses the information +in the POM (groupId, artifactId, version) to determine the proper location for +the artifact within the local repository. + +The local repository is the local cache where all artifacts needed for the +build are stored. By default, it is located within the user's home directory +(@file{~/.m2/repository}) but the location can be configured in +@file{~/.m2/settings.xml} using the @code{} element.") + (license license:asl2.0))) + +(define-public maven-filtering + (package + (name "maven-filtering") + (version "3.1.1") + (source (origin + (method url-fetch) + (uri (string-append "https://archive.apache.org/dist/maven/" + "shared/maven-filtering-" version + "-source-release.zip")) + (sha256 + (base32 + "09wrdhchnszd2l6h4z30ra0bv1a19qyjgac9z8zf1pn0m4nw05yz")))) + (build-system ant-build-system) + (arguments + `(#:jar-name "maven-filtering.jar" + #:source-dir "src/main/java" + #:test-dir "src/test" + ;; this test comes from plexus-build-api, not this package + #:test-exclude (list "**/IncrementalResourceFilteringTest.java" + "**/Abstract*.java") + #:phases + (modify-phases %standard-phases + (add-after 'build 'generate-metadata + (lambda _ + (invoke "java" "-cp" (string-append (getenv "CLASSPATH") ":build/classes") + "org.codehaus.plexus.metadata.PlexusMetadataGeneratorCli" + "--source" "src/main/java" + "--output" "build/classes/META-INF/plexus/components.xml" + "--classes" "build/classes" + "--descriptors" "build/classes/META-INF") + #t)) + (add-after 'generate-metadata 'rebuild + (lambda _ + (invoke "ant" "jar") + #t)) + (add-before 'check 'decompress-tests + (lambda* (#:key inputs #:allow-other-keys) + (let* ((build-api-source (assoc-ref inputs "java-plexus-build-api-origin")) + (classes (string-append build-api-source "/src/test/java"))) + (copy-recursively classes "src/test/")) + #t)) + (add-before 'check 'fix-directory + (lambda _ + (substitute* (find-files "src/test" ".*.java$") + (("target/test-classes/") "build/test-classes/")))) + (add-before 'check 'copy-test-resources + (lambda _ + (copy-recursively "src/test/resources" "build/test-classes/") + #t)) + (replace 'install + (install-from-pom "pom.xml"))))) + (propagated-inputs + (list maven-3.0-core + maven-shared-utils + java-plexus-utils-3.2.1 + java-plexus-interpolation + java-plexus-build-api + maven-parent-pom-30)) + (inputs + (list java-jsr305)) + (native-inputs + `(("unzip" ,unzip) + ("java-assertj" ,java-assertj) + ("java-junit" ,java-junit) + ("java-mockito" ,java-mockito-1) + ("java-objenesis" ,java-objenesis) + ("java-plexus-component-metadata" ,java-plexus-component-metadata) + ("java-plexus-build-api-origin" ,(package-source java-plexus-build-api)))) + (home-page "https://maven.apache.org/shared/maven-filtering") + (synopsis "Shared component for all plugins that needs to filter resources") + (description "This component provides an API to filter resources in Maven +projects.") + (license license:asl2.0))) + +(define-public maven-resources-plugin + (package + (name "maven-resources-plugin") + (version "3.1.0") + (source (origin + (method git-fetch) + (uri (git-reference + (url "https://github.com/apache/maven-resources-plugin") + (commit (string-append "maven-resources-plugin-" version)))) + (file-name (git-file-name name version)) + (sha256 + (base32 + "090k5j2y7ak54czfjjg3v7pdmdlgd96fbs91d1fd3vslm9zzndg8")))) + (build-system ant-build-system) + (arguments + `(#:jar-name "maven-resources-plugin.jar" + #:source-dir "src/main/java" + #:test-dir "src/test" + #:tests? #f; test depends on maven-plugin-test-harness + #:phases + (modify-phases %standard-phases + (add-before 'build 'generate-plugin.xml + (generate-plugin.xml "pom.xml" "resources" + "src/main/java/org/apache/maven/plugins/resources" + (list + (list "ResourcesMojo.java" "CopyResourcesMojo.java") + (list "ResourcesMojo.java") + (list "ResourcesMojo.java" "TestResourcesMojo.java")))) + (replace 'install + (install-from-pom "pom.xml"))))) + (propagated-inputs + (list maven-plugin-api + maven-core + java-plexus-utils + maven-filtering + java-plexus-interpolation + maven-parent-pom-31)) + (inputs + (list maven-plugin-annotations java-commons-io)) + (native-inputs + (list java-plexus-component-metadata)) + (home-page "https://maven.apache.org/plugins/maven-resources-plugin") + (synopsis "Maven plugin to collect and install resources") + (description "The Resources Plugin handles the copying of project resources +to the output directory. There are two different kinds of resources: main +resources and test resources. The difference is that the main resources are +the resources associated to the main source code while the test resources are +associated to the test source code. + +Thus, this allows the separation of resources for the main source code and its +unit tests.") + (license license:asl2.0))) + +(define-public maven-shared-incremental + (package + (name "maven-shared-incremental") + (version "1.1") + (source (origin + (method url-fetch) + (uri (string-append "https://archive.apache.org/dist/maven/shared/" + "maven-shared-incremental-" version + "-source-release.zip")) + (sha256 + (base32 + "03n4nfswyg9ahkz2zx4skcr3ghs01zh95g9js51hc75mfqx9b976")))) + (build-system ant-build-system) + (arguments + `(#:jar-name "shared-incremental.java" + #:source-dir "src/main/java" + #:test-dir "src/test" + #:phases + (modify-phases %standard-phases + (add-before 'build 'change-parent + (lambda _ + (substitute* "pom.xml" + (("19") "30")) + #t)) + (add-before 'build 'fix-pom + (lambda _ + (substitute* "pom.xml" + (("plexus-component-api") "plexus-component-annotations")) + #t)) + (add-after 'build 'generate-metadata + (lambda _ + (invoke "java" "-cp" (string-append (getenv "CLASSPATH") ":build/classes") + "org.codehaus.plexus.metadata.PlexusMetadataGeneratorCli" + "--source" "src/main/java" + "--output" "build/classes/META-INF/plexus/components.xml" + "--classes" "build/classes" + "--descriptors" "build/classes/META-INF") + #t)) + (replace 'install + (install-from-pom "pom.xml"))))) + (propagated-inputs + (list maven-plugin-api maven-core maven-shared-utils + java-plexus-component-annotations maven-parent-pom-30)) + (native-inputs + (list unzip java-plexus-component-metadata)) + (home-page "https://maven.apache.org/shared/maven-shared-incremental") + (synopsis "Maven Incremental Build support utilities") + (description "This package contains various utility classes and plexus +components for supporting incremental build functionality in maven plugins.") + (license license:asl2.0))) + +(define-public maven-compiler-plugin + (package + (name "maven-compiler-plugin") + (version "3.8.1") + (source (origin + (method git-fetch) + (uri (git-reference + (url "https://github.com/apache/maven-compiler-plugin") + (commit (string-append "maven-compiler-plugin-" version)))) + (file-name (git-file-name name version)) + (sha256 + (base32 + "0jkbq02vykd09ws8k9bzqxv6fjrpmir8gcxydbmj05kkhl242bma")))) + (build-system ant-build-system) + (arguments + `(#:jar-name "maven-compiler-plugin.jar" + #:source-dir "src/main/java" + #:test-dir "src/test" + #:tests? #f; test depends on maven-plugin-test-harness + #:phases + (modify-phases %standard-phases + (add-before 'build 'generate-plugin.xml + (generate-plugin.xml "pom.xml" + "compiler" + "src/main/java/org/apache/maven/plugin/compiler" + (list + (list "AbstractCompilerMojo.java" "CompilerMojo.java") + (list "AbstractCompilerMojo.java" "TestCompilerMojo.java")))) + (add-after 'generate-plugin.xml 'fix-plugin.xml + (lambda _ + (substitute* "build/classes/META-INF/maven/plugin.xml" + ;; These are defined in AbstractCompilerMojo.java, but not + ;; parsed correctly in the previous phase + (("DEFAULT_TARGET") "1.6") + (("DEFAULT_SOURCE") "1.6")) + #t)) + (replace 'install + (install-from-pom "pom.xml"))))) + (propagated-inputs + (list maven-plugin-api + maven-artifact + maven-core + maven-shared-utils + maven-shared-incremental + java-plexus-java + java-plexus-compiler-api + java-plexus-compiler-manager + java-plexus-compiler-javac + maven-parent-pom-33)) + (inputs + (list maven-plugin-annotations java-commons-io)) + (home-page "https://maven.apache.org/plugins/maven-compiler-plugin") + (synopsis "Compiler plugin for Maven") + (description "The Compiler Plugin is used to compile the sources of your +project. Since 3.0, the default compiler is @code{javax.tools.JavaCompiler} +(if you are using java 1.6) and is used to compile Java sources. If you want +to force the plugin using javac, you must configure the plugin option +@code{forceJavacCompilerUse}. + +Also note that at present the default source setting is 1.6 and the default +target setting is 1.6, independently of the JDK you run Maven with. You are +highly encouraged to change these defaults by setting source and target as +described in Setting the -source and -target of the Java Compiler. + +Other compilers than javac can be used and work has already started on +AspectJ, .NET, and C#.") + (license license:asl2.0))) + +(define-public java-surefire-logger-api + (package + (name "java-surefire-logger-api") + (version "3.0.0-M4") + (source (origin + (method url-fetch) + (uri (string-append "mirror://apache/maven/surefire/" + "surefire-" version "-source-release.zip")) + (sha256 + (base32 + "1s6d4pzk3bjm9l38mj9sfgbgmk145rppdj1dmqwc4d5105mr9q9w")))) + (build-system ant-build-system) + (arguments + `(#:jar-name "java-surefire-logger-api.jar" + #:source-dir "surefire-logger-api/src/main/java" + #:tests? #f; require mockito 2 + #:phases + (modify-phases %standard-phases + (replace 'install + (install-from-pom "surefire-logger-api/pom.xml"))))) + (propagated-inputs + (list java-surefire-parent-pom)) + (native-inputs + (list unzip)) + (home-page "https://maven.apache.org/surefire/surefire-logger-api") + (synopsis "Interfaces and Utilities related only to internal SureFire Logger API") + (description "This package contains interfaces and utilities that are +internal to the SureFire Logger API. It is designed to have no dependency.") + (license license:asl2.0))) + +(define-public java-surefire-parent-pom + (package + (inherit java-surefire-logger-api) + (name "java-surefire-parent-pom") + (arguments + `(#:tests? #f + #:phases + (modify-phases %standard-phases + (delete 'configure) + (delete 'build) + (add-before 'install 'fix-pom-dependency-versions + (lambda _ + (substitute* "pom.xml" + (("1.11") ,(package-version java-commons-compress)) + (("1.13") ,(package-version java-commons-codec))) + (substitute* "pom.xml" + (("commonsLang3Version>.*") + (string-append + "commonsLang3Version>" + ,(package-version java-commons-lang3) + "\n")) + (("commonsCompress>.*") + (string-append + "commonsCompress>" + ,(package-version java-commons-compress) + "\n")) + (("commonsIoVersion>.*") + (string-append + "commonsIoVersion>" + ,(package-version java-commons-io) + "\n")) + (("0.11.0") ,(package-version maven-artifact-transfer)) + (("1.0.3") ,(package-version java-plexus-java))) + #t)) + (add-after 'install 'install-providers + (install-pom-file "surefire-providers/pom.xml")) + (replace 'install + (install-pom-file "pom.xml"))))) + (propagated-inputs + (list maven-parent-pom-33)))) + +(define-public java-surefire-api + (package + (inherit java-surefire-logger-api) + (name "java-surefire-api") + (arguments + `(#:tests? #f + #:jar-name "java-surefire-api.jar" + #:source-dir "surefire-api/src/main/java" + #:phases + (modify-phases %standard-phases + (add-before 'build 'copy-resources + (lambda _ + (mkdir-p "build/classes") + (copy-recursively "surefire-api/src/main/resources" "build/classes") + #t)) + (add-before 'build 'prepare-shade + (lambda* (#:key inputs #:allow-other-keys) + (mkdir-p "build/classes") + (with-directory-excursion "build/classes" + (for-each + (lambda (input) + (for-each + (lambda (jar-file) + (invoke "jar" "xf" jar-file) + (delete-file-recursively "META-INF")) + (find-files (assoc-ref inputs input) ".*.jar$"))) + '("maven-shared-utils" "java-commons-codec"))) + #t)) + (add-after 'build 'shade + (lambda* (#:key inputs #:allow-other-keys) + (let ((jarjar + (car (find-files (assoc-ref inputs "java-jarjar") ".*.jar$"))) + (injar "java-surefire-api.jar") + (outjar "java-surefire-api-shaded.jar")) + (with-directory-excursion "build/jar" + (with-output-to-file "rules" + (lambda _ + (format #t (string-append + "rule " + "org.apache.maven.shared.utils.** " + "org.apache.maven.surefire.shade.api." + "org.apache.maven.shared.utils.@1~%")) + (format #t (string-append + "rule " + "org.apache.commons.codec.** " + "org.apache.maven.surefire.shade.api." + "org.apache.commons.codec.@1~%")))) + (invoke "java" "-jar" jarjar "process" "rules" injar outjar) + (delete-file injar) + (rename-file outjar injar))) + #t)) + (replace 'install + (install-from-pom "surefire-api/pom.xml"))))) + (propagated-inputs + (list java-surefire-logger-api java-commons-codec + java-surefire-parent-pom maven-shared-utils-3.1)) + (inputs + (list java-jsr305)) + (native-inputs + (list unzip java-jarjar)) + (synopsis "Maven SureFire API") + (description "This package contains the API to use Maven SureFire."))) + +(define-public java-surefire-booter + (package + (inherit java-surefire-logger-api) + (name "java-surefire-booter") + (arguments + `(#:tests? #f; require mockito 2 + #:jar-name "java-surefire-booter.jar" + #:source-dir "surefire-booter/src/main/java" + #:phases + (modify-phases %standard-phases + (add-before 'build 'fix-/bin/sh + (lambda _ + (substitute* "surefire-booter/src/main/java/org/apache/maven/surefire/booter/PpidChecker.java" + (("/bin/sh") (which "sh"))) + #t)) + (replace 'install + (install-from-pom "surefire-booter/pom.xml"))))) + (propagated-inputs + (list java-surefire-api java-commons-lang3 java-commons-io + java-surefire-parent-pom)) + (inputs + (list java-jsr305)) + (synopsis "API and Facilities used by forked tests running in JVM sub-process") + (description "SureFire runs tests inside a forked JVM subprocess. This +package contains an API and facilities used inside that forked JVM."))) + +(define-public java-surefire-extensions-api + (package + (inherit java-surefire-logger-api) + (name "java-surefire-extensions-api") + (arguments + `(#:tests? #f; requires mockito 2 + #:jar-name "java-surefire-extensions-api.jar" + #:source-dir "surefire-extensions-api/src/main/java" + #:phases + (modify-phases %standard-phases + (replace 'install + (install-from-pom "surefire-extensions-api/pom.xml"))))) + (propagated-inputs + (list java-surefire-api java-surefire-parent-pom)) + (inputs + (list java-plexus-component-annotations)) + (synopsis "Extension API for Maven SureFire") + (description "Surefire is a test framework project. This is the aggregator +POM in Apache Maven Surefire project."))) + +(define-public java-surefire-common-java5 + (package + (inherit java-surefire-logger-api) + (name "java-surefire-common-java5") + (arguments + `(#:jar-name "java-surefire-common-java5.jar" + #:source-dir "surefire-providers/common-java5/src/main/java" + #:test-dir "surefire-providers/common-java5/src/test" + #:test-exclude (list + ;; Abstract class + "**/PojoStackTraceWriterTest.java" + ;; Fails + "**/SmartStackTraceParserTest.java") + #:phases + (modify-phases %standard-phases + (add-before 'build 'prepare-shade + (lambda* (#:key inputs #:allow-other-keys) + (mkdir-p "build/classes") + (with-directory-excursion "build/classes" + (for-each + (lambda (jar-file) + (invoke "jar" "xf" jar-file) + (delete-file-recursively "META-INF")) + (find-files (assoc-ref inputs "maven-shared-utils") ".*.jar$"))) + #t)) + (add-after 'build 'shade + (lambda* (#:key inputs #:allow-other-keys) + (let ((jarjar + (car (find-files (assoc-ref inputs "java-jarjar") ".*.jar$"))) + (injar "java-surefire-common-java5.jar") + (outjar "java-surefire-common-java5-shaded.jar")) + (with-directory-excursion "build/jar" + (with-output-to-file "rules" + (lambda _ + (format #t (string-append + "rule " + "org.apache.maven.shared.utils.** " + "org.apache.maven.surefire.shade.common." + "org.apache.maven.shared.utils.@1~%")))) + (invoke "java" "-jar" jarjar "process" "rules" injar outjar) + (delete-file injar) + (rename-file outjar injar))) + #t)) + (replace 'install + (install-from-pom "surefire-providers/common-java5/pom.xml"))))) + (propagated-inputs + (list maven-shared-utils-3.1 java-surefire-api + java-surefire-parent-pom)) + (native-inputs + (list unzip java-jarjar java-junit java-fest-assert)) + (synopsis "Common java5 facilities for Maven SureFire") + (description "This package contains shared Java 5 code for all providers."))) + +(define-public java-surefire-common-junit3 + (package + (inherit java-surefire-logger-api) + (name "java-surefire-common-junit3") + (arguments + `(#:jar-name "java-surefire-common-junit3.jar" + #:source-dir "surefire-providers/common-junit3/src/main/java" + #:test-dir "surefire-providers/common-junit3/src/test" + #:phases + (modify-phases %standard-phases + (replace 'install + (install-from-pom "surefire-providers/common-junit3/pom.xml"))))) + (propagated-inputs + (list java-junit java-surefire-api java-surefire-parent-pom)) + (native-inputs + (list unzip java-junit java-fest-assert)) + (synopsis "Shared JUnit3 provider code for Maven SureFire") + (description "This package contains shared code for all JUnit providers."))) + +(define-public java-surefire-common-junit4 + (package + (inherit java-surefire-logger-api) + (name "java-surefire-common-junit4") + (arguments + `(#:jar-name "java-surefire-common-junit4.jar" + #:source-dir "surefire-providers/common-junit4/src/main/java" + #:tests? #f; tests require junit 4.0 + #:phases + (modify-phases %standard-phases + (replace 'install + (install-from-pom "surefire-providers/common-junit4/pom.xml"))))) + (propagated-inputs + (list java-junit + java-surefire-api + java-surefire-common-java5 + java-surefire-common-junit3 + maven-shared-utils-3.1 + java-surefire-parent-pom)) + (synopsis "Shared JUnit4 provider code for Maven SureFire") + (description "This package contains shared code for all JUnit providers, +starting from JUnit 4."))) + +(define-public java-surefire-junit4 + (package + (inherit java-surefire-logger-api) + (name "java-surefire-junit4") + (arguments + `(;#:tests? #f + #:jar-name "java-surefire-junit4.jar" + #:source-dir "surefire-providers/surefire-junit4/src/main/java" + #:test-dir "surefire-providers/surefire-junit4/src/test" + #:modules ((guix build ant-build-system) + (guix build utils) + (guix build java-utils) + (sxml simple)) + #:phases + (modify-phases %standard-phases + (add-before 'install 'regenerate-own-pom + ;; Surefire struggles resolving artifacts because of this pom + ;; file, resulting in a NullPointerException when collecting + ;; Artifacts (and a "Failure detected." message from + ;; DefaultArtifactResolver). Replace the pom file with a much + ;; simpler one. Everything is shaded anyway (as used to be the + ;; case in 2.22), so there will not be missing dependencies. + (generate-pom.xml + "surefire-providers/surefire-junit4/pom.xml" + "org.apache.maven.surefire" "surefire-junit4" + ,(package-version java-surefire-common-java5) + #:name "Surefire JUnit4")) + (add-before 'build 'copy-resources + (lambda _ + (mkdir-p "build/classes") + (copy-recursively "surefire-providers/surefire-junit4/src/main/resources" + "build/classes") + #t)) + (add-before 'build 'prepare-shade + (lambda* (#:key inputs #:allow-other-keys) + (mkdir-p "build/classes") + (with-directory-excursion "build/classes" + (for-each + (lambda (input) + (for-each + (lambda (jar-file) + (invoke "jar" "xf" jar-file) + (delete-file-recursively "META-INF")) + (find-files (assoc-ref inputs input) ".*.jar$"))) + '("maven-shared-utils" "java-surefire-common-java5" + "java-surefire-common-junit3" "java-surefire-common-junit4" + "java-surefire-api"))) + #t)) + (add-after 'build 'shade + (lambda* (#:key inputs #:allow-other-keys) + (let ((jarjar + (car (find-files (assoc-ref inputs "java-jarjar") ".*.jar$"))) + (injar "java-surefire-junit4.jar") + (outjar "java-surefire-junit4-shaded.jar")) + (with-directory-excursion "build/jar" + (with-output-to-file "rules" + (lambda _ + (format #t (string-append + "rule " + "org.apache.maven.shared.utils.** " + "org.apache.maven.surefire.shade." + "org.apache.maven.shared.utils.@1~%")))) + (invoke "java" "-jar" jarjar "process" "rules" injar outjar) + (delete-file injar) + (rename-file outjar injar))) + #t)) + (replace 'install + (install-from-pom "surefire-providers/surefire-junit4/pom.xml"))))) + (propagated-inputs + (list java-junit java-surefire-parent-pom)) + (inputs + (list java-surefire-common-junit4 java-surefire-common-junit3 + java-surefire-common-java5 java-surefire-api)) + (native-inputs + (list java-jarjar unzip java-junit java-hamcrest-all + java-fest-assert)) + (synopsis "SureFire JUnit 4.0+ runner") + (description "This package contains the runner for tests run on a forked +JVM, using JUnit 4.0 or later."))) + +(define-public maven-surefire-common + (package + (inherit java-surefire-logger-api) + (name "maven-surefire-common") + (arguments + `(#:tests? #f; require mockito 2 + #:jar-name "maven-surefire-common.jar" + #:source-dir "maven-surefire-common/src/main/java" + #:phases + (modify-phases %standard-phases + (add-before 'build 'prepare-shade + (lambda* (#:key inputs #:allow-other-keys) + (mkdir-p "build/classes") + (with-directory-excursion "build/classes" + (for-each + (lambda (input) + (for-each + (lambda (jar-file) + (invoke "jar" "xf" jar-file) + (delete-file-recursively "META-INF")) + (find-files (assoc-ref inputs input) ".*.jar$"))) + '("maven-shared-utils" "java-commons-io" "java-commons-lang3" + "java-commons-compress" "maven-common-artifact-filters"))) + #t)) + (add-after 'build 'shade + (lambda* (#:key inputs #:allow-other-keys) + (let ((jarjar + (car (find-files (assoc-ref inputs "java-jarjar") ".*.jar$"))) + (injar "maven-surefire-common.jar") + (outjar "maven-surefire-common-shaded.jar")) + (with-directory-excursion "build/jar" + (with-output-to-file "rules" + (lambda _ + (format #t (string-append + "rule " + "org.apache.maven.shared.utils.** " + "org.apache.maven.surefire.shade.common." + "org.apache.maven.shared.utils.@1~%")) + (format #t (string-append + "rule " + "org.apache.commons.io.** " + "org.apache.maven.surefire.shade.common." + "org.apache.commons.io.@1~%")) + (format #t (string-append + "rule " + "org.apache.commons.lang3.** " + "org.apache.maven.surefire.shade.common." + "org.apache.commons.lang3.@1~%")) + (format #t (string-append + "rule " + "org.apache.commons.compress.** " + "org.apache.maven.surefire.shade.common." + "org.apache.commons.compress.@1~%")))) + (invoke "java" "-jar" jarjar "process" "rules" injar outjar) + (delete-file injar) + (rename-file outjar injar))) + #t)) + (add-before 'install 'fix-pom + (lambda _ + (substitute* "maven-surefire-common/pom.xml" + (("maven-toolchain") "maven-core")) + #t)) + (replace 'install + (install-from-pom "maven-surefire-common/pom.xml"))))) + (propagated-inputs + (list java-surefire-api + java-surefire-extensions-api + java-surefire-booter + maven-core + maven-plugin-annotations + maven-common-artifact-filters + maven-artifact-transfer + java-plexus-java + java-jansi + java-commons-io + java-commons-lang3 + java-commons-compress + maven-shared-utils-3.1 + java-surefire-parent-pom)) + (inputs + (list java-jsr305)) + (native-inputs + (list unzip java-jarjar)) + (synopsis "API used in Surefire and Failsafe MOJO") + (description "This package contains an API used in SureFire and Failsafe +MOJO."))) + +(define-public maven-surefire-plugin + (package + (inherit java-surefire-logger-api) + (name "maven-surefire-plugin") + (arguments + `(#:jar-name "maven-surefire-plugin.jar" + #:source-dir "maven-surefire-plugin/src/main/java" + #:tests? #f; test depends on maven-plugin-test-harness + #:phases + (modify-phases %standard-phases + (add-before 'build 'generate-plugin.xml + (generate-plugin.xml "maven-surefire-plugin/pom.xml" + "surefire" + "." + (list + (list + "maven-surefire-common/src/main/java/org/apache/maven/plugin/surefire/AbstractSurefireMojo.java" + "maven-surefire-plugin/src/main/java/org/apache/maven/plugin/surefire/SurefirePlugin.java")))) + (replace 'install + (install-from-pom "maven-surefire-plugin/pom.xml"))))) + (propagated-inputs + (list maven-surefire-common maven-core)) + (native-inputs + (list maven-plugin-annotations unzip)) + (synopsis "SureFire Maven plugin that runs tests") + (description "The Surefire Plugin is used during the test phase of the +build lifecycle to execute the unit tests of an application. It generates +reports in two different file formats, plain text and xml."))) + +(define-public maven-jar-plugin + (package + (name "maven-jar-plugin") + (version "3.2.0") + (source (origin + (method git-fetch) + (uri (git-reference + (url "https://github.com/apache/maven-jar-plugin") + (commit (string-append "maven-jar-plugin-" version)))) + (file-name (git-file-name name version)) + (sha256 + (base32 + "04y2rlmcabmc55ljqlkgbb5xx94a59cz1dvrnpfj1vzz024pqkyg")))) + (build-system ant-build-system) + (arguments + `(#:jar-name "maven-jar-plugin.jar" + #:source-dir "src/main/java" + #:tests? #f; test depends on maven-plugin-test-harness + #:phases + (modify-phases %standard-phases + (add-before 'build 'generate-plugin.xml + (generate-plugin.xml "pom.xml" + "jar" + "src/main/java/org/apache/maven/plugins/jar" + (list + (list "AbstractJarMojo.java" "JarMojo.java") + (list "AbstractJarMojo.java" "TestJarMojo.java")))) + (replace 'install + (install-from-pom "pom.xml"))))) + (propagated-inputs + (list maven-archiver + maven-3.0-artifact + maven-3.0-core + maven-3.0-plugin-api + maven-file-management + maven-shared-utils + java-plexus-archiver + java-plexus-utils)) + (inputs + (list maven-plugin-annotations)) + (home-page "https://maven.apache.org/plugins/maven-jar-plugin") + (synopsis "Jar builder plugin for Maven") + (description "This plugin provides the capability to build jars. If you +would like to sign jars please use the Maven Jarsigner Plugin instead.") + (license license:asl2.0))) + +(define-public maven-doxia-sink-api + (package + (name "maven-doxia-sink-api") + (version "2.0.0-M2") + (source (origin + (method git-fetch) + (uri (git-reference + (url "https://gitbox.apache.org/repos/asf/maven-doxia.git") + (commit (string-append "doxia-" version)))) + (file-name (git-file-name "doxia" version)) + (sha256 + (base32 + "0jx96lg0hgjsrm8mynhac4hwh2hmgiwjpwpx2k03yr14040zcr48")))) + (build-system ant-build-system) + (propagated-inputs + (list maven-doxia-parent-pom)) + (arguments + `(#:jar-name "doxia-sink-api.jar" + #:source-dir "doxia-sink-api/src/main/java" + #:tests? #f ; no tests + #:phases (modify-phases %standard-phases + (replace 'install + (install-from-pom "doxia-sink-api/pom.xml"))))) + (home-page "https://maven.apache.org/doxia/index.html") + (synopsis "Generic markup language interface") + (description + "The @code{Sink} interface is a generic markup language +interface provided as a Java API. It contains several methods that +encapsulate common text syntax. A start tag is denoted by @code{xxxx()} +method and a end of tag by @code{xxxx_()} method.") + (license license:asl2.0))) + +(define maven-doxia-parent-pom + (package + (inherit maven-doxia-sink-api) + (name "maven-doxia-parent-pom") + (arguments + `(#:tests? #f + #:phases (modify-phases %standard-phases + (delete 'configure) + (delete 'build) + (replace 'install + (install-pom-file "pom.xml"))))) + (propagated-inputs + (list maven-parent-pom-34)) + (synopsis "Content generation framework") + (description "@samp{Doxia} is a content generation framework that provides +powerful techniques for generating static and dynamic content, supporting a +variety of markup languages."))) + +(define-public maven-doxia-core + (package + (inherit maven-doxia-sink-api) + (name "maven-doxia-core") + (arguments + `(#:jar-name "doxia-core.jar" + #:source-dir "doxia-core/src/main/java" + #:test-dir "doxia-core/src/test/java" + #:tests? #f ; tests require JUnit5 + #:phases (modify-phases %standard-phases + (replace 'install + (install-from-pom "doxia-core/pom.xml"))))) + (propagated-inputs (list maven-doxia-parent-pom + maven-doxia-sink-api + java-slf4j-api + java-javax-inject + java-plexus-utils + java-eclipse-sisu-plexus + java-commons-text)) + (synopsis "Doxia core classes and interfaces") + (description + "Doxia is a content generation framework that provides powerful +techniques for generating static and dynamic content, supporting a variety of +markup languages. + +This package contains Doxia core classes and interfaces.")))