2014-02-11 01:47:39 +00:00
|
|
|
|
package mycompiler;
|
|
|
|
|
|
2014-02-11 15:30:38 +00:00
|
|
|
|
import java.util.Vector;
|
2014-02-19 04:20:54 +00:00
|
|
|
|
|
|
|
|
|
import typinferenz.TypinferenzException;
|
2014-02-14 16:31:55 +00:00
|
|
|
|
import mycompiler.myclass.Class;
|
2014-02-11 15:30:38 +00:00
|
|
|
|
|
2014-02-12 01:12:12 +00:00
|
|
|
|
public abstract class SyntaxTreeNode {
|
|
|
|
|
|
2014-02-19 04:20:54 +00:00
|
|
|
|
protected SyntaxTreeNode parent;
|
2014-02-11 01:47:39 +00:00
|
|
|
|
|
2014-02-11 15:30:38 +00:00
|
|
|
|
/**
|
|
|
|
|
* Wird nach dem Parsen aufgerufen.
|
|
|
|
|
* Erf<EFBFBD>llt folgenden Aufgaben:
|
|
|
|
|
* 1. F<EFBFBD>llt fehlende Typangaben mit TPHs auf.
|
|
|
|
|
* 2. Verkn<EFBFBD>pft die Knoten des Syntaxbaums. (setzt Parent)
|
|
|
|
|
*
|
|
|
|
|
*/
|
2014-02-12 01:12:12 +00:00
|
|
|
|
public void parserPostProcessing(SyntaxTreeNode parent) {
|
|
|
|
|
this.parent = parent;
|
|
|
|
|
for(SyntaxTreeNode node : this.getChildren())node.parserPostProcessing(this);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public SyntaxTreeNode getParent() {
|
|
|
|
|
return this.parent;
|
|
|
|
|
}
|
2014-02-11 15:30:38 +00:00
|
|
|
|
|
2014-02-19 22:04:48 +00:00
|
|
|
|
public abstract Vector<SyntaxTreeNode> getChildren();
|
2014-02-14 16:31:55 +00:00
|
|
|
|
|
|
|
|
|
public Class getParentClass(){
|
|
|
|
|
SyntaxTreeNode parent = this.getParent();
|
|
|
|
|
if(parent instanceof Class)return (Class)parent;
|
2014-02-19 04:20:54 +00:00
|
|
|
|
if(parent == null)throw new TypinferenzException("Das Wurzelelement eines Syntaxbaumes muss Class sein");
|
2014-02-14 16:31:55 +00:00
|
|
|
|
return parent.getParentClass();
|
|
|
|
|
}
|
2014-03-12 14:27:26 +00:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Eine Beschreibung/Name des SyntaxTree-Nodes
|
|
|
|
|
* @return
|
|
|
|
|
*/
|
|
|
|
|
public String getDescription(){
|
|
|
|
|
return this.toString();
|
|
|
|
|
}
|
2014-02-11 01:47:39 +00:00
|
|
|
|
}
|