X-Git-Url: http://j8takagi.net/cgi-bin/gitweb.cgi?p=YACASL2.git;a=blobdiff_plain;f=src%2Fcerr.c;h=36b33a4dce81b1db45ca5a34bf4867e431d16547;hp=db5ca2ff1f2c31596996ac0b27df7a17e1928ee1;hb=7f7bde5dd1305cfc598fe09030c69aad0dc01368;hpb=650f92bf8dfdd0095db993f71f9e3867e7119acc diff --git a/src/cerr.c b/src/cerr.c index db5ca2f..36b33a4 100644 --- a/src/cerr.c +++ b/src/cerr.c @@ -1,37 +1,32 @@ +#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; -/* エラーリストを作成・追加する */ +/** + * エラーリストを作成・追加する + */ bool addcerrlist(int newerrc, CERR newerrv[]) { int i; @@ -56,10 +51,14 @@ bool addcerrlist(int newerrc, CERR newerrv[]) 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,7 +67,9 @@ void setcerr(int num, const char *str) } } -/* エラーリストから、エラー番号に対応するメッセージを返す */ +/** + * エラーリストから、エラー番号に対応するメッセージを返す + */ char *getcerrmsg(int num) { CERRLIST *p; @@ -78,10 +79,12 @@ char *getcerrmsg(int num) return p->cerr->msg; } } - return "unkown error"; + return "unknown error"; } -/* エラーリストと現在のエラーを解放する */ +/** + * エラーリストと現在のエラーを解放する + */ void freecerr() { CERRLIST *p = cerrlist, *q; @@ -89,9 +92,11 @@ void freecerr() /* エラーリストを解放 */ while(p != NULL) { q = p->next; - free(p); + free_chk(p, "freecerr.p"); p = q; } + /* 現在のエラーメッセージを解放 */ + free_chk(cerr->msg, "cerr.msg"); /* 現在のエラーを解放 */ - free(cerr); + free_chk(cerr, "cerr"); }