X-Git-Url: http://j8takagi.net/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Fcerr.c;h=36b33a4dce81b1db45ca5a34bf4867e431d16547;hb=d644fa5efb63608e59b9f7b84c7806c91c970b5d;hp=990673900bb3d2ad61b73abe082d92581c949c10;hpb=288d61424576d1aae956ea8e4b5fb89dc25909db;p=YACASL2.git diff --git a/src/cerr.c b/src/cerr.c index 9906739..36b33a4 100644 --- a/src/cerr.c +++ b/src/cerr.c @@ -1,57 +1,32 @@ +#include +#include +#include +#include +#include #include "cerr.h" -/* mallocを実行し、メモリを確保できない場合は */ -/* エラーを出力して終了 */ -void *malloc_chk(size_t size, char *tag) -{ - void *p; - - if((p = malloc(size)) == NULL) { - fprintf(stderr, "%s: cannot allocate memory\n", tag); - exit(-1); - } - return p; -} - -/* callocを実行し、メモリを確保できない場合は */ -/* エラーを出力して終了 */ -void *calloc_chk(size_t nmemb, size_t size, char *tag) -{ - void *p; - - if((p = calloc(nmemb, size)) == NULL) { - fprintf(stderr, "%s: cannot allocate memory\n", tag); - exit(-1); - } - return p; -} - -/* エラーの初期化 */ +/** + * エラーの初期化 + */ void cerr_init() { cerr = malloc_chk(sizeof(CERR), "cerr"); cerr->num = 0; } -/* 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 *cerr; -/* エラーリスト */ +/** + * エラーリスト + */ CERRLIST *cerrlist; -/* エラーリストを作成・追加する */ +/** + * エラーリストを作成・追加する + */ bool addcerrlist(int newerrc, CERR newerrv[]) { int i; @@ -76,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)); @@ -88,7 +67,9 @@ void setcerr(int num, const char *str) } } -/* エラーリストから、エラー番号に対応するメッセージを返す */ +/** + * エラーリストから、エラー番号に対応するメッセージを返す + */ char *getcerrmsg(int num) { CERRLIST *p; @@ -101,7 +82,9 @@ char *getcerrmsg(int num) return "unknown error"; } -/* エラーリストと現在のエラーを解放する */ +/** + * エラーリストと現在のエラーを解放する + */ void freecerr() { CERRLIST *p = cerrlist, *q; @@ -109,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"); }