summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorzowoq <59103226+zowoq@users.noreply.github.com>2024-06-23 16:35:50 +1000
committerzowoq <59103226+zowoq@users.noreply.github.com>2024-06-26 17:35:45 +1000
commit2dbd8d8258ac09714f974ef6f7fd665a0e1775b7 (patch)
tree648d82d100257cdc9481202b241fd9a3a5e7b6f4
parent4d88ae7b6189d9b81df24d5452a8bdc3f1cc22e0 (diff)
go_1_23: init at 1.23rc1
-rw-r--r--pkgs/development/compilers/go/1.23.nix190
-rw-r--r--pkgs/top-level/all-packages.nix11
2 files changed, 201 insertions, 0 deletions
diff --git a/pkgs/development/compilers/go/1.23.nix b/pkgs/development/compilers/go/1.23.nix
new file mode 100644
index 000000000000..5660710f049f
--- /dev/null
+++ b/pkgs/development/compilers/go/1.23.nix
@@ -0,0 +1,190 @@
+{ lib
+, stdenv
+, fetchurl
+, tzdata
+, substituteAll
+, iana-etc
+, Security
+, Foundation
+, xcbuild
+, mailcap
+, buildPackages
+, pkgsBuildTarget
+, threadsCross
+, testers
+, skopeo
+, buildGo123Module
+}:
+
+let
+ useGccGoBootstrap = stdenv.buildPlatform.isMusl;
+ goBootstrap = if useGccGoBootstrap then buildPackages.gccgo12 else buildPackages.callPackage ./bootstrap121.nix { };
+
+ skopeoTest = skopeo.override { buildGoModule = buildGo123Module; };
+
+ goarch = platform: {
+ "aarch64" = "arm64";
+ "arm" = "arm";
+ "armv5tel" = "arm";
+ "armv6l" = "arm";
+ "armv7l" = "arm";
+ "i686" = "386";
+ "mips" = "mips";
+ "mips64el" = "mips64le";
+ "mipsel" = "mipsle";
+ "powerpc64" = "ppc64";
+ "powerpc64le" = "ppc64le";
+ "riscv64" = "riscv64";
+ "s390x" = "s390x";
+ "x86_64" = "amd64";
+ "wasm32" = "wasm";
+ }.${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.23rc1";
+
+ src = fetchurl {
+ url = "https://go.dev/dl/go${finalAttrs.version}.src.tar.gz";
+ hash = "sha256-bpxHZYcoCGY8zwuTflY3x99nFGlD+m6JCagaDRKcgEU=";
+ };
+
+ 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 = if stdenv.targetPlatform.isWasi then "wasip1" else 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
+ # Wasi does not support CGO
+ CGO_ENABLED = if stdenv.targetPlatform.isWasi then 0 else 1;
+
+ GOROOT_BOOTSTRAP = if useGccGoBootstrap then goBootstrap else "${goBootstrap}/share/go";
+
+ buildPhase = ''
+ runHook preBuild
+ export GOCACHE=$TMPDIR/go-cache
+
+ 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 $out/share/go
+ cp -a bin pkg src lib misc api doc go.env $out/share/go
+ mkdir -p $out/bin
+ ln -s $out/share/go/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 = "Go Programming language";
+ homepage = "https://go.dev/";
+ license = licenses.bsd3;
+ maintainers = teams.golang.members;
+ platforms = platforms.darwin ++ platforms.linux ++ platforms.wasi;
+ mainProgram = "go";
+ };
+})
diff --git a/pkgs/top-level/all-packages.nix b/pkgs/top-level/all-packages.nix
index 5c30c8d34d70..ea28726c914e 100644
--- a/pkgs/top-level/all-packages.nix
+++ b/pkgs/top-level/all-packages.nix
@@ -25058,6 +25058,17 @@ with pkgs;
go = buildPackages.go_1_22;
};
+ # requires a newer Apple SDK
+ go_1_23 = darwin.apple_sdk_11_0.callPackage ../development/compilers/go/1.23.nix {
+ inherit (darwin.apple_sdk_11_0.frameworks) Foundation Security;
+ };
+ buildGo123Module = darwin.apple_sdk_11_0.callPackage ../build-support/go/module.nix {
+ go = buildPackages.go_1_23;
+ };
+ buildGo123Package = darwin.apple_sdk_11_0.callPackage ../build-support/go/package.nix {
+ go = buildPackages.go_1_23;
+ };
+
leaps = callPackage ../development/tools/leaps { };
### DEVELOPMENT / HARE