forked from JavaTX/JavaCompilerCore
GenCode: StringLit erfolgreich getestet - Strings werden in dynamisch
in den Konstantenpool geschrieben und ausgelesen
This commit is contained in:
parent
d50206a519
commit
cef7c777b2
@ -4,11 +4,15 @@ import de.dhbwstuttgart.typeinference.Menge;
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// ino.end
|
// ino.end
|
||||||
// ino.module.StringLiteral.8653.import
|
// ino.module.StringLiteral.8653.import
|
||||||
import java.util.Hashtable;
|
import java.util.Hashtable;
|
||||||
|
|
||||||
|
import org.apache.bcel.classfile.ConstantPool;
|
||||||
import org.apache.bcel.generic.ClassGen;
|
import org.apache.bcel.generic.ClassGen;
|
||||||
|
import org.apache.bcel.generic.ConstantPoolGen;
|
||||||
import org.apache.bcel.generic.InstructionFactory;
|
import org.apache.bcel.generic.InstructionFactory;
|
||||||
import org.apache.bcel.generic.InstructionList;
|
import org.apache.bcel.generic.InstructionList;
|
||||||
import org.apache.bcel.generic.LDC;
|
import org.apache.bcel.generic.LDC;
|
||||||
@ -108,14 +112,23 @@ public class StringLiteral extends Literal
|
|||||||
return "\""+this.string+"\"";
|
return "\""+this.string+"\"";
|
||||||
}
|
}
|
||||||
|
|
||||||
public static int counterString = 0;
|
|
||||||
|
public String get_String()
|
||||||
|
// ino.end
|
||||||
|
// ino.method.get_Name.26246.body
|
||||||
|
{
|
||||||
|
return string;
|
||||||
|
}
|
||||||
|
//public static int counterString = 0;
|
||||||
@Override
|
@Override
|
||||||
public InstructionList genByteCode(ClassGen cg) {
|
public InstructionList genByteCode(ClassGen cg) {
|
||||||
InstructionFactory _factory = new InstructionFactory(cg, cg.getConstantPool());
|
ConstantPoolGen cp = cg.getConstantPool();
|
||||||
|
InstructionFactory _factory = new InstructionFactory(cg, cp);
|
||||||
InstructionList il = new InstructionList();
|
InstructionList il = new InstructionList();
|
||||||
counterString++;
|
//counterString++;
|
||||||
//il.append(_factory.ASTORE_1, _factory.createNew(string));
|
//il.append(_factory.ASTORE_1, _factory.createNew(string));
|
||||||
il.append(new LDC(counterString));
|
cp.addString(get_String());
|
||||||
|
il.append(new LDC(cp.getSize()-1));
|
||||||
return il;
|
return il;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
class StringLitTest{
|
class StringLitTest{
|
||||||
|
|
||||||
|
|
||||||
void method() { s; s = "abcdefg"; }
|
void method() { s; s = "abcdefg"; t; t ="jfowehfowh"; }
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
Loading…
x
Reference in New Issue
Block a user