Makefile的origin 函数

来源:互联网 发布:单片机模块化编程 编辑:程序博客网 时间:2024/05/16 12:34

转自: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

这里特别记录一下makefile中预定义的变量

预定义变量的含义:

$*  不包含扩展名的目标文件名称。

$+   所有的依赖文件,以空格分开,并以出现的先后为序,可能包含重复的依赖文件。
$<  第一个依赖文件的名称。
$?  所有的依赖文件,以空格分开,这些依赖文件的修改日期比目标的创建日期晚。
$@   目标的完整名称。
$^   所有的依赖文件,以空格分开,不包含重复的依赖文件。
$%  如果目标是归档成员,则该变量表示目标的归档成员名称。例如,如果目标名称为

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++ 编译器的选项。




0 0
原创粉丝点击