Mirror of the JODE repository
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
jode/jode/src/net/sf/jode/flow/CreateClassField.java

87 lines
2.9 KiB

/* CreateClassField Copyright (C) 1999-2002 Jochen Hoenicke.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation; either version 2, or (at your option)
* any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program; see the file COPYING.LESSER. If not, write to
* the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
*
* $Id$
*/
package net.sf.jode.flow;
import net.sf.jode.expr.*;
import net.sf.jode.bytecode.ClassPath;
import net.sf.jode.type.Type;
public class CreateClassField {
public static boolean transform(IfThenElseBlock ifBlock,
StructuredBlock last) {
// convert
// if (class$classname == null)
// class$classname = class$("java.lang.Object");
// to
// if (classname.class == null) {
// }
if (!(ifBlock.cond instanceof CompareUnaryOperator)
|| !(((Operator)ifBlock.cond)
.getOperatorIndex() == Operator.EQUALS_OP)
|| !(ifBlock.thenBlock instanceof InstructionBlock)
|| ifBlock.elseBlock != null)
return false;
if (ifBlock.thenBlock.jump != null
&& (ifBlock.jump == null
|| (ifBlock.jump.destination
!= ifBlock.thenBlock.jump.destination)))
return false;
CompareUnaryOperator cmp = (CompareUnaryOperator) ifBlock.cond;
Expression instr =
((InstructionBlock)ifBlock.thenBlock).getInstruction();
if (!(cmp.getSubExpressions()[0] instanceof GetFieldOperator)
|| !(instr instanceof StoreInstruction))
return false;
StoreInstruction store = (StoreInstruction) instr;
if (!(store.getLValue() instanceof PutFieldOperator))
return false;
PutFieldOperator put = (PutFieldOperator) store.getLValue();
if (put.getField() == null
|| !put.matches((GetFieldOperator)cmp.getSubExpressions()[0])
|| !(store.getSubExpressions()[1] instanceof InvokeOperator))
return false;
InvokeOperator invoke = (InvokeOperator) store.getSubExpressions()[1];
if (!invoke.isGetClass())
return false;
Expression param = invoke.getSubExpressions()[0];
if (param instanceof ConstOperator
&& ((ConstOperator)param).getValue() instanceof String) {
String clazz = (String) ((ConstOperator)param).getValue();
if (put.getField().setClassConstant(clazz)) {
ClassPath cp = invoke.getClassPath();
cmp.setSubExpressions
(0, new ClassFieldOperator(clazz.charAt(0) == '['
? Type.tType(cp, clazz)
: Type.tClass(cp, clazz)));
EmptyBlock empty = new EmptyBlock();
empty.moveJump(ifBlock.thenBlock.jump);
ifBlock.setThenBlock(empty);
return true;
}
}
return false;
}
}