X-Git-Url: http://j8takagi.net/cgi-bin/gitweb.cgi?p=YACASL2.git;a=blobdiff_plain;f=src%2Fcmd.c;h=04acd32fdb4abba185eb91a8b4867c219dcc4bae;hp=f393c9acb8988c297f9ef9a2f1e350554b3e2c5e;hb=e8856643e2cc24d7419a587548396cc405ce0f19;hpb=6b30a23640168f0b99e70ad87ab4c5a98015ee02 diff --git a/src/cmd.c b/src/cmd.c index f393c9a..04acd32 100644 --- a/src/cmd.c +++ b/src/cmd.c @@ -57,12 +57,14 @@ static int comet2cmdsize = ARRAYSIZE(comet2cmd); /** * ハッシュ表のサイズ */ -static int cmdtabsize; +enum { + CMDTABSIZE = 39, +}; /** * ハッシュ表 */ -static CMDTAB **cmdtype_code, **code_type; +static CMDTAB *cmdtype_code[CMDTABSIZE], *code_type[CMDTABSIZE]; /** * 命令の名前とタイプからハッシュ値を生成する @@ -73,15 +75,15 @@ unsigned hash_cmdtype(const char *cmd, CMDTYPE type) unsigned hashval; /* 命令名を設定 */ - keys[0] = malloc_chk(sizeof(HKEY *), "hash_cmdtype.keys[0]"); + keys[0] = malloc_chk(sizeof(HKEY), "hash_cmdtype.keys[0]"); keys[0]->type = CHARS; keys[0]->val.s = strdup_chk(cmd, "keys[0].val.s"); /* 命令タイプを設定 */ - keys[1] = malloc_chk(sizeof(HKEY *), "hash_cmdtype.keys[1]"); + keys[1] = malloc_chk(sizeof(HKEY), "hash_cmdtype.keys[1]"); keys[1]->type = INT; keys[1]->val.i = (int)(type & 070); /* ハッシュ値の計算 */ - hashval = hash(2, keys, cmdtabsize); + hashval = hash(2, keys, CMDTABSIZE); FREE(keys[0]->val.s); FREE(keys[0]); FREE(keys[1]); @@ -98,13 +100,11 @@ bool create_cmdtype_code() unsigned hashval; int i; - cmdtabsize = comet2cmdsize; /* ハッシュ表のサイズ */ - cmdtype_code = calloc_chk(cmdtabsize, sizeof(CMDTAB *), "cmdtype_code"); for(i = 0; i < comet2cmdsize; i++) { - p = malloc_chk(sizeof(CMDTAB *), "create_cmdtype_code.p"); hashval = hash_cmdtype(comet2cmd[i].name, comet2cmd[i].type); /* ハッシュ値の生成 */ - p->next = cmdtype_code[hashval]; /* ハッシュ表に値を追加 */ + p = malloc_chk(sizeof(CMDTAB), "cmdtype_code"); p->cmd = &comet2cmd[i]; + p->next = cmdtype_code[hashval]; /* ハッシュ表に値を追加 */ cmdtype_code[hashval] = p; } return true; @@ -137,7 +137,7 @@ void free_cmdtype_code() int i; CMDTAB *p, *q; - for(i = 0; i < cmdtabsize; i++) { + for(i = 0; i < CMDTABSIZE; i++) { for(p = cmdtype_code[i]; p != NULL; p = q) { q = p->next; FREE(p); @@ -154,10 +154,10 @@ unsigned hash_code(WORD code) unsigned h; /* 命令コードを設定 */ - keys[0] = malloc_chk(sizeof(HKEY *), "hash_code.key"); + keys[0] = malloc_chk(sizeof(HKEY), "hash_code.key"); keys[0]->type = INT; keys[0]->val.i = (int)(code >> 8); - h = hash(1, keys, cmdtabsize); + h = hash(1, keys, CMDTABSIZE); FREE(keys[0]); return h; } @@ -171,13 +171,11 @@ bool create_code_type() unsigned hashval; int i; - cmdtabsize = comet2cmdsize; /* ハッシュ表のサイズ */ - code_type = calloc_chk(comet2cmdsize, sizeof(CMDTAB *), "code_type"); for(i = 0; i < comet2cmdsize; i++) { - p = malloc_chk(sizeof(CMDTAB *), "code_type.p"); hashval = hash_code((&comet2cmd[i])->code); /* ハッシュ値の生成 */ - p->next = code_type[hashval]; /* ハッシュ表に値を追加 */ + p = malloc_chk(sizeof(CMDTAB), "code_type"); p->cmd = &comet2cmd[i]; + p->next = code_type[hashval]; /* ハッシュ表に値を追加 */ code_type[hashval] = p; } return true; @@ -208,7 +206,7 @@ void free_code_type() { int i; CMDTAB *p, *q; - for(i = 0; i < cmdtabsize; i++) { + for(i = 0; i < CMDTABSIZE; i++) { for(p = code_type[i]; p != NULL; p = q) { q = p->next; FREE(p);