面对现实,超越自己
逆水行舟,不进则退
posts - 269,comments - 32,trackbacks - 0

对于Makefile中的各种变量,可能是我们比较头痛的事了。我们要查看他们并不是很方便,需要修改makefile加入echo命令。这有时候很不方便。其实我们可以制作下面一个专门用来输出变量的makefile(假设名字叫:vars.mk)

vars.mk

1 %:
2         @echo '$*=$($*)'
3  
4 d-%:
5         @echo '$*=$($*)'
6         @echo '  origin = $(origin $*)'
7         @echo '   value = $(value  $*)'
8         @echo '  flavor = $(flavor $*)'

 这样一来,我们可以使用make命令的-f参数来查看makefile中的相关变量(包括make的内建变量,比如:COMPILE.c或MAKE_VERSION之类的)。注意:第二个以“d-”为前缀的目标可以用来打印关于这个变量更为详细的东西(后面有详细说明)

假设我们的makefile是这个样子(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)

 那么,我们可以这样进行调试:


演示
 1 [hchen@RHELSVR5]$ make -test.mk -f var.mk OBJS
 2 OBJS=objdir/foo.o objdir/bar.o objdir/baz.o
 3     
 4 [hchen@RHELSVR5]$ make -test.mk -f var.mk d-foo
 5 foo=Huh?
 6   origin = file
 7   value = $(bar)
 8   flavor = recursive
 9  
10 [hchen@RHELSVR5]$ make -test.mk -f var.mk d-CFLAGS
11 CFLAGS=-Ifoo -Ibar --O
12   origin = file
13   value = -Ifoo -Ibar --O
14   flavor = simple
15  
16 [hchen@RHELSVR5]$  make -f test.mk -f var.mk d-COMPILE.c
17 COMPILE.c=cc -Ifoo -Ibar --Wall   -c
18   origin = default
19   flavor = recursive
20    value = $(CC) $(CFLAGS) $(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表示递归展开的变量。

(全文完)

本文转自:http://coolshell.cn/articles/3790.html#more-3790

posted on 2013-11-28 10:46 王海光 阅读(1024) 评论(0)  编辑 收藏 引用 所属分类: Linux

只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理