mirror of
https://github.com/mirror/make.git
synced 2025-03-11 02:00:35 +08:00
[SV 63537] Document and test flippable switches
* doc/make.texi (Options/Recursion): Clarify that MAKEFLAGS values from the environment have precedence over those set in the makefile. * tests/scripts/variables/MAKEFLAGS: Check boolean switches -k/-S, -w/--no-print-directory and -s/--no-silent as follows: 1. A switch can be enabled or disabled on the command line. 2. A switch can be enabled or disabled in env. 3. A switch can be enabled or disabled in makefile. 4. Command line beats env and makefile. 5. Env beats makefile. 6. MAKEFLAGS contains each specified switch at parse and build time. 7. If switches are specified in multiple origins, MAKEFLAGS contains the winning switch at parse and build time. 8. MAKEFLAGS does not contain the losing switch. Also test that --debug settings from different origins are combined together into one option.
This commit is contained in:
parent
8e805c7ba6
commit
7d8756a4a3
@ -5070,10 +5070,12 @@ set up automatically by @code{make} to contain the flag letters that
|
||||
@code{make} received. Thus, if you do @w{@samp{make -ks}} then
|
||||
@code{MAKEFLAGS} gets the value @samp{ks}.
|
||||
|
||||
As a consequence, every sub-@code{make} gets a value for @code{MAKEFLAGS}
|
||||
in its environment. In response, it takes the flags from that value and
|
||||
processes them as if they had been given as arguments.
|
||||
@xref{Options Summary, ,Summary of Options}.
|
||||
As a consequence, every sub-@code{make} gets a value for @code{MAKEFLAGS} in
|
||||
its environment. In response, it takes the flags from that value and
|
||||
processes them as if they had been given as arguments. @xref{Options Summary,
|
||||
,Summary of Options}. This means that, unlike other environment variables,
|
||||
@code{MAKEFLAGS} specified in the environment take precedence over
|
||||
@code{MAKEFLAGS} specified in the makefile.
|
||||
|
||||
The value of @code{MAKEFLAGS} is a possibly empty group of characters
|
||||
representing single-letter options that take no argument, followed by a space
|
||||
|
@ -13,11 +13,11 @@ run_make_test(undef, '-s', "MAKEFLAGS=s\ntwo");
|
||||
run_make_test(undef, '--silent', "MAKEFLAGS=s\ntwo");
|
||||
run_make_test(undef, '--quiet', "MAKEFLAGS=s\ntwo");
|
||||
|
||||
run_make_test(undef, '--no-silent', "MAKEFLAGS=\necho two\ntwo");
|
||||
run_make_test(undef, '--no-silent', "MAKEFLAGS= --no-silent\necho two\ntwo");
|
||||
|
||||
run_make_test(undef, '-s --no-silent', "MAKEFLAGS=\necho two\ntwo");
|
||||
run_make_test(undef, '--silent --no-silent', "MAKEFLAGS=\necho two\ntwo");
|
||||
run_make_test(undef, '--quiet --no-silent', "MAKEFLAGS=\necho two\ntwo");
|
||||
run_make_test(undef, '-s --no-silent', "MAKEFLAGS= --no-silent\necho two\ntwo");
|
||||
run_make_test(undef, '--silent --no-silent', "MAKEFLAGS= --no-silent\necho two\ntwo");
|
||||
run_make_test(undef, '--quiet --no-silent', "MAKEFLAGS= --no-silent\necho two\ntwo");
|
||||
|
||||
run_make_test(undef, '--no-silent -s', "MAKEFLAGS=s\ntwo");
|
||||
run_make_test(undef, '--no-silent --silent', "MAKEFLAGS=s\ntwo");
|
||||
|
@ -368,4 +368,528 @@ all:; $(info good)
|
||||
!, 'hello=\'$(world\'', "good\n#MAKE#: 'all' is up to date.\n");
|
||||
|
||||
|
||||
|
||||
# sv 63537
|
||||
# Certain switches can be flipped on and off.
|
||||
# -k/-S, -w/--no-print-directory and -s/--no-silent.
|
||||
# Test the following aspects of behavior of these switches
|
||||
# 1. A switch can be enabled or disabled in makefile.
|
||||
# 2. A switch can be enabled or disabled in env.
|
||||
# 3. A switch can be enabled or disabled on the command line.
|
||||
# 4. Command line beats makefile.
|
||||
# 5. Env beats makefile.
|
||||
# 6. Command line beats env.
|
||||
# 7. MAKEFLAGS contains each specified switch at parse and build time.
|
||||
# 8. If contradicting switches are specified in multiple origins, MAKEFLAGS
|
||||
# contains the winning switch at parse and build time.
|
||||
# 9. MAKEFLAGS does not contain the beaten switch.
|
||||
|
||||
my @flavors = ('=', ':=', ':::=', '+=');
|
||||
|
||||
# sv 63537
|
||||
# -w vs --no-print-directory
|
||||
|
||||
# -w on the command line.
|
||||
run_make_test(q!
|
||||
$(info $(MAKEFLAGS))
|
||||
all:; $(info $(MAKEFLAGS))
|
||||
!, '-w',
|
||||
"#MAKE#: Entering directory '#PWD#'
|
||||
w
|
||||
w
|
||||
#MAKE#: 'all' is up to date.
|
||||
#MAKE#: Leaving directory '#PWD#'\n");
|
||||
|
||||
# -w in the env.
|
||||
$ENV{'MAKEFLAGS'} = '-w';
|
||||
run_make_test(q!
|
||||
$(info $(MAKEFLAGS))
|
||||
all:; $(info $(MAKEFLAGS))
|
||||
!, '',
|
||||
"#MAKE#: Entering directory '#PWD#'
|
||||
w
|
||||
w
|
||||
#MAKE#: 'all' is up to date.
|
||||
#MAKE#: Leaving directory '#PWD#'\n");
|
||||
|
||||
# -w in env, --no-print-directory on the command line.
|
||||
$ENV{'MAKEFLAGS'} = '-w';
|
||||
run_make_test(q!
|
||||
$(info $(MAKEFLAGS))
|
||||
all:; $(info $(MAKEFLAGS))
|
||||
!, '--no-print-directory',
|
||||
" --no-print-directory
|
||||
--no-print-directory
|
||||
#MAKE#: 'all' is up to date.\n");
|
||||
|
||||
# --no-print-directory in env, -w on the command line.
|
||||
$ENV{'MAKEFLAGS'} = '--no-print-directory';
|
||||
run_make_test(q!
|
||||
$(info $(MAKEFLAGS))
|
||||
all:; $(info $(MAKEFLAGS))
|
||||
!, '-w',
|
||||
"#MAKE#: Entering directory '#PWD#'
|
||||
w
|
||||
w
|
||||
#MAKE#: 'all' is up to date.
|
||||
#MAKE#: Leaving directory '#PWD#'\n");
|
||||
|
||||
delete $ENV{'MAKEFLAGS'};
|
||||
|
||||
# -w in makefile.
|
||||
for my $fl (@flavors) {
|
||||
run_make_test("
|
||||
MAKEFLAGS${fl}-w
|
||||
\$(info \$(MAKEFLAGS))
|
||||
all:; \$(info \$(MAKEFLAGS))
|
||||
", '',
|
||||
"#MAKE#: Entering directory '#PWD#'
|
||||
w
|
||||
w
|
||||
#MAKE#: 'all' is up to date.
|
||||
#MAKE#: Leaving directory '#PWD#'\n");
|
||||
}
|
||||
|
||||
# sv 63537
|
||||
# -w in makefile, --no-print-directory on the command line.
|
||||
for my $fl (@flavors) {
|
||||
run_make_test("
|
||||
MAKEFLAGS${fl}-w
|
||||
\$(info \$(MAKEFLAGS))
|
||||
all:; \$(info \$(MAKEFLAGS))
|
||||
", '--no-print-directory',
|
||||
" --no-print-directory
|
||||
--no-print-directory
|
||||
#MAKE#: 'all' is up to date.\n");
|
||||
}
|
||||
|
||||
mkdir('lib2', 0777);
|
||||
create_file('lib2/makefile', 'all:; $(info $(MAKEFLAGS))');
|
||||
|
||||
# sv 63537
|
||||
# Default, no -w or --no-print-directory is specified.
|
||||
run_make_test(q!
|
||||
all:; $(MAKE) -C lib2
|
||||
!, '',
|
||||
"#MAKEPATH# -C lib2
|
||||
#MAKE#[1]: Entering directory '#PWD#/lib2'
|
||||
|
||||
#MAKE#[1]: 'all' is up to date.
|
||||
#MAKE#[1]: Leaving directory '#PWD#/lib2'\n");
|
||||
|
||||
# sv 63537
|
||||
# --no-print-directory in makefile, -w on the command line.
|
||||
for my $fl (@flavors) {
|
||||
run_make_test("
|
||||
MAKEFLAGS${fl}--no-print-directory
|
||||
\$(info \$(MAKEFLAGS))
|
||||
all:
|
||||
\$(info \$(MAKEFLAGS))
|
||||
\$(MAKE) -C lib2
|
||||
", '-w',
|
||||
"#MAKE#: Entering directory '#PWD#'
|
||||
w
|
||||
w
|
||||
#MAKEPATH# -C lib2
|
||||
#MAKE#[1]: Entering directory '#PWD#/lib2'
|
||||
w
|
||||
#MAKE#[1]: 'all' is up to date.
|
||||
#MAKE#[1]: Leaving directory '#PWD#/lib2'
|
||||
#MAKE#: Leaving directory '#PWD#'\n");
|
||||
}
|
||||
|
||||
# sv 63537
|
||||
# --no-print-directory in makefile, -w in the env.
|
||||
for my $fl (@flavors) {
|
||||
$ENV{'MAKEFLAGS'} = '-w';
|
||||
run_make_test("
|
||||
MAKEFLAGS${fl}--no-print-directory
|
||||
\$(info \$(MAKEFLAGS))
|
||||
all:
|
||||
\$(info \$(MAKEFLAGS))
|
||||
\$(MAKE) -C lib2
|
||||
", '',
|
||||
"#MAKE#: Entering directory '#PWD#'
|
||||
w
|
||||
w
|
||||
#MAKEPATH# -C lib2
|
||||
#MAKE#[1]: Entering directory '#PWD#/lib2'
|
||||
w
|
||||
#MAKE#[1]: 'all' is up to date.
|
||||
#MAKE#[1]: Leaving directory '#PWD#/lib2'
|
||||
#MAKE#: Leaving directory '#PWD#'\n");
|
||||
}
|
||||
|
||||
unlink('lib2/makefile');
|
||||
rmdir('lib2');
|
||||
|
||||
# sv 63537
|
||||
# -k vs -S.
|
||||
|
||||
|
||||
# -S in env.
|
||||
$ENV{'MAKEFLAGS'} = '-S';
|
||||
run_make_test(q!
|
||||
$(info $(MAKEFLAGS))
|
||||
all: one two
|
||||
one:
|
||||
$(info $(MAKEFLAGS))
|
||||
false
|
||||
two:; $(info $@)
|
||||
!, '',
|
||||
"S
|
||||
S
|
||||
false
|
||||
#MAKE#: *** [#MAKEFILE#:6: one] Error 1", 512);
|
||||
|
||||
# -S in env, -k on the command line.
|
||||
$ENV{'MAKEFLAGS'} = '-S';
|
||||
run_make_test(q!
|
||||
$(info $(MAKEFLAGS))
|
||||
all: one two
|
||||
one:
|
||||
$(info $(MAKEFLAGS))
|
||||
false
|
||||
two:; $(info $@)
|
||||
!, '-k',
|
||||
"k
|
||||
k
|
||||
false
|
||||
#MAKE#: *** [#MAKEFILE#:6: one] Error 1
|
||||
two
|
||||
#MAKE#: Target 'all' not remade because of errors.", 512);
|
||||
|
||||
# -k in env.
|
||||
$ENV{'MAKEFLAGS'} = '-k';
|
||||
run_make_test(q!
|
||||
$(info $(MAKEFLAGS))
|
||||
all: one two
|
||||
one:
|
||||
$(info $(MAKEFLAGS))
|
||||
false
|
||||
two:; $(info $@)
|
||||
!, '',
|
||||
"k
|
||||
k
|
||||
false
|
||||
#MAKE#: *** [#MAKEFILE#:6: one] Error 1
|
||||
two
|
||||
#MAKE#: Target 'all' not remade because of errors.", 512);
|
||||
|
||||
# -k in env, -S on the command line.
|
||||
$ENV{'MAKEFLAGS'} = '-k';
|
||||
run_make_test(q!
|
||||
$(info $(MAKEFLAGS))
|
||||
all: one two
|
||||
one:
|
||||
$(info $(MAKEFLAGS))
|
||||
false
|
||||
two:; $(info $@)
|
||||
!, '-S',
|
||||
"S
|
||||
S
|
||||
false
|
||||
#MAKE#: *** [#MAKEFILE#:6: one] Error 1", 512);
|
||||
|
||||
delete $ENV{'MAKEFLAGS'};
|
||||
|
||||
# -k in makefile.
|
||||
for my $fl (@flavors) {
|
||||
run_make_test("
|
||||
MAKEFLAGS${fl}-k
|
||||
\$(info \$(MAKEFLAGS))
|
||||
all: one two
|
||||
one:
|
||||
\$(info \$(MAKEFLAGS))
|
||||
false
|
||||
two:; \$(info \$@)
|
||||
", '',
|
||||
"k
|
||||
k
|
||||
false
|
||||
#MAKE#: *** [#MAKEFILE#:7: one] Error 1
|
||||
two
|
||||
#MAKE#: Target 'all' not remade because of errors.", 512);
|
||||
}
|
||||
|
||||
# sv 63537
|
||||
# -k in makefile and -S on the command line.
|
||||
for my $fl (@flavors) {
|
||||
run_make_test("
|
||||
MAKEFLAGS${fl}-k
|
||||
\$(info \$(MAKEFLAGS))
|
||||
all: one two
|
||||
one:
|
||||
\$(info \$(MAKEFLAGS))
|
||||
false
|
||||
two:; \$(info \$@)
|
||||
", '-S',
|
||||
"S
|
||||
S
|
||||
false
|
||||
#MAKE#: *** [#MAKEFILE#:7: one] Error 1", 512);
|
||||
}
|
||||
|
||||
# sv 63537
|
||||
# -k in makefile and -S in the env.
|
||||
for my $fl (@flavors) {
|
||||
$ENV{'MAKEFLAGS'} = '-S';
|
||||
run_make_test("
|
||||
MAKEFLAGS${fl}-k
|
||||
\$(info \$(MAKEFLAGS))
|
||||
all: one two
|
||||
one:
|
||||
\$(info \$(MAKEFLAGS))
|
||||
false
|
||||
two:; \$(info \$@)
|
||||
", '',
|
||||
"S
|
||||
S
|
||||
false
|
||||
#MAKE#: *** [#MAKEFILE#:7: one] Error 1", 512);
|
||||
}
|
||||
|
||||
delete $ENV{'MAKEFLAGS'};
|
||||
|
||||
# sv 63537
|
||||
# -S in makefile.
|
||||
for my $fl (@flavors) {
|
||||
run_make_test("
|
||||
MAKEFLAGS${fl}-S
|
||||
\$(info \$(MAKEFLAGS))
|
||||
all: one two
|
||||
one:
|
||||
\$(info \$(MAKEFLAGS))
|
||||
false
|
||||
two:; \$(info \$@)
|
||||
", '',
|
||||
"S
|
||||
S
|
||||
false
|
||||
#MAKE#: *** [#MAKEFILE#:7: one] Error 1", 512);
|
||||
}
|
||||
|
||||
# -S in makefile and -k on the command line.
|
||||
for my $fl (@flavors) {
|
||||
run_make_test("
|
||||
MAKEFLAGS${fl}-S
|
||||
\$(info \$(MAKEFLAGS))
|
||||
all: one two
|
||||
one:
|
||||
\$(info \$(MAKEFLAGS))
|
||||
false
|
||||
two:; \$(info \$@)
|
||||
", '-k',
|
||||
"k
|
||||
k
|
||||
false
|
||||
#MAKE#: *** [#MAKEFILE#:7: one] Error 1
|
||||
two
|
||||
#MAKE#: Target 'all' not remade because of errors.", 512);
|
||||
}
|
||||
|
||||
# sv 63537
|
||||
# -S in makefile and -k in the env.
|
||||
for my $fl (@flavors) {
|
||||
$ENV{'MAKEFLAGS'} = '-k';
|
||||
run_make_test("
|
||||
MAKEFLAGS${fl}-S
|
||||
\$(info \$(MAKEFLAGS))
|
||||
all: one two
|
||||
one:
|
||||
\$(info \$(MAKEFLAGS))
|
||||
false
|
||||
two:; \$(info \$@)
|
||||
", '',
|
||||
"k
|
||||
k
|
||||
false
|
||||
#MAKE#: *** [#MAKEFILE#:7: one] Error 1
|
||||
two
|
||||
#MAKE#: Target 'all' not remade because of errors.", 512);
|
||||
}
|
||||
|
||||
|
||||
# sv 63537
|
||||
# -s vs --no-silent.
|
||||
|
||||
# -s in env.
|
||||
$ENV{'MAKEFLAGS'} = '-s';
|
||||
run_make_test(q!
|
||||
$(info $(MAKEFLAGS))
|
||||
all:; $(info $(MAKEFLAGS))
|
||||
!, '', "s\ns");
|
||||
|
||||
# -s in env, --no-silent on the command line.
|
||||
$ENV{'MAKEFLAGS'} = '-s';
|
||||
run_make_test(q!
|
||||
$(info $(MAKEFLAGS))
|
||||
all:; $(info $(MAKEFLAGS))
|
||||
!, '--no-silent',
|
||||
" --no-silent
|
||||
--no-silent
|
||||
#MAKE#: 'all' is up to date.\n");
|
||||
|
||||
# --no-silent in env.
|
||||
$ENV{'MAKEFLAGS'} = '--no-silent';
|
||||
run_make_test(q!
|
||||
$(info $(MAKEFLAGS))
|
||||
all:; $(info $(MAKEFLAGS))
|
||||
!, '',
|
||||
" --no-silent
|
||||
--no-silent
|
||||
#MAKE#: 'all' is up to date.\n");
|
||||
|
||||
# --no-silent in env, -s on the command line.
|
||||
$ENV{'MAKEFLAGS'} = '--no-silent';
|
||||
run_make_test(q!
|
||||
$(info $(MAKEFLAGS))
|
||||
all:; $(info $(MAKEFLAGS))
|
||||
!, '-s', "s\ns");
|
||||
|
||||
delete $ENV{'MAKEFLAGS'};
|
||||
|
||||
# -s in the makefile.
|
||||
for my $fl (@flavors) {
|
||||
run_make_test("
|
||||
MAKEFLAGS${fl}-s
|
||||
\$(info \$(MAKEFLAGS))
|
||||
all:; \$(info \$(MAKEFLAGS))
|
||||
", '', "s\ns");
|
||||
}
|
||||
|
||||
# sv 63537
|
||||
# -s in makefile and --no-silent on the command line.
|
||||
for my $fl (@flavors) {
|
||||
run_make_test("
|
||||
MAKEFLAGS${fl}-s
|
||||
\$(info \$(MAKEFLAGS))
|
||||
all:; \$(info \$(MAKEFLAGS))
|
||||
", '--no-silent',
|
||||
" --no-silent
|
||||
--no-silent
|
||||
#MAKE#: 'all' is up to date.\n");
|
||||
}
|
||||
|
||||
# sv 63537
|
||||
# -s in makefile and --no-silent in the env.
|
||||
for my $fl (@flavors) {
|
||||
$ENV{'MAKEFLAGS'} = '--no-silent';
|
||||
run_make_test("
|
||||
MAKEFLAGS${fl}-s
|
||||
\$(info \$(MAKEFLAGS))
|
||||
all:; \$(info \$(MAKEFLAGS))
|
||||
", '',
|
||||
" --no-silent
|
||||
--no-silent
|
||||
#MAKE#: 'all' is up to date.\n");
|
||||
}
|
||||
|
||||
delete $ENV{'MAKEFLAGS'};
|
||||
|
||||
# sv 63537
|
||||
# --no-silent in makefile.
|
||||
for my $fl (@flavors) {
|
||||
run_make_test("
|
||||
MAKEFLAGS${fl}--no-silent
|
||||
\$(info \$(MAKEFLAGS))
|
||||
all:; \$(info \$(MAKEFLAGS))
|
||||
", '',
|
||||
" --no-silent
|
||||
--no-silent
|
||||
#MAKE#: 'all' is up to date.\n");
|
||||
}
|
||||
|
||||
# sv 63537
|
||||
# --no-silent in makefile and -s on the command line.
|
||||
for my $fl (@flavors) {
|
||||
run_make_test("
|
||||
MAKEFLAGS${fl}--no-silent
|
||||
\$(info \$(MAKEFLAGS))
|
||||
all:; \$(info \$(MAKEFLAGS))
|
||||
", '-s', "s\ns");
|
||||
}
|
||||
|
||||
# sv 63537
|
||||
# --no-silent in makefile and -s in the env.
|
||||
for my $fl (@flavors) {
|
||||
$ENV{'MAKEFLAGS'} = '-s';
|
||||
run_make_test("
|
||||
MAKEFLAGS${fl}--no-silent
|
||||
\$(info \$(MAKEFLAGS))
|
||||
all:; \$(info \$(MAKEFLAGS))
|
||||
", '', "s\ns");
|
||||
}
|
||||
|
||||
delete $ENV{'MAKEFLAGS'};
|
||||
|
||||
# sv 63537
|
||||
# Multiple --debug switches from various origins are all combined.
|
||||
# Because run_make_test regex matching facility does not allow to match against
|
||||
# multiple lines, run the test twice. During the first run match the output of
|
||||
# --debug=b, during the second run match the output of --debug=-j.
|
||||
#
|
||||
# --debug=b in makefile.
|
||||
for my $fl (@flavors) {
|
||||
run_make_test("
|
||||
MAKEFLAGS${fl}--debug=b
|
||||
hello:; touch \$@
|
||||
.PHONY: hello
|
||||
", '', "/Updating makefiles/");
|
||||
}
|
||||
|
||||
# --debug=b in makefile, --debug=j on the command line.
|
||||
# Test for --debug=j output.
|
||||
for my $fl (@flavors) {
|
||||
run_make_test("
|
||||
MAKEFLAGS${fl}--debug=b
|
||||
hello:; touch \$@
|
||||
.PHONY: hello
|
||||
", '--debug=j', "/Putting child/");
|
||||
}
|
||||
|
||||
# --debug=b in makefile, --debug=j on the command line.
|
||||
# Test for --debug=b output.
|
||||
for my $fl (@flavors) {
|
||||
run_make_test("
|
||||
MAKEFLAGS${fl}--debug=b
|
||||
hello:; touch \$@
|
||||
.PHONY: hello
|
||||
", '--debug=j', "/Updating makefiles/");
|
||||
}
|
||||
|
||||
# --debug=j in makefile, --debug=b on the command line.
|
||||
# Test that MAKEFLAGS contains --debug=b.
|
||||
run_make_test(q!
|
||||
MAKEFLAGS=--debug=j
|
||||
$(info makeflags=$(MAKEFLAGS))
|
||||
hello:; touch $@
|
||||
.PHONY: hello
|
||||
!, '--debug=b', "/makeflags= --debug=b/");
|
||||
|
||||
# --debug=b in makefile, --debug=j in the env.
|
||||
# Test for --debug=j output.
|
||||
for my $fl (@flavors) {
|
||||
$ENV{'MAKEFLAGS'} = '--debug=j';
|
||||
run_make_test("
|
||||
MAKEFLAGS${fl}--debug=b
|
||||
hello:; touch \$@
|
||||
.PHONY: hello
|
||||
", '', "/Putting child/");
|
||||
}
|
||||
|
||||
# --debug=b in makefile, --debug=j in the env.
|
||||
# Test for --debug=b output.
|
||||
for my $fl (@flavors) {
|
||||
$ENV{'MAKEFLAGS'} = '--debug=j';
|
||||
run_make_test("
|
||||
MAKEFLAGS${fl}--debug=b
|
||||
hello:; touch \$@
|
||||
.PHONY: hello
|
||||
", '', "/Updating makefiles/");
|
||||
}
|
||||
|
||||
unlink('hello');
|
||||
|
||||
# This tells the test driver that the perl test script executed properly.
|
||||
1;
|
||||
|
Loading…
Reference in New Issue
Block a user