mirror of
https://github.com/privatevoid-net/nix-super.git
synced 2024-11-23 14:36:16 +02:00
47 lines
1.7 KiB
XML
47 lines
1.7 KiB
XML
<chapter xmlns="http://docbook.org/ns/docbook"
|
|
xmlns:xlink="http://www.w3.org/1999/xlink"
|
|
xmlns:xi="http://www.w3.org/2001/XInclude"
|
|
version="5.0"
|
|
xml:id="ch-simple-expression">
|
|
|
|
<title>A Simple Nix Expression</title>
|
|
|
|
<para>This section shows how to add and test the <link
|
|
xlink:href='http://www.gnu.org/software/hello/hello.html'>GNU Hello
|
|
package</link> to the Nix Packages collection. Hello is a program
|
|
that prints out the text <quote>Hello, world!</quote>.</para>
|
|
|
|
<para>To add a package to the Nix Packages collection, you generally
|
|
need to do three things:
|
|
|
|
<orderedlist>
|
|
|
|
<listitem><para>Write a Nix expression for the package. This is a
|
|
file that describes all the inputs involved in building the package,
|
|
such as dependencies, sources, and so on.</para></listitem>
|
|
|
|
<listitem><para>Write a <emphasis>builder</emphasis>. This is a
|
|
shell script<footnote><para>In fact, it can be written in any
|
|
language, but typically it's a <command>bash</command> shell
|
|
script.</para></footnote> that actually builds the package from
|
|
the inputs.</para></listitem>
|
|
|
|
<listitem><para>Add the package to the file
|
|
<filename>pkgs/top-level/all-packages.nix</filename>. The Nix
|
|
expression written in the first step is a
|
|
<emphasis>function</emphasis>; it requires other packages in order
|
|
to build it. In this step you put it all together, i.e., you call
|
|
the function with the right arguments to build the actual
|
|
package.</para></listitem>
|
|
|
|
</orderedlist>
|
|
|
|
</para>
|
|
|
|
<xi:include href="expression-syntax.xml" />
|
|
<xi:include href="build-script.xml" />
|
|
<xi:include href="arguments-variables.xml" />
|
|
<xi:include href="simple-building-testing.xml" />
|
|
<xi:include href="generic-builder.xml" />
|
|
|
|
</chapter>
|