summaryrefslogtreecommitdiff
path: root/yy/main.c
diff options
context:
space:
mode:
authorsanine <sanine.not@pm.me>2023-01-31 13:45:50 -0600
committersanine <sanine.not@pm.me>2023-01-31 13:45:50 -0600
commit8e21b8f52a5c566767df9b3fe105706b6888a89b (patch)
tree8926ea0523b57135664f3840117e4d10694c4daf /yy/main.c
parentc4933ae58c84edf5a8e8f741dbb49324b1d12787 (diff)
parse xml into memory
Diffstat (limited to 'yy/main.c')
-rw-r--r--yy/main.c42
1 files changed, 42 insertions, 0 deletions
diff --git a/yy/main.c b/yy/main.c
index 0d97fba..823db5a 100644
--- a/yy/main.c
+++ b/yy/main.c
@@ -6,6 +6,44 @@
#include "kalmia.lex.h"
+void print_attrs(struct kai_attr_t *attr)
+{
+ while(attr != NULL) {
+ printf("%s=\"%s\" ", attr->key, attr->value);
+ attr = attr->next;
+ }
+}
+
+
+void print_tag(char *indent, struct kai_tag_t *tag)
+{
+ printf("%s%s[ ", indent, tag->type);
+ print_attrs(tag->attrs);
+ printf("]\n");
+}
+
+
+void print_level(int indent_level, struct kai_tag_t *tag)
+{
+ char indent[64];
+ for (int i=0; i<indent_level; i++) {
+ indent[i] = '\t';
+ }
+ indent[indent_level] = 0;
+
+ while (tag != NULL) {
+ print_tag(indent, tag);
+ if (tag->children != NULL) {
+ print_level(indent_level+1, tag->children);
+ }
+ if (tag->content != NULL) {
+ printf("%s\t%s\n", indent, tag->content);
+ }
+ tag = tag->next;
+ }
+}
+
+
int main(int argc, char **argv)
{
if (argc < 2) {
@@ -25,5 +63,9 @@ int main(int argc, char **argv)
kalmiaset_in(in, scanner);
kalmiaparse(scanner, &result);
kalmialex_destroy(scanner);
+
+ print_tag("", result.tag);
+ print_level(1, result.tag->children);
+
return 0;
}