makefile中的shell語(yǔ)法
Posted on 2012-01-10 10:50 幻海藍(lán)夢(mèng) 閱讀(16705) 評(píng)論(3) 編輯 收藏 所屬分類(lèi): 生活在Makefile中寫(xiě)shell代碼有點(diǎn)詭異,和不同的shell語(yǔ)法不太一樣,如果不了解,看Makefile會(huì)莫名其妙。下面總結(jié)了一些。
1:盡在Makefile文件的目標(biāo)項(xiàng)冒號(hào)后的另起一行的代碼才是shell代碼。
eg:
xx = xx1 // 這里時(shí)makefile代碼
yy:xx = xx2 // 這是是makefile代碼,makefile允許變量賦值時(shí),'='號(hào)兩邊留空格
yy:
xx=xx3 // 只有這里是shell代碼 ,shell不允許‘=’號(hào)兩邊有空格哦。
有一個(gè)例外:
xx=$(shell 這里的代碼也是shell代碼)
2:Makefile中的shell,每一行是一個(gè)進(jìn)程,不同行之間變量值不能傳遞。所以,Makefile中的shell不管多長(zhǎng)也要寫(xiě)在一行。
eg:
SUBDIR=src example all: @for subdir in $(SUBDIR); / // 這里往下是一行shell do/ echo "building " $$subdir; / done |
3:Makefile中的變量以$開(kāi)頭, 所以,為了避免和shell的變量沖突,shell的變量以$$開(kāi)頭
eg1:從當(dāng)前目錄路徑中提取出 /application 或 /base_class 之前的部分
PROJECT_ROOT_DIR = $(shell pwd | awk -F'/application|/base_class' '{print $$1}')
eg2:上例中$$subdir就是shell中的變量, 而$(SUBDIR)是Makefile的中的變量
=============================================================================================
1、在Makefile中只能在target中調(diào)用Shell腳本,其他地方是不能輸出的。比如如下代碼就是沒(méi)有任何輸出:
VAR="Hello"
echo "$VAR"
all:
.....
以上代碼任何時(shí)候都不會(huì)輸出,沒(méi)有在target內(nèi),如果上述代碼改為如下:
VAR="Hello"
all:
echo "$VAR"
.....
以上代碼,在make all的時(shí)候?qū)?huì)執(zhí)行echo命令。
2、在Makefile中執(zhí)行shell命令,一行創(chuàng)建一個(gè)進(jìn)程來(lái)執(zhí)行。這也是為什么很多Makefile中有很多行的末尾都是“; \”,以此來(lái)保證代碼是一行而不是多行,這樣Makefile可以在一個(gè)進(jìn)程中執(zhí)行,例如:
SUBDIR=src example
all:
@for subdir in $(SUBDIR); \
do\
echo "building "; \
done
上述可以看出for循環(huán)中每行都是以”; \”結(jié)尾的。
3、Makefile中所有以$打頭的單詞都會(huì)被解釋成Makefile中的變量。如果你需要調(diào)用shell中的變量(或者正則表達(dá)式中錨定句位$),都需要加兩個(gè)$符號(hào)($$)。實(shí)例如下:
PATH="/data/"
all:
echo ${PATH}
echo $$PATH
例子中的第一個(gè)${PATH}引用的是Makefile中的變量,而不是shell中的PATH環(huán)境變量,后者引用的事Shell中的PATH環(huán)境變量。
以上三點(diǎn)的是Makefile調(diào)用shell應(yīng)該注意的地方,寫(xiě)Makefile一定要注意。
原文: