READMEのCASL II仕様書へのリンクを修正
[YACASL2.git] / src / cerr.c
index 36b33a4..455ab5b 100644 (file)
-#include <stdio.h>
-#include <stdlib.h>
-#include <string.h>
-#include <assert.h>
-#include <stdbool.h>
 #include "cerr.h"
 
-/**
- * エラーの初期化
- */
 void cerr_init()
 {
     cerr = malloc_chk(sizeof(CERR), "cerr");
     cerr->num = 0;
 }
 
-/**
- * 現在のエラー
- */
-CERR *cerr;
+CERR *cerr = NULL;
 
-/**
- * エラーリスト
- */
-CERRLIST *cerrlist;
+CERRLIST *cerrlist = NULL;
 
-/**
- * エラーリストを作成・追加する
- */
-bool addcerrlist(int newerrc, CERR newerrv[])
+void addcerrlist(int cerrc, CERR cerrv[])
 {
-    int i;
-    CERRLIST *p, *q;
+    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 printcerrlist()
+{
+    CERRLIST *p = NULL;
 
-    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) {
+    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;
+    CERRLIST *p = NULL;
+    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;
+    CERRLIST *p = NULL;
+    CERRLIST *q = NULL;
 
+    /* 現在のエラーメッセージを解放 */
+    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");
 }