doc: Add 'guix environment' examples.

* doc/environment-gdb.scm: New file.
* doc.am (EXTRA_DIST): Add it.
* doc/guix.texi (Invoking guix environment): Clarify wording of the first
  example.  Add a --ad-hoc example upfront.  Add an example for '-e', and one
  for '-l'.
This commit is contained in:
Ludovic Courtès 2015-06-29 22:25:43 +02:00
parent 2573410865
commit fe36d84eae
3 changed files with 45 additions and 4 deletions

3
doc.am
View file

@ -24,7 +24,8 @@ EXTRA_DIST += \
doc/fdl-1.3.texi \ doc/fdl-1.3.texi \
doc/images/bootstrap-graph.dot \ doc/images/bootstrap-graph.dot \
doc/images/bootstrap-graph.eps \ doc/images/bootstrap-graph.eps \
doc/images/bootstrap-graph.pdf doc/images/bootstrap-graph.pdf \
doc/environment-gdb.scm
OS_CONFIG_EXAMPLES_TEXI = \ OS_CONFIG_EXAMPLES_TEXI = \
doc/os-config-bare-bones.texi \ doc/os-config-bare-bones.texi \

13
doc/environment-gdb.scm Normal file
View file

@ -0,0 +1,13 @@
(use-modules (guix)
(gnu packages gdb)
(gnu packages autotools)
(gnu packages texinfo))
;; Augment the package definition of GDB with the build tools
;; needed when developing GDB (and which are not needed when
;; simply installing it.)
(package (inherit gdb)
(native-inputs `(("autoconf" ,autoconf-2.64)
("automake" ,automake)
("texinfo" ,texinfo)
,@(package-native-inputs gdb))))

View file

@ -4110,6 +4110,7 @@ Consider packages for @var{system}---e.g., @code{x86_64-linux}.
@section Invoking @command{guix environment} @section Invoking @command{guix environment}
@cindex reproducible build environments @cindex reproducible build environments
@cindex development environments
The purpose of @command{guix environment} is to assist hackers in The purpose of @command{guix environment} is to assist hackers in
creating reproducible development environments without polluting their creating reproducible development environments without polluting their
package profile. The @command{guix environment} tool takes one or more package profile. The @command{guix environment} tool takes one or more
@ -4122,8 +4123,8 @@ The general syntax is:
guix environment @var{options} @var{package}@dots{} guix environment @var{options} @var{package}@dots{}
@end example @end example
The following examples spawns a new shell that is capable of building The following example spawns a new shell set up for the development of
the GNU Guile source code: GNU@tie{}Guile:
@example @example
guix environment guile guix environment guile
@ -4153,18 +4154,44 @@ Sometimes an interactive shell session is not desired. The
guix environment guile --exec=make guix environment guile --exec=make
@end example @end example
The following options are available: In other situations, it is more convenient to specify the list of
packages needed in the environment. For example, the following command
runs @command{python} from an environment containing Python@tie{}2.7 and
NumPy:
@example
guix environment --ad-hoc python2-numpy python-2.7 -E python
@end example
The available options are summarized below.
@table @code @table @code
@item --expression=@var{expr} @item --expression=@var{expr}
@itemx -e @var{expr} @itemx -e @var{expr}
Create an environment for the package that @var{expr} evaluates to. Create an environment for the package that @var{expr} evaluates to.
For example, running:
@example
guix environment -e '(@@ (gnu packages maths) petsc-openmpi)'
@end example
starts a shell with the environment for this specific variant of the
PETSc package.
@item --load=@var{file} @item --load=@var{file}
@itemx -l @var{file} @itemx -l @var{file}
Create an environment for the package that the code within @var{file} Create an environment for the package that the code within @var{file}
evaluates to. evaluates to.
As an example, @var{file} might contain a definition like this
(@pxref{Defining Packages}):
@example
@verbatiminclude environment-gdb.scm
@end example
@item --exec=@var{command} @item --exec=@var{command}
@item -E @var{command} @item -E @var{command}
Execute @var{command} in the new environment. Execute @var{command} in the new environment.