首页 > 解决方案 > 如何使用 lldb 将数据成员 char 数组漂亮地打印为字符串(如在 boost::static_string 中)?

问题描述

我正在尝试为 Boostsstatic_string类模板定义自定义摘要。示例源文件:

#include <boost/static_string/static_string.hpp>

const boost::static_string<5> s{"abc"};

没有任何格式化程序,frame variable -R s给我

(boost::static_strings::static_string<5>) s = {
  boost::static_strings::detail::static_string_base<5, char, std::__1::char_traits<char> > = {
    size_ = '\x03'
    data_ = {
      [0] = 'a'
      [1] = 'b'
      [2] = 'c'
      [3] = '\0'
      [4] = '\0'
      [5] = '\0'
    }
  }
}

我非常接近零终止 C 字符串的内置格式,即frame variable -f s &s.data_

(boost::static_strings::detail::static_string_base<...>::value_type (*)[6]) &data_ = "abc"

但试图自动化

type summary add -x "^boost::static_strings::static_string<.+>$" --summary "${&var.data_%s}"

不起作用(也尝试过"${var.&data_%s}") - 无法解析自定义格式字符串。根据文档,间接*var使用特殊var占位符,但&似乎不起作用(文档中也没有提到它,所以这是一个疯狂的猜测)。

标签: boostlldb

解决方案


python API 可以在这里提供帮助。对于摘要字符串,您可以注册一个返回所需输出的自定义 python 函数。这个函数接受一个实例SBValue(和一些你不应该接触的内部字典)。示范boost.py

import lldb

def staticStringSummary(valobj, unused):
    data = valobj.GetChildMemberWithName('data_')
    err = lldb.SBError()
    string = data.GetData().GetString(err, 0)
    return string

def __lldb_init_module(debugger, internalDict):
    debugger.HandleCommand('type summary add -x "^boost::static_strings::static_string<.+>$" -F boost.staticStringSummary')

如果您将上述文件加载到(可能是本地项目).lldbinit

command script import path/to/boost.py

对于上面的例子,fr v将产生

(boost::static_strings::static_string<5>) s = abc

请注意,Boost 的static_string类确保末尾总是有一个零字节,从而确保此解决方案有效。不过,不确定这是否是最好的方法(我在提出问题时提出了它)。


推荐阅读