7

我正在尝试将 Crashlytics 支持添加到我的 Android 项目中,该项目使用 NDK 和 gradle CMake。这意味着我的共享项目需要符号。因此,如果我想为发布构建创建符号,我会调用gradlew crashlyticsUploadSymbolsRelease

https://docs.fabric.io/android/crashlytics/ndk.html中的官方文档说符号生成和上传过程假定标准项目结构:src/main/obj 用于调试二进制文件,src/main/libs用于 ndk-build 生成的发布二进制文件。

在 gradle 文件中,这意味着一个新块,如下所示:

crashlytics {
    enableNdk true
    androidNdkOut 'src/main/obj'
    androidNdkLibsOut 'src/main/libs'
}

因为我使用 gradle CMake 集成来构建我的本机库,所以默认路径当然不起作用。我在发布模式下的本机库被构建到一个build/intermediates/cmake/release/obj目录中,在调试模式下它们进入build/intermediates/cmake/debug/obj目录。

通过反复试验,我发现如果我想让我的发布版本正常工作,我必须将发布模式本机库的路径放入两行,如下图所示。

crashlytics {
    enableNdk true
    androidNdkOut 'build/intermediates/cmake/release/obj'
    androidNdkLibsOut 'build/intermediates/cmake/release/obj'
}

我真的不明白androidNdkOutandroidNdkLibsOut变量之间的区别,因为至少在我的场景中它们指向同一个目录。幸运的是,这对我来说不是问题,因为我只需要 Crashlytics 来处理我的发布二进制文件。

所以我的问题是:

androidNdkOut1)和之间的真正区别是什么androidNdkLibsOut?为什么我不能将调试二进制文件的路径放在一个和将二进制文件发布到另一个的路径?除了解释之外,一个具体的例子会很好。

2)如果有一天我想为我的调试库包含符号,我应该如何修改我的 gradle 文件?这意味着该命令 gradlew crashlyticsUploadSymbolsRelease以及gradlew crashlyticsUploadSymbolsDebug将起作用吗?

在线程Crashlytics NDK symbols and Gradle tasksCrashlytics NDK multi androidNdkOut path support中对此进行了讨论,但他们确实没有回答这两个问题。

4

2 回答 2

6

我在维护 Crashlytics NDK 支持的 Fabric 团队工作。

提供一些上下文 - 我们的符号上传工具基于ndk-build生成 2 组二进制文件的过程:您的生产二进制文件,它们被剥离了符号数据,以及调试二进制文件,它们具有完整的符号数据以用于调试目的。

Gradle 属性映射到ndk-build进程中的变量,具体而言:

  • androidNdkOut是放置未剥离的调试二进制文件的目录(相当于$NDK_OUT变量 in ndk-build),默认调用obj
  • androidNdkLibsOut是放置已剥离的发布二进制文件的目录(相当于$NDK_LIBS_OUT变量 in ndk-build),默认调用libs

这些路径的预期内容是库的特定于体系结构的目录,例如:

obj/
  — armeabi
    — lib1.so
    — lib2.so
  — x86
    — lib1.so
    — lib2.so

libs/
  — armeabi
    — lib1.so
    — lib2.so
  — x86
    — lib1.so
    — lib2.so

要使我们的符号上传正常工作,您需要做的就是从 CMake 生成这些相同的二进制文件集,然后将您的androidNdkOut和设置androidNdkLibsOut到可以找到这些库的适当顶级目录。

编辑/更新 2017 年 7 月 7 日

我们刚刚发布了用于 Gradle 的 Fabric 插件 1.23.0 版本,当您使用带有 DSL 的 Android Gradle 插件 2.2.0+ 时,它支持自动解析适当的原生库路径,externalNativeBuild因此您不再需要设置if您正在使用最新的 Android Gradle 插件。在此处查看更多信息:https ://docs.fabric.io/android/crashlytics/ndk.html#specifying-the-path-to-debug-and-release-binariesandroidNdkOutandroidNdkLibsOut

于 2016-10-24T16:59:53.717 回答
0

如果 mWillis 提到的自动检测对您不起作用,请检查隐藏的日志文件:

~/.crashlytics/com.crashlytics.tools/crashlytics.log

无论出于何种原因,谷歌都没有指出这一点,fabric.io 文档中似乎也缺少它。

于 2019-02-27T16:46:57.760 回答