Do not force targets to be SECONDARY

In SV 43677 we forced targets to be secondary if we found an
intermediate file that was listed as a prerequisite of another
target.  This overrides .INTERMEDIATE settings, so doesn't work.
Now that we have an is_explicit flag in targets, use that instead.

* src/implicit.c (pattern_search): Remove setting of secondary.
Preserve the value of the is_explicit flag when creating a new
file target, and consider it when setting the intermediate flag.
* tests/scripts/features/patternrules: Add a test w/out INTERMEDIATE
* tests/scripts/targets/INTERMEDIATE: Add a test with INTERMEDIATE
This commit is contained in:
Paul Smith 2021-12-29 14:44:46 -05:00
parent f2b130bda8
commit 6682fbc2cb
3 changed files with 28 additions and 8 deletions

View file

@ -963,13 +963,7 @@ pattern_search (struct file *file, int archive,
struct file *imf = pat->file; struct file *imf = pat->file;
struct file *f = lookup_file (imf->name); struct file *f = lookup_file (imf->name);
/* We don't want to delete an intermediate file that happened if (!f)
to be a prerequisite of some (other) target. Mark it as
secondary. We don't want it to be precious as that disables
DELETE_ON_ERROR etc. */
if (f != 0)
f->secondary = 1;
else
f = enter_file (imf->name); f = enter_file (imf->name);
f->deps = imf->deps; f->deps = imf->deps;
@ -984,8 +978,9 @@ pattern_search (struct file *file, int archive,
f->pat_searched = imf->pat_searched; f->pat_searched = imf->pat_searched;
f->also_make = imf->also_make; f->also_make = imf->also_make;
f->is_target = 1; f->is_target = 1;
f->is_explicit |= imf->is_explicit || pat->is_explicit;
f->notintermediate |= imf->notintermediate; f->notintermediate |= imf->notintermediate;
f->intermediate |= !(pat->is_explicit || f->notintermediate); f->intermediate |= !f->is_explicit && !f->notintermediate;
f->tried_implicit = 1; f->tried_implicit = 1;
imf = lookup_file (pat->pattern); imf = lookup_file (pat->pattern);

View file

@ -444,5 +444,17 @@ hello.tsk:
unlink('hello.tsk'); unlink('hello.tsk');
# A target explicitly listed as a prerequisite of a pattern rule, is still
# considered mentioned and "ought to exist".
run_make_test(q!
1.all: 1.q ; touch $@
%.q: 1.r ; touch $@
%.r: ; touch $@
!,
'', "touch 1.r\ntouch 1.q\ntouch 1.all\n");
unlink('1.all', '1.q', '1.r');
# This tells the test driver that the perl test script executed properly. # This tells the test driver that the perl test script executed properly.
1; 1;

View file

@ -120,5 +120,18 @@ all: hello.z
unlink('hello.z'); unlink('hello.z');
# A target explicitly listed as a prerequisite of a pattern rule, is still
# considered mentioned and "ought to exist".
run_make_test(q!
1.all: 1.q ; touch $@
%.q: 1.r ; touch $@
%.r: ; touch $@
.INTERMEDIATE: 1.r
!,
'', "touch 1.r\ntouch 1.q\ntouch 1.all\nrm 1.r\n");
unlink('1.all', '1.q', '1.r');
# This tells the test driver that the perl test script executed properly. # This tells the test driver that the perl test script executed properly.
1; 1;