我是靠谱客的博主 贪玩小蝴蝶,最近开发中收集的这篇文章主要介绍如何调试makefile变量,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

于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
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
[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变量所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(43)

评论列表共有 0 条评论

立即
投稿
返回
顶部