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:
Xinglu Chen 2021-11-07 12:36:29 +01:00 committed by Ludovic Courtès
parent 4b96998292
commit 2f665d4309
No known key found for this signature in database
GPG key ID: 090B11993D9AEBB5
2 changed files with 76 additions and 19 deletions

View file

@ -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

View file

@ -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