annotate conv/cbc2c.c @ 599:df04bc5fd5fe

*** empty log message ***
author kono
date Thu, 26 Jan 2006 15:19:55 +0900
parents 0b068058dd67
children e055df7c1082
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
60
aa779bcffef7 CwC converters
kono
parents:
diff changeset
1 #define EXTERN /**/
aa779bcffef7 CwC converters
kono
parents:
diff changeset
2
599
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
3 #include <stdio.h>
60
aa779bcffef7 CwC converters
kono
parents:
diff changeset
4 #include "mc.h"
599
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
5 #include "mc-parse.h"
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
6 #include "mc-codegen.h"
60
aa779bcffef7 CwC converters
kono
parents:
diff changeset
7
599
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
8 #include "conv/conv.h"
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
9 #include "conv/convdef.h"
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
10 #include "conv/cbc2c.h"
60
aa779bcffef7 CwC converters
kono
parents:
diff changeset
11
599
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
12 extern void type_print(int type,NMTBL *nptr,FILE *out);
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
13 extern void type_print1(int type,NMTBL *nptr,FILE *out,int cont);
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
14 extern void sym_print(int type,FILE *out);
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
15
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
16 static FILE *vout,*svout;
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
17 static FILE *null;
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
18 static FILE *hout;
60
aa779bcffef7 CwC converters
kono
parents:
diff changeset
19
aa779bcffef7 CwC converters
kono
parents:
diff changeset
20 static void
599
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
21 comment_(int c)
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
22 {
599
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
23 fprintf(vout,"%c",c);
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
24 }
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
25
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
26 static void
599
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
27 open_(char *s)
65
8ad746efa4f8 *** empty log message ***
kono
parents: 60
diff changeset
28 {
599
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
29 char *p;
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
30 p = make_filename_with_extension(s,"cbc.c");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
31 #if 1
65
8ad746efa4f8 *** empty log message ***
kono
parents: 60
diff changeset
32 vout = fopen(p,"w");
599
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
33 #else
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
34 vout = stderr;p=p;
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
35 #endif
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
36 p = make_filename_with_extension(s,"cbc.h");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
37 hout = fopen(p,"w");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
38 null=fopen("/dev/null","w");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
39 if (!vout) error(-1);
65
8ad746efa4f8 *** empty log message ***
kono
parents: 60
diff changeset
40 }
8ad746efa4f8 *** empty log message ***
kono
parents: 60
diff changeset
41
8ad746efa4f8 *** empty log message ***
kono
parents: 60
diff changeset
42 static void
599
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
43 conv_()
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
44 {
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
45 vout=svout;
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
46 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
47
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
48 static void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
49 noconv_(int c)
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
50 {
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
51 svout=vout;
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
52 vout=c?null:vout;
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
53 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
54
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
55 static void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
56 print_(char *s)
60
aa779bcffef7 CwC converters
kono
parents:
diff changeset
57 {
aa779bcffef7 CwC converters
kono
parents:
diff changeset
58 fprintf(vout,"c: %s\n",s);
aa779bcffef7 CwC converters
kono
parents:
diff changeset
59 }
65
8ad746efa4f8 *** empty log message ***
kono
parents: 60
diff changeset
60
8ad746efa4f8 *** empty log message ***
kono
parents: 60
diff changeset
61 static void
599
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
62 close_()
65
8ad746efa4f8 *** empty log message ***
kono
parents: 60
diff changeset
63 {
8ad746efa4f8 *** empty log message ***
kono
parents: 60
diff changeset
64 fclose(vout);
8ad746efa4f8 *** empty log message ***
kono
parents: 60
diff changeset
65 }
8ad746efa4f8 *** empty log message ***
kono
parents: 60
diff changeset
66
599
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
67 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
68 case_begin_(int cases,int def){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
69 fprintf(vout,"case ");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
70 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
71
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
72 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
73 case_(int cases,int def){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
74 if (def)
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
75 fprintf(vout,"default:");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
76 else
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
77 fprintf(vout,"%d:",car(cases));
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
78 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
79
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
80 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
81 code_(NMTBL *n){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
82 int args;
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
83 args=n->dsp;
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
84 fprintf(vout,"code %s(",n->nm);
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
85 while(args) {
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
86 n=(NMTBL *)caddr(args);
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
87 type_print(n->ty,n,vout);
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
88 args=cadr(args);
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
89 if(args) fprintf(vout,",");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
90 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
91 fprintf(vout,")");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
92 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
93
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
94 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
95 code_end_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
96 fprintf(vout,"}");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
97 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
98
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
99 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
100 comma_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
101 fprintf(vout,",");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
102 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
103
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
104 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
105 cond_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
106
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
107 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
108
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
109 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
110 cond1_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
111 fprintf(vout,"?");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
112 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
113
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
114 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
115 cond2_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
116 fprintf(vout,":");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
117 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
118
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
119 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
120 cond_end_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
121
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
122 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
123
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
124 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
125 decl_data_begin_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
126
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
127 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
128
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
129 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
130 decl_data_end_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
131
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
132 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
133
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
134 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
135 def_(NMTBL *n){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
136 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
137
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
138 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
139 dowhile_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
140 fprintf(vout,"do");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
141 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
142
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
143 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
144 dowhile_cond_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
145 fprintf(vout,"while(");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
146 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
147
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
148 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
149 dowhile_end_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
150 fprintf(vout,");");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
151 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
152
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
153 int
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
154 error_(int n){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
155 return 0;
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
156 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
157
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
158 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
159 extern_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
160 fprintf(vout,"extern ");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
161 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
162
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
163 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
164 for_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
165 fprintf(vout,"for(");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
166 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
167
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
168 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
169 for1_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
170 fprintf(vout,";");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
171 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
172
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
173 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
174 for2_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
175 fprintf(vout,";");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
176 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
177
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
178 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
179 for_body_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
180 fprintf(vout,")");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
181 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
182
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
183 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
184 for_end_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
185
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
186 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
187
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
188 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
189 funcall_(int type){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
190 fprintf(vout,"(");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
191 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
192
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
193 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
194 funcall_args_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
195 fprintf(vout,")");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
196 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
197
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
198 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
199 function_(NMTBL *n,int cont){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
200 int args;
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
201 type_print1(cadr(n->ty),0,vout,cont);
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
202 fprintf(vout,"%s(",n->nm);
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
203 args=n->dsp;
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
204 while(args) {
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
205 n=(NMTBL *)caddr(args);
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
206 if (n==&str_ret) {
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
207 args=cadr(args); continue;
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
208 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
209 type_print(n->ty,n,vout);
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
210 args=cadr(args);
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
211 if(args) {
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
212 /* if(caddr(args)==(int)&str_ret) break; */
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
213 fprintf(vout,",");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
214 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
215 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
216 fprintf(vout,")");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
217 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
218
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
219 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
220 function_end_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
221
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
222 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
223
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
224 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
225 goto_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
226 fprintf(vout,"goto ");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
227 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
228
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
229 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
230 goto_label_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
231
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
232 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
233
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
234 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
235 id_(int sym,NMTBL *nptr){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
236 char *p = nptr->nm;
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
237 for(;*p && *p!='.';p++) fputc(*p,vout);
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
238 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
239
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
240 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
241 string_(char *s,int len){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
242 int c;
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
243 fprintf(vout,"\"");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
244 while((c=*s++)) {
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
245 if(c=='\n') fprintf(vout,"\\n");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
246 else if(c=='\r') fprintf(vout,"\\r");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
247 else if(c=='\t') fprintf(vout,"\\t");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
248 else if(c=='\e') fprintf(vout,"\\e");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
249 else if(c=='"') fprintf(vout,"\\\"");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
250 else if(c=='\\') fprintf(vout,"\\\\");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
251 else if(!(' '<=c&&c<=0x7f)) fprintf(vout,"\\%03o",c);
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
252 else fprintf(vout,"%c",c);
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
253 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
254 fprintf(vout,"\"");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
255 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
256
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
257 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
258 const_(int symval){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
259 fprintf(vout,"%d",symval);
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
260 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
261
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
262 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
263 return_f_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
264 fprintf(vout,"return");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
265 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
266
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
267 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
268 defined_(char *s){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
269 fprintf(vout,"defined(%s)",s);
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
270 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
271
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
272 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
273 environment_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
274 fprintf(vout,"environment");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
275 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
276
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
277 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
278 if_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
279 fprintf(vout,"if (");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
280 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
281
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
282 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
283 if_else_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
284 fprintf(vout," else ");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
285 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
286
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
287 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
288 if_endif_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
289 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
290
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
291 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
292 if_then_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
293 fprintf(vout,")");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
294 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
295
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
296 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
297 jump_(int env){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
298
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
299 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
300
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
301 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
302 label_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
303 fprintf(vout,"%s:",nptr->nm);
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
304 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
305
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
306 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
307 lpar_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
308 fprintf(vout,"(");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
309 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
310
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
311 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
312 rpar_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
313 fprintf(vout,")");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
314 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
315
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
316 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
317 lbra_(int sym){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
318 fprintf(vout,"[");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
319 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
320
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
321 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
322 rbra_(int sym){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
323 fprintf(vout,"]");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
324 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
325
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
326 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
327 lc_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
328 fprintf(vout,"{");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
329 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
330
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
331 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
332 rc_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
333 fprintf(vout,"}");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
334 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
335
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
336 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
337 localvar_end_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
338
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
339 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
340
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
341 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
342 op_(int sym){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
343 sym_print(sym,vout);
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
344 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
345
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
346 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
347 postfix_(int sym){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
348 sym_print(sym,vout);
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
349 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
350
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
351 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
352 prefix_(int sym){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
353 sym_print(sym,vout);
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
354 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
355
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
356 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
357 register_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
358 fprintf(vout,"register ");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
359 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
360
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
361 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
362 return_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
363 fprintf(vout,"return ");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
364 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
365
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
366 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
367 return_end_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
368 fprintf(vout,";");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
369 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
370
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
371 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
372 return_type_(int t,NMTBL *nptr,int cont){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
373 type_print1(t,nptr,vout,cont);
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
374 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
375
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
376 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
377 sm_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
378 fprintf(vout,";");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
379 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
380
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
381 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
382 static_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
383 fprintf(vout,"static ");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
384 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
385
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
386 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
387 switch_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
388 fprintf(vout,"switch (");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
389 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
390
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
391 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
392 switch_body_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
393 fprintf(vout,")");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
394 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
395
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
396 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
397 switch_end_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
398 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
399
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
400 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
401 typedef_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
402 fprintf(vout,"typedef ");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
403 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
404
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
405 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
406 type_(int t){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
407 type_print(t,0,vout);
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
408 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
409
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
410 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
411 sdecl_(int s)
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
412 {
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
413 fprintf(vout,s==UNION?"union ":"struct ");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
414 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
415
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
416 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
417 while_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
418 fprintf(vout,"while (");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
419 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
420
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
421 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
422 while_body_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
423 fprintf(vout,")");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
424 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
425
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
426 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
427 while_end_(){
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
428 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
429
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
430 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
431 decl_data_()
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
432 {
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
433 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
434
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
435 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
436 break_()
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
437 {
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
438 fprintf(vout,"break;");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
439 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
440
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
441 void
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
442 continue_()
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
443 {
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
444 fprintf(vout,"continue;");
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
445 }
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
446
df04bc5fd5fe *** empty log message ***
kono
parents: 66
diff changeset
447 /* end */