mirror of
https://git.savannah.gnu.org/git/make.git
synced 2024-11-24 04:09:41 +00:00
[SV 65917] Mark also_make targets as updated in make -n
Suggested patch by Hannes Domani <ssbssa@yahoo.de> * src/remake.c (notice_finished_file): When run with -n, mark also_make targets as updated. * tests/scripts/options/dash-n: Test pattern and grouped targets.
This commit is contained in:
parent
bc979e4949
commit
c63a5bc6a2
3 changed files with 78 additions and 13 deletions
1
AUTHORS
1
AUTHORS
|
@ -64,6 +64,7 @@ Other contributors:
|
||||||
Jeremy Devenport <jeremy.devenport@gmail.com>
|
Jeremy Devenport <jeremy.devenport@gmail.com>
|
||||||
Pete Dietl <petedietl@gmail.com>
|
Pete Dietl <petedietl@gmail.com>
|
||||||
Aaron Digulla <digulla@fh-konstanz.de>
|
Aaron Digulla <digulla@fh-konstanz.de>
|
||||||
|
Hannes Domani <ssbssa@yahoo.de>
|
||||||
Martin Dorey <martin.dorey@hds.com>
|
Martin Dorey <martin.dorey@hds.com>
|
||||||
Christian Eggers <ceggers@arri.de>
|
Christian Eggers <ceggers@arri.de>
|
||||||
Paul Eggert <eggert@twinsun.com>
|
Paul Eggert <eggert@twinsun.com>
|
||||||
|
|
16
src/remake.c
16
src/remake.c
|
@ -1112,11 +1112,17 @@ notice_finished_file (struct file *file)
|
||||||
d->file->update_status = file->update_status;
|
d->file->update_status = file->update_status;
|
||||||
|
|
||||||
if (ran && !d->file->phony)
|
if (ran && !d->file->phony)
|
||||||
/* Fetch the new modification time.
|
{
|
||||||
We do this instead of just invalidating the cached time
|
/* Fetch the new modification time.
|
||||||
so that a vpath_search can happen. Otherwise, it would
|
We do this instead of just invalidating the cached time
|
||||||
never be done because the target is already updated. */
|
so that a vpath_search can happen. Otherwise, it would
|
||||||
f_mtime (d->file, 0);
|
never be done because the target is already updated. */
|
||||||
|
f_mtime (d->file, 0);
|
||||||
|
|
||||||
|
if (just_print_flag)
|
||||||
|
/* Nothing got updated, but pretend it did. */
|
||||||
|
d->file->last_mtime = NEW_MTIME;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* If the target was created by an implicit rule, and it was updated,
|
/* If the target was created by an implicit rule, and it was updated,
|
||||||
|
|
|
@ -15,8 +15,6 @@ intermediate: orig ; echo >> $@
|
||||||
|
|
||||||
run_make_test(undef, '-Worig -n', "echo >> intermediate\necho >> final\n");
|
run_make_test(undef, '-Worig -n', "echo >> intermediate\necho >> final\n");
|
||||||
|
|
||||||
rmfiles(qw(orig intermediate final));
|
|
||||||
|
|
||||||
# We consider the actual updated timestamp of targets with all
|
# We consider the actual updated timestamp of targets with all
|
||||||
# recursive commands, even with -n. Switching this to the new model
|
# recursive commands, even with -n. Switching this to the new model
|
||||||
# is non-trivial because we use a trick below to change the log content
|
# is non-trivial because we use a trick below to change the log content
|
||||||
|
@ -65,10 +63,6 @@ close(DASH_N_LOG);
|
||||||
|
|
||||||
&compare_output("touch b\ntouch a\n", &get_logfile(1));
|
&compare_output("touch b\ntouch a\n", &get_logfile(1));
|
||||||
|
|
||||||
# CLEANUP
|
|
||||||
|
|
||||||
unlink(qw(a b c));
|
|
||||||
|
|
||||||
# Ensure -n continues to be included with recursive/re-execed make
|
# Ensure -n continues to be included with recursive/re-execed make
|
||||||
# See Savannah bug #38051
|
# See Savannah bug #38051
|
||||||
|
|
||||||
|
@ -81,7 +75,6 @@ foo: ; \@\$(MAKE) -f "$submake" bar
|
||||||
EOF
|
EOF
|
||||||
close(MAKEFILE);
|
close(MAKEFILE);
|
||||||
|
|
||||||
|
|
||||||
# The bar target should print what would happen, but not actually run
|
# The bar target should print what would happen, but not actually run
|
||||||
open(MAKEFILE, "> $submake");
|
open(MAKEFILE, "> $submake");
|
||||||
print MAKEFILE <<'EOF';
|
print MAKEFILE <<'EOF';
|
||||||
|
@ -95,6 +88,71 @@ close(MAKEFILE);
|
||||||
$answer = subst_make_string("#MAKEPATH# -f \"$submake\" bar\ntouch inc\necho n --no-print-directory\n");
|
$answer = subst_make_string("#MAKEPATH# -f \"$submake\" bar\ntouch inc\necho n --no-print-directory\n");
|
||||||
&compare_output($answer, &get_logfile(1));
|
&compare_output($answer, &get_logfile(1));
|
||||||
|
|
||||||
unlink('inc');
|
# SV 65917: Verify handling of -n with multi-target pattern rules
|
||||||
|
|
||||||
|
# This is what the makefile below would run
|
||||||
|
utouch(-12, qw(alpha.p));
|
||||||
|
utouch(-10, qw(alpha.x alpha.y));
|
||||||
|
utouch(-8, qw(beta.p));
|
||||||
|
utouch(-6, qw(beta.x beta.y));
|
||||||
|
utouch(-4, qw(alpha.q));
|
||||||
|
utouch(-2, qw(beta.q));
|
||||||
|
|
||||||
|
# Now make some things out of date
|
||||||
|
touch(qw(alpha.p));
|
||||||
|
|
||||||
|
run_make_test(q!
|
||||||
|
.SUFFIXES:
|
||||||
|
.RECIPEPREFIX := >
|
||||||
|
|
||||||
|
all: alpha.q beta.q
|
||||||
|
|
||||||
|
alpha.p beta.p:
|
||||||
|
> touch $@
|
||||||
|
|
||||||
|
%.x %.y: %.p
|
||||||
|
> touch $*.x $*.y
|
||||||
|
|
||||||
|
alpha.q: alpha.x alpha.y beta.y
|
||||||
|
> touch $@
|
||||||
|
|
||||||
|
beta.q: beta.x beta.y alpha.y
|
||||||
|
> touch $@
|
||||||
|
!,
|
||||||
|
'-n', "touch alpha.x alpha.y\ntouch alpha.q\ntouch beta.q\n");
|
||||||
|
|
||||||
|
# This is what the makefile below would run
|
||||||
|
utouch(-12, qw(quark.p));
|
||||||
|
utouch(-10, qw(quark.x quark.y));
|
||||||
|
utouch(-8, qw(meson.p));
|
||||||
|
utouch(-6, qw(meson.x meson.y));
|
||||||
|
utouch(-4, qw(quark.q));
|
||||||
|
utouch(-2, qw(meson.q));
|
||||||
|
|
||||||
|
# Now make some things out of date
|
||||||
|
touch(qw(quark.p));
|
||||||
|
|
||||||
|
run_make_test(q!
|
||||||
|
.SUFFIXES:
|
||||||
|
.RECIPEPREFIX := >
|
||||||
|
|
||||||
|
all: quark.q meson.q
|
||||||
|
|
||||||
|
quark.p meson.p:
|
||||||
|
> touch $@
|
||||||
|
|
||||||
|
quark.x quark.y &: quark.p
|
||||||
|
> touch quark.x quark.y
|
||||||
|
|
||||||
|
meson.x meson.y &: meson.p
|
||||||
|
> touch meson.x meson.y
|
||||||
|
|
||||||
|
quark.q: quark.x quark.y meson.y
|
||||||
|
> touch $@
|
||||||
|
|
||||||
|
meson.q: meson.x meson.y quark.y
|
||||||
|
> touch $@
|
||||||
|
!,
|
||||||
|
'-n', "touch quark.x quark.y\ntouch quark.q\ntouch meson.q\n");
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
|
Loading…
Reference in a new issue