X-Git-Url: http://j8takagi.net/cgi-bin/gitweb.cgi?p=YACASL2.git;a=blobdiff_plain;f=src%2Fword.c;h=1bbffdbf7d9690f02f0e5598212e0f54b1420a50;hp=6e9fb1702910f1e1ea4ff8cee583b453ececf926;hb=de18494f8acd2f8ca87b86c54bfee1c2094c0d83;hpb=2d3d185962d2997a08cd2e674868cea35b99ae04 diff --git a/src/word.c b/src/word.c index 6e9fb17..1bbffdb 100644 --- a/src/word.c +++ b/src/word.c @@ -1,19 +1,32 @@ +#include +#include +#include +#include +#include + #include "word.h" #include "cerr.h" -/* wordのエラー定義 */ -CERR cerr_word[] = { +/** + * wordのエラー定義 + */ +static CERR cerr_word[] = { { 114, "not integer" }, { 115, "not hex" }, { 116, "out of hex range" }, }; +/** + * wordのエラーをエラーリストに追加 + */ bool addcerrlist_word() { return addcerrlist(ARRAYSIZE(cerr_word), cerr_word); } -/* 10進数の文字列をWORD値に変換 */ +/** + * 10進数の文字列をWORD値に変換 + */ WORD n2word(const char *str) { assert(isdigit(*str) || *str == '-'); @@ -26,14 +39,16 @@ 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; } return (WORD)n; } -/* 16進数の文字列をWORD値に変換 */ +/** + * 16進数の文字列をWORD値に変換 + */ WORD h2word(const char *str) { assert(*str == '#'); @@ -54,11 +69,15 @@ WORD h2word(const char *str) return word; } -/* 10進数または16進数の文字列をWORD値に変換 */ +/** + * 10進数または16進数の文字列をWORD値に変換 + */ WORD nh2word(const char *str) { - addcerrlist_word(); + assert(sizeof(WORD)*8 == 16); /* WORD型のサイズが16ビットであることを確認 */ + WORD word; + if(!isdigit(*str) && *str != '-' && *str != '#') { setcerr(114, str); /* not integer */ return 0x0; @@ -71,7 +90,9 @@ WORD nh2word(const char *str) return word; } -/* WORD値を10進数の文字列に変換 */ +/** + * WORD値を10進数の文字列に変換 + */ char *word2n(WORD word) { enum { @@ -91,7 +112,9 @@ char *word2n(WORD word) return digit; } -/* WORD値を2進数の文字列に変換 */ +/** + * WORD値を2進数の文字列に変換 + */ char *word2bit(const WORD word) { enum { @@ -108,7 +131,9 @@ char *word2bit(const WORD word) return bit; } -/* WORD値を解析して表示 */ +/** + * WORD値を解析して表示 + */ void print_dumpword(WORD word, bool logicalmode) { if(logicalmode == true) {