R-GReQL-Grammatik
In der Knotenstruktur kommen abstrakte Knoten vor. Das heißt, dass von ihnen keine direkten Instanzen im Graphen vorkommen, bzw. sie nicht instanziierbar sind, sie sind lediglich Oberklassen und dienen zur Vererbung und Knotenhierarchie. Die Knotenstruktur ist hierarchisch und mittels Vererbung aufgebaut. Sie wurde hier durch die Hierarchie der Überschriften dargestellt. Beispielsweise ist AssignmentOperator die Oberklasse von Left- bzw. RightAssignmentOperator, welche wiederum von den spezifischen Operatoren die Oberklassen sind. Dadurch lassen sich allgemeinere Abfragen erstellen. Will man also beispielsweise wissen, ob ein Zuweisungsoperator (egal welcher) verwendet wird, muss man lediglich einen AssignmentOperator in der GReQL-Anfrage verwenden.
Knoten
In dieser Grammatik sind abstrakte Knoten enthalten. Diese sind nicht instanziierbar und durch kursiven Titel kenntlich gemacht.
- Context
- UnaryExpression
- Element
- Literal
- ID
- Operator
- Statement
- Block
- IfStatement
- SwitchStatement
- Loop
- BreakStatement
- NextStatement
- Unsortiert
- AnonFunctionDeclaration
- NamedElement
FunctionDeclarationReturnStatement
Kanten
Im Folgenden werden alle Kanten beschrieben, sortiert nach den Knoten von denen sie ausgehen. Dort, wo keine eigene Kante vergeben wurde, wird eine "UniversalEdge" verwendet.
- AssignmentOperator
- Block
- ForStatement
- FunctionCall
- IfStatement
- Node
- ParameterList
- Prog
- Statement
Letzte Änderungen
30.06.2017
Umbenennungen
ProgStatements => ProgStatement
BodyStatements => BodyStatement
AnonParameterList => FunctionParameterList
Neu
Abstrakte Klasse Function eingefügt, erbt von ID
Infinite, NotANumber, NotAvailable-Knoten, jeweils Unterklasse von Literal
FunctionDeclaration, Unterklasse von Function
sonst. Änderungen
AnonFunctionDeclaration von Unsortiert nach Function verschoben
NamedElement von Unsortiert nach Context verschoben
Block von Statement nach Context verschoben
Bei Eingabe von 'NULL' wird ein NullLiteral gesetzt