mirror of
https://github.com/revanced/revanced-cli.git
synced 2025-04-30 06:34:29 +02:00
81 lines
3.1 KiB
Kotlin
81 lines
3.1 KiB
Kotlin
package app.revanced.utils.patcher
|
|
|
|
import app.revanced.cli.command.MainCommand
|
|
import app.revanced.cli.command.MainCommand.args
|
|
import app.revanced.cli.command.MainCommand.logger
|
|
import app.revanced.patcher.Patcher
|
|
import app.revanced.patcher.data.base.Data
|
|
import app.revanced.patcher.extensions.PatchExtensions.compatiblePackages
|
|
import app.revanced.patcher.extensions.PatchExtensions.include
|
|
import app.revanced.patcher.extensions.PatchExtensions.patchName
|
|
import app.revanced.patcher.patch.base.Patch
|
|
import app.revanced.patcher.util.patch.implementation.JarPatchBundle
|
|
|
|
fun Patcher.addPatchesFiltered(
|
|
excludePatches: Boolean = false
|
|
) {
|
|
val packageName = this.data.packageMetadata.packageName
|
|
val packageVersion = this.data.packageMetadata.packageVersion
|
|
|
|
args.patchBundles.forEach { bundle ->
|
|
val includedPatches = mutableListOf<Class<out Patch<Data>>>()
|
|
JarPatchBundle(bundle).loadPatches().forEach patch@{ patch ->
|
|
val compatiblePackages = patch.compatiblePackages
|
|
val patchName = patch.patchName
|
|
|
|
val prefix = "Skipping $patchName"
|
|
|
|
val args = MainCommand.args.pArgs!!
|
|
|
|
if (excludePatches && args.excludedPatches.contains(patchName)) {
|
|
logger.info("$prefix: Explicitly excluded")
|
|
return@patch
|
|
} else if (!patch.include) {
|
|
logger.info("$prefix: Explicitly excluded")
|
|
return@patch
|
|
}
|
|
|
|
if (compatiblePackages == null) logger.warn("$prefix: Missing compatibility annotation. Continuing.")
|
|
else {
|
|
if (!compatiblePackages.any { it.name == packageName }) {
|
|
logger.warn("$prefix: Incompatible with $packageName. This patch is only compatible with ${
|
|
compatiblePackages.joinToString(
|
|
", "
|
|
) { it.name }
|
|
}")
|
|
return@patch
|
|
}
|
|
|
|
if (!(args.experimental || compatiblePackages.any { it.versions.isEmpty() || it.versions.any { version -> version == packageVersion } })) {
|
|
val compatibleWith = compatiblePackages.map { _package ->
|
|
"${_package.name}: ${_package.versions.joinToString(", ")}"
|
|
}.joinToString(";")
|
|
logger.warn("$prefix: Incompatible with version $packageVersion. This patch is only compatible with version $compatibleWith")
|
|
return@patch
|
|
}
|
|
}
|
|
|
|
logger.trace("Adding $patchName")
|
|
includedPatches.add(patch)
|
|
}
|
|
this.addPatches(includedPatches)
|
|
}
|
|
}
|
|
|
|
fun Patcher.applyPatchesVerbose() {
|
|
this.applyPatches().forEach { (patch, result) ->
|
|
if (result.isSuccess) {
|
|
logger.info("$patch succeeded")
|
|
return@forEach
|
|
}
|
|
logger.error("$patch failed:")
|
|
result.exceptionOrNull()!!.printStackTrace()
|
|
}
|
|
}
|
|
|
|
fun Patcher.mergeFiles() {
|
|
this.addFiles(args.pArgs!!.mergeFiles) { file ->
|
|
logger.info("Merging $file")
|
|
}
|
|
}
|