lix/src
Eelco Dolstra c4ac2a164a * The recent change in nixpkgs of calling `stdenv.mkDerivation'
instead of `derivation' triggered a huge slowdown in the Nix
  expression evaluator.  Total execution time of `nix-env -qa' went up
  by a factor of 60 or so.

  This scalability problem was caused by expressions such as

    (x: y: ... x ...) a b

  where `a' is a large term (say, the one in
  `all-packages-generic.nix').  Then the first beta-reduction would
  produce

    (y: ... a ...) b

  by substituting `a' for `x'.  The second beta-reduction would then
  substitute `b' for `y' into the body `... a ...', which is a large
  term due to `a', and thus causes a large traversal to be performed
  by substitute() in the second reduction.  This is however entirely
  redundant, since `a' cannot contain free variables (since we never
  substitute below a weak head normal form).

  The solution is to wrap substituted terms into a `Closed'
  constructor, i.e.,

    subst(subs, Var(x)) = Closed(e) iff subs[x] = e

  have substitution not descent into closed terms,

    subst(subs, Closed(x)) = Closed(x)

  and otherwise ignore them for evaluation,

    eval(Closed(x)) = eval(x).

* Fix a typo that caused incorrect substitutions to be performed in
  simple lambdas, e.g., `(x: x: x) a' would reduce to `(x: a)'.
2004-03-30 15:05:35 +00:00
..
bin2c * "Fix expression" -> "Nix expression". 2003-11-18 12:06:07 +00:00
boost * GCC 2.95 compatibility. 2003-12-22 16:40:46 +00:00
libexpr * The recent change in nixpkgs of calling `stdenv.mkDerivation' 2004-03-30 15:05:35 +00:00
libmain * Disallow the Nix store or any of its parents from being symlinks. 2004-03-27 17:58:04 +00:00
libstore * Some more nesting. 2004-03-22 21:42:28 +00:00
libutil * Disallow the Nix store or any of its parents from being symlinks. 2004-03-27 17:58:04 +00:00
log2xml * Do not close a nesting level twice after close() has been 2004-03-27 15:33:19 +00:00
nix-env * Allow linking against an external Berkeley DB / ATerm library. 2004-02-16 16:37:16 +00:00
nix-hash * Allow linking against an external Berkeley DB / ATerm library. 2004-02-16 16:37:16 +00:00
nix-instantiate * Allow linking against an external Berkeley DB / ATerm library. 2004-02-16 16:37:16 +00:00
nix-store * Allow linking against an external Berkeley DB / ATerm library. 2004-02-16 16:37:16 +00:00
Makefile.am * Added a utility that can be used to produce nice HTML pages from Nix 2004-03-15 21:51:14 +00:00