]> Dogcows Code - chaz/openbox/commitdiff
cleanups and such
authorMarius Nita <marius@cs.pdx.edu>
Mon, 14 Apr 2003 06:47:44 +0000 (06:47 +0000)
committerMarius Nita <marius@cs.pdx.edu>
Mon, 14 Apr 2003 06:47:44 +0000 (06:47 +0000)
obcl/main.c
obcl/obcl.c
obcl/obcl.h
obcl/parse.y

index 5fb83967ebc85e4e6eac4d1a133267c14558a6b7..9ae109a900337361fd9bdcfe8162275f29cb3e6b 100644 (file)
@@ -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;
 }
index b4d9aeee157bbbe2f3c84633aecb2cbdbb5998a2..a4b58eec2e9cc0f87bc5fdb889b42a9e6e8a0b06 100644 (file)
@@ -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;
         }
     }
index a940e89dbd5b257cbbb0f5d70291458916c57818..1002964d76a75e5235ea17e58971b97ed415817f 100644 (file)
@@ -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 */
index 40a071811f8bb2d3be0e7b34d334d8650f2a2d4a..f060bcecfdb558f0f5e748a46ce9ac1345ca7419 100644 (file)
@@ -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;
     }
This page took 0.027842 seconds and 4 git commands to generate.