2000-02-09 19:57:15 +00:00
|
|
|
# -*-perl-*-
|
1999-09-14 02:03:19 +00:00
|
|
|
$description = "Test various types of escaping in makefiles.";
|
|
|
|
|
2000-02-09 19:57:15 +00:00
|
|
|
$details = "\
|
|
|
|
Make sure that escaping of `:' works in target names.
|
|
|
|
Also make sure escaping of whitespace works in target names";
|
1999-09-14 02:03:19 +00:00
|
|
|
|
|
|
|
open(MAKEFILE,"> $makefile");
|
|
|
|
|
2000-02-09 19:57:15 +00:00
|
|
|
print MAKEFILE <<'EOF';
|
|
|
|
$(path)foo : ; @echo cp $^ $@
|
|
|
|
|
|
|
|
foo\ bar: ; @echo 'touch "$@"'
|
|
|
|
EOF
|
1999-09-14 02:03:19 +00:00
|
|
|
|
|
|
|
close(MAKEFILE);
|
|
|
|
|
|
|
|
|
|
|
|
# TEST 1
|
|
|
|
|
|
|
|
&run_make_with_options($makefile, "", &get_logfile);
|
|
|
|
$answer = "cp foo\n";
|
|
|
|
&compare_output($answer,&get_logfile(1));
|
|
|
|
|
|
|
|
# TEST 2: This one should fail, since the ":" is unquoted.
|
|
|
|
|
|
|
|
&run_make_with_options($makefile, "path=p:", &get_logfile, 512);
|
|
|
|
$answer = "$makefile:1: *** target pattern contains no `%'. Stop.\n";
|
|
|
|
&compare_output($answer,&get_logfile(1));
|
|
|
|
|
|
|
|
# TEST 3: This one should work, since we escape the ":".
|
|
|
|
|
|
|
|
&run_make_with_options($makefile, "'path=p\\:'", &get_logfile, 0);
|
|
|
|
$answer = "cp p:foo\n";
|
|
|
|
&compare_output($answer,&get_logfile(1));
|
|
|
|
|
|
|
|
# TEST 4: This one should fail, since the escape char is escaped.
|
|
|
|
|
|
|
|
&run_make_with_options($makefile, "'path=p\\\\:'", &get_logfile, 512);
|
|
|
|
$answer = "$makefile:1: *** target pattern contains no `%'. Stop.\n";
|
|
|
|
&compare_output($answer,&get_logfile(1));
|
|
|
|
|
2000-02-09 19:57:15 +00:00
|
|
|
# TEST 5: This one should work
|
|
|
|
|
|
|
|
&run_make_with_options($makefile, "'foo bar'", &get_logfile, 0);
|
|
|
|
$answer = "touch \"foo bar\"\n";
|
|
|
|
&compare_output($answer,&get_logfile(1));
|
|
|
|
|
1999-09-14 02:03:19 +00:00
|
|
|
# This tells the test driver that the perl test script executed properly.
|
|
|
|
1;
|