8b827ba8dc9e93b4406872b8c814404add245389
[YACASL2.git] / src / comet2.c
1 #include "package.h"
2 #include "exec.h"
3
4 /**
5  * comet2コマンドのオプション
6  */
7 static struct option longopts[] = {
8     {"trace", no_argument, NULL, 't'},
9     {"tracearithmetic", no_argument, NULL, 't'},
10     {"tracelogical", no_argument, NULL, 'T'},
11     {"dump", no_argument, NULL, 'd'},
12     {"monitor", no_argument, NULL, 'm'},
13     {"memorysize", required_argument, NULL, 'M'},
14     {"clocks", required_argument, NULL, 'C'},
15     {"version", no_argument, NULL, 'v' },
16     {"help", no_argument, NULL, 'h'},
17     {0, 0, 0, 0},
18 };
19
20
21 /**
22  * @brief comet2コマンドのメイン
23  *
24  * @return 正常終了時は0、異常終了時は1
25  *
26  * @param argc コマンドライン引数の数
27  * @param *argv[] コマンドライン引数の配列
28  */
29 int main(int argc, char *argv[])
30 {
31     int memsize = DEFAULT_MEMSIZE;
32     int clocks = DEFAULT_CLOCKS;
33     int opt = 0;
34     int stat = 0;
35     const char *version = PACKAGE_VERSION;
36     const char *cmdversion = "comet2 of YACASL2 version %s\n";
37     const char *usage = "Usage: %s [-tTdmvh] [-M <MEMORYSIZE>] [-C <CLOCKS>] FILE\n";
38
39     /* エラーの定義 */
40     cerr_init();
41     addcerrlist_load();
42     addcerrlist_exec();
43
44     /* オプションの処理 */
45     while((opt = getopt_long(argc, argv, "tTdmM:C:vh", longopts, NULL)) != -1) {
46         switch(opt) {
47         case 't':
48             execmode.trace = true;
49             break;
50         case 'T':
51             execmode.trace = true;
52             execmode.logical = true;
53             break;
54         case 'd':
55             execmode.dump = true;
56             break;
57         case 'm':
58             execmode.monitor = true;
59             break;
60         case 'M':
61             memsize = atoi(optarg);
62             break;
63         case 'C':
64             clocks = atoi(optarg);
65             break;
66         case 'v':
67             fprintf(stdout, cmdversion, version);
68             goto comet2fin;
69         case 'h':
70             fprintf(stdout, usage, argv[0]);
71             goto comet2fin;
72         case '?':
73             fprintf(stderr, usage, argv[0]);
74             setcerr(212, "");    /* invalid option */
75             goto comet2fin;
76         }
77     }
78     if(argv[optind] == NULL) {
79         setcerr(211, "");    /* object file not specified */
80         fprintf(stderr, "comet2 error - %d: %s\n", cerr->num, cerr->msg);
81         goto comet2fin;
82     }
83     reset(memsize, clocks);     /* COMET II仮想マシンのリセット */
84     execptr->start = 0;
85     execptr->end = loadassemble(argv[optind], execptr->start);
86     if(execptr->end > 0 && cerr->num == 0) {
87         exec();                 /* プログラム実行 */
88     }
89     shutdown();                 /* COMET II仮想マシンのシャットダウン */
90 comet2fin:
91     if(cerr->num > 0) {
92         stat = 1;
93     }
94     freecerr();                 /* エラーの解放 */
95     return stat;
96 }