对于Makefile中的各种变量,可能是我们比较头痛的事了。我们要查看他们并不是很方便,需要修改makefile加入echo命令。这有时候很不方便。其实我们可以制作下面一个专门用来输出变量的makefile(假设名字叫:vars.mk)
vars.mk
%:
@echo’
∗=
∗
=
($*)’
d-%:
@echo’
∗=
∗
=
(
∗)′@echo′origin=
∗
)
′
@
e
c
h
o
′
o
r
i
g
i
n
=
(origin
∗)′@echo′value=
∗
)
′
@
e
c
h
o
′
v
a
l
u
e
=
(value
∗)′@echo′flavor=
∗
)
′
@
e
c
h
o
′
f
l
a
v
o
r
=
(flavor $*)’
这样一来,我们可以使用make命令的-f参数来查看makefile中的相关变量(包括make的内建变量,比如:COMPILE.c或MAKE_VERSION之类的)。注意:第二个以“d-”为前缀的目标可以用来打印关于这个变量更为详细的东西(后面有详细说明)
假设我们的makefile是这个样子(test.mk)
test.mk
OBJDIR := objdir
OBJS :=
(addprefix
(
a
d
d
p
r
e
f
i
x
(OBJDIR)/,foo.o bar.o baz.o)
foo = (bar)bar= ( b a r ) b a r = (ugh)ugh = Huh?
CFLAGS = (includedirs)−Oincludedirs=−Ifoo−IbarCFLAGS:= ( i n c l u d e d i r s ) − O i n c l u d e d i r s = − I f o o − I b a r C F L A G S := (CFLAGS) -Wall
MYOBJ := a.o b.o c.o
MYSRC := $(MYOBJ:.o=.c)
那么,我们可以这样进行调试:
演示
[hchen@RHELSVR5]$ make -f test.mk -f var.mk OBJS
OBJS=objdir/foo.o objdir/bar.o objdir/baz.o
[hchen@RHELSVR5]
make−ftest.mk−fvar.mkd−foofoo=Huh?origin=filevalue=
m
a
k
e
−
f
t
e
s
t
.
m
k
−
f
v
a
r
.
m
k
d
−
f
o
o
f
o
o
=
H
u
h
?
o
r
i
g
i
n
=
f
i
l
e
v
a
l
u
e
=
(bar)
flavor = recursive
[hchen@RHELSVR5]$make -f test.mk -f var.mk d-CFLAGS
CFLAGS=-Ifoo -Ibar -O -O
origin =file
value = -Ifoo -Ibar -O -O
flavor = simple
[hchen@RHELSVR5] make−ftest.mk−fvar.mkd−COMPILE.cCOMPILE.c=cc−Ifoo−Ibar−O−Wall−corigin=defaultflavor=recursivevalue= m a k e − f t e s t . m k − f v a r . m k d − C O M P I L E . c C O M P I L E . c = c c − I f o o − I b a r − O − W a l l − c o r i g i n = d e f a u l t f l a v o r = r e c u r s i v e v a l u e = (CC) (CFLAGS) ( C F L A G S ) (CPPFLAGS) $(TARGET_ARCH) -c
我们可以看到:
make的第一个-f后是要测试的makefile,第二个是我们的debug makefile。
后面直接跟变量名,如果在变量名前加”d-”,则输出更为详细的东西。
说一说”d-” 前缀(其意为details),其中调用了下面三个参数。
$(origin):告诉你这个变量是来自哪儿,file表示文件,environment表示环境变量,还有environment override,command line,override,automatic等。
$(value):打出这个变量没有被展开的样子。比如上述示例中的 foo 变量。
$(flavor):有两个值,simple表示是一般展开的变量,recursive表示递归展开的变量。