X-Git-Url: http://j8takagi.net/cgi-bin/gitweb.cgi?p=YACASL2.git;a=blobdiff_plain;f=src%2Fcerr.c;h=455ab5b701cded1f9b1f12628fe19e13812f31c6;hp=24f620d9b19736a06cbc4dea57bda759b4eff66b;hb=HEAD;hpb=6b04961e3a699efa011258cc1b1166df71b4c078 diff --git a/src/cerr.c b/src/cerr.c index 24f620d..455ab5b 100644 --- a/src/cerr.c +++ b/src/cerr.c @@ -1,61 +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]; - q = p; - p = p->next = malloc_chk(sizeof(CERRLIST), "cerrlist.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."); @@ -66,28 +42,22 @@ 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) { @@ -99,20 +69,18 @@ char *getcerrmsg(int num) 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, "freecerr.p"); + FREE(p); } }