mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-11 21:59:08 -05:00
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:
parent
2573410865
commit
fe36d84eae
3 changed files with 45 additions and 4 deletions
3
doc.am
3
doc.am
|
@ -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
13
doc/environment-gdb.scm
Normal 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))))
|
|
@ -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.
|
||||||
|
|
Loading…
Reference in a new issue