diff --git a/nixos/doc/manual/from_md/release-notes/rl-2211.section.xml b/nixos/doc/manual/from_md/release-notes/rl-2211.section.xml
index 9e5d4bfd20d9..bdd55a59370b 100644
--- a/nixos/doc/manual/from_md/release-notes/rl-2211.section.xml
+++ b/nixos/doc/manual/from_md/release-notes/rl-2211.section.xml
@@ -488,6 +488,16 @@
instead.
+
+
+ The p4 package now only includes the
+ open-source Perforce Helix Core command-line client and APIs.
+ It no longer installs the unfree Helix Core Server binaries
+ p4d, p4broker, and
+ p4p. To install the Helix Core Server
+ binaries, use the p4d package instead.
+
+
The coq package and versioned variants
diff --git a/nixos/doc/manual/release-notes/rl-2211.section.md b/nixos/doc/manual/release-notes/rl-2211.section.md
index 47f3da3a435a..69e0cbd2ad51 100644
--- a/nixos/doc/manual/release-notes/rl-2211.section.md
+++ b/nixos/doc/manual/release-notes/rl-2211.section.md
@@ -162,6 +162,8 @@ Available as [services.patroni](options.html#opt-services.patroni.enable).
- `services.hbase` has been renamed to `services.hbase-standalone`.
For production HBase clusters, use `services.hadoop.hbase` instead.
+- The `p4` package now only includes the open-source Perforce Helix Core command-line client and APIs. It no longer installs the unfree Helix Core Server binaries `p4d`, `p4broker`, and `p4p`. To install the Helix Core Server binaries, use the `p4d` package instead.
+
- The `coq` package and versioned variants starting at `coq_8_14` no
longer include CoqIDE, which is now available through
`coqPackages.coqide`. It is still possible to get CoqIDE as part of
diff --git a/pkgs/applications/version-management/p4/default.nix b/pkgs/applications/version-management/p4/default.nix
index 4f61be6669aa..8a54d4eb77bf 100644
--- a/pkgs/applications/version-management/p4/default.nix
+++ b/pkgs/applications/version-management/p4/default.nix
@@ -1,31 +1,115 @@
-{ stdenv, fetchurl, lib, autoPatchelfHook }:
+{ stdenv
+, fetchurl
+, fetchzip
+, lib
+, emptyDirectory
+, linkFarm
+, symlinkJoin
+, jam
+, libcxx
+, libcxxabi
+, openssl
+, xcbuild
+, CoreServices
+, Foundation
+, Security
+}:
+let
+ opensslStatic = openssl.override {
+ static = true;
+ };
+ androidZlibContrib =
+ let
+ src = fetchzip {
+ url = "https://android.googlesource.com/platform/external/zlib/+archive/61174f4fd262c6075f88768465f308aae95a2f04.tar.gz";
+ sha256 = "sha256-EMzKAHcEWOUugcHKH2Fj3ZaIHC9UlgO4ULKe3RvgxvI=";
+ stripRoot = false;
+ };
+ in
+ linkFarm "android-zlib-contrib" [
+ # We only want to keep the contrib directory as the other files conflict
+ # with p4's own zlib files. (For the same reason, we can't use the
+ # cone-based Git sparse checkout, either.)
+ { name = "contrib"; path = "${src}/contrib"; }
+ ];
+ libcxxUnified = symlinkJoin {
+ inherit (libcxx) name;
+ paths = [ libcxx libcxxabi ];
+ };
+in
stdenv.mkDerivation rec {
pname = "p4";
- version = "2021.2.2201121";
+ version = "2022.1.2305383";
src = fetchurl {
- # actually https://cdist2.perforce.com/perforce/r21.2/bin.linux26x86_64/helix-core-server.tgz but upstream deletes releases
- url = "https://web.archive.org/web/20211118024943/https://cdist2.perforce.com/perforce/r21.2/bin.linux26x86_64/helix-core-server.tgz";
- sha256 = "sha256-SrfI2ZD7KDyttCd8+fo8g4UZKljYYO/SbzqrS9tAcC8=";
+ # Upstream replaces minor versions, so use archived URL.
+ url = "https://web.archive.org/web/20220901184735id_/https://ftp.perforce.com/perforce/r22.1/bin.tools/p4source.tgz";
+ sha256 = "27ab3ddd7b178b05cf0b710e941650dac0688d294110ebafda9027732c0944c6";
};
- sourceRoot = ".";
+ nativeBuildInputs = [ jam ];
- dontBuild = true;
+ buildInputs = lib.optionals stdenv.isDarwin [ CoreServices Foundation Security ];
- nativeBuildInputs = [ autoPatchelfHook ];
+ outputs = [ "out" "bin" "dev" ];
- installPhase = ''
- install -D --target $out/bin p4 p4broker p4d p4p
+ hardeningDisable = lib.optionals stdenv.isDarwin [ "strictoverflow" ];
+
+ jamFlags =
+ [
+ "-sEXEC=bin.unix"
+ "-sCROSS_COMPILE=${stdenv.cc.targetPrefix}"
+ "-sMALLOC_OVERRIDE=no"
+ "-sSSLINCDIR=${lib.getDev opensslStatic}/include"
+ "-sSSLLIBDIR=${lib.getLib opensslStatic}/lib"
+ ]
+ ++ lib.optionals stdenv.cc.isClang [ "-sOSCOMP=clang" "-sCLANGVER=${stdenv.cc.cc.version}" ]
+ ++ lib.optionals stdenv.cc.isGNU [ "-sOSCOMP=gcc" "-sGCCVER=${stdenv.cc.cc.version}" ]
+ ++ lib.optionals stdenv.isLinux [ "-sOSVER=26" ]
+ ++ lib.optionals stdenv.isDarwin [
+ "-sOSVER=1013"
+ "-sMACOSX_SDK=${emptyDirectory}"
+ "-sLIBC++DIR=${libcxxUnified}/lib"
+ ];
+
+ CCFLAGS =
+ # The file contrib/optimizations/slide_hash_neon.h is missing from the
+ # upstream distribution. It comes from the Android/Chromium sources.
+ lib.optionals stdenv.isAarch64 [ "-I${androidZlibContrib}" ];
+
+ "C++FLAGS" =
+ # Avoid a compilation error that only occurs for 4-byte longs.
+ lib.optionals stdenv.isi686 [ "-Wno-narrowing" ]
+ # See the "Header dependency changes" section of
+ # https://www.gnu.org/software/gcc/gcc-11/porting_to.html for more
+ # information on why we need to include these.
+ ++ lib.optionals
+ (stdenv.cc.isClang || (stdenv.cc.isGNU && lib.versionAtLeast stdenv.cc.cc.version "11.0.0"))
+ [ "-include" "limits" "-include" "thread" ];
+
+ buildPhase = ''
+ runHook preBuild
+ jam $jamFlags -j$NIX_BUILD_CORES p4
+ jam $jamFlags -j$NIX_BUILD_CORES -sPRODUCTION=yes p4api.tar
+ runHook postBuild
'';
- meta = {
- description = "Perforce Command-Line Client";
+ installPhase = ''
+ runHook preInstall
+ mkdir -p $bin/bin $dev $out
+ cp bin.unix/p4 $bin/bin
+ cp -r bin.unix/p4api-${version}/include $dev
+ cp -r bin.unix/p4api-${version}/lib $out
+ runHook postInstall
+ '';
+
+ meta = with lib; {
+ description = "Perforce Helix Core command-line client and APIs";
homepage = "https://www.perforce.com";
- sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ];
- license = lib.licenses.unfree;
- platforms = [ "x86_64-linux" ];
- maintainers = with lib.maintainers; [ corngood ];
+ license = licenses.bsd2;
+ mainProgram = "p4";
+ platforms = platforms.unix;
+ maintainers = with maintainers; [ corngood impl ];
};
}
diff --git a/pkgs/applications/version-management/p4d/default.nix b/pkgs/applications/version-management/p4d/default.nix
index 5b98131303d3..e2cf8e1013c3 100644
--- a/pkgs/applications/version-management/p4d/default.nix
+++ b/pkgs/applications/version-management/p4d/default.nix
@@ -47,6 +47,6 @@ stdenv.mkDerivation {
license = licenses.unfree;
mainProgram = "p4d";
platforms = builtins.attrNames srcs;
- maintainers = with maintainers; [ impl ];
+ maintainers = with maintainers; [ corngood impl ];
};
}
diff --git a/pkgs/top-level/all-packages.nix b/pkgs/top-level/all-packages.nix
index e3b79c211b9c..a63f783a98e0 100644
--- a/pkgs/top-level/all-packages.nix
+++ b/pkgs/top-level/all-packages.nix
@@ -30282,7 +30282,10 @@ with pkgs;
ostinato = libsForQt5.callPackage ../applications/networking/ostinato { };
- p4 = callPackage ../applications/version-management/p4 { };
+ p4 = callPackage ../applications/version-management/p4 {
+ inherit (darwin.apple_sdk.frameworks) CoreServices Foundation Security;
+ openssl = openssl_1_1;
+ };
p4d = callPackage ../applications/version-management/p4d { };
p4v = libsForQt515.callPackage ../applications/version-management/p4v { };