首页 > C/C++语言, 编程工具 > 如何调试makefile变量

如何调试makefile变量

2011年3月1日 发表评论 阅读评论 13,940 人阅读    

六、七年前写过一篇《跟我一起写Makefile》,直到今天,还有一些朋友问我一些Makefile的问题,老实说,我有一段时间没有用Makefile了,生疏了。回顾,这几年来大家问题我的问题,其实很多时候是makefile的调试问题。所以,就像我在之前的那篇关于GDB的技巧的文章中做的一样,在这里向大家介绍一个小小的调试变量的技巧。相信一定对你有用。

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

%:
        @echo '$*=$($*)'

d-%:
        @echo '$*=$($*)'
        @echo '  origin = $(origin $*)'
        @echo '   value = $(value  $*)'
        @echo '  flavor = $(flavor $*)'

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

假设我们的makefile是这个样子(test.mk)


OBJDIR := objdir
OBJS := $(addprefix $(OBJDIR)/,foo.o bar.o baz.o)

foo = $(bar)bar = $(ugh)ugh = Huh?

CFLAGS = $(include_dirs) -O
include_dirs = -Ifoo -Ibar
CFLAGS := $(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 -f test.mk -f var.mk d-foo
foo=Huh?
  origin = file
  value = $(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 -f test.mk -f var.mk d-COMPILE.c
COMPILE.c=cc -Ifoo -Ibar -O -Wall   -c
  origin = default
  flavor = recursive
   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表示递归展开的变量。

(全文完)

(转载本站文章请注明作者和出处 酷 壳 – CoolShell.cn ,请勿用于任何商业用途)

——=== 访问 酷壳404页面 寻找遗失儿童。 ===——
分类: C/C++语言, 编程工具 标签: ,
好烂啊有点差凑合看看还不错很精彩 (10 人打了分,平均分: 4.90 )
Loading ... Loading ...
  1. maplesfive
    2011年3月1日11:04 | #1

    忍不住要赞美一下,太实用了

  2. lyuehh
    2011年3月1日15:43 | #2

    恩,相当实用

  3. jruv
    2011年3月1日17:17 | #3

    我火星了,这个网站已经关注了3年了吧, 一直觉的站长的名字很熟悉, 似乎在哪里见过, 现在终于想起来了, 过去学习Makefile就是从你那篇著名的《跟我一起写Makefile》开始的。

  4. 2011年3月1日17:21 | #4

    @jruv
    关注文章就行了。是谁写的并不重要。呵呵。

  5. Noe
    2011年3月1日21:21 | #5

    这篇博文我必须拜一下,太有用了!谢谢博主。

  6. 2011年3月1日22:04 | #6

    不错,都是好的知识

  7. 2011年3月1日23:17 | #7

    非常好的知识,贵站代码高亮显示的插件是什么?我也有一个技术博客,但是里面代码高显的插件都不好用,所以想问下,非常感谢!

  8. 2011年3月2日00:05 | #8

    @eliteYang
    代码高亮插件
    SyntaxHighlighter Evolved

    插件主页:
    http://www.viper007bond.com/wordpress-plugins/syntaxhighlighter/

  9. hackage
    2011年3月2日19:12 | #9

    感谢大哥

  10. dbTech
    2011年3月2日22:31 | #10

    这个很给力,或者make -n也凑合用 :)

  11. tmy13
    2011年3月7日09:12 | #11

    这个强大,一下子觉得可以省掉很多功夫

  12. byte3w
    2011年3月18日11:51 | #12

    信皓哥得永生

  13. dreamer
    2011年3月22日10:59 | #13

    今天又学了一招。。。

  14. skyun
    2011年5月13日14:24 | #14

    博主大牛,能不能讲一下是什么原理啊

  15. 2011年7月11日16:43 | #15

    真的太实用了!节约了我至少一个小时的时间去查阅文档!!

  16. zyymcu
    2011年11月10日15:21 | #16

    我out了 来晚了 不过这个确实屌爆了!

  17. ludi
    2013年2月27日11:58 | #17

    请教: 我的项目里面使用的是默认的文件名makefile, 并且是在顶层目录 make -C subdir 的形式执行。
    那应该怎样使用var.mk 呢?

  18. tzh
    2013年4月17日23:08 | #18

    太实用了~

  19. 2013年6月14日03:44 | #19

    I love what you guys tend to be up too. Such clever work and reporting! Keep up the amazing works guys I’ve included you guys to my own blogroll.

  20. 成都_天空
    2014年3月10日18:05 | #20

    推荐使用 cmake更简单一些

  21. fkxcole
    2014年3月20日17:13 | #21

    你好,在ubuntu13.10环境下测试失败,在home目录下建立test.mk和var.mk两个文本,内容完全复制过来,在shell中输入:
    make -f test.mk -f var.mk OBJS
    输出显示:
    make: *** No rule to make target `OBJS’. Stop.

    我在man make 里也没有看到一行make语句使用两个-f的用法,请问怎么解决? 初学linux,可能问题浅显,望解答。

  1. 2012年1月6日10:00 | #1