about summary refs log tree commit diff
path: root/pkgs/development/libraries/science
diff options
context:
space:
mode:
authorSilvan Mosberger <infinisil@icloud.com>2018-12-31 03:24:48 +0100
committerGitHub <noreply@github.com>2018-12-31 03:24:48 +0100
commiteb864397a075c13700c96a243cace93114a84932 (patch)
treeb9411ae9001a42750b4c59e689ffadc918972bee /pkgs/development/libraries/science
parent78f80a6917085970caf399e6b5cf093e183c133a (diff)
parent00005ce0bdbc3c13804adc9a7fd71a02cc0b8db2 (diff)
downloadnixlib-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.nix27
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;