Add some null checks, and throw descriptive exception when SideTransformer prevents a class from loading.

This commit is contained in:
LexManos 2012-10-23 13:32:02 -07:00
parent 190c71eeb5
commit 54f5225530
3 changed files with 5 additions and 1 deletions

View file

@ -145,6 +145,7 @@ public class AccessTransformer implements IClassTransformer
@Override @Override
public byte[] transform(String name, byte[] bytes) public byte[] transform(String name, byte[] bytes)
{ {
if (bytes == null) { return null; }
if (!modifiers.containsKey(name)) { return bytes; } if (!modifiers.containsKey(name)) { return bytes; }
ClassNode classNode = new ClassNode(); ClassNode classNode = new ClassNode();

View file

@ -89,6 +89,7 @@ public class MarkerTransformer implements IClassTransformer
@Override @Override
public byte[] transform(String name, byte[] bytes) public byte[] transform(String name, byte[] bytes)
{ {
if (bytes == null) { return null; }
if (!markers.containsKey(name)) { return bytes; } if (!markers.containsKey(name)) { return bytes; }
ClassNode classNode = new ClassNode(); ClassNode classNode = new ClassNode();

View file

@ -23,6 +23,8 @@ public class SideTransformer implements IClassTransformer
@Override @Override
public byte[] transform(String name, byte[] bytes) public byte[] transform(String name, byte[] bytes)
{ {
if (bytes == null) { return null; }
ClassNode classNode = new ClassNode(); ClassNode classNode = new ClassNode();
ClassReader classReader = new ClassReader(bytes); ClassReader classReader = new ClassReader(bytes);
classReader.accept(classNode, 0); classReader.accept(classNode, 0);
@ -33,7 +35,7 @@ public class SideTransformer implements IClassTransformer
{ {
System.out.println(String.format("Attempted to load class %s for invalid side %s", classNode.name, SIDE)); System.out.println(String.format("Attempted to load class %s for invalid side %s", classNode.name, SIDE));
} }
return null; throw new RuntimeException(String.format("Attempted to load class %s for invalid side %s", classNode.name, SIDE));
} }
Iterator<FieldNode> fields = classNode.fields.iterator(); Iterator<FieldNode> fields = classNode.fields.iterator();