Skip to content

Commit

Permalink
chore(deps): adapt nix derivation for lief.
Browse files Browse the repository at this point in the history
Adapted CXX flags so warnings are no longer displayed when building with
clang++ on OSX. The nixpkgs derivation[0] for lief made use of
"/build/source" symlink, which is not available on Darwin.

build commands are taken from LIEF build scripts [1]

[0]: https://github.com/NixOS/nixpkgs/blob/8efd5d1e283604f75a808a20e6cde0ef313d07d4/pkgs/development/libraries/lief/default.nix#L37
[1]: https://github.com/lief-project/LIEF/tree/master/scripts
  • Loading branch information
qkaiser committed Oct 25, 2023
1 parent d23de21 commit 0122eea
Show file tree
Hide file tree
Showing 4 changed files with 92 additions and 9 deletions.
20 changes: 20 additions & 0 deletions nix/_sources/generated.json
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,26 @@
},
"version": "0.4.5"
},
"lief": {
"cargoLocks": null,
"date": null,
"extract": null,
"name": "lief",
"passthru": null,
"pinned": false,
"src": {
"deepClone": false,
"fetchSubmodules": false,
"leaveDotGit": false,
"name": null,
"owner": "lief-project",
"repo": "LIEF",
"rev": "0.13.2",
"sha256": "sha256-lH4SqwPB2Jp/wUI2Cll67PQbHbwMqpNuLy/ei8roiHg=",
"type": "github"
},
"version": "0.13.2"
},
"lzallright": {
"cargoLocks": {
"Cargo.lock": [
Expand Down
11 changes: 11 additions & 0 deletions nix/_sources/generated.nix
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,17 @@
sha256 = "sha256-+cPOzzO3bCQAu8LrbjUJ5S/SR5OFitOYLIu5L9t/q+k=";
};
};
lief = {
pname = "lief";
version = "0.13.2";
src = fetchFromGitHub {
owner = "lief-project";
repo = "LIEF";
rev = "0.13.2";
fetchSubmodules = false;
sha256 = "sha256-lH4SqwPB2Jp/wUI2Cll67PQbHbwMqpNuLy/ei8roiHg=";
};
};
lzallright = {
pname = "lzallright";
version = "v0.2.3";
Expand Down
4 changes: 4 additions & 0 deletions nvfetcher.toml
Original file line number Diff line number Diff line change
Expand Up @@ -18,3 +18,7 @@ fetch.pypi = "treelib"
[pyfatfs]
src.pypi = "pyfatfs"
fetch.pypi = "pyfatfs"

[lief]
src.github_tag = "lief-project/LIEF"
fetch.github = "lief-project/LIEF"
66 changes: 57 additions & 9 deletions overlay.nix
Original file line number Diff line number Diff line change
Expand Up @@ -11,18 +11,66 @@ inputs: final: prev:
hardeningDisable = (super.hardeningDisable or [ ]) ++ [ "fortify3" ];
});

# Lief 12.3 incompatibility with Cmake 3.26
# Own package updated independently of nixpkgs
jefferson = final.callPackage ./nix/jefferson { };

lief = prev.lief.overrideAttrs (super: {
postPatch = ''
substituteInPlace setup.py \
--replace \
'cmake_args = ["-DLIEF_FORCE_API_EXPORTS=ON", "-DLIEF_PYTHON_API=on"]' \
'cmake_args = ["-DLIEF_FORCE_API_EXPORTS=ON", "-DLIEF_PYTHON_API=on", "-DLIEF_EXAMPLES=off"]'

outputs = [ "out" "py" ];

nativeBuildInputs = [
final.cmake
final.ninja
];

# Not a propagatedBuildInput because only the $py output needs it; $out is
# just the library itself (e.g. C/C++ headers).
buildInputs = [
final.python3
final.python3.pkgs.setuptools
final.python3.pkgs.tomli
];

CXXFLAGS = final.lib.optional final.stdenv.isLinux [ "-ffunction-sections" "-fdata-sections" "-fvisibility-inlines-hidden" "-static-libstdc++" "-static-libgcc" ] ++ final.lib.optional final.stdenv.isDarwin [ "-faligned-allocation" "-fno-aligned-new" "-fvisibility=hidden" ];

CFLAGS = final.lib.optional final.stdenv.isLinux [ "-ffunction-sections" "-fdata-sections" "-static-libstdc++" "-static-libgcc" ];
LDFLAGS = final.lib.optional final.stdenv.isLinux [ "-Wl,--gc-sections" "-Wl,--exclude-libs,ALL" ];


dontUseCmakeConfigure = true;

buildPhase = ''
runHook preBuild
mkdir -p build
cmake -S . -B build -GNinja -DCMAKE_LINK_WHAT_YOU_USE=on -DBUILD_SHARED_LIBS=on -DLIEF_INSTALL_COMPILED_EXAMPLES=off -DCMAKE_INSTALL_PREFIX=$out -DCMAKE_BUILD_TYPE=Release
cmake --build build --target all
runHook postBuild
'';
});

# Own package updated independently of nixpkgs
jefferson = final.callPackage ./nix/jefferson { };
postBuild = ''
pushd api/python
${final.python3.interpreter} setup.py build --parallel=$NIX_BUILD_CORES
popd
'';

installPhase = ''
runHook preInstall
cmake --build build --target install
runHook postInstall
'';

postInstall = ''
pushd api/python
${final.python3.interpreter} setup.py install --skip-build --root=/ --prefix=$py
popd
'';

});

python3 = prev.python3 // {
pkgs = prev.python3.pkgs.overrideScope
Expand Down

0 comments on commit 0122eea

Please sign in to comment.