3 \details The driver assumes the existence of a bison-generated parser,
4 referenced by the external function 'yyparse'.
5 It also assumes the existence of a lexer which must be initialized
6 before parsing, referenced by the external function 'lexer_init'
7 which assumes standard error handling.
8 All input arguments are made available through the exposed (that is,
9 non-static) array of character pointers 'cargs', which point
10 to the non-duplicated strings in 'argv' directly from the system.
11 \author Jordan Lavatai
13 ----------------------------------------------------------------------------*/
15 #include <stdio.h> //print
16 #include <errno.h> //errors
17 #include <string.h> //strndupa
19 #include <stdlib.h> //exit
20 #include <unistd.h> //getopt
22 #include "parser.tab.h" //bison
24 const char* cargs
['Z'] = {0};
26 int main(int, char*[]);
35 extern //apc/parser.tab.c
40 /* Main entry from terminal
41 parses the command line and kicks off recursive scanning
47 #define $($)#$ //stringifier
49 #define MAXERR "-%c allows at most " $(MAXSTR) " input characters\n", opt
51 #define USAGE "Usage %s [-d dir_root][-o output_file][-h]\n", argv[0]
54 "\t\t-d\tRoot directory to parse from \t[./]\n" \
55 "\t\t-o\tOutput filename \t\t[a.asspak]\n" \
56 "\t\t-h\tPrint this help\n"
61 switch (opt
= getopt(argc
, argv
, OPTS
))
66 if (strnlen(optarg
, MAXSTR
) != MAXSTR
)
67 { cargs
[opt
] = optarg
;
70 fprintf(stderr
, MAXERR
);
72 fprintf(stderr
, USAGE
);
79 if (lexer_init() || ir_init())