projects
/
YACASL2.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
逆アセンブルのリファクタリング
[YACASL2.git]
/
src
/
comet2.c
diff --git
a/src/comet2.c
b/src/comet2.c
index
2f7696a
..
a3d6ee1
100644
(file)
--- a/
src/comet2.c
+++ b/
src/comet2.c
@@
-1,11
+1,5
@@
-#include <stdio.h>
-#include <stdlib.h>
-#define _GNU_SOURCE
-#include <getopt.h>
-
+#include "package.h"
#include "exec.h"
#include "exec.h"
-#include "cmem.h"
-#include "cerr.h"
/**
* comet2コマンドのオプション
/**
* comet2コマンドのオプション
@@
-15,34
+9,31
@@
static struct option longopts[] = {
{"tracearithmetic", no_argument, NULL, 't'},
{"tracelogical", no_argument, NULL, 'T'},
{"dump", no_argument, NULL, 'd'},
{"tracearithmetic", no_argument, NULL, 't'},
{"tracelogical", no_argument, NULL, 'T'},
{"dump", no_argument, NULL, 'd'},
+ {"monitor", no_argument, NULL, 'm'},
{"memorysize", required_argument, NULL, 'M'},
{"clocks", required_argument, NULL, 'C'},
{"memorysize", required_argument, NULL, 'M'},
{"clocks", required_argument, NULL, 'C'},
+ {"version", no_argument, NULL, 'v' },
{"help", no_argument, NULL, 'h'},
{"help", no_argument, NULL, 'h'},
- {0, 0, 0, 0}
-};
-
-/**
- * comet2コマンドのエラー
- */
-static CERR cerr_comet2[] = {
- { 208, "object file is not specified" },
+ {0, 0, 0, 0},
};
/**
};
/**
- * comet2コマンドのメイン
+ * @brief comet2コマンドのメイン
+ *
+ * @return 正常終了時は0、異常終了時は1
+ *
+ * @param argc コマンドライン引数の数
+ * @param *argv[] コマンドライン引数の配列
*/
int main(int argc, char *argv[])
{
int memsize = DEFAULT_MEMSIZE, clocks = DEFAULT_CLOCKS;
*/
int main(int argc, char *argv[])
{
int memsize = DEFAULT_MEMSIZE, clocks = DEFAULT_CLOCKS;
- int opt, status = 0;
- const char *usage = "Usage: %s [-tTdh] [-M <MEMORYSIZE>] [-C <CLOCKS>] FILE\n";
-
- cerr_init();
- addcerrlist(ARRAYSIZE(cerr_comet2), cerr_comet2);
- addcerrlist_exec();
+ int opt, stat = 0;
+ const char *version = PACKAGE_VERSION, *cmdversion = "comet2 of YACASL2 version %s\n";
+ const char *usage = "Usage: %s [-tTdmvh] [-M <MEMORYSIZE>] [-C <CLOCKS>] FILE\n";
/* オプションの処理 */
/* オプションの処理 */
- while((opt = getopt_long(argc, argv, "tTd
M:C:
h", longopts, NULL)) != -1) {
+ while((opt = getopt_long(argc, argv, "tTd
mM:C:v
h", longopts, NULL)) != -1) {
switch(opt) {
case 't':
execmode.trace = true;
switch(opt) {
case 't':
execmode.trace = true;
@@
-54,39
+45,47
@@
int main(int argc, char *argv[])
case 'd':
execmode.dump = true;
break;
case 'd':
execmode.dump = true;
break;
+ case 'm':
+ execmode.step = true;
+ break;
case 'M':
memsize = atoi(optarg);
break;
case 'C':
clocks = atoi(optarg);
break;
case 'M':
memsize = atoi(optarg);
break;
case 'C':
clocks = atoi(optarg);
break;
+ case 'v':
+ fprintf(stdout, cmdversion, version);
+ return 0;
case 'h':
fprintf(stdout, usage, argv[0]);
return 0;
case '?':
fprintf(stderr, usage, argv[0]);
case 'h':
fprintf(stdout, usage, argv[0]);
return 0;
case '?':
fprintf(stderr, usage, argv[0]);
- exit(
-
1);
+ exit(1);
}
}
}
}
+ /* エラーの定義 */
+ cerr_init();
+ addcerrlist_load();
+ addcerrlist_exec();
+
if(argv[optind] == NULL) {
if(argv[optind] == NULL) {
- setcerr(2
08, NULL); /* object file is
not specified */
+ setcerr(2
11, ""); /* object file
not specified */
fprintf(stderr, "comet2 error - %d: %s\n", cerr->num, cerr->msg);
fprintf(stderr, "comet2 error - %d: %s\n", cerr->num, cerr->msg);
- exit(-1);
+ freecerr(); /* エラーの解放 */
+ exit(1);
}
}
+
/* COMET II仮想マシンのリセット */
reset(memsize, clocks);
/* COMET II仮想マシンのリセット */
reset(memsize, clocks);
-
prog
->start = 0;
+
execptr
->start = 0;
if(loadassemble(argv[optind]) == true) {
if(loadassemble(argv[optind]) == true) {
- create_code_type(); /* タイプがキーの命令ハッシュ表を作成 */
exec(); /* プログラム実行 */
exec(); /* プログラム実行 */
- free_code_type(); /* タイプがキーの命令ハッシュ表を解放 */
}
/* COMET II仮想マシンのシャットダウン */
shutdown();
}
/* COMET II仮想マシンのシャットダウン */
shutdown();
- if(cerr->num > 0) {
- status = -1;
- }
- /* エラーの解放 */
- freecerr();
- return status;
+ stat = (cerr->num == 0) ? 0 : 1;
+ freecerr(); /* エラーの解放 */
+ return stat;
}
}