X-Git-Url: http://j8takagi.net/cgi-bin/gitweb.cgi?p=YACASL2.git;a=blobdiff_plain;f=src%2Fcasl2.c;h=c7ef4f034c167bb37312cf2bbb508c978a97b654;hp=334e2a1c63400778006facbcaeed8e19cd70ac11;hb=86e559d164166966a797a1e5855871d48e087ddd;hpb=a7982d41c9809fdddbc5bac27c9d08b8a9d05012 diff --git a/src/casl2.c b/src/casl2.c index 334e2a1..c7ef4f0 100644 --- a/src/casl2.c +++ b/src/casl2.c @@ -16,7 +16,7 @@ void addcerrlist_casl2(); * * @param *str ファイル名 */ -const char *objfile_name(const char *str); +char *objfile_name(const char *str); /** * @brief casl2コマンドのオプション @@ -54,10 +54,13 @@ void addcerrlist_casl2() addcerrlist(ARRAYSIZE(cerr_casl2), cerr_casl2); } -const char *objfile_name(const char *str) +char *objfile_name(const char *name) { const char *default_name = "a.o"; - return (str == NULL) ? default_name : str; + return strdup_chk( + (name == NULL || !name[0]) ? default_name : name, + "objfile_name" + ); } /** @@ -70,9 +73,15 @@ const char *objfile_name(const char *str) */ int main(int argc, char *argv[]) { - int memsize = DEFAULT_MEMSIZE, clocks = DEFAULT_CLOCKS, opt, i, stat = 0; - char *af[argc], *objfile = NULL; - const char *version = PACKAGE_VERSION, *cmdversion = "casl2 of YACASL2 version %s\n"; + int memsize = DEFAULT_MEMSIZE; + int clocks = DEFAULT_CLOCKS; + int opt = 0; + int stat = 0; + int asfilecnt = 0; + char **asfile = NULL; + char *objfile = NULL; + const char *version = PACKAGE_VERSION; + const char *cmdversion = "casl2 of YACASL2 version %s\n"; const char *usage = "Usage: %s [-slLaAtTdmvh] [-oO[]] [-M ] [-C ] FILE1[ FILE2 ...]\n"; @@ -103,11 +112,11 @@ int main(int argc, char *argv[]) asmode.onlyassemble = true; break; case 'o': - objfile = strdup_chk(objfile_name(optarg), "objfile"); + objfile = objfile_name(optarg); break; case 'O': asmode.onlyassemble = true; - objfile = strdup_chk(objfile_name(optarg), "objfile"); + objfile = objfile_name(optarg); break; case 't': execmode.trace = true; @@ -149,11 +158,13 @@ int main(int argc, char *argv[]) } create_cmdtable(HASH_CMDTYPE); /* 命令の名前とタイプがキーのハッシュ表を作成 */ reset(memsize, clocks); /* 仮想マシンCOMET IIのリセット */ - for(i = 0; i < argc - optind; i++) { /* 引数からファイル名配列を取得 */ - af[i] = argv[optind + i]; + asfilecnt = argc - optind; + asfile = calloc_chk(asfilecnt, sizeof(char *), "asfile"); + for(int i = 0; i < asfilecnt; i++) { /* 引数からファイル名配列を取得 */ + asfile[i] = argv[optind + i]; } /* アセンブル */ - if(assemble(i, af, 0) == false || asmode.onlylabel == true) { + if(assemble(asfilecnt, asfile, 0) == false || asmode.onlylabel == true) { goto shutdown; } /* オブジェクトファイル名が指定されている場合は、アセンブル結果をオブジェクトファイルに出力 */ @@ -167,8 +178,9 @@ int main(int argc, char *argv[]) shutdown: shutdown(); /* 仮想マシンCOMET IIのシャットダウン */ casl2fin: - free_cmdtable(HASH_CMDTYPE); FREE(objfile); + FREE(asfile); + free_cmdtable(HASH_CMDTYPE); if(cerr->num > 0) { stat = 1; }