對(duì)于Makefile中的各種變量,可能是我們比較頭痛的事了。我們要查看他們并不是很方便,需要修改makefile加入echo命令。這有時(shí)候很不方便。其實(shí)我們可以制作下面一個(gè)專門用來(lái)輸出變量的makefile(假設(shè)名字叫:vars.mk)
vars.mk
1 %:
2 @echo '$*=$($*)'
3
4 d-%:
5 @echo '$*=$($*)'
6 @echo ' origin = $(origin $*)'
7 @echo ' value = $(value $*)'
8 @echo ' flavor = $(flavor $*)'
這樣一來(lái),我們可以使用make命令的-f參數(shù)來(lái)查看makefile中的相關(guān)變量(包括make的內(nèi)建變量,比如:COMPILE.c或MAKE_VERSION之類的)。注意:第二個(gè)以“d-”為前綴的目標(biāo)可以用來(lái)打印關(guān)于這個(gè)變量更為詳細(xì)的東西(后面有詳細(xì)說(shuō)明)
假設(shè)我們的makefile是這個(gè)樣子(test.mk)
test.mk
1 OBJDIR := objdir
2 OBJS := $(addprefix $(OBJDIR)/,foo.o bar.o baz.o)
3
4 foo = $(bar)bar = $(ugh)ugh = Huh?
5
6 CFLAGS = $(include_dirs) -O
7 include_dirs = -Ifoo -Ibar
8 CFLAGS := $(CFLAGS) -Wall
9
10 MYOBJ := a.o b.o c.o
11 MYSRC := $(MYOBJ:.o=.c)
那么,我們可以這樣進(jìn)行調(diào)試:
演示
1 [hchen@RHELSVR5]$ make -f test.mk -f var.mk OBJS
2 OBJS=objdir/foo.o objdir/bar.o objdir/baz.o
3
4 [hchen@RHELSVR5]$ make -f test.mk -f var.mk d-foo
5 foo=Huh?
6 origin = file
7 value = $(bar)
8 flavor = recursive
9
10 [hchen@RHELSVR5]$ make -f test.mk -f var.mk d-CFLAGS
11 CFLAGS=-Ifoo -Ibar -O -O
12 origin = file
13 value = -Ifoo -Ibar -O -O
14 flavor = simple
15
16 [hchen@RHELSVR5]$ make -f test.mk -f var.mk d-COMPILE.c
17 COMPILE.c=cc -Ifoo -Ibar -O -Wall -c
18 origin = default
19 flavor = recursive
20 value = $(CC) $(CFLAGS) $(CPPFLAGS) $(TARGET_ARCH) -c
我們可以看到:
- make的第一個(gè)-f后是要測(cè)試的makefile,第二個(gè)是我們的debug makefile。
- 后面直接跟變量名,如果在變量名前加”d-”,則輸出更為詳細(xì)的東西。
說(shuō)一說(shuō)”d-” 前綴(其意為details),其中調(diào)用了下面三個(gè)參數(shù)。
- $(origin):告訴你這個(gè)變量是來(lái)自哪兒,file表示文件,environment表示環(huán)境變量,還有environment override,command line,override,automatic等。
- $(value):打出這個(gè)變量沒(méi)有被展開(kāi)的樣子。比如上述示例中的 foo 變量。
- $(flavor):有兩個(gè)值,simple表示是一般展開(kāi)的變量,recursive表示遞歸展開(kāi)的變量。
(全文完)
本文轉(zhuǎn)自:http://coolshell.cn/articles/3790.html#more-3790
posted on 2013-11-28 10:46
王海光 閱讀(1061)
評(píng)論(0) 編輯 收藏 引用 所屬分類:
Linux