summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorPreston Pan <preston@nullring.xyz>2023-01-07 09:54:40 -0800
committerPreston Pan <preston@nullring.xyz>2023-01-07 09:54:40 -0800
commit4581329cde6cfb64399be48f58d67310ab19ee1b (patch)
treec76893896ae4375c618ecffad71fa9ffb3717be2 /src
parentc620d528fb9d9efbac559002d23857623e71df05 (diff)
include working
Diffstat (limited to 'src')
-rw-r--r--src/hash_table.c1
-rw-r--r--src/main.c4
-rw-r--r--src/parser.c80
3 files changed, 82 insertions, 3 deletions
diff --git a/src/hash_table.c b/src/hash_table.c
index bd947c0..6648bd1 100644
--- a/src/hash_table.c
+++ b/src/hash_table.c
@@ -77,6 +77,7 @@ void sl_list_add(sl_list_t *l, char *key, ast_t *value) {
l->size++;
}
}
+
ast_t *sl_list_get(sl_list_t *l, char *key) {
sl_node_t *cur = l->head;
for (int i = 0; i < l->size; i++) {
diff --git a/src/main.c b/src/main.c
index bbe725c..5315549 100644
--- a/src/main.c
+++ b/src/main.c
@@ -131,6 +131,10 @@ int main(int argc, char **argv) {
printf("TOO FEW ARGUMENTS.\n");
exit(1);
}
+ if (strcmp(argv[1], "-v") == 0 || strcmp(argv[1], "--version") == 0) {
+ printf("nxs, version 1.0.0 alpha\n");
+ exit(0);
+ }
char *filename = argv[1];
char *buffer = 0;
diff --git a/src/parser.c b/src/parser.c
index 0a2b213..157bc4d 100644
--- a/src/parser.c
+++ b/src/parser.c
@@ -7,14 +7,14 @@
#include <stdlib.h>
#include <string.h>
-parser_t *init_parser(lexer_t *lexer) {
+parser_t *init_parser_copy_hash(lexer_t *lexer, hash_table_t *h) {
parser_t *p = (parser_t *)malloc(sizeof(parser_t));
if (p == NULL)
die("malloc on parser");
p->i = 0;
p->tokens = malloc(sizeof(token_t *));
- p->symbol_table = init_hash_table(100);
+ p->symbol_table = h;
p->finished = false;
if (p->tokens == NULL)
die("malloc on p->tokens");
@@ -34,6 +34,36 @@ parser_t *init_parser(lexer_t *lexer) {
p->size = size;
return p;
}
+parser_t *init_parser(lexer_t *lexer) {
+ return init_parser_copy_hash(lexer, init_hash_table(100));
+}
+/* parser_t *init_parser(lexer_t *lexer) { */
+/* parser_t *p = (parser_t *)malloc(sizeof(parser_t)); */
+/* if (p == NULL) */
+/* die("malloc on parser"); */
+
+/* p->i = 0; */
+/* p->tokens = malloc(sizeof(token_t *)); */
+/* p->symbol_table = init_hash_table(100); */
+/* p->finished = false; */
+/* if (p->tokens == NULL) */
+/* die("malloc on p->tokens"); */
+
+/* int size = 1; */
+/* token_t *t = lexer_collect_next(lexer); */
+/* p->tokens[size - 1] = t; */
+
+/* while (true) { */
+/* t = lexer_collect_next(lexer); */
+/* size++; */
+/* p->tokens = realloc(p->tokens, size * sizeof(token_t *)); */
+/* p->tokens[size - 1] = t; */
+/* if (t == NULL) */
+/* break; */
+/* } */
+/* p->size = size; */
+/* return p; */
+/* } */
void parser_move(parser_t *parser) {
if (parser->i != parser->size - 1)
@@ -142,7 +172,41 @@ void parse_bind(parser_t *parser) {
parser_move(parser);
}
-ast_t *parse_include(parser_t *parser) { parser_eat(parser, TOKEN_STRING); }
+ast_t *parse_include(parser_t *parser) {
+ parser_move(parser);
+ if (parser->tokens[parser->i]->type != TOKEN_STRING)
+ parser_error(parser);
+ char *filename = parser->tokens[parser->i]->value;
+ char *buffer = 0;
+ long length;
+ FILE *f = fopen(filename, "rb");
+
+ if (f) {
+ fseek(f, 0, SEEK_END);
+ length = ftell(f);
+ fseek(f, 0, SEEK_SET);
+ buffer = malloc(length);
+ if (buffer) {
+ fread(buffer, 1, length, f);
+ }
+ fclose(f);
+ } else {
+ parser_error(parser);
+ }
+ if (buffer) {
+ lexer_t *lexer = init_lexer(buffer);
+ parser_t *p = init_parser_copy_hash(lexer, parser->symbol_table);
+ ast_t *root = parse_all(p);
+ parser_move(parser);
+ if (parser->tokens[parser->i]->type != TOKEN_RPAREN)
+ parser_error(parser);
+ parser_move(parser);
+ return root;
+ } else {
+ parser_error(parser);
+ }
+ return NULL;
+}
ast_t *parse_list(parser_t *parser) {
ast_t *car;
@@ -159,6 +223,8 @@ ast_t *parse_list(parser_t *parser) {
} else if (strcmp(current_token->value, "bind") == 0 && first_entry) {
parse_bind(parser);
return NULL;
+ } else if (strcmp(current_token->value, "include") == 0 && first_entry) {
+ return parse_include(parser);
} else {
car = parse_symbol(parser);
}
@@ -228,6 +294,14 @@ ast_t *parse_all(parser_t *parser) {
if (cur == NULL) {
t = parser->tokens[parser->i];
continue;
+ } else if (cur->type == AST_ROOT) {
+ for (int j = 0; j < cur->root_size; j++) {
+ i++;
+ asts = realloc(asts, i * sizeof(ast_t *));
+ asts[i - 1] = cur->subnodes[j];
+ }
+ t = parser->tokens[parser->i];
+ continue;
}
i++;
asts = realloc(asts, i * sizeof(ast_t *));