author | unc0rr |
Sat, 05 May 2012 00:01:12 +0400 | |
changeset 7019 | 333afe233886 |
parent 6967 | 1224c6fb36c3 |
child 7032 | 5685ca1ec9bf |
permissions | -rw-r--r-- |
6467 | 1 |
module PascalUnitSyntaxTree where |
2 |
||
6618 | 3 |
import Data.Maybe |
6626
a447993f2ad7
Further work on propagating types. Now it hopefully works fully, just need to annotate namespace with types first.
unc0rr
parents:
6618
diff
changeset
|
4 |
import Data.Char |
6467 | 5 |
|
6 |
data PascalUnit = |
|
7 |
Program Identifier Implementation Phrase |
|
8 |
| Unit Identifier Interface Implementation (Maybe Initialize) (Maybe Finalize) |
|
6512 | 9 |
| System [TypeVarDeclaration] |
6467 | 10 |
deriving Show |
11 |
data Interface = Interface Uses TypesAndVars |
|
12 |
deriving Show |
|
13 |
data Implementation = Implementation Uses TypesAndVars |
|
14 |
deriving Show |
|
6489 | 15 |
data Identifier = Identifier String BaseType |
6467 | 16 |
deriving Show |
17 |
data TypesAndVars = TypesAndVars [TypeVarDeclaration] |
|
18 |
deriving Show |
|
19 |
data TypeVarDeclaration = TypeDeclaration Identifier TypeDecl |
|
20 |
| VarDeclaration Bool ([Identifier], TypeDecl) (Maybe InitExpression) |
|
21 |
| FunctionDeclaration Identifier TypeDecl [TypeVarDeclaration] (Maybe (TypesAndVars, Phrase)) |
|
22 |
| OperatorDeclaration String Identifier TypeDecl [TypeVarDeclaration] (Maybe (TypesAndVars, Phrase)) |
|
23 |
deriving Show |
|
24 |
data TypeDecl = SimpleType Identifier |
|
25 |
| RangeType Range |
|
26 |
| Sequence [Identifier] |
|
27 |
| ArrayDecl (Maybe Range) TypeDecl |
|
28 |
| RecordType [TypeVarDeclaration] (Maybe [[TypeVarDeclaration]]) |
|
29 |
| PointerTo TypeDecl |
|
30 |
| String Integer |
|
31 |
| Set TypeDecl |
|
32 |
| FunctionType TypeDecl [TypeVarDeclaration] |
|
6626
a447993f2ad7
Further work on propagating types. Now it hopefully works fully, just need to annotate namespace with types first.
unc0rr
parents:
6618
diff
changeset
|
33 |
| DeriveType InitExpression |
6826 | 34 |
| VoidType |
6467 | 35 |
deriving Show |
36 |
data Range = Range Identifier |
|
37 |
| RangeFromTo InitExpression InitExpression |
|
6893 | 38 |
| RangeInfinite |
6467 | 39 |
deriving Show |
40 |
data Initialize = Initialize String |
|
41 |
deriving Show |
|
42 |
data Finalize = Finalize String |
|
43 |
deriving Show |
|
44 |
data Uses = Uses [Identifier] |
|
45 |
deriving Show |
|
46 |
data Phrase = ProcCall Reference [Expression] |
|
47 |
| IfThenElse Expression Phrase (Maybe Phrase) |
|
48 |
| WhileCycle Expression Phrase |
|
49 |
| RepeatCycle Expression [Phrase] |
|
50 |
| ForCycle Identifier Expression Expression Phrase |
|
51 |
| WithBlock Reference Phrase |
|
52 |
| Phrases [Phrase] |
|
53 |
| SwitchCase Expression [([InitExpression], Phrase)] (Maybe [Phrase]) |
|
54 |
| Assignment Reference Expression |
|
6895 | 55 |
| BuiltInFunctionCall [Expression] Reference |
6467 | 56 |
| NOP |
57 |
deriving Show |
|
58 |
data Expression = Expression String |
|
59 |
| BuiltInFunCall [Expression] Reference |
|
60 |
| PrefixOp String Expression |
|
61 |
| PostfixOp String Expression |
|
62 |
| BinOp String Expression Expression |
|
63 |
| StringLiteral String |
|
64 |
| CharCode String |
|
65 |
| HexCharCode String |
|
66 |
| NumberLiteral String |
|
67 |
| FloatLiteral String |
|
68 |
| HexNumber String |
|
69 |
| Reference Reference |
|
70 |
| SetExpression [Identifier] |
|
71 |
| Null |
|
72 |
deriving Show |
|
73 |
data Reference = ArrayElement [Expression] Reference |
|
74 |
| FunCall [Expression] Reference |
|
75 |
| TypeCast Identifier Expression |
|
76 |
| SimpleReference Identifier |
|
77 |
| Dereference Reference |
|
78 |
| RecordField Reference Reference |
|
79 |
| Address Reference |
|
80 |
| RefExpression Expression |
|
81 |
deriving Show |
|
82 |
data InitExpression = InitBinOp String InitExpression InitExpression |
|
83 |
| InitPrefixOp String InitExpression |
|
84 |
| InitReference Identifier |
|
85 |
| InitArray [InitExpression] |
|
86 |
| InitRecord [(Identifier, InitExpression)] |
|
87 |
| InitFloat String |
|
88 |
| InitNumber String |
|
89 |
| InitHexNumber String |
|
90 |
| InitString String |
|
91 |
| InitChar String |
|
92 |
| BuiltInFunction String [InitExpression] |
|
93 |
| InitSet [InitExpression] |
|
94 |
| InitAddress InitExpression |
|
95 |
| InitNull |
|
96 |
| InitRange Range |
|
97 |
| InitTypeCast Identifier InitExpression |
|
98 |
deriving Show |
|
6489 | 99 |
|
6618 | 100 |
data BaseType = BTUnknown |
6489 | 101 |
| BTChar |
102 |
| BTString |
|
103 |
| BTInt |
|
6635
c2fa29fe2a58
Some progress, still can't find the source of bad behavior
unc0rr
parents:
6626
diff
changeset
|
104 |
| BTBool |
6649
7f78e8a6db69
Fix a bug with type declaration trying to resolve type being declared
unc0rr
parents:
6635
diff
changeset
|
105 |
| BTFloat |
6827 | 106 |
| BTRecord [(String, BaseType)] |
6893 | 107 |
| BTArray Range BaseType BaseType |
7019
333afe233886
Convert namespace from list into map in preparation for implementation of overloaded functions support. Greatly improve speed of rendering as a side effect (parse + render time reduced from 5:20 to 0:20)
unc0rr
parents:
6967
diff
changeset
|
108 |
| BTFunction Int BaseType |
6967
1224c6fb36c3
Support recurrent function calls. The code is kinda hackish and ugly, but I really spent a few hours thinking on a good solution.
unc0rr
parents:
6895
diff
changeset
|
109 |
| BTFunctionReturn String BaseType |
6489 | 110 |
| BTPointerTo BaseType |
6827 | 111 |
| BTUnresolved String |
6653 | 112 |
| BTSet BaseType |
6489 | 113 |
| BTEnum [String] |
6618 | 114 |
| BTVoid |
6816 | 115 |
| BTUnit |
6489 | 116 |
deriving Show |