X-Git-Url: http://j8takagi.net/cgi-bin/gitweb.cgi?p=YACASL2.git;a=blobdiff_plain;f=src%2Fcerr.c;h=116312b11cb671cca78144eaa24754b8f4a59aeb;hp=a8dfe0a5460021904a335f011878e214c1ef7d7a;hb=f8636262f5c60efbb9d1c608e2276d359bc348a0;hpb=c8548a1d9afb3c175d824d5024d2288941829180 diff --git a/src/cerr.c b/src/cerr.c index a8dfe0a..116312b 100644 --- a/src/cerr.c +++ b/src/cerr.c @@ -22,33 +22,28 @@ CERR *cerr; /** * エラーリスト */ -CERRLIST *cerrlist; +CERRLIST *cerrlist = NULL; /** * エラーリストを作成または追加する */ -bool addcerrlist(int newerrc, CERR newerrv[]) +void addcerrlist(int errc, CERR errv[]) { int i; - CERRLIST *p, *q; + CERRLIST *p = NULL, *q = malloc_chk(sizeof(CERRLIST), "cerrlist"); - assert(newerrc > 0 && newerrv != NULL); - if(cerrlist == NULL) { - p = cerrlist = malloc_chk(sizeof(CERRLIST), "cerrlist"); - } else { - for(p = cerrlist; p != NULL; p = p->next) { - q = p; + assert(errc > 0 && errv != NULL); + for(i = 0; i < errc; i++) { + if(p == NULL) { + p = q; + } else { + p = p->next = malloc_chk(sizeof(CERRLIST), "cerrlist.next"); } - p = q->next = malloc_chk(sizeof(CERRLIST), "cerrlist.next"); - } - for(i = 0; i < newerrc; i++) { - p->cerr = &(newerrv[i]); - p->next = malloc_chk(sizeof(CERRLIST), "cerrlist.next"); - q = p; - p = p->next; + p->cerr = &errv[i]; + p->next = NULL; } - q->next = NULL; - return true; + p->next = cerrlist; + cerrlist = q; } /** @@ -76,7 +71,7 @@ void setcerr(int num, const char *str) cerr->num = num; /* 現在のエラーメッセージを設定 */ cerr->msg = malloc_chk(CERRMSGSIZE + 1, "cerr.msg"); - if(str != NULL && strlen(str) <= CERRSTRSIZE) { + if(0 < strlen(str) && strlen(str) <= CERRSTRSIZE) { sprintf(cerr->msg, "%s: %s", str, getcerrmsg(cerr->num)); } else { strcpy(cerr->msg, getcerrmsg(cerr->num)); @@ -89,13 +84,15 @@ void setcerr(int num, const char *str) char *getcerrmsg(int num) { CERRLIST *p; + char *msg = "unknown error"; for(p = cerrlist; p != NULL; p = p->next) { if(num == p->cerr->num) { - return p->cerr->msg; + msg = p->cerr->msg; + break; } } - return "unknown error"; + return msg; } /** @@ -106,14 +103,12 @@ void freecerr() CERRLIST *p = cerrlist, *q; /* 現在のエラーメッセージを解放 */ - free_chk(cerr->msg, "cerr.msg"); + FREE(cerr->msg); /* 現在のエラーを解放 */ - free_chk(cerr, "cerr"); + FREE(cerr); /* エラーリストを解放 */ for(p = cerrlist; p != NULL; p = q) { q = p->next; - /* free_chk(p->cerr->msg, "freecerr.p.cerr.msg"); */ - /* free_chk(p->cerr, "freecerr.p.cerr"); */ - free_chk(p, "freecerr.p"); + FREE(p); } }