ソースコードの推敲
[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 CERR cerr_comet2[] = {
25     { 127, "invalid option" },
26 };
27
28 void addcerrlist_comet2()
29 {
30     addcerrlist(ARRAYSIZE(cerr_comet2), cerr_comet2);
31 }
32
33 /**
34  * @brief comet2コマンドのメイン
35  *
36  * @return 正常終了時は0、異常終了時は1
37  *
38  * @param argc コマンドライン引数の数
39  * @param *argv[] コマンドライン引数の配列
40  */
41 int main(int argc, char *argv[])
42 {
43     int memsize = DEFAULT_MEMSIZE, clocks = DEFAULT_CLOCKS;
44     int opt, stat = 0;
45     const char *version = PACKAGE_VERSION,  *cmdversion = "comet2 of YACASL2 version %s\n";
46     const char *usage = "Usage: %s [-tTdmvh] [-M <MEMORYSIZE>] [-C <CLOCKS>] FILE\n";
47
48     /* エラーの定義 */
49     cerr_init();
50     addcerrlist_comet2();
51     addcerrlist_load();
52     addcerrlist_exec();
53
54     /* オプションの処理 */
55     while((opt = getopt_long(argc, argv, "tTdmM:C:vh", longopts, NULL)) != -1) {
56         switch(opt) {
57         case 't':
58             execmode.trace = true;
59             break;
60         case 'T':
61             execmode.trace = true;
62             execmode.logical = true;
63             break;
64         case 'd':
65             execmode.dump = true;
66             break;
67         case 'm':
68             execmode.monitor = true;
69             break;
70         case 'M':
71             memsize = atoi(optarg);
72             break;
73         case 'C':
74             clocks = atoi(optarg);
75             break;
76         case 'v':
77             fprintf(stdout, cmdversion, version);
78             goto comet2fin;
79         case 'h':
80             fprintf(stdout, usage, argv[0]);
81             goto comet2fin;
82         case '?':
83             fprintf(stderr, usage, argv[0]);
84             setcerr(212, "");    /* invalid option */
85             goto comet2fin;
86         }
87     }
88     if(argv[optind] == NULL) {
89         setcerr(211, "");    /* object file not specified */
90         fprintf(stderr, "comet2 error - %d: %s\n", cerr->num, cerr->msg);
91         goto comet2fin;
92     }
93     reset(memsize, clocks);     /* COMET II仮想マシンのリセット */
94     execptr->start = 0;
95     execptr->end = loadassemble(argv[optind], execptr->start);
96     if(execptr->end > 0 && cerr->num == 0) {
97         exec();                 /* プログラム実行 */
98     }
99     shutdown();                 /* COMET II仮想マシンのシャットダウン */
100 comet2fin:
101     if(cerr->num > 0) {
102         stat = 1;
103     }
104     freecerr();                 /* エラーの解放 */
105     return stat;
106 }