Date: Thu, 07 Feb 2002 14:55:26 -0800 From: Terry Lambert <tlambert2@mindspring.com> To: obrien@freebsd.org Cc: Max Khon <fjoe@iclub.nsu.ru>, Joe Kelsey <joe@zircon.seattle.wa.us>, current@freebsd.org Subject: Re: gcc3.x issues Message-ID: <3C6305DE.190E67D9@mindspring.com> References: <20020206160611.B181@dragon.nuxi.com> <200202070053.g170rjQ19592@aldan.algebra.com> <20020206170904.C181@dragon.nuxi.com> <15457.55061.55399.596297@zircon.zircon.seattle.wa.us> <20020206172554.A1999@dragon.nuxi.com> <15457.56475.172650.789685@zircon.zircon.seattle.wa.us> <20020207131144.A87654@iclub.nsu.ru> <3C624223.4AE24952@mindspring.com> <20020207100125.A53237@dragon.nuxi.com>
next in thread | previous in thread | raw e-mail | index | archive | help
David O'Brien wrote: > > And hacking the Makefile a lot to specify command line > > arguments in the compiler program definition itself, so > > that the /usr/include/g++ files that came with the old > > compiler are not used for "make release" and other types > > of make targets where DESTDIR is fairly mandatory. > > Terry, we only support building the world (ie, anything in /usr/src) with > the *SYSTEM* compiler. If you are wanting to do: > > cd /usr/src > make CC=FOOcc CXX=FOO++ buildworld > > Then you are going off into the "not-supported woods" and you should > expect to have to do some hacking. The problem I noted is C++ only. I'm sure that there are other cases where it's not, but they're really fuzzy, since I don't have a comprehensive tool chain listing that can get me an explosion if anything from the default chain gets used accidently. Wasn't Eric Melville going to fix this by turning the normal system components into packages? 8-) 8-). For the "buildworld" case, and the "release" case, the problem is incredibly deeper than just replacing the day to day use tools, since if you build the compiler as part of the build, you're screwed already. You can make an argument for the "release" case using a different set of tools, since it can install patches and packages prior to the build process, but the compiler you end up with will be the "release" compiler, not the package compiler, even though pretty much everything will have been compiled with the package compiler (or cross builds would not work at all). Even so, the interaction is ugly. I think Joe's main problem is that it's not documented, except in the heads of the people who've tried it, or the people who maintain it. Yeah, that's a problem, but the only thing we can really do about it is offer to answer questions, or tell them (or imply with a "where's the patches?" response) that they are on their own. Documentation won't magically appear (e.g.: "where's the patches?" 8-)). > If you are wanting to use /usr/share/mk for your own projects, then that > is also a debatable issue. Some claim /usr/share/mk is only for use of > /usr/src; others feel it should be generic and truely usable for other > code. If you have some well tested patches to fix the assumptions in > /usr/share/mk, we might can change things. Seperate problem. Though if it *were* generic... we might see the BSD make being more widely adopted. I think this is one of the tenets of the "Open Ports" project, FWIW. If nothing else, FreeBSD ought to be pulling back in their tools changes that they've found to be necessary, so long as they don't hurt too much ("a little pain is good for you", according to the penguins...). Personally, if my projects are limited to FreeBSD, I use the .mk system, and if they aren't, then I avoid it like the plague. Building a project based partly on Open Source is really an art, more than it is an easy thing to do, though it's often worth the pain to get the benefits (per my Daemon News article -- shameless plug). I think the biggest barrier these days is that there is so much that is assumed to be "part of the base system" that is not really generic UNIX, and avoiding contamination from use of, for example, the FreeBSD version of OpenSSL, rather than the version in your source tree, requires that the engineer doing the work cross their T's and dot their I's correctly, or they will find that their code works on their developement machine, but not their target machine. Fixing *that* problem is a lot more than just waving your hands: it requires duct tape and prayers, since you will find yourself fixing the software packages you depend upon, too (this is the major drawback of autconf/automake: unlike imake and xmkmf, they really aren't portability tools, and can't make a program run on a new target through a correct description of the target, like imake can -- e.g. MySQL now runs on AIX again because I hit my head on it, and there are 5 or 6 other Open Source projects that got patches out of my last round of head hitting). In any case, it's often hard to discuss Hoover Dam when you are running low on fingers plugging holes in the local levy; know that your work on the levy *is* appreciated, since we would all be under water otherwise. I'll look at what it will take to fix the DESTDIR stuff without breaking things. That's a far cry from what Joe wanted, but it's a step in that direction, anyway. It's going to boil down to tracking down everywhere it's used in the source tree as is, particularly with regards to the "make release" case, where the headers have to come in from the target environment, but also in ports. 8-(. Fortunately, there is not a lot of C++ code in the release stuff; the ports stuff will be more problematic, of course, but much of that is already broken, in that the system compiler is passed, but the g++ compiler is searched out and preferred (!@#!$!@ autoconf/automake). ...Uh, don't let me looking at this stop anyone else from looking at it too... I won't feel offended if someone else fixes it before I get around to it. 8-). -- Terry To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-current" in the body of the message
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?3C6305DE.190E67D9>