mirror of
https://github.com/NixOS/nixpkgs.git
synced 2025-07-13 21:50:33 +03:00
build-support/go: reformat with nixfmt-rfc-style
This commit is contained in:
parent
362e56fc56
commit
fa65f09a8f
1 changed files with 363 additions and 304 deletions
|
@ -1,4 +1,10 @@
|
|||
{ go, cacert, gitMinimal, lib, stdenv }:
|
||||
{
|
||||
go,
|
||||
cacert,
|
||||
gitMinimal,
|
||||
lib,
|
||||
stdenv,
|
||||
}:
|
||||
|
||||
lib.extendMkDerivation {
|
||||
constructDrv = stdenv.mkDerivation;
|
||||
|
@ -10,59 +16,72 @@ lib.extendMkDerivation {
|
|||
];
|
||||
extendDrvArgs =
|
||||
finalAttrs:
|
||||
{ nativeBuildInputs ? [ ] # Native build inputs used for the derivation.
|
||||
, passthru ? { }
|
||||
, patches ? [ ]
|
||||
{
|
||||
nativeBuildInputs ? [ ], # Native build inputs used for the derivation.
|
||||
passthru ? { },
|
||||
patches ? [ ],
|
||||
|
||||
# A function to override the `goModules` derivation.
|
||||
, overrideModAttrs ? (finalAttrs: previousAttrs: { })
|
||||
overrideModAttrs ? (finalAttrs: previousAttrs: { }),
|
||||
|
||||
# Directory to the `go.mod` and `go.sum` relative to the `src`.
|
||||
, modRoot ? "./"
|
||||
modRoot ? "./",
|
||||
|
||||
# The SRI hash of the vendored dependencies.
|
||||
# If `vendorHash` is `null`, no dependencies are fetched and
|
||||
# the build relies on the vendor folder within the source.
|
||||
, vendorHash ? throw (
|
||||
vendorHash ? throw (
|
||||
if args ? vendorSha256 then
|
||||
"buildGoModule: Expect vendorHash instead of vendorSha256"
|
||||
else
|
||||
"buildGoModule: vendorHash is missing"
|
||||
)
|
||||
),
|
||||
|
||||
# Whether to delete the vendor folder supplied with the source.
|
||||
, deleteVendor ? false
|
||||
deleteVendor ? false,
|
||||
|
||||
# Whether to fetch (go mod download) and proxy the vendor directory.
|
||||
# This is useful if your code depends on c code and go mod tidy does not
|
||||
# include the needed sources to build or if any dependency has case-insensitive
|
||||
# conflicts which will produce platform dependant `vendorHash` checksums.
|
||||
, proxyVendor ? false
|
||||
proxyVendor ? false,
|
||||
|
||||
# We want parallel builds by default.
|
||||
, enableParallelBuilding ? true
|
||||
enableParallelBuilding ? true,
|
||||
|
||||
# Do not enable this without good reason
|
||||
# IE: programs coupled with the compiler.
|
||||
, allowGoReference ? false
|
||||
allowGoReference ? false,
|
||||
|
||||
# Meta data for the final derivation.
|
||||
, meta ? { }
|
||||
meta ? { },
|
||||
|
||||
# Go linker flags.
|
||||
, ldflags ? [ ]
|
||||
ldflags ? [ ],
|
||||
# Go build flags.
|
||||
, GOFLAGS ? [ ]
|
||||
GOFLAGS ? [ ],
|
||||
|
||||
, ...
|
||||
...
|
||||
}@args:
|
||||
{
|
||||
inherit modRoot vendorHash deleteVendor proxyVendor;
|
||||
goModules = if (finalAttrs.vendorHash == null) then "" else
|
||||
inherit
|
||||
modRoot
|
||||
vendorHash
|
||||
deleteVendor
|
||||
proxyVendor
|
||||
;
|
||||
goModules =
|
||||
if (finalAttrs.vendorHash == null) then
|
||||
""
|
||||
else
|
||||
(stdenv.mkDerivation {
|
||||
name = "${finalAttrs.name or "${finalAttrs.pname}-${finalAttrs.version}"}-go-modules";
|
||||
|
||||
nativeBuildInputs = (finalAttrs.nativeBuildInputs or [ ]) ++ [ go gitMinimal cacert ];
|
||||
nativeBuildInputs = (finalAttrs.nativeBuildInputs or [ ]) ++ [
|
||||
go
|
||||
gitMinimal
|
||||
cacert
|
||||
];
|
||||
|
||||
inherit (finalAttrs) src modRoot;
|
||||
|
||||
|
@ -86,7 +105,8 @@ lib.extendMkDerivation {
|
|||
"GOPROXY"
|
||||
];
|
||||
|
||||
configurePhase = args.modConfigurePhase or ''
|
||||
configurePhase =
|
||||
args.modConfigurePhase or ''
|
||||
runHook preConfigure
|
||||
export GOCACHE=$TMPDIR/go-cache
|
||||
export GOPATH="$TMPDIR/go"
|
||||
|
@ -94,46 +114,62 @@ lib.extendMkDerivation {
|
|||
runHook postConfigure
|
||||
'';
|
||||
|
||||
buildPhase = args.modBuildPhase or (''
|
||||
buildPhase =
|
||||
args.modBuildPhase or (
|
||||
''
|
||||
runHook preBuild
|
||||
'' + lib.optionalString finalAttrs.deleteVendor ''
|
||||
''
|
||||
+ lib.optionalString finalAttrs.deleteVendor ''
|
||||
if [ ! -d vendor ]; then
|
||||
echo "vendor folder does not exist, 'deleteVendor' is not needed"
|
||||
exit 10
|
||||
else
|
||||
rm -rf vendor
|
||||
fi
|
||||
'' + ''
|
||||
''
|
||||
+ ''
|
||||
if [ -d vendor ]; then
|
||||
echo "vendor folder exists, please set 'vendorHash = null;' in your expression"
|
||||
exit 10
|
||||
fi
|
||||
|
||||
export GIT_SSL_CAINFO=$NIX_SSL_CERT_FILE
|
||||
${if finalAttrs.proxyVendor then ''
|
||||
${
|
||||
if finalAttrs.proxyVendor then
|
||||
''
|
||||
mkdir -p "$GOPATH/pkg/mod/cache/download"
|
||||
go mod download
|
||||
'' else ''
|
||||
''
|
||||
else
|
||||
''
|
||||
if (( "''${NIX_DEBUG:-0}" >= 1 )); then
|
||||
goModVendorFlags+=(-v)
|
||||
fi
|
||||
go mod vendor "''${goModVendorFlags[@]}"
|
||||
''}
|
||||
''
|
||||
}
|
||||
|
||||
mkdir -p vendor
|
||||
|
||||
runHook postBuild
|
||||
'');
|
||||
''
|
||||
);
|
||||
|
||||
installPhase = args.modInstallPhase or ''
|
||||
installPhase =
|
||||
args.modInstallPhase or ''
|
||||
runHook preInstall
|
||||
|
||||
${if finalAttrs.proxyVendor then ''
|
||||
${
|
||||
if finalAttrs.proxyVendor then
|
||||
''
|
||||
rm -rf "$GOPATH/pkg/mod/cache/download/sumdb"
|
||||
cp -r --reflink=auto "$GOPATH/pkg/mod/cache/download" $out
|
||||
'' else ''
|
||||
''
|
||||
else
|
||||
''
|
||||
cp -r --reflink=auto vendor $out
|
||||
''}
|
||||
''
|
||||
}
|
||||
|
||||
if ! [ "$(ls -A $out)" ]; then
|
||||
echo "vendor folder is empty, please set 'vendorHash = null;' in your expression"
|
||||
|
@ -151,7 +187,8 @@ lib.extendMkDerivation {
|
|||
# empty hash requires explicit hash algorithm.
|
||||
outputHashAlgo = if finalAttrs.vendorHash == "" then "sha256" else null;
|
||||
# in case an overlay clears passthru by accident, don't fail evaluation
|
||||
}).overrideAttrs (finalAttrs.passthru.overrideModAttrs or overrideModAttrs);
|
||||
}).overrideAttrs
|
||||
(finalAttrs.passthru.overrideModAttrs or overrideModAttrs);
|
||||
|
||||
nativeBuildInputs = [ go ] ++ nativeBuildInputs;
|
||||
|
||||
|
@ -161,7 +198,8 @@ lib.extendMkDerivation {
|
|||
GO111MODULE = "on";
|
||||
GOTOOLCHAIN = "local";
|
||||
|
||||
CGO_ENABLED = args.env.CGO_ENABLED or (
|
||||
CGO_ENABLED =
|
||||
args.env.CGO_ENABLED or (
|
||||
if args ? CGO_ENABLED then
|
||||
# Compatibility layer to the CGO_ENABLED attribute not specified as env.CGO_ENABLED
|
||||
# TODO(@ShamrockLee): Remove and convert to
|
||||
|
@ -175,10 +213,15 @@ lib.extendMkDerivation {
|
|||
);
|
||||
};
|
||||
|
||||
GOFLAGS = GOFLAGS
|
||||
++ lib.warnIf (lib.any (lib.hasPrefix "-mod=") GOFLAGS) "use `proxyVendor` to control Go module/vendor behavior instead of setting `-mod=` in GOFLAGS"
|
||||
GOFLAGS =
|
||||
GOFLAGS
|
||||
++
|
||||
lib.warnIf (lib.any (lib.hasPrefix "-mod=") GOFLAGS)
|
||||
"use `proxyVendor` to control Go module/vendor behavior instead of setting `-mod=` in GOFLAGS"
|
||||
(lib.optional (!finalAttrs.proxyVendor) "-mod=vendor")
|
||||
++ lib.warnIf (builtins.elem "-trimpath" GOFLAGS) "`-trimpath` is added by default to GOFLAGS by buildGoModule when allowGoReference isn't set to true"
|
||||
++
|
||||
lib.warnIf (builtins.elem "-trimpath" GOFLAGS)
|
||||
"`-trimpath` is added by default to GOFLAGS by buildGoModule when allowGoReference isn't set to true"
|
||||
(lib.optional (!allowGoReference) "-trimpath");
|
||||
|
||||
inherit enableParallelBuilding;
|
||||
|
@ -186,7 +229,9 @@ lib.extendMkDerivation {
|
|||
# If not set to an explicit value, set the buildid empty for reproducibility.
|
||||
ldflags = ldflags ++ lib.optional (!lib.any (lib.hasPrefix "-buildid=") ldflags) "-buildid=";
|
||||
|
||||
configurePhase = args.configurePhase or (''
|
||||
configurePhase =
|
||||
args.configurePhase or (
|
||||
''
|
||||
runHook preConfigure
|
||||
|
||||
export GOCACHE=$TMPDIR/go-cache
|
||||
|
@ -194,14 +239,21 @@ lib.extendMkDerivation {
|
|||
export GOPROXY=off
|
||||
export GOSUMDB=off
|
||||
cd "$modRoot"
|
||||
'' + lib.optionalString (finalAttrs.vendorHash != null) ''
|
||||
${if finalAttrs.proxyVendor then ''
|
||||
''
|
||||
+ lib.optionalString (finalAttrs.vendorHash != null) ''
|
||||
${
|
||||
if finalAttrs.proxyVendor then
|
||||
''
|
||||
export GOPROXY="file://$goModules"
|
||||
'' else ''
|
||||
''
|
||||
else
|
||||
''
|
||||
rm -rf vendor
|
||||
cp -r --reflink=auto "$goModules" vendor
|
||||
''}
|
||||
'' + ''
|
||||
''
|
||||
}
|
||||
''
|
||||
+ ''
|
||||
|
||||
# currently pie is only enabled by default in pkgsMusl
|
||||
# this will respect the `hardening{Disable,Enable}` flags if set
|
||||
|
@ -210,9 +262,11 @@ lib.extendMkDerivation {
|
|||
fi
|
||||
|
||||
runHook postConfigure
|
||||
'');
|
||||
''
|
||||
);
|
||||
|
||||
buildPhase = args.buildPhase or (
|
||||
buildPhase =
|
||||
args.buildPhase or (
|
||||
lib.warnIf (builtins.elem "-buildid=" ldflags)
|
||||
"`-buildid=` is set by default as ldflag by buildGoModule"
|
||||
''
|
||||
|
@ -273,7 +327,8 @@ lib.extendMkDerivation {
|
|||
echo "Building subPackage $pkg"
|
||||
buildGoDir install "$pkg"
|
||||
done
|
||||
'' + lib.optionalString (stdenv.hostPlatform != stdenv.buildPlatform) ''
|
||||
''
|
||||
+ lib.optionalString (stdenv.hostPlatform != stdenv.buildPlatform) ''
|
||||
# normalize cross-compiled builds w.r.t. native builds
|
||||
(
|
||||
dir=$GOPATH/bin/''${GOOS}_''${GOARCH}
|
||||
|
@ -284,12 +339,15 @@ lib.extendMkDerivation {
|
|||
rmdir $dir
|
||||
fi
|
||||
)
|
||||
'' + ''
|
||||
''
|
||||
+ ''
|
||||
runHook postBuild
|
||||
'');
|
||||
''
|
||||
);
|
||||
|
||||
doCheck = args.doCheck or true;
|
||||
checkPhase = args.checkPhase or ''
|
||||
checkPhase =
|
||||
args.checkPhase or ''
|
||||
runHook preCheck
|
||||
# We do not set trimpath for tests, in case they reference test assets
|
||||
export GOFLAGS=''${GOFLAGS//-trimpath/}
|
||||
|
@ -301,7 +359,8 @@ lib.extendMkDerivation {
|
|||
runHook postCheck
|
||||
'';
|
||||
|
||||
installPhase = args.installPhase or ''
|
||||
installPhase =
|
||||
args.installPhase or ''
|
||||
runHook preInstall
|
||||
|
||||
mkdir -p $out
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue