From: Andrew Tropin <andrewtropin@gmail.com>
To: Oleg Pykhalov <go.wigust@gmail.com>, 50967@debbugs.gnu.org
Cc: Oleg Pykhalov <go.wigust@gmail.com>
Subject: [bug#50967] [PATCH 13/14] home: services: configuration: Support file-like objects.
Date: Thu, 14 Oct 2021 10:08:03 +0300 [thread overview]
Message-ID: <87lf2wt770.fsf@trop.in> (raw)
In-Reply-To: <20211002163834.29583-13-go.wigust@gmail.com>
[-- Attachment #1: Type: text/plain, Size: 3877 bytes --]
On 2021-10-02 19:38, Oleg Pykhalov wrote:
> * gnu/home/services/configuration.scm (interpose): Include content of files.
> (string-or-gexp?): Rename to 'file-or-string-or-gexp?' and check for file-like
> object.
> (serialize-string-or-gexp): Rename to 'serialize-file-or-string-or-gexp'.
> (text-config?): Call 'file-or-string-or-gexp?' intead of 'string-or-gexp?'.
> * guix/scripts/home/import.scm:
> (generate-bash-module+configuration): Don't call slurp-file-gexp.
> ---
> gnu/home/services/configuration.scm | 14 ++++++++++----
> guix/scripts/home/import.scm | 8 +++-----
> 2 files changed, 13 insertions(+), 9 deletions(-)
>
> diff --git a/gnu/home/services/configuration.scm b/gnu/home/services/configuration.scm
> index 5e7743e7d6..39db7a5693 100644
> --- a/gnu/home/services/configuration.scm
> +++ b/gnu/home/services/configuration.scm
> @@ -59,7 +59,12 @@ DELIMITER interposed LS. Support 'infix and 'suffix GRAMMAR values."
> (G_ "The GRAMMAR value must be 'infix or 'suffix, but ~a provided.")
> grammar)))
> (fold-right (lambda (e acc)
> - (cons e
> + (cons (if (file-like? e)
> + #~(begin
> + (use-modules (ice-9 rdelim))
> + (with-fluids ((%default-port-encoding "UTF-8"))
> + (with-input-from-file #$e read-string)))
This transformation should not be a part of interpose function,
interpose does know nothing about elements type and doesn't have to
know. This addition is semantically incorrect and also contradictionary
to docstring. It also breaks downstream channels.
The version of change in master is different, it doesn't even check
element type.
I'm strongly against this change. If it necessary to make
transformation of elements of the list it should be done outside of
interpose.
> + e)
> (if (and (null? acc) (eq? grammar 'infix))
> acc
> (cons delimiter acc))))
> @@ -79,11 +84,12 @@ the list result in @code{#t} when applying PRED? on them."
>
> (define alist? list?)
>
> -(define (string-or-gexp? sg) (or (string? sg) (gexp? sg)))
> -(define (serialize-string-or-gexp field-name val) "")
> +(define (file-or-string-or-gexp? fsg)
> + (or (string? fsg) (gexp? fsg) (file-like? fsg)))
> +(define (serialize-file-or-string-or-gexp field-name val) "")
>
> (define (text-config? config)
> - (and (list? config) (every string-or-gexp? config)))
> + (and (list? config) (every file-or-string-or-gexp? config)))
> (define (serialize-text-config field-name val)
> #~(string-append #$@(interpose val "\n" 'suffix)))
>
> diff --git a/guix/scripts/home/import.scm b/guix/scripts/home/import.scm
> index c977ec3861..611f580e85 100644
> --- a/guix/scripts/home/import.scm
> +++ b/guix/scripts/home/import.scm
> @@ -46,17 +46,15 @@
> (home-bash-configuration
> ,@(if (file-exists? rc)
> `((bashrc
> - (list (slurp-file-gexp (local-file ,rc)))))
> + (list (local-file ,rc))))
> '())
> ,@(if (file-exists? profile)
> `((bash-profile
> - (list (slurp-file-gexp
> - (local-file ,profile)))))
> + (list (local-file ,profile))))
> '())
> ,@(if (file-exists? logout)
> `((bash-logout
> - (list (slurp-file-gexp
> - (local-file ,logout)))))
> + (list (local-file ,logout))))
> '()))))))
--
Best regards,
Andrew Tropin
[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 832 bytes --]
next prev parent reply other threads:[~2021-10-14 15:23 UTC|newest]
Thread overview: 64+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-10-02 13:43 [bug#50967] [PATCH 00/12] Move (gnu home-services XYZ) to (gnu services XYZ) Oleg Pykhalov
2021-10-02 13:45 ` [bug#50967] [PATCH 01/12] tests: Add tests for guix home cli Oleg Pykhalov
2021-10-02 13:45 ` [bug#50967] [PATCH 02/12] gnu: home-services: Move configuration to (gnu services) Oleg Pykhalov
2021-10-02 13:45 ` [bug#50967] [PATCH 03/12] gnu: home-services: Move symlink-manager " Oleg Pykhalov
2021-10-02 13:45 ` [bug#50967] [PATCH 04/12] gnu: home-services: Move utils " Oleg Pykhalov
2021-10-02 13:45 ` [bug#50967] [PATCH 05/12] gnu: home-services: Move fontutils " Oleg Pykhalov
2021-10-02 13:45 ` [bug#50967] [PATCH 06/12] gnu: home-services: Move shells " Oleg Pykhalov
2021-10-02 13:45 ` [bug#50967] [PATCH 07/12] gnu: home-services: Move xdg " Oleg Pykhalov
2021-10-02 13:45 ` [bug#50967] [PATCH 08/12] gnu: home-services: Move shepherd " Oleg Pykhalov
2021-10-02 13:46 ` [bug#50967] [PATCH 09/12] gnu: home-services: Move mcron " Oleg Pykhalov
2021-10-02 13:46 ` [bug#50967] [PATCH 10/12] gnu: home-services: Change %service-type-path and filter services Oleg Pykhalov
2021-10-02 13:46 ` [bug#50967] [PATCH 11/12] scripts: home: (gnu home-services bash) -> (gnu services bash) Oleg Pykhalov
2021-10-02 13:46 ` [bug#50967] [PATCH 12/12] doc: (gnu home-services) -> (gnu services) Oleg Pykhalov
2021-10-02 16:38 ` [bug#50967] [PATCH 01/14] tests: Add tests for guix home cli Oleg Pykhalov
2021-10-02 16:38 ` [bug#50967] [PATCH 02/14] gnu: home-services: Move configuration to (gnu home services) Oleg Pykhalov
2021-10-02 18:37 ` Xinglu Chen
2021-10-02 16:38 ` [bug#50967] [PATCH 03/14] gnu: home-services: Move symlink-manager " Oleg Pykhalov
2021-10-02 16:38 ` [bug#50967] [PATCH 04/14] gnu: home-services: Move utils " Oleg Pykhalov
2021-10-02 16:38 ` [bug#50967] [PATCH 05/14] gnu: home-services: Move fontutils to (gnu services) Oleg Pykhalov
2021-10-02 16:38 ` [bug#50967] [PATCH 06/14] gnu: home-services: Move shells to (gnu home services) Oleg Pykhalov
2021-10-02 16:38 ` [bug#50967] [PATCH 07/14] gnu: home-services: Move xdg " Oleg Pykhalov
2021-10-02 16:38 ` [bug#50967] [PATCH 08/14] gnu: home-services: Move shepherd " Oleg Pykhalov
2021-10-02 16:38 ` [bug#50967] [PATCH 09/14] gnu: home-services: Move mcron " Oleg Pykhalov
2021-10-02 16:38 ` [bug#50967] [PATCH 10/14] scripts: home: (gnu home-services bash) -> (gnu home services bash) Oleg Pykhalov
2021-10-02 16:38 ` [bug#50967] [PATCH 11/14] doc: (gnu home-services) -> (gnu home services) Oleg Pykhalov
2021-10-02 16:38 ` [bug#50967] [PATCH 12/14] gnu: home-services: Update %service-type-path Oleg Pykhalov
2021-10-04 14:01 ` [bug#50967] [PATCH 00/12] Move (gnu home-services XYZ) to (gnu services XYZ) Ludovic Courtès
2021-10-02 16:38 ` [bug#50967] [PATCH 13/14] home: services: configuration: Support file-like objects Oleg Pykhalov
2021-10-02 18:35 ` Xinglu Chen
2021-10-04 14:04 ` [bug#50967] [PATCH 00/12] Move (gnu home-services XYZ) to (gnu services XYZ) Ludovic Courtès
2021-10-06 8:15 ` [bug#50967] file-like objects instead of gexps Andrew Tropin
2021-10-08 7:56 ` Ludovic Courtès
2021-10-08 10:00 ` Andrew Tropin
2021-10-09 13:34 ` Ludovic Courtès
2021-10-14 8:32 ` Andrew Tropin
2021-10-08 13:45 ` Xinglu Chen
2021-10-08 14:34 ` Andrew Tropin
2021-10-08 10:06 ` [bug#50967] [PATCH 13/14] home: services: configuration: Support file-like objects Andrew Tropin
2021-10-14 7:08 ` Andrew Tropin [this message]
2021-10-02 16:38 ` [bug#50967] [PATCH 14/14] doc: Document guix home import Oleg Pykhalov
2021-10-02 18:42 ` Xinglu Chen
2021-10-02 19:45 ` Oleg Pykhalov
2021-10-04 13:58 ` [bug#50967] [PATCH 00/12] Move (gnu home-services XYZ) to (gnu services XYZ) Ludovic Courtès
2021-10-04 23:13 ` [bug#50967] [PATCH 1/3] gnu: Move (gnu home-services) to (gnu home services) Oleg Pykhalov
2021-10-04 23:13 ` [bug#50967] [PATCH 2/3] home: services: configuration: Support file-like objects Oleg Pykhalov
2021-10-04 23:13 ` [bug#50967] [PATCH 3/3] guix: scripts: Make sure profile directory exists Oleg Pykhalov
2021-10-05 10:20 ` Oleg Pykhalov
2021-10-06 21:22 ` [bug#50967] [PATCH 00/12] Move (gnu home-services XYZ) to (gnu services XYZ) Ludovic Courtès
2021-10-06 22:05 ` [bug#50967] [PATCH 3/3] guix: scripts: Make sure profile directory exists Oleg Pykhalov
2021-10-06 22:15 ` [bug#50967] [PATCH 00/12] Move (gnu home-services XYZ) to (gnu services XYZ) Oleg Pykhalov
2021-10-07 6:37 ` Maxime Devos
2021-10-07 9:56 ` Oleg Pykhalov
2021-10-07 16:43 ` Maxime Devos
2021-10-08 22:44 ` Ludovic Courtès
2021-10-08 22:57 ` Ludovic Courtès
2021-10-09 12:34 ` Oleg Pykhalov
2021-10-09 12:45 ` Oleg Pykhalov
2021-10-09 14:34 ` Ludovic Courtès
2021-10-09 19:39 ` bug#50967: " Oleg Pykhalov
2021-10-08 12:44 ` [bug#50967] " Oleg Pykhalov
2021-10-08 14:27 ` Andrew Tropin
2021-10-08 22:46 ` Ludovic Courtès
2021-10-08 22:49 ` Ludovic Courtès
2021-10-02 20:13 ` [bug#50967] [PATCH] home: services: configuration: Move and refactor content Oleg Pykhalov
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=87lf2wt770.fsf@trop.in \
--to=andrewtropin@gmail.com \
--cc=50967@debbugs.gnu.org \
--cc=go.wigust@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
Code repositories for project(s) associated with this external index
https://git.savannah.gnu.org/cgit/guix.git
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.