On Saturday 15 March 2008, Enrico Weigelt wrote:
> * Alan McKinnon <[EMAIL PROTECTED]> wrote:
> > A long time ago I read a HUGE thread on b.g.o. about this, the
> > eventual conclusion is that after installation of a lib, a user
> > might well want to link those libs statically and if they are not
> > there, portage will barf big time and has no way to recover or even
> > know what went wrong. Then the poor user sits in mystery wondering
> > which package to remerge to get the .a
>
> Well, if there was an optional useflag (ie. "staticlib") which is
> turned on by default (or maybe "nostaticlib"), I don't see any
> problem. Most people will leave them enabled, only who are sure
> about this will disable them.

OK, I see your reasoning. It fits in the same general category 
where "USE=build" belongs - highly specialized.

However, I can predict with confidence that your chances of getting this 
accepted into portage are zero, for the following excellent reasons:

1. regardless of how many warning and how many FAQs state to not do it, 
a sizeable portion of idiots out there are going to enable it 
anyway "just to see what happens". We usually call these people ricers, 
it's the same twits who set CFLAGS=-O9999 and expect devs to help them 
out of the hole they dig for themselves. Most devs will take one look 
at this and decide why should they have their inbox filled with support 
mails from twits who do YADT (yet another dumb thing) at no real 
benefit to the dev himself? Heck, I wouldn't.

2. It's likely to break an unknown number of things in the tree. There 
is no easy way to know which ebuilds require a .a to be present, short 
of actually building everything in that state and seeing what breaks. 
Most devs would compare this to #1 and point blank refuse to support it 
for the same reason

3. Considering the current state of portage, good luck on finding a dev 
willing to build such a low-level feature into it :-) Getting it into 
paludis would be much easier IMHO

In summary, you have an excellent chance of breaking stuff that isn't 
broken for an arguably zero or near-zero benefit

> BTW: this leads me to another issue, which goes aroud in my mind for
> a longer time: packages should be split off into several "stripes"
> in the binary output. Other packages then could depend on single
> stripes at different levels. For example: if some package foo
> requires libbar, it would only depend on the buildtime stripe(s) for
> building (eg. so headers get pulled in), while at runtime it will
> only depend on the runtime stripe(s) of "bar". There could also be
> separate stripes for certain locales, docs, examples, etc.
>
> Such an approach could be really useful for binary-only targets
> (which don't build themselves) and network installations (eg.
> arch-dependent and -independent stripes could be installed
> separately).

Well, you do only need the headers to build, but the whole point of 
building the app is to run it, which requires the binaries anyway.

Frankly, it's easier to just manually delete the headers when the build 
is done

> > Ubuntu can get away with this, the user gets what the packager
> > feels like giving them, our users have *much* more freedom.
>
> I don't have much experiences w/ Ubuntu, but AFAIK this is an binary-
> distro. Those distros usually split the (binary) output into two
> separate packages, eg. "libfoo" is only the binary library, while
> "libfoo-devel" contains all the buildtime stuff (*.h, *.pc, ...).
> While this approach is quite simple, it's not very flexible and
> does't allow finer granulation (eg. separating locales, etc), but
> requires great care for filing dependencies.

Yes, Ubuntu is binary. The packagers operate under policies that say 
things like "You will always use dynamic linking", so they could delete 
all static libs from the shipped packages, as any such package that 
requires a .a is by definition broken.

The foo and foo-devel split is mostly a historical thing, dating from 
way back in the days of Red Hat 5 or even earlier. Back then, most 
users were on dial up (and binaries were much smaller than today) 
so -devel packages were introduced mostly to conserve bandwidth and 
resulting disk space. It's very much a hack actually.

You could successfully argue that this is no longer the case and we 
don't need -devel packages anymore as bandwidth and disk space are 
cheap. Add the fact that -devel packages cause lots of confusion to 
users with mysterious failures when they build something.

> > What's your reasoning for wanting to do this?
>
> a) saving space / skipping unused stuff
> b) preventing accidential static linking.
>
> While working on PHP and IMAP c-client, I discovered a broken
> libc-client.so* installation (turned out that just a symlink was
> missing). PHP always tried to build in the static library (since .so
> wasnt found), which leads to missing deps (eg. crypt,pam), after I
> removed the explicit deps within PHP. The whole issue began with PHP
> breaking at this point after I rebuild evrything w/o pam. PHP
> explicitly links in pam and crypt for IMAP c-client if it finds them.
> Obviously an dirty hack around libc-client's extremly poor
> engineering.

Hmmm. There are many thousand ebuilds in the tree. Many more in 3rd 
party overlays. Your idea fixes 1 problem in 1 ebuild.

My vote goes to the solution that tells the php packager to find a work 
around for the problem that they can check in their ebuild without 
disrupting the result of the ecosystem

-- 
Alan McKinnon
alan dot mckinnon at gmail dot com

-- 
gentoo-user@lists.gentoo.org mailing list

Reply via email to