Makefile

执行make时候会自动在当前目录顺序搜寻GNUMakefile、makefile、Makefile、。

Make命令:
         Make [参数] [宏] [目标 目标 ……]
         通常从第一条规则开始维护。检查顺序:第一个依赖文件——第一个依赖文件的依赖文件……    ——>第二个依赖文件——第二个依赖文件的依赖文件……   ……    树状一条路径逐层展开,直查找到依赖文件都是源文件,而后原路返回,查找下一条路径。同一规则的依赖文件按照从左至右顺序。

参数:
         -c dir 指定make工做后的工做目录
         -e 不容许makefile中给环境宏赋值
         -f filename 或--file filename 指定一个或顺序指定多个makefile文件
         -i 忽略makefile中命令执行是产生的错误,不停止make
         -k 执行命令出错,放弃当前目标文件,转向其余目标
         -n 或--just-print按实际执行是顺序显示命令,包括@开头的,但不实际执行 
         -p 显示makefile中全部宏定义和内部规则
         -r 忽略内部规则
         -s 执行,但不显示执行的命令
         -S 执行makefile命令菜单时出错即退出makefile
         -t 或--touch修改每一个目标文件的建立日期,但不真正从新建立目标文件
         -V 显示make版本号
         -x 把全部宏输出到环境

Make的基本规则:
         Target  [属性] 分隔符 [依赖文件] [;命令行 ]
           {Tab 命令行}
         注:命令行间能够加入任意多个空行,但空行也要以tab开头。Cat –v-t-e Makefile会使Makefile文件中tab以^]显示,行尾以$显示。
         注:命令过长,用\来链接多行成一行。注释以#开头,若是#要用做字符符号,“#”。

分隔符:
         ::目标有多个规则。哪条规则中的依赖文件比目标新,执行哪条规则。若是多条规则的依赖文件都比目标新,多条规则都执行。因为后面的规则可能覆盖前面规则的执行结构,因此规则顺序不一样,执行结构也不一样。
         :^把本规则依赖文件和目标文件已有的依赖文件合起来,生成目标新的依赖文件列表。
         :-清除目标已有依赖文件,把本规则依赖文件做为目标依赖文件列表。
         :!对每一个更新过的依赖文件都执行一次命令菜单。 ???
         :|内部规则专用。 ???
如:file.o :file.c
         file.o :^ filef.c 现依赖文件为file.c filef.c
         file.o :- filef.c 现依赖文件为 filef.c

命令行属性:
-          若本命令的执行错误,忽略掉,继续向下执行。(不加该标志,make会中止)
+   始终执行本命令,即便make参数使用了-n-q-t。(前提是本规则中依赖文件新与目标文件,命令行须要执行)
@  本命令行不在标准输出显示。

Target属性:
         指定多个目标文件属性: 属性 属性 …… :目标 目标 ……
         规则中指定单个目标属性:目标 属性:[依赖文件] ……
         ·IGNORE 相似与命令行属性-
         ·SILENT 相似与命令行属性@
         ·PRECIOUS 保留中间文件
         ·LIBRARY 目标是一个库。若是make发现目标是lib(member)或lib((entry))形式,会自动给名为lib的目标加上该属性。
         ·LIBRARYM 目标是库的一个成员。若是make发现目标是lib(member)形式,会自动给lib目标加上·LIBRARY,被member目标加上·LIBRARYM。本属性不可在makefile文件显式声明。
         ·SYMBOL 目标是指定入口的库成员。Make会自动给lib((entry))的目标和依赖文件加上本属性。本属性不可在makefile文件显式声明。

命令行属性、目标属性、make参数都是用来控制make的,当三者属性发生矛盾时候,规则遵循的属性优先顺序为:命令行属性——目标属性——make参数,但三者都未指定,则用默认。

伪目标:
         Linux提供的内部伪目标:
         ·ERROR :
                   Make遇到错误,执行该目标规则。
·INCLUDE :file1 ……
         包含其余makefile文件,其余makefile文件位于·INCLUDE规则的依赖文件位置。实际上,是把包含的文件内容copy到当前位置。好比:包含一个宏定义文件,以便在当前位置展开,本makefile文件能够用这些宏。形式:
                            ·INCLUDE :filename1 filename2……  
或要包含的文件不在当前文件夹
                            ·INCLUDE :路径1 路径2 ……
                            ·INCLUDE :filename1 filename2 …… 
或者
                            ·INCLUDE :路径/filename> ……
·IMPORT :宏 ……
         使用环境变量中的宏。
         ·IMPORT :·ENVERTHING 可使用环境中全部宏了。
·EXPORT :宏 ……
         将宏及当前值输入环境变量中。
·SETDIR=路径
         改变当前工做路径。

注:有时候要定义的伪目标可能与文件名重。好比存在clean这个文件。能够用:
         PHONY:clean
         cean:
                   …………
         PHONY的做用是确保下面的clean是伪目标,非文件,从而避免混乱。命令行

相关文章
相关标签/搜索
本站公众号
   欢迎关注本站公众号,获取更多信息