projects
/
YACASL2.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
CASL2LIBの状態が不正になっていたのを修正
[YACASL2.git]
/
src
/
cerr.c
diff --git
a/src/cerr.c
b/src/cerr.c
index
5443c3e
..
02b6a3b
100644
(file)
--- a/
src/cerr.c
+++ b/
src/cerr.c
@@
-1,79
+1,83
@@
#include "cerr.h"
#include "cerr.h"
-/* エラー番号 */
-int cerrno = 0;
+/* エラーの初期化 */
+void cerr_init()
+{
+ cerr = malloc_chk(sizeof(CERR), "cerr");
+ cerr->num = 0;
+}
-/*
エラーメッセージ
*/
-
char *cerrmsg
;
+/*
現在のエラー
*/
+
CERR *cerr
;
/* エラーリスト */
/* エラーリスト */
-CERRLIST *cerr;
+CERRLIST *cerr
list
;
-/* エラーリストを作成する */
-bool addcerrlist(int newerrc, CERR
ARRAY
newerrv[])
+/* ã
\82
¨ã
\83
©ã
\83
¼ã
\83
ªã
\82
¹ã
\83
\88
ã
\82
\92
ä½
\9c
æ
\88
\90
ã
\83
»è¿½å
\8a
ã
\81
\99
ã
\82
\8b
*/
+bool addcerrlist(int newerrc, CERR newerrv[])
{
int i;
CERRLIST *p, *q;
assert(newerrc > 0 && newerrv != NULL);
{
int i;
CERRLIST *p, *q;
assert(newerrc > 0 && newerrv != NULL);
- if(cerr != NULL) {
- p = cerr;
- while (p != NULL) {
+ if(cerrlist == NULL) {
+ p = cerrlist = malloc_chk(sizeof(CERRLIST), "cerrlist");
+ } else {
+ for(p = cerrlist; p != NULL; p = p->next) {
q = p;
q = p;
- p = p->next;
}
}
- if((p = q->next = malloc(sizeof(CERRLIST *))) == NULL) {
- goto addcerrlisterr;
- }
- } else if((p = cerr = malloc(sizeof(CERRLIST *))) == NULL) {
- goto addcerrlisterr;
+ p = q->next = malloc_chk(sizeof(CERRLIST), "cerrlist.next");
}
for(i = 0; i < newerrc; i++) {
}
for(i = 0; i < newerrc; i++) {
- p->err = &(newerrv[i]);
- if((p->next = malloc(sizeof(CERRLIST *))) == NULL) {
- goto addcerrlisterr;
- }
+ p->cerr = &(newerrv[i]);
+ p->next = malloc_chk(sizeof(CERRLIST), "cerrlist.next");
q = p;
p = p->next;
}
q->next = NULL;
return true;
q = p;
p = p->next;
}
q->next = NULL;
return true;
-addcerrlisterr:
- fprintf(stderr, "addcerrlist: cannot allocate memory\n");
- exit(-1);
}
}
-/*
エラー番号とエラーメッセージ
を設定する */
+/*
現在のエラー
を設定する */
void setcerr(int num, const char *str)
{
void setcerr(int num, const char *str)
{
- cerrno = num;
- cerrmsg = malloc(CERRMSGSIZE + 1);
+ /* 現在のエラー番号を設定 */
+ cerr->num = num;
+ /* 現在のエラーメッセージを設定 */
+ cerr->msg = malloc_chk(CERRMSGSIZE + 1, "cerr.msg");
if(str != NULL && strlen(str) <= CERRSTRSIZE) {
if(str != NULL && strlen(str) <= CERRSTRSIZE) {
- sprintf(cerr
msg, "%s: %s", str, getcerrmsg(cerrno
));
+ sprintf(cerr
->msg, "%s: %s", str, getcerrmsg(cerr->num
));
} else {
} else {
- strcpy(cerr
msg, getcerrmsg(cerrno
));
+ strcpy(cerr
->msg, getcerrmsg(cerr->num
));
}
}
}
}
-/* リストから、エラー番号に対応するメッセージを返す */
+/* ã
\82
¨ã
\83
©ã
\83
¼ã
\83
ªã
\82
¹ã
\83
\88
ã
\81
\8b
ã
\82
\89
ã
\80
\81
ã
\82
¨ã
\83
©ã
\83
¼ç
\95
ªå
\8f
·ã
\81
«å¯¾å¿
\9c
ã
\81
\99
ã
\82
\8b
ã
\83
¡ã
\83
\83
ã
\82
ȋ
\83
¼ã
\82
¸ã
\82
\92
è¿
\94
ã
\81
\99
*/
char *getcerrmsg(int num)
{
CERRLIST *p;
char *getcerrmsg(int num)
{
CERRLIST *p;
- for(p = cerr; p != NULL; p = p->next) {
- if(num == p->err->num) {
- return p->err->msg;
+ for(p = cerr
list
; p != NULL; p = p->next) {
+ if(num == p->
c
err->num) {
+ return p->
c
err->msg;
}
}
}
}
- return "unkown error";
+ return "unk
n
own error";
}
}
-/* エラーを解放する */
+/* ã
\82
¨ã
\83
©ã
\83
¼ã
\83
ªã
\82
¹ã
\83
\88
ã
\81
¨ç
\8f
¾å
\9c
¨ã
\81
®ã
\82
¨ã
\83
©ã
\83
¼ã
\82
\92
解æ
\94
¾ã
\81
\99
ã
\82
\8b
*/
void freecerr()
{
void freecerr()
{
- assert(cerrno > 0);
- cerrno = 0;
- if(strlen(cerrmsg) > 0) {
- free(cerrmsg);
+ CERRLIST *p = cerrlist, *q;
+
+ /* エラーリストを解放 */
+ while(p != NULL) {
+ q = p->next;
+ free_chk(p, "freecerr.p");
+ p = q;
}
}
+ /* 現在のエラーメッセージを解放 */
+ free_chk(cerr->msg, "cerr.msg");
+ /* 現在のエラーを解放 */
+ free_chk(cerr, "cerr");
}
}