guix: java-utils: Factorize pom.xml generation.
* guix/build/java-utils.scm (generate-pom.xml): New procedure. * gnu/packages/maven.scm (java-surefire-junit4): Use it. * gnu/packages/java.scm (java-qdox, java-jsr250, java-jsr305) (java-aopalliance, java-jboss-el-api-spec) (java-jboss-interceptors-api-spec): Use it. (java-qdox-M9): Ensure the generated pom file has the correct version.
This commit is contained in:
parent
a40207bd6f
commit
4c98db94b0
@ -3847,25 +3847,11 @@ documentation tools.")
|
|||||||
(arguments
|
(arguments
|
||||||
`(#:jar-name "qdox.jar"
|
`(#:jar-name "qdox.jar"
|
||||||
#:tests? #f; no tests
|
#:tests? #f; no tests
|
||||||
#:modules
|
|
||||||
((guix build ant-build-system)
|
|
||||||
(guix build java-utils)
|
|
||||||
(guix build utils)
|
|
||||||
(sxml simple))
|
|
||||||
#:phases
|
#:phases
|
||||||
(modify-phases %standard-phases
|
(modify-phases %standard-phases
|
||||||
(add-before 'install 'create-pom
|
(add-before 'install 'create-pom
|
||||||
(lambda _
|
(generate-pom.xml "pom.xml" "com.thoughtworks.qdox" "qdox" ,version
|
||||||
(with-output-to-file "pom.xml"
|
#:name "QDox"))
|
||||||
(lambda _
|
|
||||||
(sxml->xml
|
|
||||||
`((project
|
|
||||||
(modelVersion "4.0.0")
|
|
||||||
(name "QDox")
|
|
||||||
(groupId "com.thoughtworks.qdox")
|
|
||||||
(artifactId "qdox")
|
|
||||||
(version ,,version))))))
|
|
||||||
#t))
|
|
||||||
(replace 'install
|
(replace 'install
|
||||||
(install-from-pom "pom.xml")))))
|
(install-from-pom "pom.xml")))))
|
||||||
(home-page "https://github.com/codehaus/qdox")
|
(home-page "https://github.com/codehaus/qdox")
|
||||||
@ -3891,7 +3877,14 @@ documentation tools.")
|
|||||||
"/qdox-" version "-sources.jar"))
|
"/qdox-" version "-sources.jar"))
|
||||||
(sha256
|
(sha256
|
||||||
(base32
|
(base32
|
||||||
"1s2jnmx2dkwnaha12lcj26aynywgwa8sslc47z82wx8xai13y4fg"))))))
|
"1s2jnmx2dkwnaha12lcj26aynywgwa8sslc47z82wx8xai13y4fg"))))
|
||||||
|
(arguments
|
||||||
|
(substitute-keyword-arguments (package-arguments java-qdox)
|
||||||
|
((#:phases phases)
|
||||||
|
`(modify-phases ,phases
|
||||||
|
(replace 'create-pom
|
||||||
|
(generate-pom.xml "pom.xml" "com.thoughtworks.qdox" "qdox" ,version
|
||||||
|
#:name "QDox"))))))))
|
||||||
|
|
||||||
(define-public java-jarjar
|
(define-public java-jarjar
|
||||||
(package
|
(package
|
||||||
@ -6463,25 +6456,11 @@ bottlenecks move away from the database in an effectively cached system.")
|
|||||||
`(#:tests? #f ; no tests included
|
`(#:tests? #f ; no tests included
|
||||||
#:jdk ,icedtea-8
|
#:jdk ,icedtea-8
|
||||||
#:jar-name "jsr250.jar"
|
#:jar-name "jsr250.jar"
|
||||||
#:modules ((guix build ant-build-system)
|
|
||||||
(guix build utils)
|
|
||||||
(guix build maven pom)
|
|
||||||
(guix build java-utils)
|
|
||||||
(sxml simple))
|
|
||||||
#:phases
|
#:phases
|
||||||
(modify-phases %standard-phases
|
(modify-phases %standard-phases
|
||||||
(add-before 'install 'create-pom
|
(add-before 'install 'create-pom
|
||||||
(lambda _
|
(generate-pom.xml "pom.xml" "javax.annotation" "jsr250-api" ,version
|
||||||
(with-output-to-file "pom.xml"
|
#:name "jsr250"))
|
||||||
(lambda _
|
|
||||||
(sxml->xml
|
|
||||||
`((project
|
|
||||||
(modelVersion "4.0.0")
|
|
||||||
(name "jsr250")
|
|
||||||
(groupId "javax.annotation")
|
|
||||||
(artifactId "jsr250-api")
|
|
||||||
(version ,,version))))))
|
|
||||||
#t))
|
|
||||||
(replace 'install
|
(replace 'install
|
||||||
(install-from-pom "pom.xml")))))
|
(install-from-pom "pom.xml")))))
|
||||||
(home-page "https://jcp.org/en/jsr/detail?id=250")
|
(home-page "https://jcp.org/en/jsr/detail?id=250")
|
||||||
@ -6510,25 +6489,10 @@ namespaces.")
|
|||||||
(arguments
|
(arguments
|
||||||
`(#:tests? #f ; no tests included
|
`(#:tests? #f ; no tests included
|
||||||
#:jar-name "jsr305.jar"
|
#:jar-name "jsr305.jar"
|
||||||
#:modules ((guix build ant-build-system)
|
|
||||||
(guix build java-utils)
|
|
||||||
(guix build maven pom)
|
|
||||||
(guix build utils)
|
|
||||||
(sxml simple))
|
|
||||||
#:phases
|
#:phases
|
||||||
(modify-phases %standard-phases
|
(modify-phases %standard-phases
|
||||||
(add-before 'install 'create-pom
|
(add-before 'install 'create-pom
|
||||||
(lambda _
|
(generate-pom.xml "pom.xml" "com.google.code.findbugs" "jsr305" ,version))
|
||||||
(with-output-to-file "pom.xml"
|
|
||||||
(lambda _
|
|
||||||
(sxml->xml
|
|
||||||
`((project
|
|
||||||
(modelVersion "4.0.0")
|
|
||||||
(name "jsr305")
|
|
||||||
(groupId "com.google.code.findbugs")
|
|
||||||
(artifactId "jsr305")
|
|
||||||
(version ,,version))))))
|
|
||||||
#t))
|
|
||||||
(replace 'install
|
(replace 'install
|
||||||
(install-from-pom "pom.xml")))))
|
(install-from-pom "pom.xml")))))
|
||||||
(home-page "http://findbugs.sourceforge.net/")
|
(home-page "http://findbugs.sourceforge.net/")
|
||||||
@ -10559,25 +10523,10 @@ this is not a static analysis tool.)")
|
|||||||
#:jdk ,icedtea-8
|
#:jdk ,icedtea-8
|
||||||
#:tests? #f; no tests
|
#:tests? #f; no tests
|
||||||
#:source-dir "aopalliance/src/main"
|
#:source-dir "aopalliance/src/main"
|
||||||
#:modules ((guix build ant-build-system)
|
|
||||||
(guix build utils)
|
|
||||||
(guix build maven pom)
|
|
||||||
(guix build java-utils)
|
|
||||||
(sxml simple))
|
|
||||||
#:phases
|
#:phases
|
||||||
(modify-phases %standard-phases
|
(modify-phases %standard-phases
|
||||||
(add-before 'install 'create-pom
|
(add-before 'install 'create-pom
|
||||||
(lambda _
|
(generate-pom.xml "pom.xml" "aopalliance" "aopalliance" ,version))
|
||||||
(with-output-to-file "pom.xml"
|
|
||||||
(lambda _
|
|
||||||
(sxml->xml
|
|
||||||
`((project
|
|
||||||
(modelVersion "4.0.0")
|
|
||||||
(name "aopalliance")
|
|
||||||
(groupId "aopalliance")
|
|
||||||
(artifactId "aopalliance")
|
|
||||||
(version "1.0"))))))
|
|
||||||
#t))
|
|
||||||
(replace 'install
|
(replace 'install
|
||||||
(install-from-pom "pom.xml")))))
|
(install-from-pom "pom.xml")))))
|
||||||
(home-page "http://aopalliance.sourceforge.net")
|
(home-page "http://aopalliance.sourceforge.net")
|
||||||
@ -12176,29 +12125,14 @@ sequences to format your console output which works on every platform.")
|
|||||||
(build-system ant-build-system)
|
(build-system ant-build-system)
|
||||||
(arguments
|
(arguments
|
||||||
`(#:jar-name "java-jboss-el-api_spec.jar"
|
`(#:jar-name "java-jboss-el-api_spec.jar"
|
||||||
#:modules ((guix build ant-build-system)
|
|
||||||
(guix build utils)
|
|
||||||
(guix build maven pom)
|
|
||||||
(guix build java-utils)
|
|
||||||
(sxml simple))
|
|
||||||
#:phases
|
#:phases
|
||||||
(modify-phases %standard-phases
|
(modify-phases %standard-phases
|
||||||
;; the origin of javax.el:javax.el-api is unknown, so we use this package
|
;; the origin of javax.el:javax.el-api is unknown, so we use this package
|
||||||
;; instead, which implements the same thing. We override the pom file
|
;; instead, which implements the same thing. We override the pom file
|
||||||
;; to "rename" the package so it can be found by maven.
|
;; to "rename" the package so it can be found by maven.
|
||||||
(add-before 'install 'override-pom
|
(add-before 'install 'override-pom
|
||||||
(lambda _
|
(generate-pom.xml "pom.xml" "javax.el" "javax.el-api" "3.0"
|
||||||
(delete-file "pom.xml")
|
#:name "el-api"))
|
||||||
(with-output-to-file "pom.xml"
|
|
||||||
(lambda _
|
|
||||||
(sxml->xml
|
|
||||||
`(project
|
|
||||||
(modelVersion "4.0.0")
|
|
||||||
(name "el-api")
|
|
||||||
(groupId "javax.el")
|
|
||||||
(artifactId "javax.el-api")
|
|
||||||
(version "3.0")))))
|
|
||||||
#t))
|
|
||||||
(replace 'install
|
(replace 'install
|
||||||
(install-from-pom "pom.xml")))))
|
(install-from-pom "pom.xml")))))
|
||||||
(inputs
|
(inputs
|
||||||
@ -12230,11 +12164,6 @@ JavaServer Pages (JSP).")
|
|||||||
#:jdk ,icedtea-8
|
#:jdk ,icedtea-8
|
||||||
#:source-dir "."
|
#:source-dir "."
|
||||||
#:tests? #f; no tests
|
#:tests? #f; no tests
|
||||||
#:modules ((guix build ant-build-system)
|
|
||||||
(guix build utils)
|
|
||||||
(guix build maven pom)
|
|
||||||
(guix build java-utils)
|
|
||||||
(sxml simple))
|
|
||||||
#:phases
|
#:phases
|
||||||
(modify-phases %standard-phases
|
(modify-phases %standard-phases
|
||||||
;; the origin of javax.interceptor:javax.interceptor-api is unknown,
|
;; the origin of javax.interceptor:javax.interceptor-api is unknown,
|
||||||
@ -12242,18 +12171,8 @@ JavaServer Pages (JSP).")
|
|||||||
;; We override the pom file to "rename" the package so it can be found
|
;; We override the pom file to "rename" the package so it can be found
|
||||||
;; by maven.
|
;; by maven.
|
||||||
(add-before 'install 'override-pom
|
(add-before 'install 'override-pom
|
||||||
(lambda _
|
(generate-pom.xml "pom.xml" "javax.interceptor" "javax.interceptor-api"
|
||||||
(delete-file "pom.xml")
|
"3.0" #:name "interceptor-api"))
|
||||||
(with-output-to-file "pom.xml"
|
|
||||||
(lambda _
|
|
||||||
(sxml->xml
|
|
||||||
`(project
|
|
||||||
(modelVersion "4.0.0")
|
|
||||||
(name "interceptor-api")
|
|
||||||
(groupId "javax.interceptor")
|
|
||||||
(artifactId "javax.interceptor-api")
|
|
||||||
(version "3.0")))))
|
|
||||||
#t))
|
|
||||||
(replace 'install
|
(replace 'install
|
||||||
(install-from-pom "pom.xml")))))
|
(install-from-pom "pom.xml")))))
|
||||||
(home-page "https://github.com/jboss/jboss-interceptors-api_spec")
|
(home-page "https://github.com/jboss/jboss-interceptors-api_spec")
|
||||||
|
@ -3424,23 +3424,17 @@ starting from JUnit 4.")))
|
|||||||
#:phases
|
#:phases
|
||||||
(modify-phases %standard-phases
|
(modify-phases %standard-phases
|
||||||
(add-before 'install 'regenerate-own-pom
|
(add-before 'install 'regenerate-own-pom
|
||||||
(lambda _
|
;; Surefire struggles resolving artifacts because of this pom
|
||||||
;; Surefire struggles resolving artifacts because of this pom
|
;; file, resulting in a NullPointerException when collecting
|
||||||
;; file, resulting in a NullPointerException when collecting
|
;; Artifacts (and a "Failure detected." message from
|
||||||
;; Artifacts (and a "Failure detected." message from
|
;; DefaultArtifactResolver). Replace the pom file with a much
|
||||||
;; DefaultArtifactResolver). Replace the pom file with a much
|
;; simpler one. Everything is shaded anyway (as used to be the
|
||||||
;; simpler one. Everything is shaded anyway (as used to be the
|
;; case in 2.22), so there will not be missing dependencies.
|
||||||
;; case in 2.22), so there will not be missing dependencies.
|
(generate-pom.xml
|
||||||
(with-output-to-file "surefire-providers/surefire-junit4/pom.xml"
|
"surefire-providers/surefire-junit4/pom.xml"
|
||||||
(lambda _
|
"org.apache.maven.surefire" "surefire-junit4"
|
||||||
(sxml->xml
|
,(package-version java-surefire-common-java5)
|
||||||
`((project
|
#:name "Surefire JUnit4"))
|
||||||
(modelVersion "4.0.0")
|
|
||||||
(name "Surefire JUnit4")
|
|
||||||
(groupId "org.apache.maven.surefire")
|
|
||||||
(artifactId "surefire-junit4")
|
|
||||||
(version ,,(package-version java-surefire-common-java5)))))))
|
|
||||||
#t))
|
|
||||||
(add-before 'build 'copy-resources
|
(add-before 'build 'copy-resources
|
||||||
(lambda _
|
(lambda _
|
||||||
(mkdir-p "build/classes")
|
(mkdir-p "build/classes")
|
||||||
|
@ -28,6 +28,7 @@
|
|||||||
#:use-module (sxml simple)
|
#:use-module (sxml simple)
|
||||||
#:export (ant-build-javadoc
|
#:export (ant-build-javadoc
|
||||||
generate-plugin.xml
|
generate-plugin.xml
|
||||||
|
generate-pom.xml
|
||||||
install-jars
|
install-jars
|
||||||
install-javadoc
|
install-javadoc
|
||||||
install-pom-file
|
install-pom-file
|
||||||
@ -206,3 +207,31 @@ recognize the package as a plugin, and find the entry points in the plugin."
|
|||||||
,mojos
|
,mojos
|
||||||
(dependencies
|
(dependencies
|
||||||
,@dependencies)))))))))
|
,@dependencies)))))))))
|
||||||
|
|
||||||
|
(define* (generate-pom.xml pom-file groupid artifactid version
|
||||||
|
#:key (dependencies '())
|
||||||
|
(name artifactid))
|
||||||
|
"Generates the @file{pom.xml} for a project. It is required by Maven to find
|
||||||
|
a package, and by the java build system to know where to install a package, when
|
||||||
|
a pom.xml doesn't already exist and installing to the maven repository."
|
||||||
|
(lambda _
|
||||||
|
(mkdir-p (dirname pom-file))
|
||||||
|
(with-output-to-file pom-file
|
||||||
|
(lambda _
|
||||||
|
(sxml->xml
|
||||||
|
(sxml-indent
|
||||||
|
`(project
|
||||||
|
(modelVersion "4.0.0")
|
||||||
|
(name ,name)
|
||||||
|
(groupId ,groupid)
|
||||||
|
(artifactId ,artifactid)
|
||||||
|
(version ,version)
|
||||||
|
(dependencies
|
||||||
|
,@(map
|
||||||
|
(match-lambda
|
||||||
|
((groupid artifactid version)
|
||||||
|
`(dependency
|
||||||
|
(groupId ,groupid)
|
||||||
|
(artifactId ,artifactid)
|
||||||
|
(version ,version))))
|
||||||
|
dependencies)))))))))
|
||||||
|
Loading…
Reference in New Issue
Block a user