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 --- .../enigma/analysis/BehaviorReferenceTreeNode.java | 93 ---------------------- 1 file changed, 93 deletions(-) delete mode 100644 src/cuchaz/enigma/analysis/BehaviorReferenceTreeNode.java (limited to 'src/cuchaz/enigma/analysis/BehaviorReferenceTreeNode.java') diff --git a/src/cuchaz/enigma/analysis/BehaviorReferenceTreeNode.java b/src/cuchaz/enigma/analysis/BehaviorReferenceTreeNode.java deleted file mode 100644 index 353a4bf..0000000 --- a/src/cuchaz/enigma/analysis/BehaviorReferenceTreeNode.java +++ /dev/null @@ -1,93 +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.analysis; - -import java.util.Set; - -import javax.swing.tree.DefaultMutableTreeNode; -import javax.swing.tree.TreeNode; - -import com.google.common.collect.Sets; - -import cuchaz.enigma.mapping.BehaviorEntry; -import cuchaz.enigma.mapping.Entry; -import cuchaz.enigma.mapping.Translator; - -public class BehaviorReferenceTreeNode extends DefaultMutableTreeNode implements ReferenceTreeNode { - - private static final long serialVersionUID = -3658163700783307520L; - - private Translator m_deobfuscatingTranslator; - private BehaviorEntry m_entry; - private EntryReference m_reference; - private Access m_access; - - public BehaviorReferenceTreeNode(Translator deobfuscatingTranslator, BehaviorEntry entry) { - m_deobfuscatingTranslator = deobfuscatingTranslator; - m_entry = entry; - m_reference = null; - } - - public BehaviorReferenceTreeNode(Translator deobfuscatingTranslator, EntryReference reference, Access access) { - m_deobfuscatingTranslator = deobfuscatingTranslator; - m_entry = reference.entry; - m_reference = reference; - m_access = access; - } - - @Override - public BehaviorEntry getEntry() { - return m_entry; - } - - @Override - public EntryReference getReference() { - return m_reference; - } - - @Override - public String toString() { - if (m_reference != null) { - return String.format("%s (%s)", m_deobfuscatingTranslator.translateEntry(m_reference.context), m_access); - } - return m_deobfuscatingTranslator.translateEntry(m_entry).toString(); - } - - public void load(JarIndex index, boolean recurse) { - // get all the child nodes - for (EntryReference reference : index.getBehaviorReferences(m_entry)) { - add(new BehaviorReferenceTreeNode(m_deobfuscatingTranslator, reference, index.getAccess(m_entry))); - } - - if (recurse && children != null) { - for (Object child : children) { - if (child instanceof BehaviorReferenceTreeNode) { - BehaviorReferenceTreeNode node = (BehaviorReferenceTreeNode)child; - - // don't recurse into ancestor - Set ancestors = Sets.newHashSet(); - TreeNode n = (TreeNode)node; - while (n.getParent() != null) { - n = n.getParent(); - if (n instanceof BehaviorReferenceTreeNode) { - ancestors.add( ((BehaviorReferenceTreeNode)n).getEntry()); - } - } - if (ancestors.contains(node.getEntry())) { - continue; - } - - node.load(index, true); - } - } - } - } -} -- cgit v1.2.3