1c47d193d1305cf1df2f83038f273d78a539dd1a
[YACASL2.git] / src / comet2.c
1 #include "casl2.h"
2 #include "exec.h"
3 #define _GNU_SOURCE
4 #include <getopt.h>
5
6 static struct option longopts[] = {
7     {"trace", no_argument, NULL, 't'},
8     {"tracearithmetic", no_argument, NULL, 't'},
9     {"tracelogical", no_argument, NULL, 'T'},
10     {"dump", no_argument, NULL, 'd'},
11     {"memorysize", required_argument, NULL, 'M'},
12     {"clocks", required_argument, NULL, 'C'},
13     {"help", no_argument, NULL, 'h'},
14     {0, 0, 0, 0}
15 };
16
17 EXECMODE execmode = {false, false, false};
18
19 /* 指定されたファイルからCOMET II仮想メモリ(アセンブル結果)を読込 */
20 bool inassemble(char *file) {
21     FILE *fp;
22     reset();
23     if((fp = fopen(file, "r")) == NULL) {
24         perror(file);
25         return false;
26     }
27     fread(memory, sizeof(WORD), memsize, fp);
28     fclose(fp);
29     return true;
30 }
31
32 int main(int argc, char *argv[])
33 {
34     int opt;
35     const char *usage = "Usage: %s [-tTdh] [-M <memorysize>] [-C <clocks>] FILE\n";
36
37     while((opt = getopt_long(argc, argv, "tTdM:C:h", longopts, NULL)) != -1) {
38         switch(opt) {
39         case 't':
40             (&execmode)->tracemode = true;
41             break;
42         case 'T':
43             (&execmode)->tracemode = true;
44             (&execmode)->logicalmode = true;
45             break;
46         case 'd':
47             (&execmode)->dumpmode = true;
48             break;
49         case 'M':
50             memsize = atoi(optarg);
51             break;
52         case 'C':
53             clocks = atoi(optarg);
54             break;
55         case 'h':
56             fprintf(stdout, usage, argv[0]);
57             return 0;
58         case '?':
59             fprintf(stderr, usage, argv[0]);
60             exit(-1);
61         }
62     }
63     if(inassemble(argv[optind]) == true) {
64         exec();    /* プログラム実行 */
65     }
66     if(cerrno > 0) {
67         freecerr();
68         exit(-1);
69     }
70     return 0;
71 }