56 lines
805 B
C
56 lines
805 B
C
#include <stdlib.h>
|
|
#include <sys/log.h>
|
|
#include <yacc/parser.tab.h>
|
|
|
|
#define LOG_LEVEL LOG_LEVEL_DEBUG
|
|
|
|
extern FILE* yyin;
|
|
|
|
/**
|
|
* @brief Log a debug message to inform about beginning exit procedures
|
|
*
|
|
*/
|
|
void notify_exit(void)
|
|
{
|
|
DEBUG("Exiting gemstone...");
|
|
}
|
|
|
|
/**
|
|
* @brief Run compiler setup here
|
|
*
|
|
*/
|
|
void setup(void)
|
|
{
|
|
// setup preample
|
|
|
|
log_init();
|
|
DEBUG("starting gemstone...");
|
|
|
|
#if LOG_LEVEL <= LOG_LEVEL_DEBUG
|
|
atexit(¬ify_exit);
|
|
#endif
|
|
|
|
// actual setup
|
|
|
|
DEBUG("finished starting up gemstone...");
|
|
}
|
|
|
|
int main(void) {
|
|
setup();
|
|
|
|
FILE* input = fopen("program.gem", "r");
|
|
|
|
if (NULL == Input)
|
|
{
|
|
ERROR("File couldn't be opened!");
|
|
atexit();
|
|
}
|
|
|
|
yyin = input;
|
|
|
|
yyparse();
|
|
|
|
atexit();
|
|
return 0;
|
|
}
|