X-Git-Url: http://j8takagi.net/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Fcerr.c;h=cd2ace98be0d7801fa34279dc1c32aaf62c2f434;hb=c8fdd78cfb5ba3a2afcdbb95e69e49d1c0dc23ed;hp=6ab5e566dbfdad13c93559b48efc745c6643fb18;hpb=fd77389ef0a4c9c31228b5f71e9073a11ada9853;p=YACASL2.git diff --git a/src/cerr.c b/src/cerr.c index 6ab5e56..cd2ace9 100644 --- a/src/cerr.c +++ b/src/cerr.c @@ -1,59 +1,34 @@ -#include -#include -#include -#include -#include #include "cerr.h" -/** - * エラーの初期化 - */ void cerr_init() { cerr = malloc_chk(sizeof(CERR), "cerr"); cerr->num = 0; } -/** - * 現在のエラー - */ CERR *cerr; -/** - * エラーリスト - */ -CERRLIST *cerrlist; +CERRLIST *cerrlist = NULL; -/** - * エラーリストを作成または追加する - */ -bool addcerrlist(int newerrc, CERR newerrv[]) +void addcerrlist(int cerrc, CERR cerrv[]) { 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(cerrc > 0 && cerrv != NULL); + for(i = 0; i < cerrc; 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 = &cerrv[i]; + p->next = NULL; } - q->next = NULL; - return true; + p->next = cerrlist; + cerrlist = q; } -/** - * エラーリストを表示する - */ void printcerrlist() { CERRLIST *p; @@ -67,52 +42,44 @@ 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; + 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; + /* 現在のエラーメッセージを解放 */ + FREE(cerr->msg); + /* 現在のエラーを解放 */ + FREE(cerr); /* エラーリストを解放 */ - while(p != NULL) { + for(p = cerrlist; p != NULL; p = q) { q = p->next; - free_chk(p, "freecerr.p"); - p = q; + FREE(p); } - /* 現在のエラーメッセージを解放 */ - free_chk(cerr->msg, "cerr.msg"); - /* 現在のエラーを解放 */ - free_chk(cerr, "cerr"); }