學習《跟我一起學makefile》使用條件判斷

2021-10-06 04:22:47 字數 3223 閱讀 4433

文章**

使用條件判斷,可以讓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 和 endififeq的 意思表示條件語句的開始,並指定乙個條件表示式,表示式包含兩個引數,以逗號分隔,表示式以圓括號括 起。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 ''

""

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

ifeq (

$(strip $(foo)

),)endif

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

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

ifneq (

, )ifneq ''

''ifneq ""

""ifneq ""

''ifneq ''

""

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

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

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

示例一:

bar =

foo =

$(bar)

ifdef foo

frobozz =

yeselse

frobozz = no

endif

示例二:

foo =

ifdef foo

frobozz =

yeselse

frobozz = no

endif

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

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

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

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

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

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

《跟我一起學makefile》學習筆記(一)

最近在學習朱有鵬老師的嵌入式課程,講到了makefile,朱老師推薦了陳皓老師的 跟我一起學makefile 自己對makefile一知半解,決定跟著文件,系統地學習一下,現記錄如下 對應文件的p1 p9 第一部分 概述 makefile,管理大型工程的原始碼,定義一系列規則。指定哪些檔案先編譯 後...

《跟我一起學makefile》學習筆記(二)

學習記錄 對應文件的p10 p20 四 使用變數 edit的規則 edit main.o kbd.o display.o insert.o search.o files.o utils.o cc o edit main.o kbd.o command.o display.o insert.o sea...

讀《跟我一起學Makefile》有感

其實在之前的工作中有很多的機會接觸到makefile,但是總是沒能拿出時間通讀其語法,我想這與自身不夠積極的態度是直接掛鉤的。先說說在這次的收穫 首先從最基本的語法規則到變數定義,熟悉了其最基本的工作流程 再者結合文中的示例,自己再實際練習,熟悉了其中個別函式及特殊規則的應用。在接觸到專案中的mak...