From 015ac7c7da6dfc93d287b89e443648656a88665d Mon Sep 17 00:00:00 2001
From: Eelco Dolstra <e.dolstra@tudelft.nl>
Date: Wed, 27 Sep 2006 13:27:26 +0000
Subject: [PATCH] * Release notes.

---
 doc/manual/release-notes.xml | 215 +++++++++++++++++++++--------------
 1 file changed, 131 insertions(+), 84 deletions(-)

diff --git a/doc/manual/release-notes.xml b/doc/manual/release-notes.xml
index 5379eadef..df0e396b6 100644
--- a/doc/manual/release-notes.xml
+++ b/doc/manual/release-notes.xml
@@ -26,7 +26,10 @@ irreversible.</para></warning>
 
 <itemizedlist>
 
+  
+  <!-- Usability / features -->
 
+  
   <listitem><para><command>nix-env</command> usability improvements:
 
     <itemizedlist>
@@ -66,26 +69,6 @@ irreversible.</para></warning>
   </para></listitem>
   
 
-  <listitem><para>Berkeley DB 4.4’s process registry feature is used
-  to recover from crashed Nix processes.</para></listitem>
-
-  <!--  <listitem><para>TODO: shared stores.</para></listitem> -->
-
-  <listitem><para>A performance issue has been fixed with the
-  <literal>referer</literal> table, which stores the inverse of the
-  <literal>references</literal> table (i.e., it tells you what store
-  paths refer to a given path).  Maintaining this table could take a
-  quadratic amount of time, as well as a quadratic amount of Berkeley
-  DB log file space (in particular when running the garbage collector)
-  (<literal>NIX-23</literal>).</para></listitem>
-
-  <listitem><para>Nix now catches the <literal>TERM</literal> and
-  <literal>HUP</literal> signals in addition to the
-  <literal>INT</literal> signal.  So you can now do a <literal>killall
-  nix-store</literal> without triggering a database
-  recovery.</para></listitem>
-
-
   <listitem><para>New language features:
 
     <itemizedlist>
@@ -111,13 +94,13 @@ irreversible.</para></warning>
       <listitem><para>Multi-line string literals.</para></listitem>
 
       <listitem><para>String concatenations can now involve
-      derivations, as in the example above —
-      <code>"--with-freetype2-library=" + freetype + "/lib"</code>.
-      This was not previously possible because we need to register
-      that a derivation that uses such a string is dependent on
-      <literal>freetype</literal>.  The evaluator now properly
-      propagates this information.  Consequently, the subpath operator
-      (<literal>~</literal>) has been deprecated.</para></listitem>
+      derivations, as in the example <code>"--with-freetype2-library="
+      + freetype + "/lib"</code>.  This was not previously possible
+      because we need to register that a derivation that uses such a
+      string is dependent on <literal>freetype</literal>.  The
+      evaluator now properly propagates this information.
+      Consequently, the subpath operator (<literal>~</literal>) has
+      been deprecated.</para></listitem>
 
       <listitem><para>Default values of function arguments can now
       refer to other function arguments; that is, all arguments are in
@@ -128,10 +111,62 @@ irreversible.</para></warning>
       <listitem><para>TODO: domain checks (r5895).</para></listitem>
       -->
 
+      <listitem><para>Lots of new builtin primitives, such as
+      functions for list manipulation and integer arithmetic.  See the
+      manual for a complete list.  All primops are now available in
+      the set <varname>builtins</varname>, allowing one to test for
+      the availability of primop in a backwards-compatible
+      way.</para></listitem>
+
     </itemizedlist>
 
   </para></listitem>
