Go to file
Ludovic Courtès 90c68be883 Rename <package-source> to <origin>; use the `letrec*' behavior in packages.
* guix/packages.scm (<package-source>): Rename to...
  (<origin>): ... this.  Update users.

* distro/base.scm (libsigsegv, gawk, hello): Adjust to renaming; refer
  to VERSION to build the URL.
2012-07-03 23:50:29 +02:00
distro Rename <package-source> to <origin>; use the `letrec*' behavior in packages. 2012-07-03 23:50:29 +02:00
guix Rename <package-source> to <origin>; use the `letrec*' behavior in packages. 2012-07-03 23:50:29 +02:00
po Add `guix-build'. 2012-07-01 00:56:24 +02:00
srfi SRFI-64: Remove use of (ice-9 syntax-case). 2012-06-05 11:21:13 +02:00
tests define-record-type*: Add `letrec*' behavior. 2012-07-03 21:59:56 +02:00
.gitignore Add `guix-build'. 2012-07-01 00:56:24 +02:00
AUTHORS Add the usual top-level files. 2012-06-03 23:46:56 +02:00
COPYING Add the usual top-level files. 2012-06-03 23:46:56 +02:00
Makefile.am build: Don't auto-compile tests. 2012-07-02 01:35:39 +02:00
README Update list of dependencies. 2012-07-01 15:11:14 +02:00
configure.ac build: Use `AM_GNU_GETTEXT_VERSION'. 2012-07-02 01:35:39 +02:00
distro.scm Add (distro) with a package searching facility. 2012-06-30 16:37:19 +02:00
guix-build.in guix-build: Display multiple outputs when needed. 2012-07-02 01:35:39 +02:00
guix.scm Split (guix) in (guix store) and (guix derivations). 2012-04-18 23:34:12 +02:00

README

-*- mode: org -*-

Guix is Nix[0] from Guile[1]!

Concretely, it allows Nix package management to be done entirely in
Scheme. The goal is to investigate whether Scheme, and in particular
the ability to define EDSLs, would allow it to fulfill the role of the
Nix language.

[0] http://nixos.org/nix/
[1] http://gnu.org/software/guile/


* Hacking

Guix currently depends on the following packages:

  - [[http://gnu.org/software/guile/][GNU Guile 2.0.x]]
  - [[http://nixos.org/nix/][Nix]]
  - [[http://gnupg.org/][GNU libgcrypt]], or [[http://nongnu.org/libchop/][libchop]]

For bootstrapping purposes, it is useful to reuse packages from Nixpkgs.
For this to work, you need to have a checkout of the Nixpkgs repository,
with the `NIXPKGS' environment variable pointing to it.

  - [[http://nixos.org/nixpkgs/][Nixpkgs]]

* How It Works

Guix does the high-level preparation of a /derivation/.  A derivation is
the promise of a build; it is stored as a text file under
=/nix/store/xxx.drv=.  The (guix derivations) module provides the
`derivation' primitive, as well as higher-level wrappers such as
`build-expression->derivation'.

Guix does remote procedure calls (RPCs) to the Nix daemon (the
=nix-worker --daemon= command), which in turn performs builds and
accesses to the Nix store on its behalf.  The RPCs are implemented in
the (guix store) module.

* Contact

The repository is at <https://gitorious.org/guix/>.

Please email <ludo@gnu.org> or <nix-dev@lists.science.uu.nl>, or
join #guile or #nixos on irc.freenode.net or `civodul'.