From cc74d0e62cfdcf14c5918234f69d587d264807ed Mon Sep 17 00:00:00 2001 From: jeff Date: Wed, 13 Aug 2014 00:22:12 -0400 Subject: added support for field access searches added proper detection/handling for constructors --- src/cuchaz/enigma/analysis/FieldCallsTreeNode.java | 82 ++++++++++++++++++++++ 1 file changed, 82 insertions(+) create mode 100644 src/cuchaz/enigma/analysis/FieldCallsTreeNode.java (limited to 'src/cuchaz/enigma/analysis/FieldCallsTreeNode.java') diff --git a/src/cuchaz/enigma/analysis/FieldCallsTreeNode.java b/src/cuchaz/enigma/analysis/FieldCallsTreeNode.java new file mode 100644 index 0000000..0427b3b --- /dev/null +++ b/src/cuchaz/enigma/analysis/FieldCallsTreeNode.java @@ -0,0 +1,82 @@ +/******************************************************************************* + * 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.ConstructorEntry; +import cuchaz.enigma.mapping.Entry; +import cuchaz.enigma.mapping.FieldEntry; +import cuchaz.enigma.mapping.MethodEntry; +import cuchaz.enigma.mapping.Translator; + +public class FieldCallsTreeNode extends DefaultMutableTreeNode +{ + private static final long serialVersionUID = -7934108091928699835L; + + private Translator m_deobfuscatingTranslator; + private FieldEntry m_entry; + + public FieldCallsTreeNode( Translator deobfuscatingTranslator, FieldEntry fieldEntry ) + { + m_deobfuscatingTranslator = deobfuscatingTranslator; + m_entry = fieldEntry; + } + + public FieldEntry getFieldEntry( ) + { + return m_entry; + } + + @Override + public String toString( ) + { + String className = m_deobfuscatingTranslator.translateClass( m_entry.getClassName() ); + if( className == null ) + { + className = m_entry.getClassName(); + } + + String targetName = m_deobfuscatingTranslator.translate( m_entry ); + if( targetName == null ) + { + targetName = m_entry.getName(); + } + return className + "." + targetName; + } + + public void load( JarIndex index, boolean recurse ) + { + // get all the child nodes + for( Entry entry : index.getFieldCallers( m_entry ) ) + { + if( entry instanceof MethodEntry ) + { + add( new MethodCallsTreeNode( m_deobfuscatingTranslator, (MethodEntry)entry ) ); + } + else if( entry instanceof ConstructorEntry ) + { + add( new MethodCallsTreeNode( m_deobfuscatingTranslator, (ConstructorEntry)entry ) ); + } + } + + if( recurse && children != null ) + { + for( Object node : children ) + { + if( node instanceof MethodCallsTreeNode ) + { + ((MethodCallsTreeNode)node).load( index, true ); + } + } + } + } +} -- cgit v1.2.3