X-Git-Url: http://j8takagi.net/cgi-bin/gitweb.cgi?p=YACASL2.git;a=blobdiff_plain;f=src%2Fcerr.c;h=ae35d57847218327b099556fe823b3bf44ff1ec3;hp=db5ca2ff1f2c31596996ac0b27df7a17e1928ee1;hb=d609e3d54f40e0c4bd497a5287288d2fe3d78212;hpb=650f92bf8dfdd0095db993f71f9e3867e7119acc diff --git a/src/cerr.c b/src/cerr.c index db5ca2f..ae35d57 100644 --- a/src/cerr.c +++ b/src/cerr.c @@ -1,65 +1,75 @@ +#include +#include +#include +#include +#include #include "cerr.h" -/* mallocを実行し、メモリを確保できない場合は */ -/* エラーを出力して終了 */ -void *malloc_chk(size_t size, char *tag) +/** + * エラーの初期化 + */ +void cerr_init() { - void *p; - - if((p = malloc(size)) == NULL) { - fprintf(stderr, "%s: cannot allocate memory\n", tag); - exit(-1); - } - return p; -} - -/* malloc_chkを実行してメモリを確保してから、 */ -/* コピーした文字列を返す */ -char *strdup_chk(const char *s, char *tag) -{ - assert(s != NULL); - char *t; - - t = malloc_chk(strlen(s) + 1, tag); - strcpy(t, s); - return t; + 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 errc, CERR errv[]) { int i; - CERRLIST *p, *q; + CERRLIST *p = NULL, *q = malloc_chk(sizeof(CERRLIST), "cerrlist"); + + 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->cerr = &errv[i]; + p->next = NULL; + } + p->next = cerrlist; + cerrlist = q; +} + +/** + * エラーリストを表示する + */ +void printcerrlist() +{ + CERRLIST *p; - assert(newerrc > 0 && newerrv != NULL); if(cerrlist == NULL) { - p = cerrlist = malloc_chk(sizeof(CERRLIST), "cerrlist"); + puts("error list is null."); } else { for(p = cerrlist; p != NULL; p = p->next) { - q = p; + printf("%d: %s\n", p->cerr->num, p->cerr->msg); } - 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; } - q->next = NULL; - return true; } -/* 現在のエラーを設定する */ +/** + * 現在のエラーを設定する + */ void setcerr(int num, const char *str) { + /* 現在のエラー番号を設定 */ cerr->num = num; + /* 現在のエラーメッセージを設定 */ cerr->msg = malloc_chk(CERRMSGSIZE + 1, "cerr.msg"); if(str != NULL && strlen(str) <= CERRSTRSIZE) { sprintf(cerr->msg, "%s: %s", str, getcerrmsg(cerr->num)); @@ -68,30 +78,37 @@ 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 "unkown 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(p); - p = q; + FREE(p); } - /* 現在のエラーを解放 */ - free(cerr); }