projects
/
YACASL2.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
htagsでの出力内容を調整
[YACASL2.git]
/
src
/
word.c
diff --git
a/src/word.c
b/src/word.c
index
3e9d305
..
e355a67
100644
(file)
--- a/
src/word.c
+++ b/
src/word.c
@@
-7,15
+7,27
@@
#include "word.h"
#include "cerr.h"
#include "word.h"
#include "cerr.h"
-/* wordのエラー定義 */
+/**
+ * wordのエラー定義
+ */
static CERR cerr_word[] = {
{ 114, "not integer" },
{ 115, "not hex" },
{ 116, "out of hex range" },
};
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 == '-');
{
assert(isdigit(*str) || *str == '-');
@@
-34,12
+46,14
@@
static WORD n2word(const char *str)
return (WORD)n;
}
return (WORD)n;
}
-/* 16進数の文字列をWORD値に変換 */
-static WORD h2word(const char *str)
+/**
+ * 16進数の文字列をWORD値に変換
+ */
+WORD h2word(const char *str)
{
assert(*str == '#');
{
assert(*str == '#');
- WORD w
ord
= 0x0;
+ WORD w = 0x0;
char *check;
str++;
if(*str == '-' || strlen(str) > 4) {
char *check;
str++;
if(*str == '-' || strlen(str) > 4) {
@@
-47,41
+61,43
@@
static WORD h2word(const char *str)
return 0;
}
/* WORD値に変換 */
return 0;
}
/* WORD値に変換 */
- w
ord
= (WORD)strtol(str, &check, 16);
+ w = (WORD)strtol(str, &check, 16);
if(*check != '\0') {
setcerr(115, str-1); /* not hex */
return 0x0;
}
if(*check != '\0') {
setcerr(115, str-1); /* not hex */
return 0x0;
}
- return w
ord
;
+ return w;
}
}
-/* 10進数または16進数の文字列をWORD値に変換 */
+/**
+ * 10進数または16進数の文字列をWORD値に変換
+ */
WORD nh2word(const char *str)
{
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 == '#') {
if(!isdigit(*str) && *str != '-' && *str != '#') {
setcerr(114, str); /* not integer */
return 0x0;
}
if(*str == '#') {
- w
ord
= h2word(str);
+ w = h2word(str);
} else {
} else {
- w
ord
= n2word(str);
+ w = n2word(str);
}
}
- return w
ord
;
+ return w;
}
}
-/* WORD値を10進数の文字列に変換 */
+/**
+ * WORD値を10進数の文字列に変換
+ */
char *word2n(WORD word)
{
enum {
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{
int i = 0, j;
do{
@@
-91,11
+107,13
@@
char *word2n(WORD word)
*(digit + j) = *(p + (i - 1) - j);
}
*(digit + j + 1) = '\0';
*(digit + j) = *(p + (i - 1) - j);
}
*(digit + j + 1) = '\0';
-
free_chk(p, "word2n.p"
);
+
FREE(p
);
return digit;
}
return digit;
}
-/* WORD値を2進数の文字列に変換 */
+/**
+ * WORD値を2進数の文字列に変換
+ */
char *word2bit(const WORD word)
{
enum {
char *word2bit(const WORD word)
{
enum {
@@
-112,7
+130,9
@@
char *word2bit(const WORD word)
return bit;
}
return bit;
}
-/* WORD値を解析して表示 */
+/**
+ * WORD値を解析して表示
+ */
void print_dumpword(WORD word, bool logicalmode)
{
if(logicalmode == true) {
void print_dumpword(WORD word, bool logicalmode)
{
if(logicalmode == true) {