projects
/
YACASL2.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
ソースで、コマンド表を2重ポインタからポインタ配列に変更
[YACASL2.git]
/
src
/
cmd.c
diff --git
a/src/cmd.c
b/src/cmd.c
index
fb9ae6f
..
04acd32
100644
(file)
--- a/
src/cmd.c
+++ b/
src/cmd.c
@@
-55,14
+55,16
@@
static CMD comet2cmd[] = {
static int comet2cmdsize = ARRAYSIZE(comet2cmd);
/**
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]
;
/**
* 命令の名前とタイプからハッシュ値を生成する
/**
* 命令の名前とタイプからハッシュ値を生成する
@@
-81,10
+83,10
@@
unsigned hash_cmdtype(const char *cmd, CMDTYPE type)
keys[1]->type = INT;
keys[1]->val.i = (int)(type & 070);
/* ハッシュ値の計算 */
keys[1]->type = INT;
keys[1]->val.i = (int)(type & 070);
/* ハッシュ値の計算 */
- hashval = hash(2, keys,
cmdtabsize
);
-
free_chk(keys[0]->val.s, "keys[0].val.s"
);
-
free_chk(keys[0], "keys[0]"
);
-
free_chk(keys[1], "keys[1]"
);
+ hashval = hash(2, keys,
CMDTABSIZE
);
+
FREE(keys[0]->val.s
);
+
FREE(keys[0]
);
+
FREE(keys[1]
);
/* ハッシュ値を返す */
return hashval;
}
/* ハッシュ値を返す */
return hashval;
}
@@
-98,13
+100,11
@@
bool create_cmdtype_code()
unsigned hashval;
int i;
unsigned hashval;
int i;
- cmdtabsize = comet2cmdsize;
- cmdtype_code = calloc_chk(cmdtabsize, sizeof(CMDTAB *), "cmdtype_code");
for(i = 0; i < comet2cmdsize; i++) {
for(i = 0; i < comet2cmdsize; i++) {
- p = malloc_chk(sizeof(CMDTAB), "cmdtype_code.p");
hashval = hash_cmdtype(comet2cmd[i].name, comet2cmd[i].type); /* ハッシュ値の生成 */
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->cmd = &comet2cmd[i];
+ p->next = cmdtype_code[hashval]; /* ハッシュ表に値を追加 */
cmdtype_code[hashval] = p;
}
return true;
cmdtype_code[hashval] = p;
}
return true;
@@
-117,14
+117,16
@@
bool create_cmdtype_code()
WORD getcmdcode(const char *cmd, CMDTYPE type)
{
CMDTAB *p;
WORD getcmdcode(const char *cmd, CMDTYPE type)
{
CMDTAB *p;
+ WORD w = 0xFFFF;
assert(cmd != NULL);
assert(cmd != NULL);
- for(p = cmdtype_code[hash_cmdtype(cmd, type)]; p != NULL; p = p->next){
+ for(p = cmdtype_code[hash_cmdtype(cmd, type)]; p != NULL; p = p->next)
{
if(strcmp(cmd, p->cmd->name) == 0 && type == p->cmd->type) {
if(strcmp(cmd, p->cmd->name) == 0 && type == p->cmd->type) {
- return p->cmd->code;
+ w = p->cmd->code;
+ break;
}
}
}
}
- return
0xFFFF
;
+ return
w
;
}
/**
}
/**
@@
-135,13
+137,12
@@
void free_cmdtype_code()
int i;
CMDTAB *p, *q;
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;
for(p = cmdtype_code[i]; p != NULL; p = q) {
q = p->next;
-
free_chk(p, "free_cmdtype_code.p"
);
+
FREE(p
);
}
}
}
}
- free_chk(cmdtype_code, "cmdtype_code");
}
/**
}
/**
@@
-150,13
+151,15
@@
void free_cmdtype_code()
unsigned hash_code(WORD code)
{
HKEY *keys[1];
unsigned hash_code(WORD code)
{
HKEY *keys[1];
+ unsigned h;
/* 命令コードを設定 */
keys[0] = malloc_chk(sizeof(HKEY), "hash_code.key");
keys[0]->type = INT;
keys[0]->val.i = (int)(code >> 8);
/* 命令コードを設定 */
keys[0] = malloc_chk(sizeof(HKEY), "hash_code.key");
keys[0]->type = INT;
keys[0]->val.i = (int)(code >> 8);
- /* ハッシュ値を返す */
- return hash(1, keys, cmdtabsize);
+ h = hash(1, keys, CMDTABSIZE);
+ FREE(keys[0]);
+ return h;
}
/**
}
/**
@@
-168,13
+171,11
@@
bool create_code_type()
unsigned hashval;
int i;
unsigned hashval;
int i;
- cmdtabsize = comet2cmdsize;
- code_type = calloc_chk(cmdtabsize, sizeof(CMDTAB *), "code_type");
for(i = 0; i < comet2cmdsize; i++) {
for(i = 0; i < comet2cmdsize; i++) {
- p = malloc_chk(sizeof(CMDTAB), "code_type.p");
hashval = hash_code((&comet2cmd[i])->code); /* ハッシュ値の生成 */
hashval = hash_code((&comet2cmd[i])->code); /* ハッシュ値の生成 */
- p
->next = code_type[hashval]; /* ハッシュ表に値を追加 */
+ p
= malloc_chk(sizeof(CMDTAB), "code_type");
p->cmd = &comet2cmd[i];
p->cmd = &comet2cmd[i];
+ p->next = code_type[hashval]; /* ハッシュ表に値を追加 */
code_type[hashval] = p;
}
return true;
code_type[hashval] = p;
}
return true;
@@
-187,12
+188,15
@@
bool create_code_type()
CMDTYPE getcmdtype(WORD code)
{
CMDTAB *p;
CMDTYPE getcmdtype(WORD code)
{
CMDTAB *p;
+ CMDTYPE t = NOTCMD;
+
for(p = code_type[hash_code(code)]; p != NULL; p = p->next) {
if(code == p->cmd->code) {
for(p = code_type[hash_code(code)]; p != NULL; p = p->next) {
if(code == p->cmd->code) {
- return p->cmd->type;
+ t = p->cmd->type;
+ break;
}
}
}
}
- return
NOTCMD
;
+ return
t
;
}
/**
}
/**
@@
-202,13
+206,10
@@
void free_code_type()
{
int i;
CMDTAB *p, *q;
{
int i;
CMDTAB *p, *q;
- for(i = 0; i < cmdtabsize; i++) {
- p = code_type[i];
- while(p != NULL) {
+ for(i = 0; i < CMDTABSIZE; i++) {
+ for(p = code_type[i]; p != NULL; p = q) {
q = p->next;
q = p->next;
- free_chk(p, "code_type.p");
- p = q;
+ FREE(p);
}
}
}
}
- free_chk(code_type, "code_type");
}
}