mirror of
https://github.com/NixOS/nixpkgs.git
synced 2024-11-27 09:23:01 +00:00
Merge pull request #190105 from impl/free-p4
p4: 2021.2.2201121 -> 2022.1.2305383, build from source and remove unfree binaries
This commit is contained in:
commit
77c986e784
@ -488,6 +488,16 @@
|
|||||||
instead.
|
instead.
|
||||||
</para>
|
</para>
|
||||||
</listitem>
|
</listitem>
|
||||||
|
<listitem>
|
||||||
|
<para>
|
||||||
|
The <literal>p4</literal> 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
|
||||||
|
<literal>p4d</literal>, <literal>p4broker</literal>, and
|
||||||
|
<literal>p4p</literal>. To install the Helix Core Server
|
||||||
|
binaries, use the <literal>p4d</literal> package instead.
|
||||||
|
</para>
|
||||||
|
</listitem>
|
||||||
<listitem>
|
<listitem>
|
||||||
<para>
|
<para>
|
||||||
The <literal>coq</literal> package and versioned variants
|
The <literal>coq</literal> package and versioned variants
|
||||||
|
@ -162,6 +162,8 @@ Available as [services.patroni](options.html#opt-services.patroni.enable).
|
|||||||
- `services.hbase` has been renamed to `services.hbase-standalone`.
|
- `services.hbase` has been renamed to `services.hbase-standalone`.
|
||||||
For production HBase clusters, use `services.hadoop.hbase` instead.
|
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
|
- The `coq` package and versioned variants starting at `coq_8_14` no
|
||||||
longer include CoqIDE, which is now available through
|
longer include CoqIDE, which is now available through
|
||||||
`coqPackages.coqide`. It is still possible to get CoqIDE as part of
|
`coqPackages.coqide`. It is still possible to get CoqIDE as part of
|
||||||
|
@ -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 {
|
stdenv.mkDerivation rec {
|
||||||
pname = "p4";
|
pname = "p4";
|
||||||
version = "2021.2.2201121";
|
version = "2022.1.2305383";
|
||||||
|
|
||||||
src = fetchurl {
|
src = fetchurl {
|
||||||
# actually https://cdist2.perforce.com/perforce/r21.2/bin.linux26x86_64/helix-core-server.tgz but upstream deletes releases
|
# Upstream replaces minor versions, so use archived URL.
|
||||||
url = "https://web.archive.org/web/20211118024943/https://cdist2.perforce.com/perforce/r21.2/bin.linux26x86_64/helix-core-server.tgz";
|
url = "https://web.archive.org/web/20220901184735id_/https://ftp.perforce.com/perforce/r22.1/bin.tools/p4source.tgz";
|
||||||
sha256 = "sha256-SrfI2ZD7KDyttCd8+fo8g4UZKljYYO/SbzqrS9tAcC8=";
|
sha256 = "27ab3ddd7b178b05cf0b710e941650dac0688d294110ebafda9027732c0944c6";
|
||||||
};
|
};
|
||||||
|
|
||||||
sourceRoot = ".";
|
nativeBuildInputs = [ jam ];
|
||||||
|
|
||||||
dontBuild = true;
|
buildInputs = lib.optionals stdenv.isDarwin [ CoreServices Foundation Security ];
|
||||||
|
|
||||||
nativeBuildInputs = [ autoPatchelfHook ];
|
outputs = [ "out" "bin" "dev" ];
|
||||||
|
|
||||||
installPhase = ''
|
hardeningDisable = lib.optionals stdenv.isDarwin [ "strictoverflow" ];
|
||||||
install -D --target $out/bin p4 p4broker p4d p4p
|
|
||||||
|
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 = {
|
installPhase = ''
|
||||||
description = "Perforce Command-Line Client";
|
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";
|
homepage = "https://www.perforce.com";
|
||||||
sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ];
|
license = licenses.bsd2;
|
||||||
license = lib.licenses.unfree;
|
mainProgram = "p4";
|
||||||
platforms = [ "x86_64-linux" ];
|
platforms = platforms.unix;
|
||||||
maintainers = with lib.maintainers; [ corngood ];
|
maintainers = with maintainers; [ corngood impl ];
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -47,6 +47,6 @@ stdenv.mkDerivation {
|
|||||||
license = licenses.unfree;
|
license = licenses.unfree;
|
||||||
mainProgram = "p4d";
|
mainProgram = "p4d";
|
||||||
platforms = builtins.attrNames srcs;
|
platforms = builtins.attrNames srcs;
|
||||||
maintainers = with maintainers; [ impl ];
|
maintainers = with maintainers; [ corngood impl ];
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -30282,7 +30282,10 @@ with pkgs;
|
|||||||
|
|
||||||
ostinato = libsForQt5.callPackage ../applications/networking/ostinato { };
|
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 { };
|
p4d = callPackage ../applications/version-management/p4d { };
|
||||||
p4v = libsForQt515.callPackage ../applications/version-management/p4v { };
|
p4v = libsForQt515.callPackage ../applications/version-management/p4v { };
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user