diff options
| author | Marius Nita <marius@cs.pdx.edu> | 2003-04-14 06:47:44 +0000 |
|---|---|---|
| committer | Marius Nita <marius@cs.pdx.edu> | 2003-04-14 06:47:44 +0000 |
| commit | 99fd65baf0b14356812ddc6881fd3fe2b996bd3b (patch) | |
| tree | a47931b34177695a4e22f0ff0e2c2beeeed1150d /obcl | |
| parent | 7aae14e9b83242c2778e57c069fb8f299b8172f3 (diff) | |
cleanups and such
Diffstat (limited to 'obcl')
| -rw-r--r-- | obcl/main.c | 3 | ||||
| -rw-r--r-- | obcl/obcl.c | 49 | ||||
| -rw-r--r-- | obcl/obcl.h | 7 | ||||
| -rw-r--r-- | obcl/parse.y | 2 |
4 files changed, 46 insertions, 15 deletions
diff --git a/obcl/main.c b/obcl/main.c index 5fb83967..9ae109a9 100644 --- a/obcl/main.c +++ b/obcl/main.c @@ -3,6 +3,7 @@ int main() { GList *lst = cl_parse("foo.conf"); - cl_print_tree(lst,0); + cl_tree_print(lst,0); + cl_tree_free(lst); return 0; } diff --git a/obcl/obcl.c b/obcl/obcl.c index b4d9aeee..a4b58eec 100644 --- a/obcl/obcl.c +++ b/obcl/obcl.c @@ -1,22 +1,49 @@ #include "obcl.h" -void free_cl_tree(GList *tree) +void cl_tree_free(GList *tree) { + CLNode *tmp; + + if (!tree) return; + for (; tree; tree = tree->next) { + tmp = (CLNode*)tree->data; + switch(tmp->type) { + case CL_ID: + case CL_STR: + g_free(tmp->u.str); + break; + case CL_LIST: + case CL_BLOCK: + case CL_LISTBLOCK: + g_free(tmp->u.lb.id); + cl_tree_free(tmp->u.lb.list); + cl_tree_free(tmp->u.lb.block); + break; + default: + break; + } + g_free(tmp); + } + g_list_free(tree); } GList *cl_parse(gchar *file) { FILE *fh = fopen(file, "r"); - if (fh) - return cl_parse_fh(fh); - else { - printf("can't open file %s\n", file); - return 0; + GList *ret = NULL; + + if (fh) { + ret = cl_parse_fh(fh); + fclose(fh); + } else { + perror(file); } + + return ret; } -void cl_print_tree(GList *tree, int depth) +void cl_tree_print(GList *tree, int depth) { CLNode *tmp; int tmpd = depth; @@ -40,17 +67,17 @@ void cl_print_tree(GList *tree, int depth) break; case CL_LIST: printf("--LIST-- %s\n", tmp->u.lb.id); - cl_print_tree(tmp->u.lb.list, depth+2); + cl_tree_print(tmp->u.lb.list, depth+2); break; case CL_BLOCK: printf("--BLOCK-- %s\n", tmp->u.lb.id); - cl_print_tree(tmp->u.lb.block, depth+2); + cl_tree_print(tmp->u.lb.block, depth+2); break; case CL_LISTBLOCK: printf("--LISTBLOCK-- %s\n", tmp->u.lb.id); - cl_print_tree(tmp->u.lb.list, depth+2); + cl_tree_print(tmp->u.lb.list, depth+2); printf("\n"); - cl_print_tree(tmp->u.lb.block, depth+2); + cl_tree_print(tmp->u.lb.block, depth+2); break; } } diff --git a/obcl/obcl.h b/obcl/obcl.h index a940e89d..1002964d 100644 --- a/obcl/obcl.h +++ b/obcl/obcl.h @@ -28,11 +28,12 @@ typedef struct CLNode { } CLNode; -void free_cl_tree(GList *tree); GList *cl_parse(gchar *file); GList *cl_parse_fh(FILE *file); -void cl_print_tree(GList *tree, int depth); -GList *parse_file(FILE *fh); +void cl_tree_free(GList *tree); +void cl_tree_print(GList *tree, int depth); + +void cl_tree_process(GList *tree); #endif /* __obcl_h */ diff --git a/obcl/parse.y b/obcl/parse.y index 40a07181..f060bcec 100644 --- a/obcl/parse.y +++ b/obcl/parse.y @@ -51,6 +51,7 @@ stmt: TOK_ID list ';' CLNode *s = g_new(CLNode,1); s->type = CL_LIST; s->u.lb.list = $2; + s->u.lb.block = NULL; s->u.lb.id = $1; $$ = s; } @@ -68,6 +69,7 @@ stmt: TOK_ID list ';' CLNode *s = g_new(CLNode,1); s->type = CL_BLOCK; s->u.lb.block = $2; + s->u.lb.list = NULL; s->u.lb.id = $1; $$ = s; } |
