假设我有 3 个子项目(模块):
:libraryA
:libraryB
:app
:app
取决于:libraryA
和:libraryB
。在我的图书馆中,我有:
// libraryA
com.example.libraryA.Class1
// libraryB
com.example.libraryB.Class2
当我在这两个库上运行 R8(如 proguard)时,它们会生成以下类:
// libraryA - Class1
a.a.a.a
// libraryB - Class2
a.a.a.a
(note that 2 different classes end up having the same signature)
当我构建一个使用:libraryA
和:libraryB
的混淆.aar
的:app
变体时,我得到以下构建失败:
Caused by: com.android.tools.r8.utils.b: Type a.a.a.a is defined multiple times:
一种解决方案是在我的库保护规则中使用-keeppackagenames
-keeppackagenames com.example.**
但我想实际混淆包名称。我在这里有什么选择?
是否可以在唯一但确定的基础上对包名称进行模糊处理?例如,我希望发生以下情况:
com.example.libraryA
->a.a.a
com.example.libraryB
->a.a.b
这将避免任何潜在的冲突。这样的事情可以实现吗?
当你用 R8 打包库进行分发时,你必须使用-keeppackagenames
,否则库的消费者可能会得到重复的类。
有选项-flattenpackagehierarchy
和-repackageclasses
来控制非保留类的去向。对于 R8 库本身,我们同时使用两者。
但是,当您构建使用库的最终应用时,包括库在内的所有应用都将作为一个整体进行模糊处理,因此在用作依赖项时不必对库进行模糊处理。