X-Git-Url: http://git.cascardo.info/?p=cascardo%2Fgrammar.git;a=blobdiff_plain;f=bnf.c;fp=bnf.c;h=92d385fd4729d3f2e4c6333bc6c5a5dddef4a096;hp=4ee724168a0adf5de061a2ed854386f5629bee2e;hb=6cc79eec169468a13248d59f81c0bb463f296cdb;hpb=0032416ad5a69d4d040121e4f3c34aded139abe6 diff --git a/bnf.c b/bnf.c index 4ee7241..92d385f 100644 --- a/bnf.c +++ b/bnf.c @@ -135,7 +135,7 @@ enum BNF_NONTERMINAL }; -void grammar_tree (Grammar* grammar, GNode* tree) +void grammar_tree (grammar_t* grammar, GNode* tree) { GNode* child_rules; @@ -242,14 +242,14 @@ void grammar_tree (Grammar* grammar, GNode* tree) } -Grammar* grammar_load (char* filename) +grammar_t* grammar_load (char* filename) { - Grammar* grammar; + grammar_t* grammar; rule_t* rule; scanner_t* scanner; - Rdp* parser; + rdp_t* parser; GNode* tree; int fd; @@ -258,8 +258,8 @@ Grammar* grammar_load (char* filename) scanner = scanner_new (read, fd); - parser = rdp_new (bnf_scanner_next, scanner, BNF_GRAMMAR); - grammar = (Grammar*) parser; + grammar = grammar_new (); + parser = rdp_new (bnf_scanner_next, scanner, BNF_GRAMMAR, grammar); rule = grammar_rule_new (grammar, symbol_new (FALSE, BNF_GRAMMAR)); rule_append (rule, symbol_new (FALSE, BNF_RULES)); @@ -291,6 +291,8 @@ Grammar* grammar_load (char* filename) close (fd); scanner_delete (scanner); + rdp_delete (parser); + grammar_delete (grammar); if (tree == NULL) { @@ -298,8 +300,8 @@ Grammar* grammar_load (char* filename) } else { - Grammar* gr; - gr = g_object_new (GRAMMAR_TYPE, NULL); + grammar_t* gr; + gr = grammar_new (); grammar_tree (gr, tree); return gr; }