Skip to content

Commit 12b9523

Browse files
committed
Add a dex file rewriter to the rewriters module
Previously, if you needed to provide a custom dex file rewriter, you would have to override the DexRewriter class. This provides a more consistent interface, allowing the dex file rewriter to be specified in the module.
1 parent cb37770 commit 12b9523

File tree

5 files changed

+76
-24
lines changed

5 files changed

+76
-24
lines changed
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,67 @@
1+
/*
2+
* Copyright 2020, Google Inc.
3+
* All rights reserved.
4+
*
5+
* Redistribution and use in source and binary forms, with or without
6+
* modification, are permitted provided that the following conditions are
7+
* met:
8+
*
9+
* Redistributions of source code must retain the above copyright
10+
* notice, this list of conditions and the following disclaimer.
11+
* Redistributions in binary form must reproduce the above
12+
* copyright notice, this list of conditions and the following disclaimer
13+
* in the documentation and/or other materials provided with the
14+
* distribution.
15+
* Neither the name of Google Inc. nor the names of its
16+
* contributors may be used to endorse or promote products derived from
17+
* this software without specific prior written permission.
18+
*
19+
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20+
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21+
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
22+
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
23+
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
24+
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
25+
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
26+
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
27+
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
28+
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
29+
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30+
*/
31+
32+
package org.jf.dexlib2.rewriter;
33+
34+
import org.jf.dexlib2.Opcodes;
35+
import org.jf.dexlib2.iface.ClassDef;
36+
import org.jf.dexlib2.iface.DexFile;
37+
38+
import javax.annotation.Nonnull;
39+
import java.util.Set;
40+
41+
public class DexFileRewriter implements Rewriter<DexFile> {
42+
@Nonnull protected final Rewriters rewriters;
43+
44+
public DexFileRewriter(@Nonnull Rewriters rewriters) {
45+
this.rewriters = rewriters;
46+
}
47+
48+
@Nonnull @Override public DexFile rewrite(@Nonnull DexFile value) {
49+
return new RewrittenDexFile(value);
50+
}
51+
52+
protected class RewrittenDexFile implements DexFile {
53+
@Nonnull protected final DexFile dexFile;
54+
55+
public RewrittenDexFile(@Nonnull DexFile dexFile) {
56+
this.dexFile = dexFile;
57+
}
58+
59+
@Override @Nonnull public Set<? extends ClassDef> getClasses() {
60+
return RewriterUtils.rewriteSet(rewriters.getClassDefRewriter(), dexFile.getClasses());
61+
}
62+
63+
@Nonnull @Override public Opcodes getOpcodes() {
64+
return dexFile.getOpcodes();
65+
}
66+
}
67+
}

dexlib2/src/main/java/org/jf/dexlib2/rewriter/DexRewriter.java

+3-23
Original file line numberDiff line numberDiff line change
@@ -31,7 +31,6 @@
3131

3232
package org.jf.dexlib2.rewriter;
3333

34-
import org.jf.dexlib2.Opcodes;
3534
import org.jf.dexlib2.iface.*;
3635
import org.jf.dexlib2.iface.debug.DebugItem;
3736
import org.jf.dexlib2.iface.instruction.Instruction;
@@ -40,7 +39,6 @@
4039
import org.jf.dexlib2.iface.value.EncodedValue;
4140

4241
import javax.annotation.Nonnull;
43-
import java.util.Set;
4442

4543
/**
4644
* Out-of-the box, this class does nothing except make a picture-perfect copy of a dex file.
@@ -68,6 +66,7 @@
6866
* </pre>
6967
*/
7068
public class DexRewriter implements Rewriters {
69+
private final Rewriter<DexFile> dexFileRewriter;
7170
private final Rewriter<ClassDef> classDefRewriter;
7271
private final Rewriter<Field> fieldRewriter;
7372
private final Rewriter<Method> methodRewriter;
@@ -85,6 +84,7 @@ public class DexRewriter implements Rewriters {
8584
private final Rewriter<EncodedValue> encodedValueRewriter;
8685

8786
public DexRewriter(RewriterModule module) {
87+
this.dexFileRewriter = module.getDexFileRewriter(this);
8888
this.classDefRewriter = module.getClassDefRewriter(this);
8989
this.fieldRewriter = module.getFieldRewriter(this);
9090
this.methodRewriter = module.getMethodRewriter(this);
@@ -102,27 +102,7 @@ public DexRewriter(RewriterModule module) {
102102
this.encodedValueRewriter = module.getEncodedValueRewriter(this);
103103
}
104104

105-
@Nonnull
106-
public DexFile rewriteDexFile(@Nonnull DexFile dexFile) {
107-
return new RewrittenDexFile(dexFile);
108-
}
109-
110-
protected class RewrittenDexFile implements DexFile {
111-
@Nonnull protected final DexFile dexFile;
112-
113-
public RewrittenDexFile(@Nonnull DexFile dexFile) {
114-
this.dexFile = dexFile;
115-
}
116-
117-
@Override @Nonnull public Set<? extends ClassDef> getClasses() {
118-
return RewriterUtils.rewriteSet(getClassDefRewriter(), dexFile.getClasses());
119-
}
120-
121-
@Nonnull @Override public Opcodes getOpcodes() {
122-
return dexFile.getOpcodes();
123-
}
124-
}
125-
105+
@Nonnull @Override public Rewriter<DexFile> getDexFileRewriter() { return dexFileRewriter; }
126106
@Nonnull @Override public Rewriter<ClassDef> getClassDefRewriter() { return classDefRewriter; }
127107
@Nonnull @Override public Rewriter<Field> getFieldRewriter() { return fieldRewriter; }
128108
@Nonnull @Override public Rewriter<Method> getMethodRewriter() { return methodRewriter; }

dexlib2/src/main/java/org/jf/dexlib2/rewriter/RewriterModule.java

+4
Original file line numberDiff line numberDiff line change
@@ -41,6 +41,10 @@
4141
import javax.annotation.Nonnull;
4242

4343
public class RewriterModule {
44+
@Nonnull public Rewriter<DexFile> getDexFileRewriter(@Nonnull Rewriters rewriters) {
45+
return new DexFileRewriter(rewriters);
46+
}
47+
4448
@Nonnull public Rewriter<ClassDef> getClassDefRewriter(@Nonnull Rewriters rewriters) {
4549
return new ClassDefRewriter(rewriters);
4650
}

dexlib2/src/main/java/org/jf/dexlib2/rewriter/Rewriters.java

+1
Original file line numberDiff line numberDiff line change
@@ -41,6 +41,7 @@
4141
import javax.annotation.Nonnull;
4242

4343
public interface Rewriters {
44+
@Nonnull Rewriter<DexFile> getDexFileRewriter();
4445
@Nonnull Rewriter<ClassDef> getClassDefRewriter();
4546
@Nonnull Rewriter<Field> getFieldRewriter();
4647

dexlib2/src/test/java/org/jf/dexlib2/rewriter/RewriteArrayTypeTest.java

+1-1
Original file line numberDiff line numberDiff line change
@@ -72,7 +72,7 @@ public void testRewriteArrayTypeTest() {
7272
}
7373
});
7474

75-
DexFile rewrittenDexFile = rewriter.rewriteDexFile(dexFile);
75+
DexFile rewrittenDexFile = rewriter.getDexFileRewriter().rewrite(dexFile);
7676

7777
ClassDef rewrittenClassDef = Lists.newArrayList(rewrittenDexFile.getClasses()).get(0);
7878
Method rewrittenMethodDef = Lists.newArrayList(rewrittenClassDef.getMethods()).get(0);

0 commit comments

Comments
 (0)