YACASL2
Loading...
Searching...
No Matches
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
17WORD n2word(const char *str);
18
26WORD h2word(const char *str);
27
28WORD 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
47WORD 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
70static CERR cerr_word[] = {
71 { 114, "not integer" },
72 { 115, "not hex" },
73 { 116, "out of hex range" },
74};
75
76/* word.hで定義された関数群 */
81
82WORD 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
102char *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
120char *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
137void 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}
struct _CERR CERR
エラーを表すデータ型
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
void * malloc_chk(size_t size, const char *tag)
mallocを実行し、0で初期化する
Definition cmem.c:3
#define ARRAYSIZE(array)
配列のサイズを返すマクロ
Definition cmem.h:14
char * word2bit(const WORD word)
WORD値を2進数の文字列に変換する
Definition word.c:120
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
void addcerrlist_word()
wordデータ型についてのエラーをエラーリストに追加する
Definition word.c:77
static CERR cerr_word[]
wordのエラー定義
Definition word.c:70
char * word2n(WORD word)
WORD値を10進数値を表す文字列に変換する
Definition word.c:102
unsigned short WORD
16ビットの数値を表すデータ型
Definition word.h:9