浅显易懂 Makefile 入门 (07)— 其它函数(foreach 、if、call、origin )
1. foreach 函數
foreach 函數定義如下:
$(foreach <var>,<list>,<text>)
函數的功能是:把參數 <list> 中的單詞逐一取出放到參數 <var> 所指定的變量中,然后再執行 <text> 所包含的表達式。
每一次 <text> 會返回一個字符串,循環過程中,<text> 的返所返回的每個字符串會以空格分割,最后當整個循環結束的時候,<text> 所返回的每個字符串所組成的整個字符串(以空格分隔)將會是 foreach 函數的返回值。
所以 <var> 最好是一個變量名,<list> 可以是一個表達式,而 <text> 中一般會只用 <var> 這個參數來一次枚舉 <list> 中的單詞。
示例:
filename = 11 22 33 44
files = $(foreach n, $(filename), $(n).cpp)
all:echo $(files)
執行 make 結果
wohu@ubuntu:~/cpp/func$ make
echo 11.cpp 22.cpp 33.cpp 44.cpp
11.cpp 22.cpp 33.cpp 44.cpp
wohu@ubuntu:~/cpp/func$
foreach 中的 <var> 參數是一個臨時的局部變量,foreach 函數執行完后,參數 <var> 的變量將不再作用,其作用域只在 foreach 函數當中。
2. if 條件選擇函數
定義如下:
$(if <condition>,<then-part>)
或
$(if<condition>,<then-part>,<else-part>)
if 函數可以包含 else 部分,或者是不包含,即 if 函數的參數可以是兩個,也可以是三個。
condition 參數是 if 表達式,如果其返回的是非空的字符串,那么這個表達式就相當于返回真,于是,then-part 就會被計算,否則 else-part 會被計算。
而 if 函數的返回值是:
如果 condition 為真(非空字符串),那么 then-part 會是整個函數的返回值。
如果 condition 為假(空字符串),那么 else-part 將會是這個函數的返回值。此時如果 else-part 沒有被定義,那么整個函數返回空字串符。所以,then-part 和 else-part 只會有一個被計算。
示例 1:
file = aa
OBJ = $(if $(file), $(file), main.c)
all:echo $(OBJ)
執行 make 結果
wohu@ubuntu:~/cpp/func$ make
echo aa
aa
wohu@ubuntu:~/cpp/func$
示例 2:
OBJ = $(if $(name), $(name), main.c)
other:echo $(OBJ)
執行 make 結果
wohu@ubuntu:~/cpp/func$ make
echo main.c
main.c
wohu@ubuntu:~/cpp/func$
3. call 函數
函數定義如下:
$(call <expression>,<parm1>,<parm2>,<parm3>,...)
call 函數是唯一一個可以用來創建新的參數化的函數。我們可以用來寫一個非常復雜的表達式,這個表達式中,我們可以定義很多的參數,然后你可以用 call 函數來向這個表達式傳遞參數。
當 make 執行這個函數的時候,expression 參數中的變量 $(1)、$(2)、$(3)等,會被參數 parm1,parm2,parm3 依次取代。而 expression 的返回值就是 call 函數的返回值。
reverse = $(2) $(1)
foo = $(call reverse, aa, bb)
all:echo $(foo)
執行結果:
wohu@ubuntu:~/cpp/func$ make
echo bb aa
bb aa
wohu@ubuntu:~/cpp/func$
4. origin 函數
定義如下:
$(origin <variable>)
origin 函數不像其他的函數,它并不操作變量的值,它只是告訴你這個變量是哪里來的。
注意: variable 是變量的名字,不應該是引用,所以最好不要在 variable 中使用 $ 字符。
下面是 origin 函數返回值:
undefined:如果<variable>從來沒有定義過,函數將返回這個值。default:如果<variable>是一個默認的定義,比如說CC這個變量。environment:如果<variable>是一個環境變量并且當Makefile被執行的時候,-e參數沒有被打開。file:如果<variable>這個變量被定義在Makefile中,將會返回這個值。command line:如果<variable>這個變量是被命令執行的,將會被返回。override:如果<variable>是被override指示符重新定義的。automatic:如果<variable>是一個命令運行中的自動化變量。
這些信息對于我們編寫 Makefile 是非常有用的,例如假設我們有一個 Makefile ,其包含了一個定義文件 Make.def ,在 Make.def 中定義了一個變量 bletch ,而我們的環境變量中也有一個環境變量 bletch,我們想去判斷一下這個變量是不是環境變量,如果是我們就把它重定義了。如果是非環境變量,那么我們就不重新定義它。于是,我們在 Makefile 中,可以這樣寫:
ifdef bletch
ifeq "$(origin bletch)" "environment"
bletch = barf,gag,etc
endif
endif
當然,使用 override 關鍵字不就可以重新定義環境中的變量了嗎,為什么需要使用這樣的步驟?
是的,我們用 override 是可以達到這樣的效果的,可是 override 會把從命令行定義的變量也覆蓋了,而我們只想重新定義環境傳來的,而不是重新定義命令行傳來的。
總結
以上是生活随笔為你收集整理的浅显易懂 Makefile 入门 (07)— 其它函数(foreach 、if、call、origin )的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 2022-2028年中国汽车塑料行业市场
- 下一篇: 2022-2028年中国pu管行业市场深