aboutsummaryrefslogtreecommitdiff
path: root/include
diff options
context:
space:
mode:
authorPreston Pan <preston@nullring.xyz>2024-01-09 19:55:24 -0800
committerPreston Pan <preston@nullring.xyz>2024-01-09 19:55:24 -0800
commitbb26e7e9581f507772521ebb447f897a8f68ad57 (patch)
tree655aec6c85930f5f34c5a0f930217b21cc0c6aab /include
parent707cf3115f060fe385a253b08badd701d3caea42 (diff)
add sleep; fix bugs
Diffstat (limited to 'include')
-rw-r--r--include/builtins.h2
-rw-r--r--include/stem.h22
2 files changed, 22 insertions, 2 deletions
diff --git a/include/builtins.h b/include/builtins.h
index 148fba7..89fb26d 100644
--- a/include/builtins.h
+++ b/include/builtins.h
@@ -49,6 +49,8 @@ void ssize(value_t *v);
void qstack(value_t *v);
void vat(value_t *v);
void stemfwrite(value_t *v);
+void stemsleep(value_t *v);
+void add_objs();
void add_funcs();
#endif // BUILTINS_H_
diff --git a/include/stem.h b/include/stem.h
index 2643d36..e8a8587 100644
--- a/include/stem.h
+++ b/include/stem.h
@@ -76,6 +76,12 @@ custom_t *init_custom(void (*)(void *), void (*)(void *), void *(*)(void *));
void custom_free(void *);
+void add_func(ht_t *h, void (*func)(value_t *), char *key);
+
+void add_obj(ht_t *h, ht_t *h2, void (*printfunc)(void *),
+ void (*freefunc)(void *), void *(*copyfunc)(void *),
+ void (*createfunc)(void *), char *key);
+
parser_t *init_parser(char *source);
void parser_reset(parser_t *p, char *source);
@@ -84,13 +90,25 @@ void parser_move(parser_t *p);
void parser_skip_whitespace(parser_t *p);
+value_t *parse_string(parser_t *p);
+
+value_t *parse_quote(parser_t *p);
+
+value_t *parse_word(parser_t *p);
+
+value_t *parse_num(parser_t *p);
+
+void parser_error(parser_t *p);
+
value_t *parser_get_next(parser_t *p);
node_t *init_node(string_t *key, void *v);
+void node_free(node_t *n, void (*freefunc)(void *));
+
sll_t *init_sll();
-void sll_add(sll_t *l, string_t *key, void *v);
+void sll_add(sll_t *l, string_t *key, void *v, void (*freefunc)(void *));
void *sll_get(sll_t *l, string_t *key);
@@ -98,7 +116,7 @@ void sll_free(sll_t *l, void (*freefunc)(void *));
ht_t *init_ht(size_t size);
-void ht_add(ht_t *h, string_t *key, void *v);
+void ht_add(ht_t *h, string_t *key, void *v, void (*freefunc)(void *));
void *ht_get(ht_t *h, string_t *key);