/******************************************************************************* * Copyright (c) 2014 Jeff Martin. * All rights reserved. This program and the accompanying materials * are made available under the terms of the GNU Public License v3.0 * which accompanies this distribution, and is available at * http://www.gnu.org/licenses/gpl.html * * Contributors: * Jeff Martin - initial API and implementation ******************************************************************************/ package cuchaz.enigma.analysis; import javax.swing.tree.DefaultMutableTreeNode; import cuchaz.enigma.mapping.BehaviorEntry; import cuchaz.enigma.mapping.FieldEntry; import cuchaz.enigma.mapping.Translator; public class FieldReferenceTreeNode extends DefaultMutableTreeNode implements ReferenceTreeNode { private static final long serialVersionUID = -7934108091928699835L; private Translator m_deobfuscatingTranslator; private FieldEntry m_entry; private EntryReference m_reference; private Access m_access; public FieldReferenceTreeNode(Translator deobfuscatingTranslator, FieldEntry entry) { m_deobfuscatingTranslator = deobfuscatingTranslator; m_entry = entry; m_reference = null; } private FieldReferenceTreeNode(Translator deobfuscatingTranslator, EntryReference reference, Access access) { m_deobfuscatingTranslator = deobfuscatingTranslator; m_entry = reference.entry; m_reference = reference; m_access = access; } @Override public FieldEntry 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 if (m_reference == null) { for (EntryReference reference : index.getFieldReferences(m_entry)) { add(new FieldReferenceTreeNode(m_deobfuscatingTranslator, reference, index.getAccess(m_entry))); } } else { for (EntryReference reference : index.getBehaviorReferences(m_reference.context)) { add(new BehaviorReferenceTreeNode(m_deobfuscatingTranslator, reference, index.getAccess(m_reference.context))); } } if (recurse && children != null) { for (Object node : children) { if (node instanceof BehaviorReferenceTreeNode) { ((BehaviorReferenceTreeNode)node).load(index, true); } else if (node instanceof FieldReferenceTreeNode) { ((FieldReferenceTreeNode)node).load(index, true); } } } } }