* [bug#45632] [PATCH] guix package: Warn if uses has 'guix' package in profile.
@ 2021-01-03 18:32 Jakub Kądziołka
2021-01-07 16:39 ` zimoun
2021-01-07 17:15 ` Tobias Geerinckx-Rice via Guix-patches via
0 siblings, 2 replies; 9+ messages in thread
From: Jakub Kądziołka @ 2021-01-03 18:32 UTC (permalink / raw)
To: 45632
* guix/scripts/package.scm (warn-about-guix-in-profile): New procedure.
(process-actions): Call WARN-ABOUT-GUIX-IN-PROFILE before executing
transaction.
---
Unresolved questions:
- Is this the right place to put warn-about-guix-in-profile?
- The warning message seems to be hard-wrapped. Is this the right
line length?
- Do we want to make this configurable? Some other warnings are, but in
those cases it is the threshold that gets configured. In this case,
there is no threshold.
guix/scripts/package.scm | 11 +++++++++++
1 file changed, 11 insertions(+)
diff --git a/guix/scripts/package.scm b/guix/scripts/package.scm
index 6faf2adb7a..bc42bd7d84 100644
--- a/guix/scripts/package.scm
+++ b/guix/scripts/package.scm
@@ -9,6 +9,7 @@
;;; Copyright © 2019 Tobias Geerinckx-Rice <me@tobias.gr>
;;; Copyright © 2020 Ricardo Wurmus <rekado@elephly.net>
;;; Copyright © 2020 Simon Tournier <zimon.toutoune@gmail.com>
+;;; Copyright © 2021 Jakub Kądziołka <kuba@kadziolka.net>
;;;
;;; This file is part of GNU Guix.
;;;
@@ -863,6 +864,15 @@ processed, #f otherwise."
(switch-generation . ,switch-generation-action)
(delete-generations . ,delete-generations-action)))
+(define (warn-about-guix-in-profile manifest)
+ "Emit a warning if MANIFEST contains a 'guix' package."
+ (when (manifest-installed? manifest
+ (manifest-pattern
+ (name "guix")))
+ (warning (G_ "Installing the 'guix' package in a user profile is not recommended,
+as it will conflict with the installation managed by 'guix pull'. Consider running
+'guix package -r guix'.\n"))))
+
(define (process-actions store opts)
"Process any install/remove/upgrade action from OPTS."
@@ -928,6 +938,7 @@ processed, #f otherwise."
(manifest-entries manifest)))))
(warn-about-old-distro)
+ (warn-about-guix-in-profile new)
(unless (manifest-transaction-null? trans)
;; When '--manifest' is used, display information about TRANS as if we
--
2.29.2
^ permalink raw reply related [flat|nested] 9+ messages in thread
* [bug#45632] [PATCH] guix package: Warn if uses has 'guix' package in profile.
2021-01-03 18:32 [bug#45632] [PATCH] guix package: Warn if uses has 'guix' package in profile Jakub Kądziołka
@ 2021-01-07 16:39 ` zimoun
2021-01-07 17:11 ` Jakub Kądziołka
2021-01-07 17:15 ` Tobias Geerinckx-Rice via Guix-patches via
1 sibling, 1 reply; 9+ messages in thread
From: zimoun @ 2021-01-07 16:39 UTC (permalink / raw)
To: Jakub Kądziołka; +Cc: 45632
Hi,
On Sun, 3 Jan 2021 at 19:33, Jakub Kądziołka <kuba@kadziolka.net> wrote:
>
> * guix/scripts/package.scm (warn-about-guix-in-profile): New procedure.
> (process-actions): Call WARN-ABOUT-GUIX-IN-PROFILE before executing
> transaction.
> ---
>
> Unresolved questions:
> - Is this the right place to put warn-about-guix-in-profile?
> - The warning message seems to be hard-wrapped. Is this the right
> line length?
> - Do we want to make this configurable? Some other warnings are, but in
> those cases it is the threshold that gets configured. In this case,
> there is no threshold.
What is the use case? I have missed some context.
For example, I have the package 'guix' in some of my profiles and I
would be annoyed to be warned. And I have it for good reasons. :-)
Once the story about extension is good enough, maybe the warning would
be a good advice, otherwise it could be confusing. IMHO.
All the best,
simon
^ permalink raw reply [flat|nested] 9+ messages in thread
* [bug#45632] [PATCH] guix package: Warn if uses has 'guix' package in profile.
2021-01-07 16:39 ` zimoun
@ 2021-01-07 17:11 ` Jakub Kądziołka
2021-01-07 17:46 ` zimoun
0 siblings, 1 reply; 9+ messages in thread
From: Jakub Kądziołka @ 2021-01-07 17:11 UTC (permalink / raw)
To: zimoun; +Cc: 45632
On Thu Jan 7, 2021 at 5:39 PM CET, zimoun wrote:
> Hi,
>
> On Sun, 3 Jan 2021 at 19:33, Jakub Kądziołka <kuba@kadziolka.net>
> wrote:
> >
> > * guix/scripts/package.scm (warn-about-guix-in-profile): New procedure.
> > (process-actions): Call WARN-ABOUT-GUIX-IN-PROFILE before executing
> > transaction.
> > ---
> >
> > Unresolved questions:
> > - Is this the right place to put warn-about-guix-in-profile?
> > - The warning message seems to be hard-wrapped. Is this the right
> > line length?
> > - Do we want to make this configurable? Some other warnings are, but in
> > those cases it is the threshold that gets configured. In this case,
> > there is no threshold.
>
> What is the use case? I have missed some context.
As the actual warning text explains, including the guix package in a
profile loaded by default breaks the 'guix pull' update mechanism, as
the guix package from the profile will take priority.
This is inspired by some tech support on IRC where this turned out to be
a root cause of a problem.
Moreover, if I'm not missing anything, running 'guix package -u' with
such a setup would *downgrade* the guix package each time.
> For example, I have the package 'guix' in some of my profiles and I
> would be annoyed to be warned. And I have it for good reasons. :-)
Okay, I can see now that it is not wise to skimp on configurability for
this. Though, I would like to hear more about your usecase - how do you
keep your guix updated, for example?
> Once the story about extension is good enough,
As in adding your own commands under the 'guix $CMD' namespace, or
something more sophisticated? For the former, git seems to have a quite
good mechanism - we could borrow that.
Regards,
Jakub Kądziołka
^ permalink raw reply [flat|nested] 9+ messages in thread
* [bug#45632] [PATCH] guix package: Warn if uses has 'guix' package in profile.
2021-01-03 18:32 [bug#45632] [PATCH] guix package: Warn if uses has 'guix' package in profile Jakub Kądziołka
2021-01-07 16:39 ` zimoun
@ 2021-01-07 17:15 ` Tobias Geerinckx-Rice via Guix-patches via
2021-01-07 17:56 ` zimoun
1 sibling, 1 reply; 9+ messages in thread
From: Tobias Geerinckx-Rice via Guix-patches via @ 2021-01-07 17:15 UTC (permalink / raw)
To: Jakub Kądziołka; +Cc: 45632
[-- Attachment #1: Type: text/plain, Size: 476 bytes --]
Jakub, Simon,
How about warning on pull instead? That should address the ‘halp,
me Guix be Benjamin Buttonin'’ support calls that I assume
inspired this.
Simon, would that reduce the noise in your case?
Jakub Kądziołka 写道:
> - The warning message seems to be hard-wrapped. Is this the
> right
> line length?
Avoid hard-wrapping output entirely, by ’escaping’ the newlines
(warning (G_ "like\
this."))
Kind regards,
T G-R
[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 247 bytes --]
^ permalink raw reply [flat|nested] 9+ messages in thread
* [bug#45632] [PATCH] guix package: Warn if uses has 'guix' package in profile.
2021-01-07 17:11 ` Jakub Kądziołka
@ 2021-01-07 17:46 ` zimoun
2021-01-07 20:31 ` Ricardo Wurmus
0 siblings, 1 reply; 9+ messages in thread
From: zimoun @ 2021-01-07 17:46 UTC (permalink / raw)
To: Jakub Kądziołka; +Cc: 45632
Hi,
On Thu, 7 Jan 2021 at 18:27, Jakub Kądziołka <kuba@kadziolka.net> wrote:
> As the actual warning text explains, including the guix package in a
> profile loaded by default breaks the 'guix pull' update mechanism, as
> the guix package from the profile will take priority.
Hum? I simply have ~/.config/guix/current/bin first in my PATH. Well,
I have the package 'guix' in my profile since long time because of
'emacs-guix' and never hit an issue.
> This is inspired by some tech support on IRC where this turned out to be
> a root cause of a problem.
Could you indicate the day?
> Moreover, if I'm not missing anything, running 'guix package -u' with
> such a setup would *downgrade* the guix package each time.
I do not know, I never upgrade this way. Because I only use
manifest.scm files. Even, from my personal taste '-u' and 'guix
upgrade' are Guix abomination and should not exist; another story. ;-)
Again if ~/.config/guix/current/bin first in the PATH, then it should
not be an issue, I guess.
> > For example, I have the package 'guix' in some of my profiles and I
> > would be annoyed to be warned. And I have it for good reasons. :-)
>
> Okay, I can see now that it is not wise to skimp on configurability for
> this. Though, I would like to hear more about your usecase - how do you
> keep your guix updated, for example?
Basically, "guix pull" and "guix package -m". But I am tracking this
file "guix describe -f channels > channels.scm" and I also do "guix
time-machine -C channels.scm -- package -m manifest.scm".
Otherwise, when I want to give a try for a package, simply "guix
environment --ad-hoc"; time to time with "time-machine" too.
> > Once the story about extension is good enough,
>
> As in adding your own commands under the 'guix $CMD' namespace, or
> something more sophisticated? For the former, git seems to have a quite
> good mechanism - we could borrow that.
From my understanding, Git use shell tricks and cannot be borrowed.
The idea is to have "guix <foo>"; for details, see the recent patch
about extensions by Ricardo and discussion on #guix-hpc (because GWL
is an extension).
All the best,
simon
^ permalink raw reply [flat|nested] 9+ messages in thread
* [bug#45632] [PATCH] guix package: Warn if uses has 'guix' package in profile.
2021-01-07 17:15 ` Tobias Geerinckx-Rice via Guix-patches via
@ 2021-01-07 17:56 ` zimoun
2021-01-07 17:58 ` Jakub Kądziołka
0 siblings, 1 reply; 9+ messages in thread
From: zimoun @ 2021-01-07 17:56 UTC (permalink / raw)
To: me, 45632; +Cc: kuba
Hi Tobias,
On Thu, 7 Jan 2021 at 18:23, Tobias Geerinckx-Rice via Guix-patches
via <guix-patches@gnu.org> wrote:
> How about warning on pull instead? That should address the ‘halp,
> me Guix be Benjamin Buttonin'’ support calls that I assume
> inspired this.
Wait, does someone install packages in the profile
"~/.config/guix/current"? And does they install the package 'guix' in
this profile? Nan...
> Simon, would that reduce the noise in your case?
I am not sure to understand what the problem is; I should miss
something. My config is simply '~/.config/guix/current/bin' first in
my PATH and I am doing it manually with ~/.bash_profile. And I have a
lot of profiles that are sourced with a for-loop, some of them contain
the package 'guix'. And I have never hit an issue but I do not use
'upgrade'. Howver, I am mainly using Guix on Debian. Is the issue
Guix System specific?
Well, if the conflict is between the package 'guix' and the 'upgrade'
command, then the warning should be there, IMHO.
All the best,
simon
^ permalink raw reply [flat|nested] 9+ messages in thread
* [bug#45632] [PATCH] guix package: Warn if uses has 'guix' package in profile.
2021-01-07 17:56 ` zimoun
@ 2021-01-07 17:58 ` Jakub Kądziołka
2021-01-07 19:25 ` zimoun
0 siblings, 1 reply; 9+ messages in thread
From: Jakub Kądziołka @ 2021-01-07 17:58 UTC (permalink / raw)
To: zimon.toutoune, me, 45632
On Thu Jan 7, 2021 at 6:56 PM CET, zimoun wrote:
> Well, if the conflict is between the package 'guix' and the 'upgrade'
> command, then the warning should be there, IMHO.
The upgrade command is not part of the problem here, the same can be
observed if you use 'guix package -m' instead.
You avoid the problem by putting ~/.config/guix/current/bin first in
your path. I just checked, and that is the default on Guix System.
However, on a foreign distro, ~/.guix-profile/bin will be first in $PATH
unless the user intervenes with manual configuration.
In light of this, perhaps a better solution would be to unify the
profile loading in foreign-Guix's /etc/profile/guix.sh with Guix
System's /etc/profile?
The problem with that is, /etc/profile/guix.sh is only created once by
guix-install.sh, and doesn't get updated... perhaps *this* is something
worth fixing, to start with?
> > How about warning on pull instead? That should address the ‘halp,
> > me Guix be Benjamin Buttonin'’ support calls that I assume
> > inspired this.
>
> Wait, does someone install packages in the profile
> "~/.config/guix/current"? And does they install the package 'guix' in
> this profile? Nan...
Nah, the scenario is much less convoluted:
1. $PATH contains ~/.guix-profile/bin:~/.config/guix/current/bin, in
that order, as that is currently the default on a foreign distro.
2. User adds the guix package to their ~/.guix-profile. This doesn't
need to happen with 'guix package -i', in fact the IRC conversation that
inspired this [1] (though I seem to recall earlier occurrences of the
same problem) the user was making use of a manifest file. It might even
be easier to encounter this with a manifest file due to its clean-slate
nature.
3. ~/.guix-profile/bin/guix now takes priority. This means
- guix describe doesn't work
- guix pull has no effect
- guix package (-u or -m) will use an older 'guix' package than is
currently installed, as a packaged guix version doesn't contain the
package definition of itself, but the one that was previously
packaged.
I hope this helps resolve your confusion.
Regards,
Jakub Kądziołka
[1]: http://logs.guix.gnu.org/guix/2021-01-01.log#163217
^ permalink raw reply [flat|nested] 9+ messages in thread
* [bug#45632] [PATCH] guix package: Warn if uses has 'guix' package in profile.
2021-01-07 17:58 ` Jakub Kądziołka
@ 2021-01-07 19:25 ` zimoun
0 siblings, 0 replies; 9+ messages in thread
From: zimoun @ 2021-01-07 19:25 UTC (permalink / raw)
To: Jakub Kądziołka; +Cc: 45632
Hi,
On Thu, 7 Jan 2021 at 19:24, Jakub Kądziołka <kuba@kadziolka.net> wrote:
[...]
> The problem with that is, /etc/profile/guix.sh is only created once by
> guix-install.sh, and doesn't get updated... perhaps *this* is something
> worth fixing, to start with?
[...]
> I hope this helps resolve your confusion.
Thanks for the explanations. Yes, maybe guix-install.sh and
/etc/profile/guix.sh should be fixed before adding a warning. Because
somehow, the problem is not to have the package 'guix' but the order
in PATH.
All the best,
simon
^ permalink raw reply [flat|nested] 9+ messages in thread
* [bug#45632] [PATCH] guix package: Warn if uses has 'guix' package in profile.
2021-01-07 17:46 ` zimoun
@ 2021-01-07 20:31 ` Ricardo Wurmus
0 siblings, 0 replies; 9+ messages in thread
From: Ricardo Wurmus @ 2021-01-07 20:31 UTC (permalink / raw)
To: zimoun; +Cc: kuba, 45632
zimoun <zimon.toutoune@gmail.com> writes:
>> > Once the story about extension is good enough,
>>
>> As in adding your own commands under the 'guix $CMD' namespace, or
>> something more sophisticated? For the former, git seems to have a quite
>> good mechanism - we could borrow that.
>
> From my understanding, Git use shell tricks and cannot be borrowed.
> The idea is to have "guix <foo>"; for details, see the recent patch
> about extensions by Ricardo and discussion on #guix-hpc (because GWL
> is an extension).
This is a solved problem as far as I’m concerned. (It still needs to be
documented in the manual and maybe in the cookbook.)
You need to set GUIX_EXTENSIONS_PATH to a location that contains a Guile
module “(guix extensions my-command)” that defines “my-command” with
“define-command” (so it needs to import (guix scripts)). The category
should be “extension” (it’s a new category that has been added
recently).
As long as that’s the case Guix will be able to list it in “guix --help”
and execute it.
Here is the entry point of the Guix Workflow Language, which uses this
very mechanism:
https://git.savannah.gnu.org/cgit/gwl.git/tree/guix/extensions/workflow.scm.in
--
Ricardo
^ permalink raw reply [flat|nested] 9+ messages in thread
end of thread, other threads:[~2021-01-07 20:38 UTC | newest]
Thread overview: 9+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2021-01-03 18:32 [bug#45632] [PATCH] guix package: Warn if uses has 'guix' package in profile Jakub Kądziołka
2021-01-07 16:39 ` zimoun
2021-01-07 17:11 ` Jakub Kądziołka
2021-01-07 17:46 ` zimoun
2021-01-07 20:31 ` Ricardo Wurmus
2021-01-07 17:15 ` Tobias Geerinckx-Rice via Guix-patches via
2021-01-07 17:56 ` zimoun
2021-01-07 17:58 ` Jakub Kądziołka
2021-01-07 19:25 ` zimoun
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.