Added for loops

This commit is contained in:
Nathan Braswell
2016-01-19 11:47:09 -05:00
parent c4abfca98e
commit 162cc98f30
5 changed files with 41 additions and 7 deletions

View File

@@ -520,12 +520,24 @@ fun is_for_loop(node: *ast_node): bool {
return false return false
} }
obj for_loop (Object) { obj for_loop (Object) {
var init: *ast_node
var condition: *ast_node
var update: *ast_node
var body: *ast_node
var scope: map<string, vector<*ast_node>> var scope: map<string, vector<*ast_node>>
fun construct(): *for_loop { fun construct(): *for_loop {
scope.construct() scope.construct()
init = null<ast_node>()
condition = null<ast_node>()
update = null<ast_node>()
body = null<ast_node>()
return this return this
} }
fun copy_construct(old: *for_loop) { fun copy_construct(old: *for_loop) {
init = old->init
condition = old->condition
update = old->update
body = old->body
scope.copy_construct(&old->scope) scope.copy_construct(&old->scope)
} }
fun destruct() { fun destruct() {
@@ -536,7 +548,7 @@ obj for_loop (Object) {
copy_construct(&other) copy_construct(&other)
} }
fun operator==(other: ref for_loop): bool { fun operator==(other: ref for_loop): bool {
return true return init == other.init && condition == other.condition && update == other.update && body == other.body
} }
} }
fun ast_return_statement_ptr(return_value: *ast_node): *ast_node { fun ast_return_statement_ptr(return_value: *ast_node): *ast_node {
@@ -897,7 +909,7 @@ fun get_ast_children(node: *ast_node): vector<*ast_node> {
ast_node::match_statement(backing) return vector<*ast_node>() ast_node::match_statement(backing) return vector<*ast_node>()
ast_node::case_statement(backing) return vector<*ast_node>() ast_node::case_statement(backing) return vector<*ast_node>()
ast_node::while_loop(backing) return vector(backing.condition, backing.statement) ast_node::while_loop(backing) return vector(backing.condition, backing.statement)
ast_node::for_loop(backing) return vector<*ast_node>() ast_node::for_loop(backing) return vector(backing.init, backing.condition, backing.update, backing.body)
ast_node::return_statement(backing) return vector(backing.return_value) ast_node::return_statement(backing) return vector(backing.return_value)
ast_node::break_statement(backing) return vector<*ast_node>() ast_node::break_statement(backing) return vector<*ast_node>()
ast_node::continue_statement(backing) return vector<*ast_node>() ast_node::continue_statement(backing) return vector<*ast_node>()

View File

@@ -192,6 +192,8 @@ obj ast_transformation (Object) {
return transform_if_statement(node, scope) return transform_if_statement(node, scope)
} else if (name == "while_loop") { } else if (name == "while_loop") {
return transform_while_loop(node, scope) return transform_while_loop(node, scope)
} else if (name == "for_loop") {
return transform_for_loop(node, scope)
} else if (name == "return_statement") { } else if (name == "return_statement") {
return transform_return_statement(node, scope) return transform_return_statement(node, scope)
} else if (name == "function_call") { } else if (name == "function_call") {
@@ -308,6 +310,16 @@ obj ast_transformation (Object) {
while_loop->while_loop.statement = transform(get_node("statement", node), while_loop) while_loop->while_loop.statement = transform(get_node("statement", node), while_loop)
return while_loop return while_loop
} }
fun transform_for_loop(node: *tree<symbol>, scope: *ast_node): *ast_node {
var for_loop = ast_for_loop_ptr()
add_to_scope("~enclosing_scope", scope, for_loop)
var statements = get_nodes("statement", node)
for_loop->for_loop.init = transform(statements[0], for_loop)
for_loop->for_loop.condition = transform(get_node("boolean_expression", node), for_loop)
for_loop->for_loop.update = transform(statements[1], for_loop)
for_loop->for_loop.body = transform(statements[2], for_loop)
return for_loop
}
fun transform_return_statement(node: *tree<symbol>, scope: *ast_node): *ast_node { fun transform_return_statement(node: *tree<symbol>, scope: *ast_node): *ast_node {
return ast_return_statement_ptr(transform(node->children[0], scope)) return ast_return_statement_ptr(transform(node->children[0], scope))
} }

View File

@@ -102,6 +102,11 @@ obj c_generator (Object) {
fun generate_while_loop(node: *ast_node): string { fun generate_while_loop(node: *ast_node): string {
return string("while (") + generate(node->while_loop.condition) + ") {\n" + generate(node->while_loop.statement) + "}\n" return string("while (") + generate(node->while_loop.condition) + ") {\n" + generate(node->while_loop.statement) + "}\n"
} }
fun generate_for_loop(node: *ast_node): string {
// gotta take off last semicolon
return string("for (") + generate(node->for_loop.init) + " " + generate(node->for_loop.condition) + "; " +
generate(node->for_loop.update).slice(0,-3) + ") {\n" + generate(node->for_loop.body) + "}\n"
}
fun generate_identifier(node: *ast_node): string { fun generate_identifier(node: *ast_node): string {
return node->identifier.name return node->identifier.name
} }
@@ -122,7 +127,10 @@ obj c_generator (Object) {
fun generate_function_call(node: *ast_node): string { fun generate_function_call(node: *ast_node): string {
var func_name = generate(node->function_call.func) var func_name = generate(node->function_call.func)
var parameters = node->function_call.parameters var parameters = node->function_call.parameters
if (func_name == "+" || func_name == "-" || func_name == "*" || func_name == "/" || func_name == "||" || func_name == "&&") if (func_name == "+" || func_name == "-" || func_name == "*" || func_name == "/" || func_name == "||"
|| func_name == "&&" || func_name == "<" || func_name == ">" || func_name == "<=" || func_name == ">="
|| func_name == "=="
)
return string("(") + generate(parameters[0]) + func_name + generate(parameters[1]) + string(")") return string("(") + generate(parameters[0]) + func_name + generate(parameters[1]) + string(")")
// the post ones need to be post-ed specifically, and take the p off // the post ones need to be post-ed specifically, and take the p off
if (func_name == "++p" || func_name == "--p") if (func_name == "++p" || func_name == "--p")
@@ -147,6 +155,7 @@ obj c_generator (Object) {
ast_node::assignment_statement(backing) return generate_assignment_statement(node) ast_node::assignment_statement(backing) return generate_assignment_statement(node)
ast_node::if_statement(backing) return generate_if_statement(node) ast_node::if_statement(backing) return generate_if_statement(node)
ast_node::while_loop(backing) return generate_while_loop(node) ast_node::while_loop(backing) return generate_while_loop(node)
ast_node::for_loop(backing) return generate_for_loop(node)
ast_node::function(backing) return generate_function(node) ast_node::function(backing) return generate_function(node)
ast_node::function_call(backing) return generate_function_call(node) ast_node::function_call(backing) return generate_function_call(node)
ast_node::code_block(backing) return generate_code_block(node) ast_node::code_block(backing) return generate_code_block(node)

View File

@@ -9,9 +9,7 @@ fun simple_print(to_print: int) {
printf("%d", to_print); printf("%d", to_print);
""" """
} }
/*var a = 1*/ var a = 1
/*var b = 2*/
var a:int
var b:int var b:int

View File

@@ -35,6 +35,9 @@ fun main(): int {
while (counter) { while (counter) {
simple_print(--counter) simple_print(--counter)
} }
simple_print("\n")
for (var j = 0; j < 10; j++;)
simple_print(j)
return 0 return 0
} }