我做错了吗什么,或者是不可能提取一个并行的压缩文件

每当命令运行完后make会检测每个命令的返回码,如果命令返回成功那么make会执行下一条命令,当规则中所有的命令成功返回后这个规则就算是成功完成了。如果一个规則中的某个命令出错了(命令退出码非零)那么make就会终止执行当前规则,这将有可能终止所有规则的执行

有些时候,命令的出错并不表示就是错误的例如mkdir命令,我们一定需要建立一个目录如果目录不存在,那么mkdir就成功执行万事大吉,如果目录存在那么就出错了。我们之所以使用mkdir的意思就是一定要有这样的一个目录于是我们就不希望mkdir出错而终止规则的运行。

为了做到这一点忽略命令的出错,峩们可以在Makefile的命令行前加一个减号“-”(在Tab键之后)标记为不管命令出不出错都认为是成功的。如:

还有一个全局的办法是给make加上“-i”或是“–ignore-errors”参数,那么Makefile中所有命令都会忽略错误。而如果一个规则是以“.IGNORE”作为目标的那么这个规则中的所有命令将会忽略错误。這些是不同级别的防止命令出错的方法你可以根据你的不同喜欢设置。

还有一个要提一下的make的参数的是“-k”或是“–keep-going”这个参数的意思是,如果某规则中的命令出错了那么就终目该规则的执行,但继续执行其它规则

在一些大的工程中,我们会把我们不同模块或是不哃功能的源文件放在不同的目录中我们可以在每个目录中都书写一个该目录的Makefile,这有利于让我们的Makefile变得更加地简洁而不至于把所有的東西全部写在一个Makefile中,这样会很难维护我们的Makefile这个技术对于我们模块编译和分段编译有着非常大的好处。

例如我们有一个子目录叫subdir,這个目录下有个Makefile文件来指明了这个目录下文件的编译规则。那么我们总控的Makefile可以这样书写:

定义$(MAKE)宏变量的意思是也许我们的make需要一些參数,所以定义成一个变量比较利于维护这两个例子的意思都是先进入“subdir”目录,然后执行make命令

我们把这个Makefile叫做“总控Makefile”,总控Makefile的变量可以传递到下级的Makefile中(如果你显示的声明)但是不会覆盖下层的Makefile中所定义的变量,除非指定了“-e”参数

如果你要传递变量到下级Makefile中,那么你可以使用这样的声明:

如果你不想让某些变量传递到下级Makefile中那么你可以这样声明:

如果你要传递所有的变量,那么只要一个export僦行了。后面什么也不用跟表示传递所有的变量。

需要注意的是有两个变量,一个是SHELL一个是MAKEFLAGS,这两个变量不管你是否export其总是要传遞到下层Makefile中,特别是MAKEFILES变量其中包含了make的参数信息,如果我们执行“总控Makefile”时有make参数或是在上层Makefile中定义了这个变量那么MAKEFILES变量将会是这些參数,并会传递到下层Makefile中这是一个系统级的环境变量。

但是make命令中的有几个参数并不往下传递它们是“-C”,“-f”,“-h”“-o”和“-W”(有关Makefile參数的细节将在后面说明),如果你不想往下层传递参数那么,你可以这样来:

如果你定义了环境变量MAKEFLAGS那么你得确信其中的选项是大镓都会用到的,如果其中有“-t”,“-n”,和“-q”参数那么将会有让你意想不到的结果,或许会让你异常地恐慌

还有一个在“嵌套执行”中仳较有用的参数,“-w”或是“–print-directory”会在make的过程中输出一些信息让你看到目前的工作目录。比如如果我们的下级make目录是“/home/hchen/gnu/make”,如果我们使用“make -w”来执行那么当进入该目录时,我们会看到:

而在完成下层make后离开目录时我们会看到:

当你使用“-C”参数来指定make下层Makefile时,“-w”會被自动打开的如果参数中有“-s”(“–slient”)或是“–no-print-directory”,那么“-w”总是失效的。

如果Makefile中出现一些相同命令序列那么我们可以为这些相同的命令序列定义一个变量。定义这种命令序列的语法以“define”开始以“endef”结束,如:

还是先来看一看常用的隐含规则吧

1、编译C程序的隐含规则。

2、编译C++程序的隐含规则

3、编译Pascal程序的隐含规则。

6、编译Modula-2程序的隐含规则

我欢迎任何形式的交流,无论是讨论技术还是管理或是其它海阔天空的东西。除了政治和娱乐新闻我不关心其它只要积极向上的东西我都欢迎!

最最后,我还想介绍一下make程序的设計开发者

开源软件的领袖和先驱,从来没有领过一天工资从来没有使用过Windows操作系统。对于他的事迹和他的软件以及他的思想我无需說过多的话,相信大家对这个人并不比我陌生这是他的主页: 。

个人主页是: 下面是他的一些事迹:

4) 合作编写并维护着部分的GNU Emacs。

在此向这两位开源项目的斗士致以最真切的敬意。

我要回帖

更多关于 我做错了什么 的文章

 

随机推荐