轉:makefile裏面引用shell注意

轉:http://blog.csdn.net/myaccella/article/details/7487967


大家經常編寫和使用Makefile, Makefile裏面也經常用到shell, 但對其中一些需要注意的地方未必

會去留意, 這裏列出幾個來, 不知是否對大家有用。
1. 注意Makefile的變量和shell變量, 看如下示例:
 
  DIRS = src bin lib
   all:
    @for i in $(DIRS); /
     do /
         echo " " $$i; /
     done
   大家看出來了嗎? DIRS是makefile變量,i是shell變量, 使用的時候:
   $(DIRS), $$i區別還是蠻大的。
  
2. 每一行的shell都是在獨立的進程中運行的,如果你在上一行爲一個變量賦值, 不要指望它在下一行有效, 比如:
  @CROSS_COMPILE=mipsel-linux-
   @echo $(CROSS_COMPILE)
 
   打印的結果不會是mipsel-linux-,如果你想得到所要的結果, 就併爲一條shell吧:
   @CROSS_COMPILE=mipsel-linux- ; echo @echo $(CROSS_COMPILE)
    或者:
   @CROSS_COMPILE=mipsel-linux- ; /
    echo @echo$(CROSS_COMPILE)
   
3. shell一定要寫在target裏, 否則你寫了也白費勁, 是會被make忽略掉的.
   @echo "Building all..."
   all:
    @echo "Begin"
   只會打印Begin.
發佈了22 篇原創文章 · 獲贊 8 · 訪問量 5萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章