首页 > 解决方案 > 如何使用 Swift 在 LLDB 中打印等效的 #line #file #function?

问题描述

在源代码中,如果我这样做:

print("\(#file) \(#line) \(#function)")

我得到如下输出:

MyFile.swift 31 doFoo()

但是,从 LLDB 中的断点开始,如果我执行类似操作:

(lldb) po "\(#file) \(#function) \(#line)"

我得到:

"<EXPR> $__lldb_expr(_:) 6"

有没有办法从后者获得像前者一样的输出?我知道你可以这样做:

(lldb) frame info
frame #0: 0x0000000102d92c46 MyApp `closure #2 in Client.fetchCart($0=(error_instance = 0x0000600000810be0 -> 0x0000000108e88cc0 (void *)0x0000000108e88ce8: __SwiftNativeNSError)) at Client+Cart.swift:21:23

...但是输出非常混乱。有没有办法把它清理成文件、行和函数?

标签: swiftlldb

解决方案


您可以设置自定义格式来显示框架信息。对于您想要的,您可以执行以下操作:

settings set frame-format "${line.file.basename} ${line.number} ${function.name-without-args}\n"

然后尝试frame info。你会得到类似的东西:

AppDelegate.swift 11 AppDelegate.application(_:didFinishLaunchingWithOptions:)

您可以按照此答案永久设置此设置。


推荐阅读