admin管理员组

文章数量:1794759

Makefile

Makefile

                                                                   
先说一下 origin语法 origin函数不像其它函数。他并不直接操作变量的值,只是告诉你这个变量是从哪里来的(好好理解这句话)? 其语法是: $(origin    variable) 注意这里是变量的名字,不是引用,所以不要使用“$”字符。origin函数会以返回值告诉你这个变量的“出生情况”(这个变量从哪里来的?),下面来看一下origin函数的返回值好了。 我们先新建一个Makefile文件,内容是:
ifdef O ifeq ("$(origin O)", "command line") BUILD_DIR := $(O) endif endif all : echo  $( origin O) echo  $(BUILD_DIR)
注意;这里的“O”是字母大写的o,不是数字0. (1)返回值为"undefine"时,这个变量没有被定义过              直接在命令行中输入“make”,ifeq是比较两个变量是否相等,相等才执行后面的语句,显然这里并不相等,且因为 BUILD_DIR没有定义,所以 BUILD_DIR为空。
          (2)返回值为“command line”时,这个变量是被命令行定义的。        在命令行中输入“make    O=命令”      (3)返回值为“environment”时,这个变量是定义为环境变量      我们先把 O定义为环境变量,然后再make       (4)返回值为“file”时,这个变量是定义在Makefile中。       我们在Makefile中再输入这么一行定义O变量的命令,然后make。     

  
(5)返回值为“default”时,变量是默认定义的。‘ (6)返回值为“override”时,被override指示符重新定义 (7)返回值为“automatic”时,是一个命令运行中自动化变量

本文标签: Makefile