BIND segway -> python -> first-class ports

Alfred Perlstein alfred at freebsd.org
Wed Dec 4 02:11:04 UTC 2013


On 12/3/13, 5:58 PM, Julian Elischer wrote:
> On 12/4/13, 9:05 AM, Mark Felder said:
> -----------------
>
>> There was no alternative; we couldn't keep BIND in base. BIND 9 will
>> certainly have a EoL before the EoL of FreeBSD 10.x, and we can't use
>> BIND 10 because it requires importing Python to base.
>
> I'm coming more and more to the conclusion that we should have a 
> minimal Python in "base".
> More and more people are expecting it and more and more software needs 
> it.
>
> But maybe the problem is our definition of "base".
>
> I have said before that in my opinion we should have two classes of 
> ports.
> Mechanically they are handled the same but class 1 ports are "standard 
> additions",
> and if they don't work it's a "stop-ship" condition.. These would be 
> MAJOR ports..
> like a minimal python, a minimal Perl (ok yuk but some people would 
> insist),
> BIND, Sendmail, bash, and other things that people EXPECT to be in a 
> FreeBSD system.
> If you break such a port it has the same weight as breaking something 
> in base,
> but it's not base..

I think you would agree that while it would be a major boost in 
productivity for us to have python in base, at the same time it would 
cause quite a bit of problems as "FreeBSD's" python would be out of date 
or it would give the appearance that we only support a single version of 
python (unless we kept it bleeding edge).

A workaround for this problem is to bring in python, but to hide it 
under /usr/bsd/bin and only allow system utilities to explicitly 
reference it.  In fact a number of our other tools should very likely go 
under there or some mechanism such as the "use.perl" tool needs to be 
made not only for python, but also for clang and gcc.

Why?  Well because the outsiders I've talked to run FreeBSD and see 
older versions of the utilities in base (even though newer versions 
exist in ports) and wind up assuming that's the newest version that can 
work on FreeBSD and ignore ports.  After a while those users run away to 
Linux where you just "apt-get cc" and get the shinest newest thing 
possible on any distro you consider relevant today.

We MUST decouple the base requirements from what users want from ports.  
*WE* might want python 2.x OR *we* may want 3.x, but by putting it under 
/usr/bin and polluting the user's environment we lock the user into it.  
We must not do that otherwise we repeat the tcl fiasco and the perl 
fiasco and the gcc/egcs/clang fiasco over and over and over again.

So yes, let's get python in base, but *not make it user visible*. We 
need to only make it visible for internal use of our "src base".

The point being we need to keep ports/packages as the defacto place 
where people get python from, while the base system itself has its own 
version it uses.

Either that or we need to throw in the towel and go into more of a 
distro model where things like python and bind are never part of 
/usr/src, however they are by default installed.

Or, finally the choice can always be put the onus onto the user to 
install such packages OR leave it to the distro maintainer, an example 
being PC-BSD, or JulianBSD.

-Alfred


More information about the freebsd-stable mailing list