| /* Data base of default implicit rules for GNU Make. |
| Copyright (C) 1988, 1989, 1990, 1991, 1992, 1993, 1994, 1995, 1996, 1997, |
| 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006 Free Software |
| Foundation, Inc. |
| This file is part of GNU Make. |
| |
| GNU Make is free software; you can redistribute it and/or modify it under the |
| terms of the GNU General Public License as published by the Free Software |
| Foundation; either version 2, or (at your option) any later version. |
| |
| GNU Make is distributed in the hope that it will be useful, but WITHOUT ANY |
| WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR |
| A PARTICULAR PURPOSE. See the GNU General Public License for more details. |
| |
| You should have received a copy of the GNU General Public License along with |
| GNU Make; see the file COPYING. If not, write to the Free Software |
| Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. */ |
| |
| #include "make.h" |
| #include "filedef.h" |
| #include "variable.h" |
| #include "rule.h" |
| #include "dep.h" |
| #include "job.h" |
| #include "commands.h" |
| |
| /* Define GCC_IS_NATIVE if gcc is the native development environment on |
| your system (gcc/bison/flex vs cc/yacc/lex). */ |
| #if defined(__MSDOS__) || defined(__EMX__) |
| # define GCC_IS_NATIVE |
| #endif |
| |
| |
| /* This is the default list of suffixes for suffix rules. |
| `.s' must come last, so that a `.o' file will be made from |
| a `.c' or `.p' or ... file rather than from a .s file. */ |
| |
| static char default_suffixes[] |
| #ifdef VMS |
| = ".exe .olb .ln .obj .c .cxx .cc .pas .p .for .f .r .y .l .mar \ |
| .s .ss .i .ii .mod .sym .def .h .info .dvi .tex .texinfo .texi .txinfo \ |
| .w .ch .cweb .web .com .sh .elc .el"; |
| #elif defined(__EMX__) |
| = ".out .a .ln .o .c .cc .C .cpp .p .f .F .r .y .l .s .S \ |
| .mod .sym .def .h .info .dvi .tex .texinfo .texi .txinfo \ |
| .w .ch .web .sh .elc .el .obj .exe .dll .lib"; |
| #else |
| = ".out .a .ln .o .c .cc .C .cpp .p .f .F .r .y .l .s .S \ |
| .mod .sym .def .h .info .dvi .tex .texinfo .texi .txinfo \ |
| .w .ch .web .sh .elc .el"; |
| #endif |
| |
| static struct pspec default_pattern_rules[] = |
| { |
| { "(%)", "%", |
| "$(AR) $(ARFLAGS) $@ $<" }, |
| |
| /* The X.out rules are only in BSD's default set because |
| BSD Make has no null-suffix rules, so `foo.out' and |
| `foo' are the same thing. */ |
| #ifdef VMS |
| { "%.exe", "%", |
| "copy $< $@" }, |
| #else |
| { "%.out", "%", |
| "@rm -f $@ \n cp $< $@" }, |
| #endif |
| /* Syntax is "ctangle foo.w foo.ch foo.c". */ |
| { "%.c", "%.w %.ch", |
| "$(CTANGLE) $^ $@" }, |
| { "%.tex", "%.w %.ch", |
| "$(CWEAVE) $^ $@" }, |
| |
| { 0, 0, 0 } |
| }; |
| |
| static struct pspec default_terminal_rules[] = |
| { |
| #ifdef VMS |
| /* RCS. */ |
| { "%", "%$$5lv", /* Multinet style */ |
| "if f$$search($@) .nes. \"\" then +$(CHECKOUT,v)" }, |
| { "%", "[.$$rcs]%$$5lv", /* Multinet style */ |
| "if f$$search($@) .nes. \"\" then +$(CHECKOUT,v)" }, |
| { "%", "%_v", /* Normal style */ |
| "if f$$search($@) .nes. \"\" then +$(CHECKOUT,v)" }, |
| { "%", "[.rcs]%_v", /* Normal style */ |
| "if f$$search($@) .nes. \"\" then +$(CHECKOUT,v)" }, |
| |
| /* SCCS. */ |
| /* ain't no SCCS on vms */ |
| #else |
| /* RCS. */ |
| { "%", "%,v", |
| "$(CHECKOUT,v)" }, |
| { "%", "RCS/%,v", |
| "$(CHECKOUT,v)" }, |
| { "%", "RCS/%", |
| "$(CHECKOUT,v)" }, |
| |
| /* SCCS. */ |
| { "%", "s.%", |
| "$(GET) $(GFLAGS) $(SCCS_OUTPUT_OPTION) $<" }, |
| { "%", "SCCS/s.%", |
| "$(GET) $(GFLAGS) $(SCCS_OUTPUT_OPTION) $<" }, |
| #endif /* !VMS */ |
| { 0, 0, 0 } |
| }; |
| |
| static char *default_suffix_rules[] = |
| { |
| #ifdef VMS |
| ".obj.exe", |
| "$(LINK.obj) $^ $(LOADLIBES) $(LDLIBS) $(CRT0) /exe=$@", |
| ".mar.exe", |
| "$(COMPILE.mar) $^ \n $(LINK.obj) $(subst .mar,.obj,$^) $(LOADLIBES) $(LDLIBS) $(CRT0) /exe=$@", |
| ".s.exe", |
| "$(COMPILE.s) $^ \n $(LINK.obj) $(subst .s,.obj,$^) $(LOADLIBES) $(LDLIBS) $(CRT0) /exe=$@", |
| ".c.exe", |
| "$(COMPILE.c) $^ \n $(LINK.obj) $(subst .c,.obj,$^) $(LOADLIBES) $(LDLIBS) $(CRT0) /exe=$@", |
| ".cc.exe", |
| #ifdef GCC_IS_NATIVE |
| "$(COMPILE.cc) $^ \n $(LINK.obj) $(CXXSTARTUP),sys$$disk:[]$(subst .cc,.obj,$^) $(LOADLIBES) $(LXLIBS) $(LDLIBS) $(CXXRT0) /exe=$@", |
| #else |
| "$(COMPILE.cc) $^ \n $(CXXLINK.obj) $(subst .cc,.obj,$^) $(LOADLIBES) $(LXLIBS) $(LDLIBS) $(CXXRT0) /exe=$@", |
| ".cxx.exe", |
| "$(COMPILE.cxx) $^ \n $(CXXLINK.obj) $(subst .cxx,.obj,$^) $(LOADLIBES) $(LXLIBS) $(LDLIBS) $(CXXRT0) /exe=$@", |
| #endif |
| ".for.exe", |
| "$(COMPILE.for) $^ \n $(LINK.obj) $(subst .for,.obj,$^) $(LOADLIBES) $(LDLIBS) /exe=$@", |
| ".pas.exe", |
| "$(COMPILE.pas) $^ \n $(LINK.obj) $(subst .pas,.obj,$^) $(LOADLIBES) $(LDLIBS) /exe=$@", |
| |
| ".com", |
| "copy $< >$@", |
| |
| ".mar.obj", |
| "$(COMPILE.mar) /obj=$@ $<", |
| ".s.obj", |
| "$(COMPILE.s) /obj=$@ $<", |
| ".ss.obj", |
| "$(COMPILE.s) /obj=$@ $<", |
| ".c.i", |
| "$(COMPILE.c)/prep /list=$@ $<", |
| ".c.s", |
| "$(COMPILE.c)/noobj/machine /list=$@ $<", |
| ".i.s", |
| "$(COMPILE.c)/noprep/noobj/machine /list=$@ $<", |
| ".c.obj", |
| "$(COMPILE.c) /obj=$@ $<", |
| ".cc.ii", |
| "$(COMPILE.cc)/prep /list=$@ $<", |
| ".cc.ss", |
| "$(COMPILE.cc)/noobj/machine /list=$@ $<", |
| ".ii.ss", |
| "$(COMPILE.cc)/noprep/noobj/machine /list=$@ $<", |
| ".cc.obj", |
| "$(COMPILE.cc) /obj=$@ $<", |
| ".cxx.obj", |
| "$(COMPILE.cxx) /obj=$@ $<", |
| ".for.obj", |
| "$(COMPILE.for) /obj=$@ $<", |
| ".pas.obj", |
| "$(COMPILE.pas) /obj=$@ $<", |
| |
| ".y.c", |
| "$(YACC.y) $< \n rename y_tab.c $@", |
| ".l.c", |
| "$(LEX.l) $< \n rename lexyy.c $@", |
| |
| ".texinfo.info", |
| "$(MAKEINFO) $<", |
| |
| ".tex.dvi", |
| "$(TEX) $<", |
| |
| #else /* ! VMS */ |
| |
| ".o", |
| "$(LINK.o) $^ $(LOADLIBES) $(LDLIBS) -o $@", |
| ".s", |
| "$(LINK.s) $^ $(LOADLIBES) $(LDLIBS) -o $@", |
| ".S", |
| "$(LINK.S) $^ $(LOADLIBES) $(LDLIBS) -o $@", |
| ".c", |
| "$(LINK.c) $^ $(LOADLIBES) $(LDLIBS) -o $@", |
| ".cc", |
| "$(LINK.cc) $^ $(LOADLIBES) $(LDLIBS) -o $@", |
| ".C", |
| "$(LINK.C) $^ $(LOADLIBES) $(LDLIBS) -o $@", |
| ".cpp", |
| "$(LINK.cpp) $^ $(LOADLIBES) $(LDLIBS) -o $@", |
| ".f", |
| "$(LINK.f) $^ $(LOADLIBES) $(LDLIBS) -o $@", |
| ".p", |
| "$(LINK.p) $^ $(LOADLIBES) $(LDLIBS) -o $@", |
| ".F", |
| "$(LINK.F) $^ $(LOADLIBES) $(LDLIBS) -o $@", |
| ".r", |
| "$(LINK.r) $^ $(LOADLIBES) $(LDLIBS) -o $@", |
| ".mod", |
| "$(COMPILE.mod) -o $@ -e $@ $^", |
| |
| ".def.sym", |
| "$(COMPILE.def) -o $@ $<", |
| |
| ".sh", |
| "cat $< >$@ \n chmod a+x $@", |
| |
| ".s.o", |
| "$(COMPILE.s) -o $@ $<", |
| ".S.o", |
| "$(COMPILE.S) -o $@ $<", |
| ".c.o", |
| "$(COMPILE.c) $(OUTPUT_OPTION) $<", |
| ".cc.o", |
| "$(COMPILE.cc) $(OUTPUT_OPTION) $<", |
| ".C.o", |
| "$(COMPILE.C) $(OUTPUT_OPTION) $<", |
| ".cpp.o", |
| "$(COMPILE.cpp) $(OUTPUT_OPTION) $<", |
| ".f.o", |
| "$(COMPILE.f) $(OUTPUT_OPTION) $<", |
| ".p.o", |
| "$(COMPILE.p) $(OUTPUT_OPTION) $<", |
| ".F.o", |
| "$(COMPILE.F) $(OUTPUT_OPTION) $<", |
| ".r.o", |
| "$(COMPILE.r) $(OUTPUT_OPTION) $<", |
| ".mod.o", |
| "$(COMPILE.mod) -o $@ $<", |
| |
| ".c.ln", |
| "$(LINT.c) -C$* $<", |
| ".y.ln", |
| #ifndef __MSDOS__ |
| "$(YACC.y) $< \n $(LINT.c) -C$* y.tab.c \n $(RM) y.tab.c", |
| #else |
| "$(YACC.y) $< \n $(LINT.c) -C$* y_tab.c \n $(RM) y_tab.c", |
| #endif |
| ".l.ln", |
| "@$(RM) $*.c\n $(LEX.l) $< > $*.c\n$(LINT.c) -i $*.c -o $@\n $(RM) $*.c", |
| |
| ".y.c", |
| #ifndef __MSDOS__ |
| "$(YACC.y) $< \n mv -f y.tab.c $@", |
| #else |
| "$(YACC.y) $< \n mv -f y_tab.c $@", |
| #endif |
| ".l.c", |
| "@$(RM) $@ \n $(LEX.l) $< > $@", |
| |
| ".F.f", |
| "$(PREPROCESS.F) $(OUTPUT_OPTION) $<", |
| ".r.f", |
| "$(PREPROCESS.r) $(OUTPUT_OPTION) $<", |
| |
| /* This might actually make lex.yy.c if there's no %R% |
| directive in $*.l, but in that case why were you |
| trying to make $*.r anyway? */ |
| ".l.r", |
| "$(LEX.l) $< > $@ \n mv -f lex.yy.r $@", |
| |
| ".S.s", |
| "$(PREPROCESS.S) $< > $@", |
| |
| ".texinfo.info", |
| "$(MAKEINFO) $(MAKEINFO_FLAGS) $< -o $@", |
| |
| ".texi.info", |
| "$(MAKEINFO) $(MAKEINFO_FLAGS) $< -o $@", |
| |
| ".txinfo.info", |
| "$(MAKEINFO) $(MAKEINFO_FLAGS) $< -o $@", |
| |
| ".tex.dvi", |
| "$(TEX) $<", |
| |
| ".texinfo.dvi", |
| "$(TEXI2DVI) $(TEXI2DVI_FLAGS) $<", |
| |
| ".texi.dvi", |
| "$(TEXI2DVI) $(TEXI2DVI_FLAGS) $<", |
| |
| ".txinfo.dvi", |
| "$(TEXI2DVI) $(TEXI2DVI_FLAGS) $<", |
| |
| ".w.c", |
| "$(CTANGLE) $< - $@", /* The `-' says there is no `.ch' file. */ |
| |
| ".web.p", |
| "$(TANGLE) $<", |
| |
| ".w.tex", |
| "$(CWEAVE) $< - $@", /* The `-' says there is no `.ch' file. */ |
| |
| ".web.tex", |
| "$(WEAVE) $<", |
| |
| #endif /* !VMS */ |
| |
| 0, 0, |
| }; |
| |
| static char *default_variables[] = |
| { |
| #ifdef VMS |
| #ifdef __ALPHA |
| "ARCH", "ALPHA", |
| #endif |
| #ifdef __ia64 |
| "ARCH", "IA64", |
| #endif |
| #ifdef __VAX |
| "ARCH", "VAX", |
| #endif |
| "AR", "library/obj", |
| "ARFLAGS", "/replace", |
| "AS", "macro", |
| "MACRO", "macro", |
| #ifdef GCC_IS_NATIVE |
| "CC", "gcc", |
| #else |
| "CC", "cc", |
| #endif |
| "CD", "builtin_cd", |
| "MAKE", "make", |
| "ECHO", "write sys$$output \"", |
| #ifdef GCC_IS_NATIVE |
| "C++", "gcc/plus", |
| "CXX", "gcc/plus", |
| #else |
| "C++", "cxx", |
| "CXX", "cxx", |
| "CXXLD", "cxxlink", |
| #endif |
| "CO", "co", |
| "CPP", "$(CC) /preprocess_only", |
| "FC", "fortran", |
| /* System V uses these, so explicit rules using them should work. |
| However, there is no way to make implicit rules use them and FC. */ |
| "F77", "$(FC)", |
| "F77FLAGS", "$(FFLAGS)", |
| "LD", "link", |
| "LEX", "lex", |
| "PC", "pascal", |
| "YACC", "bison/yacc", |
| "YFLAGS", "/Define/Verbose", |
| "BISON", "bison", |
| "MAKEINFO", "makeinfo", |
| "TEX", "tex", |
| "TEXINDEX", "texindex", |
| |
| "RM", "delete/nolog", |
| |
| "CSTARTUP", "", |
| #ifdef GCC_IS_NATIVE |
| "CRT0", ",sys$$library:vaxcrtl.olb/lib,gnu_cc_library:crt0.obj", |
| "CXXSTARTUP", "gnu_cc_library:crtbegin.obj", |
| "CXXRT0", ",sys$$library:vaxcrtl.olb/lib,gnu_cc_library:crtend.obj,gnu_cc_library:gxx_main.obj", |
| "LXLIBS", ",gnu_cc_library:libstdcxx.olb/lib,gnu_cc_library:libgccplus.olb/lib", |
| "LDLIBS", ",gnu_cc_library:libgcc.olb/lib", |
| #else |
| "CRT0", "", |
| "CXXSTARTUP", "", |
| "CXXRT0", "", |
| "LXLIBS", "", |
| "LDLIBS", "", |
| #endif |
| |
| "LINK.obj", "$(LD) $(LDFLAGS)", |
| #ifndef GCC_IS_NATIVE |
| "CXXLINK.obj", "$(CXXLD) $(LDFLAGS)", |
| "COMPILE.cxx", "$(CXX) $(CXXFLAGS) $(CPPFLAGS) $(TARGET_ARCH)", |
| #endif |
| "COMPILE.c", "$(CC) $(CFLAGS) $(CPPFLAGS) $(TARGET_ARCH)", |
| "COMPILE.cc", "$(CXX) $(CXXFLAGS) $(CPPFLAGS) $(TARGET_ARCH)", |
| "YACC.y", "$(YACC) $(YFLAGS)", |
| "LEX.l", "$(LEX) $(LFLAGS)", |
| "COMPILE.for", "$(FC) $(FFLAGS) $(TARGET_ARCH)", |
| "COMPILE.pas", "$(PC) $(PFLAGS) $(CPPFLAGS) $(TARGET_ARCH)", |
| "COMPILE.mar", "$(MACRO) $(MACROFLAGS)", |
| "COMPILE.s", "$(AS) $(ASFLAGS) $(TARGET_MACH)", |
| "LINT.c", "$(LINT) $(LINTFLAGS) $(CPPFLAGS) $(TARGET_ARCH)", |
| |
| "MV", "rename/new_version", |
| "CP", "copy", |
| |
| #else /* !VMS */ |
| |
| "AR", "ar", |
| "ARFLAGS", "rv", |
| "AS", "as", |
| #ifdef GCC_IS_NATIVE |
| "CC", "gcc", |
| # ifdef __MSDOS__ |
| "CXX", "gpp", /* g++ is an invalid name on MSDOS */ |
| # else |
| "CXX", "gcc", |
| # endif /* __MSDOS__ */ |
| #else |
| "CC", "cc", |
| "CXX", "g++", |
| #endif |
| |
| /* This expands to $(CO) $(COFLAGS) $< $@ if $@ does not exist, |
| and to the empty string if $@ does exist. */ |
| "CHECKOUT,v", "+$(if $(wildcard $@),,$(CO) $(COFLAGS) $< $@)", |
| "CO", "co", |
| "COFLAGS", "", |
| |
| "CPP", "$(CC) -E", |
| #ifdef CRAY |
| "CF77PPFLAGS", "-P", |
| "CF77PP", "/lib/cpp", |
| "CFT", "cft77", |
| "CF", "cf77", |
| "FC", "$(CF)", |
| #else /* Not CRAY. */ |
| #ifdef _IBMR2 |
| "FC", "xlf", |
| #else |
| #ifdef __convex__ |
| "FC", "fc", |
| #else |
| "FC", "f77", |
| #endif /* __convex__ */ |
| #endif /* _IBMR2 */ |
| /* System V uses these, so explicit rules using them should work. |
| However, there is no way to make implicit rules use them and FC. */ |
| "F77", "$(FC)", |
| "F77FLAGS", "$(FFLAGS)", |
| #endif /* Cray. */ |
| "GET", SCCS_GET, |
| "LD", "ld", |
| #ifdef GCC_IS_NATIVE |
| "LEX", "flex", |
| #else |
| "LEX", "lex", |
| #endif |
| "LINT", "lint", |
| "M2C", "m2c", |
| #ifdef pyr |
| "PC", "pascal", |
| #else |
| #ifdef CRAY |
| "PC", "PASCAL", |
| "SEGLDR", "segldr", |
| #else |
| "PC", "pc", |
| #endif /* CRAY. */ |
| #endif /* pyr. */ |
| #ifdef GCC_IS_NATIVE |
| "YACC", "bison -y", |
| #else |
| "YACC", "yacc", /* Or "bison -y" */ |
| #endif |
| "MAKEINFO", "makeinfo", |
| "TEX", "tex", |
| "TEXI2DVI", "texi2dvi", |
| "WEAVE", "weave", |
| "CWEAVE", "cweave", |
| "TANGLE", "tangle", |
| "CTANGLE", "ctangle", |
| |
| "RM", "rm -f", |
| |
| "LINK.o", "$(CC) $(LDFLAGS) $(TARGET_ARCH)", |
| "COMPILE.c", "$(CC) $(CFLAGS) $(CPPFLAGS) $(TARGET_ARCH) -c", |
| "LINK.c", "$(CC) $(CFLAGS) $(CPPFLAGS) $(LDFLAGS) $(TARGET_ARCH)", |
| "COMPILE.cc", "$(CXX) $(CXXFLAGS) $(CPPFLAGS) $(TARGET_ARCH) -c", |
| "COMPILE.C", "$(COMPILE.cc)", |
| "COMPILE.cpp", "$(COMPILE.cc)", |
| "LINK.cc", "$(CXX) $(CXXFLAGS) $(CPPFLAGS) $(LDFLAGS) $(TARGET_ARCH)", |
| "LINK.C", "$(LINK.cc)", |
| "LINK.cpp", "$(LINK.cc)", |
| "YACC.y", "$(YACC) $(YFLAGS)", |
| "LEX.l", "$(LEX) $(LFLAGS) -t", |
| "COMPILE.f", "$(FC) $(FFLAGS) $(TARGET_ARCH) -c", |
| "LINK.f", "$(FC) $(FFLAGS) $(LDFLAGS) $(TARGET_ARCH)", |
| "COMPILE.F", "$(FC) $(FFLAGS) $(CPPFLAGS) $(TARGET_ARCH) -c", |
| "LINK.F", "$(FC) $(FFLAGS) $(CPPFLAGS) $(LDFLAGS) $(TARGET_ARCH)", |
| "COMPILE.r", "$(FC) $(FFLAGS) $(RFLAGS) $(TARGET_ARCH) -c", |
| "LINK.r", "$(FC) $(FFLAGS) $(RFLAGS) $(LDFLAGS) $(TARGET_ARCH)", |
| "COMPILE.def", "$(M2C) $(M2FLAGS) $(DEFFLAGS) $(TARGET_ARCH)", |
| "COMPILE.mod", "$(M2C) $(M2FLAGS) $(MODFLAGS) $(TARGET_ARCH)", |
| "COMPILE.p", "$(PC) $(PFLAGS) $(CPPFLAGS) $(TARGET_ARCH) -c", |
| "LINK.p", "$(PC) $(PFLAGS) $(CPPFLAGS) $(LDFLAGS) $(TARGET_ARCH)", |
| "LINK.s", "$(CC) $(ASFLAGS) $(LDFLAGS) $(TARGET_MACH)", |
| "COMPILE.s", "$(AS) $(ASFLAGS) $(TARGET_MACH)", |
| "LINK.S", "$(CC) $(ASFLAGS) $(CPPFLAGS) $(LDFLAGS) $(TARGET_MACH)", |
| "COMPILE.S", "$(CC) $(ASFLAGS) $(CPPFLAGS) $(TARGET_MACH) -c", |
| "PREPROCESS.S", "$(CC) -E $(CPPFLAGS)", |
| "PREPROCESS.F", "$(FC) $(FFLAGS) $(CPPFLAGS) $(TARGET_ARCH) -F", |
| "PREPROCESS.r", "$(FC) $(FFLAGS) $(RFLAGS) $(TARGET_ARCH) -F", |
| "LINT.c", "$(LINT) $(LINTFLAGS) $(CPPFLAGS) $(TARGET_ARCH)", |
| |
| #ifndef NO_MINUS_C_MINUS_O |
| "OUTPUT_OPTION", "-o $@", |
| #endif |
| |
| #ifdef SCCS_GET_MINUS_G |
| "SCCS_OUTPUT_OPTION", "-G$@", |
| #endif |
| |
| #ifdef _AMIGA |
| ".LIBPATTERNS", "%.lib", |
| #else |
| #ifdef __MSDOS__ |
| ".LIBPATTERNS", "lib%.a $(DJDIR)/lib/lib%.a", |
| #else |
| ".LIBPATTERNS", "lib%.so lib%.a", |
| #endif |
| #endif |
| |
| #endif /* !VMS */ |
| 0, 0 |
| }; |
| |
| /* Set up the default .SUFFIXES list. */ |
| |
| void |
| set_default_suffixes (void) |
| { |
| suffix_file = enter_file (".SUFFIXES"); |
| |
| if (no_builtin_rules_flag) |
| (void) define_variable ("SUFFIXES", 8, "", o_default, 0); |
| else |
| { |
| char *p = default_suffixes; |
| suffix_file->deps = (struct dep *) |
| multi_glob (parse_file_seq (&p, '\0', sizeof (struct dep), 1), |
| sizeof (struct dep)); |
| (void) define_variable ("SUFFIXES", 8, default_suffixes, o_default, 0); |
| } |
| } |
| |
| /* Enter the default suffix rules as file rules. This used to be done in |
| install_default_implicit_rules, but that loses because we want the |
| suffix rules installed before reading makefiles, and thee pattern rules |
| installed after. */ |
| |
| void |
| install_default_suffix_rules (void) |
| { |
| register char **s; |
| |
| if (no_builtin_rules_flag) |
| return; |
| |
| for (s = default_suffix_rules; *s != 0; s += 2) |
| { |
| register struct file *f = enter_file (s[0]); |
| /* Don't clobber cmds given in a makefile if there were any. */ |
| if (f->cmds == 0) |
| { |
| f->cmds = (struct commands *) xmalloc (sizeof (struct commands)); |
| f->cmds->fileinfo.filenm = 0; |
| f->cmds->commands = s[1]; |
| f->cmds->command_lines = 0; |
| } |
| } |
| } |
| |
| |
| /* Install the default pattern rules. */ |
| |
| void |
| install_default_implicit_rules (void) |
| { |
| register struct pspec *p; |
| |
| if (no_builtin_rules_flag) |
| return; |
| |
| for (p = default_pattern_rules; p->target != 0; ++p) |
| install_pattern_rule (p, 0); |
| |
| for (p = default_terminal_rules; p->target != 0; ++p) |
| install_pattern_rule (p, 1); |
| } |
| |
| void |
| define_default_variables (void) |
| { |
| register char **s; |
| |
| if (no_builtin_variables_flag) |
| return; |
| |
| for (s = default_variables; *s != 0; s += 2) |
| (void) define_variable (s[0], strlen (s[0]), s[1], o_default, 1); |
| } |