$(origin <variable>)
all:
@echo $(origin V)
$ make
undefined
all:
@echo $(origin USER)
$ make
environment
all:
@echo $(origin CC)
$ make
default
V := 1
all:
@echo $(origin V)
$ make
file
all:
@echo $(origin MyVar)
$ make MyVar="Are you ok?"
command line
verride SHELL = /bin/sh
all:
@echo $(origin SHELL)
$ make
override
all:
@echo $(origin @)
$ make
automatic
這些信息對(duì)于我們編寫Makefile是非常有用的,例如,假設(shè)我們有一個(gè)Makefile其包了一個(gè)定義文件Make.def,在Make.def中定義了一個(gè)變量“bletch”,而我們的環(huán)境中也有一個(gè)環(huán)境變量“bletch”,此時(shí),我們想判斷一下,如果變量來源于環(huán)境,那么我們就把之重定義了,如果來源于Make.def或是命令行等非環(huán)境的,那么我們就不重新定義它。于是,在我們的Makefile中,我們可以這樣寫:
ifdef bletch
ifeq "$(origin bletch)" "environment"
bletch = barf, gag, etc.
endif
endif
當(dāng)然,你也許會(huì)說,使用override關(guān)鍵字不就可以重新定義環(huán)境中的變量了嗎?為什么需要使用這樣的步驟?是的,我們用override是可以達(dá)到這樣的效果,可是override過于粗暴,它同時(shí)會(huì)把從命令行定義的變量也覆蓋了,而我們只想重新定義環(huán)境傳來的,而不想重新定義命令行傳來的。
四、foreach 函數(shù)
foreach函數(shù)和別的函數(shù)非常的不一樣。因?yàn)檫@個(gè)函數(shù)是用來做循環(huán)用的,Makefile中的foreach函數(shù)幾乎是仿照于Unix標(biāo)準(zhǔn)Shell(/bin/sh)中的for語句,或是C-Shell(/bin/csh)中的foreach語句而構(gòu)建的。它的語法是:
$(foreach <var>;,<list>;,<text>;)
這個(gè)函數(shù)的意思是,把參數(shù)<list>;中的單詞逐一取出放到參數(shù)<var>;所指定的變量中,然后再執(zhí)行<text>;所包含的表達(dá)式。每一次<text>;會(huì)返回一個(gè)字符串,循環(huán)過程中,<text>;的所返回的每個(gè)字符串會(huì)以空格分隔,最后當(dāng)整個(gè)循環(huán)結(jié)束時(shí),<text>;所返回的每個(gè)字符串所組成的整個(gè)字符串(以空格分隔)將會(huì)是foreach函數(shù)的返回值。
所以,<var>;最好是一個(gè)變量名,<list>;可以是一個(gè)表達(dá)式,而<text>;中一般會(huì)使用<var>;這個(gè)參數(shù)來依次枚舉<list>;中的單詞。舉個(gè)例子:
names := a b c d
files := $(foreach n,$(names),$(n).o)
上面的例子中,$(name)中的單詞會(huì)被挨個(gè)取出,并存到變量“n”中,“$(n).o”每次根據(jù)“$(n)”計(jì)算出一個(gè)值,這些值以空格分隔,最后作為foreach函數(shù)的返回,所以,$(files)的值是“a.o b.o c.o d.o”。
注意,foreach中的<var>;參數(shù)是一個(gè)臨時(shí)的局部變量,foreach函數(shù)執(zhí)行完后,參數(shù)<var>;的變量將不在作用,其作用域只在foreach函數(shù)當(dāng)中。
聯(lián)系客服