On Wed, 2014-07-23 at 01:13 +0200, Tom Wijsman wrote:
> On Mon, 21 Jul 2014 21:34:10 -0400
> Alexandre Rostovtsev <tetrom...@gentoo.org> wrote:
> > Why not adapt the updates mechanism for modifying rdepends? Perhaps
> > something like
> > 
> > rdepends-add foo-bar/blah-3.14 "wombat? ( >=dev-libs/wombat-1.0 )"
> > 
> > This would give the package manager all the benefits of static dep
> > resolution while allowing us to dynamically make simple changes (like
> > adding a missing dependency to an ebuild) without forcing users to
> > rebuild the package.
> 
> Thinking this through:
> 
>  1) What about rdepends-change and rdepends-del? If you only support
>  addition; you get the same problem as with things like pkgmove,
>  changing and/or removing it could become somewhat problematic.

rdepends-add is easy to implement: just append a string to RDEPENDS and
reparse it. Deletion is trickier. It's clear what it means to delete an
atom from a flat list of atoms. But specifying what it means to delete a
part of a complex expression (conditionals, disjunctions) requires some
careful thought.

>  2) This needs two commits every time you want to do this; one commit
>  for the updates/, another to keep the ebuild recent for (rev)bumps.

Yes, but that's just more incentive to migrate to git :)

>  3) It'll be a lot of fun to attempt to support this in Repoman.

Ideally, repoman would suggest what you should add to updates/ when it
detects that you are committing a change to an existing ebuild.

>  4) How do we clean up these entries? Doesn't this info grow fast?

The point is to *not* clean up these entries for months/years. I want to
address the situation where a users installs from an ebuild with wrong
dependencies, the next day the ebuild gets its dependencies fixed in
cvs, two weeks later the ebuild gets deleted from cvs, and only then the
user resyncs. With our current dynamic depends, as well as with the
proposed "minor revisions" mechanism, the user will still have a broken
vdb. I want to make sure the user's vdb gets updated even when the
ebuild in question is gone from portage.

>  5) The first paramater: Should that point to a single ebuild? Should
>  that support ranges?

Just like everything else in profiles/, so for now, that means a single
dependency specification. If you want version ranges, they should be
allowed in package.mask too :)

Attachment: signature.asc
Description: This is a digitally signed message part

Reply via email to