From e43fac9f55cfeebacd869352bfb090b7d8d063c1 Mon Sep 17 00:00:00 2001 From: jeff Date: Sat, 30 Aug 2014 11:41:17 -0400 Subject: got a decent class matcher working --- src/cuchaz/enigma/convert/ClassNamer.java | 75 +++++++++++++++++++++++++++++++ 1 file changed, 75 insertions(+) create mode 100644 src/cuchaz/enigma/convert/ClassNamer.java (limited to 'src/cuchaz/enigma/convert/ClassNamer.java') diff --git a/src/cuchaz/enigma/convert/ClassNamer.java b/src/cuchaz/enigma/convert/ClassNamer.java new file mode 100644 index 0000000..1cd9665 --- /dev/null +++ b/src/cuchaz/enigma/convert/ClassNamer.java @@ -0,0 +1,75 @@ +/******************************************************************************* + * 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.convert; + +import java.util.Map; + +import com.beust.jcommander.internal.Maps; +import com.google.common.collect.BiMap; + +public class ClassNamer +{ + public interface SidedClassNamer + { + String getName( String name ); + } + + private Map m_sourceNames; + private Map m_destNames; + + public ClassNamer( BiMap mappings ) + { + // convert the identity mappings to name maps + m_sourceNames = Maps.newHashMap(); + m_destNames = Maps.newHashMap(); + int i = 0; + for( Map.Entry entry : mappings.entrySet() ) + { + String name = String.format( "M%04d", i++ ); + m_sourceNames.put( entry.getKey().getClassEntry().getName(), name ); + m_destNames.put( entry.getValue().getClassEntry().getName(), name ); + } + } + + public String getSourceName( String name ) + { + return m_sourceNames.get( name ); + } + + public String getDestName( String name ) + { + return m_destNames.get( name ); + } + + public SidedClassNamer getSourceNamer( ) + { + return new SidedClassNamer( ) + { + @Override + public String getName( String name ) + { + return getSourceName( name ); + } + }; + } + + public SidedClassNamer getDestNamer( ) + { + return new SidedClassNamer( ) + { + @Override + public String getName( String name ) + { + return getDestName( name ); + } + }; + } +} -- cgit v1.2.3