aboutsummaryrefslogtreecommitdiff
path: root/src/main/kotlin/com/replaymod/gradle/remap/LorenzExtensions.kt
diff options
context:
space:
mode:
Diffstat (limited to 'src/main/kotlin/com/replaymod/gradle/remap/LorenzExtensions.kt')
-rw-r--r--src/main/kotlin/com/replaymod/gradle/remap/LorenzExtensions.kt14
1 files changed, 14 insertions, 0 deletions
diff --git a/src/main/kotlin/com/replaymod/gradle/remap/LorenzExtensions.kt b/src/main/kotlin/com/replaymod/gradle/remap/LorenzExtensions.kt
index cd04918..4994251 100644
--- a/src/main/kotlin/com/replaymod/gradle/remap/LorenzExtensions.kt
+++ b/src/main/kotlin/com/replaymod/gradle/remap/LorenzExtensions.kt
@@ -7,5 +7,19 @@ import org.cadixdev.lorenz.model.FieldMapping
import org.cadixdev.lorenz.model.MethodMapping
fun MappingSet.findClassMapping(obfuscatedName: String): ClassMapping<*, *>? = getClassMapping(obfuscatedName).orElse(null)
+
+// Find an inner class mapping with obfuscatedName in form of package.Outer.Inner
+// see https://github.com/ReplayMod/remap/issues/3
+fun MappingSet.findPotentialInnerClassMapping(obfuscatedName: String): ClassMapping<*, *>? {
+ val idx = obfuscatedName.lastIndexOf('.')
+ if (idx < 0) {
+ return findClassMapping(obfuscatedName)
+ }
+ val outerName = obfuscatedName.substring(0, idx)
+ val innerName = obfuscatedName.substring(idx + 1)
+ val outer = findPotentialInnerClassMapping(outerName) ?: return findClassMapping(obfuscatedName)
+ return outer.getInnerClassMapping(innerName).orElse(null)
+}
+
fun ClassMapping<*, *>.findFieldMapping(obfuscatedName: String): FieldMapping? = getFieldMapping(obfuscatedName).orElse(null)
fun ClassMapping<*, *>.findMethodMapping(signature: MethodSignature): MethodMapping? = getMethodMapping(signature).orElse(null)