1
mirror of https://github.com/revanced/revanced-patcher synced 2024-11-24 05:16:22 +01:00

add: addFiles method to merge additional dex containers

This commit is contained in:
oSumAtrIX 2022-04-09 04:51:31 +02:00
parent 3144ec872a
commit 08253ee010
No known key found for this signature in database
GPG Key ID: A9B3094ACDB604B4

View File

@ -36,7 +36,24 @@ class Patcher(
opcodes = dexFile.opcodes
cache = Cache(dexFile.classes.toMutableSet(), SignatureResolver(dexFile.classes, signatures).resolve())
}
/**
* Add additional dex file container to the patcher.
* @param files The dex file containers to add to the patcher.
* @param throwOnDuplicates If this is set to true, the patcher will throw an exception if a duplicate class has been found.
*/
fun addFiles(vararg files: File, throwOnDuplicates: Boolean = false) {
for (file in files) {
val dexFile = MultiDexIO.readDexFile(true, files[0], NAMER, null, null)
for (classDef in dexFile.classes) {
if (cache.classes.any { it.type == classDef.type }) {
// TODO: Use logger and warn about duplicate classes
if (throwOnDuplicates)
throw Exception("Class ${classDef.type} has already been added to the patcher.")
}
cache.classes.add(classDef)
}
}
}
/**
* Save the patched dex file.
*/