回答編集履歴

1

追記

2019/06/22 15:13

投稿

otn
otn

スコア84710

test CHANGED
@@ -79,3 +79,83 @@
79
79
  普通のコンパイラの場合は、テーブルを引くなら出力するための関数を型それぞれ個別で定義しないと駄目ですね。
80
80
 
81
81
  `if`の連鎖をマクロを使って書く案が出ていますが、そういう方向がいいと思います。
82
+
83
+
84
+
85
+ #追記
86
+
87
+ やはり処理系依存ですが、bcc32 (Borland C)だと出来ました。
88
+
89
+ `va_list`型が、ポインタになっているタイプだと多分大丈夫。
90
+
91
+ ただし、`float`型の出力指定子は無いので、`double`にする必要があります。この特別扱いはどうしようも無いですね。
92
+
93
+ ```C
94
+
95
+ #include <stdio.h>
96
+
97
+ #include <string.h>
98
+
99
+ #include <stdlib.h>
100
+
101
+ #include <stdarg.h>
102
+
103
+
104
+
105
+ int main(void)
106
+
107
+ {
108
+
109
+ char line[1024];
110
+
111
+ char type[100];
112
+
113
+
114
+
115
+ char *types[] = {"int","float","double","char"};
116
+
117
+ char *ifmts[] = {"%d", "%f","%lf"," %c"};
118
+
119
+ char *ofmts[] = {"int=%d\n", "float=%f\n","double=%f\n","char='%c'\n"};
120
+
121
+ union {
122
+
123
+ int xi;
124
+
125
+ float xf;
126
+
127
+ double xd;
128
+
129
+ char xc;
130
+
131
+ } work;
132
+
133
+
134
+
135
+ int i;
136
+
137
+
138
+
139
+ while(fgets(line,sizeof line,stdin)){
140
+
141
+ if(sscanf(line, "%s", type)!=1) exit(1);
142
+
143
+ for(i=0; i<sizeof types/sizeof types[0]; i++){
144
+
145
+ if(!strcmp(type,types[i])) break;
146
+
147
+ }
148
+
149
+ if(i==sizeof types/sizeof types[0]) exit(2);
150
+
151
+ if(sscanf(line+strlen(type), ifmts[i], (void*)&work)!=1) exit(3);
152
+
153
+ if(i==1) work.xd = work.xf;
154
+
155
+ vprintf(ofmts[i],&work);
156
+
157
+ }
158
+
159
+ }
160
+
161
+ ```