-    
+
+
+  <listitem><para>New commands <command>nix-pack-closure</command> and
+  <command>nix-unpack-closure</command> than can be used to easily
+  transfer a store path with all its dependencies to another machine.
+  Very convenient whenever you have some package on your machine and
+  you want to copy it somewhere else.</para></listitem>
+
+  
+  <listitem><para>XML support:
+
+    <itemizedlist>
+
+      <listitem><para><literal>nix-env -q --xml</literal> prints the
+      installed or available packages in an XML representation for
+      easy processing by other tools.</para></listitem>
+
+      <listitem><para><literal>nix-instantiate --eval-only
+      --xml</literal> prints an XML representation of the resulting
+      term.  (The new flag <option>--strict</option> forces ‘deep’
+      evaluation of the result, i.e., list elements and attributes are
+      evaluated recursively.)</para></listitem>
+
+      <listitem><para>In Nix expressions, the primop
+      <function>builtins.toXML</function> converts a term to an XML
+      representation.  This is primarily useful for passing structured
+      information to builders.</para></listitem>
+
+    </itemizedlist>
+
+  </para></listitem>
+  
+
+  <listitem><para>You can now unambigously specify which derivation to
+  build or install in <command>nix-env</command>,
+  <command>nix-instantiate</command> and <command>nix-build</command>
+  using the <option>--attr</option> / <option>-A</option> flags, which
+  takes an attribute name as argument.  (Unlike symbolic package names
+  such as <literal>subversion-1.4.0</literal>, attribute names in an
+  attribute set are unique.)  For instance, a quick way to perform a
+  test build of a package in Nixpkgs is <literal>nix-build
+  pkgs/top-level/all-packages.nix -A
+  <replaceable>foo</replaceable></literal>.  <literal>nix-env -q
+  --attr</literal> shows the attribute names corresponding to each
+  derivation.</para></listitem>
+  
 
   <listitem><para>If the top-level Nix expression used by
   <command>nix-env</command>, <command>nix-instantiate</command> or
@@ -142,26 +177,53 @@ irreversible.</para></warning>
   <replaceable>value</replaceable></option> can be used to specify
   function arguments on the command line.</para></listitem>
 
-  <listitem><para>TODO: proxy support.</para></listitem>
+  
+  <listitem><para><literal>nix-install-package --url
+  <replaceable>URL</replaceable></literal> allows a package to be
+  installed directly from the given URL.</para></listitem>
 
-  <listitem><para>New commands <command>nix-pack-closure</command> and
-  <command>nix-unpack-closure</command> than can be used to easily
-  transfer a store path with all its dependencies to another machine.
-  Very convenient whenever you have some package on your machine and
-  you want to copy it somewhere else.</para></listitem>
 
-  <listitem><para><command>bsdiff</command> updated
-  4.3.</para></listitem>
+  <listitem><para>Nix now works behind an HTTP proxy server; just set
+  the standard environment variables <envar>http_proxy</envar>,
+  <envar>https_proxy</envar>, <envar>ftp_proxy</envar> or
+  <envar>all_proxy</envar> appropriately.  Functions such as
+  <function>fetchurl</function> in Nixpkgs also respect these
+  variables.</para></listitem>
 
-  <listitem><para>TODO: --attr / -A flags in
-  nix-env/nix-instantiate/nix-build.  Also nix-env -qa
-  --attr.</para></listitem>
 
   <listitem><para><literal>nix-build -o
   <replaceable>symlink</replaceable></literal> allows the symlink to
   the build result to be named something other than
   <literal>result</literal>.</para></listitem>
 
+
+  <!-- Stability / performance / etc. -->
+
+
+  <listitem><para>Platform support:
+
+    <itemizedlist>
+
+      <listitem><para>Support for 64-bit platforms, provided a <link
+      xlink:href="http://bugzilla.sen.cwi.nl:8080/show_bug.cgi?id=606">suitably
+      patched ATerm library</link> is used.  Also, files larger than 2
+      GiB are now supported.</para></listitem>
+
+      <listitem><para>Added support for Cygwin (Windows,
+      <literal>i686-cygwin</literal>), Mac OS X on Intel
+      (<literal>i686-darwin</literal>) and Linux on PowerPC
+      (<literal>powerpc-linux</literal>).</para></listitem>
+
+      <listitem><para>Users of SMP and multicore machines will
+      appreciate that the number of builds to be performed in parallel
+      can now be specified in the configuration file in the
+      <literal>build-max-jobs</literal> setting.</para></listitem>
+
+    </itemizedlist>
+
+  </para></listitem>
+
+  
   <listitem><para>Garbage collector improvements:
 
     <itemizedlist>
