X-Git-Url: http://j8takagi.net/cgi-bin/gitweb.cgi?p=YACASL2.git;a=blobdiff_plain;f=src%2Fcerr.c;h=455ab5b701cded1f9b1f12628fe19e13812f31c6;hp=121b68030bc726439205fbe1406a0218dc8e7f2a;hb=86e559d164166966a797a1e5855871d48e087ddd;hpb=ccc3acda4256e10a822e41e84f6c9991271c2f61 diff --git a/src/cerr.c b/src/cerr.c index 121b680..455ab5b 100644 --- a/src/cerr.c +++ b/src/cerr.c @@ -1,46 +1,86 @@ #include "cerr.h" -/* エラーメッセージ */ -int cerrno = 0; -char *cerrmsg; +void cerr_init() +{ + cerr = malloc_chk(sizeof(CERR), "cerr"); + cerr->num = 0; +} + +CERR *cerr = NULL; + +CERRLIST *cerrlist = NULL; + +void addcerrlist(int cerrc, CERR cerrv[]) +{ + CERRLIST *stat = NULL; + CERRLIST *p = NULL; + + 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->cerr = &cerrv[i]; + p->next = NULL; + } + p->next = cerrlist; + cerrlist = stat; +} -/* エラー番号とエラーメッセージを設定する */ -void setcerr(int num, const char *val) +void printcerrlist() { - assert(&cerr != NULL && num > 0); - - cerrno = num; - cerrmsg = malloc(MSGSIZE + 1); - if(val != NULL) { - strcpy(cerrmsg, val); - strcat(cerrmsg, ": "); - strcat(cerrmsg, getcerrmsg(cerrno)); + CERRLIST *p = NULL; + + if(cerrlist == NULL) { + puts("error list is null."); } else { - strcpy(cerrmsg, getcerrmsg(cerrno)); + for(p = cerrlist; p != NULL; p = p->next) { + printf("%d: %s\n", p->cerr->num, p->cerr->msg); + } + } +} + +void setcerr(int num, const char *str) +{ + /* 現在のエラー番号を設定 */ + cerr->num = num; + /* 現在のエラーメッセージを設定 */ + cerr->msg = malloc_chk(CERRMSGSIZE + 1, "cerr.msg"); + 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) { - assert(&cerr != NULL && num > 0); - int i = 0; - CERRARRAY *ptr; + CERRLIST *p = NULL; + char *msg = "unknown error"; - do { - if((ptr = &cerr[i++])->num == num) { - return ptr->msg; + for(p = cerrlist; p != NULL; p = p->next) { + if(num == p->cerr->num) { + msg = p->cerr->msg; + break; } - } while(ptr->num > 0); - return "unkown error"; + } + return msg; } -/* エラーを解放する */ void freecerr() { - assert(cerrno > 0); - cerrno = 0; - if(strlen(cerrmsg) > 0) { - free(cerrmsg); + CERRLIST *p = NULL; + CERRLIST *q = NULL; + + /* 現在のエラーメッセージを解放 */ + FREE(cerr->msg); + /* 現在のエラーを解放 */ + FREE(cerr); + /* エラーリストを解放 */ + for(p = cerrlist; p != NULL; p = q) { + q = p->next; + FREE(p); } }