buildGraalvmNativeImage: use lib.extendMkDerivation

Co-authored-by: Philip Taron <philip.taron@gmail.com>
This commit is contained in:
Benjamin Sparks 2025-06-03 18:57:45 +02:00
parent de57db2293
commit 4d134f63fd
2 changed files with 92 additions and 83 deletions

View File

@ -2,13 +2,33 @@
lib,
stdenv,
glibcLocales,
# The GraalVM derivation to use
graalvmDrv,
removeReferencesTo,
executable ? args.pname,
# JAR used as input for GraalVM derivation, defaults to src
jar ? args.src,
dontUnpack ? (jar == args.src),
graalvmPackages,
}:
lib.extendMkDerivation {
constructDrv = stdenv.mkDerivation;
excludeDrvArgNames = [
"executable"
"extraNativeImageBuildArgs"
"graalvmDrv"
"graalvmXmx"
"nativeImageBuildArgs"
];
extendDrvArgs =
finalAttrs:
{
dontUnpack ? true,
strictDeps ? true,
__structuredAttrs ? true,
# The GraalVM derivation to use
graalvmDrv ? graalvmPackages.graalvm-ce,
executable ? finalAttrs.meta.mainProgram,
# Default native-image arguments. You probably don't want to set this,
# except in special cases. In most cases, use extraNativeBuildArgs instead
nativeImageBuildArgs ? [
@ -20,35 +40,24 @@
"-march=compatibility"
"--verbose"
],
# Extra arguments to be passed to the native-image
extraNativeImageBuildArgs ? [ ],
# XMX size of GraalVM during build
graalvmXmx ? "-J-Xmx6g",
env ? { },
meta ? { },
LC_ALL ? "en_US.UTF-8",
passthru ? { },
...
}@args:
let
extraArgs = builtins.removeAttrs args [
"lib"
"stdenv"
"glibcLocales"
"jar"
"dontUnpack"
"LC_ALL"
"meta"
"buildPhase"
"nativeBuildInputs"
"installPhase"
"postInstall"
];
in
stdenv.mkDerivation (
}@args:
{
inherit dontUnpack jar;
env = {
LC_ALL = "en_US.UTF-8";
} // env;
env = { inherit LC_ALL; };
inherit dontUnpack strictDeps __structuredAttrs;
nativeBuildInputs = (args.nativeBuildInputs or [ ]) ++ [
graalvmDrv
@ -56,13 +65,17 @@ stdenv.mkDerivation (
removeReferencesTo
];
nativeImageBuildArgs = nativeImageBuildArgs ++ extraNativeImageBuildArgs ++ [ graalvmXmx ];
# `nativeBuildInputs` does not allow `graalvmDrv`'s propagatedBuildInput to reach here this package.
# As its `propagatedBuildInputs` is required for the build process with `native-image`, we must add it here as well.
buildInputs = [ graalvmDrv ];
nativeImageArgs = nativeImageBuildArgs ++ extraNativeImageBuildArgs ++ [ graalvmXmx ];
buildPhase =
args.buildPhase or ''
runHook preBuild
native-image -jar "$jar" ''${nativeImageBuildArgs[@]}
native-image -jar "$src" ''${nativeImageArgs[@]}
runHook postBuild
'';
@ -83,14 +96,13 @@ stdenv.mkDerivation (
disallowedReferences = [ graalvmDrv ];
passthru = { inherit graalvmDrv; };
passthru = {
inherit graalvmDrv;
} // passthru;
meta = {
# default to graalvm's platforms
platforms = graalvmDrv.meta.platforms;
# default to executable name
mainProgram = executable;
inherit (graalvmDrv.meta) platforms;
} // meta;
}
// extraArgs
)
};
}

View File

@ -5747,10 +5747,7 @@ with pkgs;
openjdk_headless = jdk_headless;
graalvmPackages = recurseIntoAttrs (callPackage ../development/compilers/graalvm { });
buildGraalvmNativeImage =
(callPackage ../build-support/build-graalvm-native-image {
graalvmDrv = graalvmPackages.graalvm-ce;
}).override;
buildGraalvmNativeImage = callPackage ../build-support/build-graalvm-native-image { };
openshot-qt = libsForQt5.callPackage ../applications/video/openshot-qt { };