From 4be005617b3b8c3578cca07c5d085d12916f0d1d Mon Sep 17 00:00:00 2001 From: lclc98 Date: Thu, 30 Jun 2016 00:49:21 +1000 Subject: Json format (#2) * Added new format * Fixed bug * Updated Version --- src/cuchaz/enigma/mapping/MethodMapping.java | 191 --------------------------- 1 file changed, 191 deletions(-) delete mode 100644 src/cuchaz/enigma/mapping/MethodMapping.java (limited to 'src/cuchaz/enigma/mapping/MethodMapping.java') diff --git a/src/cuchaz/enigma/mapping/MethodMapping.java b/src/cuchaz/enigma/mapping/MethodMapping.java deleted file mode 100644 index 055e1fe..0000000 --- a/src/cuchaz/enigma/mapping/MethodMapping.java +++ /dev/null @@ -1,191 +0,0 @@ -/******************************************************************************* - * 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 - * - * Contributors: - * Jeff Martin - initial API and implementation - ******************************************************************************/ -package cuchaz.enigma.mapping; - -import java.io.Serializable; -import java.util.Map; -import java.util.Map.Entry; - -import com.google.common.collect.Maps; - -public class MethodMapping implements Serializable, Comparable, MemberMapping { - - private static final long serialVersionUID = -4409570216084263978L; - - private String m_obfName; - private String m_deobfName; - private Signature m_obfSignature; - private Map m_arguments; - - public MethodMapping(String obfName, Signature obfSignature) { - this(obfName, obfSignature, null); - } - - public MethodMapping(String obfName, Signature obfSignature, String deobfName) { - if (obfName == null) { - throw new IllegalArgumentException("obf name cannot be null!"); - } - if (obfSignature == null) { - throw new IllegalArgumentException("obf signature cannot be null!"); - } - m_obfName = obfName; - m_deobfName = NameValidator.validateMethodName(deobfName); - m_obfSignature = obfSignature; - m_arguments = Maps.newTreeMap(); - } - - public MethodMapping(MethodMapping other, ClassNameReplacer obfClassNameReplacer) { - m_obfName = other.m_obfName; - m_deobfName = other.m_deobfName; - m_obfSignature = new Signature(other.m_obfSignature, obfClassNameReplacer); - m_arguments = Maps.newTreeMap(); - for (Entry entry : other.m_arguments.entrySet()) { - m_arguments.put(entry.getKey(), new ArgumentMapping(entry.getValue())); - } - } - - @Override - public String getObfName() { - return m_obfName; - } - - public void setObfName(String val) { - m_obfName = NameValidator.validateMethodName(val); - } - - public String getDeobfName() { - return m_deobfName; - } - - public void setDeobfName(String val) { - m_deobfName = NameValidator.validateMethodName(val); - } - - public Signature getObfSignature() { - return m_obfSignature; - } - - public void setObfSignature(Signature val) { - m_obfSignature = val; - } - - public Iterable arguments() { - return m_arguments.values(); - } - - public boolean isConstructor() { - return m_obfName.startsWith("<"); - } - - public void addArgumentMapping(ArgumentMapping argumentMapping) { - boolean wasAdded = m_arguments.put(argumentMapping.getIndex(), argumentMapping) == null; - assert (wasAdded); - } - - public String getObfArgumentName(int index) { - ArgumentMapping argumentMapping = m_arguments.get(index); - if (argumentMapping != null) { - return argumentMapping.getName(); - } - - return null; - } - - public String getDeobfArgumentName(int index) { - ArgumentMapping argumentMapping = m_arguments.get(index); - if (argumentMapping != null) { - return argumentMapping.getName(); - } - - return null; - } - - public void setArgumentName(int index, String name) { - ArgumentMapping argumentMapping = m_arguments.get(index); - if (argumentMapping == null) { - argumentMapping = new ArgumentMapping(index, name); - boolean wasAdded = m_arguments.put(index, argumentMapping) == null; - assert (wasAdded); - } else { - argumentMapping.setName(name); - } - } - - public void removeArgumentName(int index) { - boolean wasRemoved = m_arguments.remove(index) != null; - assert (wasRemoved); - } - - @Override - public String toString() { - StringBuilder buf = new StringBuilder(); - buf.append("\t"); - buf.append(m_obfName); - buf.append(" <-> "); - buf.append(m_deobfName); - buf.append("\n"); - buf.append("\t"); - buf.append(m_obfSignature); - buf.append("\n"); - buf.append("\tArguments:\n"); - for (ArgumentMapping argumentMapping : m_arguments.values()) { - buf.append("\t\t"); - buf.append(argumentMapping.getIndex()); - buf.append(" -> "); - buf.append(argumentMapping.getName()); - buf.append("\n"); - } - return buf.toString(); - } - - @Override - public int compareTo(MethodMapping other) { - return (m_obfName + m_obfSignature).compareTo(other.m_obfName + other.m_obfSignature); - } - - public boolean renameObfClass(final String oldObfClassName, final String newObfClassName) { - - // rename obf classes in the signature - Signature newSignature = new Signature(m_obfSignature, new ClassNameReplacer() { - @Override - public String replace(String className) { - if (className.equals(oldObfClassName)) { - return newObfClassName; - } - return null; - } - }); - - if (!newSignature.equals(m_obfSignature)) { - m_obfSignature = newSignature; - return true; - } - return false; - } - - public boolean containsArgument(String name) { - for (ArgumentMapping argumentMapping : m_arguments.values()) { - if (argumentMapping.getName().equals(name)) { - return true; - } - } - return false; - } - - @Override - public BehaviorEntry getObfEntry(ClassEntry classEntry) { - if (isConstructor()) { - return new ConstructorEntry(classEntry, m_obfSignature); - } else { - return new MethodEntry(classEntry, m_obfName, m_obfSignature); - } - } -} -- cgit v1.2.3