Linux Makefile與Shell的問題
大概只要知道Makefile的人,都知道Makefile可以調(diào)用Shell腳本。但是在實際使用時,并不那么簡單,一些模棱兩可的地方可能會讓你抓狂。你若不信,可以先看幾個例子,想象一下這些這些例子會打印什么內(nèi)容,記下你想象的結(jié)果,然后在計算機上運行這些例子,對照看一下。
示例一:
if [ "$(BUILD)" = "debug" ]; then echo "build debug"; else echo "build release"; fi
all:
echo "done"
示例二:
all:
@CC=arm-linux-gcc
@echo $(CC)
示例三:
CC=arm-linux-gcc
all:
@echo $(CC)
示例四:
SUBDIR=src example
all:
@for subdir in $(SUBDIR); \
do\
echo "building " $(subdir); \
done
說明:
1. Shell腳本在target里才有效,其它地方都被忽略掉了。所以示例一中,”build debug”之類的字符串根本打印不出來。示例一的正確寫法是:
示例一:
all:
if [ "$(BUILD)" = "debug" ]; then echo "build debug"; else echo "build release"; fi
echo "done"
2. make把每一行Shell腳本當作一個獨立的單元,它們在單獨的進程中運行。示例二中,兩行Shell腳本在兩個莫不相干的進程里運行,第一個進程把CC設(shè)置為arm-linux-gcc,第二個進程是不知道的,所以打印的結(jié)果自然不是arm-linux-gcc了。示例二的正確寫法是:
示例二:
all:
@CC=arm-linux-gcc; echo $(CC)
或者:
all:
@CC=arm-linux-gcc; \
echo $(CC)
3. make在調(diào)用Shell之前先進行預處理,即展開所有Makefile的變量和函數(shù)。這些變量和函數(shù)都以$開頭。示例三中,Shell拿的腳本實際上是echo arm-linux-gcc,所以打印結(jié)果正確。
4. make預處理時,所有以$開頭的,它都不會放過。要想引用Shell自己的變量,應該以$$開頭。另外要注意,Shell自己的變量是不需要括號的。示例四的正確寫法是:
示例四:
SUBDIR=src example
all:
@for subdir in $(SUBDIR); \
do\
echo "building " $$subdir; \
done
相關(guān)文章
cwrsync invalid uid nobody 解決方法
這篇文章主要介紹了使用rsync/cwrsync工具進行檔案同步的時候出現(xiàn)invalid uid nobody錯誤的解決方法,需要的朋友可以參考下2016-03-03https證書選擇之DV型、OV型、EV型證書的主要區(qū)別
這篇文章主要介紹了https證書選擇之DV型、OV型、EV型證書的主要區(qū)別,需要的朋友可以參考下2017-09-09