diff options
author | Silvan Mosberger <infinisil@icloud.com> | 2018-12-31 03:24:48 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-12-31 03:24:48 +0100 |
commit | eb864397a075c13700c96a243cace93114a84932 (patch) | |
tree | b9411ae9001a42750b4c59e689ffadc918972bee /pkgs/development/libraries/science | |
parent | 78f80a6917085970caf399e6b5cf093e183c133a (diff) | |
parent | 00005ce0bdbc3c13804adc9a7fd71a02cc0b8db2 (diff) | |
download | nixlib-eb864397a075c13700c96a243cace93114a84932.tar nixlib-eb864397a075c13700c96a243cace93114a84932.tar.gz nixlib-eb864397a075c13700c96a243cace93114a84932.tar.bz2 nixlib-eb864397a075c13700c96a243cace93114a84932.tar.lz nixlib-eb864397a075c13700c96a243cace93114a84932.tar.xz nixlib-eb864397a075c13700c96a243cace93114a84932.tar.zst nixlib-eb864397a075c13700c96a243cace93114a84932.zip |
Merge pull request #52508 from tkonolige/fix_suitesparse_darwin
suitesparse: Fix darwin support
Diffstat (limited to 'pkgs/development/libraries/science')
-rw-r--r-- | pkgs/development/libraries/science/math/suitesparse/default.nix | 27 |
1 files changed, 25 insertions, 2 deletions
diff --git a/pkgs/development/libraries/science/math/suitesparse/default.nix b/pkgs/development/libraries/science/math/suitesparse/default.nix index 528fe5ed0739..ce3b048e764d 100644 --- a/pkgs/development/libraries/science/math/suitesparse/default.nix +++ b/pkgs/development/libraries/science/math/suitesparse/default.nix @@ -87,14 +87,37 @@ stdenv.mkDerivation rec { cp -r lib $out/ cp -r include $out/ cp -r share $out/ + '' + + stdenv.lib.optionalString stdenv.isDarwin '' + # The fixDarwinDylibNames in nixpkgs can't seem to fix all the libraries. + # We manually fix them up here. + fixDarwinDylibNames() { + local flags=() + local old_id + + for fn in "$@"; do + flags+=(-change "$PWD/lib/$(basename "$fn")" "$fn") + done + + for fn in "$@"; do + if [ -L "$fn" ]; then continue; fi + echo "$fn: fixing dylib" + install_name_tool -id "$fn" "''${flags[@]}" "$fn" + done + } + fixDarwinDylibNames $(find "$out" -name "*.dylib") + '' + + stdenv.lib.optionalString (!stdenv.isDarwin) '' # Fix rpaths cd $out find -name \*.so\* -type f -exec \ patchelf --set-rpath "$out/lib:${stdenv.lib.makeLibraryPath buildInputs}" {} \; - + '' + + + '' runHook postInstall - ''; + ''; nativeBuildInputs = [ cmake ] ++ stdenv.lib.optional stdenv.isDarwin fixDarwinDylibNames; |