X-Git-Url: http://j8takagi.net/cgi-bin/gitweb.cgi?p=YACASL2.git;a=blobdiff_plain;f=src%2Fcerr.c;h=455ab5b701cded1f9b1f12628fe19e13812f31c6;hp=a8dfe0a5460021904a335f011878e214c1ef7d7a;hb=HEAD;hpb=c8548a1d9afb3c175d824d5024d2288941829180 diff --git a/src/cerr.c b/src/cerr.c index a8dfe0a..455ab5b 100644 --- a/src/cerr.c +++ b/src/cerr.c @@ -1,62 +1,37 @@ -#include -#include -#include -#include -#include #include "cerr.h" -/** - * エラーの初期化 - */ void cerr_init() { cerr = malloc_chk(sizeof(CERR), "cerr"); cerr->num = 0; } -/** - * 現在のエラー - */ -CERR *cerr; +CERR *cerr = NULL; -/** - * エラーリスト - */ -CERRLIST *cerrlist; +CERRLIST *cerrlist = NULL; -/** - * エラーリストを作成または追加する - */ -bool addcerrlist(int newerrc, CERR newerrv[]) +void addcerrlist(int cerrc, CERR cerrv[]) { - int i; - CERRLIST *p, *q; + CERRLIST *stat = NULL; + CERRLIST *p = NULL; - 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(cerrc > 0 && cerrv != NULL); + for(int i = 0; i < cerrc; i++) { + if(p == NULL) { + stat = p = malloc_chk(sizeof(CERRLIST), "cerrlist"); + } 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 = &cerrv[i]; + p->next = NULL; } - q->next = NULL; - return true; + p->next = cerrlist; + cerrlist = stat; } -/** - * エラーリストを表示する - */ void printcerrlist() { - CERRLIST *p; + CERRLIST *p = NULL; if(cerrlist == NULL) { puts("error list is null."); @@ -67,53 +42,45 @@ void printcerrlist() } } -/** - * 現在のエラーを設定する - */ 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)); } } -/** - * エラーリストから、エラー番号に対応するメッセージを返す - */ char *getcerrmsg(int num) { - CERRLIST *p; + CERRLIST *p = NULL; + 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; } -/** - * エラーリストと現在のエラーを解放する - */ void freecerr() { - CERRLIST *p = cerrlist, *q; + CERRLIST *p = NULL; + CERRLIST *q = NULL; /* 現在のエラーメッセージを解放 */ - 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); } }