2017-10-29 16:15:43 +00:00
|
|
|
<chapter xmlns="http://docbook.org/ns/docbook"
|
|
|
|
xmlns:xlink="http://www.w3.org/1999/xlink"
|
|
|
|
xml:id="chap-platform-nodes">
|
2018-05-01 23:54:21 +00:00
|
|
|
<title>Platform Notes</title>
|
|
|
|
<section xml:id="sec-darwin">
|
|
|
|
<title>Darwin (macOS)</title>
|
2017-10-29 16:15:43 +00:00
|
|
|
|
2018-05-01 23:54:21 +00:00
|
|
|
<para>
|
|
|
|
Some common issues when packaging software for darwin:
|
|
|
|
</para>
|
2017-10-29 16:15:43 +00:00
|
|
|
|
2018-05-01 23:54:21 +00:00
|
|
|
<itemizedlist>
|
|
|
|
<listitem>
|
2017-10-29 16:15:43 +00:00
|
|
|
<para>
|
2018-05-01 23:54:21 +00:00
|
|
|
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.
|
2017-10-29 16:15:43 +00:00
|
|
|
</para>
|
2018-05-01 23:54:21 +00:00
|
|
|
<programlisting>
|
2017-10-29 16:15:43 +00:00
|
|
|
stdenv.mkDerivation {
|
|
|
|
name = "libfoo-1.2.3";
|
|
|
|
# ...
|
|
|
|
buildPhase = ''
|
|
|
|
$CC -o hello hello.c
|
|
|
|
'';
|
|
|
|
}
|
|
|
|
</programlisting>
|
2018-05-01 23:54:21 +00:00
|
|
|
</listitem>
|
|
|
|
<listitem>
|
2017-10-29 16:15:43 +00:00
|
|
|
<para>
|
2018-05-01 23:54:21 +00:00
|
|
|
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>.
|
2017-10-29 16:15:43 +00:00
|
|
|
</para>
|
2018-05-01 23:54:21 +00:00
|
|
|
<programlisting>
|
2017-10-29 16:15:43 +00:00
|
|
|
stdenv.mkDerivation {
|
|
|
|
name = "libfoo-1.2.3";
|
|
|
|
# ...
|
|
|
|
makeFlags = stdenv.lib.optional stdenv.isDarwin "LDFLAGS=-Wl,-install_name,$(out)/lib/libfoo.dylib";
|
|
|
|
}
|
|
|
|
</programlisting>
|
2018-05-01 23:54:21 +00:00
|
|
|
</listitem>
|
|
|
|
<listitem>
|
2017-10-29 16:15:43 +00:00
|
|
|
<para>
|
2018-05-01 23:54:21 +00:00
|
|
|
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.
|
2017-10-29 16:15:43 +00:00
|
|
|
</para>
|
2018-05-01 23:54:21 +00:00
|
|
|
<programlisting>
|
2017-10-29 16:15:43 +00:00
|
|
|
stdenv.mkDerivation {
|
|
|
|
name = "libfoo-1.2.3";
|
|
|
|
# ...
|
|
|
|
prePatch = ''
|
|
|
|
substituteInPlace Makefile \
|
|
|
|
--replace '/usr/bin/xcrun clang' clang
|
|
|
|
'';
|
|
|
|
}
|
|
|
|
</programlisting>
|
|
|
|
<para>
|
2018-05-01 23:54:21 +00:00
|
|
|
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.
|
2017-10-29 16:15:43 +00:00
|
|
|
</para>
|
2018-05-01 23:54:21 +00:00
|
|
|
</listitem>
|
|
|
|
</itemizedlist>
|
|
|
|
</section>
|
2017-10-29 16:15:43 +00:00
|
|
|
</chapter>
|