X-Git-Url: http://j8takagi.net/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Fword.c;h=3e9d30506c65b1e626218abf443662a02d4e5630;hb=373540e9b114c01712121c36b40f47a98e12d263;hp=3b309671470d78b0333ccaa4ed985808e7a67bb3;hpb=406fd6490ad76b4573b6ce9f8d322d92f13d27d8;p=YACASL2.git diff --git a/src/word.c b/src/word.c index 3b30967..3e9d305 100644 --- a/src/word.c +++ b/src/word.c @@ -1,18 +1,21 @@ +#include +#include +#include +#include +#include + #include "word.h" +#include "cerr.h" /* wordのエラー定義 */ -CERRARRAY cerr_word[] = { +static CERR cerr_word[] = { { 114, "not integer" }, { 115, "not hex" }, { 116, "out of hex range" }, }; -bool addcerrlist_word() -{ - return addcerrlist(ARRAYSIZE(cerr_word), cerr_word); -} /* 10進数の文字列をWORD値に変換 */ -WORD n2word(const char *str) +static WORD n2word(const char *str) { assert(isdigit(*str) || *str == '-'); @@ -24,7 +27,7 @@ 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 & 0xFFFF; } @@ -32,7 +35,7 @@ WORD n2word(const char *str) } /* 16進数の文字列をWORD値に変換 */ -WORD h2word(const char *str) +static WORD h2word(const char *str) { assert(*str == '#'); @@ -55,8 +58,11 @@ WORD h2word(const char *str) /* 10進数または16進数の文字列をWORD値に変換 */ WORD nh2word(const char *str) { - addcerrlist_word(); + assert(sizeof(WORD)*8 == 16); /* WORD型のサイズが16ビットであることを確認 */ + addcerrlist(ARRAYSIZE(cerr_word), cerr_word); /* エラーの設定 */ + WORD word; + if(!isdigit(*str) && *str != '-' && *str != '#') { setcerr(114, str); /* not integer */ return 0x0; @@ -72,24 +78,33 @@ WORD nh2word(const char *str) /* WORD値を10進数の文字列に変換 */ char *word2n(WORD word) { - char *p = malloc(6), *q = malloc(6); + enum { + MAXLEN = 6, /* WORD値を10進数で表したときの最大桁数 */ + }; + char *p = malloc_chk(MAXLEN, "word2n.p"), *digit = malloc_chk(MAXLEN, "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_chk(p, "word2n.p"); + return digit; } /* WORD値を2進数の文字列に変換 */ char *word2bit(const WORD word) { + enum { + MAXLEN = 16, /* WORD値を2進数で表したときの最大桁数 */ + }; WORD mask = 0x8000; - char *bit = malloc(16 + 1), *p; - p = bit; + char *bit, *p; + + bit = p = malloc_chk(MAXLEN + 1, "word2bit.bit"); do { *p++ = (word & mask) ? '1' : '0'; } while((mask >>= 1) > 0);