Merge branch 'master' into nix-integration
[jackhill/guix/guix.git] / README
CommitLineData
4255d4e3
LC
1-*- mode: org -*-
2
c80e7e55
LC
3[[http://www.gnu.org/software/guix/][GNU Guix]] (IPA: /ɡiːks/) is a purely functional package manager, and
4associated free software distribution, for the [[http://www.gnu.org/gnu/gnu.html][GNU system]]. In addition
5to standard package management features, Guix supports transactional
6upgrades and roll-backs, unprivileged package management, per-user
7profiles, and garbage collection.
b7a7f598 8
a65e3306
LC
9It provides [[http://www.gnu.org/software/guile/][Guile]] Scheme APIs, including a high-level embedded
10domain-specific languages (EDSLs) to describe how packages are to be
11built and composed.
b7a7f598 12
a65e3306
LC
13A user-land free software distribution for GNU/Linux comes as part of
14Guix.
15
16Guix is based on the [[http://nixos.org/nix/][Nix]] package manager.
4255d4e3
LC
17
18
e9f6d6dd 19* Requirements
4255d4e3 20
a65e3306 21GNU Guix currently depends on the following packages:
4255d4e3 22
a1e4a936 23 - [[http://gnu.org/software/guile/][GNU Guile 2.0.x]]
d388c2c4 24 - [[http://gnupg.org/][GNU libgcrypt]]
4255d4e3 25
e9f6d6dd
LC
26Unless `--disable-daemon' was passed, the following packages are needed:
27
28 - [[http://sqlite.org/][SQLite 3]]
29 - [[http://www.bzip.org][libbz2]]
30 - [[http://gcc.gnu.org][GCC's g++]]
31
32When `--disable-daemon' was passed, you instead need the following:
33
34 - [[http://nixos.org/nix/][Nix]]
35
e76bdf8b 36Optionally, packages from Nixpkgs may be transparently reused from Guix.
7da7ae93
LC
37For this to work, you need to have a checkout of the Nixpkgs repository;
38the `--with-nixpkgs' option allows you to let `configure' know where the
39Nixpkgs checkout is.
4255d4e3 40
a1e4a936 41 - [[http://nixos.org/nixpkgs/][Nixpkgs]]
4255d4e3 42
7da7ae93
LC
43When building Guix from a checkout, the following packages are also
44required:
45
46 - [[http://www.gnu.org/software/autoconf/][GNU Autoconf]]
47 - [[http://www.gnu.org/software/automake/][GNU Automake]]
48 - [[http://www.gnu.org/software/gettext/][GNU Gettext]]
49
50The "autoreconf -vi" command can be used to generate the build system
51infrastructure; it reports an error if an inappropriate version of the
52above packages is being used.
53
4255d4e3
LC
54* How It Works
55
56Guix does the high-level preparation of a /derivation/. A derivation is
57the promise of a build; it is stored as a text file under
58=/nix/store/xxx.drv=. The (guix derivations) module provides the
59`derivation' primitive, as well as higher-level wrappers such as
60`build-expression->derivation'.
61
62Guix does remote procedure calls (RPCs) to the Nix daemon (the
63=nix-worker --daemon= command), which in turn performs builds and
64accesses to the Nix store on its behalf. The RPCs are implemented in
65the (guix store) module.
66
67* Contact
68
a65e3306
LC
69GNU Guix is hosted at https://savannah.gnu.org/projects/guix/.
70
71Please email <bug-guix@gnu.org> for bug reports or questions regarding
72Guix and its distribution; email <gnu-system-discuss@gnu.org> for
73general issues regarding the GNU system.
74
75Join #guix on irc.freenode.net.
76
77* Guix & Nix
78
79GNU Guix is based on [[http://nixos.org/nix/][the Nix package manager]]. It implements the same
80package deployment paradigm, and in fact it reuses some of its code.
81Yet, different engineering decisions were made for Guix, as described
82below.
83
84Nix is really two things: a package build tool, implemented by a library
85and daemon, and a special-purpose programming language. GNU Guix relies
86on the former, but uses Scheme as a replacement for the latter.
87
88Using Scheme instead of a specific language allows us to get all the
89features and tooling that come with Guile (compiler, debugger, REPL,
90Unicode, libraries, etc.) And it means that we have a general-purpose
91language, on top of which we can have embedded domain-specific languages
92(EDSLs), such as the one used to define packages. This broadens what
93can be done in package recipes themselves, and what can be done around them.
94
95Technically, Guix makes remote procedure calls to the ‘nix-worker’
96daemon to perform operations on the store. At the lowest level, Nix
97“derivations” represent promises of a build, stored in ‘.drv’ files in
98the store. Guix produces such derivations, which are then interpreted
99by the daemon to perform the build. Thus, Guix derivations can use
100derivations produced by Nix (and vice versa).
101
102With Nix and the [[http://nixos.org/nixpkgs][Nixpkgs]] distribution, package composition happens at
103the Nix language level, but builders are usually written in Bash.
104Conversely, Guix encourages the use of Scheme for both package
105composition and builders. Likewise, the core functionality of Nix is
106written in C++ and Perl; Guix relies on some of the original C++ code,
107but exposes all the API as Scheme.
d38487e9
LC
108
109* Related software
110
111 - [[http://nixos.org][Nix, Nixpkgs, and NixOS]], functional package manager and associated
112 software distribution, are the inspiration of Guix
113 - [[http://www.gnu.org/software/stow/][GNU Stow]] builds around the idea of one directory per prefix, and a
114 symlink tree to create user environments
115 - [[http://www.pvv.ntnu.no/~arnej/store/storedoc_6.html][STORE]] shares the same idea
116 - [[https://live.gnome.org/OSTree/][GNOME's OSTree]] allows bootable system images to be built from a
117 specified set of packages
118 - The [[http://www.gnu.org/s/gsrc/][GNU Source Release Collection]] (GSRC) is a user-land software
119 distribution; unlike Guix, it relies on core tools available on the
120 host system