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
/
casl2.c
diff --git
a/src/casl2.c
b/src/casl2.c
index
5ae4825
..
d75650d
100644
(file)
--- a/
src/casl2.c
+++ b/
src/casl2.c
@@
-24,12
+24,12
@@
static struct option longopts[] = {
};
/* casl2のエラー定義 */
};
/* casl2のエラー定義 */
-CERR
ARRAY
cerr_casl2[] = {
+CERR cerr_casl2[] = {
{ 126, "source file is not specified" },
};
bool addcerrlist_casl2()
{
{ 126, "source file is not specified" },
};
bool addcerrlist_casl2()
{
- return addcerrlist
_casl2(ARRAYSIZE
(cerr_casl2), cerr_casl2);
+ return addcerrlist
(sizeof
(cerr_casl2), cerr_casl2);
}
/* 指定されたファイルにアセンブル結果を書込 */
}
/* 指定されたファイルにアセンブル結果を書込 */
@@
-39,7
+39,7
@@
void outassemble(const char *file) {
perror(file);
exit(-1);
}
perror(file);
exit(-1);
}
- fwrite(memory, sizeof(WORD),
endptr
, fp);
+ fwrite(memory, sizeof(WORD),
progprop->end
, fp);
fclose(fp);
}
fclose(fp);
}
@@
-58,14
+58,18
@@
const char *objfile_name(const char *str)
/* casl2コマンドのメイン */
int main(int argc, char *argv[])
{
/* casl2コマンドのメイン */
int main(int argc, char *argv[])
{
- int opt, i;
+ int opt, i
, retval = 0
;
PASS pass;
bool status = false;
WORD beginptr[argc];
char *objfile = NULL;
const char *usage =
PASS pass;
bool status = false;
WORD beginptr[argc];
char *objfile = NULL;
const char *usage =
- "Usage: %s [-slLaAtTdh] [-oO<O
UTFILE>] [-M <memorysize>] [-C <clocks
>] FILE ...\n";
+ "Usage: %s [-slLaAtTdh] [-oO<O
BJECTFILE>] [-M <MEMORYSIZE>] [-C <CLOCKS
>] FILE ...\n";
+ /* エラーの初期化 */
+ cerr = malloc_chk(sizeof(CERR), "cerr");
+ addcerrlist_casl2();
+ /* オプションの処理 */
while((opt = getopt_long(argc, argv, "tTdslLao::O::AM:C:h", longopts, NULL)) != -1) {
switch(opt) {
case 's':
while((opt = getopt_long(argc, argv, "tTdslLao::O::AM:C:h", longopts, NULL)) != -1) {
switch(opt) {
case 's':
@@
-116,28
+120,26
@@
int main(int argc, char *argv[])
exit(-1);
}
}
exit(-1);
}
}
-
- #if 0
- addcerrlist_casl2();
- #endif
/* ソースファイルが指定されていない場合は終了 */
if(argv[optind] == NULL) {
setcerr(126, NULL); /* source file is not specified */
/* ソースファイルが指定されていない場合は終了 */
if(argv[optind] == NULL) {
setcerr(126, NULL); /* source file is not specified */
- goto casl2err;
+ fprintf(stderr, "CASL2 error - %d: %s\n", cerr->num, cerr->msg);
+ exit(-1);
}
/* COMET II仮想マシンのリセット */
reset();
/* アセンブル。ラベル表作成のため、2回行う */
for(pass = FIRST; pass <= SECOND; pass++) {
}
/* COMET II仮想マシンのリセット */
reset();
/* アセンブル。ラベル表作成のため、2回行う */
for(pass = FIRST; pass <= SECOND; pass++) {
- if(pass == FIRST && create_cmdtype_code() == false) {
- goto casl2err;
+ if(pass == FIRST) {
+ create_cmdtype_code(); /* 命令と命令タイプがキーのハッシュ表を作成 */
+ asprop = malloc_chk(sizeof(ASPROP), "asprop");
}
for(i = optind; i < argc; i++) {
/* データの格納開始位置 */
if(pass == FIRST) {
}
for(i = optind; i < argc; i++) {
/* データの格納開始位置 */
if(pass == FIRST) {
- beginptr[i] = ptr;
+ beginptr[i] =
asprop->
ptr;
} else if(pass == SECOND) {
} else if(pass == SECOND) {
- ptr = beginptr[i];
+
asprop->
ptr = beginptr[i];
}
if(execmode.trace == true || execmode.dump == true || asmode.src == true ||
asmode.label == true || asmode.asdetail == true)
}
if(execmode.trace == true || execmode.dump == true || asmode.src == true ||
asmode.label == true || asmode.asdetail == true)
@@
-155,23
+157,27
@@
int main(int argc, char *argv[])
return 0;
}
}
return 0;
}
}
+ if(pass == SECOND) {
+ free_cmdtype_code(); /* 命令と命令タイプがキーのハッシュ表を解放 */
+ freelabel(); /* ラベルハッシュ表を解放 */
+ }
}
}
- free_cmdtype_code(); /* 命令表の解放 */
- freelabel(); /* ラベル表の解放 */
if(status == true) {
if(objfile != NULL) {
outassemble(objfile);
}
if(asmode.onlyassemble == false) {
if(status == true) {
if(objfile != NULL) {
outassemble(objfile);
}
if(asmode.onlyassemble == false) {
- exec(); /* プログラム実行 */
+ create_code_type(); /* 命令と命令タイプがキーのハッシュ表を作成 */
+ status = exec(); /* プログラム実行 */
+ free_code_type(); /* 命令と命令タイプがキーのハッシュ表を解放 */
}
}
}
}
- if(cerrno > 0) {
- freecerr();
- exit(-1);
+ /* COMET II仮想マシンのシャットダウン */
+ shutdown();
+ if(cerr->num > 0) {
+ retval = -1;
}
}
- return 0;
-casl2err:
- fprintf(stderr, "CASL2 error - %d: %s\n", cerrno, cerrmsg);
- exit(-1);
+ /* エラーの解放 */
+ freecerr();
+ return retval;
}
}