File: dash-k

package info (click to toggle)
make-doc-non-dfsg 4.4.1-1
  • links: PTS, VCS
  • area: non-free
  • in suites: forky, sid, trixie
  • size: 9,632 kB
  • sloc: ansic: 31,255; sh: 5,213; perl: 1,612; makefile: 160; lisp: 26; sed: 16
file content (115 lines) | stat: -rw-r--r-- 2,927 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
#                                                                    -*-perl-*-

$description = "Test the make -k (don't stop on error) option.\n";

$details = "\
The makefile created in this test is a simulation of building
a small product.  However, the trick to this one is that one
of the dependencies of the main target does not exist.
Without the -k option, make would fail immediately and not
build any part of the target.  What we are looking for here,
is that make builds the rest of the dependencies even though
it knows that at the end it will fail to rebuild the main target.";

open(MAKEFILE,"> $makefile");

# The Contents of the MAKEFILE ...

print MAKEFILE <<EOF;
VPATH = $workdir
edit:  main.o kbd.o commands.o display.o
\t\@echo cc -o edit main.o kbd.o commands.o display.o

main.o : main.c defs.h
\t\@echo cc -c main.c

kbd.o : kbd.c defs.h command.h
\t\@echo cc -c kbd.c

commands.o : command.c defs.h command.h
\t\@echo cc -c commands.c

display.o : display.c defs.h buffer.h
\t\@echo cc -c display.c
EOF

# END of Contents of MAKEFILE

close(MAKEFILE);


@files_to_touch = ("$workdir${pathsep}main.c","$workdir${pathsep}defs.h",
               "$workdir${pathsep}command.h",
               "$workdir${pathsep}commands.c","$workdir${pathsep}display.c",
               "$workdir${pathsep}buffer.h",
               "$workdir${pathsep}command.c");

&touch(@files_to_touch);

if ($vos) {
  $error_code = 3307;
}
else {
  $error_code = 512;
}

&run_make_with_options($makefile, "-k", &get_logfile, $error_code);

# Create the answer to what should be produced by this Makefile
$answer = "cc -c main.c
$make_name: *** No rule to make target 'kbd.c', needed by 'kbd.o'.
cc -c commands.c
cc -c display.c
$make_name: Target 'edit' not remade because of errors.\n";

# COMPARE RESULTS

&compare_output($answer, &get_logfile(1));

unlink(@files_to_touch) unless $keep;


# TEST 1: Make sure that top-level targets that depend on targets that
# previously failed to build, aren't attempted.  Regression for PR/1634.

$makefile2 = &get_tmpfile;

open(MAKEFILE, "> $makefile2");
print MAKEFILE <<'EOF';
.SUFFIXES:

all: exe1 exe2; @echo making $@

exe1 exe2: lib; @echo cp $^ $@

lib: foo.o; @echo cp $^ $@

foo.o: ; exit 1
EOF

close(MAKEFILE);

&run_make_with_options($makefile2, "-k", &get_logfile, $error_code);

$answer = "exit 1
$make_name: *** [$makefile2:9: foo.o] Error 1
$make_name: Target 'all' not remade because of errors.\n";

&compare_output($answer, &get_logfile(1));

# TEST -- make sure we keep the error code if we can't create an included
# makefile.

if (defined $ERR_no_such_file) {
    run_make_test('all: ; @echo hi
include ifile
ifile: no-such-file; exit 1
',
                  '-k',
                  "#MAKEFILE#:2: ifile: $ERR_no_such_file
#MAKE#: *** No rule to make target 'no-such-file', needed by 'ifile'.
#MAKEFILE#:2: Failed to remake makefile 'ifile'.\n",
                  512);
}

1;