Parser geändert
This commit is contained in:
parent
053edc0f73
commit
bbb3cf76d9
7
bin/.gitignore
vendored
7
bin/.gitignore
vendored
@ -1,9 +1,6 @@
|
|||||||
/bytecode
|
/bytecode
|
||||||
/log4jTesting.xml
|
|
||||||
/mycompiler
|
/mycompiler
|
||||||
/typinferenz
|
|
||||||
/userinterface
|
|
||||||
/myJvmDisassembler
|
|
||||||
/parser
|
|
||||||
/plugindevelopment
|
/plugindevelopment
|
||||||
/syntaxTree
|
/syntaxTree
|
||||||
|
/typinferenz
|
||||||
|
/parser
|
||||||
|
@ -169,6 +169,5 @@ null {
|
|||||||
{ws}|\n { /* System.out.print(yytext()); */ }
|
{ws}|\n { /* System.out.print(yytext()); */ }
|
||||||
\\.\n {org.apache.log4j.Logger.getLogger("parser").debug("Kommentar: "+yytext());}
|
\\.\n {org.apache.log4j.Logger.getLogger("parser").debug("Kommentar: "+yytext());}
|
||||||
"->" {this.token = new Token(JavaParser.LAMBDAASSIGNMENT, yytext(), yyline, yychar);return true;}
|
"->" {this.token = new Token(JavaParser.LAMBDAASSIGNMENT, yytext(), yyline, yychar);return true;}
|
||||||
">" {this.token = new Token(JavaParser.ENDOFGENERICVARDECLARATION, yytext(), yyline, yychar);return true;}
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -300,7 +300,7 @@ public Vector<Pair> testPair = new Vector<Pair>();
|
|||||||
%type <GenericTypeVar> boundedMethodParameter;
|
%type <GenericTypeVar> boundedMethodParameter;
|
||||||
%type <GenericTypeVar> boundedClassParameter;
|
%type <GenericTypeVar> boundedClassParameter;
|
||||||
%type <Vector> boundedclassidentifierlist //Vector<Type>
|
%type <Vector> boundedclassidentifierlist //Vector<Type>
|
||||||
%type <Vector> boundedMethodParameters; // Vector<GenericTypeVar>
|
%type <GenericVarDeclarationList> boundedMethodParameters; // Vector
|
||||||
%type <ParaList> boundedClassParameters; // ParaList
|
%type <ParaList> boundedClassParameters; // ParaList
|
||||||
%type <UsedId> packagedeclaration
|
%type <UsedId> packagedeclaration
|
||||||
%type <Assign> assignment
|
%type <Assign> assignment
|
||||||
@ -903,11 +903,16 @@ fielddeclarator :
|
|||||||
ret.setWert($3);
|
ret.setWert($3);
|
||||||
$$=ret;
|
$$=ret;
|
||||||
}
|
}
|
||||||
|
| variabledeclarator
|
||||||
|
|
||||||
genericdeclarationlist : '<' boundedMethodParameters ENDOFGENERICVARDECLARATION
|
|
||||||
{
|
{
|
||||||
GenericDeclarationList ret = new GenericDeclarationList($2,$3.getOffset());
|
FieldDeclaration ret = new FieldDeclaration($1.getOffset());
|
||||||
|
ret.set_DeclId($1);
|
||||||
|
$$=ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
genericdeclarationlist : '<' boundedMethodParameters '>'
|
||||||
|
{
|
||||||
|
GenericDeclarationList ret = new GenericDeclarationList($2.getElements(),$2.getEndOffset());
|
||||||
$$ = ret;
|
$$ = ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1064,7 +1069,7 @@ boundedclassidentifierlist : referencetype
|
|||||||
// returns Vector<Type>
|
// returns Vector<Type>
|
||||||
boundedMethodParameters : boundedMethodParameter
|
boundedMethodParameters : boundedMethodParameter
|
||||||
{
|
{
|
||||||
Vector<Type> vec=new Vector<Type>();
|
GenericVarDeclarationList vec=new GenericVarDeclarationList();
|
||||||
vec.addElement($1);
|
vec.addElement($1);
|
||||||
$$=vec;
|
$$=vec;
|
||||||
}
|
}
|
||||||
|
@ -2,6 +2,7 @@ package mycompiler.myclass;
|
|||||||
|
|
||||||
import java.util.Vector;
|
import java.util.Vector;
|
||||||
|
|
||||||
|
import mycompiler.myparser.GenericVarDeclarationList;
|
||||||
import mycompiler.mytype.GenericTypeVar;
|
import mycompiler.mytype.GenericTypeVar;
|
||||||
|
|
||||||
|
|
||||||
@ -13,8 +14,14 @@ import mycompiler.mytype.GenericTypeVar;
|
|||||||
*/
|
*/
|
||||||
public class GenericDeclarationList extends Vector<GenericTypeVar>{
|
public class GenericDeclarationList extends Vector<GenericTypeVar>{
|
||||||
|
|
||||||
public GenericDeclarationList(Vector<GenericTypeVar> vector, int offset) {
|
private int offsetOfLastElement;
|
||||||
// TODO Auto-generated constructor stub
|
|
||||||
|
public GenericDeclarationList(Vector<GenericTypeVar> values, int offset) {
|
||||||
|
this.addAll(values);
|
||||||
|
this.offsetOfLastElement = offset;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public int getOffsetOfLastElement(){
|
||||||
|
return offsetOfLastElement;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
26
src/mycompiler/myparser/GenericVarDeclarationList.java
Normal file
26
src/mycompiler/myparser/GenericVarDeclarationList.java
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
package mycompiler.myparser;
|
||||||
|
|
||||||
|
import java.util.Vector;
|
||||||
|
|
||||||
|
import typinferenz.exceptions.DebugException;
|
||||||
|
import mycompiler.mytype.GenericTypeVar;
|
||||||
|
|
||||||
|
public class GenericVarDeclarationList {
|
||||||
|
|
||||||
|
private Vector<GenericTypeVar> elements = new Vector<>();
|
||||||
|
|
||||||
|
public void addElement(GenericTypeVar e){
|
||||||
|
elements.addElement(e);
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getEndOffset() {
|
||||||
|
int ret;
|
||||||
|
if(elements.isEmpty())throw new DebugException("Es wurde eine GenericVarDeclarationList ohne Elemente geparst");
|
||||||
|
ret = elements.lastElement().getOffset() + elements.lastElement().getName().length();
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Vector<GenericTypeVar> getElements(){
|
||||||
|
return elements;
|
||||||
|
}
|
||||||
|
}
|
@ -169,6 +169,5 @@ null {
|
|||||||
{ws}|\n { /* System.out.print(yytext()); */ }
|
{ws}|\n { /* System.out.print(yytext()); */ }
|
||||||
\\.\n {org.apache.log4j.Logger.getLogger("parser").debug("Kommentar: "+yytext());}
|
\\.\n {org.apache.log4j.Logger.getLogger("parser").debug("Kommentar: "+yytext());}
|
||||||
"->" {this.token = new Token(JavaParser.LAMBDAASSIGNMENT, yytext(), yyline, yychar);return true;}
|
"->" {this.token = new Token(JavaParser.LAMBDAASSIGNMENT, yytext(), yyline, yychar);return true;}
|
||||||
">" {this.token = new Token(JavaParser.ENDOFGENERICVARDECLARATION, yytext(), yyline, yychar);return true;}
|
|
||||||
|
|
||||||
|
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -300,7 +300,7 @@ public Vector<Pair> testPair = new Vector<Pair>();
|
|||||||
%type <GenericTypeVar> boundedMethodParameter;
|
%type <GenericTypeVar> boundedMethodParameter;
|
||||||
%type <GenericTypeVar> boundedClassParameter;
|
%type <GenericTypeVar> boundedClassParameter;
|
||||||
%type <Vector> boundedclassidentifierlist //Vector<Type>
|
%type <Vector> boundedclassidentifierlist //Vector<Type>
|
||||||
%type <Vector> boundedMethodParameters; // Vector<GenericTypeVar>
|
%type <GenericVarDeclarationList> boundedMethodParameters; // Vector
|
||||||
%type <ParaList> boundedClassParameters; // ParaList
|
%type <ParaList> boundedClassParameters; // ParaList
|
||||||
%type <UsedId> packagedeclaration
|
%type <UsedId> packagedeclaration
|
||||||
%type <Assign> assignment
|
%type <Assign> assignment
|
||||||
@ -903,11 +903,16 @@ fielddeclarator :
|
|||||||
ret.setWert($3);
|
ret.setWert($3);
|
||||||
$$=ret;
|
$$=ret;
|
||||||
}
|
}
|
||||||
|
| variabledeclarator
|
||||||
|
|
||||||
genericdeclarationlist : '<' boundedMethodParameters ENDOFGENERICVARDECLARATION
|
|
||||||
{
|
{
|
||||||
GenericDeclarationList ret = new GenericDeclarationList($2,$3.getOffset());
|
FieldDeclaration ret = new FieldDeclaration($1.getOffset());
|
||||||
|
ret.set_DeclId($1);
|
||||||
|
$$=ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
genericdeclarationlist : '<' boundedMethodParameters '>'
|
||||||
|
{
|
||||||
|
GenericDeclarationList ret = new GenericDeclarationList($2.getElements(),$2.getEndOffset());
|
||||||
$$ = ret;
|
$$ = ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1064,7 +1069,7 @@ boundedclassidentifierlist : referencetype
|
|||||||
// returns Vector<Type>
|
// returns Vector<Type>
|
||||||
boundedMethodParameters : boundedMethodParameter
|
boundedMethodParameters : boundedMethodParameter
|
||||||
{
|
{
|
||||||
Vector<Type> vec=new Vector<Type>();
|
GenericVarDeclarationList vec=new GenericVarDeclarationList();
|
||||||
vec.addElement($1);
|
vec.addElement($1);
|
||||||
$$=vec;
|
$$=vec;
|
||||||
}
|
}
|
||||||
|
@ -774,6 +774,7 @@ public class RefType extends Type implements IMatchable
|
|||||||
@Override
|
@Override
|
||||||
public Vector<TypePlaceholder> getInvolvedTypePlaceholder() {
|
public Vector<TypePlaceholder> getInvolvedTypePlaceholder() {
|
||||||
Vector<TypePlaceholder> ret = super.getInvolvedTypePlaceholder();
|
Vector<TypePlaceholder> ret = super.getInvolvedTypePlaceholder();
|
||||||
|
if(this.parameter == null)return ret;
|
||||||
for(Type param : this.parameter){
|
for(Type param : this.parameter){
|
||||||
ret.addAll(param.getInvolvedTypePlaceholder());
|
ret.addAll(param.getInvolvedTypePlaceholder());
|
||||||
}
|
}
|
||||||
|
@ -29,8 +29,8 @@ public class GeneralParserTest{
|
|||||||
public void run(){
|
public void run(){
|
||||||
Vector<String> filenames = new Vector<String>();
|
Vector<String> filenames = new Vector<String>();
|
||||||
filenames.add("FieldInitializationTest.jav");
|
filenames.add("FieldInitializationTest.jav");
|
||||||
//filenames.add("ImportTest.jav");
|
filenames.add("ImportTest.jav");
|
||||||
//filenames.add("BoundedParameter.jav");
|
filenames.add("BoundedParameter.jav");
|
||||||
filenames.add("GenericFieldVarTest.jav");
|
filenames.add("GenericFieldVarTest.jav");
|
||||||
MyCompilerAPI compiler = MyCompiler.getAPI();
|
MyCompilerAPI compiler = MyCompiler.getAPI();
|
||||||
try{
|
try{
|
||||||
|
Loading…
Reference in New Issue
Block a user