dumpwordコマンド実行時やレジスタの内容を表示するときに、対応する文字を表示するよう仕様変更
[YACASL2.git] / src / word.c
1 #include "word.h"
2
3 /* 10進数の文字列をWORD値に変換 */
4 WORD n2word(const char *str)
5 {
6     assert(isdigit(*str) || *str == '-');
7     char *check;
8     int n;
9     /* WORD値に変換 */
10     n = strtol(str, &check, 10);
11     if(*check != '\0') {
12         setcerr(114, str);    /* not integer */
13         return 0x0;
14     }
15     /* nが-32768〜32767の範囲にないときは、その下位16ビットを格納 */
16     if(n < -32768 || n > 32767) {
17         n = n & 0xFFFF;
18     }
19     return (WORD)n;
20 }
21
22 /* 16進数の文字列をWORD値に変換 */
23 WORD h2word(const char *str)
24 {
25     assert(*str == '#');
26     WORD word = 0x0;
27     char *check;
28     str++;
29     if(*str == '-' || strlen(str) > 4) {
30         setcerr(116, str-1);    /* out of hex range */
31         return 0;
32     }
33     /* WORD値に変換 */
34     word = (WORD)strtol(str, &check, 16);
35     if(*check != '\0') {
36         setcerr(115, str-1);    /* not hex */
37         return 0x0;
38     }
39     return word;
40 }
41
42 /* 10進数または16進数の文字列をWORD値に変換 */
43 WORD nh2word(const char *str)
44 {
45     WORD word;
46     if(!isdigit(*str) && *str != '-' && *str != '#') {
47         setcerr(114, str);    /* not integer */
48         return 0x0;
49     }
50     if(*str == '#') {
51         word = h2word(str);
52     } else {
53         word = n2word(str);
54     }
55     return word;
56 }
57
58 /* WORD値を10進数の文字列に変換 */
59 char *word2n(WORD word)
60 {
61     char *p = malloc(6), *q = malloc(6);
62     int i = 0, j;
63     do{
64         *(p + i++) = word % 10 + '0';
65     } while((word /= 10) > 0);
66     for(j = 0; j < i; j++) {
67         *(q + j) = *(p + (i - 1) - j);
68     }
69     *(q + j + 1) = '\0';
70     return q;
71 }
72
73 /* WORD値を2進数の文字列に変換 */
74 char *word2bit(const WORD word)
75 {
76     WORD mask = 0x8000;
77     char *bit, *p;
78     bit = malloc(16 + 1);
79     p = bit;
80     do {
81         *p++ = (word & mask) ? '1' : '0';
82     } while((mask >>= 1) > 0);
83     *p = '\0';
84     return bit;
85 }
86
87 /* WORD値を解析して表示 */
88 void print_dumpword(WORD word, bool logicalmode)
89 {
90     if(logicalmode == true) {
91         fprintf(stdout, "%6d", word);
92     } else {
93         fprintf(stdout, "%6d", (signed short)word);
94     }
95     fprintf(stdout, " = #%04X = %s", word, word2bit(word));
96     /* 「文字の組」の符号表に記載された文字と、改行(CR)/タブを表示 */
97     if(word >= 0x20 && word <= 0x7E) {
98         fprintf(stdout, " = \'%c\'", word);
99     } else if(word == 0xA) {
100         fprintf(stdout, " = \'\\n\'");
101     } else if(word == '\t') {
102         fprintf(stdout, " = \'\\t\'");
103     }
104     fprintf(stdout, "\n");
105 }