[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
bug#60365: [PATCH 0/4] Rationalize 'PS1' handling in home, system, and s
From: |
Ludovic Courtès |
Subject: |
bug#60365: [PATCH 0/4] Rationalize 'PS1' handling in home, system, and shell |
Date: |
Thu, 05 Jan 2023 15:20:13 +0100 |
User-agent: |
Gnus/5.13 (Gnus v5.13) Emacs/28.2 (gnu/linux) |
Andrew Tropin <andrew@trop.in> skribis:
> On 2023-01-03 23:46, Ludovic Courtès wrote:
[...]
>>> Not sure about moving PS1 to /etc/bashrc as it won't work on foreign
>>> distros and guix environment won't be noticable in the prompt. Warning
>>> is useful, but I would expect prompt work OOB, when guix-defualts? is
>>> #t.
>>
>> Yes, you’re right.
>>
>>> The possible alternative solution is to factorize bash_profile and put
>>> PS1 here, so both skeleton and home provided bashrc have it, after that
>>> setting PS1 with environment-variables field will start working.
>>
>> How about this:
>>
>> diff --git a/gnu/home/services/shells.scm b/gnu/home/services/shells.scm
>> index d7dd579293..8d7db6b774 100644
>> --- a/gnu/home/services/shells.scm
>> +++ b/gnu/home/services/shells.scm
>> @@ -407,6 +407,9 @@ (define* (file-if-not-empty field #:optional
>> (extra-content #f))
>> # Honor per-interactive-shell startup file
>> if [ -f ~/.bashrc ]; then source ~/.bashrc; fi
>> "
>> + (if (home-bash-configuration-guix-defaults? config)
>> + "export PS1=...\n"
>
> Yep, something like that should work. Ideally, is to make
> %default-bash-profile or even more generic %default-profile and reuse it
> across system and home, but it may be not that trivial, so we can
> postpone it for now.
I adjusted things as proposed and pushed:
b5e3701f1a environment: Avoid false positive on 'PS1' check.
632e2f7ce1 environment: Simplify 'PS1' suggestion on '--check'.
086df6ef21 system: Define default 'PS1' in /etc/bashrc rather than ~/.bashrc.
2127e56bd8 system, home: Factorize default '.bashrc'.
Thanks!
Ludo’.