On 27 May 2016 at 10:28, rindeal <dev.rind...@gmail.com> wrote:
>
> 1) what are they?
> 2) why are they used?


My best explanation is its a way to re-use very large amounts of code
between 2 ebuilds, without resorting to:

a) Copying the whole ebuild and hoping you find the relevant part in diffs
b) Not needing reams of version-specific conditional code to make
copying ebuilds between versions easier.
c) Not needing confusing eclasses that exist to serve a single
package, loaded with lots of weird conditional logic.

My understanding is you could effectively roll the eblits back into
the ebuild statically, just doing so would make keeping the changes
consistent harder.

Its clearly designed for a system where you have ~10 different
versions of Perl available or ~10 different versions of glibc
available, but you don't want to pay the price of duplicating that
logic wholesale for every minor concurrent revision, and only want to
update essential differences when you need to, not because you have
to.

That said, its a very confusing system to get your head around,
because its *basically* yet another "mixin" system like "inherit", but
done in bash, which itself is a rather strange language to be doing
something as complicated as mixins.

-- 
Kent

KENTNL - https://metacpan.org/author/KENTNL

Reply via email to