1. 程式人生 > >轉:makefile裡面引用shell注意

轉: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.