mirror of
https://github.com/privatevoid-net/nix-super.git
synced 2024-12-02 10:26:16 +02:00
143 lines
4.8 KiB
XML
143 lines
4.8 KiB
XML
<chapter>
|
|
<title>Installation</title>
|
|
|
|
<sect1>
|
|
<title>Obtaining Nix</title>
|
|
|
|
<para>
|
|
The easiest way to obtain Nix is to download a <ulink
|
|
url='http://www.cs.uu.nl/groups/ST/Trace/Nix'>source
|
|
distribution.</ulink>
|
|
</para>
|
|
|
|
<para>
|
|
Alternatively, the most recent sources of Nix can be obtained from its
|
|
<ulink url='https://svn.cs.uu.nl:12443/repos/trace/nix/trunk'>Subversion
|
|
repository</ulink>. For example, the following command will check out
|
|
the latest revision into a directory called <filename>nix</filename>:
|
|
</para>
|
|
|
|
<screen>
|
|
$ svn checkout https://svn.cs.uu.nl:12443/repos/trace/nix/trunk nix</screen>
|
|
|
|
<para>
|
|
Likewise, specific releases can be obtained from the <ulink
|
|
url='https://svn.cs.uu.nl:12443/repos/trace/nix/tags'>tags
|
|
directory</ulink> of the repository. If you don't have Subversion, you
|
|
can also download an automatically generated <ulink
|
|
url='https://svn.cs.uu.nl:12443/dist/trace/'>compressed
|
|
tar-file</ulink> of the head revision of the trunk.
|
|
</para>
|
|
|
|
</sect1>
|
|
|
|
<sect1>
|
|
<title>Prerequisites</title>
|
|
|
|
<para>
|
|
A fairly recent version of GCC/G++ is required. Version 2.95 and higher
|
|
should work.
|
|
</para>
|
|
|
|
<para>
|
|
To rebuild this manual and the man-pages you need the
|
|
<command>xmllint</command> and <command>xsltproc</command>, which are
|
|
part of the <literal>libxml2</literal> and <literal>libxslt</literal>
|
|
packages, respectively. You also need the <ulink
|
|
url='http://docbook.sourceforge.net/projects/xsl/'>DocBook XSL
|
|
stylesheets</ulink> and optionally the <ulink
|
|
url='http://www.oasis-open.org/docbook/xml/4.2/docbook-xml-4.2.zip'>
|
|
DocBook XML 4.2 DTD</ulink>. Note that these are only required if you
|
|
modify the manual sources or when you are building from the Subversion
|
|
repository.
|
|
</para>
|
|
|
|
<para>
|
|
Nix uses Sleepycat's Berkeley DB, CWI's ATerm library, and SDF parser
|
|
library. These are included in the Nix source distribution. If you
|
|
build from the Subversion repository, you must download them yourself and
|
|
place them in the <filename>externals/</filename> directory. See
|
|
<filename>externals/Makefile.am</filename> for the precise URLs of these
|
|
packages.
|
|
</para>
|
|
</sect1>
|
|
|
|
<sect1>
|
|
<title>Building Nix</title>
|
|
|
|
<para>
|
|
After unpacking or checking out the Nix sources, issue the following
|
|
commands:
|
|
</para>
|
|
|
|
<screen>
|
|
$ ./configure <replaceable>options...</replaceable>
|
|
$ make
|
|
$ make install</screen>
|
|
|
|
<para>
|
|
When building from the Subversion repository, these should be preceded by
|
|
the command:
|
|
</para>
|
|
|
|
<screen>
|
|
$ autoreconf -i</screen>
|
|
|
|
<para>
|
|
The installation path can be specified by passing the
|
|
<option>--prefix=<replaceable>prefix</replaceable></option> to
|
|
<command>configure</command>. The default installation directory is
|
|
<filename>/nix</filename>. You can change this to any location you like.
|
|
You must have write permission to the <replaceable>prefix</replaceable>
|
|
path.
|
|
</para>
|
|
|
|
<warning>
|
|
<para>
|
|
It is advisable <emphasis>not</emphasis> to change the installation
|
|
prefix from its default, since doing so will in all likelihood make it
|
|
impossible to use derivations built on other systems.
|
|
</para>
|
|
</warning>
|
|
|
|
<para>
|
|
If you want to rebuilt the documentation, pass the full path to the
|
|
DocBook XML catalog file (<filename>docbook.cat</filename>) and to the
|
|
DocBook XSL stylesheets using the
|
|
<option>--with-docbook-catalog=<replaceable>path</replaceable></option>
|
|
and <option>--with-docbook-xsl=<replaceable>path</replaceable></option>
|
|
options.
|
|
</para>
|
|
|
|
</sect1>
|
|
|
|
|
|
<sect1>
|
|
<title>Using Nix</title>
|
|
|
|
<para>
|
|
To use Nix, some environment variables should be set. In particular,
|
|
<envar>PATH</envar> should contain the directories
|
|
<filename><replaceable>prefix</replaceable>/bin</filename> and
|
|
<filename><replaceable>prefix</replaceable>/var/nix/links/current/bin</filename>.
|
|
The first directory contains the Nix tools themselves, while the second
|
|
contains to the current <emphasis>user environment</emphasis> (an
|
|
automatically generated package consisting of symlinks to installed
|
|
packages). The simplest way to set the required environment variables is
|
|
to include the file
|
|
<filename><replaceable>prefix</replaceable>/etc/profile.d/nix.sh</filename>
|
|
in your <filename>~/.bashrc</filename> (or similar), like this:
|
|
</para>
|
|
|
|
<screen>
|
|
. <replaceable>prefix</replaceable>/etc/profile.d/nix.sh</screen>
|
|
|
|
</sect1>
|
|
|
|
</chapter>
|
|
|
|
<!--
|
|
local variables:
|
|
sgml-parent-document: ("book.xml" "chapter")
|
|
end:
|
|
-->
|