转自:http://blog.chinaunix.net/uid-22028680-id-3054167.html
origin 函数的作用是告诉你变量是哪里来的,其出生状况如何,他并不改变变量。其语法是:
$(origin VAR),其中VAR为变量的名字,而不是引用,所以一般没有 $ 字符在前。origin 函数通过返回值来告诉你 的出生情况。
下面用实例说明:
1. 当从来未定义过该变量时,origin 函数返回 "undefined" 。如下面的 Makefile 代码:
all:
@echo $(origin V)
运行输出:
$ make
undefined
2. 如果该变量为环境变量,那么返回 "enviroment" 。如下面的 Makefile 代码:
all:
@echo $(origin USER)
运行输出:
$ make
environment
3. 如果一个变量被定义在 Makefile 文件中,那么返回 "file" 。如下面的 Makefile 代码:
V := 1
all:
@echo $(origin V)
运行输出:
$ make
file
4. 如果变量来自命令行,那么返回 "command line" 。如下面的 Makefile 代码:
all:
@echo $(origin MyVar)
运行方法:
$ make MyVar="Are you ok?"
command line
5. 如果变量被 override 被重新定义过,那么返回 "override"。如下面的 Makefile 代码:
override SHELL = /bin/sh
all:
@echo $(origin SHELL)
运行输出:
$ make
override
6. 如果变量是自动化变量(如 $@, $< 等),那么返回 "automatic" 。如下面的 Makefile 代码:
all:
@echo $(origin @)
运行输出:
$ make
automatic
7. 如果变量是个默认定义,那么返回 "default"。如下面的 Makefile 代码:
all:
@echo $(origin CC)
运行输出:
$ make
default
预定义变量的含义:
$* 不包含扩展名的目标文件名称。
$+ 所有的依赖文件,以空格分开,并以出现的先后为序,可能包含重复的依赖文件。
$< 第一个依赖文件的名称。
$? 所有的依赖文件,以空格分开,这些依赖文件的修改日期比目标的创建日期晚。
$@ 目标的完整名称。
$^ 所有的依赖文件,以空格分开,不包含重复的依赖文件。
$% 如果目标是归档成员,则该变量表示目标的归档成员名称。例如,如果目标名称为
test.so(test.o),则 $@ 为 test.so,而 $% 为 test.o。
AR 归档维护程序的名称,默认值为 ar。
ARFLAGS 归档维护程序的选项。
AS 汇编程序的名称,默认值为 as。
ASFLAGS 汇编程序的选项。
CC C 编译器的名称,默认值为 cc。
CFLAGS C 编译器的选项。
CPP C 预编译器的名称,默认值为 $(CC) -E。
CPPFLAGS C 预编译的选项。
CXX C++ 编译器的名称,默认值为 g++。
CXXFLAGS C++ 编译器的选项。