mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-25 20:19:18 -05:00
doc: Improve documentation of the Bash home service
* doc/guix.texi (Shells Home Services): Document ‘home-bash-extension’ configuration record. * gnu/home/services/shells.scm (generate-home-bash-documentation): Extract docstrings from ‘home-bash-extension’. (home-bash-configuration): Expound on docstrings. (home-bash-extension): Likewise. Fixes: <https://issues.guix.gnu.org/50991> Signed-off-by: Ludovic Courtès <ludo@gnu.org>
This commit is contained in:
parent
4b96998292
commit
2f665d4309
2 changed files with 76 additions and 19 deletions
|
@ -36159,6 +36159,7 @@ Extend home-shell-profile service only if you really know what you do.
|
||||||
|
|
||||||
@subsubheading Bash Home Service
|
@subsubheading Bash Home Service
|
||||||
|
|
||||||
|
@anchor{home-bash-configuration}
|
||||||
@deftp {Data Type} home-bash-configuration
|
@deftp {Data Type} home-bash-configuration
|
||||||
Available @code{home-bash-configuration} fields are:
|
Available @code{home-bash-configuration} fields are:
|
||||||
|
|
||||||
|
@ -36167,15 +36168,20 @@ Available @code{home-bash-configuration} fields are:
|
||||||
The Bash package to use.
|
The Bash package to use.
|
||||||
|
|
||||||
@item @code{guix-defaults?} (default: @code{#t}) (type: boolean)
|
@item @code{guix-defaults?} (default: @code{#t}) (type: boolean)
|
||||||
Add sane defaults like reading @file{/etc/bashrc}, coloring output for
|
Add sane defaults like reading @file{/etc/bashrc} and coloring the output of
|
||||||
@code{ls} provided by guix to @file{.bashrc}.
|
@command{ls} to the end of the @file{.bashrc} file.
|
||||||
|
|
||||||
@item @code{environment-variables} (default: @code{()}) (type: alist)
|
@item @code{environment-variables} (default: @code{()}) (type: alist)
|
||||||
Association list of environment variables to set for the Bash session.
|
Association list of environment variables to set for the Bash session. The
|
||||||
|
rules for the @code{home-environment-variables-service-type} apply
|
||||||
|
here (@pxref{Essential Home Services}). The contents of this field will be
|
||||||
|
added after the contents of the @code{bash-profile} field.
|
||||||
|
|
||||||
@item @code{aliases} (default: @code{()}) (type: alist)
|
@item @code{aliases} (default: @code{()}) (type: alist)
|
||||||
Association list of aliases to set for the Bash session. The alias will
|
Association list of aliases to set for the Bash session. The aliases
|
||||||
automatically be quoted, so something line this:
|
will be defined after the contents of the @code{bashrc} field has been
|
||||||
|
put in the @file{.bashrc} file. The alias will automatically be quoted,
|
||||||
|
so something line this:
|
||||||
|
|
||||||
@lisp
|
@lisp
|
||||||
'((\"ls\" . \"ls -alF\"))
|
'((\"ls\" . \"ls -alF\"))
|
||||||
|
@ -36206,7 +36212,41 @@ be read in some cases (if the shell terminates by exec'ing another
|
||||||
process for example).
|
process for example).
|
||||||
|
|
||||||
@end table
|
@end table
|
||||||
|
@end deftp
|
||||||
|
|
||||||
|
You can extend the Bash service by using the @code{home-bash-extension}
|
||||||
|
configuration record, whose fields most mirror that of
|
||||||
|
@code{home-bash-configuration} (@pxref{home-bash-configuration}). The
|
||||||
|
contents of the extensions will be added to the end of the corresponding
|
||||||
|
Bash configuration files (@pxref{Bash Startup Files,,, bash, The GNU
|
||||||
|
Bash Reference Manual}.
|
||||||
|
|
||||||
|
@deftp {Data Type} home-bash-extension
|
||||||
|
Available @code{home-bash-extension} fields are:
|
||||||
|
|
||||||
|
@table @asis
|
||||||
|
@item @code{environment-variables} (default: @code{()}) (type: alist)
|
||||||
|
Additional environment variables to set. These will be combined with the
|
||||||
|
environment variables from other extensions and the base service to form one
|
||||||
|
coherent block of environment variables.
|
||||||
|
|
||||||
|
@item @code{aliases} (default: @code{()}) (type: alist)
|
||||||
|
Additional aliases to set. These will be combined with the aliases from
|
||||||
|
other extensions and the base service.
|
||||||
|
|
||||||
|
@item @code{bash-profile} (default: @code{()}) (type: text-config)
|
||||||
|
Additional text blocks to add to @file{.bash_profile}, which will be combined
|
||||||
|
with text blocks from other extensions and the base service.
|
||||||
|
|
||||||
|
@item @code{bashrc} (default: @code{()}) (type: text-config)
|
||||||
|
Additional text blocks to add to @file{.bashrc}, which will be combined
|
||||||
|
with text blocks from other extensions and the base service.
|
||||||
|
|
||||||
|
@item @code{bash-logout} (default: @code{()}) (type: text-config)
|
||||||
|
Additional text blocks to add to @file{.bash_logout}, which will be combined
|
||||||
|
with text blocks from other extensions and the base service.
|
||||||
|
|
||||||
|
@end table
|
||||||
@end deftp
|
@end deftp
|
||||||
|
|
||||||
@subsubheading Zsh Home Service
|
@subsubheading Zsh Home Service
|
||||||
|
|
|
@ -323,16 +323,21 @@ (define-configuration home-bash-configuration
|
||||||
"The Bash package to use.")
|
"The Bash package to use.")
|
||||||
(guix-defaults?
|
(guix-defaults?
|
||||||
(boolean #t)
|
(boolean #t)
|
||||||
"Add sane defaults like reading @file{/etc/bashrc}, coloring output
|
"Add sane defaults like reading @file{/etc/bashrc} and coloring the output of
|
||||||
for @code{ls} provided by guix to @file{.bashrc}.")
|
@command{ls} to the end of the @file{.bashrc} file.")
|
||||||
(environment-variables
|
(environment-variables
|
||||||
(alist '())
|
(alist '())
|
||||||
"Association list of environment variables to set for the Bash session."
|
"Association list of environment variables to set for the Bash session. The
|
||||||
|
rules for the @code{home-environment-variables-service-type} apply
|
||||||
|
here (@pxref{Essential Home Services}). The contents of this field will be
|
||||||
|
added after the contents of the @code{bash-profile} field."
|
||||||
serialize-posix-env-vars)
|
serialize-posix-env-vars)
|
||||||
(aliases
|
(aliases
|
||||||
(alist '())
|
(alist '())
|
||||||
"Association list of aliases to set for the Bash session. The alias will
|
"Association list of aliases to set for the Bash session. The aliases will be
|
||||||
automatically be quoted, so something line this:
|
defined after the contents of the @code{bashrc} field has been put in the
|
||||||
|
@file{.bashrc} file. The alias will automatically be quoted, so something line
|
||||||
|
this:
|
||||||
|
|
||||||
@lisp
|
@lisp
|
||||||
'((\"ls\" . \"ls -alF\"))
|
'((\"ls\" . \"ls -alF\"))
|
||||||
|
@ -450,19 +455,25 @@ (define (add-bash-packages config)
|
||||||
(define-configuration/no-serialization home-bash-extension
|
(define-configuration/no-serialization home-bash-extension
|
||||||
(environment-variables
|
(environment-variables
|
||||||
(alist '())
|
(alist '())
|
||||||
"Association list of environment variables to set.")
|
"Additional environment variables to set. These will be combined with the
|
||||||
|
environment variables from other extensions and the base service to form one
|
||||||
|
coherent block of environment variables.")
|
||||||
(aliases
|
(aliases
|
||||||
(alist '())
|
(alist '())
|
||||||
"Association list of aliases to set.")
|
"Additional aliases to set. These will be combined with the aliases from
|
||||||
|
other extensions and the base service.")
|
||||||
(bash-profile
|
(bash-profile
|
||||||
(text-config '())
|
(text-config '())
|
||||||
"List of file-like objects.")
|
"Additional text blocks to add to @file{.bash_profile}, which will be combined
|
||||||
|
with text blocks from other extensions and the base service.")
|
||||||
(bashrc
|
(bashrc
|
||||||
(text-config '())
|
(text-config '())
|
||||||
"List of file-like objects.")
|
"Additional text blocks to add to @file{.bashrc}, which will be combined
|
||||||
|
with text blocks from other extensions and the base service.")
|
||||||
(bash-logout
|
(bash-logout
|
||||||
(text-config '())
|
(text-config '())
|
||||||
"List of file-like objects."))
|
"Additional text blocks to add to @file{.bash_logout}, which will be combined
|
||||||
|
with text blocks from other extensions and the base service."))
|
||||||
|
|
||||||
(define (home-bash-extensions original-config extension-configs)
|
(define (home-bash-extensions original-config extension-configs)
|
||||||
(match original-config
|
(match original-config
|
||||||
|
@ -646,10 +657,16 @@ (define (generate-home-shell-profile-documentation)
|
||||||
'home-shell-profile-configuration))
|
'home-shell-profile-configuration))
|
||||||
|
|
||||||
(define (generate-home-bash-documentation)
|
(define (generate-home-bash-documentation)
|
||||||
|
(string-append
|
||||||
(generate-documentation
|
(generate-documentation
|
||||||
`((home-bash-configuration
|
`((home-bash-configuration
|
||||||
,home-bash-configuration-fields))
|
,home-bash-configuration-fields))
|
||||||
'home-bash-configuration))
|
'home-bash-configuration)
|
||||||
|
"\n\n"
|
||||||
|
(generate-documentation
|
||||||
|
`((home-bash-extension
|
||||||
|
,home-bash-extension-fields))
|
||||||
|
'home-bash-extension)))
|
||||||
|
|
||||||
(define (generate-home-zsh-documentation)
|
(define (generate-home-zsh-documentation)
|
||||||
(generate-documentation
|
(generate-documentation
|
||||||
|
|
Loading…
Reference in a new issue