Java tutorial
/******************************************************************************* * Copyright (c) 2015 Jeff Martin. * All rights reserved. This program and the accompanying materials * are made available under the terms of the GNU Lesser General Public * License v3.0 which accompanies this distribution, and is available at * http://www.gnu.org/licenses/lgpl.html * <p> * Contributors: * Jeff Martin - initial API and implementation ******************************************************************************/ package cuchaz.enigma.analysis; import com.google.common.collect.Lists; import com.google.common.collect.Multimap; import com.google.common.collect.Sets; import cuchaz.enigma.mapping.*; import cuchaz.enigma.mapping.entry.*; import java.util.AbstractMap; import java.util.List; import java.util.Map; import java.util.Set; public class EntryRenamer { public static <T> void renameClassesInSet(Map<String, String> renames, Set<T> set) { List<T> entries = Lists.newArrayList(); for (T val : set) { entries.add(renameClassesInThing(renames, val)); } set.clear(); set.addAll(entries); } public static <Key, Val> void renameClassesInMap(Map<String, String> renames, Map<Key, Val> map) { // for each key/value pair... Set<Map.Entry<Key, Val>> entriesToAdd = Sets.newHashSet(); for (Map.Entry<Key, Val> entry : map.entrySet()) { entriesToAdd.add(new AbstractMap.SimpleEntry<>(renameClassesInThing(renames, entry.getKey()), renameClassesInThing(renames, entry.getValue()))); } map.clear(); for (Map.Entry<Key, Val> entry : entriesToAdd) { map.put(entry.getKey(), entry.getValue()); } } public static <Key, Val> void renameClassesInMultimap(Map<String, String> renames, Multimap<Key, Val> map) { // for each key/value pair... Set<Map.Entry<Key, Val>> entriesToAdd = Sets.newHashSet(); for (Map.Entry<Key, Val> entry : map.entries()) { entriesToAdd.add(new AbstractMap.SimpleEntry<>(renameClassesInThing(renames, entry.getKey()), renameClassesInThing(renames, entry.getValue()))); } map.clear(); for (Map.Entry<Key, Val> entry : entriesToAdd) { map.put(entry.getKey(), entry.getValue()); } } public static <Key, Val> void renameMethodsInMultimap(Map<MethodEntry, MethodEntry> renames, Multimap<Key, Val> map) { // for each key/value pair... Set<Map.Entry<Key, Val>> entriesToAdd = Sets.newHashSet(); for (Map.Entry<Key, Val> entry : map.entries()) { entriesToAdd.add(new AbstractMap.SimpleEntry<>(renameMethodsInThing(renames, entry.getKey()), renameMethodsInThing(renames, entry.getValue()))); } map.clear(); for (Map.Entry<Key, Val> entry : entriesToAdd) { map.put(entry.getKey(), entry.getValue()); } } public static <Key, Val> void renameMethodsInMap(Map<MethodEntry, MethodEntry> renames, Map<Key, Val> map) { // for each key/value pair... Set<Map.Entry<Key, Val>> entriesToAdd = Sets.newHashSet(); for (Map.Entry<Key, Val> entry : map.entrySet()) { entriesToAdd.add(new AbstractMap.SimpleEntry<>(renameMethodsInThing(renames, entry.getKey()), renameMethodsInThing(renames, entry.getValue()))); } map.clear(); for (Map.Entry<Key, Val> entry : entriesToAdd) { map.put(entry.getKey(), entry.getValue()); } } @SuppressWarnings("unchecked") public static <T> T renameMethodsInThing(Map<MethodEntry, MethodEntry> renames, T thing) { if (thing instanceof MethodEntry) { MethodEntry methodEntry = (MethodEntry) thing; MethodEntry newMethodEntry = renames.get(methodEntry); if (newMethodEntry != null) { return (T) new MethodEntry(methodEntry.getOwnerClassEntry(), newMethodEntry.getName(), methodEntry.getDesc()); } return thing; } else if (thing instanceof LocalVariableEntry) { LocalVariableEntry variableEntry = (LocalVariableEntry) thing; return (T) new LocalVariableEntry(renameMethodsInThing(renames, variableEntry.getOwnerEntry()), variableEntry.getIndex(), variableEntry.getName()); } else if (thing instanceof EntryReference) { EntryReference<Entry, Entry> reference = (EntryReference<Entry, Entry>) thing; reference.entry = renameMethodsInThing(renames, reference.entry); reference.context = renameMethodsInThing(renames, reference.context); return thing; } return thing; } @SuppressWarnings("unchecked") public static <T> T renameClassesInThing(final Map<String, String> renames, T thing) { if (thing instanceof String) { String stringEntry = (String) thing; if (renames.containsKey(stringEntry)) { return (T) renames.get(stringEntry); } } else if (thing instanceof ClassEntry) { ClassEntry classEntry = (ClassEntry) thing; return (T) new ClassEntry(renameClassesInThing(renames, classEntry.getClassName())); } else if (thing instanceof FieldDefEntry) { FieldDefEntry fieldEntry = (FieldDefEntry) thing; return (T) new FieldDefEntry(renameClassesInThing(renames, fieldEntry.getOwnerClassEntry()), fieldEntry.getName(), renameClassesInThing(renames, fieldEntry.getDesc()), renameClassesInThing(renames, fieldEntry.getSignature()), fieldEntry.getAccess()); } else if (thing instanceof MethodDefEntry) { MethodDefEntry methodEntry = (MethodDefEntry) thing; return (T) new MethodDefEntry(renameClassesInThing(renames, methodEntry.getOwnerClassEntry()), methodEntry.getName(), renameClassesInThing(renames, methodEntry.getDesc()), renameClassesInThing(renames, methodEntry.getSignature()), methodEntry.getAccess()); } else if (thing instanceof MethodEntry) { MethodEntry methodEntry = (MethodEntry) thing; return (T) new MethodEntry(renameClassesInThing(renames, methodEntry.getOwnerClassEntry()), methodEntry.getName(), renameClassesInThing(renames, methodEntry.getDesc())); } else if (thing instanceof LocalVariableEntry) { LocalVariableEntry argumentEntry = (LocalVariableEntry) thing; return (T) new LocalVariableEntry(renameClassesInThing(renames, argumentEntry.getOwnerEntry()), argumentEntry.getIndex(), argumentEntry.getName()); } else if (thing instanceof EntryReference) { EntryReference<Entry, Entry> reference = (EntryReference<Entry, Entry>) thing; reference.entry = renameClassesInThing(renames, reference.entry); reference.context = renameClassesInThing(renames, reference.context); return thing; } else if (thing instanceof MethodDescriptor) { return (T) ((MethodDescriptor) thing).remap(className -> renameClassesInThing(renames, className)); } else if (thing instanceof TypeDescriptor) { return (T) ((TypeDescriptor) thing).remap(className -> renameClassesInThing(renames, className)); } else if (thing instanceof Signature) { return (T) ((Signature) thing).remap(className -> renameClassesInThing(renames, className)); } return thing; } }