jasmine214--love

          只有當你的內心總是充滿快樂、美好的愿望和寧靜時,你才能擁有強壯的體魄和明朗、快樂或者寧靜的面容。
          posts - 731, comments - 60, trackbacks - 0, articles - 0

          makefile中的shell語法

          Posted on 2012-01-10 10:50 幻海藍夢 閱讀(16699) 評論(3)  編輯  收藏 所屬分類: 生活

          在Makefile中寫shell代碼有點詭異,和不同的shell語法不太一樣,如果不了解,看Makefile會莫名其妙。下面總結了一些。

          1:盡在Makefile文件的目標項冒號后的另起一行的代碼才是shell代碼。
          eg:
          xx = xx1         // 這里時makefile代碼
          yy:xx = xx2   // 這是是makefile代碼,makefile允許變量賦值時,'='號兩邊留空格
          yy:
              xx=xx3 // 只有這里是shell代碼 ,shell不允許‘=’號兩邊有空格哦。
          有一個例外:
          xx=$(shell 這里的代碼也是shell代碼)


          2:Makefile中的shell,每一行是一個進程,不同行之間變量值不能傳遞。所以,Makefile中的shell不管多長也要寫在一行。
          eg:

          SUBDIR=src example

          all:

              @for subdir in $(SUBDIR); /      // 這里往下是一行shell

              do/

                  echo "building " $$subdir; /

              done



          3:Makefile中的變量以$開頭, 所以,為了避免和shell的變量沖突,shell的變量以$$開頭
          eg1:從當前目錄路徑中提取出 /application 或 /base_class 之前的部分
          PROJECT_ROOT_DIR = $(shell pwd | awk -F'/application|/base_class' '{print $$1}')
          eg2:上例中$$subdir就是shell中的變量, 而$(SUBDIR)是Makefile的中的變量

          =============================================================================================

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

          VAR="Hello"
          echo "$VAR"

          all:
          .....

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

          VAR="Hello"

          all:
          echo "$VAR"
          .....

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

          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}
          echo $$PATH

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

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


          原文:
          http://my.unix-center.net/~Simon_fu/?p=648

          Feedback

          # re: makefile中的shell語法  回復  更多評論   

          2012-08-02 15:20 by Bill Z
          如果是shell的 $$ (進程id) 如何輸出它,我用$$$不行,其他努力都不行 。。。 請教!

          # re: makefile中的shell語法  回復  更多評論   

          2012-08-02 15:48 by Bill Z
          已經了解到:$$$$ ($$->$)

          你上面提到的target的叫法好像不妥啊,不過我知道你在說什么?
          在makefile里面也可以這樣調shell
          如: CURRENT_DIR=$(shell pwd)

          # re: makefile中的shell語法  回復  更多評論   

          2015-12-16 18:40 by YinChao
          兄弟,多謝。今晚加班解決這個問題呢,幸虧看到你的文章。
          主站蜘蛛池模板: 五原县| 沧州市| 牙克石市| 鹤岗市| 木里| 如皋市| 义马市| 精河县| 邮箱| 微博| 米易县| 孝昌县| 淮南市| 秦皇岛市| 鄂伦春自治旗| 刚察县| 扶绥县| 菏泽市| 海宁市| 台湾省| 日喀则市| 颍上县| 马关县| 瑞昌市| 永德县| 金山区| 江门市| 紫阳县| 和龙市| 云阳县| 灵武市| 莲花县| 南康市| 青岛市| 吉首市| 咸宁市| 五河县| 平泉县| 张北县| 航空| 同心县|