5

我想将地图文件添加为资源,然后每次执行系统时提取文件,以确保地图文件始终正确,并使支持的生活更轻松。在 Delphi 7 中,我可以编译项目,将地图文件作为资源,但地图是错误的,因为当引发异常时调用堆栈是错误的。在 Delphi Seattle,我什至无法编译,因为它会在生成地图之前尝试添加资源。我知道我可以在编译后的任务中添加文件,但是有没有办法在编译/构建时做到这一点?抱歉,如果我不是很具体,这是我的第一个问题。谢谢。

更新

在我阅读了一些答案后,我做了一些研究。我已经在我的项目中使用 JEDI 异常单元,但我不知道 JEDI 调试专家。它完全符合我的要求,甚至更多。JEDI 调试专家将 .map 文件转换为 .jdbg 文件,这是一个加密的地图文件(地图只是一个文本文件)。此外,jdbg 文件比地图小约12%。它还具有将 jdbg 插入二进制 (exe)的选项。为此,我启用了以下选项:

  • 项目 -> JCL 调试专家 -> 生成 .jdbg 文件 -> 为此项目启用

  • 项目 -> JCL 调试专家 -> 将 jdbg 数据插入二进制文件 -> 为此项目启用

  • Project -> JCL Debug Expert -> Delete map files after conversion -> Enabled for this project (如果你想删除文件,当然可以)

要在 IDE 之外使用此工具,例如使用 Jenkins,我必须构建JEDI\jcl\examples\windows\debug\tools\MakeJclDbg.dpr中可用的项目。build 后会在 jcl 的 bin 目录下生成 exe 文件。如何使用:

MakeJclDbg -J -E -M map_filename

J - 创建 .JDBG 文件

E - 将调试数据插入可执行文件

M - 转换后删除 MAP 文件

可执行文件必须与 MAP 文件位于同一目录中。这将创建 jdbg 文件(基于地图文件),插入 exe 并删除地图。有了这个(以及 JEDI 的异常单元),当引发异常时,我可以使用堆栈跟踪、系统使用的所有 dll 的版本、操作系统信息等,并将所有这些发送到电子邮件。

我意识到 Embarcadero 也有他们的 bpl 的 jdbg 文件,所以我认为他们也使用 JCL 工具。

4

2 回答 2

2

不,映射文件是程序输出链接后生成的。将尚未生成的地图文件作为资源合并到项目中是不可能的。

于 2016-11-04T23:06:44.483 回答
1

你没有抓住重点。

MAP 文件作为单独的文件生成,以避免增加可执行文件的大小。试图将该文件作为资源重新嵌入到可执行文件中只是违背了目的。

你还没有提到你正在使用什么调试框架。但是还有其他方法可以提供调试信息,我建议您参考您使用的调试框架的文档以了解具体信息。我将只提供一些适用于我尝试过的大多数框架的一般概念。

  • 如果您对增加的 EXE 大小感到满意并希望在可执行文件中包含调试信息:不要使用映射文件选项。只需启用链接选项以包含调试信息。(并确保您的调试框架将使用它。)
  • 大多数调试框架建议在打开堆栈帧的情况下进行编译。这非常重要,因为它使调试框架更容易推断调用堆栈。
  • 一些调试框架具有允许猜测丢失的调用堆栈信息的功能。如果启用,您将需要手动忽略任何实际上没有意义的堆栈条目。
  • 当然,不要忘记任何没有调试信息编译的单元都不会有调试信息包含在最终的可执行文件中。
于 2016-11-04T22:41:48.490 回答