从命令行

时间:2016-10-19 14:22:59

标签: android-ndk cmake android-gradle crashlytics-android

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

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

在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来处理我的发布二进制文件。

所以我的问题是:

1)androidNdkOutandroidNdkLibsOut之间的真正区别是什么?为什么我不能在一个路径中放置调试二进制文件的路径以及将二进制文件发布到其他路径?除了解释之外,一个具体的例子会很好。

2)如果有一天我想要为我的调试库包含符号,我应该如何修改我的gradle文件?意思是命令 gradlew crashlyticsUploadSymbolsRelease以及gradlew crashlyticsUploadSymbolsDebug会有效吗?

在帖子Crashlytics NDK symbols and Gradle tasksCrashlytics NDK multi androidNdkOut path support中对此进行了讨论,但他们真的不回答这两个问题。

2 个答案:

答案 0 :(得分:4)

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

为了给出一些上下文 - 我们的符号上传工具基于ndk-build进程,该进程生成两组二进制文件:生产二进制文件,它们被剥离了符号数据,以及调试二进制文件,它们的符号数据完整无缺。调试目的。

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

  • androidNdkOut是默认情况下放置未提取的调试二进制文件(相当于$NDK_OUTndk-build变量)obj的目录。
  • androidNdkLibsOut是默认情况下放置的已剥离的发布二进制文件(相当于$NDK_LIBS_OUTndk-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生成这些相同的二进制集,然后将androidNdkOutandroidNdkLibsOut设置到适当的顶级目录,其中可以找到那些图书馆。

编辑/更新2017年7月7日

我们刚刚发布了适用于Gradle的Fabric插件版本1.23.0,它支持在您使用带有externalNativeBuild DSL的Android Gradle插件2.2.0+时自动解析相应的本机库路径,因此如果您使用的是最新的Android Gradle插件,则无需再设置androidNdkOutandroidNdkLibsOut。点击此处查看更多信息:https://docs.fabric.io/android/crashlytics/ndk.html#specifying-the-path-to-debug-and-release-binaries

答案 1 :(得分:0)

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

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

无论出于何种原因,谷歌都没有向您指出这一点,而且fabric.io文档中似乎也缺少该信息。