about summary refs log tree commit diff
AgeCommit message (Collapse)AuthorFilesLines
2003-07-31 * Set execute bit.Eelco Dolstra2-0/+0
2003-07-31 * Basic makefile.Eelco Dolstra1-0/+7
2003-07-30 * A better test case for Nix race conditions.Eelco Dolstra2-0/+19
2003-07-30 * Directories for the manual.Eelco Dolstra1-0/+3
2003-07-30 * Test cases for races.Eelco Dolstra2-0/+19
2003-07-30 * INSTALL_DATA -> INSTALL_PROGRAM to ensure that the execute bitEelco Dolstra2-3/+3
remains set.
2003-07-30 * Don't make the builder executable.Eelco Dolstra1-4/+0
2003-07-29 * Bug: Fix does not allow empty names, so don't generate them.Eelco Dolstra1-10/+10
2003-07-29 * Use `--query --requisites' and include successors when pushing. Don't Eelco Dolstra1-8/+8
use `--query --generators' anymore.
2003-07-29 * Typo: if -> elsif.Eelco Dolstra1-1/+1
2003-07-29 * Get garbage collection and cache population to work *properly*.Eelco Dolstra7-30/+86
Renamed `fstateRefs' to `fstateRequisites'. The semantics of this function is that it returns a list of all paths necessary to realise a given expression. For a derive expression, this is the union of requisites of the inputs; for a slice expression, it is the path of each element in the slice. Also included are the paths of the expressions themselves. Optionally, one can also include the requisites of successor expressions (to recycle intermediate results). * `nix-switch' now distinguishes between an expression and its normal form. Usually, only the normal form is registered as a root of the garbage collector. With the `--source-root' flag, it will also register the original expression as a root. * `nix-collect-garbage' now has a flag `--keep-successors' which causes successors not to be included in the list of garbage paths. * `nix-collect-garbage' now has a flag `--invert' which will print all paths that should *not* be garbage collected.
2003-07-29 * Nicer dot graphs.Eelco Dolstra1-1/+7
2003-07-29 * `fstateRefs' now works on derive expressions as well. TODO: makeEelco Dolstra4-14/+40
this more efficient. * A flag `-n' in 'nix --query' to normalise the argument. Default is not to normalise.
2003-07-29 * Let `nix --install' print out the id of the normal form.Eelco Dolstra5-34/+35
* Some minor refactoring.
2003-07-28 * Do not set LD_LIBRARY_PATH; it breaks many things. E.g., SuSE's ssh Eelco Dolstra1-1/+1
dynamically links against libdb4 (?!), due to LD_LIBRARY_PATH it picks up our libdb4 instead of SuSE's libdb4, but our libdb4 uses another glibc so loading barfs. Instead, all packages should use rpaths to store library locations in executables/libraries. The disadvantage is that overriding rpaths is harder. (It is possible by invoking the dynamic linker directly, e.g., `/lib/ld-linux.so.2 --ignore-path LIST program args...' to ignore the rpath for the libraries in LIST). It would be better to use DT_RUNPATH, which is consulted by the dynamic linker *after* LD_LIBRARY_PATH but *before* ld.so.cache and the system directories.
2003-07-28 * Check for the pthread library (db4 needs it on some platforms).Eelco Dolstra2-1/+4
2003-07-28 * `nix --help'.Eelco Dolstra3-37/+116
* `nix --query --graph' to print a dot dependency graph of derive expressions.
2003-07-24 * Fix message.Eelco Dolstra1-1/+2
2003-07-24 * Prevent spurious rebuilds of db/aterm.Eelco Dolstra1-2/+10
2003-07-24 * The `-v' flag no longer takes an argument; it should be repeatedEelco Dolstra6-38/+29
instead (e.g., `-vvvv' for lots of output). Default is to only print error messages.
2003-07-24 * Do sync the database, since not doing so caused database changes notEelco Dolstra1-1/+1
to reach the disk at all. Looks like a bug.
2003-07-24 * Debug levels. Use `--verbose / -v LEVEL' to display only messagesEelco Dolstra8-25/+68
up to the given verbosity levels. These currently are: lvlError = 0, lvlNormal = 5, lvlDebug = 10, lvlDebugMore = 15 although only lvlError and lvlDebug are actually used right now.
2003-07-24 * Don't sync the database on close. This was killing performance.Eelco Dolstra1-1/+1
(Of course, the real problem is that we open the database for *every* operation; we should only open it once. And we should use transactions.)
2003-07-23 * Incorporated Berkeley DB and ATerm into the source tree.Eelco Dolstra7-5/+63
* `make dist'.
2003-07-22 * libdb_cxx-4 -> libdb_cxxEelco Dolstra1-4/+4
2003-07-22 * Substitutes now should produce a path with the same id as they areEelco Dolstra8-50/+86
substituting for (obvious, really). * For greater efficiency, nix-pull/unnar will place the output in a path that is probably the same as what is actually needed, thus preventing a path copy. * Even if a output id is given in a Fix package expression, ensure that the resulting Nix derive expression has a different id. This is because Nix expressions that are semantically equivalent (i.e., build the same result) might be different w.r.t. efficiency or divergence. It is absolutely vital for the substitute mechanism that such expressions are not used interchangeably.
2003-07-22 * `nix --query --expansion' (`-qe') to get any path with contentEelco Dolstra1-3/+13
corresponding to the given id.
2003-07-21 * Changed nix-pull to match nix-push.Eelco Dolstra2-15/+16
2003-07-21 * Syntax fixes.Eelco Dolstra4-17/+32
* When pushing, put the hash in the file name so that the client can verify (proof-carrying file names?).
2003-07-21 * In `--query --generators', print out paths, not ids.Eelco Dolstra1-1/+1
(There should really be a switch for this).
2003-07-21 * Check for errors.Eelco Dolstra1-1/+1
2003-07-21 * Canonicalise path.Eelco Dolstra1-1/+1
2003-07-21 * Allow the output/expression id to be forced to a certain Eelco Dolstra6-17/+23
value; this potentially dangerous feature enables better sharing for those paths for which the content is known in advance (e.g., because a content hash is given). * Fast builds: if we can expand all output paths of a derive expression, we don't have to build.
2003-07-21 * Changes to the command line syntax of Nix.Eelco Dolstra5-78/+117
* A function to find all Nix expressions whose output ids are completely contained in some set. Useful for uploading relevant Nix expressions to a shared cache.
2003-07-21 * Memoize the evaluation of Fix expressions to speed up computation.Eelco Dolstra2-25/+47
2003-07-20 * Argh, another short-write problem. Added wrappers aroundEelco Dolstra9-36/+46
read()/write() to fix this once and for all.
2003-07-20 * Remove accidentally added file.Eelco Dolstra1-0/+0
2003-07-20 * Refactorings.Eelco Dolstra14-587/+617
2003-07-18 * Generate nar.sh, fetchurl.sh.Eelco Dolstra9-27/+32
2003-07-17 * For debugging: `nix --verify' to check the consistency of theEelco Dolstra7-14/+139
database and store.
2003-07-17 * Preserve the executable bit.Eelco Dolstra1-0/+13
2003-07-16 * The write() system call can write less than the requested Eelco Dolstra3-3/+13
number of bytes, e.g., in case of a signal like SIGSTOP. This caused `nix --dump' to fail sometimes. Note that this bug went unnoticed because the call to `nix --dump' is in a pipeline, and the shell ignores non-zero exit codes from all but the last element in the pipeline. Is there any way to check the result of the initial elements in the pipeline? (In other words, is it at all possible to write reliable shell scripts?)
2003-07-16 * Doh!Eelco Dolstra1-1/+2
2003-07-16 * Bug fix: slices are transitive, so if we detect that an Eelco Dolstra1-5/+10
input path is referenced in an output paths, we also have to add all ids referenced by that input path. * Better debug assertions to catch these sorts of errors.
2003-07-16 * Substitute fixes.Eelco Dolstra8-36/+86
2003-07-16 * Fix the -qr query.Eelco Dolstra3-15/+40
2003-07-16 * Fix self-referential outputs.Eelco Dolstra5-30/+28
* Fix -qp query.
2003-07-15 * Get Fix and Nix to work again.Eelco Dolstra6-268/+93
2003-07-15 * The new normaliser now passes the unit tests.Eelco Dolstra7-34/+179
2003-07-15 * Basic work on allowing derive expressions to build multiple paths.Eelco Dolstra7-193/+366
This is not entirely trivial since this introduces the possibility of mutual recursion. * Made normal forms self-contained. * Use unique ids, not content hashes, for content referencing.