Files
kraken/tests/test_grammer.krak

137 lines
4.8 KiB
Plaintext
Raw Normal View History

import io:*
import grammer:*
2015-08-06 02:42:40 -04:00
import parser:*
import lexer:*
import string:*
import util:*
2015-07-13 12:16:30 -04:00
import symbol:*
2015-08-06 02:42:40 -04:00
import tree:*
import serialize:*
fun main():int {
var a.construct(): grammer
2015-07-13 12:16:30 -04:00
var file_name = string("../krakenGrammer.kgm")
/*var file_name = string("grammer.kgm")*/
/*var file_name = string("grammer2.kgm")*/
/*var file_name = string("grammer3.kgm")*/
/*var file_name = string("grammer4.kgm")*/
var compiled_name = file_name + string(".comp_new")
var file_contents = read_file(file_name)
var loaded_and_valid = false
/*
println("gonna serialize")
var s = serialize(file_contents)
println("gonna write")
write_file_binary(compiled_name, s)
println("gonna read")
var bin = read_file_binary(compiled_name)
println("gonna setup")
var pos = 0
var uns = string()
println("gonna unserialize")
unpack(uns, pos) = unserialize<string>(bin, pos)
println("gonna done")
return 0
*/
/*a = load_grammer(file_contents)*/
/*println("grammer loaded, calculate_state_automaton")*/
/*a.calculate_first_set()*/
/*a.calculate_state_automaton()*/
if (file_exists(compiled_name)) {
println("cached file exists")
var pos = 0
var binary = read_file_binary(compiled_name)
println("read file!")
var cached_contents = string()
println("made tmp string!")
unpack(cached_contents, pos) = unserialize<string>(binary, pos)
println("unserialized the string!")
if (cached_contents == file_contents) {
println("loaded_and_valid, using cached version!")
loaded_and_valid = true
unpack(a, pos) = unserialize<grammer>(binary, pos)
println("finished unserializeing!!")
} else {
println("file contents do not match:")
println("CACHED:")
println(cached_contents)
println("REAL:")
println(file_contents)
println("END")
}
} else {
println("cached file does not exist")
}
if (!loaded_and_valid) {
println("Not loaded_and_valid, re-generating and writing out")
a = load_grammer(file_contents)
println("grammer loaded, calculate_first_set")
a.calculate_first_set()
println("grammer loaded, calculate_state_automaton")
a.calculate_state_automaton()
println("calculated, writing out")
write_file_binary(compiled_name, serialize(file_contents) + serialize(a))
println("done writing")
}
println(a.to_string())
var doFirstSet = fun() {
println("///////////////////START FIRST SET/////////////")
println("//TERMINALS//")
a.terminals.for_each( fun(terminal: util::pair<symbol::symbol, regex::regex>) {
var set_str = string::string("{ ")
a.first_set_map[terminal.first].for_each( fun(sym: symbol::symbol) {
set_str += sym.to_string() + ", "
})
set_str += "}"
print(terminal.first.to_string() + " first: " + set_str + "\n")
2015-07-13 12:16:30 -04:00
})
println("//NON TERMINALS//")
a.non_terminals.for_each( fun(non_terminal: symbol::symbol) {
var set_str = string::string("{ ")
a.first_set_map[non_terminal].for_each( fun(sym: symbol::symbol) {
set_str += sym.to_string() + ", "
})
set_str += "}"
print(non_terminal.to_string() + " first: " + set_str + "\n")
println()
2015-07-13 12:16:30 -04:00
})
println("///////////////////END FIRST SET/////////////")
}
/*doFirstSet()*/
2015-07-13 12:16:30 -04:00
var lex = lexer(a.terminals)
2015-08-03 14:38:17 -04:00
/*lex.set_input(read_file(string("test_grammer.krak")))*/
2015-07-15 13:56:57 -04:00
/*lex.set_input(string("ccdahas spacedhas*/
/*returndaaaaaaaaaaaaaa"))*/
//lex.set_input(string("hibyed"))
println("woo lexing:")
/*range(8).for_each(fun(i: int) { println(lex.next().to_string()); } )*/
/*range(80).for_each(fun(i: int) { println(lex.next().to_string()); } )*/
/*println(a.to_string())*/
2015-08-06 02:42:40 -04:00
var parse.construct(a): parser
/*var result = parse.parse_input(string("a"), string("fun name"))*/
var result = parse.parse_input(read_file(string("to_parse.krak")), string("fun name"))
/*var result = parse.parse_input(string("inport a;"), string("fun name"))*/
/*var result = parse.parse_input(string("fun main():int { return 0; }"), string("fun name"))*/
/*var result = parse.parse_input(string("ad"), string("fun name"))*/
/*var result = parse.parse_input(string("hibyed"), string("fun name"))*/
/*var result = parse.parse_input(string("hmmhmmend"), string("fun name"))*/
/*var result = parse.parse_input(string("hid"), string("fun name"))*/
println("the tree")
println(syntax_tree_to_dot(result))
write_file(string("syntax_tree.dot"), syntax_tree_to_dot(result))
2015-08-06 02:42:40 -04:00
/*var parse.construct(): parser*/
return 0
}