1 /* Data base of default implicit rules for GNU Make.
2 Copyright (C) 1988,89,90,91,92,93,94,95,96 Free Software Foundation, Inc.
3 This file is part of GNU Make.
5 GNU Make is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2, or (at your option)
10 GNU Make is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details.
15 You should have received a copy of the GNU General Public License
16 along with GNU Make; see the file COPYING. If not, write to
17 the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
18 Boston, MA 02111-1307, USA. */
28 /* Define GCC_IS_NATIVE if gcc is the native development environment on
29 your system (gcc/bison/flex vs cc/yacc/lex). */
35 /* This is the default list of suffixes for suffix rules.
36 `.s' must come last, so that a `.o' file will be made from
37 a `.c' or `.p' or ... file rather than from a .s file. */
39 static char default_suffixes
[]
41 = ".exe .olb .ln .obj .c .cc .pas .p .for .f .r .y .l .mar \
42 .mod .sym .def .h .info .dvi .tex .texinfo .texi .txinfo \
43 .w .ch .cweb .web .com .sh .elc .el";
45 = ".out .a .ln .o .c .cc .C .cpp .p .f .F .r .y .l .s .S \
46 .mod .sym .def .h .info .dvi .tex .texinfo .texi .txinfo \
47 .w .ch .web .sh .elc .el";
50 static struct pspec default_pattern_rules
[] =
53 "$(AR) $(ARFLAGS) $@ $<" },
55 /* The X.out rules are only in BSD's default set because
56 BSD Make has no null-suffix rules, so `foo.out' and
57 `foo' are the same thing. */
63 "@rm -f $@ \n cp $< $@" },
65 /* Syntax is "ctangle foo.w foo.ch foo.c". */
68 { "%.tex", "%.w %.ch",
74 static struct pspec default_terminal_rules
[] =
78 { "%", "%$$5lv", /* Multinet style */
79 "if f$$search($@) .nes. \"\" then +$(CHECKOUT,v)" },
80 { "%", "[.$$rcs]%$$5lv", /* Multinet style */
81 "if f$$search($@) .nes. \"\" then +$(CHECKOUT,v)" },
82 { "%", "%_v", /* Normal style */
83 "if f$$search($@) .nes. \"\" then +$(CHECKOUT,v)" },
84 { "%", "[.rcs]%_v", /* Normal style */
85 "if f$$search($@) .nes. \"\" then +$(CHECKOUT,v)" },
88 /* ain't no SCCS on vms */
100 "$(GET) $(GFLAGS) $(SCCS_OUTPUT_OPTION) $<" },
102 "$(GET) $(GFLAGS) $(SCCS_OUTPUT_OPTION) $<" },
107 static char *default_suffix_rules
[] =
111 "$(LINK.obj) $^ $(LOADLIBES) $(LDLIBS) /exe=$@",
113 "$(LINK.mar) $^ $(LOADLIBES) $(LDLIBS) /exe=$@",
115 "$(COMPILE.c) $^ \n $(LINK.obj) $(subst .c,.obj,$^) $(LOADLIBES) $(LDLIBS) /exe=$@",
117 "$(COMPILE.cc) $^ \n $(LINK.obj) $(subst .cc,.obj,$^) $(LOADLIBES) $(LDLIBS) /exe=$@",
119 "$(COMPILE.for) $^ \n $(LINK.obj) $(subst .for,.obj,$^) $(LOADLIBES) $(LDLIBS) /exe=$@",
121 "$(COMPILE.pas) $^ \n $(LINK.obj) $(subst .pas,.obj,$^) $(LOADLIBES) $(LDLIBS) /exe=$@",
127 "$(COMPILE.mar) /obj=$@ $<",
129 "$(COMPILE.c) /obj=$@ $<",
131 "$(COMPILE.cc) /obj=$@ $<",
133 "$(COMPILE.for) /obj=$@ $<",
135 "$(COMPILE.pas) /obj=$@ $<",
138 "$(YACC.y) $< \n rename y_tab.c $@",
140 "$(LEX.l) $< \n rename lexyy.c $@",
151 "$(LINK.o) $^ $(LOADLIBES) $(LDLIBS) -o $@",
153 "$(LINK.s) $^ $(LOADLIBES) $(LDLIBS) -o $@",
155 "$(LINK.S) $^ $(LOADLIBES) $(LDLIBS) -o $@",
157 "$(LINK.c) $^ $(LOADLIBES) $(LDLIBS) -o $@",
159 "$(LINK.cc) $^ $(LOADLIBES) $(LDLIBS) -o $@",
161 "$(LINK.C) $^ $(LOADLIBES) $(LDLIBS) -o $@",
163 "$(LINK.cpp) $^ $(LOADLIBES) $(LDLIBS) -o $@",
165 "$(LINK.f) $^ $(LOADLIBES) $(LDLIBS) -o $@",
167 "$(LINK.p) $^ $(LOADLIBES) $(LDLIBS) -o $@",
169 "$(LINK.F) $^ $(LOADLIBES) $(LDLIBS) -o $@",
171 "$(LINK.r) $^ $(LOADLIBES) $(LDLIBS) -o $@",
173 "$(COMPILE.mod) -o $@ -e $@ $^",
176 "$(COMPILE.def) -o $@ $<",
179 "cat $< >$@ \n chmod a+x $@",
182 "$(COMPILE.s) -o $@ $<",
184 "$(COMPILE.S) -o $@ $<",
186 "$(COMPILE.c) $< $(OUTPUT_OPTION)",
188 "$(COMPILE.cc) $< $(OUTPUT_OPTION)",
190 "$(COMPILE.C) $< $(OUTPUT_OPTION)",
192 "$(COMPILE.cpp) $< $(OUTPUT_OPTION)",
194 "$(COMPILE.f) $< $(OUTPUT_OPTION)",
196 "$(COMPILE.p) $< $(OUTPUT_OPTION)",
198 "$(COMPILE.F) $< $(OUTPUT_OPTION)",
200 "$(COMPILE.r) $< $(OUTPUT_OPTION)",
202 "$(COMPILE.mod) -o $@ $<",
208 "$(YACC.y) $< \n $(LINT.c) -C$* y.tab.c \n $(RM) y.tab.c",
210 "$(YACC.y) $< \n $(LINT.c) -C$* y_tab.c \n $(RM) y_tab.c",
213 "@$(RM) $*.c\n $(LEX.l) $< > $*.c\n$(LINT.c) -i $*.c -o $@\n $(RM) $*.c",
217 "$(YACC.y) $< \n mv -f y.tab.c $@",
219 "$(YACC.y) $< \n mv -f y_tab.c $@",
222 "@$(RM) $@ \n $(LEX.l) $< > $@",
225 "$(PREPROCESS.F) $< $(OUTPUT_OPTION)",
227 "$(PREPROCESS.r) $< $(OUTPUT_OPTION)",
229 /* This might actually make lex.yy.c if there's no %R%
230 directive in $*.l, but in that case why were you
231 trying to make $*.r anyway? */
233 "$(LEX.l) $< > $@ \n mv -f lex.yy.r $@",
236 "$(PREPROCESS.S) $< > $@",
239 "$(MAKEINFO) $(MAKEINFO_FLAGS) $< -o $@",
242 "$(MAKEINFO) $(MAKEINFO_FLAGS) $< -o $@",
245 "$(MAKEINFO) $(MAKEINFO_FLAGS) $< -o $@",
251 "$(TEXI2DVI) $(TEXI2DVI_FLAGS) $<",
254 "$(TEXI2DVI) $(TEXI2DVI_FLAGS) $<",
257 "$(TEXI2DVI) $(TEXI2DVI_FLAGS) $<",
260 "$(CTANGLE) $< - $@", /* The `-' says there is no `.ch' file. */
266 "$(CWEAVE) $< - $@", /* The `-' says there is no `.ch' file. */
276 static char *default_variables
[] =
280 "ARFLAGS", "/replace",
286 "CPP", "$(CC) /preprocess_only",
288 /* System V uses these, so explicit rules using them should work.
289 However, there is no way to make implicit rules use them and FC. */
291 "F77FLAGS", "$(FFLAGS)",
295 "YACC", "yacc", /* Or "bison -y" */
296 "MAKEINFO", "makeinfo",
298 "TEXINDEX", "texindex",
300 "RM", "delete/nolog",
302 "LINK.obj", "$(LD) $(LDFLAGS)",
303 "COMPILE.c", "$(CC) $(CFLAGS) $(CPPFLAGS) $(TARGET_ARCH)",
304 "COMPILE.cc", "$(C++) $(C++FLAGS) $(CPPFLAGS) $(TARGET_ARCH) -c",
305 "YACC.y", "$(YACC) $(YFLAGS)",
306 "LEX.l", "$(LEX) $(LFLAGS)",
307 "COMPILE.for", "$(FC) $(FFLAGS) $(TARGET_ARCH)",
308 "COMPILE.pas", "$(PC) $(PFLAGS) $(CPPFLAGS) $(TARGET_ARCH)",
309 "COMPILE.mar", "$(AS) $(ASFLAGS) $(TARGET_MACH)",
310 "LINT.c", "$(LINT) $(LINTFLAGS) $(CPPFLAGS) $(TARGET_ARCH)",
312 "MV", "rename/new_version",
328 /* This expands to $(CO) $(COFLAGS) $< $@ if $@ does not exist,
329 and to the empty string if $@ does exist. */
331 "+$(patsubst $@-noexist,$(CO) $(COFLAGS) $< $@,\
332 $(filter-out $@,$(firstword $(wildcard $@) $@-noexist)))",
338 "CF77PP", "/lib/cpp",
342 #else /* Not CRAY. */
350 #endif /* __convex__ */
352 /* System V uses these, so explicit rules using them should work.
353 However, there is no way to make implicit rules use them and FC. */
355 "F77FLAGS", "$(FFLAGS)",
379 "YACC", "yacc", /* Or "bison -y" */
381 "MAKEINFO", "makeinfo",
383 "TEXI2DVI", "texi2dvi",
387 "CTANGLE", "ctangle",
391 "LINK.o", "$(CC) $(LDFLAGS) $(TARGET_ARCH)",
392 "COMPILE.c", "$(CC) $(CFLAGS) $(CPPFLAGS) $(TARGET_ARCH) -c",
393 "LINK.c", "$(CC) $(CFLAGS) $(CPPFLAGS) $(LDFLAGS) $(TARGET_ARCH)",
394 "COMPILE.cc", "$(CXX) $(CXXFLAGS) $(CPPFLAGS) $(TARGET_ARCH) -c",
395 "COMPILE.C", "$(COMPILE.cc)",
396 "COMPILE.cpp", "$(COMPILE.cc)",
397 "LINK.cc", "$(CXX) $(CXXFLAGS) $(CPPFLAGS) $(LDFLAGS) $(TARGET_ARCH)",
398 "LINK.C", "$(LINK.cc)",
399 "LINK.cpp", "$(LINK.cc)",
400 "YACC.y", "$(YACC) $(YFLAGS)",
401 "LEX.l", "$(LEX) $(LFLAGS) -t",
402 "COMPILE.f", "$(FC) $(FFLAGS) $(TARGET_ARCH) -c",
403 "LINK.f", "$(FC) $(FFLAGS) $(LDFLAGS) $(TARGET_ARCH)",
404 "COMPILE.F", "$(FC) $(FFLAGS) $(CPPFLAGS) $(TARGET_ARCH) -c",
405 "LINK.F", "$(FC) $(FFLAGS) $(CPPFLAGS) $(LDFLAGS) $(TARGET_ARCH)",
406 "COMPILE.r", "$(FC) $(FFLAGS) $(RFLAGS) $(TARGET_ARCH) -c",
407 "LINK.r", "$(FC) $(FFLAGS) $(RFLAGS) $(LDFLAGS) $(TARGET_ARCH)",
408 "COMPILE.def", "$(M2C) $(M2FLAGS) $(DEFFLAGS) $(TARGET_ARCH)",
409 "COMPILE.mod", "$(M2C) $(M2FLAGS) $(MODFLAGS) $(TARGET_ARCH)",
410 "COMPILE.p", "$(PC) $(PFLAGS) $(CPPFLAGS) $(TARGET_ARCH) -c",
411 "LINK.p", "$(PC) $(PFLAGS) $(CPPFLAGS) $(LDFLAGS) $(TARGET_ARCH)",
412 "LINK.s", "$(CC) $(ASFLAGS) $(LDFLAGS) $(TARGET_MACH)",
413 "COMPILE.s", "$(AS) $(ASFLAGS) $(TARGET_MACH)",
414 "LINK.S", "$(CC) $(ASFLAGS) $(CPPFLAGS) $(LDFLAGS) $(TARGET_MACH)",
415 "COMPILE.S", "$(CC) $(ASFLAGS) $(CPPFLAGS) $(TARGET_MACH) -c",
416 "PREPROCESS.S", "$(CC) -E $(CPPFLAGS)",
417 "PREPROCESS.F", "$(FC) $(FFLAGS) $(CPPFLAGS) $(TARGET_ARCH) -F",
418 "PREPROCESS.r", "$(FC) $(FFLAGS) $(RFLAGS) $(TARGET_ARCH) -F",
419 "LINT.c", "$(LINT) $(LINTFLAGS) $(CPPFLAGS) $(TARGET_ARCH)",
421 #ifndef NO_MINUS_C_MINUS_O
422 "OUTPUT_OPTION", "-o $@",
425 #ifdef SCCS_GET_MINUS_G
426 "SCCS_OUTPUT_OPTION", "-G$@",
430 ".LIBPATTERNS", "%.lib",
433 ".LIBPATTERNS", "lib%.a $(DJDIR)/lib/lib%.a",
435 ".LIBPATTERNS", "lib%.so lib%.a",
443 /* Set up the default .SUFFIXES list. */
446 set_default_suffixes ()
448 suffix_file
= enter_file (".SUFFIXES");
450 if (no_builtin_rules_flag
)
451 (void) define_variable ("SUFFIXES", 8, "", o_default
, 0);
454 char *p
= default_suffixes
;
455 suffix_file
->deps
= (struct dep
*)
456 multi_glob (parse_file_seq (&p
, '\0', sizeof (struct dep
), 1),
457 sizeof (struct dep
));
458 (void) define_variable ("SUFFIXES", 8, default_suffixes
, o_default
, 0);
462 /* Enter the default suffix rules as file rules. This used to be done in
463 install_default_implicit_rules, but that loses because we want the
464 suffix rules installed before reading makefiles, and thee pattern rules
468 install_default_suffix_rules ()
472 if (no_builtin_rules_flag
)
475 for (s
= default_suffix_rules
; *s
!= 0; s
+= 2)
477 register struct file
*f
= enter_file (s
[0]);
478 /* Don't clobber cmds given in a makefile if there were any. */
481 f
->cmds
= (struct commands
*) xmalloc (sizeof (struct commands
));
482 f
->cmds
->fileinfo
.filenm
= 0;
483 f
->cmds
->commands
= s
[1];
484 f
->cmds
->command_lines
= 0;
490 /* Install the default pattern rules. */
493 install_default_implicit_rules ()
495 register struct pspec
*p
;
497 if (no_builtin_rules_flag
)
500 for (p
= default_pattern_rules
; p
->target
!= 0; ++p
)
501 install_pattern_rule (p
, 0);
503 for (p
= default_terminal_rules
; p
->target
!= 0; ++p
)
504 install_pattern_rule (p
, 1);
508 define_default_variables ()
512 for (s
= default_variables
; *s
!= 0; s
+= 2)
513 (void) define_variable (s
[0], strlen (s
[0]), s
[1], o_default
, 1);