Merge pull request #119997 from DeterminateSystems/lief

lief: build from source and enable python bindings
This commit is contained in:
Sandro 2021-04-23 06:36:09 +02:00 committed by GitHub
commit 2ce1d7a408
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 67 additions and 5 deletions

View File

@ -1,8 +1,64 @@
{ lib, fetchzip }:
{ lib
, stdenv
, fetchFromGitHub
, python
, cmake
}:
fetchzip {
url = "https://github.com/lief-project/LIEF/releases/download/0.9.0/LIEF-0.9.0-Linux.tar.gz";
sha256 = "1c47hwd00bp4mqd4p5b6xjfl89c3wwk9ccyc3a2gk658250g2la6";
let
pyEnv = python.withPackages (ps: [ ps.setuptools ]);
in
stdenv.mkDerivation rec {
pname = "lief";
version = "0.11.4";
src = fetchFromGitHub {
owner = "lief-project";
repo = "LIEF";
rev = version;
sha256 = "DgsTrJ2+zdXJK6CdDOan7roakaaxQiwrVeiQnzJnk0A=";
};
outputs = [ "out" "py" ];
nativeBuildInputs = [
cmake
];
# Not a propagatedBuildInput because only the $py output needs it; $out is
# just the library itself (e.g. C/C++ headers).
buildInputs = [
python
];
dontUseCmakeConfigure = true;
buildPhase = ''
runHook preBuild
substituteInPlace setup.py \
--replace 'cmake_args = []' "cmake_args = [ \"-DCMAKE_INSTALL_PREFIX=$prefix\" ]"
${pyEnv.interpreter} setup.py --sdk build --parallel=$NIX_BUILD_CORES
runHook postBuild
'';
# I was unable to find a way to build the library itself and have it install
# to $out, while also installing the Python bindings to $py without building
# the project twice (using cmake), so this is the best we've got. It uses
# something called CPack to create the tarball, but it's not obvious to me
# *how* that happens, or how to intercept it to just get the structured
# library output.
installPhase = ''
runHook preInstall
mkdir -p $out $py/nix-support
echo "${python}" >> $py/nix-support/propagated-build-inputs
tar xf build/*.tar.gz --directory $out --strip-components 1
${pyEnv.interpreter} setup.py install --skip-build --root=/ --prefix=$py
runHook postInstall
'';
meta = with lib; {
description = "Library to Instrument Executable Formats";

View File

@ -2725,7 +2725,9 @@ in
lexicon = callPackage ../tools/admin/lexicon { };
lief = callPackage ../development/libraries/lief {};
lief = callPackage ../development/libraries/lief {
python = python3;
};
libnbd = callPackage ../development/libraries/libnbd { };

View File

@ -4020,6 +4020,10 @@ in {
license-expression = callPackage ../development/python-modules/license-expression { };
lief = (toPythonModule (pkgs.lief.override {
inherit python;
})).py;
lightblue = callPackage ../development/python-modules/lightblue { };
lightgbm = callPackage ../development/python-modules/lightgbm { };