blob: 1b3b44abdcc7e263df3a713542d96dec15abfb64 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
|
definition module Sil.Syntax
from StdOverloaded import class toString
from Data.Maybe import :: Maybe
from Sil.Types import :: Type
:: Program =
{ p_funs :: [Function]
}
:: Function =
{ f_type :: Type
, f_name :: Name
, f_args :: [Arg]
, f_code :: CodeBlock
}
:: CodeBlock =
{ cb_init :: [Initialisation]
, cb_content :: [Statement]
}
:: Arg =
{ arg_type :: Type
, arg_name :: Name
}
:: Initialisation =
{ init_type :: Type
, init_name :: Name
}
:: Statement
= Declaration Name Expression
| Application Expression
| Return (Maybe Expression)
| If [(Expression, CodeBlock)] (Maybe CodeBlock)
| While Expression CodeBlock
| MachineStm String
:: Expression
= Name Name
| Literal Literal
| App Name [Expression]
| BuiltinApp Op1 Expression
| BuiltinApp2 Expression Op2 Expression
:: Op1
= Neg //* ~
| Not //* !
:: Op2
= Add //* +
| Sub //* -
| Mul //* *
| Div //* /
| Rem //* %
| Equals //* ==
| LogOr //* ||
| LogAnd //* &&
:: Literal
= BLit Bool
| ILit Int
:: Name :== String
instance toString Statement
instance toString Arg
instance toString Expression
instance toString Op1
instance toString Op2
instance toString Literal
class allStatements a :: a -> [Statement]
instance allStatements Program
instance allStatements Function
instance allStatements CodeBlock
instance allStatements Statement
class allCodeBlocks a :: a -> [CodeBlock]
instance allCodeBlocks Function
instance allCodeBlocks CodeBlock
instance allCodeBlocks Statement
class allLocals a :: a -> [(Type, Name)]
instance allLocals Function
instance allLocals CodeBlock
|