makefile--if條件判斷語句的語法與使用

sun_shine發表於2018-10-04

條件判斷語句


1. makefile中支援條件判斷語句

  • 可以根據條件的值來決定make的執行
  • 可以比較兩個不同變數或者變數和常量值
ifxxx (arg1,arg2)
#do true
else
#do false
#endif
複製程式碼

注意事項:
條件判斷語句只能用於控制make實際執行的語句;但是,不能控制規則中命令的執行過程。


2. 條件判斷語句的語法說明:

常用形式 ifxxx (arg1,arg2) 其它合法形式

ifxxx “arg1” “arg2”
ifxxx ‘arg1’ ‘arg2’
ifxxx “arg1” ‘arg2’
ifxxx ‘arg1’ “arg2”
複製程式碼

條件判斷語法格式:
makefile--if條件判斷語句的語法與使用

3. 條件判斷關鍵字

關鍵字功能

makefile--if條件判斷語句的語法與使用

.PHONY : test

var1 := A
var2 := $(var1)
var3 := 

test :
    ifeq ($(var1),$(var2))
    @echo "var1 == var2"
    else
    @echo "var1 != var2"
    endif
    
    ifneq ($(var3), )
    @echo "var3 is not empty"
    else
    @echo "var3 is empty"
    endif
    
    ifdef var1
    @echo "var1 is not empty"
    else
    @echo "var1 is empty"
    endif
    
    ifndef var3
    @echo "var3 is empty"
    else
    @echo "var3 is not empty"
    endif
複製程式碼

makefile--if條件判斷語句的語法與使用


4.一些工程經驗

  • 條件判斷語句之前可以有空格,但不能有Tab字元(’\t’)
  • 在條件語句中不要使用自動變數(@,@,^,$<)
  • 一條完整的條件語句必須位於同一個makefile中
  • 條件判斷類似C語言中的巨集,預處理階段有效,執行階段無效
  • make在載入makefile時
    首先計算表示式的值(賦值方式不同,計算方式不同)
    根據判斷語句的表示式決定執行的內容

小結:

  • 條件判斷根據條件的值決定make的執行
  • 條件判斷可以比較兩個不同變數或者變數和常量值
  • 條件判斷在預處理階段有效,執行階段無效
  • 條件判斷不能控制規則中命令的執行過程

相關文章