Bugs / To-Do The man-pages generated from the DocBook documentation are ugly. Generations properly form a tree. E.g., if after switching to generation 39, we perform an installation action, a generation 43 is created which is a descendant of 39, not 42. So a rollback from 43 ought to go back to 39. This is not currently implemented; generations form a linear sequence. Unify the concepts of successors and substitutes into a general notion of equivalent expressions. Expressions are equivalent if they have the same target paths with the same identifiers. However, even though they are functionally equivalent, they may differ stronly with respect to their performance characteristics. For example, realising a closure expression is more efficient that realising the derivation expression from which it was produced. On the other hand, distributing sources may be more efficient (storage- or bandwidth-wise) than distributing binaries. So we need to be able to attach weigths or priorities or performance annotations to expressions; Nix can then choose the most efficient expression dependent on the context. Build management. In principle it is already possible to do build management using Nix (by writing builders that perform appropriate build steps), but the Nix expression language is not yet powerful enough to make this pleasant (?). The language should be extended with features from the Maak build manager. Another interesting idea is to write a make implementation that uses Nix as a back-end to support legacy build files. The current garbage collector is a hack. It should be integrated into nix-store. It should delete derivations in an order determined by topologically sorting derivations under the points-to relation. This ensures that no store paths ever exist that point to non-existant store paths. There are race conditions between the garbage collector and other Nix tools. For instance, when we run nix-env to build and install a derivation and run the garbage collector at the same time, the garbage collector may kick in exactly between the build and installation steps, i.e., before the newly built derivation has become reachable from a root of the garbage collector. One solution would be for these programs to properly register temporary roots for the collector. Another would be to use stop-the-world garbage collection: if any tool is running, the garbage collector blocks, and vice versa. These solutions do not solve the situation where multiple tools are involved, e.g., $ nix-store -r $(nix-instantiate foo.nix) since even if nix-instantiate where to register a temporary root, it would be released by the time nix-store is started. A solution would be to write the intermediate value to a file that is used as a root to the collector, e.g., $ nix-instantiate foo.nix > /nix/var/nix/roots/bla $ nix-store -r $(cat /nix/var/nix/roots/bla) For security, nix-push manifests should be digitally signed, and nix-pull should verify the signatures. The actual NAR archives in the cache do not need to be signed, since the manifest contains cryptographic hashes of these files (and fetchurl.nix checks them). We should switch away from MD5, since it has been more-or-less cracked. We don't currently depend very much on the collision-resistance of MD5, but we will once we start sharing build results between users. It would be useful to have an option in nix-env --delete-generations to remove non-current generations older than a certain age.