14

我有一个 OSX 桌面 Xcode 项目,其中包括另一个 Xcode 项目(一个框架)作为依赖项。当我构建应用程序的存档时,它会生成两个 dSYM 包 - 一个用于应用程序,一个用于框架。

当我表示从应用程序收到的崩溃时,应用程序包中的符号会正确显示(带有文件名和行号)。但是,框架中的符号根本不具有象征意义——它们只是显示框架名称和内存地址。有没有办法表示涉及框架代码的堆栈跟踪部分?

查看我从中生成 .app 包的存档,框架的 dSYM 的 UUID 与复制到 .app 中的“Frameworks”文件夹中的 UUID 不匹配:

归档文件中 .app 包内的 HCCommon 框架:

/path/to/HipChat.xcarchive $ dwarfdump --uuid Products/Applications/HipChat.app/Contents/Frameworks/HCCommon.framework/HCCommon 
UUID: 84891A9C-19DB-3E16-BE7E-9D4056FFFB97 (x86_64) Products/Applications/HipChat.app/Contents/Frameworks/HCCommon.framework/HCCommon

vs HCCommon 框架的 dSYM(在归档文件的 dSYMs 目录中):

/path/to/HipChat.xcarchive $ dwarfdump --uuid dSYMs/HCCommon.framework.dSYM/Contents/Resources/DWARF/HCCommon 
UUID: 767F2D97-9E0B-3C4D-8337-FDF5A9CA2D81 (x86_64) dSYMs/HCCommon.framework.dSYM/Contents/Resources/DWARF/HCCommon
4

2 回答 2

5

我不确定为什么您的构建会导致 dSYM UUID 不一致。当我们进行这些类型的构建时(现在已经抽查了一些),我们有一致的 UUID。

但是,在回答您关于如何在给定您已经拥有的 .dSYM 的情况下表示您已经收到的崩溃报告的问题时(假设目前虽然 UUID 匹配,但它们引用相同的代码,因此可以工作)。

如果您必须强制使用特定的 dsym,我发现以下方法可以很好地工作:

atos -arch x86_64 -o <path_to_dsym_within_package> -l <offset_of_framework>

它当然不那么漂亮,通常我通过 atos 手动运行各个地址,但结果是有效的例程/行组合(假设您匹配正确的版本等)

<path_to_dsym_within_package>引用foo.framework.dSYM/Contents/Resources/DWARF/foo后跟您的二进制名称,其中是foo框架的名称。对我们来说,这也适用于任何类型的插件。

来自崩溃日志中的<offset_of_framework>偏移列,其中:

0 libsystem_kernel.dylib 0x7fff8e785ce2 0x7fff8e76f000 + 93410
1 libsystem_c.dylib 0x7fff871afa7a 0x7fff8716e000 + 268922
2 CTUtils 0x104e26c62 0x104e17000 + 64610

在这种情况下,第一个十六进制数字是地址,第二个十六进制数字是特定框架的起始偏移量,+ 值是框架内的十进制偏移量。

您需要上面命令行的第二个数字(十六进制偏移量),以及第一个数字来查找特定的例程/行号。

在最坏的情况下,总是dwarfdump直接使用,通过使用:

dwarfdump <path_to_dSYM> --arch x86_64 --lookup <offset>

<path_to_dSYM>是顶级“.dSYM”文件夹的路径(与atos上面的命令不同),<offset>是模块内的偏移量,不如atos.

如果您安装了开发工具atos,则应安装PS 。/usr/bin/atos

于 2013-03-07T13:21:37.373 回答
1

我也遇到了这个问题。经过一番调查,事实证明 Xcode 正在将调试框架构建复制到发布构建中,但显然是从正确的发布二进制文件创建 dSYM。

尽管使用 Xcode 从工作区添加框架依赖项,但仍然如此。最终我发现了原因:出于某种原因,这些框架被包含在项目中,它们的位置为“相对于组”。在我确定所有都是“相对于构建产品”之后,它为我解决了这个问题。并不是说这是唯一可能的原因,但值得仔细检查构建日志中的所有路径,因为在这种情况下 Xcode 不会发出任何警告。

在此处输入图像描述

于 2014-02-16T14:35:46.970 回答