(1)ifeq的用法
ifeq ($(變量名), 變量值 )
........
else ifeq ($(..), ..)
.........
else
.........
endif
(2)最近在學習makefile的過程中遇到需要用ifeq進行邏輯與判斷,但是ifeq並沒有像其他編程語言那樣有 邏輯或(||) 邏輯與(&&) 的符號可用。這時候需要變通一下。
1)邏輯與變通實現:
舉例說明:比如需要判斷兩個變量 VALUE1 和 VALUE2 的值都存在才執行某個動作,這需要邏輯與的判斷
C語言的邏輯: if ( VALUE1 && VALUE2){
do something....
}
沒有&&符號,我們可以這樣變通:將兩個變量鏈接起來再判斷
ifneq ($(VALUE1)$(VALUE2),)
do something....
endif
如果變量 VALUE1 和 VALUE2 都有具體的值,比如需要進行這樣的判斷: VALUE1 == V1 && VALUE2 == V2, 可以按如下的寫法;
ifeq ($(VALUE1)_$(VALUE2), V1_V2) ### 當然中間的下划線 "_" 可以用其他字符代替
do something....
endif
2) 邏輯或變通實現,同樣是上面的兩個變量
if( VALUE1 == V1 || VALUE2 == V2 ) {...} 可以用findstring函數做如下變通實現:
#如果VALUE1或者VALUE2為V1或V2,則findstring 不會返回空。
ifneq ($(findstring $(VALUE1)$(VALUE2), V1 V2),)
do something...
endif