Packagenamen - Grundsätzliches Problem #186
Labels
No Label
Codegen
confirmed
duplicate
Eclipse-Plugin
Feature Request
generics
in progress
invalid
JavaCompilerCore
needs info
Parser
Trash
Type
Unify
won't fix
works for me
No Milestone
No project
No Assignees
2 Participants
Notifications
Due Date
No due date set.
Dependencies
No dependencies set.
Reference: JavaTX/JavaCompilerCore#186
Loading…
Reference in New Issue
Block a user
No description provided.
Delete Branch "%!s()"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
im Moment ist das Problem, dass bei importierten Paketen (z.B. java.util.Vector) nicht festgelegt ob mit dem qualifizierten Namen oder ohne unifiziert wird.
z.B. wird java.util.Vector<java.util.Vector> als Vector<java.util.Vector> im FC in die Unifikation gegeben.
Das muss grundsätzlich geklärt werden.
Vorschlag: Wir arbeiten mit qualifizierten Namen. D.h.:
Vector<Vector> wird nach dem Parsen in java.util.Vector<java.util.Vector<java.lang.Integer>> umgewandelt.
Ich hab das mal versucht umzubauen, dass nur noch die qualifizierten Namen verwendet werden.
Das Problem ist hier der Aufbau, wie der Sourcecode momentan von unserem Compiler eingelesen wird.
Meiner Meinung nach sollte im Parserschritt einfach mehr passieren. Bisher macht der Parser eben ausschließlich parsen und liefert nur mäßig nützlichen Output.
Er erkennt Generische Variablen nicht, er erkennt den Konstruktor nicht, er löst die Typbezeichnungen nicht mit ihrem vollen Qualifizierten Namen auf, etc.
Daher hab ich mal so ein "parserPostProcessing" gebastelt.
Problem ist, dass bei diesem Schritt das TypeAssumption-Set noch nicht feststeht. Dieses wird gebraucht um beispielsweise Vector zu java.util.Vector aufzulösen.
Momentan werden daher die Namen erst während der TYPE Methode aufgelöst. Die FC wird aber noch vor der TYPE Methode erstellt. Dein Problem kann man wohl beheben, indem man die FC erst vor der Unifizierung erstellt.
Ein Grundsätzliches Problem bleibt, nämlich der verkorkste Workflow unserer Compilers, der momentan folgendermaßen aussieht:
Mein Vorschlag wäre (falls wirklich mal jemand das ANTLR-Parserprojekt in Angriff nimmt) die Punkte 1, 2, 3 und 5 alle in den Parser und das anschließende abstrakte Syntaxbaum Bauen zu verschieben. Dann passieren vielleicht auch solche Fehler nicht mehr.
*** Bug 47 has been marked as a duplicate of this bug. ***
OLD BUG