Hello, all.

As the next item for discussion in EAPI 6 I'd like to raise the idea of
introducing src_fetch() phase for fetching live sources.

First of all, I'd like to emphasize that the additional phase function
will not make live ebuilds any more welcome than they are now. They
will still be discouraged, and subject to masking as usual. However,
the function will improve the experience of users using them.

The major goal is to add a src_fetch() phase that could be called
earlier during the ebuild process (e.g. within a parallel fetching
process) or in a 'emerge --fetchonly' or similar call.

I will sum up the issues that came up already. However, feel free to
point out any more questions if you have some.


1. How should we state fetch dependencies?

Most of live ebuilds would need a dependency on the VCS they're using.
Currently, those dependencies are part of DEPEND. However, if
src_fetch() is done early or out-of-process, it will no longer be good
enough for us.

I see two major directions here:

a) explicitly stating fetch dependencies (as FDEPEND or using
magical USE flag thingie in DEPEND). Then, those dependencies would be
pulled in earlier than other DEPENDs and installed before src_fetch()
is called.

I think this will require more work on Zac's side. Also, should we then
install VCS-es during 'emerge --fetchonly'?

b) assume that early src_fetch() is allowed to fail and retry before
build. This is much like what portage does anyway. If VCS is not
installed yet during parallel fetch or --fetchonly, the particular
fetch fails like it can fail due to 404. When the actual build process
starts, emerge calls src_fetch() again much like it currently retries
fetching missing SRC_URI items.

This would be simpler. We could probably cache the src_fetch() result
(if possible) to avoid double-fetching. Or just accept the minimal
overhead of plain update check.


2. Should src_unpack() be disallowed from fetching VCS sources?

If we introduce src_fetch() in EAPI 6, then we should probably expect
all the live eclasses to use that rather than src_unpack() for
fetching. If we agree on this, we can extend portage's network-sandbox
to this phase, and likely filesystem sandbox as well.


3. Is everyone ok with splitting VCS fetch into fetch+unpack?

That is, the new design would be like:

- src_fetch() fetches the updates from remote server to DISTDIR,

- src_unpack() does the checkout from DISTDIR to S.

I suspect that some live ebuilds may prefer different kind of operation
but this split seems quite reasonable.


Relevant bugs:
- https://bugs.gentoo.org/show_bug.cgi?id=182028
- https://bugs.gentoo.org/show_bug.cgi?id=481434

-- 
Best regards,
Michał Górny

Attachment: signature.asc
Description: PGP signature

Reply via email to