Makefile完全解析PART6 使用條件判斷

2022-02-22 23:57:15 字數 2412 閱讀 8189

使用條件判斷,可以讓make根據執行時的不同情況選擇不同的執行分支。條件表示式可以是比較變數的值,或是比較變數和常量的值。

一、示例

下面的例子,判斷$(cc)變數是否「gcc」,如果是的話,則使用gnu函式編譯目標。

libs_for_gcc = -lgnu

normal_libs =

foo: $(objects)

ifeq ($(cc),gcc)

$(cc) -o foo $(objects) $(libs_for_gcc)

else

$(cc) -o foo $(objects) $(normal_libs)

endif

可見,在上面示例的這個規則中,目標「foo」可以根據變數「$(cc)」值來選取不同的函式庫來編譯程式。

我們可以從上面的示例中看到三個關鍵字:ifeq、else和endif。ifeq的意思表示條件語句的開始,並指定乙個條件表示式,表示式包含兩個引數,以逗號分隔,表示式以圓括號括起。else表示條件表示式為假的情況。endif表示乙個條件語句的結束,任何乙個條件表示式都應該以endif結束。

當我們的變數$(cc)值是「gcc」時,目標foo的規則是:

foo: $(objects)

$(cc) -o foo $(objects) $(libs_for_gcc)

而當我們的變數$(cc)值不是「gcc」時(比如「cc」),目標foo的規則是:

foo: $(objects)

$(cc) -o foo $(objects) $(normal_libs)

當然,我們還可以把上面的那個例子寫得更簡潔一些:

libs_for_gcc = -lgnu

normal_libs =

ifeq ($(cc),gcc)

libs=$(libs_for_gcc)

else

libs=$(normal_libs)

endif

foo: $(objects)

$(cc) -o foo $(objects) $(libs)

二、語法

條件表示式的語法為:;;

endif

以及:;

;else

;endif

其中;表示條件關鍵字,如「ifeq」。這個關鍵字有四個。

第乙個是我們前面所見過的「ifeq」

ifeq (;, ;)

ifeq ';' ';'

ifeq ";" ";"

ifeq ";" ';'

ifeq ';' ";"

比較引數「arg1」和「arg2」的值是否相同。當然,引數中我們還可以使用make的函式。如:

ifeq ($(strip $(foo)),)

;endif

這個示例中使用了「strip」函式,如果這個函式的返回值是空(empty),那麼;就生效。

第二個條件關鍵字是「ifneq」。語法是:

ifneq (;, ;)

ifneq ';' ';'

ifneq ";" ";"

ifneq ";" ';'

ifneq ';' ";"

其比較引數「arg1」和「arg2」的值是否相同,如果不同,則為真。和「ifeq」類似。

第三個條件關鍵字是「ifdef」。語法是:

ifdef ;

如果變數;的值非空,那到表示式為真。否則,表示式為假。當然,;同樣可以是乙個函式的返回值。注意,ifdef只是測試乙個變數是否有值,其並不會把變數擴充套件到當前位置。還是來看兩個例子:

示例一:

bar =

foo = $(bar)

ifdef foo

frobozz = yes

else

frobozz = no

endif

示例二:

foo =

ifdef foo

frobozz = yes

else

frobozz = no

endif

第乙個例子中,「$(frobozz)」值是「yes」,第二個則是「no」。

第四個條件關鍵字是「ifndef」。其語法是:

ifndef ;

這個我就不多說了,和「ifdef」是相反的意思。

在;這一行上,多餘的空格是被允許的,但是不能以[tab]鍵做為開始(不然就被認為是命令)。而注釋符「#」同樣也是安全的。「else」和「endif」也一樣,只要不是以[tab]鍵開始就行了。

特別注意的是,make是在讀取makefile時就計算條件表示式的值,並根據條件表示式的值來選擇語句,所以,你最好不要把自動化變數(如「$@」等)放入條件表示式中,因為自動化變數是在執行時才有的。

而且,為了避免混亂,make不允許把整個條件語句分成兩部分放在不同的檔案中。

par 函式引數解析

r有著非常強大的繪圖功能,我們可以利用簡單的幾行 繪製出各種圖形來,但是有 時候預設的圖形設定沒法滿足我們的需要,甚至會碰到各種各樣的小問題 如座標軸或者標題出界了,或者圖例說明的大小或者位置遮擋住了圖形,甚至有時候預設 的顏色也不能滿足我們的需求。如何進行調整呢?這就用到了 強大 的函式par 我...

Makefile完全解析PART2 原理

一 makefile裡有什麼?makefile裡主要包含了五個東西 顯式規則 隱晦規則 變數定義 檔案指示和注釋。1 顯式規則。顯式規則說明了,如何生成乙個或多的的目標檔案。這是由makefile的書寫者明顯指出,要生成的檔案,檔案的依賴檔案,生成的命令。2 隱晦規則。由於我們的make有自動推導的...

Makefile檔案解析

在makefile中,除第一條命令外,每一條命令的開頭必須是tab製表符,比如 cc arm linux gcc exec hello objs hello.o cflags ldflags static all exec exec objs cc ldflags o objs clean rm f...