nixpkgs/pkgs/development/compilers/go/1.19.nix

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

178 lines
4.8 KiB
Nix
Raw Normal View History

2022-08-02 08:05:24 +00:00
{ lib
, stdenv
, fetchurl
, tzdata
2022-08-08 00:50:52 +00:00
, substituteAll
2022-08-02 08:05:24 +00:00
, iana-etc
, which
, pkg-config
, procps
, pcre
, cacert
, Security
, Foundation
, xcbuild
, mailcap
, buildPackages
, pkgsBuildTarget
2022-08-04 03:40:29 +00:00
, threadsCross
2022-08-02 08:05:24 +00:00
}:
let
goBootstrap = buildPackages.callPackage ./bootstrap116.nix { };
2022-08-02 08:05:24 +00:00
goarch = platform: {
"aarch64" = "arm64";
"arm" = "arm";
"armv5tel" = "arm";
"armv6l" = "arm";
"armv7l" = "arm";
2022-08-04 03:40:29 +00:00
"i686" = "386";
2022-08-02 08:05:24 +00:00
"mips" = "mips";
2022-08-04 03:40:29 +00:00
"mips64el" = "mips64le";
2022-08-02 08:05:24 +00:00
"mipsel" = "mipsle";
2022-08-04 03:40:29 +00:00
"powerpc64le" = "ppc64le";
2022-08-02 08:05:24 +00:00
"riscv64" = "riscv64";
"s390x" = "s390x";
2022-08-04 03:40:29 +00:00
"x86_64" = "amd64";
2022-08-02 08:05:24 +00:00
}.${platform.parsed.cpu.name} or (throw "Unsupported system: ${platform.parsed.cpu.name}");
# We need a target compiler which is still runnable at build time,
# to handle the cross-building case where build != host == target
targetCC = pkgsBuildTarget.targetPackages.stdenv.cc;
isCross = stdenv.buildPlatform != stdenv.targetPlatform;
in
stdenv.mkDerivation rec {
pname = "go";
version = "1.19";
src = fetchurl {
url = "https://go.dev/dl/go${version}.src.tar.gz";
sha256 = "sha256-lBnMcNxaJSPymncFPK//ZY7SHvNWHZtrAgKA686rKLk=";
};
strictDeps = true;
nativeBuildInputs = [ which pkg-config procps ];
2022-08-02 08:05:24 +00:00
buildInputs = [ cacert pcre ]
++ lib.optionals stdenv.isLinux [ stdenv.cc.libc.out ]
++ lib.optionals (stdenv.hostPlatform.libc == "glibc") [ stdenv.cc.libc.static ];
depsTargetTargetPropagated = lib.optionals stdenv.isDarwin [ Foundation Security xcbuild ];
2022-08-02 08:05:24 +00:00
depsBuildTarget = lib.optional isCross targetCC;
2022-08-04 03:40:29 +00:00
depsTargetTarget = lib.optional stdenv.targetPlatform.isWindows threadsCross;
2022-08-02 08:05:24 +00:00
postPatch = ''
2022-08-08 00:50:52 +00:00
patchShebangs .
'';
2022-08-02 08:05:24 +00:00
2022-08-08 00:50:52 +00:00
patches = [
(substituteAll {
src = ./iana-etc-1.17.patch;
iana = iana-etc;
})
2022-08-02 08:05:24 +00:00
# Patch the mimetype database location which is missing on NixOS.
# but also allow static binaries built with NixOS to run outside nix
2022-08-08 00:50:52 +00:00
(substituteAll {
src = ./mailcap-1.17.patch;
inherit mailcap;
})
2022-08-02 08:05:24 +00:00
# prepend the nix path to the zoneinfo files but also leave the original value for static binaries
# that run outside a nix server
2022-08-08 00:50:52 +00:00
(substituteAll {
src = ./tzdata-1.19.patch;
inherit tzdata;
})
2022-08-02 08:05:24 +00:00
./remove-tools-1.11.patch
./go_no_vendor_checks-1.16.patch
];
GOOS = stdenv.targetPlatform.parsed.kernel.name;
GOARCH = goarch stdenv.targetPlatform;
# GOHOSTOS/GOHOSTARCH must match the building system, not the host system.
# Go will nevertheless build a for host system that we will copy over in
# the install phase.
GOHOSTOS = stdenv.buildPlatform.parsed.kernel.name;
GOHOSTARCH = goarch stdenv.buildPlatform;
# {CC,CXX}_FOR_TARGET must be only set for cross compilation case as go expect those
# to be different from CC/CXX
CC_FOR_TARGET =
if isCross then
"${targetCC}/bin/${targetCC.targetPrefix}cc"
else
null;
CXX_FOR_TARGET =
if isCross then
"${targetCC}/bin/${targetCC.targetPrefix}c++"
else
null;
GOARM = toString (lib.intersectLists [ (stdenv.hostPlatform.parsed.cpu.version or "") ] [ "5" "6" "7" ]);
GO386 = "softfloat"; # from Arch: don't assume sse2 on i686
CGO_ENABLED = 1;
GOROOT_BOOTSTRAP = "${goBootstrap}/share/go";
postConfigure = ''
export GOCACHE=$TMPDIR/go-cache
# this is compiled into the binary
export GOROOT_FINAL=$out/share/go
export PATH=$(pwd)/bin:$PATH
${lib.optionalString isCross ''
# Independent from host/target, CC should produce code for the building system.
# We only set it when cross-compiling.
export CC=${buildPackages.stdenv.cc}/bin/cc
''}
ulimit -a
'';
postBuild = ''
(cd src && ./make.bash)
'';
preInstall = ''
rm -r pkg/obj
# Contains the wrong perl shebang when cross compiling,
# since it is not used for anything we can deleted as well.
rm src/regexp/syntax/make_perl_groups.pl
'' + (if (stdenv.buildPlatform != stdenv.hostPlatform) then ''
mv bin/*_*/* bin
rmdir bin/*_*
${lib.optionalString (!(GOHOSTARCH == GOARCH && GOOS == GOHOSTOS)) ''
rm -rf pkg/${GOHOSTOS}_${GOHOSTARCH} pkg/tool/${GOHOSTOS}_${GOHOSTARCH}
''}
'' else if (stdenv.hostPlatform != stdenv.targetPlatform) then ''
rm -rf bin/*_*
${lib.optionalString (!(GOHOSTARCH == GOARCH && GOOS == GOHOSTOS)) ''
rm -rf pkg/${GOOS}_${GOARCH} pkg/tool/${GOOS}_${GOARCH}
''}
'' else "");
installPhase = ''
runHook preInstall
mkdir -p $GOROOT_FINAL
cp -a bin pkg src lib misc api doc $GOROOT_FINAL
ln -s $GOROOT_FINAL/bin $out/bin
runHook postInstall
'';
disallowedReferences = [ goBootstrap ];
passthru = {
inherit goBootstrap;
};
2022-08-02 08:05:24 +00:00
meta = with lib; {
description = "The Go Programming language";
2022-08-04 03:40:29 +00:00
homepage = "https://go.dev/";
2022-08-02 08:05:24 +00:00
license = licenses.bsd3;
maintainers = teams.golang.members;
2022-08-04 03:40:29 +00:00
platforms = platforms.darwin ++ platforms.linux;
2022-08-02 08:05:24 +00:00
};
}