Skip to content
Snippets Groups Projects
guix.texi 108 KiB
Newer Older
  • Learn to ignore specific revisions
  • Ludovic Courtès's avatar
    Ludovic Courtès committed
    sub-directories.  This is the default operation when no option is
    specified.
    
    When @var{min} is given, stop once @var{min} bytes have been collected.
    @var{min} may be a number of bytes, or it may include a unit as a
    suffix, such as @code{MiB} for mebibytes and @code{GB} for gigabytes.
    
    When @var{min} is omitted, collect all the garbage.
    
    @item --delete
    @itemx -d
    Attempt to delete all the store files and directories specified as
    arguments.  This fails if some of the files are not in the store, or if
    they are still live.
    
    @item --list-dead
    Show the list of dead files and directories still present in the
    store---i.e., files and directories no longer reachable from any root.
    
    @item --list-live
    Show the list of live store files and directories.
    
    
    @end table
    
    In addition, the references among existing store files can be queried:
    
    @table @code
    
    @item --references
    @itemx --referrers
    List the references (respectively, the referrers) of store files given
    as arguments.
    
    
    @item --requisites
    @itemx -R
    List the requisites of the store files passed as arguments.  Requisites
    include the store files themselves, their references, and the references
    of these, recursively.  In other words, the returned list is the
    @dfn{transitive closure} of the store files.
    
    
    Ludovic Courtès's avatar
    Ludovic Courtès committed
    @end table
    
    
    Ludovic Courtès's avatar
    Ludovic Courtès committed
    @node Invoking guix pull
    @section Invoking @command{guix pull}
    
    Packages are installed or upgraded to the latest version available in
    the distribution currently available on your local machine.  To update
    that distribution, along with the Guix tools, you must run @command{guix
    pull}: the command downloads the latest Guix source code and package
    descriptions, and deploys it.
    
    On completion, @command{guix package} will use packages and package
    versions from this just-retrieved copy of Guix.  Not only that, but all
    the Guix commands and Scheme modules will also be taken from that latest
    version.  New @command{guix} sub-commands added by the update also
    become available.
    
    The @command{guix pull} command is usually invoked with no arguments,
    but it supports the following options:
    
    @table @code
    @item --verbose
    Produce verbose output, writing build logs to the standard error output.
    
    
    @item --url=@var{url}
    Download the source tarball of Guix from @var{url}.
    
    By default, the tarball is taken from its canonical address at
    @code{gnu.org}, for the stable branch of Guix.
    
    
    Ludovic Courtès's avatar
    Ludovic Courtès committed
    @item --bootstrap
    Use the bootstrap Guile to build the latest Guix.  This option is only
    useful to Guix developers.
    @end table
    
    
    Ludovic Courtès's avatar
    Ludovic Courtès committed
    
    @node Invoking guix archive
    @section Invoking @command{guix archive}
    
    The @command{guix archive} command allows users to @dfn{export} files
    from the store into a single archive, and to later @dfn{import} them.
    In particular, it allows store files to be transferred from one machine
    to another machine's store.  For example, to transfer the @code{emacs}
    package to a machine connected over SSH, one would run:
    
    @example
    guix archive --export emacs | ssh the-machine guix archive --import
    @end example
    
    
    @noindent
    However, note that, in this example, all of @code{emacs} and its
    dependencies are transferred, regardless of what is already available in
    the target machine's store.  The @code{--missing} option can help figure
    out which items are missing from the target's store.
    
    
    Ludovic Courtès's avatar
    Ludovic Courtès committed
    Archives are stored in the ``Nix archive'' or ``Nar'' format, which is
    comparable in spirit to `tar'.  When exporting, the daemon digitally
    signs the contents of the archive, and that digital signature is
    appended.  When importing, the daemon verifies the signature and rejects
    
    the import in case of an invalid signature or if the signing key is not
    authorized.
    
    Ludovic Courtès's avatar
    Ludovic Courtès committed
    @c FIXME: Add xref to daemon doc about signatures.
    
    The main options are:
    
    @table @code
    @item --export
    Export the specified store files or packages (see below.)  Write the
    resulting archive to the standard output.
    
    @item --import
    Read an archive from the standard input, and import the files listed
    therein into the store.  Abort if the archive has an invalid digital
    
    signature, or if it is signed by a public key not among the authorized
    keys (see @code{--authorize} below.)
    
    @item --missing
    Read a list of store file names from the standard input, one per line,
    and write on the standard output the subset of these files missing from
    the store.
    
    
    @item --generate-key[=@var{parameters}]
    
    @cindex signing, archives
    
    Generate a new key pair for the daemons.  This is a prerequisite before
    archives can be exported with @code{--export}.  Note that this operation
    usually takes time, because it needs to gather enough entropy to
    generate the key pair.
    
    The generated key pair is typically stored under @file{/etc/guix}, in
    @file{signing-key.pub} (public key) and @file{signing-key.sec} (private
    key, which must be kept secret.)  When @var{parameters} is omitted, it
    is a 4096-bit RSA key.  Alternately, @var{parameters} can specify
    @code{genkey} parameters suitable for Libgcrypt (@pxref{General
    public-key related Functions, @code{gcry_pk_genkey},, gcrypt, The
    Libgcrypt Reference Manual}).
    
    
    @item --authorize
    @cindex authorizing, archives
    Authorize imports signed by the public key passed on standard input.
    The public key must be in ``s-expression advanced format''---i.e., the
    same format as the @file{signing-key.pub} file.
    
    The list of authorized keys is kept in the human-editable file
    @file{/etc/guix/acl}.  The file contains
    @url{http://people.csail.mit.edu/rivest/Sexp.txt, ``advanced-format
    s-expressions''} and is structured as an access-control list in the
    @url{http://theworld.com/~cme/spki.txt, Simple Public-Key Infrastructure
    (SPKI)}.
    
    Ludovic Courtès's avatar
    Ludovic Courtès committed
    @end table
    
    To export store files as an archive to the standard output, run:
    
    @example
    guix archive --export @var{options} @var{specifications}...
    @end example
    
    @var{specifications} may be either store file names or package
    specifications, as for @command{guix package} (@pxref{Invoking guix
    package}).  For instance, the following command creates an archive
    containing the @code{gui} output of the @code{git} package and the main
    output of @code{emacs}:
    
    @example
    guix archive --export git:gui /nix/store/...-emacs-24.3 > great.nar
    @end example
    
    If the specified packages are not built yet, @command{guix archive}
    automatically builds them.  The build process may be controlled with the
    same options that can be passed to the @command{guix build} command
    (@pxref{Invoking guix build}).
    
    
    
    @c *********************************************************************
    @node Programming Interface
    @chapter Programming Interface
    
    
    GNU Guix provides several Scheme programming interfaces (APIs) to
    define, build, and query packages.  The first interface allows users to
    write high-level package definitions.  These definitions refer to
    familiar packaging concepts, such as the name and version of a package,
    its build system, and its dependencies.  These definitions can then be
    turned into concrete build actions.
    
    
    Ludovic Courtès's avatar
    Ludovic Courtès committed
    Build actions are performed by the Guix daemon, on behalf of users.  In a
    
    standard setup, the daemon has write access to the store---the
    @file{/nix/store} directory---whereas users do not.  The recommended
    setup also has the daemon perform builds in chroots, under a specific
    build users, to minimize interference with the rest of the system.
    
    @cindex derivation
    Lower-level APIs are available to interact with the daemon and the
    store.  To instruct the daemon to perform a build action, users actually
    provide it with a @dfn{derivation}.  A derivation is a low-level
    representation of the build actions to be taken, and the environment in
    which they should occur---derivations are to package definitions what
    assembly is to C programs.
    
    This chapter describes all these APIs in turn, starting from high-level
    package definitions.
    
    
    Ludovic Courtès's avatar
    Ludovic Courtès committed
    * Defining Packages::           Defining new packages.
    * The Store::                   Manipulating the package store.
    * Derivations::                 Low-level interface to package derivations.
    * The Store Monad::             Purely functional interface to the store.
    
    @end menu
    
    @node Defining Packages
    @section Defining Packages
    
    
    The high-level interface to package definitions is implemented in the
    @code{(guix packages)} and @code{(guix build-system)} modules.  As an
    example, the package definition, or @dfn{recipe}, for the GNU Hello
    package looks like this:
    
    @example
    
    (use-modules (guix packages)
                 (guix download)
                 (guix build-system gnu)
                 (guix licenses))
    
    
    (define hello
      (package
        (name "hello")
        (version "2.8")
        (source (origin
                 (method url-fetch)
                 (uri (string-append "mirror://gnu/hello/hello-" version
                                     ".tar.gz"))
                 (sha256
                  (base32 "0wqd8sjmxfskrflaxywc7gqw7sfawrfvdxd9skxawzfgyy0pzdz6"))))
        (build-system gnu-build-system)
        (inputs `(("gawk" ,gawk)))
        (synopsis "GNU Hello")
        (description "Yeah...")
        (home-page "http://www.gnu.org/software/hello/")
    
    @end example
    
    @noindent
    Without being a Scheme expert, the reader may have guessed the meaning
    of the various fields here.  This expression binds variable @var{hello}
    to a @code{<package>} object, which is essentially a record
    (@pxref{SRFI-9, Scheme records,, guile, GNU Guile Reference Manual}).
    This package object can be inspected using procedures found in the
    @code{(guix packages)} module; for instance, @code{(package-name hello)}
    returns---surprise!---@code{"hello"}.
    
    There are a few points worth noting in the above package definition:
    
    @itemize
    @item
    The @code{source} field of the package is an @code{<origin>} object.
    Here, the @code{url-fetch} method from @code{(guix download)} is used,
    meaning that the source is a file to be downloaded over FTP or HTTP.
    
    The @code{mirror://gnu} prefix instructs @code{url-fetch} to use one of
    the GNU mirrors defined in @code{(guix download)}.
    
    The @code{sha256} field specifies the expected SHA256 hash of the file
    being downloaded.  It is mandatory, and allows Guix to check the
    integrity of the file.  The @code{(base32 @dots{})} form introduces the
    
    Nikita Karetnikov's avatar
    Nikita Karetnikov committed
    base32 representation of the hash.  You can obtain this information with
    
    @code{guix download} (@pxref{Invoking guix download}) and @code{guix
    hash} (@pxref{Invoking guix hash}).
    
    @cindex patches
    When needed, the @code{origin} form can also have a @code{patches} field
    listing patches to be applied, and a @code{snippet} field giving a
    Scheme expression to modify the source code.
    
    
    @item
    @cindex GNU Build System
    The @code{build-system} field is set to @var{gnu-build-system}.  The
    @var{gnu-build-system} variable is defined in the @code{(guix
    build-system gnu)} module, and is bound to a @code{<build-system>}
    object.
    
    Naturally, @var{gnu-build-system} represents the familiar GNU Build
    System, and variants thereof (@pxref{Configuration, configuration and
    makefile conventions,, standards, GNU Coding Standards}).  In a
    
    Ludovic Courtès's avatar
    Ludovic Courtès committed
    nutshell, packages using the GNU Build System may be configured, built,
    
    and installed with the usual @code{./configure && make && make check &&
    make install} command sequence.  This is what @var{gnu-build-system}
    does.
    
    In addition, @var{gnu-build-system} ensures that the ``standard''
    environment for GNU packages is available.  This includes tools such as
    GCC, Coreutils, Bash, Make, Diffutils, and Patch.
    
    @item
    The @code{inputs} field specifies inputs to the build process---i.e.,
    build-time or run-time dependencies of the package.  Here, we define an
    input called @code{"gawk"} whose value is that of the @var{gawk}
    variable; @var{gawk} is itself bound to a @code{<package>} object.
    
    Note that GCC, Coreutils, Bash, and other essential tools do not need to
    be specified as inputs here.  Instead, @var{gnu-build-system} takes care
    of ensuring that they are present.
    
    However, any other dependencies need to be specified in the
    @code{inputs} field.  Any dependency not specified here will simply be
    unavailable to the build process, possibly leading to a build failure.
    @end itemize
    
    There are other fields that package definitions may provide.  Of
    particular interest is the @code{arguments} field.  When specified, it
    must be bound to a list of additional arguments to be passed to the
    build system.  For instance, the above definition could be augmented
    with the following field initializer:
    
    @example
        (arguments `(#:tests? #f
                     #:configure-flags '("--enable-silent-rules")))
    @end example
    
    @noindent
    These are keyword arguments (@pxref{Optional Arguments, keyword
    arguments in Guile,, guile, GNU Guile Reference Manual}).  They are
    passed to @var{gnu-build-system}, which interprets them as meaning ``do
    not run @code{make check}'', and ``run @file{configure} with the
    
    @code{--enable-silent-rules} flag''.  The value of these keyword
    parameters is actually evaluated in the @dfn{build stratum}---i.e., by a
    Guile process launched by the daemon (@pxref{Derivations}).
    
    
    Once a package definition is in place@footnote{Simple package
    definitions like the one above may be automatically converted from the
    
    Nixpkgs distribution using the @command{guix import} command.}, the
    package may actually be built using the @code{guix build} command-line
    
    tool (@pxref{Invoking guix build}).  Eventually, updating the package
    definition to a new upstream version can be partly automated by the
    @command{guix refresh} command (@pxref{Invoking guix refresh}).
    
    
    Behind the scenes, a derivation corresponding to the @code{<package>}
    object is first computed by the @code{package-derivation} procedure.
    That derivation is stored in a @code{.drv} file under @file{/nix/store}.
    
    Ludovic Courtès's avatar
    Ludovic Courtès committed
    The build actions it prescribes may then be realized by using the
    
    @code{build-derivations} procedure (@pxref{The Store}).
    
    @deffn {Scheme Procedure} package-derivation @var{store} @var{package} [@var{system}]
    
    Return the @code{<derivation>} object of @var{package} for @var{system}
    (@pxref{Derivations}).
    
    
    @var{package} must be a valid @code{<package>} object, and @var{system}
    must be a string denoting the target system type---e.g.,
    @code{"x86_64-linux"} for an x86_64 Linux-based GNU system.  @var{store}
    must be a connection to the daemon, which operates on the store
    (@pxref{The Store}).
    @end deffn
    
    @noindent
    @cindex cross-compilation
    Similarly, it is possible to compute a derivation that cross-builds a
    package for some other system:
    
    @deffn {Scheme Procedure} package-cross-derivation @var{store} @
                @var{package} @var{target} [@var{system}]
    
    Return the @code{<derivation>} object of @var{package} cross-built from
    @var{system} to @var{target}.
    
    
    @var{target} must be a valid GNU triplet denoting the target hardware
    and operating system, such as @code{"mips64el-linux-gnu"}
    (@pxref{Configuration Names, GNU configuration triplets,, configure, GNU
    Configure and Build System}).
    @end deffn
    
    
    
    @node The Store
    @section The Store
    
    
    @cindex store
    @cindex store paths
    
    Conceptually, the @dfn{store} is where derivations that have been
    successfully built are stored---by default, under @file{/nix/store}.
    Sub-directories in the store are referred to as @dfn{store paths}.  The
    store has an associated database that contains information such has the
    store paths referred to by each store path, and the list of @emph{valid}
    store paths---paths that result from a successful build.
    
    The store is always accessed by the daemon on behalf of its clients
    (@pxref{Invoking guix-daemon}).  To manipulate the store, clients
    connect to the daemon over a Unix-domain socket, send it requests, and
    read the result---these are remote procedure calls, or RPCs.
    
    The @code{(guix store)} module provides procedures to connect to the
    daemon, and to perform RPCs.  These are described below.
    
    @deffn {Scheme Procedure} open-connection [@var{file}] [#:reserve-space? #t]
    Connect to the daemon over the Unix-domain socket at @var{file}.  When
    @var{reserve-space?} is true, instruct it to reserve a little bit of
    extra space on the file system so that the garbage collector can still
    operate, should the disk become full.  Return a server object.
    
    @var{file} defaults to @var{%default-socket-path}, which is the normal
    location given the options that were passed to @command{configure}.
    @end deffn
    
    @deffn {Scheme Procedure} close-connection @var{server}
    Close the connection to @var{server}.
    @end deffn
    
    @defvr {Scheme Variable} current-build-output-port
    This variable is bound to a SRFI-39 parameter, which refers to the port
    where build and error logs sent by the daemon should be written.
    @end defvr
    
    Procedures that make RPCs all take a server object as their first
    argument.
    
    @deffn {Scheme Procedure} valid-path? @var{server} @var{path}
    Return @code{#t} when @var{path} is a valid store path.
    @end deffn
    
    
    @deffn {Scheme Procedure} add-text-to-store @var{server} @var{name} @var{text} [@var{references}]
    
    Add @var{text} under file @var{name} in the store, and return its store
    path.  @var{references} is the list of store paths referred to by the
    resulting store path.
    @end deffn
    
    
    @deffn {Scheme Procedure} build-derivations @var{server} @var{derivations}
    
    Build @var{derivations} (a list of @code{<derivation>} objects or
    derivation paths), and return when the worker is done building them.
    Return @code{#t} on success.
    
    Ludovic Courtès's avatar
    Ludovic Courtès committed
    Note that the @code{(guix monads)} module provides a monad as well as
    monadic versions of the above procedures, with the goal of making it
    more convenient to work with code that accesses the store (@pxref{The
    Store Monad}).
    
    
    @c FIXME
    @i{This section is currently incomplete.}
    
    
    @node Derivations
    @section Derivations
    
    
    @cindex derivations
    Low-level build actions and the environment in which they are performed
    are represented by @dfn{derivations}.  A derivation contain the
    following pieces of information:
    
    @itemize
    @item
    The outputs of the derivation---derivations produce at least one file or
    directory in the store, but may produce more.
    
    @item
    The inputs of the derivations, which may be other derivations or plain
    files in the store (patches, build scripts, etc.)
    
    @item
    The system type targeted by the derivation---e.g., @code{x86_64-linux}.
    
    @item
    The file name of a build script in the store, along with the arguments
    to be passed.
    
    @item
    A list of environment variables to be defined.
    
    @end itemize
    
    @cindex derivation path
    Derivations allow clients of the daemon to communicate build actions to
    the store.  They exist in two forms: as an in-memory representation,
    both on the client- and daemon-side, and as files in the store whose
    name end in @code{.drv}---these files are referred to as @dfn{derivation
    paths}.  Derivations paths can be passed to the @code{build-derivations}
    procedure to perform the build actions they prescribe (@pxref{The
    Store}).
    
    The @code{(guix derivations)} module provides a representation of
    derivations as Scheme objects, along with procedures to create and
    otherwise manipulate derivations.  The lowest-level primitive to create
    a derivation is the @code{derivation} procedure:
    
    
    @deffn {Scheme Procedure} derivation @var{store} @var{name} @var{builder} @
      @var{args} [#:outputs '("out")] [#:hash #f] [#:hash-algo #f] @
      [#:hash-mode #f] [#:inputs '()] [#:env-vars '()] @
      [#:system (%current-system)] [#:references-graphs #f] @
      [#:local-build? #f]
    
    Build a derivation with the given arguments, and return the resulting
    @code{<derivation>} object.
    
    
    When @var{hash}, @var{hash-algo}, and @var{hash-mode} are given, a
    @dfn{fixed-output derivation} is created---i.e., one whose result is
    known in advance, such as a file download.
    
    When @var{references-graphs} is true, it must be a list of file
    
    name/store path pairs.  In that case, the reference graph of each store
    path is exported in the build environment in the corresponding file, in
    a simple text format.
    
    
    When @var{local-build?} is true, declare that the derivation is not a
    good candidate for offloading and should rather be built locally
    (@pxref{Daemon Offload Setup}).  This is the case for small derivations
    where the costs of data transfers would outweigh the benefits.
    
    @end deffn
    
    @noindent
    Here's an example with a shell script as its builder, assuming
    @var{store} is an open connection to the daemon, and @var{bash} points
    to a Bash executable in the store:
    
    @lisp
    (use-modules (guix utils)
                 (guix store)
                 (guix derivations))
    
    
    (let ((builder   ; add the Bash script to the store
            (add-text-to-store store "my-builder.sh"
                               "echo hello world > $out\n" '())))
      (derivation store "foo"
                  bash `("-e" ,builder)
                  #:env-vars '(("HOME" . "/homeless"))))
    @result{} #<derivation /nix/store/@dots{}-foo.drv => /nix/store/@dots{}-foo>
    
    @end lisp
    
    As can be guessed, this primitive is cumbersome to use directly.  An
    improved variant is @code{build-expression->derivation}, which allows
    the caller to directly pass a Guile expression as the build script:
    
    
    @deffn {Scheme Procedure} build-expression->derivation @var{store} @
           @var{name} @var{exp} @
           [#:system (%current-system)] [#:inputs '()] @
           [#:outputs '("out")] [#:hash #f] [#:hash-algo #f] @
           [#:env-vars '()] [#:modules '()] @
    
           [#:references-graphs #f] [#:local-build? #f] [#:guile-for-build #f]
    
    Return a derivation that executes Scheme expression @var{exp} as a
    builder for derivation @var{name}.  @var{inputs} must be a list of
    @code{(name drv-path sub-drv)} tuples; when @var{sub-drv} is omitted,
    @code{"out"} is assumed.  @var{modules} is a list of names of Guile
    modules from the current search path to be copied in the store,
    compiled, and made available in the load path during the execution of
    @var{exp}---e.g., @code{((guix build utils) (guix build
    gnu-build-system))}.
    
    @var{exp} is evaluated in an environment where @code{%outputs} is bound
    to a list of output/path pairs, and where @code{%build-inputs} is bound
    to a list of string/output-path pairs made from @var{inputs}.
    Optionally, @var{env-vars} is a list of string pairs specifying the name
    and value of environment variables visible to the builder.  The builder
    terminates by passing the result of @var{exp} to @code{exit}; thus, when
    @var{exp} returns @code{#f}, the build is considered to have failed.
    
    @var{exp} is built using @var{guile-for-build} (a derivation).  When
    @var{guile-for-build} is omitted or is @code{#f}, the value of the
    @code{%guile-for-build} fluid is used instead.
    
    See the @code{derivation} procedure for the meaning of @var{references-graphs}
    and @var{local-build?}.
    
    @end deffn
    
    @noindent
    Here's an example of a single-output derivation that creates a directory
    containing one file:
    
    @lisp
    (let ((builder '(let ((out (assoc-ref %outputs "out")))
                      (mkdir out)    ; create /nix/store/@dots{}-goo
                      (call-with-output-file (string-append out "/test")
                        (lambda (p)
                          (display '(hello guix) p))))))
    
      (build-expression->derivation store "goo" builder))
    
    @result{} #<derivation /nix/store/@dots{}-goo.drv => @dots{}>
    
    @end lisp
    
    @cindex strata of code
    Remember that the build expression passed to
    @code{build-expression->derivation} is run by a separate Guile process
    than the one that calls @code{build-expression->derivation}: it is run
    by a Guile process launched by the daemon, typically in a chroot.  So,
    while there is a single language for both the @dfn{host} and the build
    side, there are really two @dfn{strata} of code: the host-side, and the
    build-side code@footnote{The term @dfn{stratum} in this context was
    coined by Manuel Serrano et al. in the context of their work on Hop.}.
    This distinction is important to keep in mind, notably when using
    higher-level constructs such as @var{gnu-build-system} (@pxref{Defining
    Packages}).  For this reason, Guix modules that are meant to be used in
    the build stratum are kept in the @code{(guix build @dots{})} name
    space.
    
    Ludovic Courtès's avatar
    Ludovic Courtès committed
    @node The Store Monad
    @section The Store Monad
    
    @cindex monad
    
    The procedures that operate on the store described in the previous
    sections all take an open connection to the build daemon as their first
    argument.  Although the underlying model is functional, they either have
    side effects or depend on the current state of the store.
    
    The former is inconvenient: the connection to the build daemon has to be
    carried around in all those functions, making it impossible to compose
    functions that do not take that parameter with functions that do.  The
    latter can be problematic: since store operations have side effects
    and/or depend on external state, they have to be properly sequenced.
    
    @cindex monadic values
    @cindex monadic functions
    This is where the @code{(guix monads)} module comes in.  This module
    provides a framework for working with @dfn{monads}, and a particularly
    useful monad for our uses, the @dfn{store monad}.  Monads are a
    construct that allows two things: associating ``context'' with values
    (in our case, the context is the store), and building sequences of
    computations (here computations includes accesses to the store.)  Values
    in a monad---values that carry this additional context---are called
    @dfn{monadic values}; procedures that return such values are called
    @dfn{monadic procedures}.
    
    Consider this ``normal'' procedure:
    
    @example
    
    (define (sh-symlink store)
      ;; Return a derivation that symlinks the 'bash' executable.
      (let* ((drv (package-derivation store bash))
             (out (derivation->output-path drv))
             (sh  (string-append out "/bin/bash")))
        (build-expression->derivation store "sh"
                                      `(symlink ,sh %output))))
    
    Ludovic Courtès's avatar
    Ludovic Courtès committed
    @end example
    
    Using @code{(guix monads)}, it may be rewritten as a monadic function:
    
    @example
    
    (define (sh-symlink)
    
    Ludovic Courtès's avatar
    Ludovic Courtès committed
      ;; Same, but return a monadic value.
    
      (mlet %store-monad ((sh (package-file bash "bin")))
        (derivation-expression "sh" `(symlink ,sh %output))))
    
    Ludovic Courtès's avatar
    Ludovic Courtès committed
    @end example
    
    There are two things to note in the second version: the @code{store}
    parameter is now implicit, and the monadic value returned by
    @code{package-file}---a wrapper around @code{package-derivation} and
    @code{derivation->output-path}---is @dfn{bound} using @code{mlet}
    instead of plain @code{let}.
    
    Calling the monadic @code{profile.sh} has no effect.  To get the desired
    effect, one must use @code{run-with-store}:
    
    @example
    (run-with-store (open-connection) (profile.sh))
    @result{} /nix/store/...-profile.sh
    @end example
    
    The main syntactic forms to deal with monads in general are described
    below.
    
    @deffn {Scheme Syntax} with-monad @var{monad} @var{body} ...
    Evaluate any @code{>>=} or @code{return} forms in @var{body} as being
    in @var{monad}.
    @end deffn
    
    @deffn {Scheme Syntax} return @var{val}
    Return a monadic value that encapsulates @var{val}.
    @end deffn
    
    @deffn {Scheme Syntax} >>= @var{mval} @var{mproc}
    @dfn{Bind} monadic value @var{mval}, passing its ``contents'' to monadic
    procedure @var{mproc}@footnote{This operation is commonly referred to as
    ``bind'', but that name denotes an unrelated procedure in Guile.  Thus
    we use this somewhat cryptic symbol inherited from the Haskell
    language.}.
    @end deffn
    
    @deffn {Scheme Syntax} mlet @var{monad} ((@var{var} @var{mval}) ...) @
           @var{body} ...
    @deffnx {Scheme Syntax} mlet* @var{monad} ((@var{var} @var{mval}) ...) @
           @var{body} ...
    Bind the variables @var{var} to the monadic values @var{mval} in
    @var{body}.  The form (@var{var} -> @var{val}) binds @var{var} to the
    ``normal'' value @var{val}, as per @code{let}.
    
    @code{mlet*} is to @code{mlet} what @code{let*} is to @code{let}
    (@pxref{Local Bindings,,, guile, GNU Guile Reference Manual}).
    @end deffn
    
    The interface to the store monad provided by @code{(guix monads)} is as
    follows.
    
    @defvr {Scheme Variable} %store-monad
    The store monad.  Values in the store monad encapsulate accesses to the
    store.  When its effect is needed, a value of the store monad must be
    ``evaluated'' by passing it to the @code{run-with-store} procedure (see
    below.)
    @end defvr
    
    @deffn {Scheme Procedure} run-with-store @var{store} @var{mval} [#:guile-for-build] [#:system (%current-system)]
    Run @var{mval}, a monadic value in the store monad, in @var{store}, an
    open store connection.
    @end deffn
    
    @deffn {Monadic Procedure} text-file @var{name} @var{text}
    Return as a monadic value the absolute file name in the store of the file
    
    containing @var{text}, a string.
    @end deffn
    
    @deffn {Monadic Procedure} text-file* @var{name} @var{text} @dots{}
    Return as a monadic value a derivation that builds a text file
    containing all of @var{text}.  @var{text} may list, in addition to
    strings, packages, derivations, and store file names; the resulting
    store file holds references to all these.
    
    This variant should be preferred over @code{text-file} anytime the file
    to create will reference items from the store.  This is typically the
    case when building a configuration file that embeds store file names,
    like this:
    
    @example
    (define (profile.sh)
      ;; Return the name of a shell script in the store that
      ;; initializes the 'PATH' environment variable.
      (text-file* "profile.sh"
                  "export PATH=" coreutils "/bin:"
                  grep "/bin:" sed "/bin\n"))
    @end example
    
    In this example, the resulting @file{/nix/store/@dots{}-profile.sh} file
    will references @var{coreutils}, @var{grep}, and @var{sed}, thereby
    preventing them from being garbage-collected during its lifetime.
    
    Ludovic Courtès's avatar
    Ludovic Courtès committed
    @end deffn
    
    @deffn {Monadic Procedure} package-file @var{package} [@var{file}] @
           [#:system (%current-system)] [#:output "out"] Return as a monadic
    value in the absolute file name of @var{file} within the @var{output}
    directory of @var{package}.  When @var{file} is omitted, return the name
    of the @var{output} directory of @var{package}.
    @end deffn
    
    
    @deffn {Monadic Procedure} derivation-expression @var{name} @var{exp} @
           [#:system (%current-system)] [#:inputs '()] @
           [#:outputs '("out")] [#:hash #f] @
    
    Ludovic Courtès's avatar
    Ludovic Courtès committed
           [#:hash-algo #f] [#:env-vars '()] [#:modules '()] @
           [#:references-graphs #f] [#:guile-for-build #f]
    Monadic version of @code{build-expression->derivation}
    (@pxref{Derivations}).
    @end deffn
    
    @deffn {Monadic Procedure} package->derivation @var{package} [@var{system}]
    Monadic version of @code{package-derivation} (@pxref{Defining
    Packages}).
    @end deffn
    
    
    
    @c *********************************************************************
    @node Utilities
    @chapter Utilities
    
    
    This section describes tools primarily targeted at developers and users
    who write new package definitions.  They complement the Scheme
    programming interface of Guix in a convenient way.
    
    
    * Invoking guix build::         Building packages from the command line.
    
    * Invoking guix download::      Downloading a file and printing its hash.
    
    * Invoking guix hash::          Computing the cryptographic hash of a file.
    * Invoking guix refresh::       Updating package definitions.
    
    @node Invoking guix build
    @section Invoking @command{guix build}
    
    The @command{guix build} command builds packages or derivations and
    
    their dependencies, and prints the resulting store paths.  Note that it
    does not modify the user's profile---this is the job of the
    
    @command{guix package} command (@pxref{Invoking guix package}).  Thus,
    
    it is mainly useful for distribution developers.
    
    The general syntax is:
    
    guix build @var{options} @var{package-or-derivation}@dots{}
    
    @end example
    
    @var{package-or-derivation} may be either the name of a package found in
    
    the software distribution such as @code{coreutils} or
    @code{coreutils-8.20}, or a derivation such as
    @file{/nix/store/@dots{}-coreutils-8.19.drv}.  Alternatively, the
    
    @code{--expression} option may be used to specify a Scheme expression
    that evaluates to a package; this is useful when disambiguation among
    several same-named packages or package variants is needed.
    
    The @var{options} may be zero or more of the following:
    
    @table @code
    
    @item --expression=@var{expr}
    @itemx -e @var{expr}
    
    Build the package or derivation @var{expr} evaluates to.
    
    For example, @var{expr} may be @code{(@@ (gnu packages guile)
    
    guile-1.8)}, which unambiguously designates this specific variant of
    version 1.8 of Guile.
    
    
    Alternately, @var{expr} may refer to a zero-argument monadic procedure
    (@pxref{The Store Monad}).  The procedure must return a derivation as a
    monadic value, which is then passed through @code{run-with-store}.
    
    
    @item --source
    @itemx -S
    Build the packages' source derivations, rather than the packages
    themselves.
    
    
    For instance, @code{guix build -S gcc} returns something like
    
    @file{/nix/store/@dots{}-gcc-4.7.2.tar.bz2}, which is GCC's source tarball.
    
    The returned source tarball is the result of applying any patches and
    code snippets specified in the package's @code{origin} (@pxref{Defining
    Packages}).
    
    
    @item --system=@var{system}
    @itemx -s @var{system}
    Attempt to build for @var{system}---e.g., @code{i686-linux}---instead of
    the host's system type.
    
    An example use of this is on Linux-based systems, which can emulate
    different personalities.  For instance, passing
    @code{--system=i686-linux} on an @code{x86_64-linux} system allows users
    to build packages in a complete 32-bit environment.
    
    
    @item --target=@var{triplet}
    @cindex cross-compilation
    Cross-build for @var{triplet}, which must be a valid GNU triplet, such
    as @code{"mips64el-linux-gnu"} (@pxref{Configuration Names, GNU
    configuration triplets,, configure, GNU Configure and Build System}).
    
    
    @item --derivations
    @itemx -d
    Return the derivation paths, not the output paths, of the given
    packages.
    
    @item --keep-failed
    @itemx -K
    Keep the build tree of failed builds.  Thus, if a build fail, its build
    tree is kept under @file{/tmp}, in a directory whose name is shown at
    the end of the build log.  This is useful when debugging build issues.
    
    @item --dry-run
    @itemx -n
    Do not build the derivations.
    
    
    @item --fallback
    When substituting a pre-built binary fails, fall back to building
    packages locally.
    
    
    @item --no-substitutes
    
    Do not use substitutes for build products.  That is, always build things
    locally instead of allowing downloads of pre-built binaries.
    
    @item --no-build-hook
    
    Do not attempt to offload builds @i{via} the daemon's ``build hook''
    (@pxref{Daemon Offload Setup}).  That is, always build things locally
    instead of offloading builds to remote machines.
    
    @item --max-silent-time=@var{seconds}
    When the build or substitution process remains silent for more than
    @var{seconds}, terminate it and report a build failure.
    
    
    @item --cores=@var{n}
    @itemx -c @var{n}
    Allow the use of up to @var{n} CPU cores for the build.  The special
    value @code{0} means to use as many CPU cores as available.
    
    @item --root=@var{file}
    @itemx -r @var{file}
    Make @var{file} a symlink to the result, and register it as a garbage
    collector root.
    
    
    @item --verbosity=@var{level}
    Use the given verbosity level.  @var{level} must be an integer between 0
    and 5; higher means more verbose output.  Setting a level of 4 or more
    may be helpful when debugging setup issues with the build daemon.
    
    
    @item --log-file
    Return the build log file names for the given
    @var{package-or-derivation}s, or raise an error if build logs are
    missing.
    
    This works regardless of how packages or derivations are specified.  For
    instance, the following invocations are equivalent:
    
    @example
    guix build --log-file `guix build -d guile`
    guix build --log-file `guix build guile`
    guix build --log-file guile
    guix build --log-file -e '(@@ (gnu packages guile) guile-2.0)'
    @end example
    
    
    
    Behind the scenes, @command{guix build} is essentially an interface to
    
    the @code{package-derivation} procedure of the @code{(guix packages)}
    module, and to the @code{build-derivations} procedure of the @code{(guix
    store)} module.
    
    
    @node Invoking guix download
    @section Invoking @command{guix download}
    
    When writing a package definition, developers typically need to download
    the package's source tarball, compute its SHA256 hash, and write that
    hash in the package definition (@pxref{Defining Packages}).  The
    @command{guix download} tool helps with this task: it downloads a file
    from the given URI, adds it to the store, and prints both its file name
    in the store and its SHA256 hash.
    
    The fact that the downloaded file is added to the store saves bandwidth:
    when the developer eventually tries to build the newly defined package
    with @command{guix build}, the source tarball will not have to be
    downloaded again because it is already in the store.  It is also a
    convenient way to temporarily stash files, which may be deleted
    eventually (@pxref{Invoking guix gc}).
    
    The @command{guix download} command supports the same URIs as used in
    package definitions.  In particular, it supports @code{mirror://} URIs.
    @code{https} URIs (HTTP over TLS) are supported @emph{provided} the
    Guile bindings for GnuTLS are available in the user's environment; when
    they are not available, an error is raised.
    
    The following option is available:
    
    @table @code
    @item --format=@var{fmt}
    @itemx -f @var{fmt}
    Write the hash in the format specified by @var{fmt}.  For more
    information on the valid values for @var{fmt}, @ref{Invoking guix hash}.
    @end table
    
    
    Nikita Karetnikov's avatar
    Nikita Karetnikov committed
    @node Invoking guix hash
    @section Invoking @command{guix hash}
    
    
    The @command{guix hash} command computes the SHA256 hash of a file.
    
    Nikita Karetnikov's avatar
    Nikita Karetnikov committed
    It is primarily a convenience tool for anyone contributing to the
    distribution: it computes the cryptographic hash of a file, which can be
    used in the definition of a package (@pxref{Defining Packages}).
    
    The general syntax is:
    
    @example
    guix hash @var{option} @var{file}
    @end example
    
    @command{guix hash} has the following option:
    
    @table @code
    
    @item --format=@var{fmt}
    @itemx -f @var{fmt}
    
    Write the hash in the format specified by @var{fmt}.
    
    Nikita Karetnikov's avatar
    Nikita Karetnikov committed
    
    Supported formats: @code{nix-base32}, @code{base32}, @code{base16}
    (@code{hex} and @code{hexadecimal} can be used as well).
    
    If the @option{--format} option is not specified, @command{guix hash}
    will output the hash in @code{nix-base32}.  This representation is used
    in the definitions of packages.
    
    @end table
    
    
    @node Invoking guix refresh
    @section Invoking @command{guix refresh}
    
    The primary audience of the @command{guix refresh} command is developers
    of the GNU software distribution.  By default, it reports any packages
    provided by the distribution that are outdated compared to the latest
    upstream version, like this:
    
    @example
    $ guix refresh
    gnu/packages/gettext.scm:29:13: gettext would be upgraded from 0.18.1.1 to 0.18.2.1
    gnu/packages/glib.scm:77:12: glib would be upgraded from 2.34.3 to 2.37.0
    @end example
    
    It does so by browsing each package's FTP directory and determining the
    highest version number of the source tarballs
    therein@footnote{Currently, this only works for GNU packages.}.
    
    When passed @code{--update}, it modifies distribution source files to
    update the version numbers and source tarball hashes of those packages'
    recipes (@pxref{Defining Packages}).  This is achieved by downloading
    each package's latest source tarball and its associated OpenPGP
    signature, authenticating the downloaded tarball against its signature
    using @command{gpg}, and finally computing its hash.  When the public
    key used to sign the tarball is missing from the user's keyring, an
    attempt is made to automatically retrieve it from a public key server;
    when it's successful, the key is added to the user's keyring; otherwise,
    @command{guix refresh} reports an error.
    
    The following options are supported:
    
    @table @code
    
    @item --update
    @itemx -u
    Update distribution source files (package recipes) in place.
    @ref{Defining Packages}, for more information on package definitions.