annotate mc-parse.c @ 334:dc81596066df

type fix done.
author kono
date Thu, 24 Jun 2004 20:50:17 +0900
parents ce85d6106119
children d488b72254fb
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
203
28baf6cd9ad1 *** empty log message ***
kono
parents: 202
diff changeset
1 /* Micro-C Parser Part */ /* $Id$ */
1
0529f5abe9d0 *** empty log message ***
kono
parents: 0
diff changeset
2
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3 #include <stdio.h>
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
4 #include "mc.h"
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
5 #include "mc-parse.h"
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
6 #include "mc-codegen.h"
297
0f79c95df73a switch index no compile error
kono
parents: 293
diff changeset
7 #include "mc-switch.h"
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
8 #include "mc-macro.h"
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
9 #include "conv/conv.h"
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
10
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
11 #define FILES 10
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
12 #define OUTPUT_FILE_NAME "mcout.s"
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
13
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
14 extern void exit(int); /* to avoid stdlib.h inclusion */
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
15 #if LONGLONG_CODE
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
16 #if 0
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
17 extern long long
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
18 strtoll(char * nptr, char ** endptr, int base);
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
19 #endif
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
20 #endif
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
21 #if FLOAT_CODE
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
22 extern double strtod(const char *nptr, char **endptr);
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
23 #endif
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
24
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
25 NMTBL null_nptr;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
26 NMTBL *fnptr;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
27 NMTBL *msearch0(char *name);
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
28 NMTBL *nptr,*gnptr;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
29 NMTBL ntable[GSYMS+LSYMS];
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
30 char *cheapp;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
31 char cheap[CHEAPSIZE]; // should be extendable
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
32 char linebuf[LBUFSIZE],namebuf[LBUFSIZE],*chptr;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
33 int args,init_vars,heap[HEAPSIZE];
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
34 int asmf;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
35 int bit_field_disp;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
36 int blabel,dlabel;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
37 int ch;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
38 int chk;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
39 int chptrsave;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
40 int chsave;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
41 int cslabel,control;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
42 int csvalue1;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
43 int debug;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
44 int fields;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
45 int glineno;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
46 int gtypedefed;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
47 int in_comment;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
48 int in_quote;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
49 int labelno,gpc,disp;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
50 int lastexp;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
51 int lfree;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
52 int lineno;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
53 int lsrc;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
54 int retlabel,retpending,retcont;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
55 int struct_return;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
56 int sym,type,mode,stmode;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
57 int typedefed;
328
7ecb023d29b8 macro/codegen reorganization done.
kono
parents: 327
diff changeset
58 int decl_str_init;
7ecb023d29b8 macro/codegen reorganization done.
kono
parents: 327
diff changeset
59
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
60 struct {int fd,ln;char *name0;int inc;FILE *fcb;} *filep,filestack[FILES];
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
61
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
62 static NMTBL *decl0(void),*decl1(void),*lsearch(char *name,int sc);
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
63 static NMTBL *gsearch(int sc);
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
64 static NMTBL *msearch(char *name);
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
65 static int append3(int p,int a1,int a2);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
66 static int expr0(void);
d35df41eac69 Initial revision
kono
parents:
diff changeset
67 static int expr1(void);
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
68 static int expr10(void);
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
69 static int expr11(void);
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
70 static int expr12(void);
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
71 static int expr13(void);
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
72 static int expr14(void);
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
73 static int expr15(int e1);
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
74 static int expr16(int e1);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
75 static int expr2(void);
d35df41eac69 Initial revision
kono
parents:
diff changeset
76 static int expr3(void);
d35df41eac69 Initial revision
kono
parents:
diff changeset
77 static int expr4(void);
d35df41eac69 Initial revision
kono
parents:
diff changeset
78 static int expr5(void);
d35df41eac69 Initial revision
kono
parents:
diff changeset
79 static int expr6(void);
d35df41eac69 Initial revision
kono
parents:
diff changeset
80 static int expr7(void);
d35df41eac69 Initial revision
kono
parents:
diff changeset
81 static int expr8(void);
d35df41eac69 Initial revision
kono
parents:
diff changeset
82 static int expr9(void);
d35df41eac69 Initial revision
kono
parents:
diff changeset
83 static int getfree(int n);
d35df41eac69 Initial revision
kono
parents:
diff changeset
84 static int ndecl0(void);
d35df41eac69 Initial revision
kono
parents:
diff changeset
85 static int ndecl1(void);
d35df41eac69 Initial revision
kono
parents:
diff changeset
86 static int postequ(int s1, int s2);
d35df41eac69 Initial revision
kono
parents:
diff changeset
87 static int sdecl(int s);
176
kono
parents: 174
diff changeset
88 static int edecl();
87
1738f313f98b floating point (at most) done.
kono
parents: 86
diff changeset
89 static int adecl(NMTBL *n);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
90 static void code_decl(NMTBL *n);
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
91 static void copy(NMTBL *nptr, char *s);
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
92 static void decl(void);
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
93 static void docase(void);
316
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
94 static void docomp(int);
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
95 static void dodefault(void);
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
96 static void dodo(void);
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
97 static void dofor(void);
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
98 static void dogoto(void);
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
99 static void doif(void);
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
100 static void dolabel(void);
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
101 static void doreturn(void);
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
102 static void doswitch(void);
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
103 static void dowhile(void);
316
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
104 #if ASM_CODE
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
105 static void doasm();
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
106 #endif
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
107 static void errmsg(void);
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
108 static void fdecl(NMTBL *n);
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
109 static void getstring(void);
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
110 static void init(void);
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
111 static void newfile(void);
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
112 static void reserve(char *s, int d);
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
113 static void reverse(int t1);
59
eeca07d1b1c2 *** empty log message ***
kono
parents: 55
diff changeset
114 static void set_converter(char *s);
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
115 static int escape(void);
316
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
116 static void statement(int);
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
117 static int typename(void);
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
118 static void decl_data_field(int type,NMTBL *n,int offset);
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
119 static int decl_data(int t, NMTBL *n,int offset,int skip);
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
120 static int typeid(int s);
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
121 static int typename(void);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
122
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
123 #if FLOAT_CODE
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
124 static double dsymval;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
125 #endif
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
126 #if LONGLONG_CODE
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
127 static long long lsymval;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
128 #endif
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
129 static int symval;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
130 static char *name;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
131 static unsigned hash;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
132 static int gfree;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
133 static char *sptr;
18
df7fa8cee67b pass -Wall
kono
parents: 16
diff changeset
134
76
fb3fb9e9a462 *** empty log message ***
kono
parents: 75
diff changeset
135 static int sdecl_f = 1;
fb3fb9e9a462 *** empty log message ***
kono
parents: 75
diff changeset
136 static int stypedecl;
178
0f395aa93438 gcc include file
kono
parents: 177
diff changeset
137
109
e09f9de6f5d3 *** empty log message ***
kono
parents: 108
diff changeset
138 static Converter *conv = &null_converter;
82
25654dc29ecc First Floating Point coding done.
kono
parents: 81
diff changeset
139 /* Converter *conv = &c_converter; */
59
eeca07d1b1c2 *** empty log message ***
kono
parents: 55
diff changeset
140
65
8ad746efa4f8 *** empty log message ***
kono
parents: 62
diff changeset
141 static char *ccout = 0;
8ad746efa4f8 *** empty log message ***
kono
parents: 62
diff changeset
142
173
3b33c7daae95 *** empty log message ***
kono
parents: 169
diff changeset
143 #define MAX_INCLUDE_PATH_COUNT 10
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
144 char *include_path[MAX_INCLUDE_PATH_COUNT];
173
3b33c7daae95 *** empty log message ***
kono
parents: 169
diff changeset
145 int include_path_count;
3b33c7daae95 *** empty log message ***
kono
parents: 169
diff changeset
146 extern char *l_include_path[];
3b33c7daae95 *** empty log message ***
kono
parents: 169
diff changeset
147
224
82a55cc6b5fc *** empty log message ***
kono
parents: 223
diff changeset
148 static
82a55cc6b5fc *** empty log message ***
kono
parents: 223
diff changeset
149 char current_file_dir[LBUFSIZE];
82a55cc6b5fc *** empty log message ***
kono
parents: 223
diff changeset
150
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
151 static int ac,ac2;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
152 static char **av;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
153 static int cslist;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
154 static int clabel;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
155 static int ilabel;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
156 static int stat_no;
304
9df8aa0497ea fix line continuation and #macro in string.
kono
parents: 303
diff changeset
157
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
158 static NMTBL mtable[MSYMS];
326
e5d40f8c4cce bit-field continue.
kono
parents: 324
diff changeset
159
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
160 int
d35df41eac69 Initial revision
kono
parents:
diff changeset
161 main(int argc, char **argv)
d35df41eac69 Initial revision
kono
parents:
diff changeset
162 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
163 NMTBL *nptr;
d35df41eac69 Initial revision
kono
parents:
diff changeset
164 int i;
d35df41eac69 Initial revision
kono
parents:
diff changeset
165
d35df41eac69 Initial revision
kono
parents:
diff changeset
166 if(argc==1) exit(1);
d35df41eac69 Initial revision
kono
parents:
diff changeset
167 lsrc = chk = asmf = 0;
d35df41eac69 Initial revision
kono
parents:
diff changeset
168 ac=argc;
d35df41eac69 Initial revision
kono
parents:
diff changeset
169 av=argv;
224
82a55cc6b5fc *** empty log message ***
kono
parents: 223
diff changeset
170 current_file_dir[0] = 0;
82a55cc6b5fc *** empty log message ***
kono
parents: 223
diff changeset
171 include_path[include_path_count++] = current_file_dir;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
172 for (ac2=1; (ac2 < ac) && (*av[ac2] == '-'); ++ac2) {
d35df41eac69 Initial revision
kono
parents:
diff changeset
173 switch (*(av[ac2]+1)) {
59
eeca07d1b1c2 *** empty log message ***
kono
parents: 55
diff changeset
174 case 's':
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
175 lsrc = 1;
d35df41eac69 Initial revision
kono
parents:
diff changeset
176 break;
59
eeca07d1b1c2 *** empty log message ***
kono
parents: 55
diff changeset
177 case 'o':
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
178 ccout = av[ac2]+2;
d35df41eac69 Initial revision
kono
parents:
diff changeset
179 break;
59
eeca07d1b1c2 *** empty log message ***
kono
parents: 55
diff changeset
180 case 'c':
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
181 chk = 1;
d35df41eac69 Initial revision
kono
parents:
diff changeset
182 break;
59
eeca07d1b1c2 *** empty log message ***
kono
parents: 55
diff changeset
183 case 'd':
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
184 debug = 1;
d35df41eac69 Initial revision
kono
parents:
diff changeset
185 break;
195
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
186 case 'D':
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
187 break;
59
eeca07d1b1c2 *** empty log message ***
kono
parents: 55
diff changeset
188 case 'C':
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
189 if (av[ac2+1]) set_converter(av[ac2]+2);
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
190 chk = 1;
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
191 ccout=0;
59
eeca07d1b1c2 *** empty log message ***
kono
parents: 55
diff changeset
192 break;
173
3b33c7daae95 *** empty log message ***
kono
parents: 169
diff changeset
193 case 'I':
3b33c7daae95 *** empty log message ***
kono
parents: 169
diff changeset
194 include_path[include_path_count++] = av[ac2]+2;
3b33c7daae95 *** empty log message ***
kono
parents: 169
diff changeset
195 if (include_path_count<MAX_INCLUDE_PATH_COUNT)
3b33c7daae95 *** empty log message ***
kono
parents: 169
diff changeset
196 break;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
197 default:
d35df41eac69 Initial revision
kono
parents:
diff changeset
198 error(OPTION);
d35df41eac69 Initial revision
kono
parents:
diff changeset
199 exit(1);
d35df41eac69 Initial revision
kono
parents:
diff changeset
200 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
201 }
65
8ad746efa4f8 *** empty log message ***
kono
parents: 62
diff changeset
202 if (!chk && ccout)
18
df7fa8cee67b pass -Wall
kono
parents: 16
diff changeset
203 if ( (freopen(ccout,"w",stdout)) == NULL ) error(FILERR);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
204 init();
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
205 while(1) {
2
kono
parents: 1
diff changeset
206 for (nptr = &ntable[GSYMS],i=LSYMS; i--;) {
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
207 (nptr++)->sc = 0;
2
kono
parents: 1
diff changeset
208 }
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
209 mode=TOP;
d35df41eac69 Initial revision
kono
parents:
diff changeset
210 lfree= HEAPSIZE;
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
211 codegen_decl_init();
275
8f09f8bbc494 MIPS switch statement. basic.c passed.
kono
parents: 273
diff changeset
212 while (chptrsave!=0) {
8f09f8bbc494 MIPS switch statement. basic.c passed.
kono
parents: 273
diff changeset
213 i = cadr(chptrsave); free_glist2(chptrsave); chptrsave = i;
8f09f8bbc494 MIPS switch statement. basic.c passed.
kono
parents: 273
diff changeset
214 }
8f09f8bbc494 MIPS switch statement. basic.c passed.
kono
parents: 273
diff changeset
215 while (chsave!=0) {
8f09f8bbc494 MIPS switch statement. basic.c passed.
kono
parents: 273
diff changeset
216 i = cadr(chsave); free_glist2(chsave); chsave = i;
8f09f8bbc494 MIPS switch statement. basic.c passed.
kono
parents: 273
diff changeset
217 }
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
218 while(getsym(0)==SM) conv->sm_();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
219 mode=GDECL;
d35df41eac69 Initial revision
kono
parents:
diff changeset
220 stmode=0;
d35df41eac69 Initial revision
kono
parents:
diff changeset
221 args=0;
d35df41eac69 Initial revision
kono
parents:
diff changeset
222 decl();
d35df41eac69 Initial revision
kono
parents:
diff changeset
223 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
224 /*NOTREACHED*/
d35df41eac69 Initial revision
kono
parents:
diff changeset
225 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
226
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
227 extern void
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
228 error(int n)
d35df41eac69 Initial revision
kono
parents:
diff changeset
229 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
230 if(n == EOFERR) {
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
231 if(filep!=filestack) {
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
232 fclose(filep->fcb);
d35df41eac69 Initial revision
kono
parents:
diff changeset
233 lineno=filep->ln;
d35df41eac69 Initial revision
kono
parents:
diff changeset
234 --filep;
224
82a55cc6b5fc *** empty log message ***
kono
parents: 223
diff changeset
235 copy_current_file_dir(filep->name0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
236 return;
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
237 } else if(ac2!=ac) {
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
238 fclose(filep->fcb);
d35df41eac69 Initial revision
kono
parents:
diff changeset
239 newfile();
d35df41eac69 Initial revision
kono
parents:
diff changeset
240 return;
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
241 } else if(mode == TOP) {
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
242 if (chk) {
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
243 fprintf(stderr, "Total internal labels : %u.\n",labelno-1);
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
244 fprintf(stderr, "Total global variables: %u bytes.\n",gpc);
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
245 }
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
246 closing();
d35df41eac69 Initial revision
kono
parents:
diff changeset
247 exit(0);
d35df41eac69 Initial revision
kono
parents:
diff changeset
248 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
249 }
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
250 if (conv->error_(n)) return;
25
b7a94557bf92 *** empty log message ***
kono
parents: 23
diff changeset
251 fprintf(stderr,"%s:%d:%s\n",filep->name0,lineno,
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
252 (n==FILERR) ? "Can't open specified file" :
d35df41eac69 Initial revision
kono
parents:
diff changeset
253 (n==DCERR) ? "Declaration syntax" :
304
9df8aa0497ea fix line continuation and #macro in string.
kono
parents: 303
diff changeset
254 (n==RDERR) ? "Redefined" :
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
255 (n==STERR) ? "Statement syntax" :
d35df41eac69 Initial revision
kono
parents:
diff changeset
256 (n==EXERR) ? "Expression syntax" :
d35df41eac69 Initial revision
kono
parents:
diff changeset
257 (n==CNERR) ? "Constant required" :
d35df41eac69 Initial revision
kono
parents:
diff changeset
258 (n==CHERR) ? "Illegal character" :
d35df41eac69 Initial revision
kono
parents:
diff changeset
259 (n==GSERR) ? "Too many global symbols" :
d35df41eac69 Initial revision
kono
parents:
diff changeset
260 (n==LSERR) ? "Too many local symbols" :
29
160e20394f80 macro function (imcomplete)
kono
parents: 28
diff changeset
261 (n==MSERR) ? "Too many macro symbols" :
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
262 (n==STRERR) ? "Too many strings or macros" :
d35df41eac69 Initial revision
kono
parents:
diff changeset
263 (n==LNERR) ? "Line too long" :
d35df41eac69 Initial revision
kono
parents:
diff changeset
264 (n==EOFERR) ? "Unexpected end of file" :
d35df41eac69 Initial revision
kono
parents:
diff changeset
265 (n==MCERR) ? "Macro syntax" :
d35df41eac69 Initial revision
kono
parents:
diff changeset
266 (n==INCERR) ? "Include syntax" :
d35df41eac69 Initial revision
kono
parents:
diff changeset
267 (n==HPERR) ? "Too long expression" :
d35df41eac69 Initial revision
kono
parents:
diff changeset
268 (n==TYERR) ? "Type mismatch" :
d35df41eac69 Initial revision
kono
parents:
diff changeset
269 (n==LVERR) ? "Lvalue required" :
d35df41eac69 Initial revision
kono
parents:
diff changeset
270 (n==UDERR) ? "Undeclared identifier" :
d35df41eac69 Initial revision
kono
parents:
diff changeset
271 (n==OPTION) ? "Illegal option" :
d35df41eac69 Initial revision
kono
parents:
diff changeset
272 (n==REG_ERR) ? "illegal register var" :
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
273 (n==INERR) ? "bad initialization" :
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
274 (n==CODE_ERR) ? "goto code is necessary" :
d35df41eac69 Initial revision
kono
parents:
diff changeset
275 "Bug of compiler");
d35df41eac69 Initial revision
kono
parents:
diff changeset
276 errmsg();
d35df41eac69 Initial revision
kono
parents:
diff changeset
277 exit(1);
d35df41eac69 Initial revision
kono
parents:
diff changeset
278 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
279
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
280 static void
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
281 errmsg(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
282 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
283 char *p,*lim;
d35df41eac69 Initial revision
kono
parents:
diff changeset
284
d35df41eac69 Initial revision
kono
parents:
diff changeset
285 if(lineno==0) return;
d35df41eac69 Initial revision
kono
parents:
diff changeset
286 fprintf(stderr,"%s",linebuf);
29
160e20394f80 macro function (imcomplete)
kono
parents: 28
diff changeset
287 lim=chptr;
115
ebac635814dc fix nested macro function
kono
parents: 114
diff changeset
288 while (chptrsave) {
ebac635814dc fix nested macro function
kono
parents: 114
diff changeset
289 lim = (char*)car(chptrsave);
ebac635814dc fix nested macro function
kono
parents: 114
diff changeset
290 chptrsave = cadr(chptrsave);
29
160e20394f80 macro function (imcomplete)
kono
parents: 28
diff changeset
291 }
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
292 for (p=linebuf; p < lim;)
d35df41eac69 Initial revision
kono
parents:
diff changeset
293 fprintf(stderr,(*p++ == '\t') ? "\t" : " ");
d35df41eac69 Initial revision
kono
parents:
diff changeset
294 fprintf (stderr,"^\n");
d35df41eac69 Initial revision
kono
parents:
diff changeset
295 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
296
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
297 static void
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
298 checksym(int s)
d35df41eac69 Initial revision
kono
parents:
diff changeset
299 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
300 char *p;
d35df41eac69 Initial revision
kono
parents:
diff changeset
301
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
302 if (sym != s) {
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
303 p=(s==RPAR) ? "')'": (s==RBRA) ? "']'": (s==SM) ? "';'":
d35df41eac69 Initial revision
kono
parents:
diff changeset
304 (s==LPAR) ? "'('": (s==WHILE) ? "'while'":
308
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
305 (s==ASS) ? "'='":
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
306 (s==COLON) ? "':'": "Identifier";
d35df41eac69 Initial revision
kono
parents:
diff changeset
307 fprintf(stderr,"%d:%s expected.\n",lineno,p);
d35df41eac69 Initial revision
kono
parents:
diff changeset
308 errmsg();
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
309 } else
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
310 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
311 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
312
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
313 static void
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
314 heap_init()
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
315 {
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
316 gpc=glineno=0;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
317 gfree=ilabel=1;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
318 labelno=2;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
319 lfree=HEAPSIZE;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
320 }
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
321
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
322 static void
181
4beb7f079055 new file
kono
parents: 180
diff changeset
323 reinit(void)
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
324 {
181
4beb7f079055 new file
kono
parents: 180
diff changeset
325 int i;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
326 NMTBL *nptr;
d35df41eac69 Initial revision
kono
parents:
diff changeset
327
d35df41eac69 Initial revision
kono
parents:
diff changeset
328 cheapp=cheap;
d35df41eac69 Initial revision
kono
parents:
diff changeset
329 for(nptr = ntable,i = GSYMS; i--;) (nptr++)->sc = 0;
30
20ed2786a276 still macro
kono
parents: 29
diff changeset
330 for(nptr = mtable,i = MSYMS; i--;) (nptr++)->sc = 0;
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
331
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
332 reserve("int",INT);
d35df41eac69 Initial revision
kono
parents:
diff changeset
333 reserve("void",VOID);
d35df41eac69 Initial revision
kono
parents:
diff changeset
334 reserve("char",CHAR);
20
8d3db5fc8a97 *** empty log message ***
kono
parents: 19
diff changeset
335 reserve("const",KONST);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
336 reserve("struct",STRUCT);
d35df41eac69 Initial revision
kono
parents:
diff changeset
337 reserve("union",UNION);
d35df41eac69 Initial revision
kono
parents:
diff changeset
338 reserve("unsigned",UNSIGNED);
182
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
339 reserve("signed",SIGNED);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
340 reserve("static",STATIC);
d35df41eac69 Initial revision
kono
parents:
diff changeset
341 reserve("goto",GOTO);
d35df41eac69 Initial revision
kono
parents:
diff changeset
342 reserve("return",RETURN);
d35df41eac69 Initial revision
kono
parents:
diff changeset
343 reserve("break",BREAK);
d35df41eac69 Initial revision
kono
parents:
diff changeset
344 reserve("continue",CONTINUE);
d35df41eac69 Initial revision
kono
parents:
diff changeset
345 reserve("if",IF);
d35df41eac69 Initial revision
kono
parents:
diff changeset
346 reserve("else",ELSE);
d35df41eac69 Initial revision
kono
parents:
diff changeset
347 reserve("for",FOR);
d35df41eac69 Initial revision
kono
parents:
diff changeset
348 reserve("do",DO);
d35df41eac69 Initial revision
kono
parents:
diff changeset
349 reserve("while",WHILE);
d35df41eac69 Initial revision
kono
parents:
diff changeset
350 reserve("switch",SWITCH);
d35df41eac69 Initial revision
kono
parents:
diff changeset
351 reserve("case",CASE);
d35df41eac69 Initial revision
kono
parents:
diff changeset
352 reserve("default",DEFAULT);
d35df41eac69 Initial revision
kono
parents:
diff changeset
353 reserve("typedef",TYPEDEF);
d35df41eac69 Initial revision
kono
parents:
diff changeset
354 reserve("sizeof",SIZEOF);
d35df41eac69 Initial revision
kono
parents:
diff changeset
355 reserve("long",LONG);
d35df41eac69 Initial revision
kono
parents:
diff changeset
356 reserve("short",SHORT);
d35df41eac69 Initial revision
kono
parents:
diff changeset
357 reserve("extern",EXTRN);
18
df7fa8cee67b pass -Wall
kono
parents: 16
diff changeset
358 reserve("defined",DEFINED);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
359 reserve("register",REGISTER);
d35df41eac69 Initial revision
kono
parents:
diff changeset
360 reserve("code",CODE);
d35df41eac69 Initial revision
kono
parents:
diff changeset
361 reserve("environment",ENVIRONMENT);
78
8418d4b7caa7 *** empty log message ***
kono
parents: 77
diff changeset
362 reserve("float",FLOAT);
8418d4b7caa7 *** empty log message ***
kono
parents: 77
diff changeset
363 reserve("double",DOUBLE);
173
3b33c7daae95 *** empty log message ***
kono
parents: 169
diff changeset
364 reserve("inline",INLINE);
174
8b0ffe9b933d enum first try
kono
parents: 173
diff changeset
365 reserve("enum",ENUM);
177
352feeae4b0a macro else/ccout
kono
parents: 176
diff changeset
366 reserve("volatile",VOLATILE);
316
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
367 reserve("__volatile__",VOLATILE);
312
a93e619cf772 typeof, MIPS stdarg
kono
parents: 311
diff changeset
368 reserve("typeof",TYPEOF);
324
575481408653 minor fix
kono
parents: 323
diff changeset
369 reserve("__typeof__",TYPEOF);
313
f73b93de216a alloca done for ia32, powerpc, mips
kono
parents: 312
diff changeset
370 reserve("__builtin_alloca",ALLOCA);
316
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
371 #if ASM_CODE
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
372 reserve("asm",ASM);
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
373 reserve("__asm__",ASM);
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
374 #endif
19
b62230ea38f6 ifdef debug
kono
parents: 18
diff changeset
375
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
376 heap_init();
328
7ecb023d29b8 macro/codegen reorganization done.
kono
parents: 327
diff changeset
377 codegen_reinit();
178
0f395aa93438 gcc include file
kono
parents: 177
diff changeset
378 macro_define("__restrict\n");
0f395aa93438 gcc include file
kono
parents: 177
diff changeset
379 macro_define("__micro_c__ 1\n");
115
ebac635814dc fix nested macro function
kono
parents: 114
diff changeset
380 #ifdef __APPLE__
ebac635814dc fix nested macro function
kono
parents: 114
diff changeset
381 macro_define("__APPLE__ 1\n");
ebac635814dc fix nested macro function
kono
parents: 114
diff changeset
382 #endif
ebac635814dc fix nested macro function
kono
parents: 114
diff changeset
383 #ifdef bsd
ebac635814dc fix nested macro function
kono
parents: 114
diff changeset
384 macro_define("bsd 1\n");
ebac635814dc fix nested macro function
kono
parents: 114
diff changeset
385 #endif
195
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
386 for(i=0;av[i]&&av[i][0]=='-'&&av[i][1]=='D';i++) {
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
387 macro_define(av[i]+2);
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
388 }
181
4beb7f079055 new file
kono
parents: 180
diff changeset
389 }
4beb7f079055 new file
kono
parents: 180
diff changeset
390
4beb7f079055 new file
kono
parents: 180
diff changeset
391 static void
4beb7f079055 new file
kono
parents: 180
diff changeset
392 init(void)
4beb7f079055 new file
kono
parents: 180
diff changeset
393 {
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
394 codegen_init();
181
4beb7f079055 new file
kono
parents: 180
diff changeset
395 reinit();
185
427008a06333 comment
kono
parents: 184
diff changeset
396 filep=filestack;
181
4beb7f079055 new file
kono
parents: 180
diff changeset
397 newfile();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
398 getch();
d35df41eac69 Initial revision
kono
parents:
diff changeset
399 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
400
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
401 extern void
224
82a55cc6b5fc *** empty log message ***
kono
parents: 223
diff changeset
402 copy_current_file_dir(char *name)
82a55cc6b5fc *** empty log message ***
kono
parents: 223
diff changeset
403 {
82a55cc6b5fc *** empty log message ***
kono
parents: 223
diff changeset
404 char *s = name;
82a55cc6b5fc *** empty log message ***
kono
parents: 223
diff changeset
405 char *d = current_file_dir;
82a55cc6b5fc *** empty log message ***
kono
parents: 223
diff changeset
406 char *p;
82a55cc6b5fc *** empty log message ***
kono
parents: 223
diff changeset
407 for(p = d;d<current_file_dir+LBUFSIZE && *s; ) {
82a55cc6b5fc *** empty log message ***
kono
parents: 223
diff changeset
408 if (*s=='/') p = d+1;
82a55cc6b5fc *** empty log message ***
kono
parents: 223
diff changeset
409 *d++ = *s++;
82a55cc6b5fc *** empty log message ***
kono
parents: 223
diff changeset
410 }
82a55cc6b5fc *** empty log message ***
kono
parents: 223
diff changeset
411 *p = 0;
82a55cc6b5fc *** empty log message ***
kono
parents: 223
diff changeset
412 }
82a55cc6b5fc *** empty log message ***
kono
parents: 223
diff changeset
413
181
4beb7f079055 new file
kono
parents: 180
diff changeset
414 static int first_newfile = 1;
4beb7f079055 new file
kono
parents: 180
diff changeset
415
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
416 static void
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
417 newfile(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
418 {
25
b7a94557bf92 *** empty log message ***
kono
parents: 23
diff changeset
419 char *s;
177
352feeae4b0a macro else/ccout
kono
parents: 176
diff changeset
420 int flag = 0;
65
8ad746efa4f8 *** empty log message ***
kono
parents: 62
diff changeset
421
181
4beb7f079055 new file
kono
parents: 180
diff changeset
422 if (!first_newfile) {
4beb7f079055 new file
kono
parents: 180
diff changeset
423 closing();
4beb7f079055 new file
kono
parents: 180
diff changeset
424 reinit();
4beb7f079055 new file
kono
parents: 180
diff changeset
425 } else
4beb7f079055 new file
kono
parents: 180
diff changeset
426 first_newfile = 0;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
427 lineno=0;
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
428 if (chk) fprintf(stderr,"%s:\n",av[ac2]);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
429 if ( (filep->fcb = fopen(av[ac2++],"r")) == NULL ) error(FILERR);
25
b7a94557bf92 *** empty log message ***
kono
parents: 23
diff changeset
430 s = av[ac2-1];
224
82a55cc6b5fc *** empty log message ***
kono
parents: 223
diff changeset
431 copy_current_file_dir(s);
25
b7a94557bf92 *** empty log message ***
kono
parents: 23
diff changeset
432 filep->name0 = cheapp;
173
3b33c7daae95 *** empty log message ***
kono
parents: 169
diff changeset
433 filep->inc = 0;
25
b7a94557bf92 *** empty log message ***
kono
parents: 23
diff changeset
434 while((*cheapp++ = *s++));
65
8ad746efa4f8 *** empty log message ***
kono
parents: 62
diff changeset
435 if(!ccout) {
8ad746efa4f8 *** empty log message ***
kono
parents: 62
diff changeset
436 ccout=s=cheapp; s= filep->name0;
8ad746efa4f8 *** empty log message ***
kono
parents: 62
diff changeset
437 while((*cheapp++ = *s++)) {
8ad746efa4f8 *** empty log message ***
kono
parents: 62
diff changeset
438 if(s[0]=='.'&&s[1]=='c') {
8ad746efa4f8 *** empty log message ***
kono
parents: 62
diff changeset
439 *cheapp++=*s++; *cheapp++=*s++;
8ad746efa4f8 *** empty log message ***
kono
parents: 62
diff changeset
440 cheapp[-1]='s';
177
352feeae4b0a macro else/ccout
kono
parents: 176
diff changeset
441 flag =1;
65
8ad746efa4f8 *** empty log message ***
kono
parents: 62
diff changeset
442 }
8ad746efa4f8 *** empty log message ***
kono
parents: 62
diff changeset
443 }
177
352feeae4b0a macro else/ccout
kono
parents: 176
diff changeset
444 if (flag) {
352feeae4b0a macro else/ccout
kono
parents: 176
diff changeset
445 if ( (freopen(ccout,"w",stdout)) == NULL ) error(FILERR);
352feeae4b0a macro else/ccout
kono
parents: 176
diff changeset
446 } else {
352feeae4b0a macro else/ccout
kono
parents: 176
diff changeset
447 if ( (freopen("mcout.s","w",stdout)) == NULL ) error(FILERR);
352feeae4b0a macro else/ccout
kono
parents: 176
diff changeset
448 }
65
8ad746efa4f8 *** empty log message ***
kono
parents: 62
diff changeset
449 cheapp=ccout;
8ad746efa4f8 *** empty log message ***
kono
parents: 62
diff changeset
450 ccout=0;
8ad746efa4f8 *** empty log message ***
kono
parents: 62
diff changeset
451 }
8ad746efa4f8 *** empty log message ***
kono
parents: 62
diff changeset
452 opening(filep->name0);
67
254a0c576114 argument type list
kono
parents: 66
diff changeset
453 conv->open_(filep->name0);
304
9df8aa0497ea fix line continuation and #macro in string.
kono
parents: 303
diff changeset
454
9df8aa0497ea fix line continuation and #macro in string.
kono
parents: 303
diff changeset
455 if (init_src) {
9df8aa0497ea fix line continuation and #macro in string.
kono
parents: 303
diff changeset
456 // before reading any file, perform initialization source
9df8aa0497ea fix line continuation and #macro in string.
kono
parents: 303
diff changeset
457 chinput = init_src;
9df8aa0497ea fix line continuation and #macro in string.
kono
parents: 303
diff changeset
458 }
9df8aa0497ea fix line continuation and #macro in string.
kono
parents: 303
diff changeset
459 getline();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
460 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
461
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
462 static void
59
eeca07d1b1c2 *** empty log message ***
kono
parents: 55
diff changeset
463 set_converter(char *s)
eeca07d1b1c2 *** empty log message ***
kono
parents: 55
diff changeset
464 {
eeca07d1b1c2 *** empty log message ***
kono
parents: 55
diff changeset
465 chptr = s;
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
466 #if 0
59
eeca07d1b1c2 *** empty log message ***
kono
parents: 55
diff changeset
467 if (macroeq("c2cbc")) conv=&c2cbc_converter;
eeca07d1b1c2 *** empty log message ***
kono
parents: 55
diff changeset
468 else if (macroeq("cbc2c")) conv=&cbc2c_converter;
eeca07d1b1c2 *** empty log message ***
kono
parents: 55
diff changeset
469 else if (macroeq("c")) conv=&c_converter;
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
470 #else
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
471 if (macroeq("c")) conv=&c_converter;
82
25654dc29ecc First Floating Point coding done.
kono
parents: 81
diff changeset
472 else conv=&null_converter;
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
473 #endif
59
eeca07d1b1c2 *** empty log message ***
kono
parents: 55
diff changeset
474 }
eeca07d1b1c2 *** empty log message ***
kono
parents: 55
diff changeset
475
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
476 static void
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
477 reserve(char *s, int d)
d35df41eac69 Initial revision
kono
parents:
diff changeset
478 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
479 NMTBL *nptr;
d35df41eac69 Initial revision
kono
parents:
diff changeset
480 int i;
d35df41eac69 Initial revision
kono
parents:
diff changeset
481
d35df41eac69 Initial revision
kono
parents:
diff changeset
482 hash=0; name=namebuf; i=0;
d35df41eac69 Initial revision
kono
parents:
diff changeset
483 while((name[i++] = *s)) {
116
b14ff9671c90 register offset fix
kono
parents: 115
diff changeset
484 hash=(((7*hash)&0xfffffff) ^ *s++);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
485 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
486 if (cheapp+i >= cheap+CHEAPSIZE) error(STRERR);
d35df41eac69 Initial revision
kono
parents:
diff changeset
487 name[i++] = 0;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
488 (nptr = gsearch(0))->sc = RESERVE;
19
b62230ea38f6 ifdef debug
kono
parents: 18
diff changeset
489 if (d==0) {
b62230ea38f6 ifdef debug
kono
parents: 18
diff changeset
490 nptr->sc = MACRO;
29
160e20394f80 macro function (imcomplete)
kono
parents: 28
diff changeset
491 nptr->dsp = (int)""; nptr->ty=0;
19
b62230ea38f6 ifdef debug
kono
parents: 18
diff changeset
492 } else {
b62230ea38f6 ifdef debug
kono
parents: 18
diff changeset
493 nptr->dsp = d;
b62230ea38f6 ifdef debug
kono
parents: 18
diff changeset
494 }
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
495 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
496
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
497 static void
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
498 storage_class()
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
499 {
177
352feeae4b0a macro else/ccout
kono
parents: 176
diff changeset
500 if(sym==VOLATILE) {
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
501 getsym(0);
177
352feeae4b0a macro else/ccout
kono
parents: 176
diff changeset
502 }
160
1f440a2790fb *** empty log message ***
kono
parents: 156
diff changeset
503 if(sym==STATIC) {
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
504 if(mode==LDECL) {
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
505 getsym(0);
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
506 conv->static_();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
507 mode=STADECL;
d35df41eac69 Initial revision
kono
parents:
diff changeset
508 stmode=LDECL;
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
509 } else if(mode==GDECL) {
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
510 getsym(0);
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
511 conv->static_();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
512 stmode=STATIC;
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
513 } else
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
514 error(DCERR);
d35df41eac69 Initial revision
kono
parents:
diff changeset
515 } else if(sym==REGISTER) {
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
516 if(mode!=LDECL)
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
517 error(DCERR);
d35df41eac69 Initial revision
kono
parents:
diff changeset
518 stmode=REGISTER;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
519 getsym(0);
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
520 conv->register_();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
521 } else if(sym==EXTRN) {
186
6391432ca002 nkf binary fix
kono
parents: 185
diff changeset
522 if(mode==LDECL) {
6391432ca002 nkf binary fix
kono
parents: 185
diff changeset
523 getsym(0);
6391432ca002 nkf binary fix
kono
parents: 185
diff changeset
524 conv->static_();
6391432ca002 nkf binary fix
kono
parents: 185
diff changeset
525 mode=GDECL;
6391432ca002 nkf binary fix
kono
parents: 185
diff changeset
526 stmode=EXTRN;
6391432ca002 nkf binary fix
kono
parents: 185
diff changeset
527 } else if(mode==GDECL) {
6391432ca002 nkf binary fix
kono
parents: 185
diff changeset
528 getsym(0);
6391432ca002 nkf binary fix
kono
parents: 185
diff changeset
529 conv->extern_();
6391432ca002 nkf binary fix
kono
parents: 185
diff changeset
530 stmode=EXTRN;
6391432ca002 nkf binary fix
kono
parents: 185
diff changeset
531 } else
6391432ca002 nkf binary fix
kono
parents: 185
diff changeset
532 error(DCERR);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
533 } else if(sym==TYPEDEF) {
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
534 if(mode==GDECL) {
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
535 getsym(0);
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
536 conv->typedef_();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
537 mode=GTDECL;
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
538 } else if(mode==LDECL) {
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
539 getsym(0);
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
540 conv->typedef_();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
541 mode=LTDECL;
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
542 } else
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
543 error(DCERR);
d35df41eac69 Initial revision
kono
parents:
diff changeset
544 }
160
1f440a2790fb *** empty log message ***
kono
parents: 156
diff changeset
545 }
1f440a2790fb *** empty log message ***
kono
parents: 156
diff changeset
546
1f440a2790fb *** empty log message ***
kono
parents: 156
diff changeset
547 static void
1f440a2790fb *** empty log message ***
kono
parents: 156
diff changeset
548 decl(void)
1f440a2790fb *** empty log message ***
kono
parents: 156
diff changeset
549 {
1f440a2790fb *** empty log message ***
kono
parents: 156
diff changeset
550 NMTBL *n;
1f440a2790fb *** empty log message ***
kono
parents: 156
diff changeset
551 int t,sd;
1f440a2790fb *** empty log message ***
kono
parents: 156
diff changeset
552 if (mode==GDECL) { typedefed=0; }
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
553 storage_class();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
554 if((t=typespec())==0) return;
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
555 if(sym==SM) {
72
3b5d293cea36 type def etc
kono
parents: 71
diff changeset
556 conv->return_type_(t,0,stypedecl);
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
557 conv->sm_(); return;
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
558 }
76
fb3fb9e9a462 *** empty log message ***
kono
parents: 75
diff changeset
559 type=t;sd=stypedecl;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
560 n=decl0();
d35df41eac69 Initial revision
kono
parents:
diff changeset
561 reverse(t);
d35df41eac69 Initial revision
kono
parents:
diff changeset
562 if (n == &null_nptr) {
331
f25aa4f03198 bit-field continue...
kono
parents: 329
diff changeset
563 /* only bit field allows null identifier */
f25aa4f03198 bit-field continue...
kono
parents: 329
diff changeset
564 if (!(type>0&&car(type)==BIT_FIELD))
f25aa4f03198 bit-field continue...
kono
parents: 329
diff changeset
565 error(DCERR);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
566 return;
d35df41eac69 Initial revision
kono
parents:
diff changeset
567 }
331
f25aa4f03198 bit-field continue...
kono
parents: 329
diff changeset
568 if(sym==LC || ( sym!=SM && sym!=COMMA && sym!=ASS)) {
321
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
569 if (mode!=GDECL) error(DCERR);
76
fb3fb9e9a462 *** empty log message ***
kono
parents: 75
diff changeset
570 stypedecl=sd;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
571 if (car(type)==CODE) {
d35df41eac69 Initial revision
kono
parents:
diff changeset
572 code_decl(n); return;
d35df41eac69 Initial revision
kono
parents:
diff changeset
573 } else if (car(type)==FUNCTION) {
d35df41eac69 Initial revision
kono
parents:
diff changeset
574 fdecl(n); return;
178
0f395aa93438 gcc include file
kono
parents: 177
diff changeset
575 } else error(DCERR);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
576 }
75
92dcf107a837 c code output
kono
parents: 72
diff changeset
577 conv->return_type_(type,n,sd);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
578 def(n);
331
f25aa4f03198 bit-field continue...
kono
parents: 329
diff changeset
579 if (sym==ASS && n!=&null_nptr) { decl_data(type,n,0,0); data_closing(n); }
328
7ecb023d29b8 macro/codegen reorganization done.
kono
parents: 327
diff changeset
580
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
581 while(sym==COMMA) {
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
582 conv->comma_();
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
583 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
584 type=t;
d35df41eac69 Initial revision
kono
parents:
diff changeset
585 n=decl0();
d35df41eac69 Initial revision
kono
parents:
diff changeset
586 reverse(t);
331
f25aa4f03198 bit-field continue...
kono
parents: 329
diff changeset
587 if(n == &null_nptr) {
f25aa4f03198 bit-field continue...
kono
parents: 329
diff changeset
588 if (!(type>0&&car(type)==BIT_FIELD))
f25aa4f03198 bit-field continue...
kono
parents: 329
diff changeset
589 error(DCERR);
f25aa4f03198 bit-field continue...
kono
parents: 329
diff changeset
590 }
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
591 conv->return_type_(type,n,1);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
592 def(n);
331
f25aa4f03198 bit-field continue...
kono
parents: 329
diff changeset
593 if (sym==ASS && n!=&null_nptr) {decl_data(type,n,0,0);data_closing(n);}
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
594 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
595 if(sym!=SM) error(DCERR);
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
596 conv->sm_();
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
597 if(mode==GTDECL)
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
598 mode=GDECL;
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
599 if(mode==STADECL||mode==LTDECL)
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
600 mode=LDECL;
d35df41eac69 Initial revision
kono
parents:
diff changeset
601 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
602
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
603 extern int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
604 typespec(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
605 {
127
eb4d8975926c Intel float fix
kono
parents: 126
diff changeset
606 int t = INT;
312
a93e619cf772 typeof, MIPS stdarg
kono
parents: 311
diff changeset
607 int slfree;
72
3b5d293cea36 type def etc
kono
parents: 71
diff changeset
608 stypedecl = 0;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
609
20
8d3db5fc8a97 *** empty log message ***
kono
parents: 19
diff changeset
610 while (sym==KONST) {
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
611 getsym(0);
20
8d3db5fc8a97 *** empty log message ***
kono
parents: 19
diff changeset
612 }
173
3b33c7daae95 *** empty log message ***
kono
parents: 169
diff changeset
613 if (sym==INLINE) {
312
a93e619cf772 typeof, MIPS stdarg
kono
parents: 311
diff changeset
614 getsym(0); // should be static?
173
3b33c7daae95 *** empty log message ***
kono
parents: 169
diff changeset
615 }
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
616 switch(sym) {
d35df41eac69 Initial revision
kono
parents:
diff changeset
617 case VOID:
d35df41eac69 Initial revision
kono
parents:
diff changeset
618 case INT:
d35df41eac69 Initial revision
kono
parents:
diff changeset
619 case CHAR:
d35df41eac69 Initial revision
kono
parents:
diff changeset
620 case CODE:
78
8418d4b7caa7 *** empty log message ***
kono
parents: 77
diff changeset
621 case FLOAT:
8418d4b7caa7 *** empty log message ***
kono
parents: 77
diff changeset
622 case DOUBLE:
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
623 t= sym;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
624 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
625 break;
174
8b0ffe9b933d enum first try
kono
parents: 173
diff changeset
626 case ENUM:
178
0f395aa93438 gcc include file
kono
parents: 177
diff changeset
627 t = edecl();
174
8b0ffe9b933d enum first try
kono
parents: 173
diff changeset
628 break;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
629 case STRUCT:
d35df41eac69 Initial revision
kono
parents:
diff changeset
630 case UNION:
d35df41eac69 Initial revision
kono
parents:
diff changeset
631 t=sdecl(sym);
d35df41eac69 Initial revision
kono
parents:
diff changeset
632 break;
182
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
633 case SIGNED:
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
634 t = INT;
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
635 if(getsym(0)==INT) getsym(0);
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
636 else if (sym==CHAR) { getsym(0); t = CHAR; }
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
637 else if (sym==SHORT) {
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
638 t = SHORT;
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
639 if(getsym(0)==INT) getsym(0);
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
640 } else if (sym==LONG) {
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
641 getsym(0);
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
642 t = INT;
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
643 if(sym==LONG) {
183
1d80ad165831 recursive macros
kono
parents: 182
diff changeset
644 if(getsym(0)==INT) getsym(0);
182
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
645 t=LONGLONG;
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
646 } else if(sym==INT) {
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
647 getsym(0);
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
648 t=INT;
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
649 }
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
650 }
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
651 break;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
652 case UNSIGNED:
d35df41eac69 Initial revision
kono
parents:
diff changeset
653 t = UNSIGNED;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
654 if(getsym(0)==INT) getsym(0);
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
655 else if (sym==CHAR) { getsym(0); t = UCHAR; }
182
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
656 else if (sym==SHORT) {
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
657 t = USHORT;
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
658 if(getsym(0)==INT) getsym(0);
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
659 } else if (sym==LONG) {
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
660 getsym(0);
177
352feeae4b0a macro else/ccout
kono
parents: 176
diff changeset
661 t = UNSIGNED;
173
3b33c7daae95 *** empty log message ***
kono
parents: 169
diff changeset
662 if(sym==LONG) {
183
1d80ad165831 recursive macros
kono
parents: 182
diff changeset
663 if(getsym(0)==INT) getsym(0);
178
0f395aa93438 gcc include file
kono
parents: 177
diff changeset
664 t=ULONGLONG;
173
3b33c7daae95 *** empty log message ***
kono
parents: 169
diff changeset
665 } else if(sym==INT) {
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
666 getsym(0);
173
3b33c7daae95 *** empty log message ***
kono
parents: 169
diff changeset
667 t=UNSIGNED;
3b33c7daae95 *** empty log message ***
kono
parents: 169
diff changeset
668 }
3b33c7daae95 *** empty log message ***
kono
parents: 169
diff changeset
669 }
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
670 break;
d35df41eac69 Initial revision
kono
parents:
diff changeset
671 case SHORT:
166
9e55cc5551fb *** empty log message ***
kono
parents: 165
diff changeset
672 t=SHORT;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
673 if(getsym(0)==INT) getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
674 break;
d35df41eac69 Initial revision
kono
parents:
diff changeset
675 case LONG:
d35df41eac69 Initial revision
kono
parents:
diff changeset
676 t=INT;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
677 getsym(0);
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
678 if(sym==LONG) {
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
679 getsym(0);
178
0f395aa93438 gcc include file
kono
parents: 177
diff changeset
680 t=LONGLONG;
233
2208a18f3799 *** empty log message ***
kono
parents: 231
diff changeset
681 if (sym==INT) getsym(0);
2208a18f3799 *** empty log message ***
kono
parents: 231
diff changeset
682 else if (sym==UNSIGNED) { t=ULONGLONG; getsym(0); break; }
178
0f395aa93438 gcc include file
kono
parents: 177
diff changeset
683 } else if(sym==DOUBLE) {
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
684 getsym(0);
178
0f395aa93438 gcc include file
kono
parents: 177
diff changeset
685 t=DOUBLE;
233
2208a18f3799 *** empty log message ***
kono
parents: 231
diff changeset
686 } else if(sym==INT) { getsym(0);
2208a18f3799 *** empty log message ***
kono
parents: 231
diff changeset
687 } else if(sym==UNSIGNED) { t=UNSIGNED; getsym(0); }
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
688 break;
312
a93e619cf772 typeof, MIPS stdarg
kono
parents: 311
diff changeset
689 case TYPEOF:
a93e619cf772 typeof, MIPS stdarg
kono
parents: 311
diff changeset
690 getsym(0);
a93e619cf772 typeof, MIPS stdarg
kono
parents: 311
diff changeset
691 checksym(LPAR);
a93e619cf772 typeof, MIPS stdarg
kono
parents: 311
diff changeset
692 slfree=lfree;
a93e619cf772 typeof, MIPS stdarg
kono
parents: 311
diff changeset
693 expr(0); type=t;
a93e619cf772 typeof, MIPS stdarg
kono
parents: 311
diff changeset
694 lfree=slfree;
a93e619cf772 typeof, MIPS stdarg
kono
parents: 311
diff changeset
695 checksym(RPAR);
a93e619cf772 typeof, MIPS stdarg
kono
parents: 311
diff changeset
696 return t;
a93e619cf772 typeof, MIPS stdarg
kono
parents: 311
diff changeset
697 break;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
698 default:
d35df41eac69 Initial revision
kono
parents:
diff changeset
699 if(sym==IDENT) {
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
700 if(nptr->sc==TYPE) {
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
701 t=nptr->ty;
72
3b5d293cea36 type def etc
kono
parents: 71
diff changeset
702 typedefed=glist2((int)nptr,typedefed);
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
703 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
704 break;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
705 } else if(nptr->sc==EMPTY && gnptr->sc==TYPE) {
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
706 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
707 break;
d35df41eac69 Initial revision
kono
parents:
diff changeset
708 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
709 }
20
8d3db5fc8a97 *** empty log message ***
kono
parents: 19
diff changeset
710 while (sym==KONST) {
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
711 getsym(0);
20
8d3db5fc8a97 *** empty log message ***
kono
parents: 19
diff changeset
712 }
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
713 if(mode==LDECL) return 0;
d35df41eac69 Initial revision
kono
parents:
diff changeset
714 t= INT;
d35df41eac69 Initial revision
kono
parents:
diff changeset
715 }
20
8d3db5fc8a97 *** empty log message ***
kono
parents: 19
diff changeset
716 while (sym==KONST) {
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
717 getsym(0);
20
8d3db5fc8a97 *** empty log message ***
kono
parents: 19
diff changeset
718 }
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
719 return t;
d35df41eac69 Initial revision
kono
parents:
diff changeset
720 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
721
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
722 static struct nametable *
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
723 decl0(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
724 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
725 NMTBL *n;
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
726 if(sym==MUL) {
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
727 getsym(0);
183
1d80ad165831 recursive macros
kono
parents: 182
diff changeset
728 while (sym==KONST) {
1d80ad165831 recursive macros
kono
parents: 182
diff changeset
729 getsym(0);
1d80ad165831 recursive macros
kono
parents: 182
diff changeset
730 }
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
731 n=decl0();
d35df41eac69 Initial revision
kono
parents:
diff changeset
732 type=list2(POINTER,type);
d35df41eac69 Initial revision
kono
parents:
diff changeset
733 return n;
d35df41eac69 Initial revision
kono
parents:
diff changeset
734 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
735 return decl1();
d35df41eac69 Initial revision
kono
parents:
diff changeset
736 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
737
d35df41eac69 Initial revision
kono
parents:
diff changeset
738
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
739 static NMTBL *
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
740 decl1(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
741 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
742 NMTBL *n;
203
28baf6cd9ad1 *** empty log message ***
kono
parents: 202
diff changeset
743 int i,array_type,arg;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
744
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
745 if(sym==LPAR) {
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
746 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
747 n=decl0();
d35df41eac69 Initial revision
kono
parents:
diff changeset
748 checksym(RPAR);
313
f73b93de216a alloca done for ia32, powerpc, mips
kono
parents: 312
diff changeset
749 } else if (sym == IDENT||sym==ALLOCA) {
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
750 n=nptr;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
751 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
752 } else {
d35df41eac69 Initial revision
kono
parents:
diff changeset
753 /* error(DCERR); */
d35df41eac69 Initial revision
kono
parents:
diff changeset
754 n= &null_nptr;
d35df41eac69 Initial revision
kono
parents:
diff changeset
755 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
756 while(1) {
185
427008a06333 comment
kono
parents: 184
diff changeset
757 if(sym==LBRA) { /* array */
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
758 if(getsym(0)==RBRA) {
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
759 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
760 if(mode==ADECL) {
d35df41eac69 Initial revision
kono
parents:
diff changeset
761 type=list2(POINTER,type);
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
762 } else if (mode==GDECL || stmode==EXTRN) {
79
82d0e30f61dd *** empty log message ***
kono
parents: 78
diff changeset
763 type=list3(ARRAY,type,0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
764 } else {
d35df41eac69 Initial revision
kono
parents:
diff changeset
765 error(DCERR);
d35df41eac69 Initial revision
kono
parents:
diff changeset
766 }
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
767 } else {
203
28baf6cd9ad1 *** empty log message ***
kono
parents: 202
diff changeset
768 array_type=type;
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
769 i=cexpr(expr(1));
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
770 checksym(RBRA);
203
28baf6cd9ad1 *** empty log message ***
kono
parents: 202
diff changeset
771 type=list3(ARRAY,array_type,i);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
772 }
185
427008a06333 comment
kono
parents: 184
diff changeset
773 } else if(sym==LPAR) { /* function or code segment */
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
774 if(mode==GDECL) {
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
775 mode=ADECL;getsym(0);mode=GDECL; /* ??? */
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
776 } else
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
777 getsym(0);
77
2b8ba655e572 fix arg type
kono
parents: 76
diff changeset
778 n->dsp=0;
111
7aa449aff3e6 floating point
kono
parents: 109
diff changeset
779 if(stmode==EXTRN) n->sc=EXTRN;
185
427008a06333 comment
kono
parents: 184
diff changeset
780 else if(stmode==STATIC) n->sc=STATIC;
77
2b8ba655e572 fix arg type
kono
parents: 76
diff changeset
781 if (type==CODE) {
87
1738f313f98b floating point (at most) done.
kono
parents: 86
diff changeset
782 n->ty=CODE;
77
2b8ba655e572 fix arg type
kono
parents: 76
diff changeset
783 if(sym==RPAR) {
203
28baf6cd9ad1 *** empty log message ***
kono
parents: 202
diff changeset
784 getsym(0);arg=0;
77
2b8ba655e572 fix arg type
kono
parents: 76
diff changeset
785 } else {
203
28baf6cd9ad1 *** empty log message ***
kono
parents: 202
diff changeset
786 arg=adecl(n);
77
2b8ba655e572 fix arg type
kono
parents: 76
diff changeset
787 }
203
28baf6cd9ad1 *** empty log message ***
kono
parents: 202
diff changeset
788 type=glist3(CODE,CODE,arg);
77
2b8ba655e572 fix arg type
kono
parents: 76
diff changeset
789 } else {
2b8ba655e572 fix arg type
kono
parents: 76
diff changeset
790 if(sym==RPAR) {
203
28baf6cd9ad1 *** empty log message ***
kono
parents: 202
diff changeset
791 getsym(0);arg=0;
103
f849af4b5ea9 *** empty log message ***
kono
parents: 102
diff changeset
792 } else {
203
28baf6cd9ad1 *** empty log message ***
kono
parents: 202
diff changeset
793 arg=adecl(n);
103
f849af4b5ea9 *** empty log message ***
kono
parents: 102
diff changeset
794 }
203
28baf6cd9ad1 *** empty log message ***
kono
parents: 202
diff changeset
795 type=glist3(FUNCTION,type,arg);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
796 }
185
427008a06333 comment
kono
parents: 184
diff changeset
797 /* Do not set n->ty here. It could be K&R style arguments or
427008a06333 comment
kono
parents: 184
diff changeset
798 struct field names */
427008a06333 comment
kono
parents: 184
diff changeset
799 /* in GDECL n->dsp contains real parameter, if not,
87
1738f313f98b floating point (at most) done.
kono
parents: 86
diff changeset
800 it contains arg type list. Real parameter list is compatible
1738f313f98b floating point (at most) done.
kono
parents: 86
diff changeset
801 with arg type list. See def/ADECL */
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
802 if (mode!=GDECL)
203
28baf6cd9ad1 *** empty log message ***
kono
parents: 202
diff changeset
803 n->dsp=arg;
331
f25aa4f03198 bit-field continue...
kono
parents: 329
diff changeset
804 } else if(sym==COLON) { /* bit-field */
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
805 if (mode==GSDECL||mode==GUDECL||mode==LSDECL||mode==LUDECL) {
326
e5d40f8c4cce bit-field continue.
kono
parents: 324
diff changeset
806 if (scalar(type) || type==LONGLONG || type==ULONGLONG) {
e5d40f8c4cce bit-field continue.
kono
parents: 324
diff changeset
807 getsym(0);
332
ce85d6106119 bit field continue. (code generation done)
kono
parents: 331
diff changeset
808 type = list4(BIT_FIELD,type,0 /* bit offset */,symval);
331
f25aa4f03198 bit-field continue...
kono
parents: 329
diff changeset
809 getsym(0);
326
e5d40f8c4cce bit-field continue.
kono
parents: 324
diff changeset
810 }
331
f25aa4f03198 bit-field continue...
kono
parents: 329
diff changeset
811 } else
f25aa4f03198 bit-field continue...
kono
parents: 329
diff changeset
812 error(DCERR);
326
e5d40f8c4cce bit-field continue.
kono
parents: 324
diff changeset
813 return n;
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
814 } else
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
815 return n;
d35df41eac69 Initial revision
kono
parents:
diff changeset
816 }
77
2b8ba655e572 fix arg type
kono
parents: 76
diff changeset
817 /* NOT REACHED */
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
818 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
819
d35df41eac69 Initial revision
kono
parents:
diff changeset
820
87
1738f313f98b floating point (at most) done.
kono
parents: 86
diff changeset
821 static int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
822 adecl(NMTBL *n)
d35df41eac69 Initial revision
kono
parents:
diff changeset
823 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
824 NMTBL *arg,*sfnptr;
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
825 int t;
161
cc2fc5c0dfe5 struct field fix
kono
parents: 160
diff changeset
826 int stype,smode,sd,sargs,sstmode;
87
1738f313f98b floating point (at most) done.
kono
parents: 86
diff changeset
827 int argtypes;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
828
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
829 sstmode=stmode; stmode=REGISTER; /* nobody use this? */
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
830 stype=type;
d35df41eac69 Initial revision
kono
parents:
diff changeset
831 sfnptr=fnptr;
d35df41eac69 Initial revision
kono
parents:
diff changeset
832 fnptr=n;
76
fb3fb9e9a462 *** empty log message ***
kono
parents: 75
diff changeset
833 sd = sdecl_f;
fb3fb9e9a462 *** empty log message ***
kono
parents: 75
diff changeset
834 sdecl_f = 0;
87
1738f313f98b floating point (at most) done.
kono
parents: 86
diff changeset
835 argtypes = 0;
16
ca0bce3b4810 struct copy
kono
parents: 14
diff changeset
836 smode = mode;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
837 mode=ADECL;
46
b1c8ac8c308d fix cascading struct retrun. Now it should be compatible with gcc
kono
parents: 45
diff changeset
838 args = 0;
67
254a0c576114 argument type list
kono
parents: 66
diff changeset
839 n->dsp=0;
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
840 for(;;) {
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
841 if(sym==IDENT && nptr->sc!=TYPE) {
76
fb3fb9e9a462 *** empty log message ***
kono
parents: 75
diff changeset
842 type=INT; /* naked argument, old K&R C */
46
b1c8ac8c308d fix cascading struct retrun. Now it should be compatible with gcc
kono
parents: 45
diff changeset
843 def(nptr);
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
844 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
845 if(sym==RPAR) break;
d35df41eac69 Initial revision
kono
parents:
diff changeset
846 } else {
d35df41eac69 Initial revision
kono
parents:
diff changeset
847 if(sym==DOTS) {
87
1738f313f98b floating point (at most) done.
kono
parents: 86
diff changeset
848 argtypes=list2(DOTS,argtypes);
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
849 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
850 break;
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
851 }
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
852 if((t=typespec())==0) {
d35df41eac69 Initial revision
kono
parents:
diff changeset
853 error(DCERR);
d35df41eac69 Initial revision
kono
parents:
diff changeset
854 break;
d35df41eac69 Initial revision
kono
parents:
diff changeset
855 }
115
ebac635814dc fix nested macro function
kono
parents: 114
diff changeset
856 type=t;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
857 if(sym!=COMMA && sym!=RPAR) {
79
82d0e30f61dd *** empty log message ***
kono
parents: 78
diff changeset
858 sargs = args;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
859 arg=decl0();
79
82d0e30f61dd *** empty log message ***
kono
parents: 78
diff changeset
860 args = sargs;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
861 reverse(t);
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
862 if (arg != &null_nptr) {
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
863 if (smode==GDECL)
67
254a0c576114 argument type list
kono
parents: 66
diff changeset
864 def(arg);
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
865 }
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
866 }
114
e6cb1e293b35 float/int passed.
kono
parents: 111
diff changeset
867 argtypes=list2(type,argtypes);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
868 if(sym==RPAR) break;
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
869 }
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
870 if (sym!=COMMA) error(DCERR);
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
871 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
872 }
87
1738f313f98b floating point (at most) done.
kono
parents: 86
diff changeset
873 argtypes=reverse0(argtypes);
67
254a0c576114 argument type list
kono
parents: 66
diff changeset
874 n->dsp=reverse0(n->dsp);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
875 checksym(RPAR);
16
ca0bce3b4810 struct copy
kono
parents: 14
diff changeset
876 mode=smode;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
877 fnptr=sfnptr;
d35df41eac69 Initial revision
kono
parents:
diff changeset
878 type=stype;
76
fb3fb9e9a462 *** empty log message ***
kono
parents: 75
diff changeset
879 sdecl_f = sd;
161
cc2fc5c0dfe5 struct field fix
kono
parents: 160
diff changeset
880 stmode=sstmode;
87
1738f313f98b floating point (at most) done.
kono
parents: 86
diff changeset
881 return argtypes;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
882 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
883
185
427008a06333 comment
kono
parents: 184
diff changeset
884 /* reverse modifies type also */
427008a06333 comment
kono
parents: 184
diff changeset
885
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
886 static void
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
887 reverse(int t1)
d35df41eac69 Initial revision
kono
parents:
diff changeset
888 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
889 int t2,t3;
d35df41eac69 Initial revision
kono
parents:
diff changeset
890 t2=t1;
d35df41eac69 Initial revision
kono
parents:
diff changeset
891
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
892 while(type!=t1) {
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
893 t3=cadr(type);
188
4303255fc3cf minor fix
kono
parents: 187
diff changeset
894 cadr(type) = t2;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
895 t2=type;
d35df41eac69 Initial revision
kono
parents:
diff changeset
896 type=t3;
d35df41eac69 Initial revision
kono
parents:
diff changeset
897 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
898 type = t2;
d35df41eac69 Initial revision
kono
parents:
diff changeset
899 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
900
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
901 int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
902 reverse0(int t1)
d35df41eac69 Initial revision
kono
parents:
diff changeset
903 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
904 int t2,t3;
d35df41eac69 Initial revision
kono
parents:
diff changeset
905
d35df41eac69 Initial revision
kono
parents:
diff changeset
906 t2=0;
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
907 while(t1) {
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
908 t3=cadr(t1);
188
4303255fc3cf minor fix
kono
parents: 187
diff changeset
909 cadr(t1) = t2;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
910 t2=t1;
d35df41eac69 Initial revision
kono
parents:
diff changeset
911 t1=t3;
d35df41eac69 Initial revision
kono
parents:
diff changeset
912 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
913 return t2;
d35df41eac69 Initial revision
kono
parents:
diff changeset
914 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
915
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
916 extern int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
917 size(int t)
d35df41eac69 Initial revision
kono
parents:
diff changeset
918 {
166
9e55cc5551fb *** empty log message ***
kono
parents: 165
diff changeset
919 if (t<0) {
9e55cc5551fb *** empty log message ***
kono
parents: 165
diff changeset
920 if(t==CHAR) return 1;
9e55cc5551fb *** empty log message ***
kono
parents: 165
diff changeset
921 if(t==UCHAR) return 1;
9e55cc5551fb *** empty log message ***
kono
parents: 165
diff changeset
922 if(t==VOID) return 0;
9e55cc5551fb *** empty log message ***
kono
parents: 165
diff changeset
923 if(t==SHORT) return size_of_short;
9e55cc5551fb *** empty log message ***
kono
parents: 165
diff changeset
924 if(t==USHORT) return size_of_short;
9e55cc5551fb *** empty log message ***
kono
parents: 165
diff changeset
925 if(t==REGISTER) return size_of_int;
9e55cc5551fb *** empty log message ***
kono
parents: 165
diff changeset
926 if(t==DREGISTER) return size_of_double;
9e55cc5551fb *** empty log message ***
kono
parents: 165
diff changeset
927 if(t==FREGISTER) return size_of_float;
219
6190d24e178c long long code generation level 4
kono
parents: 213
diff changeset
928 if(t==LREGISTER) return size_of_longlong;
166
9e55cc5551fb *** empty log message ***
kono
parents: 165
diff changeset
929 if(scalar(t)) return size_of_int;
9e55cc5551fb *** empty log message ***
kono
parents: 165
diff changeset
930 if(t==FLOAT) return size_of_float;
9e55cc5551fb *** empty log message ***
kono
parents: 165
diff changeset
931 if(t==DOUBLE) return size_of_double;
9e55cc5551fb *** empty log message ***
kono
parents: 165
diff changeset
932 if(t==LONGLONG) return size_of_longlong;
173
3b33c7daae95 *** empty log message ***
kono
parents: 169
diff changeset
933 if(t==ULONGLONG) return size_of_longlong;
176
kono
parents: 174
diff changeset
934 if(t==ENUM) return size_of_int;
166
9e55cc5551fb *** empty log message ***
kono
parents: 165
diff changeset
935 error(DCERR);
9e55cc5551fb *** empty log message ***
kono
parents: 165
diff changeset
936 }
185
427008a06333 comment
kono
parents: 184
diff changeset
937 /* type represented in a list */
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
938 if(car(t)==STRUCT||car(t)==UNION) {
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
939 if(cadr(t)==-1) error(DCERR);
d35df41eac69 Initial revision
kono
parents:
diff changeset
940 return(cadr(t));
d35df41eac69 Initial revision
kono
parents:
diff changeset
941 }
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
942 if(car(t)==ARRAY)
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
943 return(size(cadr(t))*caddr(t));
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
944 else if(car(t)==CODE)
77
2b8ba655e572 fix arg type
kono
parents: 76
diff changeset
945 return size_of_int;
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
946 else if(car(t)==FUNCTION)
77
2b8ba655e572 fix arg type
kono
parents: 76
diff changeset
947 return size_of_int;
166
9e55cc5551fb *** empty log message ***
kono
parents: 165
diff changeset
948 else if(car(t)==POINTER)
9e55cc5551fb *** empty log message ***
kono
parents: 165
diff changeset
949 return size_of_int;
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
950 else
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
951 error(DCERR);
d35df41eac69 Initial revision
kono
parents:
diff changeset
952 return 0;
d35df41eac69 Initial revision
kono
parents:
diff changeset
953 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
954
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
955
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
956 extern char *
322
46ac55e8b14c struct init by cast
kono
parents: 321
diff changeset
957 new_static_name(char *name,int delimit)
309
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
958 {
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
959 int ndsp;
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
960 char *p = cheapp;
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
961
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
962 while((*cheapp++ = *name++));
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
963 ndsp = ++stat_no;
322
46ac55e8b14c struct init by cast
kono
parents: 321
diff changeset
964 cheapp[-1] = delimit;
309
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
965 while(ndsp>0) {
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
966 *cheapp++ = ndsp%10+'0';
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
967 ndsp /= 10;
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
968 }
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
969 *cheapp++ = 0;
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
970 return p;
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
971 }
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
972
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
973
309
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
974 #define LOCAL_STRUCT_INIT_STATIC 1
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
975
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
976
308
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
977 static void
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
978 decl_data_field(int type,NMTBL *n,int offset)
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
979 {
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
980 int e,t1;
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
981 int foffset;
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
982 int offset0 = offset;
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
983 int decl_str_init_save = decl_str_init;
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
984 int mode_save=mode;
322
46ac55e8b14c struct init by cast
kono
parents: 321
diff changeset
985 NMTBL *nptr0;
308
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
986
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
987 decl_str_init = 0;
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
988 if(cadr(type)==-1) {
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
989 error(DCERR);
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
990 return;
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
991 }
309
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
992 if (mode==LDECL && LOCAL_STRUCT_INIT_STATIC) {
310
5ae5857ded2c struct partial init done.
kono
parents: 309
diff changeset
993 // uninitialized part should be 0.
5ae5857ded2c struct partial init done.
kono
parents: 309
diff changeset
994 // local var init cannot postponed because of assign_expr0/type
322
46ac55e8b14c struct init by cast
kono
parents: 321
diff changeset
995 nptr0=lsearch(new_static_name("__lstruct",'_'),0);
46ac55e8b14c struct init by cast
kono
parents: 321
diff changeset
996 nptr0->sc = GVAR;
46ac55e8b14c struct init by cast
kono
parents: 321
diff changeset
997 e = size(type);
46ac55e8b14c struct init by cast
kono
parents: 321
diff changeset
998 nptr0->ty = type;
309
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
999 mode=STADECL;
322
46ac55e8b14c struct init by cast
kono
parents: 321
diff changeset
1000 decl_data_field(type,nptr0,offset);
309
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
1001 init_vars = list2(
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
1002 list4(STASS,list2(LVAR,n->dsp+offset),
322
46ac55e8b14c struct init by cast
kono
parents: 321
diff changeset
1003 list3(RSTRUCT,list2(GVAR,(int)nptr0),e),e),
309
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
1004 init_vars);
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
1005 return;
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
1006 }
308
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1007 mode=SFDINIT;
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1008 t1 = caddr(type); /* list of fields */
309
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
1009 while(1) {
310
5ae5857ded2c struct partial init done.
kono
parents: 309
diff changeset
1010 getsym(0);
5ae5857ded2c struct partial init done.
kono
parents: 309
diff changeset
1011 if (sym==PERIOD) { /* struct/union field initializaer */
308
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1012 getsym(0);
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1013 if (sym==IDENT) {
309
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
1014 t1 = search_struct_type(type,nptr->nm,&foffset);
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
1015 getsym(0);
308
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1016 if (sym==ASS) {
310
5ae5857ded2c struct partial init done.
kono
parents: 309
diff changeset
1017 decl_data(t1,n,foffset,0);
309
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
1018 } else
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
1019 error(TYERR); /* should be initialization error */
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
1020 } else
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
1021 error(TYERR); /* should be initialization error */
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
1022 } else {
322
46ac55e8b14c struct init by cast
kono
parents: 321
diff changeset
1023 if(!t1) {
46ac55e8b14c struct init by cast
kono
parents: 321
diff changeset
1024 // empty field case (it can happen...)
46ac55e8b14c struct init by cast
kono
parents: 321
diff changeset
1025 break;
46ac55e8b14c struct init by cast
kono
parents: 321
diff changeset
1026 }
310
5ae5857ded2c struct partial init done.
kono
parents: 309
diff changeset
1027 // next decl_data must skip getsym
5ae5857ded2c struct partial init done.
kono
parents: 309
diff changeset
1028 offset = decl_data(car(t1),n,offset,1); /* alignment? */
309
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
1029 t1 = cadr(t1);
308
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1030 }
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1031 if ( t1 && sym==COMMA) { conv->comma_(); continue; }
309
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
1032 // if (!t1 && sym==COMMA) getsym(0); /* extra comma */
308
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1033 if (sym==RC) break; // premature end
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1034 }
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1035 mode = mode_save;
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1036 offset = offset0;
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1037 /*
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1038 decl_str_init
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1039 list4(offset,next,expression,type);
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1040 */
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1041 while (decl_str_init) {
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1042 offset= car(decl_str_init);
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1043 e=caddr(decl_str_init);
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1044 type=cadddr(decl_str_init);
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1045 if (offset!=offset0) {
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1046 // make space
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1047 assign_data(list2(CONST,offset-offset0),EMPTY,n,offset0);
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1048 }
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1049 offset0 = assign_data(e,type,n,offset);
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1050 decl_str_init = cadr(decl_str_init);
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1051 }
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1052 decl_str_init = decl_str_init_save;
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1053 }
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1054
326
e5d40f8c4cce bit-field continue.
kono
parents: 324
diff changeset
1055 // data structure initialization
322
46ac55e8b14c struct init by cast
kono
parents: 321
diff changeset
1056
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
1057 static int
310
5ae5857ded2c struct partial init done.
kono
parents: 309
diff changeset
1058 decl_data(int t, NMTBL *n,int offset,int skip)
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1059 {
32
b35787d8a442 macro initialization
kono
parents: 31
diff changeset
1060 int t1,e,i,mode_save;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1061
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
1062 if (offset==0 && n->sc==GVAR && n->dsp==-1) {
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
1063 /* duplicate initialization */
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
1064 error(INERR);
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
1065 }
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
1066 conv->decl_data_();
32
b35787d8a442 macro initialization
kono
parents: 31
diff changeset
1067 mode_save = mode;
b35787d8a442 macro initialization
kono
parents: 31
diff changeset
1068 mode=STAT;
310
5ae5857ded2c struct partial init done.
kono
parents: 309
diff changeset
1069 if (!skip) getsym(0);
308
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1070 if (sym==RC) { /* premature end (not necessary?) */
179
fde8cb5d9254 *** empty log message ***
kono
parents: 178
diff changeset
1071 conv->decl_data_end_();
fde8cb5d9254 *** empty log message ***
kono
parents: 178
diff changeset
1072 mode = mode_save;
fde8cb5d9254 *** empty log message ***
kono
parents: 178
diff changeset
1073 return offset;
308
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1074 } else if (scalar(t)) {
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1075 e=expr1();
32
b35787d8a442 macro initialization
kono
parents: 31
diff changeset
1076 mode = mode_save;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1077 if(car(e)!=CONST && t==CHAR)
d35df41eac69 Initial revision
kono
parents:
diff changeset
1078 error(TYERR);
310
5ae5857ded2c struct partial init done.
kono
parents: 309
diff changeset
1079 offset = assign_data(e,t,n,offset);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1080 type=t;
13
a8a812dace23 struct local initialization
kono
parents: 7
diff changeset
1081 return offset;
308
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1082 } else if (t==FLOAT||t==DOUBLE||t==LONGLONG||t==ULONGLONG) {
82
25654dc29ecc First Floating Point coding done.
kono
parents: 81
diff changeset
1083 e=expr1();
25654dc29ecc First Floating Point coding done.
kono
parents: 81
diff changeset
1084 mode = mode_save;
310
5ae5857ded2c struct partial init done.
kono
parents: 309
diff changeset
1085 offset = assign_data(e,t,n,offset);
82
25654dc29ecc First Floating Point coding done.
kono
parents: 81
diff changeset
1086 type=t;
25654dc29ecc First Floating Point coding done.
kono
parents: 81
diff changeset
1087 return offset;
308
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1088 } else if ((t1 = car(t)) && t1==ARRAY) {
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1089 if (sym==LC) {
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
1090 conv->decl_data_begin_();
32
b35787d8a442 macro initialization
kono
parents: 31
diff changeset
1091 mode = mode_save;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1092 t1 = cadr(t);
d35df41eac69 Initial revision
kono
parents:
diff changeset
1093 for(i=0;;i++) {
d35df41eac69 Initial revision
kono
parents:
diff changeset
1094 if (sym!=RC)
310
5ae5857ded2c struct partial init done.
kono
parents: 309
diff changeset
1095 offset=decl_data(t1,n,offset,0); /* array of some thing */
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
1096 if (sym==COMMA) {
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
1097 conv->comma_();
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
1098 continue;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1099 } else if (sym==RC) {
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
1100 conv->decl_data_end_();
13
a8a812dace23 struct local initialization
kono
parents: 7
diff changeset
1101 if (caddr(t)==0) { /* size not defined */
188
4303255fc3cf minor fix
kono
parents: 187
diff changeset
1102 caddr(t)=i+1; /* define array size */
179
fde8cb5d9254 *** empty log message ***
kono
parents: 178
diff changeset
1103 } else if (0 && caddr(t)!=i+1) { /* size match? */
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1104 error(TYERR);
d35df41eac69 Initial revision
kono
parents:
diff changeset
1105 }
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1106 getsym(0);
13
a8a812dace23 struct local initialization
kono
parents: 7
diff changeset
1107 return offset;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1108 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
1109 }
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
1110 /* NOT REACHED */
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1111 } else if (cadr(t)==CHAR) {
d35df41eac69 Initial revision
kono
parents:
diff changeset
1112 e=expr1();
32
b35787d8a442 macro initialization
kono
parents: 31
diff changeset
1113 mode = mode_save;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1114 if(car(e)!=STRING)
d35df41eac69 Initial revision
kono
parents:
diff changeset
1115 error(TYERR);
13
a8a812dace23 struct local initialization
kono
parents: 7
diff changeset
1116 offset=assign_data(e,list3(ARRAY,CHAR,size(type)),n,offset);
a8a812dace23 struct local initialization
kono
parents: 7
diff changeset
1117 if (caddr(t)==0) { /* size not defined */
188
4303255fc3cf minor fix
kono
parents: 187
diff changeset
1118 caddr(t)=size(type); /* define array size */
13
a8a812dace23 struct local initialization
kono
parents: 7
diff changeset
1119 } else if (caddr(t)!=size(type)) { /* size match? */
a8a812dace23 struct local initialization
kono
parents: 7
diff changeset
1120 error(TYERR);
a8a812dace23 struct local initialization
kono
parents: 7
diff changeset
1121 }
308
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1122 return offset; /* not reached */
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1123 }
326
e5d40f8c4cce bit-field continue.
kono
parents: 324
diff changeset
1124 } else if (t1==BIT_FIELD) {
329
4c8f8ef8c0cf bit field continue...
kono
parents: 328
diff changeset
1125 e=expr1();
4c8f8ef8c0cf bit field continue...
kono
parents: 328
diff changeset
1126 mode = mode_save;
4c8f8ef8c0cf bit field continue...
kono
parents: 328
diff changeset
1127 offset = assign_data(e,t,n,offset);
4c8f8ef8c0cf bit field continue...
kono
parents: 328
diff changeset
1128 type=t;
4c8f8ef8c0cf bit field continue...
kono
parents: 328
diff changeset
1129 return offset;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1130 } else if (t1==STRUCT) {
308
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1131 if (sym==LC) {
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1132 conv->lc_(); conv->decl_data_begin_();
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1133 mode = mode_save;
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1134 decl_data_field(t,n,offset);
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1135 conv->decl_data_end_(); conv->rc_();
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1136 checksym(RC);
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1137 return offset+size(t);
140
aac62d1e30a6 fix minor syntax error
kono
parents: 138
diff changeset
1138 } else if (sym==RC) { /* empty case */
aac62d1e30a6 fix minor syntax error
kono
parents: 138
diff changeset
1139 conv->lc_();
aac62d1e30a6 fix minor syntax error
kono
parents: 138
diff changeset
1140 return offset;
308
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1141 }
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1142 }
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1143 mode = mode_save;
e1d17d6adfcc struct field init (first try, no compile error)
kono
parents: 307
diff changeset
1144 error(TYERR); /* should be initialization error */
18
df7fa8cee67b pass -Wall
kono
parents: 16
diff changeset
1145 return offset; /* not reached */
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1146 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
1147
168
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
1148 static void
160
1f440a2790fb *** empty log message ***
kono
parents: 156
diff changeset
1149 sdecl_field()
1f440a2790fb *** empty log message ***
kono
parents: 156
diff changeset
1150 {
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1151 while (getsym(0) != RC) {
160
1f440a2790fb *** empty log message ***
kono
parents: 156
diff changeset
1152 decl();
1f440a2790fb *** empty log message ***
kono
parents: 156
diff changeset
1153 }
1f440a2790fb *** empty log message ***
kono
parents: 156
diff changeset
1154 if (sdecl_f) conv->rc_();
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1155 getsym(0);
168
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
1156 fields = reverse0(fields);
160
1f440a2790fb *** empty log message ***
kono
parents: 156
diff changeset
1157 }
1f440a2790fb *** empty log message ***
kono
parents: 156
diff changeset
1158
161
cc2fc5c0dfe5 struct field fix
kono
parents: 160
diff changeset
1159 #if 0
cc2fc5c0dfe5 struct field fix
kono
parents: 160
diff changeset
1160 static void
cc2fc5c0dfe5 struct field fix
kono
parents: 160
diff changeset
1161 print_fields(int fields,char *s) {
cc2fc5c0dfe5 struct field fix
kono
parents: 160
diff changeset
1162 for(;fields;fields=cadr(fields)) {
cc2fc5c0dfe5 struct field fix
kono
parents: 160
diff changeset
1163 fprintf(stderr,"%s %s %d %d\n",s,(char*)caddr(fields),car(fields),cadddr(fields));
cc2fc5c0dfe5 struct field fix
kono
parents: 160
diff changeset
1164 }
cc2fc5c0dfe5 struct field fix
kono
parents: 160
diff changeset
1165 fprintf(stderr,"\n");
cc2fc5c0dfe5 struct field fix
kono
parents: 160
diff changeset
1166 }
cc2fc5c0dfe5 struct field fix
kono
parents: 160
diff changeset
1167 #endif
cc2fc5c0dfe5 struct field fix
kono
parents: 160
diff changeset
1168
185
427008a06333 comment
kono
parents: 184
diff changeset
1169 /*
427008a06333 comment
kono
parents: 184
diff changeset
1170 struct/union
427008a06333 comment
kono
parents: 184
diff changeset
1171 tag ... struct/union name
427008a06333 comment
kono
parents: 184
diff changeset
1172 nptr0->sc = TAG;
427008a06333 comment
kono
parents: 184
diff changeset
1173 nptr0->ty = list4(...)
427008a06333 comment
kono
parents: 184
diff changeset
1174 type ... list4(STRUCT,disp,fields,(int)nptr0);
427008a06333 comment
kono
parents: 184
diff changeset
1175 filed ... assoc list defined in def();
427008a06333 comment
kono
parents: 184
diff changeset
1176 */
160
1f440a2790fb *** empty log message ***
kono
parents: 156
diff changeset
1177 static int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1178 sdecl(int s)
d35df41eac69 Initial revision
kono
parents:
diff changeset
1179 {
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
1180 int smode,sdisp,sbit_field_disp,type0=0;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1181 NMTBL *nptr0,*gnptr0;
168
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
1182 int sfields = fields;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1183
168
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
1184 fields = 0;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1185 smode=mode;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1186 if (mode==GDECL || mode==GSDECL || mode==GUDECL || mode==GTDECL)
d35df41eac69 Initial revision
kono
parents:
diff changeset
1187 mode=(s==STRUCT?GSDECL:GUDECL);
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
1188 else
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1189 mode=(s==STRUCT?LSDECL:LUDECL);
d35df41eac69 Initial revision
kono
parents:
diff changeset
1190 sdisp=disp;
326
e5d40f8c4cce bit-field continue.
kono
parents: 324
diff changeset
1191 sbit_field_disp=bit_field_disp;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1192 disp=0;
326
e5d40f8c4cce bit-field continue.
kono
parents: 324
diff changeset
1193 bit_field_disp=0;
76
fb3fb9e9a462 *** empty log message ***
kono
parents: 75
diff changeset
1194 if (sdecl_f) conv->sdecl_(s);
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1195 if (getsym(TAG) == IDENT) {
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1196 nptr0 = nptr;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1197 gnptr0 = gnptr;
76
fb3fb9e9a462 *** empty log message ***
kono
parents: 75
diff changeset
1198 if (sdecl_f) conv->id_(sym,nptr);
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1199 if (getsym(0) == LC) {
76
fb3fb9e9a462 *** empty log message ***
kono
parents: 75
diff changeset
1200 if (sdecl_f) conv->lc_();
178
0f395aa93438 gcc include file
kono
parents: 177
diff changeset
1201 if(nptr0->sc == EMPTY) nptr0=gnptr0;
182
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
1202 if (nptr0->sc!=TAG && nptr0->sc != EMPTY) error(DCERR);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1203 nptr0->sc = TAG;
160
1f440a2790fb *** empty log message ***
kono
parents: 156
diff changeset
1204 nptr0->ty = list4(s,-1,0,(int)nptr0);
168
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
1205 sdecl_field();
188
4303255fc3cf minor fix
kono
parents: 187
diff changeset
1206 caddr(nptr0->ty)=fields;
4303255fc3cf minor fix
kono
parents: 187
diff changeset
1207 cadr((type0 = nptr0->ty))=disp;
161
cc2fc5c0dfe5 struct field fix
kono
parents: 160
diff changeset
1208 /* type0 = list4(s,disp,fields,0); now ... */
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
1209 } else {
13
a8a812dace23 struct local initialization
kono
parents: 7
diff changeset
1210 /* struct tag name */
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1211 if(nptr0->sc == EMPTY) nptr0=gnptr0;
178
0f395aa93438 gcc include file
kono
parents: 177
diff changeset
1212 if(nptr0->sc == EMPTY) nptr0->sc = TAG;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1213 if(nptr0->sc != TAG) error(TYERR);
323
d5cb084fc3f4 typedef struct tag before struct fields def.
kono
parents: 322
diff changeset
1214 if (nptr0->ty) {
d5cb084fc3f4 typedef struct tag before struct fields def.
kono
parents: 322
diff changeset
1215 fields = caddr(nptr0->ty);
d5cb084fc3f4 typedef struct tag before struct fields def.
kono
parents: 322
diff changeset
1216 disp = cadr(nptr0->ty);
d5cb084fc3f4 typedef struct tag before struct fields def.
kono
parents: 322
diff changeset
1217 }
76
fb3fb9e9a462 *** empty log message ***
kono
parents: 75
diff changeset
1218 conv->comment_(' ');
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1219 type0 = list4(s,disp,fields,(int)nptr0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1220 }
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
1221 } else if(sym==LC) {
76
fb3fb9e9a462 *** empty log message ***
kono
parents: 75
diff changeset
1222 if (sdecl_f) conv->lc_();
168
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
1223 sdecl_field();
161
cc2fc5c0dfe5 struct field fix
kono
parents: 160
diff changeset
1224 type0 = list4(s,disp,fields,0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1225 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
1226 else error(DCERR);
161
cc2fc5c0dfe5 struct field fix
kono
parents: 160
diff changeset
1227
72
3b5d293cea36 type def etc
kono
parents: 71
diff changeset
1228 stypedecl=1;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1229 disp=sdisp;
326
e5d40f8c4cce bit-field continue.
kono
parents: 324
diff changeset
1230 bit_field_disp=sbit_field_disp;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1231 mode=smode;
168
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
1232 fields = sfields;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1233 return type0;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1234 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
1235
185
427008a06333 comment
kono
parents: 184
diff changeset
1236 /*
427008a06333 comment
kono
parents: 184
diff changeset
1237 enum
427008a06333 comment
kono
parents: 184
diff changeset
1238 */
427008a06333 comment
kono
parents: 184
diff changeset
1239
174
8b0ffe9b933d enum first try
kono
parents: 173
diff changeset
1240 static int
176
kono
parents: 174
diff changeset
1241 edecl()
174
8b0ffe9b933d enum first try
kono
parents: 173
diff changeset
1242 {
176
kono
parents: 174
diff changeset
1243 int smode=mode;
kono
parents: 174
diff changeset
1244 int sdisp=disp;
kono
parents: 174
diff changeset
1245 NMTBL *nptr0;
178
0f395aa93438 gcc include file
kono
parents: 177
diff changeset
1246
0f395aa93438 gcc include file
kono
parents: 177
diff changeset
1247 if (mode==GDECL || mode==GTDECL)
176
kono
parents: 174
diff changeset
1248 mode=GEDECL;
kono
parents: 174
diff changeset
1249 else
kono
parents: 174
diff changeset
1250 mode=LEDECL;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1251 if (getsym(0) == IDENT) {
176
kono
parents: 174
diff changeset
1252 nptr->sc = TAG;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1253 getsym(0);
176
kono
parents: 174
diff changeset
1254 }
kono
parents: 174
diff changeset
1255 if(sym==LC) {
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1256 while (getsym(0) == IDENT) {
176
kono
parents: 174
diff changeset
1257 nptr->sc = ENUM;
kono
parents: 174
diff changeset
1258 nptr->ty = INT;
kono
parents: 174
diff changeset
1259 nptr0 = nptr;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1260 if (getsym(0) == ASS) {
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1261 getsym(0);
176
kono
parents: 174
diff changeset
1262 disp = cexpr(expr1());
kono
parents: 174
diff changeset
1263 }
kono
parents: 174
diff changeset
1264 nptr0->dsp = disp;
kono
parents: 174
diff changeset
1265 if (sym!=COMMA) break;
kono
parents: 174
diff changeset
1266 disp++;
174
8b0ffe9b933d enum first try
kono
parents: 173
diff changeset
1267 }
176
kono
parents: 174
diff changeset
1268 checksym(RC);
174
8b0ffe9b933d enum first try
kono
parents: 173
diff changeset
1269 }
176
kono
parents: 174
diff changeset
1270 type = ENUM;
kono
parents: 174
diff changeset
1271 disp=sdisp;
174
8b0ffe9b933d enum first try
kono
parents: 173
diff changeset
1272 mode=smode;
8b0ffe9b933d enum first try
kono
parents: 173
diff changeset
1273 return type;
8b0ffe9b933d enum first try
kono
parents: 173
diff changeset
1274 }
8b0ffe9b933d enum first try
kono
parents: 173
diff changeset
1275
185
427008a06333 comment
kono
parents: 184
diff changeset
1276 /* code sgement
427008a06333 comment
kono
parents: 184
diff changeset
1277 simpler than fdecl, because it does not have return value.
427008a06333 comment
kono
parents: 184
diff changeset
1278 */
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
1279 static void
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1280 code_decl(NMTBL *n)
d35df41eac69 Initial revision
kono
parents:
diff changeset
1281 {
79
82d0e30f61dd *** empty log message ***
kono
parents: 78
diff changeset
1282 int t,arglist;
53
64a4e3789fd2 parallel assign works.
kono
parents: 50
diff changeset
1283
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
1284 if(!chk) gen_code_enter(n->nm);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1285 fnptr=n;
103
f849af4b5ea9 *** empty log message ***
kono
parents: 102
diff changeset
1286 n->sc = CODE;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1287 n->ty = type;
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1288 fcheck(n);
3
kono
parents: 2
diff changeset
1289 disp = -args;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1290 mode=ADECL;
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
1291 if (sym!=LC) {
186
6391432ca002 nkf binary fix
kono
parents: 185
diff changeset
1292 arglist=fnptr->dsp;
6391432ca002 nkf binary fix
kono
parents: 185
diff changeset
1293 args=fnptr->dsp=0;
76
fb3fb9e9a462 *** empty log message ***
kono
parents: 75
diff changeset
1294 while (sym!=LC) { /* argument declaration !ANSI */
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1295 decl(); getsym(0);
76
fb3fb9e9a462 *** empty log message ***
kono
parents: 75
diff changeset
1296 }
fb3fb9e9a462 *** empty log message ***
kono
parents: 75
diff changeset
1297 disp = -args;
186
6391432ca002 nkf binary fix
kono
parents: 185
diff changeset
1298 fnptr->dsp = arg_reorder(arglist,fnptr->dsp);
6391432ca002 nkf binary fix
kono
parents: 185
diff changeset
1299 // fnptr->dsp = reverse0(fnptr->dsp);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1300 }
53
64a4e3789fd2 parallel assign works.
kono
parents: 50
diff changeset
1301 /* reverse all argument offset (with size) */
79
82d0e30f61dd *** empty log message ***
kono
parents: 78
diff changeset
1302 arglist = fnptr->dsp;
53
64a4e3789fd2 parallel assign works.
kono
parents: 50
diff changeset
1303 for(t=arglist;t;t=cadr(t)) {
79
82d0e30f61dd *** empty log message ***
kono
parents: 78
diff changeset
1304 n=(NMTBL *)caddr(t);
53
64a4e3789fd2 parallel assign works.
kono
parents: 50
diff changeset
1305 if(n->sc==LVAR)
79
82d0e30f61dd *** empty log message ***
kono
parents: 78
diff changeset
1306 n->dsp = -n->dsp-cadddr(t);
53
64a4e3789fd2 parallel assign works.
kono
parents: 50
diff changeset
1307 }
79
82d0e30f61dd *** empty log message ***
kono
parents: 78
diff changeset
1308 arg_register(fnptr);
82d0e30f61dd *** empty log message ***
kono
parents: 78
diff changeset
1309 conv->code_(fnptr);
70
2e84590720a6 typedef name
kono
parents: 69
diff changeset
1310 typedefed=0;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1311 /* local variable declaration */
d35df41eac69 Initial revision
kono
parents:
diff changeset
1312 stmode=0;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1313 mode=STAT;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1314 init_vars=0;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1315 while (typeid(getsym(0)) || sym==STATIC || sym==EXTRN || sym==TYPEDEF) {
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1316 mode=LDECL;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1317 decl();
d35df41eac69 Initial revision
kono
parents:
diff changeset
1318 mode=STAT;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1319 }
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
1320 conv->localvar_end_();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1321 control=1;
292
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1322 cslabel = -1;
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
1323 if(!chk) gen_code_enter1(args);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1324 emit_init_vars();
316
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1325 while(sym!=RC) statement(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1326 if(control)
d35df41eac69 Initial revision
kono
parents:
diff changeset
1327 error(STERR);
d35df41eac69 Initial revision
kono
parents:
diff changeset
1328 control=0;
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
1329 conv->code_end_();
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
1330 if(!chk) gen_code_leave(fnptr->nm);
79
82d0e30f61dd *** empty log message ***
kono
parents: 78
diff changeset
1331 args = 0;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1332 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
1333
45
b9266c88495c *** empty log message ***
kono
parents: 42
diff changeset
1334 static NMTBL *tmp_struct;
b9266c88495c *** empty log message ***
kono
parents: 42
diff changeset
1335
185
427008a06333 comment
kono
parents: 184
diff changeset
1336 /* local decl can be used, after {} */
427008a06333 comment
kono
parents: 184
diff changeset
1337 /* but it's lexical scope remains after {} */
427008a06333 comment
kono
parents: 184
diff changeset
1338 /* my be in for(int i=....) not yet */
427008a06333 comment
kono
parents: 184
diff changeset
1339
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
1340 static void
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1341 local_decl()
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1342 {
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1343 init_vars=0;
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1344 /* local variable declaration */
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1345 stmode=0;
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1346 mode=STAT;
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1347 while (typeid(getsym(0)) || sym==STATIC || sym==EXTRN
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1348 || sym==REGISTER || sym==TYPEDEF) {
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1349 mode=LDECL;
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1350 stmode=0;
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1351 decl();
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1352 mode=STAT;
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1353 }
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1354 conv->localvar_end_();
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1355 }
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1356
185
427008a06333 comment
kono
parents: 184
diff changeset
1357 /* function define */
427008a06333 comment
kono
parents: 184
diff changeset
1358
186
6391432ca002 nkf binary fix
kono
parents: 185
diff changeset
1359
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1360 static void
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1361 fdecl(NMTBL *n)
d35df41eac69 Initial revision
kono
parents:
diff changeset
1362 {
75
92dcf107a837 c code output
kono
parents: 72
diff changeset
1363 int sd = stypedecl;
187
dffcccf8b1cb nested COND
kono
parents: 186
diff changeset
1364 int arglist;
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
1365 if(!chk) gen_enter(n->nm);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1366 fnptr=n;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1367 retlabel=fwdlabel();
d35df41eac69 Initial revision
kono
parents:
diff changeset
1368 retcont = 0;
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
1369 if (tmp_struct) { tmp_struct->sc = 0; tmp_struct->nm = 0; }
185
427008a06333 comment
kono
parents: 184
diff changeset
1370 tmp_struct = 0; /* a = f().filed */
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1371
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1372 n->ty = type;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1373 fcheck(n);
103
f849af4b5ea9 *** empty log message ***
kono
parents: 102
diff changeset
1374 n->sc = FUNCTION;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1375 mode=ADECL;
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
1376 if (sym!=LC) {
187
dffcccf8b1cb nested COND
kono
parents: 186
diff changeset
1377 arglist = fnptr->dsp;
186
6391432ca002 nkf binary fix
kono
parents: 185
diff changeset
1378 fnptr->dsp =args=0;
67
254a0c576114 argument type list
kono
parents: 66
diff changeset
1379 while (sym!=LC) { /* argument declaration !ANSI */
254a0c576114 argument type list
kono
parents: 66
diff changeset
1380 stmode=0;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1381 decl(); getsym(0);
67
254a0c576114 argument type list
kono
parents: 66
diff changeset
1382 }
188
4303255fc3cf minor fix
kono
parents: 187
diff changeset
1383 // This order can be different from proto type. Proto type is correct.
4303255fc3cf minor fix
kono
parents: 187
diff changeset
1384 // Recalculate offset using prototype list.
187
dffcccf8b1cb nested COND
kono
parents: 186
diff changeset
1385 // arglist is set by adecl() and is reversed.
dffcccf8b1cb nested COND
kono
parents: 186
diff changeset
1386 fnptr->dsp = arg_reorder(arglist,fnptr->dsp);
dffcccf8b1cb nested COND
kono
parents: 186
diff changeset
1387 }
dffcccf8b1cb nested COND
kono
parents: 186
diff changeset
1388 fnptr->dsp=reverse0(fnptr->dsp);
185
427008a06333 comment
kono
parents: 184
diff changeset
1389 fdecl_struct(fnptr->ty); /* insert extra argument for struct passing */
111
7aa449aff3e6 floating point
kono
parents: 109
diff changeset
1390 disp=0;
79
82d0e30f61dd *** empty log message ***
kono
parents: 78
diff changeset
1391 arg_register(fnptr);
70
2e84590720a6 typedef name
kono
parents: 69
diff changeset
1392 typedefed=0;
79
82d0e30f61dd *** empty log message ***
kono
parents: 78
diff changeset
1393 conv->function_(fnptr,sd); conv->lc_();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1394 init_vars=0;
188
4303255fc3cf minor fix
kono
parents: 187
diff changeset
1395
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1396 /* local variable declaration */
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1397 local_decl();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1398 control=1;
292
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1399 cslabel = -1;
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
1400 if(!chk) gen_enter1();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1401 emit_init_vars();
316
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1402 while(sym!=RC) statement(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1403
68
0266905063b5 *** empty log message ***
kono
parents: 67
diff changeset
1404 conv->function_end_(); conv->rc_();
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
1405 if(!chk) gen_leave(control,n->nm);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1406 retpending = 0;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1407 control=0;
75
92dcf107a837 c code output
kono
parents: 72
diff changeset
1408 arglist=0;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1409 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
1410
d35df41eac69 Initial revision
kono
parents:
diff changeset
1411
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
1412 static void
316
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1413 statement(int use)
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1414 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
1415 int slfree;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1416
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
1417 if(sym==SM) {
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
1418 conv->sm_();
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1419 getsym(0); return;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1420 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
1421 switch(sym) {
d35df41eac69 Initial revision
kono
parents:
diff changeset
1422 case IF:
d35df41eac69 Initial revision
kono
parents:
diff changeset
1423 doif();
d35df41eac69 Initial revision
kono
parents:
diff changeset
1424 return;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1425 case WHILE:
d35df41eac69 Initial revision
kono
parents:
diff changeset
1426 dowhile();
d35df41eac69 Initial revision
kono
parents:
diff changeset
1427 return;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1428 case DO:
d35df41eac69 Initial revision
kono
parents:
diff changeset
1429 dodo();
d35df41eac69 Initial revision
kono
parents:
diff changeset
1430 return;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1431 case FOR:
d35df41eac69 Initial revision
kono
parents:
diff changeset
1432 dofor();
d35df41eac69 Initial revision
kono
parents:
diff changeset
1433 return;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1434 case SWITCH:
d35df41eac69 Initial revision
kono
parents:
diff changeset
1435 doswitch();
d35df41eac69 Initial revision
kono
parents:
diff changeset
1436 return;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1437 case LC:
316
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1438 docomp(use);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1439 return;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1440 case BREAK:
292
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1441 checkret();
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
1442 conv->break_();
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
1443 if (control) gen_jmp(blabel);
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1444 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1445 checksym(SM);
d35df41eac69 Initial revision
kono
parents:
diff changeset
1446 return;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1447 case CONTINUE:
292
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1448 checkret();
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
1449 conv->continue_();
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
1450 if (control) gen_jmp(clabel);
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1451 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1452 checksym(SM);
d35df41eac69 Initial revision
kono
parents:
diff changeset
1453 return;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1454 case CASE:
d35df41eac69 Initial revision
kono
parents:
diff changeset
1455 docase();
316
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1456 statement(use); return;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1457 case DEFAULT:
d35df41eac69 Initial revision
kono
parents:
diff changeset
1458 dodefault();
316
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1459 statement(use); return;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1460 case RETURN:
d35df41eac69 Initial revision
kono
parents:
diff changeset
1461 doreturn();
d35df41eac69 Initial revision
kono
parents:
diff changeset
1462 return;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1463 case GOTO:
d35df41eac69 Initial revision
kono
parents:
diff changeset
1464 dogoto();
d35df41eac69 Initial revision
kono
parents:
diff changeset
1465 return;
316
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1466 #if ASM_CODE
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1467 case ASM:
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1468 doasm();
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1469 return;
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1470 #endif
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1471 default:
316
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1472 checkret();
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
1473 if(sym==IDENT&&skipspc()==':') {
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1474 dolabel();
316
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1475 statement(use);
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
1476 } else {
316
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1477 if (use) {
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1478 lastexp = expr(0);
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1479 return;
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1480 } else {
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1481 slfree=lfree;
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1482 gexpr(expr(0),use);
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1483 lfree=slfree;
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1484 conv->sm_();
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1485 checksym(SM);
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1486 }
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1487 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
1488 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
1489 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
1490
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
1491 static void
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1492 doif(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
1493 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
1494 int l1,l2,slfree;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1495 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1496 checksym(LPAR);
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
1497 conv->if_();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1498 slfree=lfree;
292
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1499 checkret();
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
1500 bexpr(expr(0),0,l1=fwdlabel());
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1501 lfree=slfree;
71
be313430f90b *** empty log message ***
kono
parents: 70
diff changeset
1502 conv->if_then_();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1503 checksym(RPAR);
316
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1504 statement(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1505 checkret();
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
1506 if(sym==ELSE) {
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
1507 conv->if_else_();
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
1508 if ((l2 = control))
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
1509 gen_jmp(l2=fwdlabel());
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1510 fwddef(l1);
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1511 getsym(0);
316
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1512 statement(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1513 checkret();
d35df41eac69 Initial revision
kono
parents:
diff changeset
1514 if (l2) fwddef(l2);
d35df41eac69 Initial revision
kono
parents:
diff changeset
1515 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
1516 else fwddef(l1);
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
1517 conv->if_endif_();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1518 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
1519
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
1520 static void
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1521 dowhile(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
1522 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
1523 int sbreak,scontinue,slfree,e;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1524
d35df41eac69 Initial revision
kono
parents:
diff changeset
1525 sbreak=blabel;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1526 scontinue=clabel;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1527 blabel=fwdlabel();
292
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1528 control=1;
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1529 checkret();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1530 clabel=backdef();
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
1531 conv->while_();
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1532 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1533 checksym(LPAR);
d35df41eac69 Initial revision
kono
parents:
diff changeset
1534 slfree=lfree;
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
1535 e=expr(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1536 checksym(RPAR);
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
1537 conv->while_body_();
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
1538 if(sym==SM) {
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1539 bexpr(e,1,clabel);
d35df41eac69 Initial revision
kono
parents:
diff changeset
1540 lfree=slfree;
72
3b5d293cea36 type def etc
kono
parents: 71
diff changeset
1541 conv->sm_();
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1542 getsym(0);
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
1543 } else {
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1544 bexpr(e,0,blabel);
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1545 // lfree=slfree;
316
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1546 statement(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1547 checkret();
d35df41eac69 Initial revision
kono
parents:
diff changeset
1548 if(control)
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
1549 gen_jmp(clabel);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1550 }
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
1551 conv->while_end_();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1552 fwddef(blabel);
d35df41eac69 Initial revision
kono
parents:
diff changeset
1553 clabel=scontinue;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1554 blabel=sbreak;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1555 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
1556
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
1557 static void
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1558 dodo(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
1559 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
1560 int sbreak,scontinue,l,slfree;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1561
d35df41eac69 Initial revision
kono
parents:
diff changeset
1562 sbreak=blabel;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1563 scontinue=clabel;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1564 blabel=fwdlabel();
d35df41eac69 Initial revision
kono
parents:
diff changeset
1565 clabel=fwdlabel();
292
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1566 control=1;
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1567 checkret();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1568 l=backdef();
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
1569 conv->dowhile_();
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1570 getsym(0);
316
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1571 statement(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1572 checkret();
d35df41eac69 Initial revision
kono
parents:
diff changeset
1573 fwddef(clabel);
d35df41eac69 Initial revision
kono
parents:
diff changeset
1574 checksym(WHILE);
d35df41eac69 Initial revision
kono
parents:
diff changeset
1575 checksym(LPAR);
d35df41eac69 Initial revision
kono
parents:
diff changeset
1576 slfree=lfree;
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
1577 conv->dowhile_cond_();
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
1578 bexpr(expr(0),1,l);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1579 lfree=slfree;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1580 checksym(RPAR);
72
3b5d293cea36 type def etc
kono
parents: 71
diff changeset
1581 conv->dowhile_end_();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1582 checksym(SM);
d35df41eac69 Initial revision
kono
parents:
diff changeset
1583 fwddef(blabel);
d35df41eac69 Initial revision
kono
parents:
diff changeset
1584 clabel=scontinue;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1585 blabel=sbreak;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1586 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
1587
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
1588 static void
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1589 dofor(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
1590 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
1591 int sbreak,scontinue,l,e,slfree;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1592
d35df41eac69 Initial revision
kono
parents:
diff changeset
1593 sbreak=blabel;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1594 scontinue=clabel;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1595 blabel=fwdlabel();
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
1596 conv->for_();
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1597 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1598 checksym(LPAR);
d35df41eac69 Initial revision
kono
parents:
diff changeset
1599 slfree=lfree;
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
1600 if(sym!=SM) {
292
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1601 checkret();
83
f3f75911d62c *** empty log message ***
kono
parents: 82
diff changeset
1602 gexpr(expr(0),0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1603 checksym(SM);
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
1604 conv->for1_();
72
3b5d293cea36 type def etc
kono
parents: 71
diff changeset
1605 } else {
3b5d293cea36 type def etc
kono
parents: 71
diff changeset
1606 conv->for1_();
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1607 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1608 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
1609 lfree=slfree;
292
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1610 control=1;
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1611 checkret();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1612 l=backdef();
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
1613 if(sym!=SM) {
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
1614 bexpr(expr(0),0,blabel);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1615 checksym(SM);
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
1616 conv->for2_();
72
3b5d293cea36 type def etc
kono
parents: 71
diff changeset
1617 } else {
3b5d293cea36 type def etc
kono
parents: 71
diff changeset
1618 conv->for2_();
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1619 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1620 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
1621 lfree=slfree;
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
1622 if(sym==RPAR) {
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1623 clabel=l;
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
1624 conv->for_body_();
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1625 getsym(0);
316
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1626 statement(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1627 checkret();
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
1628 } else {
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1629 clabel=fwdlabel();
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
1630 e=expr(0);
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
1631 conv->for_body_();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1632 checksym(RPAR);
316
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1633 statement(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1634 checkret();
d35df41eac69 Initial revision
kono
parents:
diff changeset
1635 fwddef(clabel);
83
f3f75911d62c *** empty log message ***
kono
parents: 82
diff changeset
1636 gexpr(e,0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1637 lfree=slfree;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1638 }
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
1639 conv->for_end_();
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
1640 gen_jmp(l);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1641 fwddef(blabel);
d35df41eac69 Initial revision
kono
parents:
diff changeset
1642 clabel=scontinue;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1643 blabel=sbreak;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1644 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
1645
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
1646 static void
316
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1647 docomp(int use)
292
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1648 {
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1649 conv->lc_();
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1650 local_decl();
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1651 emit_init_vars();
316
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1652 while(sym!=RC) statement(use);
292
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1653 conv->rc_();
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1654 getsym(0);
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1655 }
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1656
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1657 static void
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1658 doswitch(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
1659 {
292
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1660 int sbreak,scase,sdefault,slfree,svalue,slist;
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1661
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1662 checkret();
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1663 slist = cslist;
293
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
1664 cslist = 0;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1665 sbreak=blabel; /* save parents break label */
d35df41eac69 Initial revision
kono
parents:
diff changeset
1666 blabel=fwdlabel();
d35df41eac69 Initial revision
kono
parents:
diff changeset
1667 sdefault=dlabel; /* save parents default label */
d35df41eac69 Initial revision
kono
parents:
diff changeset
1668 dlabel=0;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1669 scase=cslabel; /* save parents next case label */
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
1670 conv->switch_();
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1671 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1672 checksym(LPAR);
d35df41eac69 Initial revision
kono
parents:
diff changeset
1673 slfree=lfree;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1674 svalue=csvalue1; /* save parents switch value */
83
f3f75911d62c *** empty log message ***
kono
parents: 82
diff changeset
1675 gexpr(expr(0),1);
293
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
1676 if (!scalar(type)) error(EXERR);
42
a89cf0d6904f regv assop
kono
parents: 40
diff changeset
1677 csvalue1=csvalue() ;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1678 lfree=slfree;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1679 checksym(RPAR);
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
1680 conv->switch_body_();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1681 cslabel = control = 0;
292
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1682 /* should be case statement but... for example,
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1683 main() {
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1684 int i=3,j=1,k=0;
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1685 switch(i) {
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1686 for(;j<10;j++) {
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1687 case 3: k++; case 2: k++; case 1: k++; case 0: k++;
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1688 }
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1689 }
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1690 printf("%d\n",k);
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1691 }
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1692 In this case, we have to jump into the first case label.
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1693 Can be done in checkret();
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1694 */
316
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1695 statement(0);
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
1696 conv->switch_end_();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1697 checkret();
292
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1698 #if CASE_CODE
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
1699 if (control) gen_jmp(blabel);
299
3d260008c449 level 2 looks ok.
kono
parents: 297
diff changeset
1700 genswitch(cslist,cslabel);
292
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1701 #else
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1702 if(dlabel) def_label(cslabel,dlabel);
d35df41eac69 Initial revision
kono
parents:
diff changeset
1703 else fwddef(cslabel);
292
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1704 #endif
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1705 csvalue1=svalue;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1706 cslabel=scase;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1707 dlabel=sdefault;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1708 fwddef(blabel);
d35df41eac69 Initial revision
kono
parents:
diff changeset
1709 blabel=sbreak;
292
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1710 cslist = slist;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1711 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
1712
309
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
1713 static int
293
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
1714 docase_eq()
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
1715 {
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
1716 error(-1); // duplicate case value
309
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
1717 return 0; // remove duplicate value
293
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
1718 }
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
1719
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
1720 static void
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1721 docase(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
1722 {
292
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1723 #if CASE_CODE
293
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
1724 int l,clist=0,c;
292
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1725 l = fwdlabel();
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1726 while(sym==CASE) {
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1727 conv->case_begin_(0,0);
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1728 getsym(0);
311
38c9976863b7 swtich list fix. macro fix.
kono
parents: 310
diff changeset
1729 clist=glist3(cexpr(expr(1)),clist,l);
292
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1730 conv->case_(0,0);
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1731 checksym(COLON);
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1732 }
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1733 if (retpending) { ret(); retpending=0; }
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1734 if (!cslabel) {
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1735 if (!control) {
326
e5d40f8c4cce bit-field continue.
kono
parents: 324
diff changeset
1736 // immediate after switch(i) (usual case)
293
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
1737 // use it for jump to table lookup
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
1738
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
1739 cmpdimm(car(clist),csvalue1,cslabel=fwdlabel(),1);
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
1740
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
1741 // Insert anyway to check duplicate case value.
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
1742 // Mark it already used.
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
1743
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
1744 caddr(clist)=0;
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
1745
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
1746 } else {
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
1747 // checkret() sequence inconsistent
326
e5d40f8c4cce bit-field continue.
kono
parents: 324
diff changeset
1748 // This can't happen, because checkret() force table lookup jump
e5d40f8c4cce bit-field continue.
kono
parents: 324
diff changeset
1749 // before any executable instruction in switch such as switch-for.
293
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
1750 error(-1);
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
1751 }
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
1752 }
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
1753 // Make ascend order list of case value
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
1754 while(clist) {
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
1755 clist = cadr(c=clist); cadr(c) = 0; // insert destroy cadr of clist
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
1756 cslist=insert_ascend(cslist,c,docase_eq);
292
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1757 }
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1758 fwddef(l);
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1759 control=1;
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1760 #else
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1761 int c,l,slfree;
292
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1762 l = 0;
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1763 if (retpending) ret();
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1764 slfree=lfree;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1765 c=0;
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
1766 while(sym==CASE) {
67
254a0c576114 argument type list
kono
parents: 66
diff changeset
1767 conv->case_begin_(c,0);
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1768 getsym(0);
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
1769 c=list2(cexpr(expr(1)),c);
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
1770 conv->case_(c,0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1771 checksym(COLON);
d35df41eac69 Initial revision
kono
parents:
diff changeset
1772 }
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
1773 if (control) {
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1774 control=0;
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
1775 gen_jmp(l=fwdlabel());
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1776 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
1777 if (cslabel) fwddef(cslabel);
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
1778 while(cadr(c)) {
287
a0779a414855 *** empty log message ***
kono
parents: 285
diff changeset
1779 cmpdimm(car(c),csvalue1,l,0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1780 c=cadr(c);
d35df41eac69 Initial revision
kono
parents:
diff changeset
1781 }
292
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1782 cmpdimm(car(c),csvalue1,cslabel=fwdlabel(),1);
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1783 if (l) fwddef(l);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1784 lfree=slfree;
292
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1785 #endif
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1786 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
1787
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
1788 static void
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1789 dodefault(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
1790 {
292
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1791 control=1;
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1792 checkret();
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1793 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1794 checksym(COLON);
292
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1795 if (dlabel) error(STERR); // double default:
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1796 dlabel = backdef();
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
1797 conv->case_(0,1);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1798 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
1799
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
1800 static void
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1801 doreturn(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
1802 {
39
c63c4fdeb9a7 struct done.
kono
parents: 38
diff changeset
1803 int slfree,e,e1;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1804
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
1805 if (!cslabel) gen_jmp(cslabel = fwdlabel());
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1806 if(getsym(0)==SM) {
292
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1807 // should check fnptr have no return value
71
be313430f90b *** empty log message ***
kono
parents: 70
diff changeset
1808 conv->return_();
be313430f90b *** empty log message ***
kono
parents: 70
diff changeset
1809 conv->return_end_();
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1810 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1811 retpending = 1;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1812 return;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1813 }
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
1814 conv->return_();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1815 slfree=lfree;
37
412ad2e6c2a2 struct copy
kono
parents: 36
diff changeset
1816 if (struct_return) {
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
1817 e = expr(0);
37
412ad2e6c2a2 struct copy
kono
parents: 36
diff changeset
1818 if ((car(type)==STRUCT || car(type)==UNION)&&
412ad2e6c2a2 struct copy
kono
parents: 36
diff changeset
1819 size(type)==cadr(struct_return)) {
46
b1c8ac8c308d fix cascading struct retrun. Now it should be compatible with gcc
kono
parents: 45
diff changeset
1820 if(car(e)==RSTRUCT && car(cadr(e))==FUNCTION) {
83
f3f75911d62c *** empty log message ***
kono
parents: 82
diff changeset
1821 /* pass the return pointer to the called function */
46
b1c8ac8c308d fix cascading struct retrun. Now it should be compatible with gcc
kono
parents: 45
diff changeset
1822 replace_return_struct(cadr(e),
b1c8ac8c308d fix cascading struct retrun. Now it should be compatible with gcc
kono
parents: 45
diff changeset
1823 rvalue_t(car(struct_return),caddr(struct_return)));
83
f3f75911d62c *** empty log message ***
kono
parents: 82
diff changeset
1824 gexpr(cadr(e),0);
46
b1c8ac8c308d fix cascading struct retrun. Now it should be compatible with gcc
kono
parents: 45
diff changeset
1825 } else {
b1c8ac8c308d fix cascading struct retrun. Now it should be compatible with gcc
kono
parents: 45
diff changeset
1826 type = caddr(struct_return);
306
1ec915dcd2d1 struct return size error
kono
parents: 305
diff changeset
1827 // e1 = rvalue_t(cadr(struct_return),INT); /* size */
1ec915dcd2d1 struct return size error
kono
parents: 305
diff changeset
1828 e1 = cadr(struct_return); /* size */
164
1c2a9232ea93 mc.h generation
kono
parents: 162
diff changeset
1829 gexpr(list4(STASS,rvalue(car(struct_return)),e,e1),0);
46
b1c8ac8c308d fix cascading struct retrun. Now it should be compatible with gcc
kono
parents: 45
diff changeset
1830 }
37
412ad2e6c2a2 struct copy
kono
parents: 36
diff changeset
1831 } else {
39
c63c4fdeb9a7 struct done.
kono
parents: 38
diff changeset
1832 error(TYERR); /* should check compatible */
37
412ad2e6c2a2 struct copy
kono
parents: 36
diff changeset
1833 }
412ad2e6c2a2 struct copy
kono
parents: 36
diff changeset
1834 } else {
114
e6cb1e293b35 float/int passed.
kono
parents: 111
diff changeset
1835 gexpr(correct_type(expr(0),cadr(fnptr->ty)),1);
37
412ad2e6c2a2 struct copy
kono
parents: 36
diff changeset
1836 }
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1837 lfree=slfree;
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
1838 conv->return_end_();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1839 checksym(SM);
326
e5d40f8c4cce bit-field continue.
kono
parents: 324
diff changeset
1840 /* control = 0; still control continue until pending return emission */
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1841 retpending = 1;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1842 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
1843
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
1844 static void
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1845 dogoto(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
1846 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
1847 NMTBL *nptr0;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1848 int t,e1,e2,env;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1849
292
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1850 checkret();
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
1851 conv->goto_();
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1852 getsym(0);
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
1853 e1 = expr(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1854 t=car(e1);
d35df41eac69 Initial revision
kono
parents:
diff changeset
1855 if (t==FNAME) {
d35df41eac69 Initial revision
kono
parents:
diff changeset
1856 nptr0 = (NMTBL *)cadr(e1);
d35df41eac69 Initial revision
kono
parents:
diff changeset
1857 t = nptr0->sc;
223
1ac647873577 *** empty log message ***
kono
parents: 221
diff changeset
1858 if (t==EMPTY||t==EXTRN1||t==EXTRN) {
322
46ac55e8b14c struct init by cast
kono
parents: 321
diff changeset
1859 nptr0->sc=EMPTY;
321
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
1860 nptr0=lsearch(nptr0->nm,0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1861 nptr0->sc = FLABEL;
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
1862 gen_jmp(nptr0->dsp = fwdlabel());
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1863 } else if (t==FLABEL||t==BLABEL) {
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
1864 gen_jmp(nptr0->dsp);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1865 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
1866 control=0;
76
fb3fb9e9a462 *** empty log message ***
kono
parents: 75
diff changeset
1867 conv->sm_();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1868 checksym(SM);
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
1869 conv->goto_label_(nptr0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1870 return;
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
1871 }
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1872 if (t==COMMA) {
d35df41eac69 Initial revision
kono
parents:
diff changeset
1873 env = caddr(e1);
d35df41eac69 Initial revision
kono
parents:
diff changeset
1874 e1 = cadr(e1);
d35df41eac69 Initial revision
kono
parents:
diff changeset
1875 t = car(e1);
d35df41eac69 Initial revision
kono
parents:
diff changeset
1876 } else {
d35df41eac69 Initial revision
kono
parents:
diff changeset
1877 env = 0;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1878 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
1879 if (t==FUNCTION) {
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
1880 conv->jump_(env);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1881 e2 = cadr(e1);
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
1882 if (car(e2) == FNAME) {
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1883 nptr0=(NMTBL *)cadr(e2);
103
f849af4b5ea9 *** empty log message ***
kono
parents: 102
diff changeset
1884 if (nptr0->sc==EMPTY)
f849af4b5ea9 *** empty log message ***
kono
parents: 102
diff changeset
1885 nptr0->sc = EXTRN1;
f849af4b5ea9 *** empty log message ***
kono
parents: 102
diff changeset
1886 else if(nptr0->sc==FUNCTION)
98
07c2554e1cfa *** empty log message ***
kono
parents: 97
diff changeset
1887 nptr0->sc = CODE;
103
f849af4b5ea9 *** empty log message ***
kono
parents: 102
diff changeset
1888 if (nptr0->ty>0&&car(nptr0->ty)==FUNCTION)
f849af4b5ea9 *** empty log message ***
kono
parents: 102
diff changeset
1889 car(nptr0->ty)=CODE;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1890 }
83
f3f75911d62c *** empty log message ***
kono
parents: 82
diff changeset
1891 gexpr(list3(CODE,e1,env),0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1892 control=0;
76
fb3fb9e9a462 *** empty log message ***
kono
parents: 75
diff changeset
1893 conv->sm_();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1894 checksym(SM);
d35df41eac69 Initial revision
kono
parents:
diff changeset
1895 return;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1896 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
1897 error(STERR);
d35df41eac69 Initial revision
kono
parents:
diff changeset
1898 return;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1899 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
1900
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
1901 static void
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1902 dolabel(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
1903 {
321
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
1904 NMTBL *nptr1;
292
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1905 control=1;
6d4231b6f9fe switch statement prepare
kono
parents: 287
diff changeset
1906 checkret();
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
1907 if(nptr->sc == FLABEL)
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1908 fwddef(nptr->dsp);
201
3ae7e188416f *** empty log message ***
kono
parents: 197
diff changeset
1909 else if(nptr->sc != EMPTY && nptr->sc != EXTRN1)
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1910 error(TYERR);
322
46ac55e8b14c struct init by cast
kono
parents: 321
diff changeset
1911 nptr->sc=EMPTY;
321
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
1912 nptr1=lsearch(nptr->nm,0);
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
1913 nptr1->sc = BLABEL;
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
1914 nptr1->dsp = backdef();
72
3b5d293cea36 type def etc
kono
parents: 71
diff changeset
1915 conv->label_();
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1916 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1917 checksym(COLON);
d35df41eac69 Initial revision
kono
parents:
diff changeset
1918 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
1919
316
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1920 #if ASM_CODE
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1921 static void
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1922 doasm()
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1923 {
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1924 int e1 = 0, asm0 = 0, input = 0, out = 0, opt = 0;
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1925 int e;
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1926
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1927 checkret();
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1928 getsym(0);
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1929 if (sym==VOLATILE) getsym(0);
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1930 checksym(LPAR);
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1931 // asm string
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1932 if (sym!=STRING) error(DCERR);
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1933 asm0=list3(STRING,(int)sptr,symval);
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1934 getsym(0);
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1935 if (sym!=COLON) error(DCERR);
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1936 do {
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1937 // output expression
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1938 getsym(0);
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1939 if (sym==COLON) break;
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1940 if (sym!=STRING) error(DCERR);
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1941 out=list2(list3(STRING,(int)sptr,symval),out);
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1942 getsym(0);
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1943 e1=list2(e=expr1(),e1);
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1944 lcheck(e);
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1945 } while(sym==COMMA);
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1946 if (sym==COLON) {
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1947 do {
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1948 // input expression
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1949 getsym(0);
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1950 if (sym==COLON) break;
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1951 if (sym!=STRING) error(DCERR);
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1952 input=list2(list3(STRING,(int)sptr,symval),input);
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1953 getsym(0);
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1954 e1=list2(expr1(),e1);
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1955 } while(sym==COMMA);
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1956 }
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1957 if (sym==COLON) {
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1958 do {
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1959 // option string
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1960 getsym(0);
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1961 if (sym!=STRING) error(DCERR);
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1962 opt=list2(list3(STRING,(int)sptr,symval),opt);
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1963 getsym(0);
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1964 } while(sym==COMMA);
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1965 }
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1966 checksym(RPAR);
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1967 gexpr(list3(ASM,list4(asm0,input,out,opt),e1),0);
324
575481408653 minor fix
kono
parents: 323
diff changeset
1968 checksym(SM);
316
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1969 }
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1970 #endif
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
1971
48
8575ec496cd4 jump with overrupped struct (first code)
kono
parents: 46
diff changeset
1972
185
427008a06333 comment
kono
parents: 184
diff changeset
1973 /* C expression */
427008a06333 comment
kono
parents: 184
diff changeset
1974
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
1975 extern int
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
1976 expr(int noconv)
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1977 {
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
1978 int r;
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
1979 conv->noconv_(noconv);
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
1980 r=rvalue(expr0());
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
1981 return r;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1982 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
1983
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
1984 static int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1985 expr0(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
1986 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
1987 int e;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1988
d35df41eac69 Initial revision
kono
parents:
diff changeset
1989 e=expr1();
d35df41eac69 Initial revision
kono
parents:
diff changeset
1990 while(sym==COMMA) {
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
1991 conv->op_(sym);
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
1992 getsym(0);e=list3(COMMA,e,rvalue(expr1()));
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1993 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
1994 return e;
d35df41eac69 Initial revision
kono
parents:
diff changeset
1995 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
1996
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
1997 static int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
1998 expr1(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
1999 {
135
4cfd24d1b929 fix power-pc basic test
kono
parents: 133
diff changeset
2000 int e1,e2,t,op,no_float;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2001 e1=expr2();
135
4cfd24d1b929 fix power-pc basic test
kono
parents: 133
diff changeset
2002 no_float = 0;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2003 switch (sym) {
d35df41eac69 Initial revision
kono
parents:
diff changeset
2004 case ASS:
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
2005 conv->op_(sym);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2006 lcheck(e1);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2007 t=type;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2008 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2009 e2=rvalue(expr1());
331
f25aa4f03198 bit-field continue...
kono
parents: 329
diff changeset
2010 e1 = assign_expr(e1,e2,t);
276
ebaec1ae566e MIPS double/longlong lib operand register conflict
kono
parents: 275
diff changeset
2011 return e1;
185
427008a06333 comment
kono
parents: 184
diff changeset
2012 case RSHIFT+AS: case LSHIFT+AS: case BAND+AS:
427008a06333 comment
kono
parents: 184
diff changeset
2013 case EOR+AS: case BOR+AS: case MOD+AS:
135
4cfd24d1b929 fix power-pc basic test
kono
parents: 133
diff changeset
2014 no_float = 1;
4cfd24d1b929 fix power-pc basic test
kono
parents: 133
diff changeset
2015 case ADD+AS: case SUB+AS: case MUL+AS: case DIV+AS:
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
2016 conv->op_(sym);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2017 op = sym-AS;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2018 lcheck(e1);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2019 t=type;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2020 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2021 e2=rvalue(expr1());
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
2022 return assop(e1,e2,op,t,no_float);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2023 default:
d35df41eac69 Initial revision
kono
parents:
diff changeset
2024 return(e1);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2025 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2026 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2027
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
2028 static int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2029 expr2(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
2030 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
2031 int e1,e2,e3,t;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2032
d35df41eac69 Initial revision
kono
parents:
diff changeset
2033 e1=expr3();
160
1f440a2790fb *** empty log message ***
kono
parents: 156
diff changeset
2034 if(sym==COND) { // e1?e2:e3
82
25654dc29ecc First Floating Point coding done.
kono
parents: 81
diff changeset
2035 conv->cond_();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2036 e1=rvalue(e1);
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2037 getsym(0);
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
2038 conv->cond1_();
213
kono
parents: 209
diff changeset
2039 e2=rvalue(expr0());
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2040 t=type;
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
2041 conv->cond2_();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2042 checksym(COLON);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2043 e3=rvalue(expr2());
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
2044 conv->cond_end_();
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
2045 return cond(t,e1,e2,e3);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2046 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2047 return(e1);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2048 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2049
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
2050 static int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2051 expr3(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
2052 {
132
07eb1249f07a *** empty log message ***
kono
parents: 128
diff changeset
2053 int e,e1;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2054
d35df41eac69 Initial revision
kono
parents:
diff changeset
2055 e=expr4();
160
1f440a2790fb *** empty log message ***
kono
parents: 156
diff changeset
2056 while(sym==LOR) { /* || */
132
07eb1249f07a *** empty log message ***
kono
parents: 128
diff changeset
2057 conv->op_(sym);
07eb1249f07a *** empty log message ***
kono
parents: 128
diff changeset
2058 e=rvalue(e);
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2059 getsym(0);
132
07eb1249f07a *** empty log message ***
kono
parents: 128
diff changeset
2060 e1=rvalue(expr4());
07eb1249f07a *** empty log message ***
kono
parents: 128
diff changeset
2061 if(car(e)==CONST) e = cadr(e )?e:e1;
07eb1249f07a *** empty log message ***
kono
parents: 128
diff changeset
2062 else if(car(e1)==CONST) e = cadr(e1)?e1:e;
07eb1249f07a *** empty log message ***
kono
parents: 128
diff changeset
2063 else e=list3(LOR,e,e1);
07eb1249f07a *** empty log message ***
kono
parents: 128
diff changeset
2064 type = INT;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2065 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2066 return(e);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2067 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2068
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
2069 static int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2070 expr4(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
2071 {
132
07eb1249f07a *** empty log message ***
kono
parents: 128
diff changeset
2072 int e,e1;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2073
d35df41eac69 Initial revision
kono
parents:
diff changeset
2074 e=expr5();
160
1f440a2790fb *** empty log message ***
kono
parents: 156
diff changeset
2075 while(sym==LAND) { /* && */
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
2076 conv->op_(sym);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2077 e=rvalue(e);
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2078 getsym(0);
132
07eb1249f07a *** empty log message ***
kono
parents: 128
diff changeset
2079 e1=rvalue(expr5());
07eb1249f07a *** empty log message ***
kono
parents: 128
diff changeset
2080 if(car(e)==CONST) e = cadr(e )?e1:e;
07eb1249f07a *** empty log message ***
kono
parents: 128
diff changeset
2081 else if(car(e1)==CONST) e = cadr(e1)?e:e1;
07eb1249f07a *** empty log message ***
kono
parents: 128
diff changeset
2082 else e=list3(LAND,e,e1);
07eb1249f07a *** empty log message ***
kono
parents: 128
diff changeset
2083 type = INT;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2084 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2085 return(e);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2086 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2087
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
2088 static int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2089 expr5(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
2090 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
2091 int e1,e2,t;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2092
d35df41eac69 Initial revision
kono
parents:
diff changeset
2093 e1=expr6();
185
427008a06333 comment
kono
parents: 184
diff changeset
2094 while(sym==BOR) { /* | */
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
2095 conv->op_(sym);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2096 e1=rvalue(e1);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2097 t=type;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2098 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2099 e2=rvalue(expr6());
d35df41eac69 Initial revision
kono
parents:
diff changeset
2100 e1=binop(BOR,e1,e2,t,type);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2101 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2102 return(e1);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2103 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2104
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
2105 static int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2106 expr6(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
2107 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
2108 int e1,e2,t;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2109
d35df41eac69 Initial revision
kono
parents:
diff changeset
2110 e1=expr7();
160
1f440a2790fb *** empty log message ***
kono
parents: 156
diff changeset
2111 while(sym==EOR) { /* ^ */
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
2112 conv->op_(sym);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2113 e1=rvalue(e1);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2114 t=type;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2115 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2116 e2=rvalue(expr7());
d35df41eac69 Initial revision
kono
parents:
diff changeset
2117 e1=binop(EOR,e1,e2,t,type);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2118 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2119 return(e1);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2120 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2121
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
2122 static int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2123 expr7(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
2124 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
2125 int e1,e2,t;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2126
d35df41eac69 Initial revision
kono
parents:
diff changeset
2127 e1=expr8();
160
1f440a2790fb *** empty log message ***
kono
parents: 156
diff changeset
2128 while(sym==BAND) { /* & */
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
2129 conv->op_(sym);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2130 e1=rvalue(e1);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2131 t=type;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2132 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2133 e2=rvalue(expr8());
d35df41eac69 Initial revision
kono
parents:
diff changeset
2134 e1=binop(BAND,e1,e2,t,type);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2135 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2136 return(e1);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2137 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2138
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
2139 static int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2140 expr8(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
2141 {
82
25654dc29ecc First Floating Point coding done.
kono
parents: 81
diff changeset
2142 int e1,e2,op,t;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2143
82
25654dc29ecc First Floating Point coding done.
kono
parents: 81
diff changeset
2144 e1=expr9();
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
2145 while((op=sym)==EQ||op==NEQ) {
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
2146 conv->op_(sym);
82
25654dc29ecc First Floating Point coding done.
kono
parents: 81
diff changeset
2147 e1=rvalue(e1);
25654dc29ecc First Floating Point coding done.
kono
parents: 81
diff changeset
2148 t=type;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2149 getsym(0);
82
25654dc29ecc First Floating Point coding done.
kono
parents: 81
diff changeset
2150 e2=rvalue(expr9());
25654dc29ecc First Floating Point coding done.
kono
parents: 81
diff changeset
2151 e1=binop(op,e1,e2,t,type);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2152 type= INT;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2153 }
82
25654dc29ecc First Floating Point coding done.
kono
parents: 81
diff changeset
2154 return e1;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2155 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2156
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
2157 static int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2158 expr9(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
2159 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
2160 int e1,e2,t,op;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2161
d35df41eac69 Initial revision
kono
parents:
diff changeset
2162 e1=expr10();
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
2163 while((op=sym)==GT||op==GE||op==LT||op==LE) {
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
2164 conv->op_(sym);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2165 e1=rvalue(e1);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2166 t=type;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2167 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2168 e2=rvalue(expr10());
231
f5efe15629d4 *** empty log message ***
kono
parents: 224
diff changeset
2169 e1=binop(op,e1,e2,t,type);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2170 type= INT;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2171 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2172 return e1;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2173 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2174
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
2175 static int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2176 expr10(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
2177 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
2178 int e1,e2,t,op;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2179
d35df41eac69 Initial revision
kono
parents:
diff changeset
2180 e1=expr11();
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
2181 while((op=sym)==RSHIFT||op==LSHIFT) {
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
2182 conv->op_(sym);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2183 e1=rvalue(e1);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2184 t=type;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2185 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2186 e2=rvalue(expr11());
d35df41eac69 Initial revision
kono
parents:
diff changeset
2187 e1=binop(op,e1,e2,t,type);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2188 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2189 return e1;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2190 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2191
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
2192 static int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2193 expr11(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
2194 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
2195 int e1,e2,t,op;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2196
d35df41eac69 Initial revision
kono
parents:
diff changeset
2197 e1=expr12();
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
2198 while((op=sym)==ADD||op==SUB) {
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
2199 conv->op_(sym);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2200 e1=rvalue(e1);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2201 t=type;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2202 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2203 e2=rvalue(expr12());
d35df41eac69 Initial revision
kono
parents:
diff changeset
2204 e1=binop(op,e1,e2,t,type);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2205 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2206 return e1;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2207 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2208
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
2209 static int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2210 expr12(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
2211 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
2212 int e1,e2,t,op;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2213
d35df41eac69 Initial revision
kono
parents:
diff changeset
2214 e1=expr13();
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
2215 while((op=sym)==MUL||op==DIV||op==MOD) {
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
2216 conv->op_(sym);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2217 e1=rvalue(e1);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2218 t=type;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2219 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2220 e2=rvalue(expr13());
d35df41eac69 Initial revision
kono
parents:
diff changeset
2221 e1=binop(op,e1,e2,t,type);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2222 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2223 return e1;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2224 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2225
185
427008a06333 comment
kono
parents: 184
diff changeset
2226 /* unary operators */
427008a06333 comment
kono
parents: 184
diff changeset
2227
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
2228 static int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2229 expr13(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
2230 {
168
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2231 int e,op,dir;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2232
d35df41eac69 Initial revision
kono
parents:
diff changeset
2233 switch (op = sym) {
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
2234 case INC: case DEC:
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
2235 conv->prefix_(sym);
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2236 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2237 lcheck(e=expr13());
168
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2238 dir = op==INC?1:-1;
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
2239 if(type==CHAR) {
168
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2240 type= INT; return(list4(PREINC,e,dir,1));
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2241 } else if(type==UCHAR) {
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2242 type= UNSIGNED; return(list4(UPREINC,e,dir,1));
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2243 } else if(type==SHORT) {
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2244 type= INT; return(list4(PREINC,e,dir,size_of_short));
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2245 } else if(type==USHORT) {
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2246 type= UNSIGNED; return(list4(UPREINC,e,dir,size_of_short));
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2247 } else if(type==INT) {
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2248 type= INT; return(list4(PREINC,e,dir,size_of_int));
195
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2249 #if LONGLONG_CODE
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2250 } else if(type==LONGLONG) {
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2251 type= LONGLONG; return(list4(LPREINC,e,dir,size_of_longlong));
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2252 } else if(type==ULONGLONG) {
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2253 type= ULONGLONG; return(list4(LUPREINC,e,dir,size_of_longlong));
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2254 #endif
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2255 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2256 if(integral(type))
168
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2257 return(list4(PREINC,e,dir,size_of_int));
195
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2258 #if FLOAT_CODE
83
f3f75911d62c *** empty log message ***
kono
parents: 82
diff changeset
2259 if(type==FLOAT)
168
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2260 return(list3(FPREINC,e,dir));
83
f3f75911d62c *** empty log message ***
kono
parents: 82
diff changeset
2261 if(type==DOUBLE)
168
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2262 return(list3(DPREINC,e,dir));
195
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2263 #endif
331
f25aa4f03198 bit-field continue...
kono
parents: 329
diff changeset
2264 if(type>0 && car(type)==BIT_FIELD)
332
ce85d6106119 bit field continue. (code generation done)
kono
parents: 331
diff changeset
2265 return(list4(BPREINC,e,dir,type));
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
2266 if(car(type)!=POINTER)
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2267 error(TYERR);
168
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2268 return(list4(UPREINC,e,
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2269 op==INC?size(cadr(type)):-size(cadr(type)),size_of_int ));
160
1f440a2790fb *** empty log message ***
kono
parents: 156
diff changeset
2270 case MUL: /* *p */
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
2271 conv->prefix_(sym);
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2272 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2273 e=rvalue(expr13());
d35df41eac69 Initial revision
kono
parents:
diff changeset
2274 return(indop(e));
160
1f440a2790fb *** empty log message ***
kono
parents: 156
diff changeset
2275 case BAND: /* &p */
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
2276 conv->prefix_(sym);
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2277 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2278 switch(car(e=expr13())) {
d35df41eac69 Initial revision
kono
parents:
diff changeset
2279 case INDIRECT:
d35df41eac69 Initial revision
kono
parents:
diff changeset
2280 e=cadr(e);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2281 break;
137
9fb09db54436 fix powerpc get_fregister_var's regs error.
kono
parents: 136
diff changeset
2282 case DREGISTER: /* should be error? */
9fb09db54436 fix powerpc get_fregister_var's regs error.
kono
parents: 136
diff changeset
2283 case FREGISTER:
195
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2284 case LREGISTER:
105
7e3d59e56a53 save register ( incomplete )
kono
parents: 104
diff changeset
2285 case REGISTER:
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2286 case GVAR:
d35df41eac69 Initial revision
kono
parents:
diff changeset
2287 case LVAR:
d35df41eac69 Initial revision
kono
parents:
diff changeset
2288 e=list2(ADDRESS,e);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2289 break;
140
aac62d1e30a6 fix minor syntax error
kono
parents: 138
diff changeset
2290 case FNAME:
aac62d1e30a6 fix minor syntax error
kono
parents: 138
diff changeset
2291 break;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2292 default:error(LVERR);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2293 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2294 type=list2(POINTER,type);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2295 return e;
160
1f440a2790fb *** empty log message ***
kono
parents: 156
diff changeset
2296 case SUB: /* -p */
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
2297 conv->prefix_(sym);
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2298 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2299 e=rvalue(expr13());
195
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2300 #if FLOAT_CODE
271
e1a96bdbe527 MIPS continue...
kono
parents: 267
diff changeset
2301 if(type==FLOAT) {
e1a96bdbe527 MIPS continue...
kono
parents: 267
diff changeset
2302 return(car(e)==DCONST?dlist2(DCONST,-dcadr(e)):list2(FMINUS,e));
e1a96bdbe527 MIPS continue...
kono
parents: 267
diff changeset
2303 } else if(type==DOUBLE) {
118
07b91b625f84 assignment optimization
kono
parents: 117
diff changeset
2304 return(car(e)==DCONST?dlist2(DCONST,-dcadr(e)):list2(DMINUS,e));
07b91b625f84 assignment optimization
kono
parents: 117
diff changeset
2305 }
195
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2306 #endif
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2307 #if LONGLONG_CODE
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2308 if(type==LONGLONG||type==ULONGLONG) {
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2309 // return list2(LMINUS,e);
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2310 return(car(e)==LCONST?llist2(LCONST,-lcadr(e)):list2(LMINUS,e));
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2311 }
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2312 #endif
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
2313 if(!integral(type))
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2314 error(TYERR);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2315 return(car(e)==CONST?list2(CONST,-cadr(e)):list2(MINUS,e));
160
1f440a2790fb *** empty log message ***
kono
parents: 156
diff changeset
2316 case BNOT: /* ~p */
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
2317 conv->prefix_(sym);
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2318 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2319 e=rvalue(expr13());
195
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2320 // LONGLONG?
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
2321 if(!integral(type))
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2322 error(TYERR);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2323 return(car(e)==CONST?list2(CONST,~cadr(e)):list2(BNOT,e));
160
1f440a2790fb *** empty log message ***
kono
parents: 156
diff changeset
2324 case LNOT: /* !p */
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
2325 conv->prefix_(sym);
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2326 getsym(0);
19
b62230ea38f6 ifdef debug
kono
parents: 18
diff changeset
2327 e=rvalue(expr13());
252
1452eb0eab20 *** empty log message ***
kono
parents: 233
diff changeset
2328 type=INT;
195
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2329 #if FLOAT_CODE
252
1452eb0eab20 *** empty log message ***
kono
parents: 233
diff changeset
2330 if (car(e)==DCONST) return list2(CONST,!dcadr(e));
195
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2331 #endif
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2332 #if LONGLONG_CODE
252
1452eb0eab20 *** empty log message ***
kono
parents: 233
diff changeset
2333 if (car(e)==LCONST) return list2(CONST,!lcadr(e));
195
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2334 #endif
252
1452eb0eab20 *** empty log message ***
kono
parents: 233
diff changeset
2335 if (car(e)==CONST) return list2(CONST,!cadr(e));
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
2336 if(!scalar(type))
19
b62230ea38f6 ifdef debug
kono
parents: 18
diff changeset
2337 error(TYERR);
252
1452eb0eab20 *** empty log message ***
kono
parents: 233
diff changeset
2338 return list2(LNOT,e);
313
f73b93de216a alloca done for ia32, powerpc, mips
kono
parents: 312
diff changeset
2339 case ALLOCA:
f73b93de216a alloca done for ia32, powerpc, mips
kono
parents: 312
diff changeset
2340 conv->prefix_(sym);
f73b93de216a alloca done for ia32, powerpc, mips
kono
parents: 312
diff changeset
2341 type=POINTER;
f73b93de216a alloca done for ia32, powerpc, mips
kono
parents: 312
diff changeset
2342 getsym(0);
f73b93de216a alloca done for ia32, powerpc, mips
kono
parents: 312
diff changeset
2343 checksym(LPAR);
f73b93de216a alloca done for ia32, powerpc, mips
kono
parents: 312
diff changeset
2344 e=expr0();
f73b93de216a alloca done for ia32, powerpc, mips
kono
parents: 312
diff changeset
2345 checksym(RPAR);
f73b93de216a alloca done for ia32, powerpc, mips
kono
parents: 312
diff changeset
2346 return list2(ALLOCA,rvalue(e));
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2347 case SIZEOF:
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
2348 conv->prefix_(sym);
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2349 if(getsym(0)==LPAR) {
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2350 if(typeid(getsym(0))) {
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2351 e=list2(CONST,size(typename()));
d35df41eac69 Initial revision
kono
parents:
diff changeset
2352 type=INT;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2353 checksym(RPAR);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2354 return e;
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
2355 } else {
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2356 e=expr0();
d35df41eac69 Initial revision
kono
parents:
diff changeset
2357 checksym(RPAR);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2358 expr16(e);
168
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2359 if(sym==INC||sym==DEC) {
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2360 /* after this operation, type is extended */
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2361 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2362 if(type==CHAR) type=INT;
168
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2363 else if(type==SHORT) type=INT;
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2364 else if(type==UCHAR) type=UNSIGNED;
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2365 else if(type==USHORT) type=UNSIGNED;
83
f3f75911d62c *** empty log message ***
kono
parents: 82
diff changeset
2366 else if(!scalar(type)&&type!=FLOAT&&type!=DOUBLE)
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2367 error(TYERR);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2368 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2369 }
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
2370 } else
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2371 expr13();
d35df41eac69 Initial revision
kono
parents:
diff changeset
2372 e=list2(CONST,size(type));
d35df41eac69 Initial revision
kono
parents:
diff changeset
2373 type=INT;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2374 return e;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2375 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2376 e=expr14();
185
427008a06333 comment
kono
parents: 184
diff changeset
2377
427008a06333 comment
kono
parents: 184
diff changeset
2378 /* postfix unary operators */
427008a06333 comment
kono
parents: 184
diff changeset
2379
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
2380 if((op=sym)==INC||op==DEC) {
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
2381 conv->postfix_(sym);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2382 lcheck(e);
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2383 getsym(0);
168
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2384
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2385 dir = op==INC?1:-1;
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
2386 if(type==CHAR) {
168
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2387 type= INT; return(list4(POSTINC,e,dir,1));
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2388 } else if(type==UCHAR) {
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2389 type= UNSIGNED; return(list4(UPOSTINC,e,dir,1));
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2390 } else if(type==SHORT) {
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2391 type= INT; return(list4(POSTINC,e,dir,size_of_short));
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2392 } else if(type==USHORT) {
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2393 type= UNSIGNED; return(list4(UPOSTINC,e,dir,size_of_short));
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2394 } else if(type==INT) {
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2395 type= INT; return(list4(POSTINC,e,dir,size_of_int));
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2396 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2397 if(integral(type))
168
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2398 return(list4(POSTINC,e,dir,size_of_int));
195
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2399 #if FLOAT_CODE
83
f3f75911d62c *** empty log message ***
kono
parents: 82
diff changeset
2400 if(type==FLOAT)
168
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2401 return(list3(FPOSTINC,e,dir));
83
f3f75911d62c *** empty log message ***
kono
parents: 82
diff changeset
2402 if(type==DOUBLE)
168
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2403 return(list3(DPOSTINC,e,dir));
195
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2404 #endif
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2405 #if LONGLONG_CODE
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2406 if(type==LONGLONG)
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2407 return(list3(LPOSTINC,e,dir));
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2408 if(type==ULONGLONG)
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2409 return(list3(LUPOSTINC,e,dir));
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2410 #endif
331
f25aa4f03198 bit-field continue...
kono
parents: 329
diff changeset
2411 if(type>0 && car(type)==BIT_FIELD)
332
ce85d6106119 bit field continue. (code generation done)
kono
parents: 331
diff changeset
2412 return(list4(BPOSTINC,e,dir,type));
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
2413 if(car(type)!=POINTER)
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2414 error(TYERR);
168
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2415 return(list4(UPOSTINC,e,
b1297c82e926 cpostinc removal
kono
parents: 166
diff changeset
2416 op==INC?size(cadr(type)):-size(cadr(type)),size_of_int ));
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2417 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2418 return e;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2419 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2420
97
6d42fcac07af *** empty log message ***
kono
parents: 95
diff changeset
2421 static void
6d42fcac07af *** empty log message ***
kono
parents: 95
diff changeset
2422 extrn_use(NMTBL *nptr)
6d42fcac07af *** empty log message ***
kono
parents: 95
diff changeset
2423 {
164
1c2a9232ea93 mc.h generation
kono
parents: 162
diff changeset
2424 /* EXTRN1 means that defined extern is used in this source */
98
07c2554e1cfa *** empty log message ***
kono
parents: 97
diff changeset
2425 if(nptr->sc==EXTRN) nptr->sc=EXTRN1;
07c2554e1cfa *** empty log message ***
kono
parents: 97
diff changeset
2426 }
07c2554e1cfa *** empty log message ***
kono
parents: 97
diff changeset
2427
07c2554e1cfa *** empty log message ***
kono
parents: 97
diff changeset
2428 static int
07c2554e1cfa *** empty log message ***
kono
parents: 97
diff changeset
2429 fname(NMTBL *nptr)
07c2554e1cfa *** empty log message ***
kono
parents: 97
diff changeset
2430 {
07c2554e1cfa *** empty log message ***
kono
parents: 97
diff changeset
2431 int e1;
07c2554e1cfa *** empty log message ***
kono
parents: 97
diff changeset
2432 e1=list2(FNAME,(int)nptr);
203
28baf6cd9ad1 *** empty log message ***
kono
parents: 202
diff changeset
2433 // type=list3(FUNCTION,type,arg);
114
e6cb1e293b35 float/int passed.
kono
parents: 111
diff changeset
2434 type=list3(car(nptr->ty),cadr(nptr->ty),caddr(nptr->ty));
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2435 getsym(0);
98
07c2554e1cfa *** empty log message ***
kono
parents: 97
diff changeset
2436 extrn_use(nptr);
07c2554e1cfa *** empty log message ***
kono
parents: 97
diff changeset
2437 return expr16(e1);
97
6d42fcac07af *** empty log message ***
kono
parents: 95
diff changeset
2438 }
6d42fcac07af *** empty log message ***
kono
parents: 95
diff changeset
2439
185
427008a06333 comment
kono
parents: 184
diff changeset
2440 /* term */
427008a06333 comment
kono
parents: 184
diff changeset
2441
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
2442 static int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2443 expr14(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
2444 {
322
46ac55e8b14c struct init by cast
kono
parents: 321
diff changeset
2445 int e1=0,t,t1,smode;
46ac55e8b14c struct init by cast
kono
parents: 321
diff changeset
2446 NMTBL *nptr0;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2447
d35df41eac69 Initial revision
kono
parents:
diff changeset
2448 switch(sym) {
d35df41eac69 Initial revision
kono
parents:
diff changeset
2449 case IDENT:
68
0266905063b5 *** empty log message ***
kono
parents: 67
diff changeset
2450 conv->id_(sym,nptr);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2451 switch(nptr->sc) {
114
e6cb1e293b35 float/int passed.
kono
parents: 111
diff changeset
2452 case EXTRN: case EXTRN1:
109
e09f9de6f5d3 *** empty log message ***
kono
parents: 108
diff changeset
2453 extrn_use(nptr);
114
e6cb1e293b35 float/int passed.
kono
parents: 111
diff changeset
2454 case STATIC:
98
07c2554e1cfa *** empty log message ***
kono
parents: 97
diff changeset
2455 if(is_code(nptr)||is_function(nptr)) {
07c2554e1cfa *** empty log message ***
kono
parents: 97
diff changeset
2456 return fname(nptr);
07c2554e1cfa *** empty log message ***
kono
parents: 97
diff changeset
2457 }
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2458 case GVAR:
109
e09f9de6f5d3 *** empty log message ***
kono
parents: 108
diff changeset
2459 e1=list2(GVAR,(int)nptr);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2460 type=nptr->ty;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2461 getsym(0);
97
6d42fcac07af *** empty log message ***
kono
parents: 95
diff changeset
2462 extrn_use(nptr);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2463 break;
98
07c2554e1cfa *** empty log message ***
kono
parents: 97
diff changeset
2464 case FLABEL: case BLABEL:
07c2554e1cfa *** empty log message ***
kono
parents: 97
diff changeset
2465 case FUNCTION: case CODE:
07c2554e1cfa *** empty log message ***
kono
parents: 97
diff changeset
2466 return fname(nptr);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2467 case LVAR:
d35df41eac69 Initial revision
kono
parents:
diff changeset
2468 e1=list2(LVAR,nptr->dsp);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2469 type=nptr->ty;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2470 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2471 break;
219
6190d24e178c long long code generation level 4
kono
parents: 213
diff changeset
2472 case LREGISTER:
105
7e3d59e56a53 save register ( incomplete )
kono
parents: 104
diff changeset
2473 case DREGISTER:
137
9fb09db54436 fix powerpc get_fregister_var's regs error.
kono
parents: 136
diff changeset
2474 case FREGISTER:
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2475 case REGISTER:
137
9fb09db54436 fix powerpc get_fregister_var's regs error.
kono
parents: 136
diff changeset
2476 e1=list3(nptr->sc,nptr->dsp,(int)nptr);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2477 type=nptr->ty;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2478 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2479 break;
176
kono
parents: 174
diff changeset
2480 case ENUM:
kono
parents: 174
diff changeset
2481 e1=list2(CONST,nptr->dsp);
kono
parents: 174
diff changeset
2482 type=INT;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2483 getsym(0);
176
kono
parents: 174
diff changeset
2484 break;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2485 case EMPTY:
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2486 if(getsym(0)==LPAR) {
103
f849af4b5ea9 *** empty log message ***
kono
parents: 102
diff changeset
2487 type= glist3(FUNCTION,INT,0);
184
4bf42b2df5d7 function extrn1
kono
parents: 183
diff changeset
2488 nptr->sc = EXTRN1;
103
f849af4b5ea9 *** empty log message ***
kono
parents: 102
diff changeset
2489 nptr->ty= type;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2490 e1=expr15(list2(FNAME,(int)nptr));
d35df41eac69 Initial revision
kono
parents:
diff changeset
2491 break;
182
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
2492 } else if (in_macro_if) {
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
2493 type = INT;
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
2494 e1= list2(CONST,0);
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
2495 break;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2496 } else {
182
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
2497 nptr->sc = EXTRN1;
103
f849af4b5ea9 *** empty log message ***
kono
parents: 102
diff changeset
2498 nptr->ty= glist3(FUNCTION,INT,0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2499 e1=list2(FNAME,(int)nptr);
67
254a0c576114 argument type list
kono
parents: 66
diff changeset
2500 type=list3(nptr->sc,nptr->ty,nptr->dsp);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2501 break;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2502 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2503 default:error(UDERR);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2504 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2505 break;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2506 case STRING:
68
0266905063b5 *** empty log message ***
kono
parents: 67
diff changeset
2507 conv-> string_(sptr);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2508 e1=list3(STRING,(int)sptr,symval);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2509 type=list3(ARRAY,CHAR,symval);
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2510 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2511 break;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2512 case CONST:
68
0266905063b5 *** empty log message ***
kono
parents: 67
diff changeset
2513 conv-> const_(symval);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2514 type= INT;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2515 e1=list2(CONST,symval);
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2516 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2517 break;
195
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2518 #if FLOAT_CODE
81
f94ca1168520 float first try...
kono
parents: 80
diff changeset
2519 case DCONST:
f94ca1168520 float first try...
kono
parents: 80
diff changeset
2520 conv-> const_(symval);
f94ca1168520 float first try...
kono
parents: 80
diff changeset
2521 type= DOUBLE;
f94ca1168520 float first try...
kono
parents: 80
diff changeset
2522 e1=dlist2(DCONST,dsymval);
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2523 getsym(0);
81
f94ca1168520 float first try...
kono
parents: 80
diff changeset
2524 break;
195
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2525 #endif
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2526 #if LONGLONG_CODE
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2527 case LCONST:
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2528 conv-> const_(symval);
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2529 type= LONGLONG;
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2530 e1=llist2(LCONST,lsymval);
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2531 getsym(0);
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2532 break;
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
2533 #endif
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2534 case RETURN:
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
2535 conv-> return_f_();
103
f849af4b5ea9 *** empty log message ***
kono
parents: 102
diff changeset
2536 if (!is_function(fnptr)) {
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2537 error(STERR);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2538 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2539 type=list2(POINTER,CODE);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2540 e1=list2(RETURN,(int)fnptr);
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2541 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2542 break;
18
df7fa8cee67b pass -Wall
kono
parents: 16
diff changeset
2543 case DEFINED:
182
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
2544 t = mode; mode = IFDEF;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2545 getsym(0);
182
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
2546 if (sym==LPAR) { t1 = 1; getsym(0); } else t1 = 0;
68
0266905063b5 *** empty log message ***
kono
parents: 67
diff changeset
2547 conv-> defined_(name);
18
df7fa8cee67b pass -Wall
kono
parents: 16
diff changeset
2548 mode = t;
df7fa8cee67b pass -Wall
kono
parents: 16
diff changeset
2549 type= INT;
df7fa8cee67b pass -Wall
kono
parents: 16
diff changeset
2550 e1=list2(CONST,symval);
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2551 getsym(0);
182
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
2552 if (t1)
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
2553 checksym(RPAR);
18
df7fa8cee67b pass -Wall
kono
parents: 16
diff changeset
2554 break;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2555 case ENVIRONMENT:
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
2556 conv-> environment_();
2
kono
parents: 1
diff changeset
2557 type=list2(POINTER,VOID);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2558 e1=list2(ENVIRONMENT,0);
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2559 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2560 break;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2561 case LPAR:
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
2562 conv->lpar_();
317
3dfac70ef7e1 asm statement, valued statement syntactically passed.
kono
parents: 316
diff changeset
2563 getsym(0);
3dfac70ef7e1 asm statement, valued statement syntactically passed.
kono
parents: 316
diff changeset
2564 if(sym==VOLATILE) getsym(0);
3dfac70ef7e1 asm statement, valued statement syntactically passed.
kono
parents: 316
diff changeset
2565 if(typeid(sym)) { /* cast */
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2566 t=typename();
72
3b5d293cea36 type def etc
kono
parents: 71
diff changeset
2567 conv->return_type_(t,0,0);
3b5d293cea36 type def etc
kono
parents: 71
diff changeset
2568 conv->rpar_();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2569 checksym(RPAR);
322
46ac55e8b14c struct init by cast
kono
parents: 321
diff changeset
2570 if (sym==LC && (t>0 && (car(t)==STRUCT||car(t)==UNION))) {
46ac55e8b14c struct init by cast
kono
parents: 321
diff changeset
2571 // q->lock = (spinlock_t) { };
46ac55e8b14c struct init by cast
kono
parents: 321
diff changeset
2572 smode = mode;
46ac55e8b14c struct init by cast
kono
parents: 321
diff changeset
2573 type = t;
46ac55e8b14c struct init by cast
kono
parents: 321
diff changeset
2574 nptr0=lsearch(new_static_name("__lstruct",'_'),0);
46ac55e8b14c struct init by cast
kono
parents: 321
diff changeset
2575 nptr0->sc = GVAR;
46ac55e8b14c struct init by cast
kono
parents: 321
diff changeset
2576 e1 = size(type);
46ac55e8b14c struct init by cast
kono
parents: 321
diff changeset
2577 nptr0->ty = type;
46ac55e8b14c struct init by cast
kono
parents: 321
diff changeset
2578 mode=STADECL;
46ac55e8b14c struct init by cast
kono
parents: 321
diff changeset
2579 decl_data_field(type,nptr0,0);
46ac55e8b14c struct init by cast
kono
parents: 321
diff changeset
2580 checksym(RC);
46ac55e8b14c struct init by cast
kono
parents: 321
diff changeset
2581 e1 = list3(RSTRUCT,list2(GVAR,(int)nptr0),e1);
46ac55e8b14c struct init by cast
kono
parents: 321
diff changeset
2582 mode = smode;
46ac55e8b14c struct init by cast
kono
parents: 321
diff changeset
2583 return e1;
46ac55e8b14c struct init by cast
kono
parents: 321
diff changeset
2584 }
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2585 e1=expr13();
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
2586 return correct_type(e1,t);
316
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
2587 } else if (sym==LC) {
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
2588 // statement in expression
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
2589 docomp(1);
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
2590 e1 = lastexp; lastexp = 0;
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
2591 } else {
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
2592 e1=expr0();
22d92986c7f7 asm, valued statement, local decls continue...
kono
parents: 313
diff changeset
2593 conv->rpar_();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2594 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2595 checksym(RPAR);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2596 break;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2597 default:error(EXERR);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2598 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2599 return expr16(e1);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2600 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2601
185
427008a06333 comment
kono
parents: 184
diff changeset
2602 /* post fix binary operator (struct . -> or array[] */
427008a06333 comment
kono
parents: 184
diff changeset
2603
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
2604 static int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2605 expr16(int e1)
d35df41eac69 Initial revision
kono
parents:
diff changeset
2606 {
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
2607 int e2,t,ind;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2608
d35df41eac69 Initial revision
kono
parents:
diff changeset
2609 while(1) {
160
1f440a2790fb *** empty log message ***
kono
parents: 156
diff changeset
2610 if(sym==LBRA) { /* a[3] */
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
2611 conv->lbra_(sym);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2612 e1=rvalue(e1);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2613 t=type;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2614 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2615 e2=rvalue(expr0());
d35df41eac69 Initial revision
kono
parents:
diff changeset
2616 checksym(RBRA);
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
2617 conv->rbra_(sym);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2618 e1=binop(ADD,e1,e2,t,type);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2619 e1=indop(e1);
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
2620 } else if(sym==LPAR) {
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
2621 e1=expr15(e1); /* f() */
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
2622 } else if(sym==PERIOD||sym==ARROW) {
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
2623 ind = sym;
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
2624 conv->op_(sym);
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
2625 getsym(0);
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
2626 if (sym!=IDENT) error(TYERR);
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
2627 conv->id_(sym,nptr);
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
2628 e1=strop(e1,ind==ARROW);
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
2629 getsym(0);
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
2630 } else break;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2631 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2632 if(car(e1)==FNAME) type=list2(POINTER,type);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2633 return e1;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2634 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2635
87
1738f313f98b floating point (at most) done.
kono
parents: 86
diff changeset
2636
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
2637 static int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2638 expr15(int e1)
d35df41eac69 Initial revision
kono
parents:
diff changeset
2639 {
136
069960078249 remove redundant funcall argument for prototyped code in PowerPC case.
kono
parents: 135
diff changeset
2640 int t,arglist,e,sz,argtypes,at,ftype;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2641
185
427008a06333 comment
kono
parents: 184
diff changeset
2642 /* function call target */
427008a06333 comment
kono
parents: 184
diff changeset
2643
79
82d0e30f61dd *** empty log message ***
kono
parents: 78
diff changeset
2644 if(car(type)==POINTER) {
82d0e30f61dd *** empty log message ***
kono
parents: 78
diff changeset
2645 if (car(cadr(type))==FUNCTION||car(cadr(type))==CODE) {
82d0e30f61dd *** empty log message ***
kono
parents: 78
diff changeset
2646 e1=rvalue(e1);
82d0e30f61dd *** empty log message ***
kono
parents: 78
diff changeset
2647 type=cadr(type);
103
f849af4b5ea9 *** empty log message ***
kono
parents: 102
diff changeset
2648 } /* else error */
79
82d0e30f61dd *** empty log message ***
kono
parents: 78
diff changeset
2649 }
87
1738f313f98b floating point (at most) done.
kono
parents: 86
diff changeset
2650 if(integral(type)|| ((car(type)!=FUNCTION)&&(car(type)!=CODE))) {
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2651 error(TYERR);
79
82d0e30f61dd *** empty log message ***
kono
parents: 78
diff changeset
2652 }
136
069960078249 remove redundant funcall argument for prototyped code in PowerPC case.
kono
parents: 135
diff changeset
2653 ftype = type;
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
2654 conv->funcall_(type);
185
427008a06333 comment
kono
parents: 184
diff changeset
2655
427008a06333 comment
kono
parents: 184
diff changeset
2656 /* function argments */
427008a06333 comment
kono
parents: 184
diff changeset
2657
87
1738f313f98b floating point (at most) done.
kono
parents: 86
diff changeset
2658 argtypes = caddr(type);
203
28baf6cd9ad1 *** empty log message ***
kono
parents: 202
diff changeset
2659 if ((t=cadr(type))>=0 && (car(t)==STRUCT||car(t)==UNION)) {
87
1738f313f98b floating point (at most) done.
kono
parents: 86
diff changeset
2660 /* skip return struct pointer */
1738f313f98b floating point (at most) done.
kono
parents: 86
diff changeset
2661 if (argtypes==0) error(-1);
1738f313f98b floating point (at most) done.
kono
parents: 86
diff changeset
2662 argtypes = cadr(argtypes);
1738f313f98b floating point (at most) done.
kono
parents: 86
diff changeset
2663 }
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2664 arglist=0;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2665 getsym(0);
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
2666 while(sym!=RPAR) {
3
kono
parents: 2
diff changeset
2667 e=rvalue(expr1());
87
1738f313f98b floating point (at most) done.
kono
parents: 86
diff changeset
2668 if(argtypes==0) at=DOTS;
1738f313f98b floating point (at most) done.
kono
parents: 86
diff changeset
2669 else if(car(argtypes)==DOTS) at=DOTS;
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
2670 else { at=car(argtypes); argtypes=cadr(argtypes); }
114
e6cb1e293b35 float/int passed.
kono
parents: 111
diff changeset
2671 e = correct_type(e,at);
3
kono
parents: 2
diff changeset
2672 arglist=list3(e,arglist,type);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2673 if(sym!=COMMA) break;
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
2674 conv->comma_();
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2675 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2676 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2677 checksym(RPAR);
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
2678 conv->funcall_args_();
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
2679 if(car(t)==CODE)
136
069960078249 remove redundant funcall argument for prototyped code in PowerPC case.
kono
parents: 135
diff changeset
2680 return list4(FUNCTION,e1,arglist,ftype);
185
427008a06333 comment
kono
parents: 184
diff changeset
2681
427008a06333 comment
kono
parents: 184
diff changeset
2682 /* return type */
427008a06333 comment
kono
parents: 184
diff changeset
2683
427008a06333 comment
kono
parents: 184
diff changeset
2684 type = cadr(ftype);
39
c63c4fdeb9a7 struct done.
kono
parents: 38
diff changeset
2685 if(type==CHAR) type=INT;
c63c4fdeb9a7 struct done.
kono
parents: 38
diff changeset
2686 else if(car(type)==STRUCT||car(type)==UNION) {
326
e5d40f8c4cce bit-field continue.
kono
parents: 324
diff changeset
2687 /* make temporary struct for return value */
45
b9266c88495c *** empty log message ***
kono
parents: 42
diff changeset
2688 /* but it is better to see we can reuse old one */
b9266c88495c *** empty log message ***
kono
parents: 42
diff changeset
2689 if (tmp_struct) {
b9266c88495c *** empty log message ***
kono
parents: 42
diff changeset
2690 sz = size(tmp_struct->ty);
b9266c88495c *** empty log message ***
kono
parents: 42
diff changeset
2691 if (sz>=size(type)) {
b9266c88495c *** empty log message ***
kono
parents: 42
diff changeset
2692 /* reuse it */
b9266c88495c *** empty log message ***
kono
parents: 42
diff changeset
2693 } else if (tmp_struct->dsp-sz==disp) {
b9266c88495c *** empty log message ***
kono
parents: 42
diff changeset
2694 /* extendable */
b9266c88495c *** empty log message ***
kono
parents: 42
diff changeset
2695 disp -= tmp_struct->dsp-sz;
b9266c88495c *** empty log message ***
kono
parents: 42
diff changeset
2696 tmp_struct->dsp = disp;
b9266c88495c *** empty log message ***
kono
parents: 42
diff changeset
2697 } else {
b9266c88495c *** empty log message ***
kono
parents: 42
diff changeset
2698 tmp_struct = def(0);
b9266c88495c *** empty log message ***
kono
parents: 42
diff changeset
2699 }
b9266c88495c *** empty log message ***
kono
parents: 42
diff changeset
2700 } else {
b9266c88495c *** empty log message ***
kono
parents: 42
diff changeset
2701 tmp_struct = def(0);
b9266c88495c *** empty log message ***
kono
parents: 42
diff changeset
2702 }
b9266c88495c *** empty log message ***
kono
parents: 42
diff changeset
2703 e = list2(LVAR,tmp_struct->dsp);
b9266c88495c *** empty log message ***
kono
parents: 42
diff changeset
2704
39
c63c4fdeb9a7 struct done.
kono
parents: 38
diff changeset
2705 /* pass the pointer as an argument */
c63c4fdeb9a7 struct done.
kono
parents: 38
diff changeset
2706 /* this is recognized by called function declaration */
160
1f440a2790fb *** empty log message ***
kono
parents: 156
diff changeset
2707 /* but I don't know this sequence is compatible with gcc */
45
b9266c88495c *** empty log message ***
kono
parents: 42
diff changeset
2708
223
1ac647873577 *** empty log message ***
kono
parents: 221
diff changeset
2709 arglist = append3(arglist,list2(ADDRESS,e),list2(POINTER,type));
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2710 }
136
069960078249 remove redundant funcall argument for prototyped code in PowerPC case.
kono
parents: 135
diff changeset
2711 return list4(FUNCTION,e1,arglist,ftype);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2712 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2713
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
2714 static int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2715 typeid(int s)
d35df41eac69 Initial revision
kono
parents:
diff changeset
2716 {
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
2717 return (integral(s) || s==CODE || s==SHORT ||
176
kono
parents: 174
diff changeset
2718 s==LONG || s==STRUCT || s==UNION || s==ENUM ||
183
1d80ad165831 recursive macros
kono
parents: 182
diff changeset
2719 s==LONGLONG || s==FLOAT || s==DOUBLE || s==VOID ||
312
a93e619cf772 typeof, MIPS stdarg
kono
parents: 311
diff changeset
2720 s==ULONGLONG || s==TYPEOF ||
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2721 (s==IDENT && nptr->sc==TYPE));
d35df41eac69 Initial revision
kono
parents:
diff changeset
2722 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2723
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
2724 static int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2725 typename(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
2726 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
2727 int t;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2728
d35df41eac69 Initial revision
kono
parents:
diff changeset
2729 type=t=typespec();
d35df41eac69 Initial revision
kono
parents:
diff changeset
2730 ndecl0();
d35df41eac69 Initial revision
kono
parents:
diff changeset
2731 reverse(t);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2732 return type;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2733 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2734
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
2735 static int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2736 ndecl0(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
2737 {
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
2738 if(sym==MUL) {
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2739 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2740 return type=list2(POINTER,ndecl0());
d35df41eac69 Initial revision
kono
parents:
diff changeset
2741 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2742 return ndecl1();
d35df41eac69 Initial revision
kono
parents:
diff changeset
2743 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2744
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
2745 static int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2746 ndecl1(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
2747 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
2748 int i,t,arglist;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2749
d35df41eac69 Initial revision
kono
parents:
diff changeset
2750 if(sym==LPAR) {
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2751 if(getsym(0)==RPAR) {
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2752 type=list3(FUNCTION,type,0); getsym(0);
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
2753 } else {
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2754 ndecl0();
d35df41eac69 Initial revision
kono
parents:
diff changeset
2755 checksym(RPAR);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2756 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2757 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2758 while(1) {
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
2759 if(sym==LBRA) {
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2760 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2761 t=type;
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
2762 i=cexpr(expr(1));
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2763 checksym(RBRA);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2764 type=list3(ARRAY,t,i);
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
2765 } else if(sym==LPAR) {
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2766 t = type;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2767 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2768 arglist=0;
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
2769 while(sym!=RPAR) {
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2770 ndecl0();
d35df41eac69 Initial revision
kono
parents:
diff changeset
2771 arglist=list2(type,arglist);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2772 if(sym!=COMMA) break;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2773 getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2774 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2775 checksym(RPAR);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2776 type=list3(FUNCTION,t,arglist);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2777 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2778 else return type;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2779 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2780 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
2781
185
427008a06333 comment
kono
parents: 184
diff changeset
2782 static void
427008a06333 comment
kono
parents: 184
diff changeset
2783 get_name()
427008a06333 comment
kono
parents: 184
diff changeset
2784 {
427008a06333 comment
kono
parents: 184
diff changeset
2785 int i = 0;
427008a06333 comment
kono
parents: 184
diff changeset
2786 hash = 0;
427008a06333 comment
kono
parents: 184
diff changeset
2787 name = namebuf;
427008a06333 comment
kono
parents: 184
diff changeset
2788 while (alpha(ch) || digit(ch)) {
427008a06333 comment
kono
parents: 184
diff changeset
2789 if (i < LBUFSIZE-1)
427008a06333 comment
kono
parents: 184
diff changeset
2790 hash=(((7*hash)&0xfffffff) ^ (name[i++]=ch));
427008a06333 comment
kono
parents: 184
diff changeset
2791 getch();
427008a06333 comment
kono
parents: 184
diff changeset
2792 }
427008a06333 comment
kono
parents: 184
diff changeset
2793 name[i++] = '\0';
427008a06333 comment
kono
parents: 184
diff changeset
2794 }
427008a06333 comment
kono
parents: 184
diff changeset
2795
427008a06333 comment
kono
parents: 184
diff changeset
2796
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
2797 static int
321
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2798 is_ll()
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2799 {
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2800 if (ch=='U' || ch=='u') {
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2801 getch();
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2802 }
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2803 if (ch=='L'||ch=='l') {
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2804 if (getch()=='L'||ch=='l') {
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2805 getch();
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2806 return 1;
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2807 }
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2808 }
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2809 return 0;
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2810 }
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2811
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2812 static int
285
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2813 get_numerical()
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2814 {
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2815 int d;
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2816 char *scheapp;
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2817 /* numerical */
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2818
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2819 symval=0; d=0;
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2820 scheapp = cheapp;
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2821 if(ch=='.') {
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2822 getch();
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2823 if(ch=='.') {
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2824 getch();
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2825 if (ch=='.') {
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2826 getch();
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2827 return sym=DOTS;
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2828 }
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2829 error(CHERR);
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2830 return getsym(0);
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2831 } else if (!digit(ch))
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2832 return sym=PERIOD;
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2833 d=1;
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2834 *cheapp++ = '.'; /* .0 case */
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2835 } else if (ch == '0') {
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2836 if (getch() == 'x' || ch == 'X') {
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2837 /* hexadicimal */
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2838 while(1) {
321
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2839 getch(); *cheapp++ = ch;
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2840 if(digit(ch))
285
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2841 symval=symval*16+ch-'0';
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2842 else if('a'<=ch&&ch<='f')
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2843 symval=symval*16+ch-'a'+10;
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2844 else if('A'<=ch&&ch<='F')
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2845 symval=symval*16+ch-'A'+10;
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2846 else break;
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2847 }
321
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2848 if (is_ll()) {
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2849 #if LONGLONG_CODE
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2850 *cheapp++ = 0;
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2851 lsymval = strtoll(scheapp,0,0);
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2852 cheapp=scheapp;
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2853 return sym=LCONST;
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2854 #endif
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2855 }
285
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2856 return sym=CONST;
321
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2857 } else if (digit(ch)) {
285
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2858 /* octal */
321
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2859 while(1) {
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2860 getch(); *cheapp++ = ch;
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2861 if(digit(ch))
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2862 symval=symval*8+ch-'0';
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2863 else break;
285
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2864 }
321
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2865 if (is_ll()) {
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2866 #if LONGLONG_CODE
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2867 *cheapp++ = 0;
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2868 lsymval = strtoll(scheapp,0,0);
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2869 cheapp=scheapp;
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2870 return sym=LCONST;
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2871 #endif
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2872 }
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2873 cheapp=scheapp;
285
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2874 return sym=CONST;
304
9df8aa0497ea fix line continuation and #macro in string.
kono
parents: 303
diff changeset
2875 } else if (ch=='L'||ch=='U') { /* 0L or 0LL case */
321
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2876 if (is_ll()) {
285
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2877 #if LONGLONG_CODE
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2878 lsymval = 0;
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2879 return sym=LCONST;
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2880 #endif
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2881 }
321
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2882 } else if (ch=='.'||ch=='e') {
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2883 d=1;
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2884 *cheapp++ = '0'; /* 0. case */
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2885 } else {
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2886 cheapp=scheapp;
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2887 symval = 0;
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2888 return sym=CONST;
285
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2889 }
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2890 } else {
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2891 while(digit(ch)) {
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2892 *cheapp++ = ch;
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2893 symval=symval*10+ch-'0';getch();
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2894 }
321
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2895 if (ch=='.'||ch=='e') d=1;
285
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2896 }
321
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2897 if (!d) {
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2898 if (is_ll()) {
285
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2899 #if LONGLONG_CODE
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2900 *cheapp++ = 0;
321
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2901 lsymval = strtoll(scheapp,0,0);
285
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2902 cheapp=scheapp;
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2903 return sym=LCONST;
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2904 #endif
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2905 }
321
80beb03e5b73 ULL,ull, 0x0ull etc.
kono
parents: 318
diff changeset
2906 cheapp=scheapp;
285
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2907 return sym=CONST;
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2908 }
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2909 #if FLOAT_CODE
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2910 /* floating point case */
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2911 while(digit(ch)|| ch=='.'||ch=='e') {
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2912 *cheapp++ = ch;
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2913 getch();
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2914 if (ch=='-' && cheapp[-1]=='e') {
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2915 *cheapp++ = ch; getch();
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2916 } else if (ch=='+' && cheapp[-1]=='e') {
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2917 *cheapp++ = ch; getch();
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2918 }
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2919 }
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2920 *cheapp++ = 0;
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2921 dsymval = strtod(scheapp,0);
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2922 cheapp=scheapp;
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2923 return sym=DCONST;
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2924 #else
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2925 symval = 0;
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2926 return sym=CONST;
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2927 #endif
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2928 }
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2929
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
2930 extern int
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2931 getsym(int sc)
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2932 {
29
160e20394f80 macro function (imcomplete)
kono
parents: 28
diff changeset
2933 NMTBL *nptr0,*nptr1,*nptrm;
35
fd18d440f5ee macro function (works. but dirty. )
kono
parents: 34
diff changeset
2934 char c;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2935
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
2936 if (alpha(skipspc())) {
185
427008a06333 comment
kono
parents: 184
diff changeset
2937 get_name();
29
160e20394f80 macro function (imcomplete)
kono
parents: 28
diff changeset
2938
160e20394f80 macro function (imcomplete)
kono
parents: 28
diff changeset
2939 nptrm=msearch(name);
160e20394f80 macro function (imcomplete)
kono
parents: 28
diff changeset
2940 if (mode==MDECL) {
160e20394f80 macro function (imcomplete)
kono
parents: 28
diff changeset
2941 nptr = nptrm;
160e20394f80 macro function (imcomplete)
kono
parents: 28
diff changeset
2942 return (sym==MACRO);
160e20394f80 macro function (imcomplete)
kono
parents: 28
diff changeset
2943 }
160e20394f80 macro function (imcomplete)
kono
parents: 28
diff changeset
2944 if (mode==IFDEF) {
178
0f395aa93438 gcc include file
kono
parents: 177
diff changeset
2945 nptr = nptrm;
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
2946 if (nptrm->sc == MACRO||nptrm->sc==FMACRO) {
18
df7fa8cee67b pass -Wall
kono
parents: 16
diff changeset
2947 return (symval=1);
29
160e20394f80 macro function (imcomplete)
kono
parents: 28
diff changeset
2948 } else {
160e20394f80 macro function (imcomplete)
kono
parents: 28
diff changeset
2949 return (symval=0);
18
df7fa8cee67b pass -Wall
kono
parents: 16
diff changeset
2950 }
29
160e20394f80 macro function (imcomplete)
kono
parents: 28
diff changeset
2951 }
183
1d80ad165831 recursive macros
kono
parents: 182
diff changeset
2952 if ((nptrm->sc==MACRO&&neqname((char *)car(nptrm->dsp),name)) ||
1d80ad165831 recursive macros
kono
parents: 182
diff changeset
2953 (nptrm->sc==FMACRO&&skipspc()=='(')) {
185
427008a06333 comment
kono
parents: 184
diff changeset
2954 macro_expansion(nptrm);
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2955 return getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2956 }
185
427008a06333 comment
kono
parents: 184
diff changeset
2957 /* global variable name table */
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2958 nptr0 = gsearch(sc);
18
df7fa8cee67b pass -Wall
kono
parents: 16
diff changeset
2959 if (nptr0->sc == RESERVE) return sym = nptr0->dsp;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2960 sym = IDENT;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2961 gnptr=nptr=nptr0;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2962 if (mode==ADECL && nptr0->sc ==TYPE) return sym;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2963 if (mode==GDECL || mode==GSDECL || mode==GUDECL ||
177
352feeae4b0a macro else/ccout
kono
parents: 176
diff changeset
2964 mode==GTDECL || mode==TOP || mode==GEDECL) {
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2965 return sym;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2966 }
185
427008a06333 comment
kono
parents: 184
diff changeset
2967
427008a06333 comment
kono
parents: 184
diff changeset
2968 /* local variable name table */
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2969 nptr1=lsearch(nptr0->nm,sc);
18
df7fa8cee67b pass -Wall
kono
parents: 16
diff changeset
2970 if (mode==STAT) {
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2971 if (nptr1->sc == EMPTY) return sym;
18
df7fa8cee67b pass -Wall
kono
parents: 16
diff changeset
2972 }
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2973 nptr=nptr1;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2974 return sym;
185
427008a06333 comment
kono
parents: 184
diff changeset
2975
81
f94ca1168520 float first try...
kono
parents: 80
diff changeset
2976 } else if (digit(ch)||ch=='.') {
285
912b54949344 register assop const ( int/long )
kono
parents: 280
diff changeset
2977 return get_numerical();
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
2978 } else if(ch=='\'') {
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2979 getch();
d35df41eac69 Initial revision
kono
parents:
diff changeset
2980 symval=escape();
d35df41eac69 Initial revision
kono
parents:
diff changeset
2981 if(ch!='\'') error(CHERR);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2982 getch();
d35df41eac69 Initial revision
kono
parents:
diff changeset
2983 return sym=CONST;
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
2984 } else if(ch=='"') {
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2985 getstring();
d35df41eac69 Initial revision
kono
parents:
diff changeset
2986 return sym= STRING;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
2987 }
185
427008a06333 comment
kono
parents: 184
diff changeset
2988 /* 2 letters literal */
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
2989 c=ch;
d35df41eac69 Initial revision
kono
parents:
diff changeset
2990 getch();
d35df41eac69 Initial revision
kono
parents:
diff changeset
2991 switch(c) {
d35df41eac69 Initial revision
kono
parents:
diff changeset
2992 case '*':
d35df41eac69 Initial revision
kono
parents:
diff changeset
2993 return postequ(MUL,MUL+AS);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2994 case '&':
d35df41eac69 Initial revision
kono
parents:
diff changeset
2995 if(ch=='&') {getch();return sym=LAND;}
d35df41eac69 Initial revision
kono
parents:
diff changeset
2996 return postequ(BAND,BAND+AS);
d35df41eac69 Initial revision
kono
parents:
diff changeset
2997 case '-':
d35df41eac69 Initial revision
kono
parents:
diff changeset
2998 if(ch=='>') {getch();return sym=ARROW;}
d35df41eac69 Initial revision
kono
parents:
diff changeset
2999 if(ch=='-') {getch();return sym=DEC;}
d35df41eac69 Initial revision
kono
parents:
diff changeset
3000 return postequ(SUB,SUB+AS);
d35df41eac69 Initial revision
kono
parents:
diff changeset
3001 case '!':
d35df41eac69 Initial revision
kono
parents:
diff changeset
3002 return postequ(LNOT,NEQ);
d35df41eac69 Initial revision
kono
parents:
diff changeset
3003 case '~':
d35df41eac69 Initial revision
kono
parents:
diff changeset
3004 return sym=BNOT;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3005 case '+':
d35df41eac69 Initial revision
kono
parents:
diff changeset
3006 if(ch=='+') {getch();return sym=INC;}
d35df41eac69 Initial revision
kono
parents:
diff changeset
3007 return postequ(ADD,ADD+AS);
d35df41eac69 Initial revision
kono
parents:
diff changeset
3008 case '%':
d35df41eac69 Initial revision
kono
parents:
diff changeset
3009 return postequ(MOD,MOD+AS);
d35df41eac69 Initial revision
kono
parents:
diff changeset
3010 case '^':
d35df41eac69 Initial revision
kono
parents:
diff changeset
3011 return postequ(EOR,EOR+AS);
d35df41eac69 Initial revision
kono
parents:
diff changeset
3012 case '|':
d35df41eac69 Initial revision
kono
parents:
diff changeset
3013 if(ch=='|') {getch();return sym=LOR;}
d35df41eac69 Initial revision
kono
parents:
diff changeset
3014 return postequ(BOR,BOR+AS);
d35df41eac69 Initial revision
kono
parents:
diff changeset
3015 case '=':
d35df41eac69 Initial revision
kono
parents:
diff changeset
3016 return postequ(ASS,EQ);
d35df41eac69 Initial revision
kono
parents:
diff changeset
3017 case '>':
d35df41eac69 Initial revision
kono
parents:
diff changeset
3018 if(ch=='>') {getch();return postequ(RSHIFT,RSHIFT+AS);}
d35df41eac69 Initial revision
kono
parents:
diff changeset
3019 return postequ(GT,GE);
d35df41eac69 Initial revision
kono
parents:
diff changeset
3020 case '<':
d35df41eac69 Initial revision
kono
parents:
diff changeset
3021 if(ch=='<') {getch();return postequ(LSHIFT,LSHIFT+AS);}
d35df41eac69 Initial revision
kono
parents:
diff changeset
3022 return postequ(LT,LE);
d35df41eac69 Initial revision
kono
parents:
diff changeset
3023 case '(':
d35df41eac69 Initial revision
kono
parents:
diff changeset
3024 return sym=LPAR;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3025 case ')':
d35df41eac69 Initial revision
kono
parents:
diff changeset
3026 return sym=RPAR;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3027 case '[':
d35df41eac69 Initial revision
kono
parents:
diff changeset
3028 return sym=LBRA;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3029 case ']':
d35df41eac69 Initial revision
kono
parents:
diff changeset
3030 return sym=RBRA;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3031 case '{':
d35df41eac69 Initial revision
kono
parents:
diff changeset
3032 return sym=LC;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3033 case '}':
d35df41eac69 Initial revision
kono
parents:
diff changeset
3034 return sym=RC;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3035 case ',':
d35df41eac69 Initial revision
kono
parents:
diff changeset
3036 return sym=COMMA;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3037 case ':':
d35df41eac69 Initial revision
kono
parents:
diff changeset
3038 return sym=COLON;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3039 case '?':
d35df41eac69 Initial revision
kono
parents:
diff changeset
3040 return sym=COND;
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
3041 case ';':
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
3042 return sym=SM;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3043 case '/':
34
0756caa79167 macro function recursive and copy method
kono
parents: 33
diff changeset
3044 if(ch=='/') {
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
3045 in_comment = 1;
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
3046 conv->comment_('/'); conv->comment_('/');
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
3047 while(ch!='\n') { getch(); conv->comment_(ch); }
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
3048 in_comment = 0;
34
0756caa79167 macro function recursive and copy method
kono
parents: 33
diff changeset
3049 getch();
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
3050 return getsym(0);
34
0756caa79167 macro function recursive and copy method
kono
parents: 33
diff changeset
3051 }
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
3052 if(ch!='*') return postequ(DIV,DIV+AS);
20
8d3db5fc8a97 *** empty log message ***
kono
parents: 19
diff changeset
3053 in_comment = 1;
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
3054 conv->comment_('/'); conv->comment_('*');
66
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
3055 do {
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
3056 c=ch; getch(); conv->comment_(ch);
0b068058dd67 *** empty log message ***
kono
parents: 65
diff changeset
3057 } while(!(c=='*'&&ch=='/'));
20
8d3db5fc8a97 *** empty log message ***
kono
parents: 19
diff changeset
3058 in_comment = 0;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3059 getch();
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
3060 return getsym(0);
34
0756caa79167 macro function recursive and copy method
kono
parents: 33
diff changeset
3061 case 0:
0756caa79167 macro function recursive and copy method
kono
parents: 33
diff changeset
3062 case '\n':
182
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
3063 case '\f':
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
3064 case '\\':
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
3065 return getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3066 default:
d35df41eac69 Initial revision
kono
parents:
diff changeset
3067 error(CHERR);
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
3068 return getsym(0);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3069 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
3070 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
3071
179
fde8cb5d9254 *** empty log message ***
kono
parents: 178
diff changeset
3072
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
3073 static int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3074 postequ(int s1, int s2)
d35df41eac69 Initial revision
kono
parents:
diff changeset
3075 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
3076 if(ch=='=') {getch();return sym=s2;}
d35df41eac69 Initial revision
kono
parents:
diff changeset
3077 return sym=s1;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3078 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
3079
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3080 extern int
318
9fe0b32a7d57 asm continue...
kono
parents: 317
diff changeset
3081 alpha(int c)
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3082 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
3083 return(('a'<=c&&c<='z')||('A'<=c&&c<='Z')||c=='_');
d35df41eac69 Initial revision
kono
parents:
diff changeset
3084 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
3085
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3086 extern int
318
9fe0b32a7d57 asm continue...
kono
parents: 317
diff changeset
3087 digit(int c)
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3088 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
3089 return('0'<=c&&c<='9');
d35df41eac69 Initial revision
kono
parents:
diff changeset
3090 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
3091
37
412ad2e6c2a2 struct copy
kono
parents: 36
diff changeset
3092 int dummy_count = 0;
412ad2e6c2a2 struct copy
kono
parents: 36
diff changeset
3093
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3094 extern NMTBL *
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3095 anonymous_nptr()
37
412ad2e6c2a2 struct copy
kono
parents: 36
diff changeset
3096 {
412ad2e6c2a2 struct copy
kono
parents: 36
diff changeset
3097 NMTBL *nptr,*iptr;
412ad2e6c2a2 struct copy
kono
parents: 36
diff changeset
3098
412ad2e6c2a2 struct copy
kono
parents: 36
diff changeset
3099 iptr=nptr= &ntable[hash % GSYMS];
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
3100 while(nptr->sc!=0) {
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
3101 if (++nptr== &ntable[GSYMS])
37
412ad2e6c2a2 struct copy
kono
parents: 36
diff changeset
3102 nptr=ntable;
412ad2e6c2a2 struct copy
kono
parents: 36
diff changeset
3103 if (nptr==iptr) error(GSERR);
412ad2e6c2a2 struct copy
kono
parents: 36
diff changeset
3104 }
412ad2e6c2a2 struct copy
kono
parents: 36
diff changeset
3105 copy(nptr,"_00000");
412ad2e6c2a2 struct copy
kono
parents: 36
diff changeset
3106 dummy_count++;
412ad2e6c2a2 struct copy
kono
parents: 36
diff changeset
3107 if (dummy_count>999) error(STRERR);
412ad2e6c2a2 struct copy
kono
parents: 36
diff changeset
3108 nptr->nm[5]='0'+dummy_count%10;
412ad2e6c2a2 struct copy
kono
parents: 36
diff changeset
3109 nptr->nm[4]='0'+(dummy_count/10)%10;
412ad2e6c2a2 struct copy
kono
parents: 36
diff changeset
3110 nptr->nm[3]='0'+(dummy_count/100)%10;
412ad2e6c2a2 struct copy
kono
parents: 36
diff changeset
3111 nptr->sc=EMPTY;
412ad2e6c2a2 struct copy
kono
parents: 36
diff changeset
3112 return nptr;
412ad2e6c2a2 struct copy
kono
parents: 36
diff changeset
3113 }
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3114
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
3115 static NMTBL *
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
3116 gsearch(int sc)
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3117 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
3118 NMTBL *nptr,*iptr;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3119
d35df41eac69 Initial revision
kono
parents:
diff changeset
3120 iptr=nptr= &ntable[hash % GSYMS];
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
3121 while(nptr->sc!=0 && (neqname(nptr->nm,name) ||
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
3122 !(sc?(nptr->sc==sc):(nptr->sc!=TAG)))) {
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
3123 if (++nptr== &ntable[GSYMS])
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3124 nptr=ntable;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3125 if (nptr==iptr) error(GSERR);
d35df41eac69 Initial revision
kono
parents:
diff changeset
3126 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
3127 if (nptr->sc == 0) {
d35df41eac69 Initial revision
kono
parents:
diff changeset
3128 copy(nptr,name);
d35df41eac69 Initial revision
kono
parents:
diff changeset
3129 nptr->sc=EMPTY;
267
e7ab23c992e5 static double define fix
kono
parents: 265
diff changeset
3130 nptr->dsp=0;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3131 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
3132 return nptr;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3133 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
3134
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
3135 static NMTBL *
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
3136 lsearch(char *name,int sc)
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3137 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
3138 NMTBL *nptr,*iptr;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3139
d35df41eac69 Initial revision
kono
parents:
diff changeset
3140 iptr=nptr= &ntable[hash%LSYMS+GSYMS];
180
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
3141 while(nptr->sc!=0 && (neqname(nptr->nm,name) ||
f00e3bfa1b45 nkf.c compile (not correct)
kono
parents: 179
diff changeset
3142 !(sc?(nptr->sc==sc):(nptr->sc!=TAG)))) {
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
3143 if (++nptr== &ntable[LSYMS+GSYMS])
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3144 nptr= &ntable[GSYMS];
d35df41eac69 Initial revision
kono
parents:
diff changeset
3145 if (nptr==iptr) error(LSERR);
d35df41eac69 Initial revision
kono
parents:
diff changeset
3146 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
3147 if (nptr->sc == 0) {
d35df41eac69 Initial revision
kono
parents:
diff changeset
3148 nptr->nm=name; /* already saved in gsearch */
d35df41eac69 Initial revision
kono
parents:
diff changeset
3149 nptr->sc=EMPTY;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3150 nptr->dsp=0;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3151 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
3152 return nptr;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3153 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
3154
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
3155 static NMTBL *
29
160e20394f80 macro function (imcomplete)
kono
parents: 28
diff changeset
3156 msearch(char *name)
160e20394f80 macro function (imcomplete)
kono
parents: 28
diff changeset
3157 {
160e20394f80 macro function (imcomplete)
kono
parents: 28
diff changeset
3158 NMTBL *nptr,*iptr;
160e20394f80 macro function (imcomplete)
kono
parents: 28
diff changeset
3159
160e20394f80 macro function (imcomplete)
kono
parents: 28
diff changeset
3160 iptr=nptr= &mtable[hash%MSYMS];
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
3161 while(nptr->sc!=0 && neqname(nptr->nm,name)) {
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
3162 if (++nptr== &mtable[MSYMS])
30
20ed2786a276 still macro
kono
parents: 29
diff changeset
3163 nptr= &mtable[0];
29
160e20394f80 macro function (imcomplete)
kono
parents: 28
diff changeset
3164 if (nptr==iptr) error(MSERR);
160e20394f80 macro function (imcomplete)
kono
parents: 28
diff changeset
3165 }
160e20394f80 macro function (imcomplete)
kono
parents: 28
diff changeset
3166 if (nptr->sc == 0) {
160e20394f80 macro function (imcomplete)
kono
parents: 28
diff changeset
3167 copy(nptr,name);
160e20394f80 macro function (imcomplete)
kono
parents: 28
diff changeset
3168 nptr->sc=EMPTY;
160e20394f80 macro function (imcomplete)
kono
parents: 28
diff changeset
3169 nptr->dsp=0;
160e20394f80 macro function (imcomplete)
kono
parents: 28
diff changeset
3170 nptr->ty=0;
160e20394f80 macro function (imcomplete)
kono
parents: 28
diff changeset
3171 }
160e20394f80 macro function (imcomplete)
kono
parents: 28
diff changeset
3172 return nptr;
160e20394f80 macro function (imcomplete)
kono
parents: 28
diff changeset
3173 }
160e20394f80 macro function (imcomplete)
kono
parents: 28
diff changeset
3174
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3175 extern NMTBL *
30
20ed2786a276 still macro
kono
parents: 29
diff changeset
3176 msearch0(char *name)
20ed2786a276 still macro
kono
parents: 29
diff changeset
3177 {
20ed2786a276 still macro
kono
parents: 29
diff changeset
3178 NMTBL *nptr,*iptr;
20ed2786a276 still macro
kono
parents: 29
diff changeset
3179 int hash,i;
20ed2786a276 still macro
kono
parents: 29
diff changeset
3180
31
8b87de87eb54 *** empty log message ***
kono
parents: 30
diff changeset
3181 i = 0; hash = 0;
30
20ed2786a276 still macro
kono
parents: 29
diff changeset
3182 while((name[i])) {
116
b14ff9671c90 register offset fix
kono
parents: 115
diff changeset
3183 hash=(((7*hash)&0xfffffff) ^ (name[i++]));
30
20ed2786a276 still macro
kono
parents: 29
diff changeset
3184 }
20ed2786a276 still macro
kono
parents: 29
diff changeset
3185 iptr=nptr= &mtable[hash%MSYMS];
20ed2786a276 still macro
kono
parents: 29
diff changeset
3186 while(nptr->sc!=0 && neqname(nptr->nm,name)) {
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
3187 if (++nptr== &mtable[MSYMS])
30
20ed2786a276 still macro
kono
parents: 29
diff changeset
3188 nptr= &mtable[0];
20ed2786a276 still macro
kono
parents: 29
diff changeset
3189 if (nptr==iptr) error(MSERR);
20ed2786a276 still macro
kono
parents: 29
diff changeset
3190 }
20ed2786a276 still macro
kono
parents: 29
diff changeset
3191 if (nptr->sc == 0) {
20ed2786a276 still macro
kono
parents: 29
diff changeset
3192 copy(nptr,name);
20ed2786a276 still macro
kono
parents: 29
diff changeset
3193 nptr->sc=EMPTY;
20ed2786a276 still macro
kono
parents: 29
diff changeset
3194 nptr->dsp=0;
20ed2786a276 still macro
kono
parents: 29
diff changeset
3195 nptr->ty=0;
20ed2786a276 still macro
kono
parents: 29
diff changeset
3196 }
20ed2786a276 still macro
kono
parents: 29
diff changeset
3197 return nptr;
20ed2786a276 still macro
kono
parents: 29
diff changeset
3198 }
20ed2786a276 still macro
kono
parents: 29
diff changeset
3199
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3200 extern void
185
427008a06333 comment
kono
parents: 184
diff changeset
3201 extern_define(char *s,int d,int type,int use)
427008a06333 comment
kono
parents: 184
diff changeset
3202 {
427008a06333 comment
kono
parents: 184
diff changeset
3203 NMTBL *nptr0;
427008a06333 comment
kono
parents: 184
diff changeset
3204 int i;
427008a06333 comment
kono
parents: 184
diff changeset
3205
427008a06333 comment
kono
parents: 184
diff changeset
3206 hash=0; name=namebuf; i=0;
427008a06333 comment
kono
parents: 184
diff changeset
3207 while((name[i++] = *s)) {
427008a06333 comment
kono
parents: 184
diff changeset
3208 hash=(((7*hash)&0xfffffff) ^ (*s)); s++;
427008a06333 comment
kono
parents: 184
diff changeset
3209 }
427008a06333 comment
kono
parents: 184
diff changeset
3210 if (cheapp+i >= cheap+CHEAPSIZE) error(STRERR);
427008a06333 comment
kono
parents: 184
diff changeset
3211 name[i++] = 0;
427008a06333 comment
kono
parents: 184
diff changeset
3212 (nptr0 = gsearch(0))->sc = EXTRN;
427008a06333 comment
kono
parents: 184
diff changeset
3213 nptr0->dsp = d; nptr0->ty=type;
427008a06333 comment
kono
parents: 184
diff changeset
3214 if (use) extrn_use(nptr0);
427008a06333 comment
kono
parents: 184
diff changeset
3215 }
427008a06333 comment
kono
parents: 184
diff changeset
3216
30
20ed2786a276 still macro
kono
parents: 29
diff changeset
3217
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
3218 static void
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3219 copy(NMTBL *nptr, char *s)
d35df41eac69 Initial revision
kono
parents:
diff changeset
3220 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
3221 nptr->nm = cheapp;
18
df7fa8cee67b pass -Wall
kono
parents: 16
diff changeset
3222 while((*cheapp++ = *s++));
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3223 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
3224
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3225 extern int
30
20ed2786a276 still macro
kono
parents: 29
diff changeset
3226 neqname(char *p,char *q)
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3227 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
3228 if (!p)
d35df41eac69 Initial revision
kono
parents:
diff changeset
3229 return 0;
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
3230 while(*p && *p!='.')
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3231 if(*p++ != *q++) return 1;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3232 return (*q!=0);
d35df41eac69 Initial revision
kono
parents:
diff changeset
3233 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
3234
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
3235 static void
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3236 getstring(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
3237 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
3238 symval = 0;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3239 sptr = cheapp;
304
9df8aa0497ea fix line continuation and #macro in string.
kono
parents: 303
diff changeset
3240 while (ch == '"') {
9df8aa0497ea fix line continuation and #macro in string.
kono
parents: 303
diff changeset
3241 in_quote = 1;
9df8aa0497ea fix line continuation and #macro in string.
kono
parents: 303
diff changeset
3242 getch();
9df8aa0497ea fix line continuation and #macro in string.
kono
parents: 303
diff changeset
3243 while (ch != '"') {
9df8aa0497ea fix line continuation and #macro in string.
kono
parents: 303
diff changeset
3244 *cheapp++ = escape();
9df8aa0497ea fix line continuation and #macro in string.
kono
parents: 303
diff changeset
3245 symval++;
9df8aa0497ea fix line continuation and #macro in string.
kono
parents: 303
diff changeset
3246 if (cheapp >= cheap+CHEAPSIZE) error(STRERR);
9df8aa0497ea fix line continuation and #macro in string.
kono
parents: 303
diff changeset
3247 }
9df8aa0497ea fix line continuation and #macro in string.
kono
parents: 303
diff changeset
3248 in_quote = 0;
9df8aa0497ea fix line continuation and #macro in string.
kono
parents: 303
diff changeset
3249 getch();
9df8aa0497ea fix line continuation and #macro in string.
kono
parents: 303
diff changeset
3250 skipspc();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3251 }
304
9df8aa0497ea fix line continuation and #macro in string.
kono
parents: 303
diff changeset
3252 in_quote = 0;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3253 *cheapp++ = '\0';
d35df41eac69 Initial revision
kono
parents:
diff changeset
3254 symval++;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3255 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
3256
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3257 extern int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3258 skipspc(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
3259 {
182
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
3260 static int topspc = 0;
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
3261
67
254a0c576114 argument type list
kono
parents: 66
diff changeset
3262 while(ch=='\t'||ch=='\n'||ch==' '||ch=='\r') {
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
3263 if (ch=='\n'||ch=='\r') topspc=1;
dba8d111b7a0 c output
kono
parents: 68
diff changeset
3264 if (topspc)
dba8d111b7a0 c output
kono
parents: 68
diff changeset
3265 conv->comment_(ch);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3266 getch();
67
254a0c576114 argument type list
kono
parents: 66
diff changeset
3267 }
69
dba8d111b7a0 c output
kono
parents: 68
diff changeset
3268 topspc=0;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3269 return ch;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3270 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
3271
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3272 extern int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3273 getch(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
3274 {
275
8f09f8bbc494 MIPS switch statement. basic.c passed.
kono
parents: 273
diff changeset
3275 int i,j;
115
ebac635814dc fix nested macro function
kono
parents: 114
diff changeset
3276 if(*chptr)
ebac635814dc fix nested macro function
kono
parents: 114
diff changeset
3277 return ch = *chptr++;
34
0756caa79167 macro function recursive and copy method
kono
parents: 33
diff changeset
3278 else if (chptrsave) {
115
ebac635814dc fix nested macro function
kono
parents: 114
diff changeset
3279 chptr = (char *)car(chptrsave);
ebac635814dc fix nested macro function
kono
parents: 114
diff changeset
3280 ch = car(chsave);
275
8f09f8bbc494 MIPS switch statement. basic.c passed.
kono
parents: 273
diff changeset
3281 i = cadr(chptrsave);
8f09f8bbc494 MIPS switch statement. basic.c passed.
kono
parents: 273
diff changeset
3282 j = cadr(chsave);
8f09f8bbc494 MIPS switch statement. basic.c passed.
kono
parents: 273
diff changeset
3283 free_glist2(chptrsave);
8f09f8bbc494 MIPS switch statement. basic.c passed.
kono
parents: 273
diff changeset
3284 free_glist2(chsave);
8f09f8bbc494 MIPS switch statement. basic.c passed.
kono
parents: 273
diff changeset
3285 chptrsave = i;
8f09f8bbc494 MIPS switch statement. basic.c passed.
kono
parents: 273
diff changeset
3286 chsave = j;
34
0756caa79167 macro function recursive and copy method
kono
parents: 33
diff changeset
3287 return ch;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3288 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
3289 getline();
182
e1e9ec8c96a7 some fix
kono
parents: 181
diff changeset
3290 if (in_macro_if) check_macro_eof();
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3291 return getch();
d35df41eac69 Initial revision
kono
parents:
diff changeset
3292 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
3293
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3294 static int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3295 escape(void)
d35df41eac69 Initial revision
kono
parents:
diff changeset
3296 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
3297 char c;
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
3298 if ((c=ch) == '\\') {
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
3299 if (digit(c=getch())) {
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3300 c = ch-'0';
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
3301 if (digit(getch())) {
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3302 c = c*8+ch-'0';
d35df41eac69 Initial revision
kono
parents:
diff changeset
3303 if (digit(getch())) {
d35df41eac69 Initial revision
kono
parents:
diff changeset
3304 c=c*8+ch-'0';getch();
d35df41eac69 Initial revision
kono
parents:
diff changeset
3305 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
3306 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
3307 return c;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3308 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
3309 getch();
d35df41eac69 Initial revision
kono
parents:
diff changeset
3310 switch(c) {
d35df41eac69 Initial revision
kono
parents:
diff changeset
3311 case 'n':
d35df41eac69 Initial revision
kono
parents:
diff changeset
3312 return '\n';
d35df41eac69 Initial revision
kono
parents:
diff changeset
3313 case 't':
d35df41eac69 Initial revision
kono
parents:
diff changeset
3314 return '\t';
d35df41eac69 Initial revision
kono
parents:
diff changeset
3315 case 'b':
d35df41eac69 Initial revision
kono
parents:
diff changeset
3316 return '\b';
d35df41eac69 Initial revision
kono
parents:
diff changeset
3317 case 'r':
d35df41eac69 Initial revision
kono
parents:
diff changeset
3318 return '\r';
d35df41eac69 Initial revision
kono
parents:
diff changeset
3319 case 'f':
d35df41eac69 Initial revision
kono
parents:
diff changeset
3320 return '\f';
116
b14ff9671c90 register offset fix
kono
parents: 115
diff changeset
3321 case '\\':
b14ff9671c90 register offset fix
kono
parents: 115
diff changeset
3322 return '\\';
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3323 case '\n':
304
9df8aa0497ea fix line continuation and #macro in string.
kono
parents: 303
diff changeset
3324 if (ch=='"') {
9df8aa0497ea fix line continuation and #macro in string.
kono
parents: 303
diff changeset
3325 return 0;
9df8aa0497ea fix line continuation and #macro in string.
kono
parents: 303
diff changeset
3326 }
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3327 return escape();
d35df41eac69 Initial revision
kono
parents:
diff changeset
3328 default:
d35df41eac69 Initial revision
kono
parents:
diff changeset
3329 return c;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3330 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
3331 }
304
9df8aa0497ea fix line continuation and #macro in string.
kono
parents: 303
diff changeset
3332 // if (c == '\n') error(EXERR);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3333 getch();
d35df41eac69 Initial revision
kono
parents:
diff changeset
3334 return c;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3335 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
3336
185
427008a06333 comment
kono
parents: 184
diff changeset
3337 /* node management (cdr coding ) */
427008a06333 comment
kono
parents: 184
diff changeset
3338
195
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
3339 #if LONGLONG_CODE
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
3340
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3341 extern int
195
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
3342 llist2(int e1, long long d1)
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
3343 {
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
3344 int e;
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
3345
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
3346 e=getfree((size_of_int+size_of_longlong)/size_of_int);
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
3347 heap[e]=e1;
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
3348 lcadr(e)=d1;
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
3349 return e;
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
3350 }
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
3351
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3352 extern int
195
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
3353 llist3(int e1, int e2,long long d1)
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
3354 {
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
3355 int e;
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
3356
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
3357 e=getfree((size_of_int+size_of_longlong)/size_of_int);
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
3358 heap[e]=e1;
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
3359 heap[e+1]=e2;
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
3360 lcaddr(e)=d1;
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
3361 return e;
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
3362 }
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
3363
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
3364 #endif
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
3365
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
3366 #if FLOAT_CODE
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
3367
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3368 extern int
81
f94ca1168520 float first try...
kono
parents: 80
diff changeset
3369 dlist2(int e1, double d1)
f94ca1168520 float first try...
kono
parents: 80
diff changeset
3370 {
f94ca1168520 float first try...
kono
parents: 80
diff changeset
3371 int e;
f94ca1168520 float first try...
kono
parents: 80
diff changeset
3372
f94ca1168520 float first try...
kono
parents: 80
diff changeset
3373 e=getfree((size_of_int+size_of_double)/size_of_int);
f94ca1168520 float first try...
kono
parents: 80
diff changeset
3374 heap[e]=e1;
f94ca1168520 float first try...
kono
parents: 80
diff changeset
3375 dcadr(e)=d1;
f94ca1168520 float first try...
kono
parents: 80
diff changeset
3376 return e;
f94ca1168520 float first try...
kono
parents: 80
diff changeset
3377 }
f94ca1168520 float first try...
kono
parents: 80
diff changeset
3378
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3379 extern int
81
f94ca1168520 float first try...
kono
parents: 80
diff changeset
3380 dlist3(int e1, int e2,double d1)
f94ca1168520 float first try...
kono
parents: 80
diff changeset
3381 {
f94ca1168520 float first try...
kono
parents: 80
diff changeset
3382 int e;
f94ca1168520 float first try...
kono
parents: 80
diff changeset
3383
f94ca1168520 float first try...
kono
parents: 80
diff changeset
3384 e=getfree((size_of_int*2+size_of_double)/size_of_int);
f94ca1168520 float first try...
kono
parents: 80
diff changeset
3385 heap[e]=e1;
f94ca1168520 float first try...
kono
parents: 80
diff changeset
3386 heap[e+1]=e2;
f94ca1168520 float first try...
kono
parents: 80
diff changeset
3387 dcaddr(e)=d1;
f94ca1168520 float first try...
kono
parents: 80
diff changeset
3388 return e;
f94ca1168520 float first try...
kono
parents: 80
diff changeset
3389 }
f94ca1168520 float first try...
kono
parents: 80
diff changeset
3390
195
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
3391 #endif
c193120ee2a6 *** empty log message ***
kono
parents: 194
diff changeset
3392
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3393 extern int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3394 list2(int e1, int e2)
d35df41eac69 Initial revision
kono
parents:
diff changeset
3395 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
3396 int e;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3397
d35df41eac69 Initial revision
kono
parents:
diff changeset
3398 e=getfree(2);
d35df41eac69 Initial revision
kono
parents:
diff changeset
3399 heap[e]=e1;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3400 heap[e+1]=e2;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3401 return e;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3402 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
3403
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3404 extern int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3405 list3(int e1, int e2, int e3)
d35df41eac69 Initial revision
kono
parents:
diff changeset
3406 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
3407 int e;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3408
d35df41eac69 Initial revision
kono
parents:
diff changeset
3409 e=getfree(3);
d35df41eac69 Initial revision
kono
parents:
diff changeset
3410 heap[e]=e1;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3411 heap[e+1]=e2;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3412 heap[e+2]=e3;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3413 return e;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3414 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
3415
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3416 extern int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3417 list4(int e1, int e2, int e3, int e4)
d35df41eac69 Initial revision
kono
parents:
diff changeset
3418 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
3419 int e;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3420
d35df41eac69 Initial revision
kono
parents:
diff changeset
3421 e=getfree(4);
d35df41eac69 Initial revision
kono
parents:
diff changeset
3422 heap[e]=e1;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3423 heap[e+1]=e2;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3424 heap[e+2]=e3;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3425 heap[e+3]=e4;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3426 return e;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3427 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
3428
61
8ffb8ca3fe34 separation of architecture dependent part.
kono
parents: 59
diff changeset
3429 static int
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3430 getfree(int n)
d35df41eac69 Initial revision
kono
parents:
diff changeset
3431 {
d35df41eac69 Initial revision
kono
parents:
diff changeset
3432 int e;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3433
d35df41eac69 Initial revision
kono
parents:
diff changeset
3434 switch (mode) {
d35df41eac69 Initial revision
kono
parents:
diff changeset
3435 case GDECL: case GSDECL: case GUDECL: case GTDECL:
178
0f395aa93438 gcc include file
kono
parents: 177
diff changeset
3436 case MDECL: case ADECL: case LSDECL: case LUDECL: case GEDECL:
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3437 e=gfree;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3438 gfree+=n;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3439 break;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3440 default:
d35df41eac69 Initial revision
kono
parents:
diff changeset
3441 lfree-=n;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3442 e=lfree;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3443 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
3444 if(lfree<gfree) error(HPERR);
d35df41eac69 Initial revision
kono
parents:
diff changeset
3445 return e;
d35df41eac69 Initial revision
kono
parents:
diff changeset
3446 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
3447
117
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3448 static int free_glist2_list = 0;
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3449 static int free_glist3_list = 0;
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3450
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3451 extern int
33
8500dbb69dd9 bad macro processing. give up this method.
kono
parents: 32
diff changeset
3452 glist2(int e1,int e2)
8500dbb69dd9 bad macro processing. give up this method.
kono
parents: 32
diff changeset
3453 {
8500dbb69dd9 bad macro processing. give up this method.
kono
parents: 32
diff changeset
3454 int smode,ret;
117
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3455 if (free_glist2_list) {
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3456 ret = free_glist2_list;
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3457 free_glist2_list = cadr(free_glist2_list);
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3458 car(ret)=e1; cadr(ret)=e2;
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3459 return ret;
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3460 }
33
8500dbb69dd9 bad macro processing. give up this method.
kono
parents: 32
diff changeset
3461 smode = mode;
8500dbb69dd9 bad macro processing. give up this method.
kono
parents: 32
diff changeset
3462 mode = GDECL;
8500dbb69dd9 bad macro processing. give up this method.
kono
parents: 32
diff changeset
3463 ret = list2(e1,e2);
8500dbb69dd9 bad macro processing. give up this method.
kono
parents: 32
diff changeset
3464 mode = smode;
8500dbb69dd9 bad macro processing. give up this method.
kono
parents: 32
diff changeset
3465 return ret;
8500dbb69dd9 bad macro processing. give up this method.
kono
parents: 32
diff changeset
3466 }
8500dbb69dd9 bad macro processing. give up this method.
kono
parents: 32
diff changeset
3467
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3468 extern void
117
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3469 free_glist2(int e1)
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3470 {
206
4170cefb48f6 *** empty log message ***
kono
parents: 204
diff changeset
3471 if (e1>gfree) return; /* freeing local heap */
117
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3472 if (e1==gfree) {
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3473 gfree-=2;
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3474 } else {
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3475 cadr(e1) = free_glist2_list;
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3476 free_glist2_list = e1;
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3477 }
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3478 }
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3479
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3480 extern int
95
185d2cc6a3a9 *** empty log message ***
kono
parents: 94
diff changeset
3481 glist3(int e1,int e2,int e3)
185d2cc6a3a9 *** empty log message ***
kono
parents: 94
diff changeset
3482 {
185d2cc6a3a9 *** empty log message ***
kono
parents: 94
diff changeset
3483 int smode,ret;
117
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3484 if (free_glist3_list) {
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3485 ret = free_glist3_list;
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3486 free_glist3_list = cadr(free_glist3_list);
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3487 car(ret)=e1; cadr(ret)=e2; caddr(ret)=e3;
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3488 return ret;
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3489 }
95
185d2cc6a3a9 *** empty log message ***
kono
parents: 94
diff changeset
3490 smode = mode;
185d2cc6a3a9 *** empty log message ***
kono
parents: 94
diff changeset
3491 mode = GDECL;
185d2cc6a3a9 *** empty log message ***
kono
parents: 94
diff changeset
3492 ret = list3(e1,e2,e3);
185d2cc6a3a9 *** empty log message ***
kono
parents: 94
diff changeset
3493 mode = smode;
185d2cc6a3a9 *** empty log message ***
kono
parents: 94
diff changeset
3494 return ret;
185d2cc6a3a9 *** empty log message ***
kono
parents: 94
diff changeset
3495 }
185d2cc6a3a9 *** empty log message ***
kono
parents: 94
diff changeset
3496
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3497 extern void
117
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3498 free_glist3(int e1)
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3499 {
206
4170cefb48f6 *** empty log message ***
kono
parents: 204
diff changeset
3500 if (e1>gfree) return; /* freeing local heap */
117
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3501 if (e1==gfree) {
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3502 gfree-=3;
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3503 } else {
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3504 cadr(e1) = free_glist3_list;
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3505 free_glist3_list = e1;
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3506 }
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3507 }
2d5a203cc3a6 lvar reuse
kono
parents: 116
diff changeset
3508
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3509 extern int
318
9fe0b32a7d57 asm continue...
kono
parents: 317
diff changeset
3510 length(int list)
9fe0b32a7d57 asm continue...
kono
parents: 317
diff changeset
3511 {
9fe0b32a7d57 asm continue...
kono
parents: 317
diff changeset
3512 int n=0;
9fe0b32a7d57 asm continue...
kono
parents: 317
diff changeset
3513 for(;list;n++) {
9fe0b32a7d57 asm continue...
kono
parents: 317
diff changeset
3514 list = cadr(list);
9fe0b32a7d57 asm continue...
kono
parents: 317
diff changeset
3515 }
9fe0b32a7d57 asm continue...
kono
parents: 317
diff changeset
3516 return n;
9fe0b32a7d57 asm continue...
kono
parents: 317
diff changeset
3517 }
9fe0b32a7d57 asm continue...
kono
parents: 317
diff changeset
3518
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3519 extern int
318
9fe0b32a7d57 asm continue...
kono
parents: 317
diff changeset
3520 nth(int n, int list)
9fe0b32a7d57 asm continue...
kono
parents: 317
diff changeset
3521 {
9fe0b32a7d57 asm continue...
kono
parents: 317
diff changeset
3522 while(n-->0) {
9fe0b32a7d57 asm continue...
kono
parents: 317
diff changeset
3523 list = cadr(list);
9fe0b32a7d57 asm continue...
kono
parents: 317
diff changeset
3524 }
9fe0b32a7d57 asm continue...
kono
parents: 317
diff changeset
3525 return list;
9fe0b32a7d57 asm continue...
kono
parents: 317
diff changeset
3526 }
9fe0b32a7d57 asm continue...
kono
parents: 317
diff changeset
3527
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3528 extern int
309
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
3529 insert_ascend(int p,int e,int eq())
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3530 {
309
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
3531 int p1,p2,dup;
293
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
3532 if(!p) return e;
309
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
3533 if (car(p)==car(e)) {
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
3534 if ((dup=eq())==0) // duplicate value is not override
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
3535 return p;
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
3536 else if (dup==2) { // keep unique allow override
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
3537 cadr(e) = cadr(p); // skip one
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
3538 return e;
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
3539 } // any other value allows duplicate
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
3540 } else if (car(p)>car(e)) {
293
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
3541 cadr(e) = p;
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
3542 return e;
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
3543 }
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
3544 p1=p;
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
3545 while(cadr(p)) {
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
3546 p = cadr(p2=p);
309
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
3547 if (car(p)==car(e)) {
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
3548 if ((dup=eq())==0) // duplicate value is not override
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
3549 return p1;
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
3550 else if (dup==2) { // keep unique allow override
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
3551 cadr(e) = cadr(p); // skip one
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
3552 cadr(p2) = e;
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
3553 return p1;
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
3554 } // any other value allows duplicate
a86612cf1a19 struct partial initialization (local struct copy)
kono
parents: 308
diff changeset
3555 } else if (car(p)>=car(e)) {
293
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
3556 cadr(e) = cadr(p2);
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
3557 cadr(p2) = e;
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
3558 return p1;
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
3559 }
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
3560 }
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
3561 cadr(p) = e;
5bf2c3070d36 sort case value
kono
parents: 292
diff changeset
3562 return p1;
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3563 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
3564
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3565 extern int
55
94564b45c4f3 all save implementation of parallel assignment
kono
parents: 53
diff changeset
3566 append4(int p,int a1,int a2,int a3)
94564b45c4f3 all save implementation of parallel assignment
kono
parents: 53
diff changeset
3567 {
94564b45c4f3 all save implementation of parallel assignment
kono
parents: 53
diff changeset
3568 int p1;
94564b45c4f3 all save implementation of parallel assignment
kono
parents: 53
diff changeset
3569 if(!p) return list4(a1,0,a2,a3);
94564b45c4f3 all save implementation of parallel assignment
kono
parents: 53
diff changeset
3570 p1=p;
94564b45c4f3 all save implementation of parallel assignment
kono
parents: 53
diff changeset
3571 while(cadr(p)) p = cadr(p);
188
4303255fc3cf minor fix
kono
parents: 187
diff changeset
3572 cadr(p) = list4(a1,0,a2,a3);
55
94564b45c4f3 all save implementation of parallel assignment
kono
parents: 53
diff changeset
3573 return p1;
94564b45c4f3 all save implementation of parallel assignment
kono
parents: 53
diff changeset
3574 }
94564b45c4f3 all save implementation of parallel assignment
kono
parents: 53
diff changeset
3575
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3576 extern int
46
b1c8ac8c308d fix cascading struct retrun. Now it should be compatible with gcc
kono
parents: 45
diff changeset
3577 append3(int p,int a1,int a2)
b1c8ac8c308d fix cascading struct retrun. Now it should be compatible with gcc
kono
parents: 45
diff changeset
3578 {
b1c8ac8c308d fix cascading struct retrun. Now it should be compatible with gcc
kono
parents: 45
diff changeset
3579 int p1;
b1c8ac8c308d fix cascading struct retrun. Now it should be compatible with gcc
kono
parents: 45
diff changeset
3580 if(!p) return list3(a1,0,a2);
b1c8ac8c308d fix cascading struct retrun. Now it should be compatible with gcc
kono
parents: 45
diff changeset
3581 p1=p;
b1c8ac8c308d fix cascading struct retrun. Now it should be compatible with gcc
kono
parents: 45
diff changeset
3582 while(cadr(p)) p = cadr(p);
188
4303255fc3cf minor fix
kono
parents: 187
diff changeset
3583 cadr(p) = list3(a1,0,a2);
46
b1c8ac8c308d fix cascading struct retrun. Now it should be compatible with gcc
kono
parents: 45
diff changeset
3584 return p1;
b1c8ac8c308d fix cascading struct retrun. Now it should be compatible with gcc
kono
parents: 45
diff changeset
3585 }
b1c8ac8c308d fix cascading struct retrun. Now it should be compatible with gcc
kono
parents: 45
diff changeset
3586
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3587 extern void
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3588 display_ntable(NMTBL *n, char *s)
d35df41eac69 Initial revision
kono
parents:
diff changeset
3589 {
94
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
3590 fprintf(stderr,"\n%s %0x %0x ",s,(int)n,(int)ntable);
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
3591 fprintf(stderr,"nptr->sc %d ",n->sc);
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
3592 fprintf(stderr,"nptr->dsp %d ",n->dsp);
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
3593 fprintf(stderr,"nptr->ty %d ",n->ty);
1ad7045741a7 float dbinop fix
kono
parents: 87
diff changeset
3594 fprintf(stderr,"nptr->nm %s\n",n->nm);
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3595 }
d35df41eac69 Initial revision
kono
parents:
diff changeset
3596
327
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3597 /* for gdb... */
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3598
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3599 extern int c0(int d) { fprintf(stderr,"heap[%d]=",d);return car(d); }
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3600 extern int c1(int d) { fprintf(stderr,"heap[%d]=",d);return cadr(d); }
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3601 extern int c2(int d) { fprintf(stderr,"heap[%d]=",d);return caddr(d); }
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3602 extern int c3(int d) { fprintf(stderr,"heap[%d]=",d);return cadddr(d); }
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3603 extern char *cc0(int d) { fprintf(stderr,"heap[%d]=",d);return (char *)car(d); }
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3604 extern char *cc1(int d) { fprintf(stderr,"heap[%d]=",d);return (char *)cadr(d); }
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3605 extern char *cc2(int d) { fprintf(stderr,"heap[%d]=",d);return (char *)caddr(d); }
da2e3f2d127d macro/codegen reorganization
kono
parents: 326
diff changeset
3606 extern char *cc3(int d) { fprintf(stderr,"heap[%d]=",d);return (char *)cadddr(d); }
37
412ad2e6c2a2 struct copy
kono
parents: 36
diff changeset
3607
0
d35df41eac69 Initial revision
kono
parents:
diff changeset
3608 /* end */