X-Git-Url: http://j8takagi.net/cgi-bin/gitweb.cgi?p=YACASL2.git;a=blobdiff_plain;f=src%2Fcmd.c;h=83e80af870ef02c532529f4988e5589449d1d34d;hp=7e2b7fa6e01892d2a4541dee977ea3edff371311;hb=f1803bd560071fb724b2c7ff2f5f35fa5086d10a;hpb=44cde08e6cf148928a219593c78a57abfd89b424 diff --git a/src/cmd.c b/src/cmd.c index 7e2b7fa..83e80af 100644 --- a/src/cmd.c +++ b/src/cmd.c @@ -38,7 +38,7 @@ CMDCODEARRAY cmdcodearray[] = { { "POP", R_, 0x7100 }, { "CALL", ADR_X, 0x8000 }, { "SVC", ADR_X, 0xF000 }, - { "RET", NONE, 0x8100 } + { "RET", NONE, 0x8100 }, }; int cmdcodesize = ARRAYSIZE(cmdcodearray); @@ -50,7 +50,7 @@ bool create_cmdtype_code() CMDCODETAB *np; unsigned hashval; int i; - + for(i = 0; i < cmdcodesize; i++) { np = (CMDCODETAB *) malloc(sizeof(*np)); if(np == NULL) { @@ -69,17 +69,22 @@ bool create_cmdtype_code() /* 命令と命令タイプからハッシュ値を生成する */ unsigned hash_cmdtype(const char *cmd, CMDTYPE type) { - int i; - unsigned hashval = 0; - for(i = 0; *cmd != '\0'; cmd++) { - hashval = *cmd + 31 * hashval; - } - hashval = (int)(type & 070) + 31 * hashval; - return hashval % cmdcodesize; + HKEY *keys[2]; + + /* 命令をセット */ + keys[0] = malloc(sizeof(HKEY)); + keys[0]->type = CHARS; + keys[0]->val.s = strdup(cmd); + /* 命令タイプをセット */ + keys[1] = malloc(sizeof(HKEY)); + keys[1]->type = INT; + keys[1]->val.i = (int)(type & 070); + /* ハッシュ値を返す */ + return hash(2, keys, cmdcodesize); } -/* 命令と命令タイプから、命令コードを取得する。 - 無効な場合は0xFFFFを返す */ +/* 命令と命令タイプから、命令コードを取得する */ +/* 無効な場合は0xFFFFを返す */ WORD getcmdcode(const char *cmd, CMDTYPE type) { CMDCODETAB *np; @@ -128,10 +133,9 @@ bool create_code_type() CMDCODETAB *np; unsigned hashval; int i; - + for(i = 0; i < cmdcodesize; i++) { - np = (CMDCODETAB *) malloc(sizeof(*np)); - if(np == NULL) { + if((np = (CMDCODETAB *) malloc(sizeof(*np))) == NULL) { setcerr(122, NULL); /* cannot create hash table */ return false; } @@ -148,13 +152,18 @@ bool create_code_type() /* 命令コードからハッシュ値を生成する */ unsigned hash_code(WORD code) { - unsigned hashval = 0; - hashval = (code >> 8); - return hashval % cmdcodesize; + HKEY *keys[1]; + + /* 命令コードをセット */ + keys[0] = malloc(sizeof(HKEY)); + keys[0]->type = INT; + keys[0]->val.i = (int)(code >> 8); + /* ハッシュ値を返す */ + return hash(1, keys, cmdcodesize); } -/* 命令コードから命令タイプを取得する。 - 無効な場合はNONEを返す */ +/* 命令コードから命令タイプを取得する */ +/* 無効な場合はNONEを返す */ CMDTYPE getcmdtype(WORD code) { CMDCODETAB *np;