⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 default.c

📁 DSP网络驱动开发_TMS3206
💻 C
字号:
/* Data base of default implicit rules for GNU Make.Copyright (C) 1988,89,90,91,92,93,94,95,96 Free Software Foundation, Inc.This file is part of GNU Make.GNU Make is free software; you can redistribute it and/or modifyit under the terms of the GNU General Public License as published bythe 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 ofMERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See theGNU General Public License for more details.You should have received a copy of the GNU General Public Licensealong with GNU Make; see the file COPYING.  If not, write tothe Free Software Foundation, Inc., 59 Temple Place - Suite 330,Boston, MA 02111-1307, USA.  */#include "make.h"#include "rule.h"#include "dep.h"#include "filedef.h"#include "job.h"#include "commands.h"#include "variable.h"/* Define GCC_IS_NATIVE if gcc is the native development environment on   your system (gcc/bison/flex vs cc/yacc/lex).  */#ifdef __MSDOS__#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 .cc .pas .p .for .f .r .y .l .mar \.mod .sym .def .h .info .dvi .tex .texinfo .texi .txinfo \.w .ch .cweb .web .com .sh .elc .el";#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";#endifstatic 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) /exe=$@",    ".mar.exe",    "$(LINK.mar) $^ $(LOADLIBES) $(LDLIBS) /exe=$@",    ".c.exe",    "$(COMPILE.c) $^ \n $(LINK.obj) $(subst .c,.obj,$^) $(LOADLIBES) $(LDLIBS) /exe=$@",    ".cc.exe",    "$(COMPILE.cc) $^ \n $(LINK.obj) $(subst .cc,.obj,$^) $(LOADLIBES) $(LDLIBS) /exe=$@",    ".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=$@ $<",    ".c.obj",    "$(COMPILE.c) /obj=$@ $<",    ".cc.obj",    "$(COMPILE.cc) /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    "AR", "library/obj",    "ARFLAGS", "/replace",    "AS", "macro",    "CC", "cc",    "C++", "gcc/plus",    "CXX", "gcc/plus",    "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", "yacc",	/* Or "bison -y"  */    "MAKEINFO", "makeinfo",    "TEX", "tex",    "TEXINDEX", "texindex",    "RM", "delete/nolog",    "LINK.obj", "$(LD) $(LDFLAGS)",    "COMPILE.c", "$(CC) $(CFLAGS) $(CPPFLAGS) $(TARGET_ARCH)",    "COMPILE.cc", "$(C++) $(C++FLAGS) $(CPPFLAGS) $(TARGET_ARCH) -c",    "YACC.y", "$(YACC) $(YFLAGS)",    "LEX.l", "$(LEX) $(LFLAGS)",    "COMPILE.for", "$(FC) $(FFLAGS) $(TARGET_ARCH)",    "COMPILE.pas", "$(PC) $(PFLAGS) $(CPPFLAGS) $(TARGET_ARCH)",    "COMPILE.mar", "$(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",    "CXX", "gcc",#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",    "+$(patsubst $@-noexist,$(CO) $(COFLAGS) $< $@,\		 $(filter-out $@,$(firstword $(wildcard $@) $@-noexist)))",    "CO", "co",    "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.  */voidset_default_suffixes (){  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.  */voidinstall_default_suffix_rules (){  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.  */voidinstall_default_implicit_rules (){  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);}voiddefine_default_variables (){  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);}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -