X-Git-Url: http://j8takagi.net/cgi-bin/gitweb.cgi?p=YACASL2.git;a=blobdiff_plain;f=src%2Fword.c;h=34a39463263b4dabd319d2a89183daee2598e9e3;hp=3e9d30506c65b1e626218abf443662a02d4e5630;hb=019b584feedf0402e473fba3e0e7752db78e616a;hpb=d1f82970bf7d41db2fea11b08cd8e308f6cb8138 diff --git a/src/word.c b/src/word.c index 3e9d305..34a3946 100644 --- a/src/word.c +++ b/src/word.c @@ -7,15 +7,27 @@ #include "word.h" #include "cerr.h" -/* wordのエラー定義 */ +/** + * wordのエラー定義 + */ static CERR cerr_word[] = { { 114, "not integer" }, { 115, "not hex" }, { 116, "out of hex range" }, }; -/* 10進数の文字列をWORD値に変換 */ -static WORD n2word(const char *str) +/** + * wordのエラーをエラーリストに追加 + */ +void addcerrlist_word() +{ + addcerrlist(ARRAYSIZE(cerr_word), cerr_word); +} + +/** + * 10進数の文字列をWORD値に変換 + */ +WORD n2word(const char *str) { assert(isdigit(*str) || *str == '-'); @@ -34,12 +46,14 @@ static WORD n2word(const char *str) return (WORD)n; } -/* 16進数の文字列をWORD値に変換 */ -static WORD h2word(const char *str) +/** + * 16進数の文字列をWORD値に変換 + */ +WORD h2word(const char *str) { assert(*str == '#'); - WORD word = 0x0; + WORD w = 0x0; char *check; str++; if(*str == '-' || strlen(str) > 4) { @@ -47,41 +61,43 @@ static WORD h2word(const char *str) return 0; } /* WORD値に変換 */ - word = (WORD)strtol(str, &check, 16); + w = (WORD)strtol(str, &check, 16); if(*check != '\0') { setcerr(115, str-1); /* not hex */ return 0x0; } - return word; + return w; } -/* 10進数または16進数の文字列をWORD値に変換 */ +/** + * 10進数または16進数の文字列をWORD値に変換 + */ WORD nh2word(const char *str) { - assert(sizeof(WORD)*8 == 16); /* WORD型のサイズが16ビットであることを確認 */ - addcerrlist(ARRAYSIZE(cerr_word), cerr_word); /* エラーの設定 */ - - 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) { enum { - MAXLEN = 6, /* WORD値を10進数で表したときの最大桁数 */ + MAXLEN = 5, /* WORD値を10進数で表したときの最大桁数 */ }; - char *p = malloc_chk(MAXLEN, "word2n.p"), *digit = malloc_chk(MAXLEN, "word2n.digit"); + char *p = malloc_chk(MAXLEN + 1, "word2n.p"), *digit = malloc_chk(MAXLEN + 1, "word2n.digit"); int i = 0, j; do{ @@ -91,11 +107,13 @@ char *word2n(WORD word) *(digit + j) = *(p + (i - 1) - j); } *(digit + j + 1) = '\0'; - free_chk(p, "word2n.p"); + FREE(p); return digit; } -/* WORD値を2進数の文字列に変換 */ +/** + * WORD値を2進数の文字列に変換 + */ char *word2bit(const WORD word) { enum { @@ -112,15 +130,19 @@ char *word2bit(const WORD word) return bit; } -/* WORD値を解析して表示 */ +/** + * WORD値を解析して表示 + */ void print_dumpword(WORD word, bool logicalmode) { + char *b; + if(logicalmode == true) { fprintf(stdout, "%6d", word); } else { fprintf(stdout, "%6d", (signed short)word); } - fprintf(stdout, " = #%04X = %s", word, word2bit(word)); + fprintf(stdout, " = #%04X = %s", word, (b = word2bit(word))); /* 「文字の組」の符号表に記載された文字と、改行(CR)/タブを表示 */ if(word >= 0x20 && word <= 0x7E) { fprintf(stdout, " = \'%c\'", word); @@ -130,4 +152,5 @@ void print_dumpword(WORD word, bool logicalmode) fprintf(stdout, " = \'\\t\'"); } fprintf(stdout, "\n"); + FREE(b); }