X-Git-Url: http://j8takagi.net/cgi-bin/gitweb.cgi?p=YACASL2.git;a=blobdiff_plain;f=src%2Fword.c;h=1c1f84547b73a646fb4ecf076f43bb44bc95aa69;hp=df953c5060b0dd8bd728fb8a07a5b81c6a7a2878;hb=1866f147802418826c9386c755a9d6ba1d5cff89;hpb=bbd97e8f26bfbb3d4b4688bea469062d82aaa764 diff --git a/src/word.c b/src/word.c index df953c5..1c1f845 100644 --- a/src/word.c +++ b/src/word.c @@ -25,20 +25,11 @@ WORD n2word(const char *str); */ WORD h2word(const char *str); -/** - * @brief wordのエラー定義 - */ -static CERR cerr_word[] = { - { 114, "not integer" }, - { 115, "not hex" }, - { 116, "out of hex range" }, -}; - WORD n2word(const char *str) { assert(isdigit(str[0]) || str[0] == '-'); - char *check; + char *check = NULL; int n; /* WORD値に変換 */ n = strtol(str, &check, 10); @@ -57,8 +48,8 @@ WORD h2word(const char *str) { assert(str[0] == '#'); - WORD w = 0x0; - char *check; + WORD w = 0; + char *check = NULL; str++; if(*str == '-' || strlen(str) > 4) { setcerr(116, str-1); /* out of hex range */ @@ -73,6 +64,15 @@ WORD h2word(const char *str) return w; } +/** + * @brief wordのエラー定義 + */ +static CERR cerr_word[] = { + { 114, "not integer" }, + { 115, "not hex" }, + { 116, "out of hex range" }, +}; + /* word.hで定義された関数群 */ void addcerrlist_word() { @@ -125,9 +125,10 @@ char *word2bit(const WORD word) MAXLEN = 16, /* WORD値を2進数で表したときの最大桁数 */ }; WORD mask = 0x8000; - char *bit = malloc_chk(MAXLEN + 1, "word2bit.bit"); + char *bit = NULL; int i = 0; + bit = malloc_chk(MAXLEN + 1, "word2bit.bit"); do { bit[i++] = (word & mask) ? '1' : '0'; } while((mask >>= 1) > 0); @@ -137,14 +138,14 @@ char *word2bit(const WORD word) void print_dumpword(WORD word, bool logicalmode) { - const char *bit = word2bit(word); + char *bit = NULL; if(logicalmode == true) { fprintf(stdout, "%6d", word); } else { fprintf(stdout, "%6d", (signed short)word); } - fprintf(stdout, " = #%04X = %s", word, bit); + fprintf(stdout, " = #%04X = %s", word, (bit = word2bit(word))); /* 「文字の組」の符号表に記載された文字と、改行(CR)/タブを表示 */ if(word >= 0x20 && word <= 0x7E) { fprintf(stdout, " = \'%c\'", word); @@ -153,4 +154,5 @@ void print_dumpword(WORD word, bool logicalmode) } else if(word == '\t') { fprintf(stdout, " = \'\\t\'"); } + FREE(bit); }