forked from JavaTX/JavaCompilerCore
Pattern Matching in JavaTX
.externalToolBuilders | ||
.settings | ||
bin | ||
doc | ||
examples | ||
lib | ||
notizen | ||
Papers/FMCO2005 | ||
src | ||
test | ||
tools | ||
.classpath | ||
.cvsignore | ||
.gitignore | ||
.project | ||
log4j.xml | ||
Readme.md | ||
README.me |
Typinferenz
ResultSet
-
Spezifisch für jedes SourceFile (nicht für jede Klasse)
-
mehrere ResultSets pro Klasse
-
Enthält:
- constraintPairs
- unifiedConstraints
TypeInsertSet
- Stellt die Typeinsetzung für eine der generierten Lösungen dar
- Setzt alle Typen und generischen Variablen ein, welche zu dieser Lösung gehören
Ablauf Typinferenz:
-
Parsen
- (Parser postProcessing)
-
Typinferenz
- Anfangspunkt SourceFile
- löst geparste Typen zu richtigen Typen auf (RefTypes, GenericVar)
- setzt TPHs ein
- bildet Constraints, welche in ResultSet gesammelt werden. ResultSet wird durch Syntaxbaum gereicht.
- Assumptions generieren
- Wird im Syntaxbaum für jeden Knoten ausgeführt und die Assumptions für darunterliegende Knoten gebildet
-
Unifizierung
- wird im SourceFile aufgerufen
- unifiziert Constraints aller im SourceFile vorkommenden Klassen
-
Erstellen von TypeInsertSet
- Durchlaufen des Syntaxbaumes
- Jeder Knoten erstellt TypeInsertSets anhand des ResultSets.
- Bei nichtauflösung eines TPH muss GenericVar eingesetzt werden:
- Dazu alle Abhängigkeite in Form von Pairs aus dem ResultSet ermitteln.
- GenericVarTypeInsertPoints generieren und in TypeInsertSet speichern.
- Beim Hinzufügen von GenericVarTypeInsertPoints wird kontrolliert, ob diese bereits (auch in Teilen) schon vorhanden sind.
-
Einsetzen eines TypeInsertSet (optional)
- Auf allen TypeInsertPoints die getUnresolvedTPHs-Methoden aufrufen
- Alle Abhängigkeiten dieser