mirror of
https://github.com/krgamestudios/Toy.git
synced 2026-04-16 07:14:07 +10:00
166 lines
4.3 KiB
C
166 lines
4.3 KiB
C
#include "toy_parser.h"
|
|
|
|
#include "toy_console_colors.h"
|
|
|
|
#include "../repl/repl_tools.h"
|
|
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
|
|
int main() {
|
|
{
|
|
//source
|
|
const char* source = "print null;";
|
|
|
|
//test init & quit
|
|
Toy_Lexer lexer;
|
|
Toy_Parser parser;
|
|
Toy_initLexer(&lexer, source);
|
|
Toy_initParser(&parser, &lexer);
|
|
|
|
Toy_freeParser(&parser);
|
|
}
|
|
|
|
{
|
|
//source
|
|
const char* source = "print null;";
|
|
|
|
//test parsing
|
|
Toy_Lexer lexer;
|
|
Toy_Parser parser;
|
|
Toy_initLexer(&lexer, source);
|
|
Toy_initParser(&parser, &lexer);
|
|
|
|
Toy_ASTNode* node = Toy_scanParser(&parser);
|
|
|
|
//inspect the node
|
|
if (node == NULL) {
|
|
fprintf(stderr, TOY_CC_ERROR "ERROR: ASTNode is null\n" TOY_CC_RESET);
|
|
return -1;
|
|
}
|
|
|
|
if (node->type != TOY_AST_NODE_UNARY || node->unary.opcode != TOY_OP_PRINT) {
|
|
fprintf(stderr, TOY_CC_ERROR "ERROR: ASTNode is not a unary print instruction\n" TOY_CC_RESET);
|
|
return -1;
|
|
}
|
|
|
|
if (node->unary.child->type != TOY_AST_NODE_LITERAL || !TOY_IS_NULL(node->unary.child->atomic.literal)) {
|
|
fprintf(stderr, TOY_CC_ERROR "ERROR: ASTNode to be printed is not a null literal\n" TOY_CC_RESET);
|
|
return -1;
|
|
}
|
|
|
|
//cleanup
|
|
Toy_freeASTNode(node);
|
|
Toy_freeParser(&parser);
|
|
}
|
|
|
|
{
|
|
//get the source file
|
|
size_t size = 0;
|
|
const char* source = (const char*)Toy_readFile("scripts/parser_sample_code.toy", &size);
|
|
|
|
//test parsing a chunk of junk (valgrind will find leaks)
|
|
Toy_Lexer lexer;
|
|
Toy_Parser parser;
|
|
Toy_initLexer(&lexer, source);
|
|
Toy_initParser(&parser, &lexer);
|
|
|
|
Toy_ASTNode* node = Toy_scanParser(&parser);
|
|
|
|
while (node != NULL) {
|
|
if (node->type == TOY_AST_NODE_ERROR) {
|
|
fprintf(stderr, TOY_CC_ERROR "ERROR: Error node detected\n" TOY_CC_RESET);
|
|
return -1;
|
|
}
|
|
|
|
Toy_freeASTNode(node);
|
|
node = Toy_scanParser(&parser);
|
|
}
|
|
|
|
//cleanup
|
|
Toy_freeParser(&parser);
|
|
free((void*)source);
|
|
}
|
|
|
|
{
|
|
//test parsing of escaped characters
|
|
const char* source = "print \"\\\"\";"; //NOTE: this string goes through two layers of escaping
|
|
|
|
//test parsing
|
|
Toy_Lexer lexer;
|
|
Toy_Parser parser;
|
|
Toy_initLexer(&lexer, source);
|
|
Toy_initParser(&parser, &lexer);
|
|
|
|
Toy_ASTNode* node = Toy_scanParser(&parser);
|
|
|
|
//inspect the node
|
|
if (node == NULL) {
|
|
fprintf(stderr, TOY_CC_ERROR "ERROR: ASTNode is null\n" TOY_CC_RESET);
|
|
return -1;
|
|
}
|
|
|
|
if (node->type != TOY_AST_NODE_UNARY || node->unary.opcode != TOY_OP_PRINT) {
|
|
fprintf(stderr, TOY_CC_ERROR "ERROR: ASTNode is not a unary print instruction\n" TOY_CC_RESET);
|
|
return -1;
|
|
}
|
|
|
|
if (node->unary.child->type != TOY_AST_NODE_LITERAL || !TOY_IS_STRING(node->unary.child->atomic.literal)) {
|
|
fprintf(stderr, TOY_CC_ERROR "ERROR: ASTNode to be printed is not a string literal\n" TOY_CC_RESET);
|
|
return -1;
|
|
}
|
|
|
|
if (!Toy_equalsRefStringCString(TOY_AS_STRING(node->unary.child->atomic.literal), "\"")) {
|
|
fprintf(stderr, TOY_CC_ERROR "ERROR: ASTNode to be printed is not an escaped character, found: %s\n" TOY_CC_RESET, Toy_toCString(TOY_AS_STRING(node->unary.child->atomic.literal)));
|
|
return -1;
|
|
}
|
|
|
|
//cleanup
|
|
Toy_freeASTNode(node);
|
|
Toy_freeParser(&parser);
|
|
}
|
|
|
|
{
|
|
//test parsing of underscored numbers
|
|
const char* source = "print 1_000_000;";
|
|
|
|
//test parsing
|
|
Toy_Lexer lexer;
|
|
Toy_Parser parser;
|
|
Toy_initLexer(&lexer, source);
|
|
Toy_initParser(&parser, &lexer);
|
|
|
|
Toy_ASTNode* node = Toy_scanParser(&parser);
|
|
|
|
//inspect the node
|
|
if (node == NULL) {
|
|
fprintf(stderr, TOY_CC_ERROR "ERROR: ASTNode is null\n" TOY_CC_RESET);
|
|
return -1;
|
|
}
|
|
|
|
if (node->type != TOY_AST_NODE_UNARY || node->unary.opcode != TOY_OP_PRINT) {
|
|
fprintf(stderr, TOY_CC_ERROR "ERROR: ASTNode is not a unary print instruction\n" TOY_CC_RESET);
|
|
return -1;
|
|
}
|
|
|
|
if (node->unary.child->type != TOY_AST_NODE_LITERAL || !TOY_IS_INTEGER(node->unary.child->atomic.literal)) {
|
|
fprintf(stderr, TOY_CC_ERROR "ERROR: ASTNode to be printed is not a string literal\n" TOY_CC_RESET);
|
|
return -1;
|
|
}
|
|
|
|
if (TOY_AS_INTEGER(node->unary.child->atomic.literal) != 1000000) {
|
|
fprintf(stderr, TOY_CC_ERROR "ERROR: ASTNode to be printed is not the correct value, found: %d\n" TOY_CC_RESET, TOY_AS_INTEGER(node->unary.child->atomic.literal));
|
|
return -1;
|
|
}
|
|
|
|
//cleanup
|
|
Toy_freeASTNode(node);
|
|
Toy_freeParser(&parser);
|
|
}
|
|
|
|
printf(TOY_CC_NOTICE "All good\n" TOY_CC_RESET);
|
|
return 0;
|
|
}
|
|
|