]> git.droids-corp.org - protos/libecoli.git/commitdiff
add missing child ops
authorOlivier Matz <zer0@droids-corp.org>
Tue, 10 Jul 2018 20:38:03 +0000 (22:38 +0200)
committerOlivier Matz <zer0@droids-corp.org>
Tue, 10 Jul 2018 20:38:03 +0000 (22:38 +0200)
lib/ecoli_node_re_lex.c
lib/ecoli_node_sh_lex.c

index a017635bb7354ef445b4b6c23964b76ab1e5e68c..e0acdfec9e0077d5dcde52b1a7eec8fb40455fa7 100644 (file)
@@ -152,12 +152,35 @@ static void ec_node_re_lex_free_priv(struct ec_node *gen_node)
        ec_node_free(node->child);
 }
 
+static size_t
+ec_node_re_lex_get_children_count(const struct ec_node *gen_node)
+{
+       struct ec_node_re_lex *node = (struct ec_node_re_lex *)gen_node;
+
+       if (node->child)
+               return 1;
+       return 0;
+}
+
+static struct ec_node *
+ec_node_re_lex_get_child(const struct ec_node *gen_node, size_t i)
+{
+       struct ec_node_re_lex *node = (struct ec_node_re_lex *)gen_node;
+
+       if (i >= 1)
+               return NULL;
+
+       return node->child;
+}
+
 static struct ec_node_type ec_node_re_lex_type = {
        .name = "re_lex",
        .parse = ec_node_re_lex_parse,
        .complete = ec_node_complete_unknown,
        .size = sizeof(struct ec_node_re_lex),
        .free_priv = ec_node_re_lex_free_priv,
+       .get_children_count = ec_node_re_lex_get_children_count,
+       .get_child = ec_node_re_lex_get_child,
 };
 
 EC_NODE_TYPE_REGISTER(ec_node_re_lex_type);
index 53122c478362364a3439a899521a53bd7cfc7b01..b39ce213e580c725e3b6b7f94aa3777545f58e0d 100644 (file)
@@ -343,12 +343,35 @@ static void ec_node_sh_lex_free_priv(struct ec_node *gen_node)
        ec_node_free(node->child);
 }
 
+static size_t
+ec_node_sh_lex_get_children_count(const struct ec_node *gen_node)
+{
+       struct ec_node_sh_lex *node = (struct ec_node_sh_lex *)gen_node;
+
+       if (node->child)
+               return 1;
+       return 0;
+}
+
+static struct ec_node *
+ec_node_sh_lex_get_child(const struct ec_node *gen_node, size_t i)
+{
+       struct ec_node_sh_lex *node = (struct ec_node_sh_lex *)gen_node;
+
+       if (i >= 1)
+               return NULL;
+
+       return node->child;
+}
+
 static struct ec_node_type ec_node_sh_lex_type = {
        .name = "sh_lex",
        .parse = ec_node_sh_lex_parse,
        .complete = ec_node_sh_lex_complete,
        .size = sizeof(struct ec_node_sh_lex),
        .free_priv = ec_node_sh_lex_free_priv,
+       .get_children_count = ec_node_sh_lex_get_children_count,
+       .get_child = ec_node_sh_lex_get_child,
 };
 
 EC_NODE_TYPE_REGISTER(ec_node_sh_lex_type);