summary refs log tree commit diff
path: root/doc/platform-notes.xml
diff options
context:
space:
mode:
authorDaiderd Jordan <daiderd@gmail.com>2017-10-29 17:15:43 +0100
committerDaiderd Jordan <daiderd@gmail.com>2017-11-01 18:08:19 +0100
commit633b03c57f658d57a192eabb088b171b4542081e (patch)
tree4b7435dd9e2bef447a1c5ff495a7f99f84560e08 /doc/platform-notes.xml
parent91d3da04ad1999953e7e89baf73aedd3730d4b8e (diff)
downloadnixpkgs-633b03c57f658d57a192eabb088b171b4542081e.tar
nixpkgs-633b03c57f658d57a192eabb088b171b4542081e.tar.gz
nixpkgs-633b03c57f658d57a192eabb088b171b4542081e.tar.bz2
nixpkgs-633b03c57f658d57a192eabb088b171b4542081e.tar.lz
nixpkgs-633b03c57f658d57a192eabb088b171b4542081e.tar.xz
nixpkgs-633b03c57f658d57a192eabb088b171b4542081e.tar.zst
nixpkgs-633b03c57f658d57a192eabb088b171b4542081e.zip
docs: add section on common darwin issues
Diffstat (limited to 'doc/platform-notes.xml')
-rw-r--r--doc/platform-notes.xml83
1 files changed, 83 insertions, 0 deletions
diff --git a/doc/platform-notes.xml b/doc/platform-notes.xml
new file mode 100644
index 00000000000..f4f6ec60029
--- /dev/null
+++ b/doc/platform-notes.xml
@@ -0,0 +1,83 @@
+<chapter xmlns="http://docbook.org/ns/docbook"
+         xmlns:xlink="http://www.w3.org/1999/xlink"
+         xml:id="chap-platform-nodes">
+
+<title>Platform Notes</title>
+
+<section xml:id="sec-darwin">
+
+<title>Darwin (macOS)</title>
+<para>Some common issues when packaging software for darwin:</para>
+
+<itemizedlist>
+
+  <listitem>
+    <para>
+      The darwin <literal>stdenv</literal> uses clang instead of gcc.
+      When referring to the compiler <varname>$CC</varname> or <command>cc</command>
+      will work in both cases.  Some builds hardcode gcc/g++ in their
+      build scripts, that can usually be fixed with using something
+      like <literal>makeFlags = [ "CC=cc" ];</literal> or by patching
+      the build scripts.
+    </para>
+
+    <programlisting>
+      stdenv.mkDerivation {
+        name = "libfoo-1.2.3";
+        # ...
+        buildPhase = ''
+          $CC -o hello hello.c
+        '';
+      }
+    </programlisting>
+  </listitem>
+
+  <listitem>
+    <para>
+      On darwin libraries are linked using absolute paths, libraries
+      are resolved by their <literal>install_name</literal> at link
+      time.  Sometimes packages won't set this correctly causing the
+      library lookups to fail at runtime.  This can be fixed by adding
+      extra linker flags or by running <command>install_name_tool -id</command>
+      during the <function>fixupPhase</function>.
+    </para>
+
+    <programlisting>
+      stdenv.mkDerivation {
+        name = "libfoo-1.2.3";
+        # ...
+        makeFlags = stdenv.lib.optional stdenv.isDarwin "LDFLAGS=-Wl,-install_name,$(out)/lib/libfoo.dylib";
+      }
+    </programlisting>
+  </listitem>
+
+  <listitem>
+    <para>
+      Some packages assume xcode is available and use <command>xcrun</command>
+      to resolve build tools like <command>clang</command>, etc.
+      This causes errors like <code>xcode-select: error: no developer tools were found at '/Applications/Xcode.app'</code>
+      while the build doesn't actually depend on xcode.
+    </para>
+
+    <programlisting>
+      stdenv.mkDerivation {
+        name = "libfoo-1.2.3";
+        # ...
+        prePatch = ''
+          substituteInPlace Makefile \
+              --replace '/usr/bin/xcrun clang' clang
+        '';
+      }
+    </programlisting>
+
+    <para>
+      The package <literal>xcbuild</literal> can be used to build projects
+      that really depend on Xcode, however projects that build some kind of
+      graphical interface won't work without using Xcode in an impure way.
+    </para>
+  </listitem>
+
+</itemizedlist>
+</section>
+
+</chapter>