projects
/
YACASL2.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Valgrindで見つかったメモリー周辺の問題点を修正
[YACASL2.git]
/
src
/
cerr.c
diff --git
a/src/cerr.c
b/src/cerr.c
index
02b6a3b
..
d595275
100644
(file)
--- a/
src/cerr.c
+++ b/
src/cerr.c
@@
-1,44
+1,70
@@
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <assert.h>
+#include <stdbool.h>
#include "cerr.h"
#include "cerr.h"
-/* エラーの初期化 */
+/**
+ * エラーの初期化
+ */
void cerr_init()
{
cerr = malloc_chk(sizeof(CERR), "cerr");
cerr->num = 0;
}
void cerr_init()
{
cerr = malloc_chk(sizeof(CERR), "cerr");
cerr->num = 0;
}
-/* 現在のエラー */
+/**
+ * 現在のエラー
+ */
CERR *cerr;
CERR *cerr;
-/* エラーリスト */
-CERRLIST *cerrlist;
+/**
+ * エラーリスト
+ */
+CERRLIST *cerrlist = NULL;
-/* エラーリストを作成・追加する */
-bool addcerrlist(int newerrc, CERR newerrv[])
+/**
+ * エラーリストを作成または追加する
+ */
+void addcerrlist(int newerrc, CERR newerrv[])
{
int i;
{
int i;
- CERRLIST *p, *q;
+ CERRLIST *p
= NULL
, *q;
assert(newerrc > 0 && newerrv != NULL);
assert(newerrc > 0 && newerrv != NULL);
+ for(i = 0; i < newerrc; i++) {
+ if(p == NULL) {
+ p = q = malloc_chk(sizeof(CERRLIST), "cerrlist");
+ } else {
+ p = p->next = malloc_chk(sizeof(CERRLIST), "cerrlist.next");
+ }
+ p->cerr = &newerrv[i];
+ p->next = NULL;
+ }
+ p->next = cerrlist;
+ cerrlist = q;
+}
+
+/**
+ * エラーリストを表示する
+ */
+void printcerrlist()
+{
+ CERRLIST *p;
+
if(cerrlist == NULL) {
if(cerrlist == NULL) {
- p
= cerrlist = malloc_chk(sizeof(CERRLIST), "cerrlist
");
+ p
uts("error list is null.
");
} else {
for(p = cerrlist; p != NULL; p = p->next) {
} 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)
{
/* 現在のエラー番号を設定 */
void setcerr(int num, const char *str)
{
/* 現在のエラー番号を設定 */
@@
-52,32
+78,37
@@
void setcerr(int num, const char *str)
}
}
}
}
-/* エラーリストから、エラー番号に対応するメッセージを返す */
+/**
+ * エラーリストから、エラー番号に対応するメッセージを返す
+ */
char *getcerrmsg(int num)
{
CERRLIST *p;
char *getcerrmsg(int num)
{
CERRLIST *p;
+ char *msg = "unknown error";
for(p = cerrlist; p != NULL; p = p->next) {
if(num == p->cerr->num) {
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;
void freecerr()
{
CERRLIST *p = cerrlist, *q;
+ /* 現在のエラーメッセージを解放 */
+ FREE(cerr->msg);
+ /* 現在のエラーを解放 */
+ FREE(cerr);
/* エラーリストを解放 */
/* エラーリストを解放 */
-
while(p != NULL
) {
+
for(p = cerrlist; p != NULL; p = q
) {
q = p->next;
q = p->next;
- free_chk(p, "freecerr.p");
- p = q;
+ FREE(p);
}
}
- /* 現在のエラーメッセージを解放 */
- free_chk(cerr->msg, "cerr.msg");
- /* 現在のエラーを解放 */
- free_chk(cerr, "cerr");
}
}