summary refs log tree commit diff
path: root/pkgs/test
diff options
context:
space:
mode:
authorJohn Ericson <John.Ericson@Obsidian.Systems>2017-07-17 23:36:17 -0400
committerJohn Ericson <John.Ericson@Obsidian.Systems>2017-07-31 17:02:56 -0400
commit0c37778c2c17fb40407f6432ff009cd7ae5b17b1 (patch)
tree8e373e03d047490e92a725cb741b07b6701780b9 /pkgs/test
parentd4ef5ac0e962bd6604dda38617c4b98c77a62949 (diff)
downloadnixpkgs-0c37778c2c17fb40407f6432ff009cd7ae5b17b1.tar
nixpkgs-0c37778c2c17fb40407f6432ff009cd7ae5b17b1.tar.gz
nixpkgs-0c37778c2c17fb40407f6432ff009cd7ae5b17b1.tar.bz2
nixpkgs-0c37778c2c17fb40407f6432ff009cd7ae5b17b1.tar.lz
nixpkgs-0c37778c2c17fb40407f6432ff009cd7ae5b17b1.tar.xz
nixpkgs-0c37778c2c17fb40407f6432ff009cd7ae5b17b1.tar.zst
nixpkgs-0c37778c2c17fb40407f6432ff009cd7ae5b17b1.zip
cc-wrapper: WIP linking hack for mac OS
Probably best to override Haskell packages set, or anything else
linking a lot of libraries, with this.
Diffstat (limited to 'pkgs/test')
-rw-r--r--pkgs/test/macos-sierra-shared/default.nix43
1 files changed, 43 insertions, 0 deletions
diff --git a/pkgs/test/macos-sierra-shared/default.nix b/pkgs/test/macos-sierra-shared/default.nix
new file mode 100644
index 00000000000..8d7b9fc9384
--- /dev/null
+++ b/pkgs/test/macos-sierra-shared/default.nix
@@ -0,0 +1,43 @@
+{ lib, clangStdenv, clang-sierraHack-stdenv }:
+
+let
+  makeBigExe = stdenv: prefix: rec {
+
+    sillyLibs = lib.genList (i: stdenv.mkDerivation rec {
+      name = "${prefix}-fluff-${toString i}";
+      unpackPhase = ''
+        src=$PWD
+        echo 'int asdf${toString i}(void) { return ${toString i}; }' > ${name}.c
+      '';
+      buildPhase = ''
+        $CC -shared ${name}.c -o lib${name}.dylib -Wl,-install_name,$out/lib/lib${name}.dylib
+      '';
+      installPhase = ''
+        mkdir -p "$out/lib"
+        mv lib${name}.dylib "$out/lib"
+      '';
+    }) 500
+    ;
+
+    finalExe = stdenv.mkDerivation rec {
+      name = "${prefix}-final-asdf";
+      unpackPhase = ''
+        src=$PWD
+        echo 'int main(int argc, char **argv) { return argc; }' > main.c;
+      '';
+      buildPhase = ''
+        $CC main.c ${toString (map (x: "-l${x.name}") sillyLibs)} -o asdf
+      '';
+      buildInputs = sillyLibs;
+      installPhase = ''
+        mkdir -p "$out/bin"
+        mv asdf "$out/bin"
+      '';
+    };
+
+  };
+
+in {
+  good = makeBigExe clang-sierraHack-stdenv "good";
+  bad  = makeBigExe clangStdenv             "bad";
+}