fix(YouTube): Change fingerprints to support a wider range of target versions

This commit is contained in:
LisoUseInAIKyrios 2024-12-21 12:55:18 +04:00
parent 979565e7b5
commit 8a09174def
2 changed files with 43 additions and 54 deletions

View File

@ -15,22 +15,16 @@ internal val onBackPressedFingerprint = fingerprint {
} }
} }
internal val recyclerViewScrollingFingerprint = fingerprint { internal val scrollPositionFingerprint = fingerprint {
accessFlags(AccessFlags.PRIVATE, AccessFlags.FINAL) accessFlags(AccessFlags.PROTECTED, AccessFlags.FINAL)
returns("V") returns("V")
parameters() parameters("L")
opcodes( opcodes(
Opcode.IGET_OBJECT, Opcode.IF_NEZ,
Opcode.IGET_OBJECT, Opcode.INVOKE_DIRECT,
Opcode.IF_EQZ, Opcode.RETURN_VOID
Opcode.IGET_OBJECT,
Opcode.CHECK_CAST,
Opcode.INVOKE_VIRTUAL,
Opcode.MOVE_RESULT,
Opcode.IF_LEZ,
Opcode.IGET_OBJECT,
Opcode.CONST_4,
) )
strings("scroll_position")
} }
internal val recyclerViewTopScrollingFingerprint = fingerprint { internal val recyclerViewTopScrollingFingerprint = fingerprint {

View File

@ -1,54 +1,49 @@
package app.revanced.patches.youtube.misc.fix.backtoexitgesture package app.revanced.patches.youtube.misc.fix.backtoexitgesture
import app.revanced.patcher.Fingerprint
import app.revanced.patcher.extensions.InstructionExtensions.addInstruction import app.revanced.patcher.extensions.InstructionExtensions.addInstruction
import app.revanced.patcher.patch.bytecodePatch import app.revanced.patcher.patch.bytecodePatch
import app.revanced.util.getReference
import app.revanced.util.indexOfFirstInstructionOrThrow
import com.android.tools.smali.dexlib2.Opcode
import com.android.tools.smali.dexlib2.iface.reference.MethodReference
private const val EXTENSION_CLASS_DESCRIPTOR = "Lapp/revanced/extension/youtube/patches/FixBackToExitGesturePatch;"
internal val fixBackToExitGesturePatch = bytecodePatch( internal val fixBackToExitGesturePatch = bytecodePatch(
description = "Fixes the swipe back to exit gesture.", description = "Fixes the swipe back to exit gesture.",
) { ) {
execute { execute {
/** recyclerViewTopScrollingFingerprint.match(recyclerViewTopScrollingParentFingerprint.originalClassDef)
* Inject a call to a method from the extension. .let {
* it.method.addInstruction(
* @param targetMethod The target method to call. it.patternMatch!!.endIndex,
*/ "invoke-static { }, $EXTENSION_CLASS_DESCRIPTOR->onTopView()V"
fun Fingerprint.injectCall(targetMethod: ExtensionMethod) = method.addInstruction(
patternMatch!!.endIndex,
targetMethod.toString(),
) )
}
mapOf( scrollPositionFingerprint.let {
recyclerViewTopScrollingFingerprint.also { navigate(it.originalMethod)
it.match(recyclerViewTopScrollingParentFingerprint.originalClassDef) .to(it.patternMatch!!.startIndex + 1)
} to ExtensionMethod( .stop().apply {
methodName = "onTopView", val index = indexOfFirstInstructionOrThrow {
), opcode == Opcode.INVOKE_VIRTUAL && getReference<MethodReference>()?.definingClass ==
recyclerViewScrollingFingerprint to ExtensionMethod( "Landroid/support/v7/widget/RecyclerView;"
methodName = "onScrollingViews", }
),
onBackPressedFingerprint to ExtensionMethod( addInstruction(
"p0", index,
"onBackPressed", "invoke-static { }, $EXTENSION_CLASS_DESCRIPTOR->onScrollingViews()V"
"Landroid/app/Activity;", )
), }
).forEach { (fingerprint, target) -> fingerprint.injectCall(target) }
}
onBackPressedFingerprint.let {
it.method.addInstruction(
it.patternMatch!!.endIndex,
"invoke-static { p0 }, $EXTENSION_CLASS_DESCRIPTOR->onBackPressed(Landroid/app/Activity;)V"
)
}
} }
} }
/**
* A reference to a method from the extension for [fixBackToExitGesturePatch].
*
* @param register The method registers.
* @param methodName The method name.
* @param parameterTypes The parameters of the method.
*/
private class ExtensionMethod(
val register: String = "",
val methodName: String,
val parameterTypes: String = "",
) {
override fun toString() =
"invoke-static {$register}, Lapp/revanced/extension/youtube/patches/FixBackToExitGesturePatch;->$methodName($parameterTypes)V"
}