diff options
Diffstat (limited to 'src/main/kotlin/com/replaymod/gradle/remap/LorenzExtensions.kt')
-rw-r--r-- | src/main/kotlin/com/replaymod/gradle/remap/LorenzExtensions.kt | 14 |
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) |