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>
 |