mirror of
https://github.com/revanced/revanced-cli.git
synced 2025-01-22 00:47:32 +01:00
fix: migrate from PatchLoader.load(...)
to JarPatchBundle(...).loadPatches()
Signed-off-by: oSumAtrIX <johan.melkonyan1@web.de>
This commit is contained in:
parent
61235d7c41
commit
cabd32fda4
@ -2,7 +2,7 @@ package app.revanced.cli
|
|||||||
|
|
||||||
import app.revanced.patcher.annotation.Name
|
import app.revanced.patcher.annotation.Name
|
||||||
import app.revanced.patcher.extensions.findAnnotationRecursively
|
import app.revanced.patcher.extensions.findAnnotationRecursively
|
||||||
import app.revanced.patcher.util.patch.PatchLoader
|
import app.revanced.patcher.util.patch.implementation.JarPatchBundle
|
||||||
import app.revanced.utils.adb.Adb
|
import app.revanced.utils.adb.Adb
|
||||||
import app.revanced.utils.patcher.addPatchesFiltered
|
import app.revanced.utils.patcher.addPatchesFiltered
|
||||||
import app.revanced.utils.signature.Signature
|
import app.revanced.utils.signature.Signature
|
||||||
@ -20,7 +20,7 @@ internal object MainCommand : Runnable {
|
|||||||
internal var includedPatches = arrayOf<String>()
|
internal var includedPatches = arrayOf<String>()
|
||||||
|
|
||||||
@Option(names = ["-p", "--patches"], description = ["One or more bundles of patches"])
|
@Option(names = ["-p", "--patches"], description = ["One or more bundles of patches"])
|
||||||
internal var patchBundles = arrayOf<File>()
|
internal var patchBundles = arrayOf<String>()
|
||||||
|
|
||||||
@Option(names = ["-t", "--temp-dir"], description = ["Temporal resource cache directory"], required = true)
|
@Option(names = ["-t", "--temp-dir"], description = ["Temporal resource cache directory"], required = true)
|
||||||
internal lateinit var cacheDirectory: String
|
internal lateinit var cacheDirectory: String
|
||||||
@ -54,8 +54,8 @@ internal object MainCommand : Runnable {
|
|||||||
|
|
||||||
override fun run() {
|
override fun run() {
|
||||||
if (listOnly) {
|
if (listOnly) {
|
||||||
for (patchBundle in patchBundles)
|
for (patchBundlePath in patchBundles)
|
||||||
for (it in PatchLoader.loadFromFile(patchBundle))
|
for (it in JarPatchBundle(patchBundlePath).loadPatches())
|
||||||
println(
|
println(
|
||||||
"[available] ${
|
"[available] ${
|
||||||
it.javaClass.findAnnotationRecursively(
|
it.javaClass.findAnnotationRecursively(
|
||||||
@ -90,7 +90,7 @@ internal object MainCommand : Runnable {
|
|||||||
if (clean) File(cacheDirectory).deleteRecursively()
|
if (clean) File(cacheDirectory).deleteRecursively()
|
||||||
|
|
||||||
adb?.deploy()
|
adb?.deploy()
|
||||||
|
|
||||||
if (clean) outputFile.delete()
|
if (clean) outputFile.delete()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -7,7 +7,7 @@ import app.revanced.patcher.annotation.Name
|
|||||||
import app.revanced.patcher.data.base.Data
|
import app.revanced.patcher.data.base.Data
|
||||||
import app.revanced.patcher.extensions.findAnnotationRecursively
|
import app.revanced.patcher.extensions.findAnnotationRecursively
|
||||||
import app.revanced.patcher.patch.base.Patch
|
import app.revanced.patcher.patch.base.Patch
|
||||||
import app.revanced.patcher.util.patch.PatchLoader
|
import app.revanced.patcher.util.patch.implementation.JarPatchBundle
|
||||||
|
|
||||||
fun Patcher.addPatchesFiltered(
|
fun Patcher.addPatchesFiltered(
|
||||||
packageCompatibilityFilter: Boolean = true,
|
packageCompatibilityFilter: Boolean = true,
|
||||||
@ -19,7 +19,7 @@ fun Patcher.addPatchesFiltered(
|
|||||||
|
|
||||||
MainCommand.patchBundles.forEach { bundle ->
|
MainCommand.patchBundles.forEach { bundle ->
|
||||||
val includedPatches = mutableListOf<Patch<Data>>()
|
val includedPatches = mutableListOf<Patch<Data>>()
|
||||||
PatchLoader.loadFromFile(bundle).forEach patch@{ p ->
|
JarPatchBundle(bundle).loadPatches().forEach patch@{ p ->
|
||||||
val patch = p.getDeclaredConstructor().newInstance()
|
val patch = p.getDeclaredConstructor().newInstance()
|
||||||
|
|
||||||
val compatibilityAnnotation = patch.javaClass.findAnnotationRecursively(Compatibility::class.java)
|
val compatibilityAnnotation = patch.javaClass.findAnnotationRecursively(Compatibility::class.java)
|
||||||
@ -41,13 +41,13 @@ fun Patcher.addPatchesFiltered(
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
for (compatiblePackage in compatibilityAnnotation.compatiblePackages) {
|
compatibilityAnnotation.compatiblePackages.forEach { compatiblePackage ->
|
||||||
if (packageCompatibilityFilter && compatiblePackage.name != packageName) {
|
if (packageCompatibilityFilter && compatiblePackage.name != packageName) {
|
||||||
println("$prefix: Package name not matching ${compatiblePackage.name}.")
|
println("$prefix: Package name not matching ${compatiblePackage.name}.")
|
||||||
return@patch
|
return@patch
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!packageVersionCompatibilityFilter || compatiblePackage.versions.any { it == packageVersion }) continue
|
if (!packageVersionCompatibilityFilter || compatiblePackage.versions.any { it == packageVersion }) return@patch
|
||||||
println("$prefix: Unsupported version.")
|
println("$prefix: Unsupported version.")
|
||||||
return@patch
|
return@patch
|
||||||
}
|
}
|
||||||
@ -61,8 +61,13 @@ fun Patcher.addPatchesFiltered(
|
|||||||
}
|
}
|
||||||
|
|
||||||
fun Patcher.applyPatchesPrint() {
|
fun Patcher.applyPatchesPrint() {
|
||||||
for ((patch, result) in this.applyPatches()) {
|
this.applyPatches().forEach { (patch, result) ->
|
||||||
println("[${if (result.isFailure) "error" else "success"}] $patch")
|
if (result.isSuccess) {
|
||||||
|
println("[success] $patch")
|
||||||
|
return@forEach
|
||||||
|
}
|
||||||
|
println("[error] $patch:")
|
||||||
|
result.exceptionOrNull()!!.printStackTrace()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user