summaryrefslogtreecommitdiff
path: root/old-lib/c/gfcc-tree.c
diff options
context:
space:
mode:
authoraarne <aarne@chalmers.se>2009-06-22 15:39:08 +0000
committeraarne <aarne@chalmers.se>2009-06-22 15:39:08 +0000
commite89fdae2fa1626348d8025824a7469252fa85e42 (patch)
treec7d46bbd0494043b4bd6f917a25a7687517d0547 /old-lib/c/gfcc-tree.c
parent3049b59b35b25381a7c6787444165c200d66e08b (diff)
next-lib renamed to lib, lib to old-lib
Diffstat (limited to 'old-lib/c/gfcc-tree.c')
-rw-r--r--old-lib/c/gfcc-tree.c61
1 files changed, 61 insertions, 0 deletions
diff --git a/old-lib/c/gfcc-tree.c b/old-lib/c/gfcc-tree.c
new file mode 100644
index 000000000..6cd8759be
--- /dev/null
+++ b/old-lib/c/gfcc-tree.c
@@ -0,0 +1,61 @@
+#include "gfcc-tree.h"
+
+#include <stdlib.h>
+
+
+extern int arity(Tree *t) {
+ switch (t->type) {
+ case ATOM_STRING:
+ case ATOM_INTEGER:
+ case ATOM_DOUBLE:
+ case ATOM_META:
+ return 0;
+ default:
+ return t->value.size;
+ }
+}
+
+static Tree *create_tree(atom_type c, int n) {
+ Tree *t = (Tree *)malloc(sizeof(Tree) + n * sizeof(Tree *));
+ t->type = c;
+ return t;
+}
+
+extern Tree *tree_string(const char *s) {
+ Tree *t = create_tree(ATOM_STRING, 0);
+ t->value.string_value = s;
+ return t;
+}
+
+extern Tree *tree_integer(int i) {
+ Tree *t = create_tree(ATOM_INTEGER, 0);
+ t->value.integer_value = i;
+ return t;
+}
+
+extern Tree *tree_double(double d) {
+ Tree *t = create_tree(ATOM_DOUBLE, 0);
+ t->value.double_value = d;
+ return t;
+}
+
+extern Tree *tree_meta() {
+ return create_tree(ATOM_META, 0);
+}
+
+extern Tree *tree_fun(atom_type f, int n) {
+ Tree *t = create_tree(f, n);
+ t->value.size = n;
+ return t;
+}
+
+
+extern void tree_free(Tree *t) {
+ int n = arity(t);
+ int i;
+
+ for (i = 0; i < n; i++) {
+ tree_free(tree_get_child(t,i));
+ }
+ free(t);
+}