コマンドごとに異なるエラー表を設定するよう内部仕様変更
authorj8takagi <j8takagi@nifty.com>
Thu, 4 Feb 2010 11:38:05 +0000 (20:38 +0900)
committerj8takagi <j8takagi@nifty.com>
Thu, 4 Feb 2010 11:38:05 +0000 (20:38 +0900)
include/cerr.h
src/Makefile
src/cerr.c
src/dumpword.c
src/struct.c

index 586ab4d..878fd85 100644 (file)
@@ -21,6 +21,9 @@ typedef struct {
     char *msg;
 } CERRARRAY;
 
+/* エラーメッセージ */
+extern CERRARRAY cerr[];
+
 enum {
     MSGSIZE = 60,
 };
index 7e39583..e28e81d 100644 (file)
@@ -1,7 +1,10 @@
 INCLUDE = ../include
 CC = gcc
 CFLAGS = -g -Wall -I $(INCLUDE)
-COMMONSRC = word.o struct.o hash.o cmd.o cerr.o
+HASHSRC = hash.o
+CERRSRC = cerr.o
+WORDSRC = word.o
+COMMONSRC = $(WORDSRC) $(HASHSRC) $(CERRSRC) struct.o cmd.o
 ASSRC = assemble.o token.o label.o macro.o
 EXECSRC = exec.o dump.o
 .PHPNY: all clean
@@ -10,7 +13,7 @@ all: ../casl2 ../comet2 ../dumpword TAGS
        $(CC) $(CFLAGS) -o $@ $^
 ../comet2: comet2.o $(COMMONSRC) $(EXECSRC)
        $(CC) $(CFLAGS) -o $@ $^
-../dumpword: dumpword.o $(COMMONSRC)
+../dumpword: dumpword.o $(WORDSRC) $(CERRSRC)
        $(CC) $(CFLAGS) -o $@ $^
 %.o: %.c
        $(CC) -c $(CFLAGS) $<
index ceea3af..f7971f6 100644 (file)
@@ -1,36 +1,8 @@
 #include "cerr.h"
 
-CERRARRAY cerr[] = {
-    { 101, "label already defined" },
-    { 102, "label table is full" },
-    { 103, "label not found" },
-    { 104, "label length is too long" },
-    { 105, "no command in the line" },
-    { 106, "operand count mismatch" },
-    { 107, "no label in START" },
-    { 108, "not command of operand \"r\"" },
-    { 109, "not command of operand \"r1,r2\"" },
-    { 110, "not command of operand \"r,adr[,x]\"" },
-    { 111, "not command of operand \"adr[,x]\"" },
-    { 112, "not command of no operand" },
-    { 113, "command not defined" },
-    { 114, "not integer" },
-    { 115, "not hex" },
-    { 116, "out of hex range" },
-    { 117, "operand is too many" },
-    { 118, "operand length is too long" },
-    { 119, "out of COMET II memory" },
-    { 120, "GR0 in operand x" },
-    { 121, "cannot get operand token" },
-    { 122, "cannot create hash table" },
-    { 201, "execute - out of COMET II memory" },
-    { 202, "SVC input - out of Input memory" },
-    { 203, "SVC output - out of COMET II memory" },
-    { 204, "Program Register (PR) - out of COMET II memory" },
-    { 205, "Stack Pointer (SP) - cannot allocate stack buffer" },
-    { 206, "Address - out of COMET II memory" },
-    { 207, "Stack Pointer (SP) - out of COMET II memory" },
-};
+/* エラーメッセージ */
+int cerrno = 0;
+char *cerrmsg;
 
 /* エラー番号とエラーメッセージを設定する */
 void setcerr(int num, const char *val)
@@ -50,12 +22,13 @@ void setcerr(int num, const char *val)
 char *getcerrmsg(int num)
 {
     assert(num > 0);
-    int i;
-    for(i = 0; i < ARRAYSIZE(cerr); i++) {
-        if((&cerr[i])->num == num) {
-            return (&cerr[i])->msg;
+    int i = 0;
+    CERRARRAY *ptr;
+    do {
+        if((ptr = &cerr[i++])->num == num) {
+            return ptr->msg;
         }
-    }
+    } while(ptr->num > 0);
     return "unkown error";
 }
 
index e78b108..cefbc0f 100644 (file)
@@ -9,6 +9,16 @@ static struct option longopts[] = {
     {0, 0, 0, 0},
 };
 
+CERRARRAY cerr[] = {
+    { 114, "not integer" },
+    { 115, "not hex" },
+    { 116, "out of hex range" },
+    { 0, NULL },
+};
+
+/* レジストリの内容を論理値(0〜65535)で表示する場合はtrue */
+bool logicalmode = false;
+
 int main(int argc, char *argv[])
 {
     int opt;
index 31be1e6..d918c7a 100644 (file)
@@ -6,9 +6,38 @@ WORD *memory;
 /* COMET IIのCPUレジスタ */
 WORD GR[REGSIZE], SP, PR, FR;
 
-/* エラーメッセージ */
-int cerrno = 0;
-char *cerrmsg;
+CERRARRAY cerr[] = {
+    { 101, "label already defined" },
+    { 102, "label table is full" },
+    { 103, "label not found" },
+    { 104, "label length is too long" },
+    { 105, "no command in the line" },
+    { 106, "operand count mismatch" },
+    { 107, "no label in START" },
+    { 108, "not command of operand \"r\"" },
+    { 109, "not command of operand \"r1,r2\"" },
+    { 110, "not command of operand \"r,adr[,x]\"" },
+    { 111, "not command of operand \"adr[,x]\"" },
+    { 112, "not command of no operand" },
+    { 113, "command not defined" },
+    { 114, "not integer" },
+    { 115, "not hex" },
+    { 116, "out of hex range" },
+    { 117, "operand is too many" },
+    { 118, "operand length is too long" },
+    { 119, "out of COMET II memory" },
+    { 120, "GR0 in operand x" },
+    { 121, "cannot get operand token" },
+    { 122, "cannot create hash table" },
+    { 201, "execute - out of COMET II memory" },
+    { 202, "SVC input - out of Input memory" },
+    { 203, "SVC output - out of COMET II memory" },
+    { 204, "Program Register (PR) - out of COMET II memory" },
+    { 205, "Stack Pointer (SP) - cannot allocate stack buffer" },
+    { 206, "Address - out of COMET II memory" },
+    { 207, "Stack Pointer (SP) - out of COMET II memory" },
+    { 0, NULL },
+};
 
 /* レジストリの内容を表示する場合はtrue */
 bool tracemode = false;