Merge pull request #316764 from atorres1985-contrib/maven-refactor

Maven: refactor
This commit is contained in:
superherointj 2024-06-09 10:59:06 -03:00 committed by GitHub
commit 21f2d189e4
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
5 changed files with 62 additions and 54 deletions

View File

@ -0,0 +1,60 @@
{
lib,
callPackage,
fetchurl,
jdk,
makeWrapper,
stdenvNoCC,
}:
stdenvNoCC.mkDerivation (finalAttrs: {
pname = "apache-maven";
version = "3.9.6";
src = fetchurl {
url = "mirror://apache/maven/maven-3/${finalAttrs.version}/binaries/apache-maven-${finalAttrs.version}-bin.tar.gz";
hash = "sha256-bu3SyuNibWrTpcnuMkvSZYU9ZCl/B/AzQwdVvQ4MOks=";
};
sourceRoot = ".";
nativeBuildInputs = [ makeWrapper ];
installPhase = ''
runHook preInstall
mkdir -p $out/maven
cp -r apache-maven-${finalAttrs.version}/* $out/maven
makeWrapper $out/maven/bin/mvn $out/bin/mvn \
--set-default JAVA_HOME "${jdk}"
makeWrapper $out/maven/bin/mvnDebug $out/bin/mvnDebug \
--set-default JAVA_HOME "${jdk}"
runHook postInstall
'';
passthru = {
buildMaven = callPackage ./build-maven.nix {
maven = finalAttrs.finalPackage;
};
buildMavenPackage = callPackage ./build-maven-package.nix {
maven = finalAttrs.finalPackage;
};
};
meta = {
homepage = "https://maven.apache.org/";
description = "Build automation tool (used primarily for Java projects)";
longDescription = ''
Apache Maven is a software project management and comprehension
tool. Based on the concept of a project object model (POM), Maven can
manage a project's build, reporting and documentation from a central piece
of information.
'';
license = lib.licenses.asl20;
mainProgram = "mvn";
maintainers = with lib.maintainers; [ cko ];
inherit (jdk.meta) platforms;
};
})

View File

@ -1,50 +0,0 @@
{ lib
, stdenvNoCC
, fetchurl
, jdk
, makeWrapper
, callPackage
}:
assert jdk != null;
stdenvNoCC.mkDerivation (finalAttrs: {
pname = "apache-maven";
version = "3.9.6";
src = fetchurl {
url = "mirror://apache/maven/maven-3/${finalAttrs.version}/binaries/${finalAttrs.pname}-${finalAttrs.version}-bin.tar.gz";
hash = "sha256-bu3SyuNibWrTpcnuMkvSZYU9ZCl/B/AzQwdVvQ4MOks=";
};
sourceRoot = ".";
nativeBuildInputs = [ makeWrapper ];
installPhase = ''
runHook preInstall
mkdir -p $out/maven
cp -r ${finalAttrs.pname}-${finalAttrs.version}/* $out/maven
makeWrapper $out/maven/bin/mvn $out/bin/mvn \
--set-default JAVA_HOME "${jdk}"
makeWrapper $out/maven/bin/mvnDebug $out/bin/mvnDebug \
--set-default JAVA_HOME "${jdk}"
runHook postInstall
'';
passthru.buildMavenPackage = callPackage ./build-package.nix {
maven = finalAttrs.finalPackage;
};
meta = with lib; {
mainProgram = "mvn";
description = "Build automation tool (used primarily for Java projects)";
homepage = "https://maven.apache.org/";
license = licenses.asl20;
platforms = platforms.unix;
maintainers = with maintainers; [ cko ];
};
})

View File

@ -403,8 +403,6 @@ with pkgs;
buildFHSEnvChroot = callPackage ../build-support/build-fhsenv-chroot { }; # Deprecated; use buildFHSEnv/buildFHSEnvBubblewrap
buildFHSEnvBubblewrap = callPackage ../build-support/build-fhsenv-bubblewrap { };
buildMaven = callPackage ../build-support/build-maven.nix { };
c64-debugger = callPackage ../applications/emulators/c64-debugger { };
camunda-modeler = callPackage ../applications/misc/camunda-modeler { };
@ -19067,8 +19065,8 @@ with pkgs;
math-preview = callPackage ../tools/text/math-review { };
maven = maven3;
maven3 = callPackage ../development/tools/build-managers/apache-maven { };
maven3 = maven;
inherit (maven) buildMaven;
mavproxy = python3Packages.callPackage ../applications/science/robotics/mavproxy { };