RFR: JDK-8034199 Add 'reconfigure' target for re-creating a configuration
Magnus Ihse Bursie
magnus.ihse.bursie at oracle.com
Mon Feb 17 14:04:36 UTC 2014
On 2014-02-17 03:10, David Holmes wrote:
> Presumably the right way to do this would be:
>
> "make clean reconfigure ..."
>
> otherwise you could get some kind of weird hybrid build. I'm not sure
> that every change in spec.gmk, for example would force a recompile of
> everything that depended on something in there. But perhaps it does?
I agree. The only way we can guarantee a correct build after a
configuration change is to clean the build.
Unfortunately, this seems a bit harsh, since most of the time a complete
rebuild is not needed.
Ideally, we would of course be able to detect exactly what needs to be
rebuilt as a result of creating a new configuration in place with
different arguments, or by re-creating the same configuration due to an
update of the configuration script. In practice, that's hardly doable. :-(
The compromise we have chosen is to:
1) check in make if the configure script has been updated since spec.gmk
was generated. If so, abort and request a reconfiguration. (Which will
be helped by the current patch.)
2) check in configure if there are an existing configuration in place.
This can be the case either due to the user creating a new configuration
with different arguments (or on a different platform using a network
share etc), or due to a recreation of the original configuration,
perhaps as prompted to by case 1. For this, we only generates a warning
(saying that it is recommended that you run "make clean").
We could get harder about the sloppiness in step 2, and force a make
clean, but I haven't heard many complaints about incorrect build results
due to such changes, but I'm sure we'd hear complaints about too
frequent updates to the configure files if we were to enforce a clean! :-)
> Sometimes I've re-run configure with the exact same args and I get a
> warning about doing this over an existing configuration ?? At which
> point I either do a dist-clean or "rm -rf ...".
You'll get this warning everytime you run configure where a spec.gmk
already exists. If you have not noticed it always, it is because you are
like everyone else and do not read configure warnings. ;-)
/Magnus
More information about the build-dev
mailing list