Format files
This commit is contained in:
@@ -74,29 +74,3 @@ Lexis Dec:decimal ::= '1'-'9'('0'-'9')*
|
|||||||
|
|
||||||
Semantics dec-val[[ _:decimal ]] : ints
|
Semantics dec-val[[ _:decimal ]] : ints
|
||||||
Rule dec-val[[ Dec ]] = decimal-natural(\"Dec\")
|
Rule dec-val[[ Dec ]] = decimal-natural(\"Dec\")
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//Semantics eval-exp[[ _:exp ]] : => values
|
|
||||||
//
|
|
||||||
//Rule eval-exp[[ Id ]] = assigned bound id[[ Id ]]
|
|
||||||
//
|
|
||||||
//Rule eval-exp[[ Int ]] = int-val[[ Int ]]
|
|
||||||
//
|
|
||||||
//Rule eval-exp[[ Exp1 '+' Exp2 ]] =
|
|
||||||
// int-add(eval-exp[[ Exp1 ]], eval-exp[[ Exp2 ]])
|
|
||||||
//
|
|
||||||
//Rule eval-exp[[ Exp1 '/' Exp2 ]] =
|
|
||||||
// checked int-div(eval-exp[[ Exp1 ]], eval-exp[[ Exp2 ]])
|
|
||||||
//
|
|
||||||
//Rule eval-exp[[ Id '(' ParamValues? ')' ]] =
|
|
||||||
// handle-return apply(bound id[[ Id ]], eval-params[[ ParamValues? ]])
|
|
||||||
//
|
|
||||||
//Rule eval-exp[[ '(' Exp ')' ]] = eval-exp[[ Exp ]]
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -2,7 +2,7 @@ Language "IBAFlang"
|
|||||||
|
|
||||||
Syntax START:start ::= statement*
|
Syntax START:start ::= statement*
|
||||||
Semantics start[[ _:start ]] : =>null-type
|
Semantics start[[ _:start ]] : =>null-type
|
||||||
Rule start[[ Stmt* ]] = initialise-binding scope(collateral(collect-declared-vars[[ Stmt* ]]), execute[[ Stmt* ]])
|
Rule start[[ Stmt* ]] = initialise-binding execute-block[[ Stmt* ]]
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -17,8 +17,8 @@ Syntax Stmt: statement ::= block
|
|||||||
|
|
||||||
Syntax Params: params ::= id (',' params)?
|
Syntax Params: params ::= id (',' params)?
|
||||||
|
|
||||||
Semantics execute[[ Stmt*:statement* ]] : =>null-type
|
|
||||||
|
|
||||||
|
Semantics execute[[ Stmt*:statement* ]] : =>null-type
|
||||||
Rule execute[[ Block ]] = execute-block[[ Block ]]
|
Rule execute[[ Block ]] = execute-block[[ Block ]]
|
||||||
Rule execute[[ 'print' Exp ';' ]] = print(to-string eval-exp[[ Exp ]], "\n")
|
Rule execute[[ 'print' Exp ';' ]] = print(to-string eval-exp[[ Exp ]], "\n")
|
||||||
Rule execute[[ 'int' Id ';' ]] = initialise-variable(bound id[[ Id ]], 0)
|
Rule execute[[ 'int' Id ';' ]] = initialise-variable(bound id[[ Id ]], 0)
|
||||||
@@ -35,9 +35,7 @@ Rule execute[[ ]] = null
|
|||||||
Rule execute[[ Stmt Stmt+ ]] = sequential(execute[[ Stmt ]], execute[[ Stmt+ ]])
|
Rule execute[[ Stmt Stmt+ ]] = sequential(execute[[ Stmt ]], execute[[ Stmt+ ]])
|
||||||
|
|
||||||
Semantics execute-block[[ _:block ]] : =>null-type
|
Semantics execute-block[[ _:block ]] : =>null-type
|
||||||
Rule execute-block[[ '{' Stmt* '}' ]] = execute[[ Stmt* ]]
|
Rule execute-block[[ '{' Stmt* '}' ]] = scope(collateral(collect-declared-vars[[ Stmt* ]]), execute[[ Stmt* ]])
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -55,7 +53,6 @@ Rule collect-params[[ Id ',' Params ]] = collect-params[[ Id ]], give(checked ta
|
|||||||
# Handling variable declarations
|
# Handling variable declarations
|
||||||
|
|
||||||
Semantics collect-declared-vars[[ Stmt*:statement* ]] : (=>environments)+
|
Semantics collect-declared-vars[[ Stmt*:statement* ]] : (=>environments)+
|
||||||
|
|
||||||
Rule collect-declared-vars[[ 'int' Id '=' Exp ';' ]] = bind(id[[ Id ]], allocate-variable(integers))
|
Rule collect-declared-vars[[ 'int' Id '=' Exp ';' ]] = bind(id[[ Id ]], allocate-variable(integers))
|
||||||
Rule collect-declared-vars[[ 'int' Id ';' ]] = bind(id[[ Id ]], allocate-variable(integers))
|
Rule collect-declared-vars[[ 'int' Id ';' ]] = bind(id[[ Id ]], allocate-variable(integers))
|
||||||
Rule collect-declared-vars[[ 'fun' Id '(' Params ')' '{' Stmt* '}' ]] = bind(id[[ Id ]],
|
Rule collect-declared-vars[[ 'fun' Id '(' Params ')' '{' Stmt* '}' ]] = bind(id[[ Id ]],
|
||||||
@@ -67,23 +64,6 @@ Rule collect-declared-vars[[ 'fun' Id '(' Params ')' '{' Stmt* '}' ]] = bind(id[
|
|||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
Rule collect-declared-vars[[ '{' Stmt* '}' ]] = collect-declared-vars[[ Stmt* ]]
|
|
||||||
Rule collect-declared-vars[[ 'if' '(' Exp ')' Block ]] = collect-declared-vars[[ Block ]]
|
|
||||||
Rule collect-declared-vars[[ 'if' '(' Exp ')' Block1 'else' Block2 ]] = collect-declared-vars[[ Block1 ]], collect-declared-vars[[ Block2 ]]
|
|
||||||
Rule collect-declared-vars[[ 'while' '(' Exp ')' Block ]] = collect-declared-vars[[ Block ]]
|
|
||||||
|
|
||||||
Rule collect-declared-vars[[ ]] = map()
|
Rule collect-declared-vars[[ ]] = map()
|
||||||
Rule collect-declared-vars[[ Stmt ]] = map()
|
Rule collect-declared-vars[[ Stmt ]] = map()
|
||||||
Rule collect-declared-vars[[ Stmt1 Stmt2 Stmt* ]] = collect-declared-vars[[ Stmt1 ]], collect-declared-vars[[ Stmt2 ]], collect-declared-vars[[ Stmt* ]]
|
Rule collect-declared-vars[[ Stmt1 Stmt2 Stmt* ]] = collect-declared-vars[[ Stmt1 ]], collect-declared-vars[[ Stmt2 ]], collect-declared-vars[[ Stmt* ]]
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user