X-Git-Url: http://j8takagi.net/cgi-bin/gitweb.cgi?p=YACASL2.git;a=blobdiff_plain;f=src%2Fword.c;h=e355a67d8cddbab448730bf010ae80d7d1f9d1df;hp=83ae9bd52c75d2878901af4cf25bbc74db486ac8;hb=d609e3d54f40e0c4bd497a5287288d2fe3d78212;hpb=8a76ef9abe62fac15c40aebb64fbb8a541b78075 diff --git a/src/word.c b/src/word.c index 83ae9bd..e355a67 100644 --- a/src/word.c +++ b/src/word.c @@ -1,9 +1,36 @@ +#include +#include +#include +#include +#include + #include "word.h" +#include "cerr.h" + +/** + * wordのエラー定義 + */ +static CERR cerr_word[] = { + { 114, "not integer" }, + { 115, "not hex" }, + { 116, "out of hex range" }, +}; + +/** + * wordのエラーをエラーリストに追加 + */ +void addcerrlist_word() +{ + addcerrlist(ARRAYSIZE(cerr_word), cerr_word); +} -/* 10進数の文字列をWORD値に変換 */ +/** + * 10進数の文字列をWORD値に変換 + */ WORD n2word(const char *str) { assert(isdigit(*str) || *str == '-'); + char *check; int n; /* WORD値に変換 */ @@ -12,17 +39,20 @@ WORD n2word(const char *str) setcerr(114, str); /* not integer */ return 0x0; } - /* nが-32768〜32767の範囲にないときは、その下位16ビットを格納 */ + /* nが-32768から32767の範囲にないときは、その下位16ビットを格納 */ if(n < -32768 || n > 32767) { - n = n % 0x10000; + n = n & 0xFFFF; } return (WORD)n; } -/* 16進数の文字列をWORD値に変換 */ +/** + * 16進数の文字列をWORD値に変換 + */ WORD h2word(const char *str) { assert(*str == '#'); + WORD w = 0x0; char *check; str++; @@ -39,47 +69,85 @@ WORD h2word(const char *str) return w; } -/* 10進数または16進数の文字列をWORD値に変換 */ +/** + * 10進数または16進数の文字列をWORD値に変換 + */ WORD nh2word(const char *str) { - WORD word; + WORD w; + + assert(sizeof(WORD) * 8 == 16); /* WORD型のサイズが16ビットであることを確認 */ if(!isdigit(*str) && *str != '-' && *str != '#') { setcerr(114, str); /* not integer */ return 0x0; } if(*str == '#') { - word = h2word(str); + w = h2word(str); } else { - word = n2word(str); + w = n2word(str); } - return word; + return w; } -/* WORD値を10進数の文字列に変換 */ +/** + * WORD値を10進数の文字列に変換 + */ char *word2n(WORD word) { - char *p = malloc(6), *q = malloc(6); + enum { + MAXLEN = 5, /* WORD値を10進数で表したときの最大桁数 */ + }; + char *p = malloc_chk(MAXLEN + 1, "word2n.p"), *digit = malloc_chk(MAXLEN + 1, "word2n.digit"); int i = 0, j; + do{ *(p + i++) = word % 10 + '0'; } while((word /= 10) > 0); for(j = 0; j < i; j++) { - *(q + j) = *(p + (i - 1) - j); + *(digit + j) = *(p + (i - 1) - j); } - *(q + j + 1) = '\0'; - return q; + *(digit + j + 1) = '\0'; + FREE(p); + return digit; } -/* WORD値を2進数の文字列に変換 */ +/** + * WORD値を2進数の文字列に変換 + */ char *word2bit(const WORD word) { + enum { + MAXLEN = 16, /* WORD値を2進数で表したときの最大桁数 */ + }; WORD mask = 0x8000; char *bit, *p; - bit = malloc(16 + 1); - p = bit; + + bit = p = malloc_chk(MAXLEN + 1, "word2bit.bit"); do { *p++ = (word & mask) ? '1' : '0'; } while((mask >>= 1) > 0); *p = '\0'; return bit; } + +/** + * WORD値を解析して表示 + */ +void print_dumpword(WORD word, bool logicalmode) +{ + if(logicalmode == true) { + fprintf(stdout, "%6d", word); + } else { + fprintf(stdout, "%6d", (signed short)word); + } + fprintf(stdout, " = #%04X = %s", word, word2bit(word)); + /* 「文字の組」の符号表に記載された文字と、改行(CR)/タブを表示 */ + if(word >= 0x20 && word <= 0x7E) { + fprintf(stdout, " = \'%c\'", word); + } else if(word == 0xA) { + fprintf(stdout, " = \'\\n\'"); + } else if(word == '\t') { + fprintf(stdout, " = \'\\t\'"); + } + fprintf(stdout, "\n"); +}