@@ -188,14 +250,38 @@ irreversible.</para></warning>
       --gc</literal>).  This is an easy way to get rid of all old
       packages in the Nix store.</para></listitem>
 
+      <listitem><para><command>nix-store</command> now has an
+      operation <option>--delete</option> to delete specific paths
+      from the Nix store.  It won’t delete reachable (non-garbage)
+      paths unless <option>--ignore-liveness</option> is
+      specified.</para></listitem>
+      
     </itemizedlist>
 
   </para></listitem>
 
-  <listitem><para>New command <literal>nix-store --delete</literal> to
-  delete specific paths from the Nix store.  It won’t delete reachable
-  (non-garbage) paths unless <option>--ignore-liveness</option> is
-  specified.</para></listitem>
+  
+  <listitem><para>Berkeley DB 4.4’s process registry feature is used
+  to recover from crashed Nix processes.</para></listitem>
+
+  <!--  <listitem><para>TODO: shared stores.</para></listitem> -->
+
+  <listitem><para>A performance issue has been fixed with the
+  <literal>referer</literal> table, which stores the inverse of the
+  <literal>references</literal> table (i.e., it tells you what store
+  paths refer to a given path).  Maintaining this table could take a
+  quadratic amount of time, as well as a quadratic amount of Berkeley
+  DB log file space (in particular when running the garbage collector)
+  (<literal>NIX-23</literal>).</para></listitem>
+
+  <listitem><para>Nix now catches the <literal>TERM</literal> and
+  <literal>HUP</literal> signals in addition to the
+  <literal>INT</literal> signal.  So you can now do a <literal>killall
+  nix-store</literal> without triggering a database
+  recovery.</para></listitem>
+
+  <listitem><para><command>bsdiff</command> updated
+  4.3.</para></listitem>
 
   <listitem><para>Substantial performance improvements in expression
   evaluation and <literal>nix-env -qa</literal>, all thanks to <link
@@ -225,51 +311,12 @@ irreversible.</para></warning>
 
   </para></listitem>
 
-  
-  <listitem><para>XML support:
-
-    <itemizedlist>
-
-      <listitem><para><literal>nix-env -q --xml</literal> prints the
-      installed or available packages in an XML representation for
-      easy processing by other tools.</para></listitem>
-
-      <listitem><para><literal>nix-instantiate --eval-only
-      --xml</literal> prints an XML representation of the resulting
-      term.  (The new flag <option>--strict</option> forces ‘deep’
-      evaluation of the result, i.e., list elements and attributes are
-      evaluated recursively.)</para></listitem>
-
-      <listitem><para>In Nix expressions, the primop
-      <function>builtins.toXML</function> converts a term to an XML
-      representation.  This is primarily useful for passing structured
-      information to builders.</para></listitem>
-
-    </itemizedlist>
-
-  </para></listitem>
-  
-
   <listitem><para>Nix source distributions are a lot smaller now since
   we no longer include a full copy of the Berkeley DB source
   distribution (but only the bits we need).</para></listitem>
 
-  <listitem><para>Support for 64-bit platforms, provided <link
-  xlink:href="http://bugzilla.sen.cwi.nl:8080/show_bug.cgi?id=606">suitably
-  patched ATerm library</link> is used.  Also, files larger than 2 GiB
-  are now supported.</para></listitem>
-
-  <listitem><para>Users of SMP and multicore machines will appreciate
-  that the number of builds to be performed in parallel can now be
-  specified in the configuration file in the
-  <literal>build-max-jobs</literal> setting.</para></listitem>
-
-  <listitem><para>Added support for Cygwin (Windows,
-  <literal>i686-cygwin</literal>) and Mac OS X on Intel
-  (<literal>i686-darwin</literal>).</para></listitem>
-
-  <listitem><para>TODO: <literal>nix-push
-  --target</literal>.</para></listitem>
+  <listitem><para>Header files are now installed so that external
+  programs can use the Nix libraries.</para></listitem>
 
 </itemizedlist>