-
-
Notifications
You must be signed in to change notification settings - Fork 14.8k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge #313691: tailscale: 1.58.2 -> 1.66.4
...into release-23.11
- Loading branch information
Showing
4 changed files
with
229 additions
and
4 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,189 @@ | ||
{ lib | ||
, stdenv | ||
, fetchurl | ||
, tzdata | ||
, substituteAll | ||
, iana-etc | ||
, Security | ||
, Foundation | ||
, xcbuild | ||
, mailcap | ||
, buildPackages | ||
, pkgsBuildTarget | ||
, threadsCross | ||
, testers | ||
, skopeo | ||
, buildGo122Module | ||
}: | ||
|
||
let | ||
useGccGoBootstrap = stdenv.buildPlatform.isMusl; | ||
goBootstrap = if useGccGoBootstrap then buildPackages.gccgo12 else buildPackages.callPackage ./bootstrap121.nix { }; | ||
|
||
skopeoTest = skopeo.override { buildGoModule = buildGo122Module; }; | ||
|
||
goarch = platform: { | ||
"aarch64" = "arm64"; | ||
"arm" = "arm"; | ||
"armv5tel" = "arm"; | ||
"armv6l" = "arm"; | ||
"armv7l" = "arm"; | ||
"i686" = "386"; | ||
"mips" = "mips"; | ||
"mips64el" = "mips64le"; | ||
"mipsel" = "mipsle"; | ||
"powerpc64le" = "ppc64le"; | ||
"riscv64" = "riscv64"; | ||
"s390x" = "s390x"; | ||
"x86_64" = "amd64"; | ||
}.${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 (finalAttrs: { | ||
pname = "go"; | ||
version = "1.22.3"; | ||
|
||
src = fetchurl { | ||
url = "https://go.dev/dl/go${finalAttrs.version}.src.tar.gz"; | ||
hash = "sha256-gGSO80+QMZPXKlnA3/AZ9fmK4MmqE63gsOy/+ZGnb2g="; | ||
}; | ||
|
||
strictDeps = true; | ||
buildInputs = [ ] | ||
++ lib.optionals stdenv.isLinux [ stdenv.cc.libc.out ] | ||
++ lib.optionals (stdenv.hostPlatform.libc == "glibc") [ stdenv.cc.libc.static ]; | ||
|
||
depsTargetTargetPropagated = lib.optionals stdenv.targetPlatform.isDarwin [ Foundation Security xcbuild ]; | ||
|
||
depsBuildTarget = lib.optional isCross targetCC; | ||
|
||
depsTargetTarget = lib.optional stdenv.targetPlatform.isWindows threadsCross.package; | ||
|
||
postPatch = '' | ||
patchShebangs . | ||
''; | ||
|
||
patches = [ | ||
(substituteAll { | ||
src = ./iana-etc-1.17.patch; | ||
iana = iana-etc; | ||
}) | ||
# Patch the mimetype database location which is missing on NixOS. | ||
# but also allow static binaries built with NixOS to run outside nix | ||
(substituteAll { | ||
src = ./mailcap-1.17.patch; | ||
inherit mailcap; | ||
}) | ||
# prepend the nix path to the zoneinfo files but also leave the original value for static binaries | ||
# that run outside a nix server | ||
(substituteAll { | ||
src = ./tzdata-1.19.patch; | ||
inherit tzdata; | ||
}) | ||
./remove-tools-1.11.patch | ||
./go_no_vendor_checks-1.22.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 = if useGccGoBootstrap then goBootstrap else "${goBootstrap}/share/go"; | ||
|
||
buildPhase = '' | ||
runHook preBuild | ||
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 | ||
pushd src | ||
./make.bash | ||
popd | ||
runHook postBuild | ||
''; | ||
|
||
preInstall = '' | ||
# 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.system != stdenv.hostPlatform.system) then '' | ||
mv bin/*_*/* bin | ||
rmdir bin/*_* | ||
${lib.optionalString (!(finalAttrs.GOHOSTARCH == finalAttrs.GOARCH && finalAttrs.GOOS == finalAttrs.GOHOSTOS)) '' | ||
rm -rf pkg/${finalAttrs.GOHOSTOS}_${finalAttrs.GOHOSTARCH} pkg/tool/${finalAttrs.GOHOSTOS}_${finalAttrs.GOHOSTARCH} | ||
''} | ||
'' else lib.optionalString (stdenv.hostPlatform.system != stdenv.targetPlatform.system) '' | ||
rm -rf bin/*_* | ||
${lib.optionalString (!(finalAttrs.GOHOSTARCH == finalAttrs.GOARCH && finalAttrs.GOOS == finalAttrs.GOHOSTOS)) '' | ||
rm -rf pkg/${finalAttrs.GOOS}_${finalAttrs.GOARCH} pkg/tool/${finalAttrs.GOOS}_${finalAttrs.GOARCH} | ||
''} | ||
''); | ||
|
||
installPhase = '' | ||
runHook preInstall | ||
mkdir -p $GOROOT_FINAL | ||
cp -a bin pkg src lib misc api doc go.env $GOROOT_FINAL | ||
mkdir -p $out/bin | ||
ln -s $GOROOT_FINAL/bin/* $out/bin | ||
runHook postInstall | ||
''; | ||
|
||
disallowedReferences = [ goBootstrap ]; | ||
|
||
passthru = { | ||
inherit goBootstrap skopeoTest; | ||
tests = { | ||
skopeo = testers.testVersion { package = skopeoTest; }; | ||
version = testers.testVersion { | ||
package = finalAttrs.finalPackage; | ||
command = "go version"; | ||
version = "go${finalAttrs.version}"; | ||
}; | ||
}; | ||
}; | ||
|
||
meta = with lib; { | ||
changelog = "https://go.dev/doc/devel/release#go${lib.versions.majorMinor finalAttrs.version}"; | ||
description = "The Go Programming language"; | ||
homepage = "https://go.dev/"; | ||
license = licenses.bsd3; | ||
maintainers = teams.golang.members; | ||
platforms = platforms.darwin ++ platforms.linux; | ||
mainProgram = "go"; | ||
}; | ||
}) |
23 changes: 23 additions & 0 deletions
23
pkgs/development/compilers/go/go_no_vendor_checks-1.22.patch
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
Starting from go1.14, go verifes that vendor/modules.txt matches the requirements | ||
and replacements listed in the main module go.mod file, and it is a hard failure if | ||
vendor/modules.txt is missing. | ||
|
||
Relax module consistency checks and switch back to pre go1.14 behaviour if | ||
vendor/modules.txt is missing regardless of go version requirement in go.mod. | ||
|
||
This has been ported from FreeBSD: https://reviews.freebsd.org/D24122 | ||
See https://github.com/golang/go/issues/37948 for discussion. | ||
|
||
diff --git a/src/cmd/go/internal/modload/vendor.go b/src/cmd/go/internal/modload/vendor.go | ||
index b2cb44100e..05bf3829d5 100644 | ||
--- a/src/cmd/go/internal/modload/vendor.go | ||
+++ b/src/cmd/go/internal/modload/vendor.go | ||
@@ -159,7 +159,7 @@ func checkVendorConsistency(indexes []*modFileIndex, modFiles []*modfile.File, m | ||
panic(fmt.Errorf("not in workspace mode but number of indexes is %v, not 1", len(indexes))) | ||
} | ||
index := indexes[0] | ||
- if gover.Compare(index.goVersion, "1.14") < 0 { | ||
+ if gover.Compare(index.goVersion, "1.14") < 0 || (os.Getenv("GO_NO_VENDOR_CHECKS") == "1" && len(vendorMeta) == 0) { | ||
// Go versions before 1.14 did not include enough information in | ||
// vendor/modules.txt to check for consistency. | ||
// If we know that we're on an earlier version, relax the consistency check. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters