projects
/
YACASL2.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
DCで''だけを指定する場合のサンプルとテストを追加
[YACASL2.git]
/
src
/
comet2.c
diff --git
a/src/comet2.c
b/src/comet2.c
index
f499022
..
f358ec1
100644
(file)
--- a/
src/comet2.c
+++ b/
src/comet2.c
@@
-1,5
+1,6
@@
#include "package.h"
#include "exec.h"
#include "package.h"
#include "exec.h"
+#include "load.h"
/**
* comet2コマンドのオプション
/**
* comet2コマンドのオプション
@@
-9,15
+10,15
@@
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'},
- {"debug", no_argument, NULL, 'b'},
{"monitor", no_argument, NULL, 'm'},
{"memorysize", required_argument, NULL, 'M'},
{"clocks", required_argument, NULL, 'C'},
{"monitor", no_argument, NULL, 'm'},
{"memorysize", required_argument, NULL, 'M'},
{"clocks", required_argument, NULL, 'C'},
- {
"version", no_argument, NULL, 'v' },
+ {"version", no_argument, NULL, 'v' },
{"help", no_argument, NULL, 'h'},
{0, 0, 0, 0},
};
{"help", no_argument, NULL, 'h'},
{0, 0, 0, 0},
};
+
/**
* @brief comet2コマンドのメイン
*
/**
* @brief comet2コマンドのメイン
*
@@
-28,11
+29,19
@@
static struct option longopts[] = {
*/
int main(int argc, char *argv[])
{
*/
int main(int argc, char *argv[])
{
- int memsize = DEFAULT_MEMSIZE, clocks = DEFAULT_CLOCKS;
- int opt, stat = 0;
- const char *version = PACKAGE_VERSION, *cmdversion = "comet2 of YACASL2 version %s\n";
+ int memsize = DEFAULT_MEMSIZE;
+ int clocks = DEFAULT_CLOCKS;
+ int opt = 0;
+ int stat = 0;
+ const char *version = PACKAGE_VERSION;
+ const char *cmdversion = "comet2 of YACASL2 version %s\n";
const char *usage = "Usage: %s [-tTdmvh] [-M <MEMORYSIZE>] [-C <CLOCKS>] FILE\n";
const char *usage = "Usage: %s [-tTdmvh] [-M <MEMORYSIZE>] [-C <CLOCKS>] FILE\n";
+ /* エラーの定義 */
+ cerr_init();
+ addcerrlist_load();
+ addcerrlist_exec();
+
/* オプションの処理 */
while((opt = getopt_long(argc, argv, "tTdmM:C:vh", longopts, NULL)) != -1) {
switch(opt) {
/* オプションの処理 */
while((opt = getopt_long(argc, argv, "tTdmM:C:vh", longopts, NULL)) != -1) {
switch(opt) {
@@
-47,7
+56,7
@@
int main(int argc, char *argv[])
execmode.dump = true;
break;
case 'm':
execmode.dump = true;
break;
case 'm':
- execmode.
step
= true;
+ execmode.
monitor
= true;
break;
case 'M':
memsize = atoi(optarg);
break;
case 'M':
memsize = atoi(optarg);
@@
-57,36
+66,32
@@
int main(int argc, char *argv[])
break;
case 'v':
fprintf(stdout, cmdversion, version);
break;
case 'v':
fprintf(stdout, cmdversion, version);
-
return 0
;
+
goto comet2fin
;
case 'h':
fprintf(stdout, usage, argv[0]);
case 'h':
fprintf(stdout, usage, argv[0]);
-
return 0
;
+
goto comet2fin
;
case '?':
fprintf(stderr, usage, argv[0]);
case '?':
fprintf(stderr, usage, argv[0]);
- exit(1);
+ setcerr(212, ""); /* invalid option */
+ goto comet2fin;
}
}
}
}
- /* エラーの定義 */
- cerr_init();
- addcerrlist_load();
- addcerrlist_exec();
-
if(argv[optind] == NULL) {
setcerr(211, ""); /* object file not specified */
fprintf(stderr, "comet2 error - %d: %s\n", cerr->num, cerr->msg);
if(argv[optind] == NULL) {
setcerr(211, ""); /* object file not specified */
fprintf(stderr, "comet2 error - %d: %s\n", cerr->num, cerr->msg);
- freecerr(); /* エラーの解放 */
- exit(1);
+ goto comet2fin;
}
}
-
- /* COMET II仮想マシンのリセット */
- reset(memsize, clocks);
+ reset(memsize, clocks); /* COMET II仮想マシンのリセット */
execptr->start = 0;
execptr->start = 0;
- if(loadassemble(argv[optind]) == true) {
- exec(); /* プログラム実行 */
+ execptr->end = loadassemble(argv[optind], execptr->start);
+ if(execptr->end > 0 && cerr->num == 0) {
+ exec(); /* プログラム実行 */
+ }
+ shutdown(); /* COMET II仮想マシンのシャットダウン */
+comet2fin:
+ if(cerr->num > 0) {
+ stat = 1;
}
}
- /* COMET II仮想マシンのシャットダウン */
- shutdown();
- stat = (cerr->num == 0) ? 0 : 1;
freecerr(); /* エラーの解放 */
return stat;
}
freecerr(); /* エラーの解放 */
return stat;
}