projects
/
YACASL2.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
disassembleコマンドを追加
[YACASL2.git]
/
src
/
cerr.c
diff --git
a/src/cerr.c
b/src/cerr.c
index
069564b
..
f1cb09c
100644
(file)
--- a/
src/cerr.c
+++ b/
src/cerr.c
@@
-5,55
+5,35
@@
#include <stdbool.h>
#include "cerr.h"
#include <stdbool.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 cerrc, CERR cerrv[])
{
int i;
{
int i;
- CERRLIST *p
, *q
;
+ CERRLIST *p
= NULL, *q = malloc_chk(sizeof(CERRLIST), "cerrlist")
;
- assert(
newerrc > 0 && new
errv != NULL);
-
if(cerrlist == NULL
) {
- p = cerrlist = malloc_chk(sizeof(CERRLIST), "cerrlist");
- } else {
-
for(p = cerrlist; p != NULL; p = p->next)
{
-
q = p
;
+ assert(
cerrc > 0 && c
errv != NULL);
+
for(i = 0; i < cerrc; i++
) {
+ if(p == NULL) {
+ p = q;
+
} else
{
+
p = p->next = malloc_chk(sizeof(CERRLIST), "cerrlist.next")
;
}
}
- 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;
+ p->cerr = &cerrv[i];
+ p->next = NULL;
}
}
-
q->next = NULL
;
-
return true
;
+
p->next = cerrlist
;
+
cerrlist = q
;
}
}
-/**
- * エラーリストを表示する
- */
void printcerrlist()
{
CERRLIST *p;
void printcerrlist()
{
CERRLIST *p;
@@
-67,52
+47,44
@@
void printcerrlist()
}
}
}
}
-/**
- * 現在のエラーを設定する
- */
void setcerr(int num, const char *str)
{
/* 現在のエラー番号を設定 */
cerr->num = num;
/* 現在のエラーメッセージを設定 */
cerr->msg = malloc_chk(CERRMSGSIZE + 1, "cerr.msg");
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));
}
}
sprintf(cerr->msg, "%s: %s", str, getcerrmsg(cerr->num));
} else {
strcpy(cerr->msg, getcerrmsg(cerr->num));
}
}
-/**
- * エラーリストから、エラー番号に対応するメッセージを返す
- */
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");
}
}