diff --git a/Makefile b/Makefile index c031a22..6309379 100644 --- a/Makefile +++ b/Makefile @@ -10,10 +10,10 @@ BINDIR = $(PREFIX)/bin MANDIR = $(PREFIX)/share/man/man1 # Flags -LDFLAGS = $(shell pkg-config --libs) -CFLAGS = -O3 -march=native -mtune=native -pipe -g -std=c99 -pedantic -Wall -D_DEFAULT_SOURCE -D_XOPEN_SOURCE=600 $(shell pkg-config --cflags) +LDFLAGS = +CFLAGS = -O3 -march=native -mtune=native -pipe -s -std=c99 -pedantic -Wall -D_DEFAULT_SOURCE -D_XOPEN_SOURCE=600 -SRC = slr.c lexer.c +SRC = slr.c lexer.c parser.c $(TARGET): $(SRC) $(CC) $(SRC) -o $@ $(CFLAGS) $(LDFLAGS) diff --git a/README.md b/README.md index a00da11..4c67772 100644 --- a/README.md +++ b/README.md @@ -1,7 +1,18 @@ # S Lang Runtime - S Lang(Slang) Runtime is a interpreter for Slang. +# Usage + +# Depedencies +None + +# Building +You will need to run these with elevated privilages. +``` +$ make +# make install +``` + # Contributions Contributions are welcomed, feel free to open a pull request. diff --git a/lexer.c b/lexer.c index ab7c694..c21f340 100644 --- a/lexer.c +++ b/lexer.c @@ -14,35 +14,17 @@ Token *lexer(char *buf) while(current[current_index] != '\0') { Token *token = NULL; if(current[current_index] == ';') { - token = malloc(sizeof(Token)); - char *value = malloc(2 * sizeof(char)); - value[0] = current[current_index]; - value[1] = '\0'; - token->value = value; - token->type = SEPARATOR; + token = generate_separator(current, ¤t_index); tokens[tokens_index] = *token; tokens_index++; - printf("FOUND SEMICOLON\n"); } else if(current[current_index] == '(') { - token = malloc(sizeof(Token)); - char *value = malloc(2 * sizeof(char)); - value[0] = current[current_index]; - value[1] = '\0'; - token->value = value; - token->type = SEPARATOR; + token = generate_separator(current, ¤t_index); tokens[tokens_index] = *token; tokens_index++; - printf("FOUND OPEN PAREN\n"); } else if(current[current_index] == ')') { - token = malloc(sizeof(Token)); - char *value = malloc(2 * sizeof(char)); - value[0] = current[current_index]; - value[1] = '\0'; - token->value = value; - token->type = SEPARATOR; + token = generate_separator(current, ¤t_index); tokens[tokens_index] = *token; tokens_index++; - printf("FOUND CLOSE PAREN\n"); } else if(isdigit(current[current_index])) { token = generate_number(current, ¤t_index); tokens[tokens_index] = *token; @@ -54,9 +36,6 @@ Token *lexer(char *buf) tokens_index++; current_index--; } - if (token != NULL) { - print_token(*token); - } current_index++; } tokens[tokens_index].type = END_OF_TOKENS; @@ -64,3 +43,71 @@ Token *lexer(char *buf) return tokens; } +void print_token(Token token) +{ + printf("Token Value: \""); + for (int i = 0; token.value[i] != '\0'; i++) { + printf("%c", token.value[i]); + } + printf("\"\nToken Type: "); + switch (token.type) { + case INT: + printf("int\n"); + break; + case KEYWORD: + printf("Keyword\n"); + break; + case SEPARATOR: + printf("Separator\n"); + break; + case END_OF_TOKENS: + printf("End of Tokens\n"); + break; + } +} + +Token *generate_separator(char *current, int *current_index) +{ + Token *token = malloc(sizeof(Token)); + token->value = malloc(sizeof(char) * 2); + token->value[0] = current[*current_index]; + token->value[1] = '\0'; + token->type = SEPARATOR; + return token; +} + +Token *generate_number(char *current, int *current_index) +{ + Token *token = malloc(sizeof(Token)); + token->type = INT; + char *value = malloc(8 * sizeof(char)); + int value_index = 0; + while(isdigit(current[*current_index]) && current[*current_index] != '\0') { + value[value_index] = current[*current_index]; + value_index++; + (*current_index)++; + } + value[value_index] = '\0'; + token->value = value; + return token; +} + +Token *generate_keyword(char *current, int *current_index) +{ + Token *token = malloc(sizeof(Token)); + char *keyword = malloc(8 * sizeof(char)); + int keyword_index = 0; + while(isalpha(current[*current_index]) && current[*current_index] != '\0') { + keyword[keyword_index] = current[*current_index]; + keyword_index++; + (*current_index)++; + } + keyword[keyword_index] = '\0'; + if(strcmp(keyword, "exit") == 0) { + printf("TYPE EXIT\n"); + token->type = KEYWORD; + } + token->type = KEYWORD; + token->value = keyword; + return token; +} diff --git a/lexer.h b/lexer.h index d76dd3c..71aa566 100644 --- a/lexer.h +++ b/lexer.h @@ -1,8 +1,22 @@ #ifndef LEXER_H_ #define LEXER_H_ -#include "slr.h" +typedef enum { + INT, + KEYWORD, + SEPARATOR, + END_OF_TOKENS, +} TokenType; + +typedef struct { + TokenType type; + char *value; +} Token; Token *lexer(char *buf); +void print_token(Token token); +Token *generate_separator(char *current, int *current_index); +Token *generate_number(char *current, int *current_index); +Token *generate_keyword(char *current, int *current_index); #endif diff --git a/parser.c b/parser.c new file mode 100644 index 0000000..e0e516f --- /dev/null +++ b/parser.c @@ -0,0 +1,102 @@ +#include +#include +#include +#include + +#include "lexer.h" + +typedef enum { + INT_LIT, + STATEMENT, + EXTRA, + BEGINNING, +} NodeTypes; + +typedef struct Node { + char *value; + NodeTypes type; + struct Node *right; + struct Node *left; +} Node; + +void print_tree(Node *node){ + if(node == NULL){ + return; + } + for(size_t i = 0; node->value[i] != '\0'; i++){ + printf("%c", node->value[i]); + } + printf("\n"); + print_tree(node->left); + print_tree(node->right); +} + +Node *init_node(Node *node, char *value, NodeTypes type){ + node = malloc(sizeof(Node)); + node->value = malloc(sizeof(char) * 2); + node->type = (int)type; + node->value = value; + node->left = NULL; + node->right = NULL; + return node; +} + +Token *parser(Token *tokens){ + Token *current_token = &tokens[0]; + Node *root = malloc(sizeof(Node)); + Node *left = malloc(sizeof(Node)); + Node *right = malloc(sizeof(Node)); + root = init_node(root, "PROGRAM", BEGINNING); + + print_tree(root); + + Node *current = root; + + while(current_token->type != END_OF_TOKENS){ + if(current == NULL){ + break; + } + if(current == root){ + //; + } + + if(current_token->type == KEYWORD && strcmp(current_token->value, "exit")){ + Node *exit_node = malloc(sizeof(Node)); + exit_node = init_node(exit_node, current_token->value, STATEMENT); + root->right = exit_node; + current = exit_node; + current_token++; + if(current_token->type != SEPARATOR){ + printf("ERROR\n"); + exit(1); + } + Node *open_paren_node = malloc(sizeof(Node)); + open_paren_node = init_node(open_paren_node, current_token->value, EXTRA); + current->left = open_paren_node; + + current_token++; + + Node *expr_node = malloc(sizeof(Node)); + expr_node = init_node(expr_node, current_token->value, INT_LIT); + current->left->left = expr_node; + + current_token++; + + Node *close_paren_node = malloc(sizeof(Node)); + close_paren_node = init_node(close_paren_node, current_token->value, EXTRA); + current->left->right = close_paren_node; + + current_token++; + + Node *semi_node = malloc(sizeof(Node)); + semi_node = init_node(semi_node, current_token->value, EXTRA); + current->right = semi_node; + + printf("EXIT\n"); + break; + } + current_token++; + } + print_tree(root); + return current_token; +} diff --git a/parser.h b/parser.h new file mode 100644 index 0000000..ccbc562 --- /dev/null +++ b/parser.h @@ -0,0 +1,6 @@ +#ifndef PARSER_H_ +#define PARSER_H_ + +Token *parser(Token *tokens); + +#endif diff --git a/slr.c b/slr.c index d6b5dd6..715a2c2 100644 --- a/slr.c +++ b/slr.c @@ -3,64 +3,8 @@ #include #include -#include "slr.h" #include "lexer.h" - -void print_token(Token token) -{ - printf("Token Value: "); - for (int i = 0; token.value[i] != '\0'; i++) { - printf("%c", token.value[i]); - } - printf("\nToken Type: "); - switch (token.type) { - case INT: - printf("int\n"); - break; - case KEYWORD: - printf("Keyword\n"); - break; - case SEPARATOR: - printf("Separator\n"); - break; - } -} - -Token *generate_number(char *current, int *current_index) -{ - Token *token = malloc(sizeof(Token)); - token->type = INT; - char *value = malloc(8 * sizeof(char)); - int value_index = 0; - while(isdigit(current[*current_index]) && current[*current_index] != '\0') { - value[value_index] = current[*current_index]; - value_index++; - (*current_index)++; - } - value[value_index] = '\0'; - token->value = value; - return token; -} - -Token *generate_keyword(char *current, int *current_index) -{ - Token *token = malloc(sizeof(Token)); - char *keyword = malloc(8 * sizeof(char)); - int keyword_index = 0; - while(isalpha(current[*current_index]) && current[*current_index] != '\0') { - keyword[keyword_index] = current[*current_index]; - keyword_index++; - (*current_index)++; - } - keyword[keyword_index] = '\0'; - if(strcmp(keyword, "exit") == 0) { - printf("TYPE EXIT\n"); - token->type = KEYWORD; - } - token->type = KEYWORD; - token->value = keyword; - return token; -} +#include "parser.h" long long get_file_length(FILE *file) { @@ -70,18 +14,24 @@ long long get_file_length(FILE *file) return length; } - int main(int argc, char **argv) { if (argc < 2) { fprintf(stderr, "\033[1;37mslr:\033[0m \033[1;31mfatal error:\033[0m no input files\ninterpretation termined.\n"); - exit(1); + return 1; } FILE *file = fopen(argv[1], "r"); + if (!file) { + perror("fopen"); + return 1; + } long long length = get_file_length(file); char *buf = malloc(length * sizeof(char)); fread(buf, 1, length, file); fclose(file); buf[length + 1] = '\0'; Token *tokens = lexer(buf); + for(size_t i = 0; tokens[i].type != END_OF_TOKENS; i++){ + print_token(tokens[i]); + } } diff --git a/slr.h b/slr.h deleted file mode 100644 index 504c5ae..0000000 --- a/slr.h +++ /dev/null @@ -1,20 +0,0 @@ -#ifndef SLR_H_ -#define SLR_H_ - -typedef enum { - INT, - KEYWORD, - SEPARATOR, - END_OF_TOKENS, -} TokenType; - -typedef struct { - TokenType type; - char *value; -} Token; - -void print_token(Token token); -Token *generate_number(char *current, int *current_index); -Token *generate_keyword(char *current, int *current_index); - -#endif