ifdef <variable-name>; 如果变量<variable-name>;的值非空,那到表达式为真。否则,表达式为假。当然,<variable- name>;同样可以是一个函数的返回值。注意,ifdef只是测试一个变量是否有值,其并不会把变量扩展到当前位置。还是来看两个例子: 示例一: bar = foo = $(bar) ifdef foo froboz
语法是: ifdef <variable-name>; 如果变量<variable-name>;的值非空,那到表达式为真。否则,表达式为假。当然,<variable-name>;同样可以是一个函数的返回值。注意,ifdef只是测试一个变量是否有值,其并不会把变量扩展到当前位置。还是来看两个例子: 示例一: bar = foo = $(bar) ifdef foo frobozz = yes el...
filename可以是当前操作系统Shell的文件模式(可以保含路径和通配符) 在include 前面可以有一些空字符,但是绝不能是[Tab]键开始。include和<filename>可以用一个或多个空格隔开。举个例子,你有这样几个Makefile:a.mk、b.mk、c.mk,还有一个文件叫foo.make,以及一个变量$(bar),其包含了e.mk和f.mk,那么,下面...
如果变量<variable-name>的值非空,那到表达式为真。否则,表达式为假。当然,<variable-name>同样可以是一个函数的返回值。注意,ifdef只是测试一个变量是否有值,其并不会把变量扩展到当前位置。还是来看两个例子: 示例一: bar= foo=$(bar) ifdef foo frobozz=yes else frobozz=no endif 示例二: foo= ifdef fo...
$(space)使用了$(empty)定义了一个空格,$(foo)的值是“a b c”,$(bar)的定义用,调用了函数“subst”,这是一个替换函数,这个函数有三个参数,第一个参数是被替换字串,第二个参数是替换字串,第三个参数是替换操作作用的字串。这个函数也就是把$(foo)中的空格替换成逗号,所以$(bar)的值是“a,b,c”...
`ifdef VARIABLE-NAME' 这个就不详细讨论了,它的功能就是实现了和“ifdef”相反的条件判断。 在“CONDITIONAL-DIRECTIVE”这一行上,可以以若干个空格开始,make处理时会被忽略这些空格。但不能以[Tab]字符做为开始(不然就被认为是命令)。条件判断语句中,在除关键字(包括“endif”)之前、和条件表达式的参数中之外,...
filename可以是当前操作系统Shell的文件模式(可以保含路径和通配符) 在include 前面可以有一些空字符,但是绝不能是[Tab]键开始。include和<filename>可以用一个或多个空格隔开。举个例子,你有这样几个Makefile:a.mk、b.mk、c.mk,还有一个文件叫foo.make,以及一个变量$(bar),其包含了e.mk和f.mk,那么,下面...
借助编译器(-MM)为每个源文件生成依赖关系并保存到对应的 name.xxxx (在Makefile中 $ 有特殊含义,如果要表示它的字面意思需要写两个 $,所以 Makefile 中的四个 $ 传给Shell变成两个 $,而两个 $ 在Shell中表示当前进程的id,一般用它给临时文件起名,以保证文件名唯一。) ...
ifdef <variable-name>;如果变量<variable-name>;的值非空,那到表达式为真。否则,表达式为假。当然,<variable-name>;同样可以是一个函数的返回值。注意,ifdef只是测试一个变量是否有值,其并不会把变量扩展到当前位置。还是来看两个例子:示例一:bar = foo = $(bar)ifdef foo frobozz = yes ...
如果<variable>是一个环境变量,并且当Makefile被执行时,“-e”参数没有被打开。 “file” 如果<variable>这个变量被定义在Makefile中。 “command line” 如果<variable>这个变量是被命令行定义的。 “override” 如果<variable>是被override指示符重新定义的。 “automatic” 如果<variable>是一个命令运行中的自动...