chore(nix/buildGo): add support for Go 1.20+
https://github.com/golang/go/issues/51225 and other changes mean that importcfgs are now basically required for Go 1.20+; we also separately compile the Go stdlib, since it looks like pkgs.go no longer actually has the compiled version of the stdlib shipped, just the source. Change-Id: Ibf5ee7d43f7800c6dd1e0dec6c7a6d35ef50b7b0 Reviewed-on: https://cl.tvl.fyi/c/depot/+/10801 Reviewed-by: tazjin <tazjin@tvl.su> Tested-by: BuildkiteCI
This commit is contained in:
parent
ca06731e64
commit
0c6813ccf8
1 changed files with 42 additions and 7 deletions
|
@ -22,10 +22,8 @@ let
|
||||||
replaceStrings
|
replaceStrings
|
||||||
toString;
|
toString;
|
||||||
|
|
||||||
inherit (pkgs) lib runCommand fetchFromGitHub protobuf symlinkJoin;
|
inherit (pkgs) lib runCommand fetchFromGitHub protobuf symlinkJoin go;
|
||||||
|
goStdlib = buildStdlib go;
|
||||||
# TODO: Adapt to Go 1.20 changes
|
|
||||||
go = pkgs.go_1_19;
|
|
||||||
|
|
||||||
# Helpers for low-level Go compiler invocations
|
# Helpers for low-level Go compiler invocations
|
||||||
spaceOut = lib.concatStringsSep " ";
|
spaceOut = lib.concatStringsSep " ";
|
||||||
|
@ -53,16 +51,52 @@ let
|
||||||
overrideGo = new: makeOverridable f (orig // (new orig));
|
overrideGo = new: makeOverridable f (orig // (new orig));
|
||||||
};
|
};
|
||||||
|
|
||||||
|
buildStdlib = go: runCommand "go-stdlib-${go.version}"
|
||||||
|
{
|
||||||
|
nativeBuildInputs = [ go ];
|
||||||
|
} ''
|
||||||
|
HOME=$NIX_BUILD_TOP/home
|
||||||
|
mkdir $HOME
|
||||||
|
|
||||||
|
goroot="$(go env GOROOT)"
|
||||||
|
cp -R "$goroot/src" "$goroot/pkg" .
|
||||||
|
|
||||||
|
chmod -R +w .
|
||||||
|
GODEBUG=installgoroot=all GOROOT=$NIX_BUILD_TOP go install -v --trimpath std
|
||||||
|
|
||||||
|
mkdir $out
|
||||||
|
cp -r pkg/*_*/* $out
|
||||||
|
|
||||||
|
find $out -name '*.a' | while read -r ARCHIVE_FULL; do
|
||||||
|
ARCHIVE="''${ARCHIVE_FULL#"$out/"}"
|
||||||
|
PACKAGE="''${ARCHIVE%.a}"
|
||||||
|
echo "packagefile $PACKAGE=$ARCHIVE_FULL"
|
||||||
|
done > $out/importcfg
|
||||||
|
'';
|
||||||
|
|
||||||
|
importcfgCmd = { name, deps, out ? "importcfg" }: ''
|
||||||
|
echo "# nix buildGo ${name}" > "${out}"
|
||||||
|
cat "${goStdlib}/importcfg" >> "${out}"
|
||||||
|
${lib.concatStringsSep "\n" (map (dep: ''
|
||||||
|
find "${dep}" -name '*.a' | while read -r pkgp; do
|
||||||
|
relpath="''${pkgp#"${dep}/"}"
|
||||||
|
pkgname="''${relpath%.a}"
|
||||||
|
echo "packagefile $pkgname=$pkgp"
|
||||||
|
done >> "${out}"
|
||||||
|
'') deps)}
|
||||||
|
'';
|
||||||
|
|
||||||
# High-level build functions
|
# High-level build functions
|
||||||
|
|
||||||
# Build a Go program out of the specified files and dependencies.
|
# Build a Go program out of the specified files and dependencies.
|
||||||
program = { name, srcs, deps ? [ ], x_defs ? { } }:
|
program = { name, srcs, deps ? [ ], x_defs ? { } }:
|
||||||
let uniqueDeps = allDeps (map (d: d.gopkg) deps);
|
let uniqueDeps = allDeps (map (d: d.gopkg) deps);
|
||||||
in runCommand name { } ''
|
in runCommand name { } ''
|
||||||
${go}/bin/go tool compile -o ${name}.a -trimpath=$PWD -trimpath=${go} -p main ${includeSources uniqueDeps} ${spaceOut srcs}
|
${importcfgCmd { inherit name; deps = uniqueDeps; }}
|
||||||
|
${go}/bin/go tool compile -o ${name}.a -importcfg=importcfg -trimpath=$PWD -trimpath=${go} -p main ${includeSources uniqueDeps} ${spaceOut srcs}
|
||||||
mkdir -p $out/bin
|
mkdir -p $out/bin
|
||||||
export GOROOT_FINAL=go
|
export GOROOT_FINAL=go
|
||||||
${go}/bin/go tool link -o $out/bin/${name} -buildid nix ${xFlags x_defs} ${includeLibs uniqueDeps} ${name}.a
|
${go}/bin/go tool link -o $out/bin/${name} -importcfg=importcfg -buildid nix ${xFlags x_defs} ${includeLibs uniqueDeps} ${name}.a
|
||||||
'';
|
'';
|
||||||
|
|
||||||
# Build a Go library assembled out of the specified files.
|
# Build a Go library assembled out of the specified files.
|
||||||
|
@ -91,7 +125,8 @@ let
|
||||||
mkdir -p $out/${path}
|
mkdir -p $out/${path}
|
||||||
${srcList path (map (s: "${s}") srcs)}
|
${srcList path (map (s: "${s}") srcs)}
|
||||||
${asmBuild}
|
${asmBuild}
|
||||||
${go}/bin/go tool compile -pack ${asmLink} -o $out/${path}.a -trimpath=$PWD -trimpath=${go} -p ${path} ${includeSources uniqueDeps} ${spaceOut srcs}
|
${importcfgCmd { inherit name; deps = uniqueDeps; }}
|
||||||
|
${go}/bin/go tool compile -pack ${asmLink} -o $out/${path}.a -importcfg=importcfg -trimpath=$PWD -trimpath=${go} -p ${path} ${includeSources uniqueDeps} ${spaceOut srcs}
|
||||||
${asmPack}
|
${asmPack}
|
||||||
'').overrideAttrs (_: {
|
'').overrideAttrs (_: {
|
||||||
passthru = {
|
passthru = {
|
||||||
|
|
Loading…
Reference in a new issue