Makefile与Shell的问题
轉自:http://blog.csdn.net/absurd/archive/2006/03/23/636418.aspx
Makefile與Shell的問題
?
大概只要知道Makefile的人,都知道Makefile可以調用Shell腳本。但是在實際使用時,并不那么簡單,一些模棱兩可的地方可能會讓你抓狂。你若不信,可以先看幾個例子,想象一下這些這些例子會打印什么內容,記下你想象的結果,然后在計算機上運行這些例子,對照看一下。
?
?
| 示例一: |
| 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設置為arm-linux-gcc,第二個進程是不知道的,所以打印的結果自然不是arm-linux-gcc了。示例二的正確寫法是:
?
| 示例二: |
| all: ??? @CC=arm-linux-gcc; echo $(CC) |
| 或者: |
| all: @CC=arm-linux-gcc; \ echo $(CC) |
?
3.???????? make在調用Shell之前先進行預處理,即展開所有Makefile的變量和函數。這些變量和函數都以$開頭。示例三中,Shell拿的腳本實際上是echo arm-linux-gcc,所以打印結果正確。
?
4.???????? make預處理時,所有以$開頭的,它都不會放過。要想引用Shell自己的變量,應該以$$開頭。另外要注意,Shell自己的變量是不需要括號的。示例四的正確寫法是:
?
| 示例四: |
| SUBDIR=src example all: ??? @for subdir in $(SUBDIR); \ ??? do\ ??????? echo "building " $$subdir; \ ??? done |
轉載于:https://www.cnblogs.com/itech/archive/2009/08/10/1542917.html
《新程序員》:云原生和全面數字化實踐50位技術專家共同創作,文字、視頻、音頻交互閱讀總結
以上是生活随笔為你收集整理的Makefile与Shell的问题的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 童年记忆-莴苣姑娘的故事
- 下一篇: “theform._eventtarge