YACASL2
word.c
Go to the documentation of this file.
1 #include <stdio.h>
2 #include <string.h>
3 #include <assert.h>
4 #include <stdlib.h>
5 #include <ctype.h>
6 
7 #include "word.h"
8 #include "cerr.h"
9 
17 WORD n2word(const char *str);
18 
26 WORD h2word(const char *str);
27 
28 WORD n2word(const char *str)
29 {
30  assert(isdigit(str[0]) || str[0] == '-');
31 
32  char *check = NULL;
33  int n;
34  /* WORD値に変換 */
35  n = strtol(str, &check, 10);
36  if(check[0]) {
37  setcerr(114, str); /* not integer */
38  return 0x0;
39  }
40  /* nが-32768から32767の範囲にないときは、その下位16ビットを格納 */
41  if(n < -32768 || n > 32767) {
42  n &= 0xFFFF;
43  }
44  return (WORD)n;
45 }
46 
47 WORD h2word(const char *str)
48 {
49  assert(str[0] == '#');
50 
51  WORD w = 0;
52  char *check = NULL;
53  str++;
54  if(*str == '-' || strlen(str) > 4) {
55  setcerr(116, str-1); /* out of hex range */
56  return 0x0;
57  }
58  /* WORD値に変換 */
59  w = (WORD)strtol(str, &check, 16);
60  if(check[0]) {
61  setcerr(115, str-1); /* not hex */
62  return 0x0;
63  }
64  return w;
65 }
66 
70 static CERR cerr_word[] = {
71  { 114, "not integer" },
72  { 115, "not hex" },
73  { 116, "out of hex range" },
74 };
75 
76 /* word.hで定義された関数群 */
78 {
80 }
81 
82 WORD nh2word(const char *str)
83 {
84  WORD w;
85 
86  assert(sizeof(WORD) * 8 == 16); /* WORD型のサイズが16ビットであることを確認 */
87  if(str == NULL) {
88  return 0x0;
89  }
90  if(!isdigit(*str) && *str != '-' && *str != '#') {
91  setcerr(114, str); /* not integer */
92  return 0x0;
93  }
94  if(*str == '#') {
95  w = h2word(str);
96  } else {
97  w = n2word(str);
98  }
99  return w;
100 }
101 
102 char *word2n(WORD word)
103 {
104  enum {
105  MAXLEN = 5, /* WORD値を10進数で表したときの最大けた数 */
106  };
107  char *s = malloc_chk(MAXLEN + 1, "word2n.n");
108  char *t = NULL;
109  int d = 0; /* けた数 */
110 
111  do{
112  s[d++] = word % 10 + '0';
113  } while((word /= 10) > 0);
114  s[d] = '\0';
115  t = strrev(s);
116  FREE(s);
117  return t;
118 }
119 
120 char *word2bit(const WORD word)
121 {
122  enum {
123  MAXLEN = 16, /* WORD値を2進数で表したときの最大桁数 */
124  };
125  WORD mask = 0x8000;
126  char *bit = NULL;
127  int i = 0;
128 
129  bit = malloc_chk(MAXLEN + 1, "word2bit.bit");
130  do {
131  bit[i++] = (word & mask) ? '1' : '0';
132  } while((mask >>= 1) > 0);
133  bit[i] = '\0';
134  return bit;
135 }
136 
137 void print_dumpword(WORD word, bool logicalmode)
138 {
139  char *bit = word2bit(word);
140 
141  if(logicalmode == true) {
142  fprintf(stdout, "%6u", word);
143  } else {
144  fprintf(stdout, "%6d", (signed short)word);
145  }
146  fprintf(stdout, " = #%04X = %s", word, bit);
147  /* 「文字の組」の符号表に記載された文字と、改行(CR)/タブを表示 */
148  if(word >= 0x20 && word <= 0x7E) {
149  fprintf(stdout, " = \'%c\'", word);
150  } else if(word == 0xA) {
151  fprintf(stdout, " = \'\\n\'");
152  } else if(word == '\t') {
153  fprintf(stdout, " = \'\\t\'");
154  }
155  FREE(bit);
156 }
void addcerrlist(int cerrc, CERR cerrv[])
エラーリストを作成・追加する
Definition: cerr.c:13
void setcerr(int num, const char *str)
現在のエラーを設定する
Definition: cerr.c:45
#define FREE(ptr)
メモリを解放するマクロ
Definition: cmem.h:21
char * strrev(const char *s)
逆にした文字列を返す
Definition: cmem.c:71
#define ARRAYSIZE(array)
配列のサイズを返すマクロ
Definition: cmem.h:14
void * malloc_chk(size_t size, const char *tag)
mallocを実行し、0で初期化する
Definition: cmem.c:3
エラーを表すデータ型
Definition: cerr.h:15
WORD n2word(const char *str)
10進数値を表す文字列をWORD値に変換する
Definition: word.c:28
WORD nh2word(const char *str)
10進数または16進数の文字列をWORD値に変換する
Definition: word.c:82
WORD h2word(const char *str)
16進数の文字列をWORD値に変換する
Definition: word.c:47
void print_dumpword(WORD word, bool logicalmode)
WORD値を解析して表示する
Definition: word.c:137
char * word2bit(const WORD word)
WORD値を2進数の文字列に変換する
Definition: word.c:120
char * word2n(WORD word)
WORD値を10進数値を表す文字列に変換する
Definition: word.c:102
void addcerrlist_word()
wordデータ型についてのエラーをエラーリストに追加する
Definition: word.c:77
static CERR cerr_word[]
wordのエラー定義
Definition: word.c:70
unsigned short WORD
16ビットの数値を表すデータ型
Definition: word.h:9