MacOS Xcode 使用LLDB调试Qt的 QString

环境:

  • MacOS: 14.3
  • Xcode: Version 15.0
  • Qt:Qt 6.5.3

前言

Xcode 中显示 预览 QString 特别不方便, 而Qt官方的 lldb 脚本debugger/lldbbridge.py一直加载失败,其他第三方的脚本都 不兼容当前的 环境。所以自己研究写了当前的教程。

当前方法同样适用于其他非 苹果内置类型的预览和显示。

原始效果如下:

优化后的效果:

创建步骤:

  1. 检测 ~/.lldbinit 文件
    判断文件是否存在,不存在则创建。
    每次 lldb 启动都会 加载 ~/.lldbinit 文件的命令,可以理解为存在硬盘里面的默认用户配置。

  2. 创建 python 脚本文件
    在任意路径创建一个python 文件。 我这里创建的python文件的路径为:~/Documents/source/PYTest/lldb_qt_value.py

  3. ~/.lldbinit 写入命令
    这里lldb 在初始化的时候就会导入 这个python文件

    复制代码
    # 加载 lldb 预览 qt 内置成员的 脚本
    command script import '~/Documents/source/PYTest/lldb_qt_value.py'
  4. 回到 lldb_qt_value.py 文件,写具体脚本

python 复制代码
import lldb

def QString_summary(value, internal_dict):
    summary = value.GetChildMemberWithName('d').GetChildMemberWithName('ptr').GetSummary()
    if summary == "Summary Unavailable":
        return "NULL"
    return summary[2:-1]

# lldb 的 默认初始化 函数
def __lldb_init_module(debugger, internal_dict):
    debugger.HandleCommand('type summary add QString -F lldb_qt_value.QString_summary')
    print('lldb_qt_value.py 正在为您服务.')

具体逻辑如下:

  • lldb 初始化调用 __lldb_init_module 函数
  • 创建一个 QString 的钩子函数。函数为 lldb_qt_value 文件的 QString_summary方法。
  • 初始化 会在控制台打印 'lldb_qt_value.py 正在为您服务.'
  • QString 类型被预览时(或者控制台输入 pop 命令) 会进入这个函数QString_summary
  • 获取我们准备替换显示的值, 获取路径为test1 -> d -> ptr -> summary.
    具体对应这个代码 summary = value.GetChildMemberWithName('d').GetChildMemberWithName('ptr').GetSummary()
  • 判断如果是空的 就返回 NULL
  • 不为空则 去除 前面两个字符 u" 和最后 一个 "。 从u"ABC测试" -> ABC测试
  • 返回处理后的值,供lldb 预览显示

结果

QStringstd::vector<QString> 和 其他包含QString的类型都可以正确格式化。

如果需要其他 Qt 类型或者 自定义类型都可以用此方法 显示。

最终脚本预览如下:

参考

https://lldb.llvm.org/use/variable.html
https://lldb.llvm.org/python_api/lldb.SBValue.html

相关推荐
先知后行。几秒前
QT实现计算器
开发语言·qt
掘根1 分钟前
【Qt】常用控件3——显示类控件
开发语言·数据库·qt
GUIQU.7 分钟前
【QT】嵌入式开发:从零开始,让硬件“活”起来的魔法之旅
java·数据库·c++·qt
望获linux7 小时前
【Linux基础知识系列:第一百四十篇】理解SELinux与系统安全
linux·运维·服务器·数据库·chrome·macos
feiyangqingyun8 小时前
基于Qt和FFmpeg的安卓监控模拟器/手机摄像头模拟成onvif和28181设备
android·qt·ffmpeg
奇舞精选10 小时前
CEF框架实践:构建Mac混合桌面应用
macos·浏览器
2501_9275393016 小时前
Permute 媒体文件格式转换【音视频图像文件转换】(Mac电脑)
macos·音视频·媒体·格式转换
xiyangxiaoguo16 小时前
Qt中使用多线程的范式
qt
攻城狮7号18 小时前
【AI时代速通QT】第七节:Visual Studio+Qt 开发指南
c++·qt·跨平台·visual studio·qt vs tools
布拉格沃兹基硕德19 小时前
MacOS报错“zsh: command not found: brew”【已解决】
macos·bug