zoukankan      html  css  js  c++  java
  • 如何调试makefile变量

    六、七年前写过一篇《跟我一起写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
    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表示递归展开的变量。
  • 相关阅读:
    12.7 Test
    51Nod.1766.树上最远点对(树的直径 RMQ 线段树/ST表)
    BZOJ.3675.[APIO2014]序列分割(DP 斜率优化)
    BZOJ.4515.[SDOI2016]游戏(树链剖分 李超线段树)
    BZOJ.3165.[HEOI2013]Segment(李超线段树)
    Linux系统CentOS进入单用户模式和救援模式详解
    KVM 管理界面挂载多UKEY
    挂载银行前置机Ukey到windows server2012虚拟机的操作记录
    为什么服务器做了raid 系统文件还会丢失?
    LVS+Keepalived深度理解,阐述你不知道的坑点
  • 原文地址:https://www.cnblogs.com/alantu2018/p/8503715.html
Copyright © 2011-2022 走看看