Date: Tue, 21 Jan 1997 08:41:15 +0200 (IST) From: Eli Zaretskii <eliz AT is DOT elta DOT co DOT il> To: Mark Habersack <grendel AT ananke DOT amu DOT edu DOT pl> cc: djgpp-workers AT delorie DOT com Subject: Re: Configure scripts In-Reply-To: <199701192041.VAA07597@math.amu.edu.pl> Message-ID: <Pine.SUN.3.91.970121083130.26269D-100000@is> MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII On Sun, 19 Jan 1997, Mark Habersack wrote: > Wouldn't it be possible to pre-generate config scripts with bash on your machine and > distribute them along with the sources? That way you have all the birds in > your hand: someone who doesn't have bash/tools already has a pre-configured > package and someone else with bash/tools can reconfigure it at will. Or is > that solution not flexible enough? It doesn't work this way at all. The configure script is itself a shell script which requires a Unix shell to run; that's where the port of bash comes in handy. The generation of configure scripts is done by a totally different tool (GNU autoconf, based on the m4 macro-processor); when you get a source release of any GNU package, that part is already done by the person who released that package. But you cannot *run* configure unless you have a Unix shell. What configure scripts do is to probe the system for existence and names of various programs (such as the C compiler and preprocessor) and support for some non-standard functions and header files. The script then automatically generates the Makefiles and the local "config.h" header so you only have to say "make" and watch the stuff build itself. DJGPP comes with <sys/config.h> which takes care of most of the second part, but creating Makefiles is still a job to be done for every ported package, and it needs to be redone with every new release of a package, even if a previous version has already been ported, because some major releases change the package too much.