On 12/07/14 17:41, William Hubbs wrote:
On Sun, Dec 07, 2014 at 08:32:57AM -0500, Rich Freeman wrote:
On Sun, Dec 7, 2014 at 8:05 AM, Anthony G. Basile
<bas...@opensource.dyc.edu> wrote:
On 12/07/14 05:37, Michał Górny wrote:
If you're interested in testing it, 'layman -a mgorny' and enjoy. I'd
appreciate any bug reports, except for those covering things i've
already listed as missing :). Any further comments will be very helpful
in deciding on the way forward.
Removing the eclass is a bad idea:
0) This reduces code reusability. The eclass is used by sys-devel/kgcc64 in
the tree and (at least) the hardened-dev::musl overlay outside.
Well, other packages could keep using the eclass.
I think that eclasses tend to get abused in situations like these. It
is one thing if you have 300 ebuilds that are all maintained together
like there are with kde and logic really is shared in common between
them.
However, this eclass is only used by a few packages, the shared code
isn't across stuff installed in parallel but across stuff that changes
over time. This is done without upstream support for the most part,
so it becomes a growing collection of workarounds. When eclasses
start following different code paths every time a package that uses
them is versioned, it makes a lot more sense to either version the
eclass every time or move the code to the ebuild.
This makes sense to me as well, let's work twoard getting rid of
toolchain.eclass.
Hardened has used the eclass in its overlay and continues to use it. We
do not wish to get rid of it.
@hardened, we should discuss this at our next meeting.
1) Those version specific conditionals that you don't like give a
history/comparison of gcc versions. It is not cruft. It encodes what
versions allow what features. Moving to the ebuilds makes this history much
harder to read. Think of a diff -Naur when producing a patch. I like the
current eclass approach.
Why do we need a history/comparison of gcc written in shell script?
Wouldn't a text file or webpage be a better way to document this?
Wouldn't upstream be the place to document this?
This seems a bit like saying that we don't need the EAPI/PMS guide or
even PMS itself because anybody can just read the portage source code
and figure out how it works.
If you need a list of what features are supported in what versions of
gcc, wouldn't it make more sense to create a wiki page somewhere?
I thinkk this makes more sense as well. Historical reasons don't work
for me by them selves as a reason to justify keeping old code,
especially when it is to support versions of packages that are no longer
really supported upstream.
I'm not sure what you mean by "old code" which is "no longer really
supported upstream". gcc is built using gcc. We should have a window
on gcc versions which goes backwards and forwards a couple of versions,
so I can build 4.8 with 4.7 or 4.6 and vice versa. And build 4.6 with
4.5 or 4.4, etc. There is an entire chain there. Keeping the detailed
decisions in an eclass of what features were on/off for each version
makes sense so we can conveniently track that chain. When I say I want
to keep history, that's what I'm talking about. In hardened we went
through a pains taking process of making sure the first hardened gcc-4
versions (4.4 I believe) was buildable by the previous one, and that it
could build itself and could rebuild itself both adding and remove
hardening etc. (BTW by "we" I mean Magnus who deserves all the kudos.
I just helped with testing and told him what broke.)
If you want to simplify code, then let's bump all the gcc ebuilds to
EAPI 4 or above and refactor the phase functions and remove all the EAPI
checks. But removing all instances of tc_version_is_* is not a good idea.
If there is a real interest in my fork, I will probably move it to gx86
as sys-devel/gcc-mgorny.
I don't think we should proceed this way. The way I'd like to proceed is to
introduce a new toolchain-r1.eclass which addresses at least your QA issues
below. If I understood Ryan's plan with the eclass, it was to simply
refactor the phase functions to modernize things but keep backwards compat.
When toolchain-r1.eclass is mature, then we switch the inherit. I'd like to
keep gcc-2* and gcc-3* around. We could consider cleaning up those ebuilds
to work with EAPI=4 or 5 with the new eclass or just leave them with the old
eclass.
Why do you want to keep these outdated and not supported versions of gcc
around? Have you tried building a modern system with gcc-2 or gcc-3? I
haven't but I'm sure it would fail horribly.
But not certain embedded systems or other scenarios. gcc-3 for instance
did hardening differently than 4. While I'm not as interested in gcc-2,
I don't want to see gcc-3 dumped. Even minor leaps like 4.7 to 4.8
introduced deep changes like requiring c++. Its easy to say, why do we
need this? when one forgets that evolution, or was never familiar with it.
This line of reasoning is used often: "I can't see how this is useful
for the type of systems I envision, so this is not useful." Gentoo is
not that spectacular as a "regular" distro. Only masochists pick gentoo
as a desktop given that it has no installer --- why wouldn't the average
user pick ubuntu over gentoo if they want something that "just works."
But for niche systems, Gentoo shines like nothing else. ChromeOS would
never have been born of a debian-ish or fedora-ish distro. Let's keep
this alive.
Also, no to the name sys-devel/gcc-mgorny. I very much appreciate the
excellent hard work you've done on eclasses, but the reason this is
happening is because of patches that toolchain lead is not accepting.
Anyhow, most of the work with gcc (in my opinion) is with the patches
against gcc itself which are housed in ~vapier, ~rhill and ~zorry. When you
don't accept my patches to gcc-mgorny, shall I add gcc-basile to the tree?
Well, that would be in keeping with GLEP 39, which seems to encourage
everybody to fork each other's packages. :)
It seems like there is a fundamental disagreement here over the right
way to refactor all this code. Honestly, the fact that nobody seems
to even want to look at the toolchain suggests to me that
simplification is probably worthwhile.
This statement is not true. The maintainer is actively making commits
to toolchain.eclass and gcc. The problem stems from the maintainer
ignoring patches to the eclass regarding certain fixes, eg the thorny
dependencies on gcj[awt] which draws in windowing system stuff. A
compiler depending on media-libs/alsa-lib! Yuck!
These are QA issues. I do agree with Michal that they should be
addressed. I am willing to support QA against the maintainer as I said
in a previous email, after a review of proposed changes. But these
problems are not the occasion to throw out the current approach to
toolchain.
I tend to agree here too; let's get rid of the old versions of things
where we can and simplify.
This move will not simply things. It will just re-encode the
complexities in a new way. Or it will throw out stuff we later realize
we want. Take a look at bug #513716, #513578, #513576 and others and
tell me how any of the above suggestions to remove the eclass will make
that ugliness simple?
If people really want this, then I'd rather see a fork in the tree for
those "forward looking devs" and leave the current toolchian stuff in
tact for us old "fuddy duddies" like me.
William
--
Anthony G. Basile, Ph.D.
Gentoo Linux Developer [Hardened]
E-Mail : bluen...@gentoo.org
GnuPG FP : 1FED FAD9 D82C 52A5 3BAB DC79 9384 FA6E F52D 4BBA
GnuPG ID : F52D4BBA