annotate conv/c.c @ 68:0266905063b5

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