Re: Future plans for Autotools

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Mon, Jan 25, 2021 at 03:15:47PM -0800, Paul Eggert wrote:
> On 1/25/21 2:59 PM, Gavin Smith wrote:
> > Does this
> > work or does GNU make have other ways of doing this?  (It would be
> > better if it could be done without communicating via files.)  Is there
> > any way to set a Makefile variable from within a rule and then depend upon
> > that variable being set in other rules?
> 
> GNU Make supports variables defined via ::=, and an earlier section of a GNU
> makefile could compute CC and assign to it that way. This would handle the
> simple case you gave. Unfortunately there are other cases that would require
> intermediate files with current GNU Make. Still, the overhead in using files
> would be worth it (at least for me) if we could use make -j.
> 
> The ::= feature was added to POSIX ten years ago or so, so it could even be
> used in Makefiles intended to be portable to other new-enough
> POSIX-compatible platforms. It wouldn't work on older platforms, though.

Another issue is how to record the results of tests from a a Makefile.
With autoconf, autoconf variables are recorded with AC_CONFIG_FILES
and AC_CONFIG_HEADERS.  Presumably the same would have to be done,
substituting in an output file with the values of these variables.
However, there can be many hundreds of them (just look at a Makefile.in
file).  As far as I can tell, there isn't an easy way to export
hundreds of Makefile variables to a process.  Is there some feature or
trick I'm missing?

You could build up a long command line, but it could end up being
extremely long.  The code below shows how this could be done with
GNU Make (for just 3 variables).  The substitution step would need to
be done after all the variables had been set, unless there was some
kind of locking/synchronisation to allow Makefile rules to record
configuration variables in parallel.  It's possible to create a
small file for every variable but this would lead to hundreds of
small files being created.

VARS::=

VARS::=$(VARS) A=$$(A)
set-A:
	$(eval A ::= $(shell echo 1))

VARS::=$(VARS) B=$$(B)
set-B:
	$(eval B ::= $(shell echo 2))

VARS::=$(VARS) C=$$(C)
set-C:
	$(eval C ::= $(shell echo 3))

finish-configure: set-A set-B set-C
	$(eval EXVARS=$(VARS))
	export $(EXVARS) ; echo "$$A $$B $$C"





[Index of Archives]     [GCC Help]     [Kernel Discussion]     [RPM Discussion]     [Red Hat Development]     [Yosemite News]     [Linux USB]     [Samba]

  Powered by Linux