1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
|
/*******************************************************************************
* 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.mapping;
import java.io.IOException;
import java.io.ObjectOutputStream;
import java.io.OutputStream;
import java.util.zip.GZIPOutputStream;
public class Renamer
{
private Ancestries m_ancestries;
private Mappings m_mappings;
public Renamer( Ancestries ancestries, Mappings mappings )
{
m_ancestries = ancestries;
m_mappings = mappings;
}
public void setClassName( ClassEntry obf, String deobfName )
{
deobfName = NameValidator.validateClassName( deobfName );
ClassMapping classMapping = m_mappings.m_classesByObf.get( obf.getName() );
if( classMapping == null )
{
classMapping = createClassMapping( obf );
}
m_mappings.m_classesByDeobf.remove( classMapping.getDeobfName() );
classMapping.setDeobfName( deobfName );
m_mappings.m_classesByDeobf.put( deobfName, classMapping );
updateDeobfMethodSignatures();
}
public void setFieldName( FieldEntry obf, String deobfName )
{
deobfName = NameValidator.validateFieldName( deobfName );
ClassMapping classMapping = m_mappings.m_classesByObf.get( obf.getClassName() );
if( classMapping == null )
{
classMapping = createClassMapping( obf.getClassEntry() );
}
classMapping.setFieldName( obf.getName(), deobfName );
}
public void setMethodName( MethodEntry obf, String deobfName )
{
deobfName = NameValidator.validateMethodName( deobfName );
ClassMapping classMapping = m_mappings.m_classesByObf.get( obf.getClassName() );
if( classMapping == null )
{
classMapping = createClassMapping( obf.getClassEntry() );
}
String deobfSignature = m_mappings.getTranslator( m_ancestries, TranslationDirection.Deobfuscating ).translateSignature( obf.getSignature() );
classMapping.setMethodNameAndSignature( obf.getName(), obf.getSignature(), deobfName, deobfSignature );
// TODO: update ancestor/descendant methods in other classes in the inheritance hierarchy too
}
public void setArgumentName( ArgumentEntry obf, String deobfName )
{
deobfName = NameValidator.validateArgumentName( deobfName );
ClassMapping classMapping = m_mappings.m_classesByObf.get( obf.getClassName() );
if( classMapping == null )
{
classMapping = createClassMapping( obf.getClassEntry() );
}
classMapping.setArgumentName( obf.getMethodName(), obf.getMethodSignature(), obf.getIndex(), deobfName );
}
public void write( OutputStream out )
throws IOException
{
// TEMP: just use the object output for now. We can find a more efficient storage format later
GZIPOutputStream gzipout = new GZIPOutputStream( out );
ObjectOutputStream oout = new ObjectOutputStream( gzipout );
oout.writeObject( this );
gzipout.finish();
}
private ClassMapping createClassMapping( ClassEntry obf )
{
ClassMapping classMapping = new ClassMapping( obf.getName(), obf.getName() );
m_mappings.m_classesByObf.put( classMapping.getObfName(), classMapping );
m_mappings.m_classesByDeobf.put( classMapping.getDeobfName(), classMapping );
return classMapping;
}
private void updateDeobfMethodSignatures( )
{
Translator translator = m_mappings.getTranslator( m_ancestries, TranslationDirection.Deobfuscating );
for( ClassMapping classMapping : m_mappings.m_classesByObf.values() )
{
classMapping.updateDeobfMethodSignatures( translator );
}
}
}
|