陈皓的,makefile的调试问题

转载 2012年03月26日 11:05:00

 

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

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

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

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

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

test.mk
1
2
3
4
5
6
7
8
9
10
11
12
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)

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

演示
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
[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表示递归展开的变量。

(全文完)

如何调试makefile

makefile 的调试有点像魔法。可惜,并不存在makefile 调试器之类的东西可用来查看特定规则是如何被求值的,或某个变量是如何被扩展的。相反,大部分的调试过程只是在执行输出的动作以及查看mak...
  • Mevin
  • Mevin
  • 2011年07月19日 23:33
  • 21649

Makefile中的几个调试方法

1,使用info/warning/error增加调试信息 方法1: $(info, "here add the debug info")            但是此不能打印出.mk的行号 方法2...
  • wlqingwei
  • wlqingwei
  • 2015年03月19日 16:22
  • 9629

如何调试makefile + 调试makefile 【转】

makefile 的调试有点像魔法。可惜,并不存在makefile 调试器之类的东西可用来查看特定规则是如何被求值的,或某个变量是如何被扩展的。相反,大部分的调试过程只是在执 行输出的动作以及查看m...
  • dabang_007
  • dabang_007
  • 2014年06月07日 11:04
  • 1371

如何调试makefile + 调试makefile 【转】

makefile 的调试有点像魔法。可惜,并不存在makefile 调试器之类的东西可用来查看特定规则是如何被求值的,或某个变量是如何被扩展的。相反,大部分的调试过程只是在执 行输出的动作以及查看m...
  • dabang_007
  • dabang_007
  • 2014年06月07日 11:04
  • 1371

linux C —— gdb调试、简单Makefile

gcc可以编译c, c++, object-c, java等众多的语言程序 g++则是专注于C和C++。 GDB 调试器是一个功能强大的工具,它可以做很多的调试工作,如断点,单步跟踪等。 相关命...
  • theArcticOcean
  • theArcticOcean
  • 2016年05月27日 22:12
  • 1414

Linux 工程编译调试Makefile及技巧

随着编程语言技术的不断发展,应用程序的开发过程也越来越简化。然而功能越是强大的工具,其内部结构也越复杂。高级编程语言的背后是一套复杂的编译系统。编译系统的任务是把高级语言编写的程序翻译成计算机可以直接...
  • ywgdk
  • ywgdk
  • 2016年04月10日 13:47
  • 1754

Android makefile文件调试方法

最近有一个bug问题,本以为解起来分分钟就可以搞定,却耽误了大半天。借这个机会,记录一下自己的学习心得。这里先来描述一下应用场景。 1.应用场景 isp在调试af时需要将af一些配置文件(xml文件)...
  • armwind
  • armwind
  • 2016年12月01日 20:36
  • 605

linux环境下c++的编写、调试以及makefile多文件连编需要注意的问题

最近刚开始接触Linux C++,发现其与windows C++有太大的差别。这里是自己的一些总结,如果有新人看到,希望能够帮到您。 1、gcc编译器简介 生成一个.out需要将源文件依次进行预处...
  • JKAZAN
  • JKAZAN
  • 2016年08月14日 13:46
  • 551

Linux下调试器GDB、makefile的使用

前面的几篇博客中我们讲解了Linux下的编辑器vim、编译器gcc和g++,今天我们来介绍一下其他常用的三种工具,它们分别是程序调试器:GDB、代码查看器:ctags、还有一个辅助工程的工具:Make...
  • bit_clearoff
  • bit_clearoff
  • 2017年01月01日 19:28
  • 1169

跟陈皓一起学makefile

作者:陈皓     http://blog.csdn.net/haoel/article/details/2886/ 本文转载自:  http://blog.csdn.net/ruglcc/arti...
  • Timekeeperl
  • Timekeeperl
  • 2016年02月14日 09:45
  • 611
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:陈皓的,makefile的调试问题
举报原因:
原因补充:

(最多只允许输入30个字)