gemstone/src/main.c

92 lines
1.7 KiB
C
Raw Normal View History

#include <ast/ast.h>
#include <stdio.h>
#include <stdlib.h>
#include <sys/log.h>
2024-02-04 15:23:32 +00:00
#define LOG_LEVEL LOG_LEVEL_DEBUG
2024-04-26 14:21:54 +00:00
extern FILE* yyin;
2024-04-12 15:29:39 +00:00
/**
* @brief Log a debug message to inform about beginning exit procedures
*
*/
void notify_exit(void)
{
DEBUG("Exiting gemstone...");
}
2024-04-23 13:27:11 +00:00
/**
* @brief Closes File after compiling.
*
*/
2024-04-26 14:21:54 +00:00
void close_file(void)
2024-04-23 13:27:11 +00:00
{
2024-04-26 14:21:54 +00:00
if (NULL != yyin)
{
fclose(yyin);
}
2024-04-23 13:27:11 +00:00
}
2024-04-12 15:29:39 +00:00
/**
* @brief Run compiler setup here
*
*/
void setup(void)
{
2024-04-12 15:29:39 +00:00
// setup preample
log_init();
DEBUG("starting gemstone...");
#if LOG_LEVEL <= LOG_LEVEL_DEBUG
atexit(&notify_exit);
#endif
2024-04-12 15:29:39 +00:00
// actual setup
DEBUG("finished starting up gemstone...");
}
int main(int argc, char *argv[]) {
setup();
2024-04-26 14:21:54 +00:00
atexit(close_file);
// Check for file input as argument
if (2 != argc)
{
2024-04-23 13:27:11 +00:00
INFO("Usage: %s <filename>\n", argv[0]);
PANIC("No File could be found");
}
// filename as first argument
char *filename = argv[1];
2024-04-26 14:21:54 +00:00
FILE *file = fopen(filename, "r");
struct AST_Node_t* node = AST_new_node(AST_Branch, NULL);
struct AST_Node_t* child = AST_new_node(AST_OperatorAdd, NULL);
AST_push_node(child, AST_new_node(AST_IntegerLiteral, "43"));
AST_push_node(child, AST_new_node(AST_IntegerLiteral, "9"));
AST_push_node(node, child);
AST_push_node(node, AST_new_node(AST_Expression, NULL));
AST_push_node(node, AST_new_node(AST_Expression, NULL));
FILE* out = fopen("ast.gv", "w+");
// convert this file ^^^^^^
// to an svg with: `dot -Tsvg ast.gv > graph.svg`
AST_fprint_graphviz(out, node);
AST_delete_node(node);
fflush(out);
fclose(out);
2024-02-04 15:23:32 +00:00
return 0;
}