projects
/
YACASL2.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
変数名の整理
[YACASL2.git]
/
src
/
cerr.c
diff --git
a/src/cerr.c
b/src/cerr.c
index
c0146a2
..
3f7887b
100644
(file)
--- a/
src/cerr.c
+++ b/
src/cerr.c
@@
-1,77
+1,85
@@
#include "cerr.h"
#include "cerr.h"
-/* エラー番号 */
-int cerrno = 0;
+/* 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;
+}
-/*
エラーメッセージ
*/
-
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) {
- for(p = cerr; p != NULL; p = p->next) {
+ if(cerrlist == NULL) {
+ p = cerrlist = malloc_chk(sizeof(CERRLIST), "cerrlist");
+ } else {
+ for(p = cerrlist; p != NULL; p = p->next) {
q = p;
}
q = p;
}
- 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)
{
- cerr
no
= num;
- cerr
msg = 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 "unkown 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(p);
+ p = q;
}
}
+ /* 現在のエラーを解放 */
+ free(cerr);
}
}