From: Maxim Cournoyer <maxim.cournoyer@gmail.com>
To: Simon Tournier <zimon.toutoune@gmail.com>
Cc: 63276@debbugs.gnu.org
Subject: bug#63276: Allow channels to depend on a past Guix revision / private dependencies
Date: Fri, 05 May 2023 10:36:49 -0400 [thread overview]
Message-ID: <87mt2i4zge.fsf@gmail.com> (raw)
In-Reply-To: <865y97zzf4.fsf@gmail.com> (Simon Tournier's message of "Thu, 04 May 2023 21:09:35 +0200")
Hi Simon,
Simon Tournier <zimon.toutoune@gmail.com> writes:
> Hi Maxim,
>
> Well, part of the message is in: :-)
>
> https://issues.guix.gnu.org/msgid/875y987z1m.fsf@gmail.com
Oh, a Mumi reference to a message ID! I didn't know it supported that,
cool!
> On Thu, 04 May 2023 at 11:52, Maxim Cournoyer <maxim.cournoyer@gmail.com> wrote:
>
>> It seems a valid use case to have a channel that depends on an old Guix
>> version. Should this be supported?
>>
>> If I could for example use the following channel dependency file at the
>> level of the channel in a .guix-channel, to depend on an older Guix
>> revision:
>>
>> --8<---------------cut here---------------start------------->8---
>> (channel
>> (version 0)
>> (dependencies
>> (channel
>> (inherit %default-guix-channel)
>> (commit "9ed65e6af77893b658a7159b091b5002892c2f95"))))
>> --8<---------------cut here---------------end--------------->8---
>
> You want complete channel depends on a previous Guix, right?
That's the idea I had yes, seeing that my channel won't work with any
newer Guix revision, I thought I should be able to declare that upfront
as a dependency, and have the channels mechanism take care of treating
all things relating to this channel via a Guix inferior. The benefit
above having to explain to users how to do this in a manifest as done in
[0] would be twofold:
1. The channel can simply be added and works out of the box, without
having users go through the hoops of configuring an inferior.
2. 'guix pull', if taught to translate a dependency on a past Guix into
an inferior, could use that at the time it runs ad avoid errors caused
by removed or moved packages in current Guix.
[0] https://gitlab.com/Apteryks/sfl-guix-channel/-/blob/master/README.org
> Somehow, it would become equivalent to this channels.scm
>
> (list (channel
> (name 'guix)
> (url "https://git.savannah.gnu.org/git/guix.git")
> (branch "master")
> (commit
> "9ed65e6af77893b658a7159b091b5002892c2f95"))
> (channel
> (name 'sfl)
> (url "file:///tmp/sfl-guix-channel")
> (branch "master"))))
>
> and then run “guix pull && guix build sflvault-client” or:
>
> guix time-machine -C channels.scm -- shell sflvault-client
>
>
> Well, I do not know if it is desirable. Most of the time, I only want
> one specific package from one specific Guix revision.
Not exactly equivalent to that channel file. In my idea (not thinking
about the technicalities/difficulties yet), the dependency on the Guix
channel would be made private to the package (my translating it to a
Guix inferior as mentioned above), instead of spilling into the global
package namespace (which I agree would be undesirable!).
In other words, declaring a dependency on a prior Guix channel would
cause all derivations for packages in that channel to happen in a
corresponding Guix inferior. Does that make sense?
>
>> As a workaround, I can define a 'python-pycryto*' in the channel itself,
>> although that's kind of silly because it can only be used with a Guix
>> inferior pegged to commit 9ed65e6af77893b658a7159b091b5002892c2f95,
>> which does contain 'python-pycryto'.
>
> Well, I do not know if we are using the time-travel the same way. :-)
>
> Considering this:
>
> (define-public foo
> (package
> (name "foo")
> (inputs
> (list bar)
> (list baz))))
>
> Most of the time, I want to build ’foo’ using a recent Guix but that
> recent Guix removed ’bar’ so I want to pick it up from an inferior.
> And let say I want ’baz’ from another Guix revision because some
> specific version of ’baz’ is required for building ’foo’.
>
> Basically, I am tempted to define the symbol ’bar’ and ’baz’ in my
> channel and bind them to some inferior packages (here from 2 Guix
> revisions).
Interesting. So using inferiors inside your channel does work in
general, contrary to experiments made with the sfl-guix-channel in the
other thread?
--
Thanks,
Maxim
next prev parent reply other threads:[~2023-05-05 14:37 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-05-04 15:52 bug#63276: Allow channels to depend on a past Guix revision / private dependencies Maxim Cournoyer
2023-05-04 19:09 ` Simon Tournier
2023-05-05 14:36 ` Maxim Cournoyer [this message]
2024-11-12 6:02 ` Maxim Cournoyer
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
List information: https://guix.gnu.org/
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=87mt2i4zge.fsf@gmail.com \
--to=maxim.cournoyer@gmail.com \
--cc=63276@debbugs.gnu.org \
--cc=zimon.toutoune@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 public inbox
https://git.savannah.gnu.org/cgit/guix.git
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).