1
0
mirror of https://git.tartarus.org/simon/putty.git synced 2025-01-10 01:48:00 +00:00

Create empty.h (used to force rebuilds of version.o by the automake

makefile) as a side effect of running mkfiles.pl.

The automake docs observe that the BUILT_SOURCES list is only
automatically built by plain 'make' or 'make all' or a couple of other
targets, so the sequence './configure && make plink' from a freshly
unpacked tar file would previously fail for lack of empty.h.

If empty.h had important _content_ that needed to be built at compile
time, of course, I wouldn't be able to fix it like this; but since the
only important thing is the timestamp, I can just make sure it already
exists at the time of first build.

[originally from svn r9288]
This commit is contained in:
Simon Tatham 2011-09-14 15:54:26 +00:00
parent aac16a33e8
commit a4424bfd85
2 changed files with 13 additions and 2 deletions

5
Recipe
View File

@ -179,9 +179,12 @@ version.o: FORCE
BUILT_SOURCES = empty.h BUILT_SOURCES = empty.h
CLEANFILES = empty.h CLEANFILES = empty.h
empty.h: $(allsources) empty.h: $(allsources)
echo '/* nothing to see here */' >$@ echo '/* Empty file touched by automake makefile to force rebuild of version.o */' >$@
!end !end
!begin >empty.h
/* Empty file touched by automake makefile to force rebuild of version.o */
!end
# Add VER to Windows resource targets, and force them to be rebuilt every # Add VER to Windows resource targets, and force them to be rebuilt every
# time, on the assumption that they will contain version information. # time, on the assumption that they will contain version information.

View File

@ -88,7 +88,9 @@ while (<IN>) {
} }
if ($_[0] eq "!forceobj") { $forceobj{$_[1]} = 1; next; } if ($_[0] eq "!forceobj") { $forceobj{$_[1]} = 1; next; }
if ($_[0] eq "!begin") { if ($_[0] eq "!begin") {
if (&mfval($_[1])) { if ($_[1] =~ /^>(.*)/) {
$divert = \$auxfiles{$1};
} elsif (&mfval($_[1])) {
$sect = $_[2] ? $_[2] : "end"; $sect = $_[2] ? $_[2] : "end";
$divert = \($makefile_extra{$_[1]}->{$sect}); $divert = \($makefile_extra{$_[1]}->{$sect});
} else { } else {
@ -145,6 +147,12 @@ while (<IN>) {
close IN; close IN;
foreach $aux (sort keys %auxfiles) {
open AUX, ">$aux";
print AUX $auxfiles{$aux};
close AUX;
}
# Now retrieve the complete list of objects and resource files, and # Now retrieve the complete list of objects and resource files, and
# construct dependency data for them. While we're here, expand the # construct dependency data for them. While we're here, expand the
# object list for each program, and complain if its type isn't set. # object list for each program, and complain if its type isn't set.