forked from JavaTX/JavaCompilerCore
Fixed Tests. Doppelte TypeAssumptions beseitigt
This commit is contained in:
parent
61e9c953c9
commit
f0ef3017b9
@ -1330,7 +1330,6 @@ primitivetype :BOOLEAN
|
|||||||
$$=$1;
|
$$=$1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
referencetype :classorinterfacetype
|
referencetype :classorinterfacetype
|
||||||
{
|
{
|
||||||
org.apache.log4j.Logger.getLogger("parser").debug("T->Parser->referenctype: " + $1);
|
org.apache.log4j.Logger.getLogger("parser").debug("T->Parser->referenctype: " + $1);
|
||||||
|
@ -42,6 +42,7 @@ import org.apache.log4j.xml.DOMConfigurator;
|
|||||||
import com.sun.corba.se.spi.orbutil.fsm.Guard.Result;
|
import com.sun.corba.se.spi.orbutil.fsm.Guard.Result;
|
||||||
import com.sun.org.apache.xerces.internal.impl.xs.identity.Field;
|
import com.sun.org.apache.xerces.internal.impl.xs.identity.Field;
|
||||||
|
|
||||||
|
import typinferenz.FunNInterface;
|
||||||
import typinferenz.ResultSet;
|
import typinferenz.ResultSet;
|
||||||
// ino.end
|
// ino.end
|
||||||
import typinferenz.assumptions.TypeAssumptions;
|
import typinferenz.assumptions.TypeAssumptions;
|
||||||
@ -521,7 +522,7 @@ public class MyCompiler implements MyCompilerAPI
|
|||||||
inferencelog.info("# TypeReconstruction-Algorithmus - START #");
|
inferencelog.info("# TypeReconstruction-Algorithmus - START #");
|
||||||
inferencelog.info("##########################################\n");
|
inferencelog.info("##########################################\n");
|
||||||
|
|
||||||
TypeAssumptions globalAssumptions = m_AbstractSyntaxTree.elementAt(0).makeBasicAssumptions();
|
TypeAssumptions globalAssumptions = makeFunNAssumptions();
|
||||||
Vector<TypeinferenceResultSet> result = new Vector<TypeinferenceResultSet>();
|
Vector<TypeinferenceResultSet> result = new Vector<TypeinferenceResultSet>();
|
||||||
for(SourceFile srcFile : m_AbstractSyntaxTree){
|
for(SourceFile srcFile : m_AbstractSyntaxTree){
|
||||||
result.addAll(srcFile.typeReconstruction(globalAssumptions));
|
result.addAll(srcFile.typeReconstruction(globalAssumptions));
|
||||||
@ -536,7 +537,24 @@ public class MyCompiler implements MyCompilerAPI
|
|||||||
}
|
}
|
||||||
// ino.end
|
// ino.end
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Erstellt die FunN-Assumptions
|
||||||
|
* Fun0-FunN (momentan für N = 6)
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
private TypeAssumptions makeFunNAssumptions(){
|
||||||
|
TypeAssumptions ret = new TypeAssumptions();
|
||||||
|
|
||||||
|
//Basic Assumptions für die FunN Interfaces:
|
||||||
|
//TODO: Hier mehr als Fun1-Fun5 implementieren
|
||||||
|
for(int i = 0; i<6; i++){
|
||||||
|
FunNInterface funN = new FunNInterface(i);
|
||||||
|
ret.add(funN.getPublicFieldAssumptions());
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Author: J<EFBFBD>rg B<EFBFBD>uerle<br/>
|
* Author: J<EFBFBD>rg B<EFBFBD>uerle<br/>
|
||||||
|
@ -1281,7 +1281,7 @@ public class SourceFile
|
|||||||
*/
|
*/
|
||||||
// ino.end
|
// ino.end
|
||||||
// ino.method.makeBasicAssumptions.21418.definition
|
// ino.method.makeBasicAssumptions.21418.definition
|
||||||
public TypeAssumptions makeBasicAssumptions()
|
private TypeAssumptions makeBasicAssumptions()
|
||||||
// ino.end
|
// ino.end
|
||||||
// ino.method.makeBasicAssumptions.21418.body
|
// ino.method.makeBasicAssumptions.21418.body
|
||||||
{
|
{
|
||||||
|
@ -844,7 +844,7 @@ public class Class extends SyntaxTreeNode implements AClassOrInterface
|
|||||||
//assumptions.setThisV(thisAssumption);
|
//assumptions.setThisV(thisAssumption);
|
||||||
|
|
||||||
for(Field field : this.getFields()){
|
for(Field field : this.getFields()){
|
||||||
assumptions.add(field.createTypeAssumptions(this));
|
if(!field.isPublic())assumptions.add(field.createTypeAssumptions(this));
|
||||||
}
|
}
|
||||||
|
|
||||||
//Eine Assumption für den Standardkonstruktor:
|
//Eine Assumption für den Standardkonstruktor:
|
||||||
@ -1267,10 +1267,10 @@ public class Class extends SyntaxTreeNode implements AClassOrInterface
|
|||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
public TypeAssumptions getPublicFieldAssumptions() {
|
public TypeAssumptions getPublicFieldAssumptions() {
|
||||||
TypeAssumptions ret = this.getPrivateFieldAssumptions();
|
TypeAssumptions ret = new TypeAssumptions();//this.getPrivateFieldAssumptions();
|
||||||
ret.addClassAssumption(new ClassAssumption(this));
|
ret.addClassAssumption(new ClassAssumption(this));
|
||||||
for(Field f : this.getFields()){
|
for(Field f : this.getFields()){
|
||||||
ret.add(f.createTypeAssumptions(this));
|
if(f.isPublic())ret.add(f.createTypeAssumptions(this));
|
||||||
}
|
}
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
@ -1314,6 +1314,7 @@ public class Class extends SyntaxTreeNode implements AClassOrInterface
|
|||||||
this.addField(standardKonstruktor);
|
this.addField(standardKonstruktor);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//TODO: Umwandlung zu RefTypes funktioniert noch nicht richtig. (siehe LambdaTest2)
|
||||||
//Als RefType geparste Generische Variablen umwandeln:
|
//Als RefType geparste Generische Variablen umwandeln:
|
||||||
this.wandleRefTypeAttributes2GenericAttributes();
|
this.wandleRefTypeAttributes2GenericAttributes();
|
||||||
}
|
}
|
||||||
|
@ -27,6 +27,7 @@ public class ClassHelper
|
|||||||
*/
|
*/
|
||||||
// ino.end
|
// ino.end
|
||||||
// ino.method.findGenericType.23209.definition
|
// ino.method.findGenericType.23209.definition
|
||||||
|
@Deprecated
|
||||||
public static GenericTypeVar findGenericType(Type type, Vector<Type> paralist, Vector<GenericTypeVar> methodParaList)
|
public static GenericTypeVar findGenericType(Type type, Vector<Type> paralist, Vector<GenericTypeVar> methodParaList)
|
||||||
// ino.end
|
// ino.end
|
||||||
// ino.method.findGenericType.23209.body
|
// ino.method.findGenericType.23209.body
|
||||||
|
@ -6,6 +6,7 @@ import mycompiler.SyntaxTreeNode;
|
|||||||
import mycompiler.mybytecode.ClassFile;
|
import mycompiler.mybytecode.ClassFile;
|
||||||
import mycompiler.myexception.JVMCodeException;
|
import mycompiler.myexception.JVMCodeException;
|
||||||
import mycompiler.mytype.GenericTypeVar;
|
import mycompiler.mytype.GenericTypeVar;
|
||||||
|
import mycompiler.mytype.RefType;
|
||||||
import mycompiler.mytype.Type;
|
import mycompiler.mytype.Type;
|
||||||
import mycompiler.mytype.TypePlaceholder;
|
import mycompiler.mytype.TypePlaceholder;
|
||||||
import mycompiler.mytypereconstruction.replacementlistener.CReplaceTypeEvent;
|
import mycompiler.mytypereconstruction.replacementlistener.CReplaceTypeEvent;
|
||||||
@ -114,9 +115,15 @@ public abstract class Field extends SyntaxTreeNode implements TypeInsertable, Ty
|
|||||||
public void wandleRefTypeAttributes2GenericAttributes(Vector<Type> paralist){
|
public void wandleRefTypeAttributes2GenericAttributes(Vector<Type> paralist){
|
||||||
// Zuerst Returntype untersuchen
|
// Zuerst Returntype untersuchen
|
||||||
Type type=getType();
|
Type type=getType();
|
||||||
GenericTypeVar pendantReturnType=ClassHelper.findGenericType(type, paralist,new Vector<GenericTypeVar>());
|
Type pendantReturnType = null;
|
||||||
|
if(type instanceof RefType)pendantReturnType = ((RefType)type).findGenericType(paralist, new Vector<GenericTypeVar>());//GenericTypeVar pendantReturnType=ClassHelper.findGenericType(type, paralist,new Vector<GenericTypeVar>());
|
||||||
if(pendantReturnType!=null){ //Wenn generisch, dann modifizieren
|
if(pendantReturnType!=null){ //Wenn generisch, dann modifizieren
|
||||||
setType(pendantReturnType);
|
setType(pendantReturnType);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean isPublic() {
|
||||||
|
//TODO: momentan ist jedes Feld public!
|
||||||
|
return true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -503,7 +503,9 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
|
|||||||
{
|
{
|
||||||
// Zuerst Returntype untersuchen
|
// Zuerst Returntype untersuchen
|
||||||
Type returnType=getType();
|
Type returnType=getType();
|
||||||
GenericTypeVar pendantReturnType=ClassHelper.findGenericType(returnType, paralist,genericMethodParameters);
|
Type pendantReturnType = null;
|
||||||
|
if(returnType instanceof RefType)pendantReturnType = ((RefType)returnType).findGenericType(paralist, new Vector<GenericTypeVar>());
|
||||||
|
//GenericTypeVar pendantReturnType=ClassHelper.findGenericType(returnType, paralist,genericMethodParameters);
|
||||||
if(pendantReturnType!=null){ //Wenn generisch, dann modifizieren
|
if(pendantReturnType!=null){ //Wenn generisch, dann modifizieren
|
||||||
setReturnType(pendantReturnType);
|
setReturnType(pendantReturnType);
|
||||||
}
|
}
|
||||||
@ -513,7 +515,9 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
|
|||||||
FormalParameter fp=parameterlist.formalparameter.get(par);
|
FormalParameter fp=parameterlist.formalparameter.get(par);
|
||||||
Type fpType=fp.getType();
|
Type fpType=fp.getType();
|
||||||
// Nur wenn es sich um ein RefType-Field handelt
|
// Nur wenn es sich um ein RefType-Field handelt
|
||||||
GenericTypeVar pendantPara=ClassHelper.findGenericType(fpType,paralist,genericMethodParameters);
|
Type pendantPara = null;
|
||||||
|
if(fpType instanceof RefType)pendantPara = ((RefType)fpType).findGenericType(paralist, new Vector<GenericTypeVar>());
|
||||||
|
//GenericTypeVar pendantPara=ClassHelper.findGenericType(fpType,paralist,genericMethodParameters);
|
||||||
if(pendantPara!=null){ //Wenn generisch, dann modifizieren
|
if(pendantPara!=null){ //Wenn generisch, dann modifizieren
|
||||||
fp.setType(pendantPara);
|
fp.setType(pendantPara);
|
||||||
}
|
}
|
||||||
@ -537,7 +541,9 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
|
|||||||
|
|
||||||
|
|
||||||
public ConstraintsSet TYPE(TypeAssumptions ass) {
|
public ConstraintsSet TYPE(TypeAssumptions ass) {
|
||||||
if((this.returntype instanceof RefType))this.returntype = ass.getTypeFor((RefType)this.returntype);
|
if((this.returntype instanceof RefType) &&
|
||||||
|
!(this.returntype instanceof mycompiler.mytype.Void))//Sonderfall der Methode: Ihr Typ darf Void definiert werden.
|
||||||
|
this.returntype = ass.getTypeFor((RefType)this.returntype);
|
||||||
ConstraintsSet ret = new ConstraintsSet();
|
ConstraintsSet ret = new ConstraintsSet();
|
||||||
TypeAssumptions localAss = new TypeAssumptions();
|
TypeAssumptions localAss = new TypeAssumptions();
|
||||||
localAss.add(ass); //Die globalen Assumptions anhängen
|
localAss.add(ass); //Die globalen Assumptions anhängen
|
||||||
|
@ -1972,7 +1972,7 @@ case 150:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 151:
|
case 151:
|
||||||
// line 1335 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1334 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
org.apache.log4j.Logger.getLogger("parser").debug("T->Parser->referenctype: " + ((UsedId)yyVals[0+yyTop]));
|
org.apache.log4j.Logger.getLogger("parser").debug("T->Parser->referenctype: " + ((UsedId)yyVals[0+yyTop]));
|
||||||
RefType RT = new RefType(((UsedId)yyVals[0+yyTop]).getOffset());
|
RefType RT = new RefType(((UsedId)yyVals[0+yyTop]).getOffset());
|
||||||
@ -1992,25 +1992,25 @@ case 151:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 152:
|
case 152:
|
||||||
// line 1355 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1354 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((DeclId)yyVals[0+yyTop]);
|
yyVal=((DeclId)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 153:
|
case 153:
|
||||||
// line 1376 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1375 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((LocalVarDecl)yyVals[0+yyTop]);
|
yyVal=((LocalVarDecl)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 154:
|
case 154:
|
||||||
// line 1380 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1379 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Statement)yyVals[0+yyTop]);
|
yyVal=((Statement)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 155:
|
case 155:
|
||||||
// line 1385 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1384 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
FormalParameter FP = new FormalParameter(((DeclId)yyVals[0+yyTop]));
|
FormalParameter FP = new FormalParameter(((DeclId)yyVals[0+yyTop]));
|
||||||
FP.setType(((Type)yyVals[-1+yyTop]));
|
FP.setType(((Type)yyVals[-1+yyTop]));
|
||||||
@ -2019,7 +2019,7 @@ case 155:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 156:
|
case 156:
|
||||||
// line 1410 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1409 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
org.apache.log4j.Logger.getLogger("parser").debug("\nFunktionsdeklaration mit typlosen Parametern: " + ((DeclId)yyVals[0+yyTop]).name);
|
org.apache.log4j.Logger.getLogger("parser").debug("\nFunktionsdeklaration mit typlosen Parametern: " + ((DeclId)yyVals[0+yyTop]).name);
|
||||||
|
|
||||||
@ -2039,7 +2039,7 @@ case 156:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 157:
|
case 157:
|
||||||
// line 1429 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1428 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
ArgumentList AL = new ArgumentList();
|
ArgumentList AL = new ArgumentList();
|
||||||
AL.expr.addElement(((Expr)yyVals[0+yyTop]));
|
AL.expr.addElement(((Expr)yyVals[0+yyTop]));
|
||||||
@ -2047,20 +2047,20 @@ case 157:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 158:
|
case 158:
|
||||||
// line 1435 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1434 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
((ArgumentList)yyVals[-2+yyTop]).expr.addElement(((Expr)yyVals[0+yyTop]));
|
((ArgumentList)yyVals[-2+yyTop]).expr.addElement(((Expr)yyVals[0+yyTop]));
|
||||||
yyVal=((ArgumentList)yyVals[-2+yyTop]);
|
yyVal=((ArgumentList)yyVals[-2+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 159:
|
case 159:
|
||||||
// line 1441 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1440 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((BaseType)yyVals[0+yyTop]);
|
yyVal=((BaseType)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 160:
|
case 160:
|
||||||
// line 1446 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1445 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
DeclId DI = new DeclId();
|
DeclId DI = new DeclId();
|
||||||
/* #JB# 10.04.2005 */
|
/* #JB# 10.04.2005 */
|
||||||
@ -2073,61 +2073,61 @@ case 160:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 161:
|
case 161:
|
||||||
// line 1458 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1457 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Expr)yyVals[0+yyTop]);
|
yyVal=((Expr)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 162:
|
case 162:
|
||||||
// line 1463 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1462 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((LocalVarDecl)yyVals[-1+yyTop]);
|
yyVal=((LocalVarDecl)yyVals[-1+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 163:
|
case 163:
|
||||||
// line 1468 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1467 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Statement)yyVals[0+yyTop]);
|
yyVal=((Statement)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 164:
|
case 164:
|
||||||
// line 1472 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1471 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((IfStmt)yyVals[0+yyTop]);
|
yyVal=((IfStmt)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 165:
|
case 165:
|
||||||
// line 1476 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1475 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((IfStmt)yyVals[0+yyTop]);
|
yyVal=((IfStmt)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 166:
|
case 166:
|
||||||
// line 1480 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1479 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((WhileStmt)yyVals[0+yyTop]);
|
yyVal=((WhileStmt)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 167:
|
case 167:
|
||||||
// line 1484 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1483 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((ForStmt)yyVals[0+yyTop]);
|
yyVal=((ForStmt)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 168:
|
case 168:
|
||||||
// line 1489 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1488 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Expr)yyVals[0+yyTop]);
|
yyVal=((Expr)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 169:
|
case 169:
|
||||||
// line 1493 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1492 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((NewClass)yyVals[0+yyTop]);
|
yyVal=((NewClass)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 170:
|
case 170:
|
||||||
// line 1498 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1497 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
IntegerType IT = new IntegerType();
|
IntegerType IT = new IntegerType();
|
||||||
/* #JB# 05.04.2005 */
|
/* #JB# 05.04.2005 */
|
||||||
@ -2138,7 +2138,7 @@ case 170:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 171:
|
case 171:
|
||||||
// line 1507 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1506 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
CharacterType CT = new CharacterType();
|
CharacterType CT = new CharacterType();
|
||||||
/* #JB# 05.04.2005 */
|
/* #JB# 05.04.2005 */
|
||||||
@ -2149,7 +2149,7 @@ case 171:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 172:
|
case 172:
|
||||||
// line 1517 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1516 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
org.apache.log4j.Logger.getLogger("parser").debug("P -> Lokale Variable angelegt!");
|
org.apache.log4j.Logger.getLogger("parser").debug("P -> Lokale Variable angelegt!");
|
||||||
LocalVarDecl LVD = new LocalVarDecl(((Type)yyVals[-1+yyTop]).getOffset(),((Type)yyVals[-1+yyTop]).getVariableLength());
|
LocalVarDecl LVD = new LocalVarDecl(((Type)yyVals[-1+yyTop]).getOffset(),((Type)yyVals[-1+yyTop]).getVariableLength());
|
||||||
@ -2159,7 +2159,7 @@ case 172:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 173:
|
case 173:
|
||||||
// line 1528 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1527 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
org.apache.log4j.Logger.getLogger("parser").debug("P -> Lokale Variable angelegt!");
|
org.apache.log4j.Logger.getLogger("parser").debug("P -> Lokale Variable angelegt!");
|
||||||
LocalVarDecl LVD = new LocalVarDecl(((FieldDeclaration)yyVals[0+yyTop]).getOffset(),((FieldDeclaration)yyVals[0+yyTop]).getVariableLength());
|
LocalVarDecl LVD = new LocalVarDecl(((FieldDeclaration)yyVals[0+yyTop]).getOffset(),((FieldDeclaration)yyVals[0+yyTop]).getVariableLength());
|
||||||
@ -2169,31 +2169,31 @@ case 173:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 174:
|
case 174:
|
||||||
// line 1538 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1537 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Block)yyVals[0+yyTop]);
|
yyVal=((Block)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 175:
|
case 175:
|
||||||
// line 1542 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1541 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((EmptyStmt)yyVals[0+yyTop]);
|
yyVal=((EmptyStmt)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 176:
|
case 176:
|
||||||
// line 1546 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1545 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((ExprStmt)yyVals[0+yyTop]);
|
yyVal=((ExprStmt)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 177:
|
case 177:
|
||||||
// line 1550 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1549 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Return)yyVals[0+yyTop]);
|
yyVal=((Return)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 178:
|
case 178:
|
||||||
// line 1555 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1554 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
IfStmt Ifst = new IfStmt(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
IfStmt Ifst = new IfStmt(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
||||||
Ifst.set_Expr(((Expr)yyVals[-2+yyTop]));
|
Ifst.set_Expr(((Expr)yyVals[-2+yyTop]));
|
||||||
@ -2202,7 +2202,7 @@ case 178:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 179:
|
case 179:
|
||||||
// line 1563 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1562 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
IfStmt IfstElst = new IfStmt(((Expr)yyVals[-4+yyTop]).getOffset(),((Expr)yyVals[-4+yyTop]).getVariableLength());
|
IfStmt IfstElst = new IfStmt(((Expr)yyVals[-4+yyTop]).getOffset(),((Expr)yyVals[-4+yyTop]).getVariableLength());
|
||||||
IfstElst.set_Expr(((Expr)yyVals[-4+yyTop]));
|
IfstElst.set_Expr(((Expr)yyVals[-4+yyTop]));
|
||||||
@ -2212,7 +2212,7 @@ case 179:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 180:
|
case 180:
|
||||||
// line 1572 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1571 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
WhileStmt Whlst = new WhileStmt(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
WhileStmt Whlst = new WhileStmt(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
||||||
Whlst.set_Expr(((Expr)yyVals[-2+yyTop]));
|
Whlst.set_Expr(((Expr)yyVals[-2+yyTop]));
|
||||||
@ -2221,7 +2221,7 @@ case 180:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 181:
|
case 181:
|
||||||
// line 1583 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1582 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
ForStmt Fst = new ForStmt(((Expr)yyVals[-6+yyTop]).getOffset(),((Expr)yyVals[-6+yyTop]).getVariableLength());
|
ForStmt Fst = new ForStmt(((Expr)yyVals[-6+yyTop]).getOffset(),((Expr)yyVals[-6+yyTop]).getVariableLength());
|
||||||
Fst.set_head_Initializer(((Expr)yyVals[-6+yyTop]));
|
Fst.set_head_Initializer(((Expr)yyVals[-6+yyTop]));
|
||||||
@ -2234,7 +2234,7 @@ case 181:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 182:
|
case 182:
|
||||||
// line 1595 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1594 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
ForStmt Fst = new ForStmt(((Expr)yyVals[-5+yyTop]).getOffset(),((Expr)yyVals[-5+yyTop]).getVariableLength());
|
ForStmt Fst = new ForStmt(((Expr)yyVals[-5+yyTop]).getOffset(),((Expr)yyVals[-5+yyTop]).getVariableLength());
|
||||||
Fst.set_head_Initializer(((Expr)yyVals[-5+yyTop]));
|
Fst.set_head_Initializer(((Expr)yyVals[-5+yyTop]));
|
||||||
@ -2246,7 +2246,7 @@ case 182:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 183:
|
case 183:
|
||||||
// line 1606 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1605 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
ForStmt Fst = new ForStmt(((Expr)yyVals[-5+yyTop]).getOffset(),((Expr)yyVals[-5+yyTop]).getVariableLength());
|
ForStmt Fst = new ForStmt(((Expr)yyVals[-5+yyTop]).getOffset(),((Expr)yyVals[-5+yyTop]).getVariableLength());
|
||||||
Fst.set_head_Initializer(((Expr)yyVals[-5+yyTop]));
|
Fst.set_head_Initializer(((Expr)yyVals[-5+yyTop]));
|
||||||
@ -2258,7 +2258,7 @@ case 183:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 184:
|
case 184:
|
||||||
// line 1617 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1616 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
ForStmt Fst = new ForStmt(((Expr)yyVals[-4+yyTop]).getOffset(),((Expr)yyVals[-4+yyTop]).getVariableLength());
|
ForStmt Fst = new ForStmt(((Expr)yyVals[-4+yyTop]).getOffset(),((Expr)yyVals[-4+yyTop]).getVariableLength());
|
||||||
Fst.set_head_Condition(((Expr)yyVals[-4+yyTop]));
|
Fst.set_head_Condition(((Expr)yyVals[-4+yyTop]));
|
||||||
@ -2270,7 +2270,7 @@ case 184:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 185:
|
case 185:
|
||||||
// line 1628 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1627 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
ForStmt Fst = new ForStmt(((Expr)yyVals[-4+yyTop]).getOffset(),((Expr)yyVals[-4+yyTop]).getVariableLength());
|
ForStmt Fst = new ForStmt(((Expr)yyVals[-4+yyTop]).getOffset(),((Expr)yyVals[-4+yyTop]).getVariableLength());
|
||||||
Fst.set_head_Initializer(((Expr)yyVals[-4+yyTop]));
|
Fst.set_head_Initializer(((Expr)yyVals[-4+yyTop]));
|
||||||
@ -2281,7 +2281,7 @@ case 185:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 186:
|
case 186:
|
||||||
// line 1638 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1637 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
ForStmt Fst = new ForStmt(((Expr)yyVals[-3+yyTop]).getOffset(),((Expr)yyVals[-3+yyTop]).getVariableLength());
|
ForStmt Fst = new ForStmt(((Expr)yyVals[-3+yyTop]).getOffset(),((Expr)yyVals[-3+yyTop]).getVariableLength());
|
||||||
Fst.set_head_Condition(((Expr)yyVals[-3+yyTop]));
|
Fst.set_head_Condition(((Expr)yyVals[-3+yyTop]));
|
||||||
@ -2292,7 +2292,7 @@ case 186:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 187:
|
case 187:
|
||||||
// line 1648 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1647 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
ForStmt Fst = new ForStmt(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
ForStmt Fst = new ForStmt(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
||||||
Fst.set_head_Loop_expr(((Expr)yyVals[-2+yyTop]));
|
Fst.set_head_Loop_expr(((Expr)yyVals[-2+yyTop]));
|
||||||
@ -2303,7 +2303,7 @@ case 187:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 188:
|
case 188:
|
||||||
// line 1658 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1657 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
ForStmt Fst = new ForStmt(((Statement)yyVals[0+yyTop]).getOffset(),((Statement)yyVals[0+yyTop]).getVariableLength());
|
ForStmt Fst = new ForStmt(((Statement)yyVals[0+yyTop]).getOffset(),((Statement)yyVals[0+yyTop]).getVariableLength());
|
||||||
Fst.set_body_Loop_block(((Statement)yyVals[0+yyTop]));
|
Fst.set_body_Loop_block(((Statement)yyVals[0+yyTop]));
|
||||||
@ -2313,40 +2313,40 @@ case 188:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 189:
|
case 189:
|
||||||
// line 1667 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1666 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
org.apache.log4j.Logger.getLogger("parser").debug("conditionalexpression");
|
org.apache.log4j.Logger.getLogger("parser").debug("conditionalexpression");
|
||||||
yyVal=((Expr)yyVals[0+yyTop]);
|
yyVal=((Expr)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 190:
|
case 190:
|
||||||
// line 1672 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1671 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Assign)yyVals[0+yyTop]);
|
yyVal=((Assign)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 191:
|
case 191:
|
||||||
// line 1678 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1677 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
EmptyStmt Empst = new EmptyStmt();
|
EmptyStmt Empst = new EmptyStmt();
|
||||||
yyVal=Empst;
|
yyVal=Empst;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 192:
|
case 192:
|
||||||
// line 1684 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1683 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Expr)yyVals[-1+yyTop]);
|
yyVal=((Expr)yyVals[-1+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 193:
|
case 193:
|
||||||
// line 1689 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1688 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
Return ret = new Return(-1,-1);
|
Return ret = new Return(-1,-1);
|
||||||
yyVal= ret;
|
yyVal= ret;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 194:
|
case 194:
|
||||||
// line 1694 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1693 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
Return retexp = new Return(((Expr)yyVals[-1+yyTop]).getOffset(),((Expr)yyVals[-1+yyTop]).getVariableLength());
|
Return retexp = new Return(((Expr)yyVals[-1+yyTop]).getOffset(),((Expr)yyVals[-1+yyTop]).getVariableLength());
|
||||||
retexp.set_ReturnExpr(((Expr)yyVals[-1+yyTop]));
|
retexp.set_ReturnExpr(((Expr)yyVals[-1+yyTop]));
|
||||||
@ -2354,31 +2354,31 @@ case 194:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 195:
|
case 195:
|
||||||
// line 1701 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1700 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Statement)yyVals[0+yyTop]);
|
yyVal=((Statement)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 196:
|
case 196:
|
||||||
// line 1705 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1704 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((IfStmt)yyVals[0+yyTop]);
|
yyVal=((IfStmt)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 197:
|
case 197:
|
||||||
// line 1709 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1708 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((WhileStmt)yyVals[0+yyTop]);
|
yyVal=((WhileStmt)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 198:
|
case 198:
|
||||||
// line 1714 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1713 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Expr)yyVals[0+yyTop]);
|
yyVal=((Expr)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 199:
|
case 199:
|
||||||
// line 1720 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1719 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
org.apache.log4j.Logger.getLogger("parser").debug("\nParser --> Zuweisung1!\n");
|
org.apache.log4j.Logger.getLogger("parser").debug("\nParser --> Zuweisung1!\n");
|
||||||
Assign Ass = new Assign(((UsedId)yyVals[-2+yyTop]).getOffset(),((UsedId)yyVals[-2+yyTop]).getVariableLength());
|
Assign Ass = new Assign(((UsedId)yyVals[-2+yyTop]).getOffset(),((UsedId)yyVals[-2+yyTop]).getVariableLength());
|
||||||
@ -2405,7 +2405,7 @@ case 199:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 200:
|
case 200:
|
||||||
// line 1745 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1744 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
Assign Ass =new Assign(((UsedId)yyVals[-2+yyTop]).getOffset(),((UsedId)yyVals[-2+yyTop]).getVariableLength());
|
Assign Ass =new Assign(((UsedId)yyVals[-2+yyTop]).getOffset(),((UsedId)yyVals[-2+yyTop]).getVariableLength());
|
||||||
LocalOrFieldVar LOFV = new LocalOrFieldVar(((UsedId)yyVals[-2+yyTop]).getOffset(),((UsedId)yyVals[-2+yyTop]).getVariableLength());
|
LocalOrFieldVar LOFV = new LocalOrFieldVar(((UsedId)yyVals[-2+yyTop]).getOffset(),((UsedId)yyVals[-2+yyTop]).getVariableLength());
|
||||||
@ -2429,43 +2429,43 @@ case 200:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 201:
|
case 201:
|
||||||
// line 1768 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1767 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Assign)yyVals[0+yyTop]);
|
yyVal=((Assign)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 202:
|
case 202:
|
||||||
// line 1772 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1771 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Expr)yyVals[0+yyTop]);
|
yyVal=((Expr)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 203:
|
case 203:
|
||||||
// line 1776 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1775 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Expr)yyVals[0+yyTop]);
|
yyVal=((Expr)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 204:
|
case 204:
|
||||||
// line 1780 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1779 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Expr)yyVals[0+yyTop]);
|
yyVal=((Expr)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 205:
|
case 205:
|
||||||
// line 1784 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1783 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Expr)yyVals[0+yyTop]);
|
yyVal=((Expr)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 206:
|
case 206:
|
||||||
// line 1788 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1787 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((MethodCall)yyVals[0+yyTop]);
|
yyVal=((MethodCall)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 207:
|
case 207:
|
||||||
// line 1799 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1798 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
IfStmt IfElno = new IfStmt(((Expr)yyVals[-4+yyTop]).getOffset(),((Expr)yyVals[-4+yyTop]).getVariableLength());
|
IfStmt IfElno = new IfStmt(((Expr)yyVals[-4+yyTop]).getOffset(),((Expr)yyVals[-4+yyTop]).getVariableLength());
|
||||||
IfElno.set_Expr(((Expr)yyVals[-4+yyTop]));
|
IfElno.set_Expr(((Expr)yyVals[-4+yyTop]));
|
||||||
@ -2475,7 +2475,7 @@ case 207:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 208:
|
case 208:
|
||||||
// line 1808 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1807 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
WhileStmt Whstno = new WhileStmt(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
WhileStmt Whstno = new WhileStmt(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
||||||
Whstno.set_Expr(((Expr)yyVals[-2+yyTop]));
|
Whstno.set_Expr(((Expr)yyVals[-2+yyTop]));
|
||||||
@ -2484,13 +2484,13 @@ case 208:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 209:
|
case 209:
|
||||||
// line 1816 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1815 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Expr)yyVals[0+yyTop]);
|
yyVal=((Expr)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 210:
|
case 210:
|
||||||
// line 1820 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1819 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
Binary LogOr = new Binary(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
Binary LogOr = new Binary(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
||||||
OrOp OrO = new OrOp(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
OrOp OrO = new OrOp(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
||||||
@ -2502,19 +2502,19 @@ case 210:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 211:
|
case 211:
|
||||||
// line 1833 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1832 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=null;
|
yyVal=null;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 212:
|
case 212:
|
||||||
// line 1838 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1837 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Block)yyVals[0+yyTop]);
|
yyVal=((Block)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 213:
|
case 213:
|
||||||
// line 1842 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1841 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
/*Lambdabody kann auch nur aus einer Expression bestehen. In diesem Fall wird ein Block erstellt, welcher als einziges Statement ein return statment mit der expression hat.*/
|
/*Lambdabody kann auch nur aus einer Expression bestehen. In diesem Fall wird ein Block erstellt, welcher als einziges Statement ein return statment mit der expression hat.*/
|
||||||
/*Bsp.: Aus der Expression |var=="hallo"| wird: |{return var=="hallo";}|*/
|
/*Bsp.: Aus der Expression |var=="hallo"| wird: |{return var=="hallo";}|*/
|
||||||
@ -2525,19 +2525,19 @@ case 213:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 214:
|
case 214:
|
||||||
// line 1852 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1851 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=null;
|
yyVal=null;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 215:
|
case 215:
|
||||||
// line 1856 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1855 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((ParameterList)yyVals[-1+yyTop]);
|
yyVal=((ParameterList)yyVals[-1+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 216:
|
case 216:
|
||||||
// line 1861 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1860 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
LambdaExpression lambda = new LambdaExpression(/*((ParameSterList)$2).getOffset(),((ParameterList)$2).getVariableLength()*/0,0);
|
LambdaExpression lambda = new LambdaExpression(/*((ParameSterList)$2).getOffset(),((ParameterList)$2).getVariableLength()*/0,0);
|
||||||
if(((ParameterList)yyVals[-2+yyTop])!=null)lambda.setParameterList(((ParameterList)yyVals[-2+yyTop]));
|
if(((ParameterList)yyVals[-2+yyTop])!=null)lambda.setParameterList(((ParameterList)yyVals[-2+yyTop]));
|
||||||
@ -2546,54 +2546,54 @@ case 216:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 217:
|
case 217:
|
||||||
// line 1880 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1879 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((UsedId)yyVals[0+yyTop]);
|
yyVal=((UsedId)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 218:
|
case 218:
|
||||||
// line 1885 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1884 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=null;
|
yyVal=null;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 219:
|
case 219:
|
||||||
// line 1889 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1888 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
TimesOp TEO = new TimesOp(-1,-1);
|
TimesOp TEO = new TimesOp(-1,-1);
|
||||||
yyVal=TEO;
|
yyVal=TEO;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 220:
|
case 220:
|
||||||
// line 1894 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1893 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
DivideOp DEO = new DivideOp(-1,-1);
|
DivideOp DEO = new DivideOp(-1,-1);
|
||||||
yyVal=DEO;
|
yyVal=DEO;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 221:
|
case 221:
|
||||||
// line 1899 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1898 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
ModuloOp MEO = new ModuloOp(-1,-1);
|
ModuloOp MEO = new ModuloOp(-1,-1);
|
||||||
yyVal=MEO;
|
yyVal=MEO;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 222:
|
case 222:
|
||||||
// line 1904 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1903 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
PlusOp PEO = new PlusOp(-1,-1);
|
PlusOp PEO = new PlusOp(-1,-1);
|
||||||
yyVal=PEO;
|
yyVal=PEO;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 223:
|
case 223:
|
||||||
// line 1909 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1908 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
MinusOp MEO = new MinusOp(-1,-1);
|
MinusOp MEO = new MinusOp(-1,-1);
|
||||||
yyVal=MEO;
|
yyVal=MEO;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 224:
|
case 224:
|
||||||
// line 1921 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1920 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
PreIncExpr PRINC = new PreIncExpr(((Expr)yyVals[0+yyTop]).getOffset(),((Expr)yyVals[0+yyTop]).getVariableLength());
|
PreIncExpr PRINC = new PreIncExpr(((Expr)yyVals[0+yyTop]).getOffset(),((Expr)yyVals[0+yyTop]).getVariableLength());
|
||||||
PRINC.set_Expr(((Expr)yyVals[0+yyTop]));
|
PRINC.set_Expr(((Expr)yyVals[0+yyTop]));
|
||||||
@ -2601,7 +2601,7 @@ case 224:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 225:
|
case 225:
|
||||||
// line 1928 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1927 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
PreDecExpr PRDEC = new PreDecExpr(((Expr)yyVals[0+yyTop]).getOffset(),((Expr)yyVals[0+yyTop]).getVariableLength());
|
PreDecExpr PRDEC = new PreDecExpr(((Expr)yyVals[0+yyTop]).getOffset(),((Expr)yyVals[0+yyTop]).getVariableLength());
|
||||||
PRDEC.set_Expr(((Expr)yyVals[0+yyTop]));
|
PRDEC.set_Expr(((Expr)yyVals[0+yyTop]));
|
||||||
@ -2609,7 +2609,7 @@ case 225:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 226:
|
case 226:
|
||||||
// line 1935 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1934 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
PostIncExpr PIE = new PostIncExpr(((Expr)yyVals[-1+yyTop]).getOffset(),((Expr)yyVals[-1+yyTop]).getVariableLength());
|
PostIncExpr PIE = new PostIncExpr(((Expr)yyVals[-1+yyTop]).getOffset(),((Expr)yyVals[-1+yyTop]).getVariableLength());
|
||||||
PIE.set_Expr(((Expr)yyVals[-1+yyTop]));
|
PIE.set_Expr(((Expr)yyVals[-1+yyTop]));
|
||||||
@ -2617,7 +2617,7 @@ case 226:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 227:
|
case 227:
|
||||||
// line 1942 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1941 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
PostDecExpr PDE = new PostDecExpr(((Expr)yyVals[-1+yyTop]).getOffset(),((Expr)yyVals[-1+yyTop]).getVariableLength());
|
PostDecExpr PDE = new PostDecExpr(((Expr)yyVals[-1+yyTop]).getOffset(),((Expr)yyVals[-1+yyTop]).getVariableLength());
|
||||||
PDE.set_Expr(((Expr)yyVals[-1+yyTop]));
|
PDE.set_Expr(((Expr)yyVals[-1+yyTop]));
|
||||||
@ -2625,7 +2625,7 @@ case 227:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 228:
|
case 228:
|
||||||
// line 1950 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1949 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
org.apache.log4j.Logger.getLogger("parser").debug("M1");
|
org.apache.log4j.Logger.getLogger("parser").debug("M1");
|
||||||
MethodCall MC = new MethodCall(((UsedId)yyVals[-2+yyTop]).getOffset(),((UsedId)yyVals[-2+yyTop]).getVariableLength());
|
MethodCall MC = new MethodCall(((UsedId)yyVals[-2+yyTop]).getOffset(),((UsedId)yyVals[-2+yyTop]).getVariableLength());
|
||||||
@ -2657,7 +2657,7 @@ case 228:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 229:
|
case 229:
|
||||||
// line 1980 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 1979 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
org.apache.log4j.Logger.getLogger("parser").debug("M2");
|
org.apache.log4j.Logger.getLogger("parser").debug("M2");
|
||||||
MethodCall MCarg = new MethodCall(((UsedId)yyVals[-3+yyTop]).getOffset(),((UsedId)yyVals[-3+yyTop]).getVariableLength());
|
MethodCall MCarg = new MethodCall(((UsedId)yyVals[-3+yyTop]).getOffset(),((UsedId)yyVals[-3+yyTop]).getVariableLength());
|
||||||
@ -2690,7 +2690,7 @@ case 229:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 230:
|
case 230:
|
||||||
// line 2011 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2010 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
org.apache.log4j.Logger.getLogger("parser").debug("M3");
|
org.apache.log4j.Logger.getLogger("parser").debug("M3");
|
||||||
MethodCall MCpr = new MethodCall(((Expr)yyVals[-4+yyTop]).getOffset(),((Expr)yyVals[-4+yyTop]).getVariableLength());
|
MethodCall MCpr = new MethodCall(((Expr)yyVals[-4+yyTop]).getOffset(),((Expr)yyVals[-4+yyTop]).getVariableLength());
|
||||||
@ -2711,7 +2711,7 @@ case 230:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 231:
|
case 231:
|
||||||
// line 2030 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2029 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
org.apache.log4j.Logger.getLogger("parser").debug("M4");
|
org.apache.log4j.Logger.getLogger("parser").debug("M4");
|
||||||
MethodCall MCPA = new MethodCall(((Expr)yyVals[-5+yyTop]).getOffset(),((Expr)yyVals[-5+yyTop]).getVariableLength());
|
MethodCall MCPA = new MethodCall(((Expr)yyVals[-5+yyTop]).getOffset(),((Expr)yyVals[-5+yyTop]).getVariableLength());
|
||||||
@ -2733,7 +2733,7 @@ case 231:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 232:
|
case 232:
|
||||||
// line 2053 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2052 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
NewClass NC = new NewClass(((UsedId)yyVals[-2+yyTop]).getOffset(),((UsedId)yyVals[-2+yyTop]).getVariableLength());
|
NewClass NC = new NewClass(((UsedId)yyVals[-2+yyTop]).getOffset(),((UsedId)yyVals[-2+yyTop]).getVariableLength());
|
||||||
NC.set_UsedId(((UsedId)yyVals[-2+yyTop]));
|
NC.set_UsedId(((UsedId)yyVals[-2+yyTop]));
|
||||||
@ -2743,7 +2743,7 @@ case 232:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 233:
|
case 233:
|
||||||
// line 2061 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2060 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
NewClass NCarg = new NewClass(((UsedId)yyVals[-3+yyTop]).getOffset(),((UsedId)yyVals[-3+yyTop]).getVariableLength());
|
NewClass NCarg = new NewClass(((UsedId)yyVals[-3+yyTop]).getOffset(),((UsedId)yyVals[-3+yyTop]).getVariableLength());
|
||||||
NCarg.set_UsedId(((UsedId)yyVals[-3+yyTop]));
|
NCarg.set_UsedId(((UsedId)yyVals[-3+yyTop]));
|
||||||
@ -2754,13 +2754,13 @@ case 233:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 234:
|
case 234:
|
||||||
// line 2071 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2070 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Expr)yyVals[0+yyTop]);
|
yyVal=((Expr)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 235:
|
case 235:
|
||||||
// line 2075 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2074 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
Binary And = new Binary(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
Binary And = new Binary(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
||||||
AndOp AndO = new AndOp(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
AndOp AndO = new AndOp(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
||||||
@ -2772,19 +2772,19 @@ case 235:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 236:
|
case 236:
|
||||||
// line 2091 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2090 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Expr)yyVals[0+yyTop]);
|
yyVal=((Expr)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 237:
|
case 237:
|
||||||
// line 2095 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2094 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Expr)yyVals[0+yyTop]);
|
yyVal=((Expr)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 238:
|
case 238:
|
||||||
// line 2099 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2098 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
PositivExpr POSEX=new PositivExpr(((Expr)yyVals[0+yyTop]).getOffset(),((Expr)yyVals[0+yyTop]).getVariableLength());
|
PositivExpr POSEX=new PositivExpr(((Expr)yyVals[0+yyTop]).getOffset(),((Expr)yyVals[0+yyTop]).getVariableLength());
|
||||||
UnaryPlus UP= new UnaryPlus();
|
UnaryPlus UP= new UnaryPlus();
|
||||||
@ -2794,7 +2794,7 @@ case 238:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 239:
|
case 239:
|
||||||
// line 2107 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2106 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
NegativeExpr NEGEX=new NegativeExpr(((Expr)yyVals[0+yyTop]).getOffset(),((Expr)yyVals[0+yyTop]).getVariableLength());
|
NegativeExpr NEGEX=new NegativeExpr(((Expr)yyVals[0+yyTop]).getOffset(),((Expr)yyVals[0+yyTop]).getVariableLength());
|
||||||
UnaryMinus UM=new UnaryMinus();
|
UnaryMinus UM=new UnaryMinus();
|
||||||
@ -2804,19 +2804,19 @@ case 239:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 240:
|
case 240:
|
||||||
// line 2115 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2114 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Expr)yyVals[0+yyTop]);
|
yyVal=((Expr)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 241:
|
case 241:
|
||||||
// line 2120 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2119 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Expr)yyVals[0+yyTop]);
|
yyVal=((Expr)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 242:
|
case 242:
|
||||||
// line 2124 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2123 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
if (((UsedId)yyVals[0+yyTop]).get_Name().size() > 1) {
|
if (((UsedId)yyVals[0+yyTop]).get_Name().size() > 1) {
|
||||||
|
|
||||||
@ -2836,37 +2836,37 @@ case 242:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 243:
|
case 243:
|
||||||
// line 2142 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2141 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Expr)yyVals[0+yyTop]);
|
yyVal=((Expr)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 244:
|
case 244:
|
||||||
// line 2146 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2145 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Expr)yyVals[0+yyTop]);
|
yyVal=((Expr)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 245:
|
case 245:
|
||||||
// line 2151 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2150 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Expr)yyVals[0+yyTop]);
|
yyVal=((Expr)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 246:
|
case 246:
|
||||||
// line 2156 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2155 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Expr)yyVals[0+yyTop]);
|
yyVal=((Expr)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 248:
|
case 248:
|
||||||
// line 2162 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2161 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Literal)yyVals[0+yyTop]);
|
yyVal=((Literal)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 249:
|
case 249:
|
||||||
// line 2166 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2165 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
This T = new This(((Token)yyVals[0+yyTop]).getOffset(),((Token)yyVals[0+yyTop]).getLexem().length());
|
This T = new This(((Token)yyVals[0+yyTop]).getOffset(),((Token)yyVals[0+yyTop]).getLexem().length());
|
||||||
UsedId UT = new UsedId(((Token)yyVals[0+yyTop]).getOffset());
|
UsedId UT = new UsedId(((Token)yyVals[0+yyTop]).getOffset());
|
||||||
@ -2876,23 +2876,23 @@ case 249:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 250:
|
case 250:
|
||||||
// line 2187 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2186 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((MethodCall)yyVals[0+yyTop]);
|
yyVal=((MethodCall)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 251:
|
case 251:
|
||||||
// line 2191 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2190 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Expr)yyVals[0+yyTop]);
|
yyVal=((Expr)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 252:
|
case 252:
|
||||||
// line 2196 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2195 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{yyVal=((Expr)yyVals[0+yyTop]);}
|
{yyVal=((Expr)yyVals[0+yyTop]);}
|
||||||
break;
|
break;
|
||||||
case 253:
|
case 253:
|
||||||
// line 2198 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2197 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{NotExpr NE=new NotExpr(((Expr)yyVals[0+yyTop]).getOffset(),((Expr)yyVals[0+yyTop]).getVariableLength());
|
{NotExpr NE=new NotExpr(((Expr)yyVals[0+yyTop]).getOffset(),((Expr)yyVals[0+yyTop]).getVariableLength());
|
||||||
UnaryNot UN=new UnaryNot();
|
UnaryNot UN=new UnaryNot();
|
||||||
NE.set_UnaryNot(UN);
|
NE.set_UnaryNot(UN);
|
||||||
@ -2901,36 +2901,36 @@ case 253:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 254:
|
case 254:
|
||||||
// line 2204 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2203 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{yyVal=((CastExpr)yyVals[0+yyTop]);}
|
{yyVal=((CastExpr)yyVals[0+yyTop]);}
|
||||||
break;
|
break;
|
||||||
case 255:
|
case 255:
|
||||||
// line 2206 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2205 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{yyVal=((Expr)yyVals[0+yyTop]);}
|
{yyVal=((Expr)yyVals[0+yyTop]);}
|
||||||
break;
|
break;
|
||||||
case 257:
|
case 257:
|
||||||
// line 2211 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2210 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{IntLiteral IL = new IntLiteral();
|
{IntLiteral IL = new IntLiteral();
|
||||||
IL.set_Int(((Token)yyVals[0+yyTop]).String2Int());
|
IL.set_Int(((Token)yyVals[0+yyTop]).String2Int());
|
||||||
yyVal = IL;
|
yyVal = IL;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 258:
|
case 258:
|
||||||
// line 2216 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2215 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{BoolLiteral BL = new BoolLiteral();
|
{BoolLiteral BL = new BoolLiteral();
|
||||||
BL.set_Bool(((Token)yyVals[0+yyTop]).String2Bool());
|
BL.set_Bool(((Token)yyVals[0+yyTop]).String2Bool());
|
||||||
yyVal = BL;
|
yyVal = BL;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 259:
|
case 259:
|
||||||
// line 2220 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2219 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{CharLiteral CL = new CharLiteral();
|
{CharLiteral CL = new CharLiteral();
|
||||||
CL.set_Char(((Token)yyVals[0+yyTop]).CharInString());
|
CL.set_Char(((Token)yyVals[0+yyTop]).CharInString());
|
||||||
yyVal=CL;
|
yyVal=CL;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 260:
|
case 260:
|
||||||
// line 2225 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2224 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
StringLiteral ST = new StringLiteral();
|
StringLiteral ST = new StringLiteral();
|
||||||
ST.set_String(((Token)yyVals[0+yyTop]).get_String());
|
ST.set_String(((Token)yyVals[0+yyTop]).get_String());
|
||||||
@ -2938,14 +2938,14 @@ case 260:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 261:
|
case 261:
|
||||||
// line 2230 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2229 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{ LongLiteral LL = new LongLiteral();
|
{ LongLiteral LL = new LongLiteral();
|
||||||
LL.set_Long(((Token)yyVals[0+yyTop]).String2Long());
|
LL.set_Long(((Token)yyVals[0+yyTop]).String2Long());
|
||||||
yyVal = LL;
|
yyVal = LL;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 262:
|
case 262:
|
||||||
// line 2234 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2233 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
FloatLiteral FL = new FloatLiteral();
|
FloatLiteral FL = new FloatLiteral();
|
||||||
FL.set_Float(((Token)yyVals[0+yyTop]).String2Float());
|
FL.set_Float(((Token)yyVals[0+yyTop]).String2Float());
|
||||||
@ -2953,7 +2953,7 @@ case 262:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 263:
|
case 263:
|
||||||
// line 2239 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2238 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
DoubleLiteral DL = new DoubleLiteral();
|
DoubleLiteral DL = new DoubleLiteral();
|
||||||
DL.set_Double(((Token)yyVals[0+yyTop]).String2Double());
|
DL.set_Double(((Token)yyVals[0+yyTop]).String2Double());
|
||||||
@ -2961,14 +2961,14 @@ case 263:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 264:
|
case 264:
|
||||||
// line 2245 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2244 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
Null NN = new Null();
|
Null NN = new Null();
|
||||||
yyVal=NN;
|
yyVal=NN;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 265:
|
case 265:
|
||||||
// line 2251 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2250 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
CastExpr CaEx=new CastExpr(((Expr)yyVals[0+yyTop]).getOffset(),((Expr)yyVals[0+yyTop]).getVariableLength());
|
CastExpr CaEx=new CastExpr(((Expr)yyVals[0+yyTop]).getOffset(),((Expr)yyVals[0+yyTop]).getVariableLength());
|
||||||
CaEx.set_Type(((BaseType)yyVals[-2+yyTop]));
|
CaEx.set_Type(((BaseType)yyVals[-2+yyTop]));
|
||||||
@ -2977,24 +2977,24 @@ case 265:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 266:
|
case 266:
|
||||||
// line 2260 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2259 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Expr)yyVals[0+yyTop]);
|
yyVal=((Expr)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 267:
|
case 267:
|
||||||
// line 2264 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2263 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 268:
|
case 268:
|
||||||
// line 2268 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2267 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Expr)yyVals[0+yyTop]);
|
yyVal=((Expr)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 269:
|
case 269:
|
||||||
// line 2272 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2271 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
Binary EQ = new Binary(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
Binary EQ = new Binary(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
||||||
EqualOp EO = new EqualOp(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
EqualOp EO = new EqualOp(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
||||||
@ -3006,7 +3006,7 @@ case 269:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 270:
|
case 270:
|
||||||
// line 2282 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2281 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
Binary NEQ = new Binary(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
Binary NEQ = new Binary(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
||||||
NotEqualOp NEO = new NotEqualOp(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
NotEqualOp NEO = new NotEqualOp(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
||||||
@ -3018,13 +3018,13 @@ case 270:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 271:
|
case 271:
|
||||||
// line 2293 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2292 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Expr)yyVals[0+yyTop]);
|
yyVal=((Expr)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 272:
|
case 272:
|
||||||
// line 2297 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2296 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
Binary LO = new Binary(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
Binary LO = new Binary(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
||||||
LessOp LOO = new LessOp(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
LessOp LOO = new LessOp(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
||||||
@ -3036,7 +3036,7 @@ case 272:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 273:
|
case 273:
|
||||||
// line 2307 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2306 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
Binary GO = new Binary(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
Binary GO = new Binary(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
||||||
GreaterOp GOO = new GreaterOp(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
GreaterOp GOO = new GreaterOp(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
||||||
@ -3048,7 +3048,7 @@ case 273:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 274:
|
case 274:
|
||||||
// line 2317 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2316 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
Binary LE = new Binary(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
Binary LE = new Binary(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
||||||
LessEquOp LEO = new LessEquOp(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
LessEquOp LEO = new LessEquOp(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
||||||
@ -3060,7 +3060,7 @@ case 274:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 275:
|
case 275:
|
||||||
// line 2327 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2326 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
Binary GE = new Binary(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
Binary GE = new Binary(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
||||||
GreaterEquOp GEO = new GreaterEquOp(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
GreaterEquOp GEO = new GreaterEquOp(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
||||||
@ -3072,7 +3072,7 @@ case 275:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 276:
|
case 276:
|
||||||
// line 2337 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2336 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
InstanceOf ISO=new InstanceOf(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
InstanceOf ISO=new InstanceOf(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
||||||
ISO.set_Expr(((Expr)yyVals[-2+yyTop]));
|
ISO.set_Expr(((Expr)yyVals[-2+yyTop]));
|
||||||
@ -3081,19 +3081,19 @@ case 276:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 277:
|
case 277:
|
||||||
// line 2345 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2344 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Expr)yyVals[0+yyTop]);
|
yyVal=((Expr)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 278:
|
case 278:
|
||||||
// line 2350 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2349 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Expr)yyVals[0+yyTop]);
|
yyVal=((Expr)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 279:
|
case 279:
|
||||||
// line 2354 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2353 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
Binary AD = new Binary(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
Binary AD = new Binary(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
||||||
PlusOp PO = new PlusOp(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
PlusOp PO = new PlusOp(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
||||||
@ -3105,7 +3105,7 @@ case 279:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 280:
|
case 280:
|
||||||
// line 2364 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2363 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
Binary MI = new Binary(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
Binary MI = new Binary(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
||||||
MinusOp MO = new MinusOp(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
MinusOp MO = new MinusOp(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
||||||
@ -3117,13 +3117,13 @@ case 280:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 281:
|
case 281:
|
||||||
// line 2375 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2374 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
yyVal=((Expr)yyVals[0+yyTop]);
|
yyVal=((Expr)yyVals[0+yyTop]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 282:
|
case 282:
|
||||||
// line 2379 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2378 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
Binary ML = new Binary(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
Binary ML = new Binary(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
||||||
TimesOp TO = new TimesOp(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
TimesOp TO = new TimesOp(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
||||||
@ -3135,7 +3135,7 @@ case 282:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 283:
|
case 283:
|
||||||
// line 2389 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2388 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
Binary DV = new Binary(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
Binary DV = new Binary(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
||||||
DivideOp DO = new DivideOp(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
DivideOp DO = new DivideOp(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
||||||
@ -3147,7 +3147,7 @@ case 283:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 284:
|
case 284:
|
||||||
// line 2399 "./../src/mycompiler/myparser/JavaParser.jay"
|
// line 2398 "./../src/mycompiler/myparser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
Binary MD = new Binary(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
Binary MD = new Binary(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
||||||
ModuloOp MO = new ModuloOp(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
ModuloOp MO = new ModuloOp(((Expr)yyVals[-2+yyTop]).getOffset(),((Expr)yyVals[-2+yyTop]).getVariableLength());
|
||||||
|
@ -1330,7 +1330,6 @@ primitivetype :BOOLEAN
|
|||||||
$$=$1;
|
$$=$1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
referencetype :classorinterfacetype
|
referencetype :classorinterfacetype
|
||||||
{
|
{
|
||||||
org.apache.log4j.Logger.getLogger("parser").debug("T->Parser->referenctype: " + $1);
|
org.apache.log4j.Logger.getLogger("parser").debug("T->Parser->referenctype: " + $1);
|
||||||
|
@ -26,6 +26,7 @@ import mycompiler.myexception.JVMCodeException;
|
|||||||
import mycompiler.myexception.SCStatementException;
|
import mycompiler.myexception.SCStatementException;
|
||||||
import mycompiler.mytype.DoubleType;
|
import mycompiler.mytype.DoubleType;
|
||||||
import mycompiler.mytype.GenericTypeVar;
|
import mycompiler.mytype.GenericTypeVar;
|
||||||
|
import mycompiler.mytype.RefType;
|
||||||
import mycompiler.mytype.Type;
|
import mycompiler.mytype.Type;
|
||||||
import mycompiler.mytype.TypePlaceholder;
|
import mycompiler.mytype.TypePlaceholder;
|
||||||
import mycompiler.mytypereconstruction.CSupportData;
|
import mycompiler.mytypereconstruction.CSupportData;
|
||||||
@ -85,7 +86,10 @@ public class LambdaExpression extends Expr{
|
|||||||
Block block = this.method_body;
|
Block block = this.method_body;
|
||||||
// Zuerst Returntype untersuchen
|
// Zuerst Returntype untersuchen
|
||||||
Type returnType=getType();
|
Type returnType=getType();
|
||||||
GenericTypeVar pendantReturnType=ClassHelper.findGenericType(returnType, paralist,genericMethodParameters);
|
Type pendantReturnType = null;
|
||||||
|
if(returnType instanceof RefType)
|
||||||
|
pendantReturnType = ((RefType)returnType).findGenericType(paralist, new Vector<GenericTypeVar>());
|
||||||
|
//GenericTypeVar pendantReturnType=ClassHelper.findGenericType(returnType, paralist,genericMethodParameters);
|
||||||
if(pendantReturnType!=null){ //Wenn generisch, dann modifizieren
|
if(pendantReturnType!=null){ //Wenn generisch, dann modifizieren
|
||||||
setType(pendantReturnType);
|
setType(pendantReturnType);
|
||||||
}
|
}
|
||||||
@ -94,7 +98,10 @@ public class LambdaExpression extends Expr{
|
|||||||
for(FormalParameter fp : params){
|
for(FormalParameter fp : params){
|
||||||
Type fpType=fp.getType();
|
Type fpType=fp.getType();
|
||||||
// Nur wenn es sich um ein RefType-Field handelt
|
// Nur wenn es sich um ein RefType-Field handelt
|
||||||
GenericTypeVar pendantPara=ClassHelper.findGenericType(fpType,paralist,genericMethodParameters);
|
Type pendantPara = null;
|
||||||
|
if(fpType instanceof RefType)
|
||||||
|
pendantPara = ((RefType)fpType).findGenericType(paralist, new Vector<GenericTypeVar>());
|
||||||
|
//GenericTypeVar pendantPara=ClassHelper.findGenericType(fpType,paralist,genericMethodParameters);
|
||||||
if(pendantPara!=null){ //Wenn generisch, dann modifizieren
|
if(pendantPara!=null){ //Wenn generisch, dann modifizieren
|
||||||
fp.setType(pendantPara);
|
fp.setType(pendantPara);
|
||||||
}
|
}
|
||||||
|
@ -427,7 +427,10 @@ public class LocalVarDecl extends Statement implements TypeInsertable
|
|||||||
|
|
||||||
Type fpType=getType();
|
Type fpType=getType();
|
||||||
// Nur wenn es sich um ein RefType-Field handelt
|
// Nur wenn es sich um ein RefType-Field handelt
|
||||||
GenericTypeVar pendantPara=ClassHelper.findGenericType(fpType,paralist,genericMethodParameters);
|
Type pendantPara = null;
|
||||||
|
if(fpType instanceof RefType)
|
||||||
|
pendantPara = ((RefType)fpType).findGenericType(paralist, new Vector<GenericTypeVar>());
|
||||||
|
//GenericTypeVar pendantPara=ClassHelper.findGenericType(fpType,paralist,genericMethodParameters);
|
||||||
if(pendantPara!=null){ //Wenn generisch, dann modifizieren
|
if(pendantPara!=null){ //Wenn generisch, dann modifizieren
|
||||||
setType(pendantPara);
|
setType(pendantPara);
|
||||||
}
|
}
|
||||||
|
@ -18,6 +18,7 @@ import org.apache.log4j.Logger;
|
|||||||
// ino.end
|
// ino.end
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
import sun.reflect.generics.reflectiveObjects.NotImplementedException;
|
import sun.reflect.generics.reflectiveObjects.NotImplementedException;
|
||||||
import typinferenz.JavaCodeResult;
|
import typinferenz.JavaCodeResult;
|
||||||
import typinferenz.ResultSet;
|
import typinferenz.ResultSet;
|
||||||
@ -209,6 +210,41 @@ public class RefType extends Type implements IMatchable
|
|||||||
this.set_ParaList(paralist);
|
this.set_ParaList(paralist);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* HOTI
|
||||||
|
* Diese Methode sucht in der Klassendefinition nach einen GTV, die
|
||||||
|
* so heißt wie die im RefType definierte Variable. Wenn sie diese gefunden
|
||||||
|
* hat, wird sie zurückgeben. Wenn dies nicht der Fall war, schaut sie, falls
|
||||||
|
* angegeben in den Methodenparametern nach. Findet sie dort auch nichts, liefert
|
||||||
|
* die Methode <b>null</b>.
|
||||||
|
* @param type
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public GenericTypeVar findGenericType(Vector<Type> paralist, Vector<GenericTypeVar> methodParaList)
|
||||||
|
{
|
||||||
|
for(int i=0;i<paralist.size();i++){
|
||||||
|
if(paralist.get(i) instanceof GenericTypeVar){
|
||||||
|
GenericTypeVar gtv=(GenericTypeVar)paralist.get(i);
|
||||||
|
if(gtv.getName().equals(this.getName())){
|
||||||
|
return gtv;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(methodParaList!=null){
|
||||||
|
for(int i=0;i<methodParaList.size();i++){
|
||||||
|
GenericTypeVar gtv=methodParaList.elementAt(i);
|
||||||
|
if(gtv.getName().equals(this.getName())){
|
||||||
|
return gtv;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//Auch die Parameterliste nach GenericTypeVars durchsuchen:
|
||||||
|
if(this.get_ParaList() != null)for(Type t : this.get_ParaList()){
|
||||||
|
if(t instanceof RefType)((RefType)t).findGenericType(paralist, methodParaList);
|
||||||
|
}
|
||||||
|
return(null);
|
||||||
|
}
|
||||||
|
|
||||||
// ino.method.setName.26655.definition
|
// ino.method.setName.26655.definition
|
||||||
public void setName( String name )
|
public void setName( String name )
|
||||||
// ino.end
|
// ino.end
|
||||||
|
@ -2,6 +2,7 @@ package typinferenz;
|
|||||||
|
|
||||||
import java.util.Vector;
|
import java.util.Vector;
|
||||||
|
|
||||||
|
import typinferenz.assumptions.ClassAssumption;
|
||||||
import typinferenz.assumptions.MethodAssumption;
|
import typinferenz.assumptions.MethodAssumption;
|
||||||
import typinferenz.assumptions.TypeAssumptions;
|
import typinferenz.assumptions.TypeAssumptions;
|
||||||
import mycompiler.mytype.*;
|
import mycompiler.mytype.*;
|
||||||
@ -40,6 +41,7 @@ public class FunNInterface extends Class{
|
|||||||
//return super.getPublicFieldAssumptions();
|
//return super.getPublicFieldAssumptions();
|
||||||
TypeAssumptions ret = new TypeAssumptions();
|
TypeAssumptions ret = new TypeAssumptions();
|
||||||
ret.addAssumption(new MethodAssumption(this.getApplyFunction(), this));
|
ret.addAssumption(new MethodAssumption(this.getApplyFunction(), this));
|
||||||
|
ret.addClassAssumption(new ClassAssumption(this));
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -25,4 +25,11 @@ public class ClassAssumption{
|
|||||||
public String toString(){
|
public String toString(){
|
||||||
return this.classType.getName();
|
return this.classType.getName();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean equals(Object obj){
|
||||||
|
if(!(obj instanceof ClassAssumption))return false;
|
||||||
|
ClassAssumption equals = (ClassAssumption)obj;
|
||||||
|
if(!equals.classType.equals(this.classType))return false;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -10,5 +10,12 @@ public class ConstructorAssumption extends MethodAssumption{
|
|||||||
super(assumedMethod, parentClass);
|
super(assumedMethod, parentClass);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(Object obj) {
|
||||||
|
if(!(obj instanceof ConstructorAssumption))return false;
|
||||||
|
return super.equals(obj);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -27,6 +27,15 @@ public class FieldAssumption extends Assumption {
|
|||||||
public String toString(){
|
public String toString(){
|
||||||
return "FieldAssumption: "+this.field.getType()+" "+this.getIdentifier();
|
return "FieldAssumption: "+this.field.getType()+" "+this.getIdentifier();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(Object obj) {
|
||||||
|
if(!(obj instanceof FieldAssumption))return false;
|
||||||
|
FieldAssumption equals = (FieldAssumption)obj;
|
||||||
|
if(!equals.field.equals(this.field))return false;
|
||||||
|
if(!equals.parentClass.equals(this.parentClass))return false;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -16,4 +16,5 @@ public class LocalVarAssumption extends Assumption {
|
|||||||
public Type getAssumedType() {
|
public Type getAssumedType() {
|
||||||
return this.localVar.getType();
|
return this.localVar.getType();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -214,11 +214,18 @@ public class TypeAssumptions {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void addAssumption(Assumption ass){
|
public void addAssumption(Assumption ass){
|
||||||
if(ass instanceof MethodAssumption)this.methodAssumptions.add((MethodAssumption)ass);//if(!this.methodAssumptions.contains(ass))this.methodAssumptions.add((MethodAssumption)ass);
|
if(ass instanceof ConstructorAssumption){
|
||||||
if(ass instanceof FieldAssumption)this.fieldAssumptions.add((FieldAssumption)ass);//if(!this.fieldAssumptions.contains(ass))this.fieldAssumptions.add((FieldAssumption)ass);
|
if(!this.constructorAssumptions.contains(ass))this.constructorAssumptions.add((ConstructorAssumption)ass);//this.constructorAssumptions.add((ConstructorAssumption)ass);
|
||||||
if(ass instanceof LocalVarAssumption)this.localVarAssumptions.add((LocalVarAssumption)ass);//if(!this.localVarAssumptions.contains(ass))this.localVarAssumptions.add((LocalVarAssumption)ass);
|
return;
|
||||||
|
}
|
||||||
|
if(ass instanceof MethodAssumption){
|
||||||
|
if(!this.methodAssumptions.contains(ass))this.methodAssumptions.add((MethodAssumption)ass);//this.methodAssumptions.add((MethodAssumption)ass);//
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(ass instanceof LocalVarAssumption)if(!this.localVarAssumptions.contains(ass))this.localVarAssumptions.add((LocalVarAssumption)ass);//this.localVarAssumptions.add((LocalVarAssumption)ass);//
|
||||||
if(ass instanceof ParameterAssumption)if(!this.parameterAssumptions.contains(ass))this.parameterAssumptions.add((ParameterAssumption)ass);//this.parameterAssumptions.add((ParameterAssumption)ass);
|
if(ass instanceof ParameterAssumption)if(!this.parameterAssumptions.contains(ass))this.parameterAssumptions.add((ParameterAssumption)ass);//this.parameterAssumptions.add((ParameterAssumption)ass);
|
||||||
if(ass instanceof ConstructorAssumption)if(!this.constructorAssumptions.contains(ass))this.constructorAssumptions.add((ConstructorAssumption)ass);//this.constructorAssumptions.add((ConstructorAssumption)ass);
|
if(ass instanceof FieldAssumption)if(!this.fieldAssumptions.contains(ass))this.fieldAssumptions.add((FieldAssumption)ass);//this.fieldAssumptions.add((FieldAssumption)ass);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void addAllAssumptions(Vector<Assumption> assumptions){
|
private void addAllAssumptions(Vector<Assumption> assumptions){
|
||||||
@ -309,7 +316,8 @@ public class TypeAssumptions {
|
|||||||
* @param classAssumption
|
* @param classAssumption
|
||||||
*/
|
*/
|
||||||
public void addClassAssumption(ClassAssumption classAssumption) {
|
public void addClassAssumption(ClassAssumption classAssumption) {
|
||||||
this.classAssumptions.add(classAssumption);
|
if(!this.classAssumptions.contains(classAssumption))//throw new TypinferenzException("Die Klasse "+classAssumption.getAssumedClass().getName()+" wurde bereits deklariert");
|
||||||
|
this.classAssumptions.add(classAssumption);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
File diff suppressed because one or more lines are too long
@ -1,7 +1,7 @@
|
|||||||
|
|
||||||
class VariableTypeInsertTest{
|
class VariableTypeInsertTest{
|
||||||
String var;
|
String var;
|
||||||
void methode(String test){
|
void methode(java.lang.String test){
|
||||||
var = test;
|
var = test;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -9,10 +9,10 @@ class FunNInsertTest{
|
|||||||
var3 = c;
|
var3 = c;
|
||||||
};
|
};
|
||||||
|
|
||||||
o2p = () -> (a, b, c) -> {
|
|
||||||
var1 = a;
|
|
||||||
var2 = b;
|
|
||||||
var3 = c;
|
|
||||||
};
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
class Object1{}
|
||||||
|
class Object2{}
|
||||||
|
class Object3{}
|
@ -1,5 +1,5 @@
|
|||||||
class LambdaTest{
|
class LambdaTest<R,S>{
|
||||||
|
|
||||||
Fun1<Fun1<K, Fun2<LambdaTest, C>>, C> op = (m) -> (f) -> f.apply(this,m);
|
Fun1<Fun1<R, Fun2<R, LambdaTest<R,S>, S>>, S> op = (m) -> (f) -> f.apply(this,m);
|
||||||
|
|
||||||
}
|
}
|
@ -11,7 +11,7 @@ public class LambdaTest2 {
|
|||||||
@Test
|
@Test
|
||||||
public void run(){
|
public void run(){
|
||||||
Vector<String> mustContain = new Vector<String>();
|
Vector<String> mustContain = new Vector<String>();
|
||||||
mustContain.add("C m");
|
mustContain.add("S m");
|
||||||
MultipleTypesInsertTester.test(this.TEST_FILE, mustContain);
|
MultipleTypesInsertTester.test(this.TEST_FILE, mustContain);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
5
test/plugindevelopment/TypeInsertTests/LambdaTest5.jav
Normal file
5
test/plugindevelopment/TypeInsertTests/LambdaTest5.jav
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
class LambdaTest<A>{
|
||||||
|
|
||||||
|
Fun1<A, A> op = (var) -> {return var;};
|
||||||
|
|
||||||
|
}
|
18
test/plugindevelopment/TypeInsertTests/LambdaTest5.java
Normal file
18
test/plugindevelopment/TypeInsertTests/LambdaTest5.java
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
package plugindevelopment.TypeInsertTests;
|
||||||
|
|
||||||
|
import java.util.Vector;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
public class LambdaTest5 {
|
||||||
|
|
||||||
|
private static final String TEST_FILE = "LambdaTest5.jav";
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void run(){
|
||||||
|
Vector<String> mustContain = new Vector<String>();
|
||||||
|
mustContain.add("A var");
|
||||||
|
MultipleTypesInsertTester.test(this.TEST_FILE, mustContain);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user