[轉] Makefile中調用Shell


1、在Makefile中只能在target中調用Shell腳本,其他地方是不能輸出的。比如如下代碼就是沒有任何輸出:

VAR="Hello"
echo "$(VAR)" all: .....

以上代碼任何時候都不會輸出,沒有在target內,如果上述代碼改為如下:

VAR="Hello"

all:
    echo "$(VAR)" .....

以上代碼,在make all的時候將會執行echo命令。

最后打印結果是:

echo ""Hello""

"Hello"

2、在Makefile中執行shell命令,一行創建一個進程來執行。這也是為什么很多Makefile中有很多行的末尾都是“;  \”,以此來保證代碼是一行而不是多行,這樣Makefile可以在一個進程中執行,例如:

SUBDIR=src example
all:
    @for subdir in $(SUBDIR); \ do\ echo "building "; \ done

上述可以看出for循環中每行都是以”; \”結尾的。

3、Makefile中所有以$打頭的單詞都會被解釋成Makefile中的變量。如果你需要調用shell中的變量(或者正則表達式中錨定句位$),都需要加兩個$符號($$)。實例如下:

PATH="/data/"

all:
    echo ${PATH}/*Makefile中變量,即"/data"*/ echo $$PATH /*shell中的變量*/

例子中的第一個${PATH}引用的是Makefile中的變量,而不是shell中的PATH環境變量,后者引用的事Shell中的PATH環境變量。

     以上三點的是Makefile調用shell應該注意的地方,寫Makefile一定要注意。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM