* ILParser.jay: Use the extern table for all extern type
[mono.git] / mcs / ilasm / parser / ILParser.jay
1 %{\r
2 //\r
3 // Mono::ILASM::ILParser\r
4 // \r
5 // (C) Sergey Chaban (serge@wildwestsoftware.com)\r
6 // (C) 2003 Jackson Harper, All rights reserved\r
7 //\r
8 \r
9 using PEAPI;\r
10 using System;\r
11 using System.IO;\r
12 using System.Collections;\r
13 using System.Globalization;\r
14 \r
15 namespace Mono.ILASM {\r
16 \r
17         public class ILParser {\r
18 \r
19                 private CodeGen codegen;\r
20 \r
21                 private bool is_value_class;\r
22                 private bool is_enum_class;\r
23                 private bool pinvoke_info;\r
24                 private string pinvoke_mod;\r
25                 private string pinvoke_meth;\r
26                 private PEAPI.PInvokeAttr pinvoke_attr;\r
27                 private StreamReader stream;\r
28                                 \r
29                 public ILParser (CodeGen codegen, StreamReader stream) {\r
30                         this.codegen = codegen;\r
31                         this.stream = stream;\r
32                 }\r
33 \r
34                 public CodeGen CodeGen {\r
35                         get { return codegen; }\r
36                 }\r
37                 \r
38 %}\r
39 \r
40 %token EOF\r
41 \r
42 /* ID - alpha-numeric identifier */\r
43 %token ID\r
44 \r
45 /* QSTRING - quoted string */\r
46 %token QSTRING\r
47 \r
48 /* SQSTRING - single quoted string */\r
49 %token SQSTRING\r
50 \r
51 /* COMP_NAME - A name with dots */\r
52 %token COMP_NAME\r
53 \r
54 /* INT32 - 32 bit integer */\r
55 %token INT32\r
56 \r
57 /* INT64 - 64 bit integer */\r
58 %token INT64\r
59 \r
60 /* FLOAT64 - floating point number */\r
61 %token FLOAT64\r
62 \r
63 /* HEXBYTE - two digit hex number */\r
64 %token HEXBYTE\r
65 \r
66 \r
67 /* Punctuation */\r
68 %token DOT           "."\r
69 %token OPEN_BRACE    "{"\r
70 %token CLOSE_BRACE   "}"\r
71 %token OPEN_BRACKET  "["\r
72 %token CLOSE_BRACKET "]"\r
73 %token OPEN_PARENS   "("\r
74 %token CLOSE_PARENS  ")"\r
75 %token COMMA         ","\r
76 %token COLON         ":"\r
77 %token DOUBLE_COLON  "::"\r
78 %token SEMICOLON     ";"\r
79 %token ASSIGN        "="\r
80 %token STAR          "*"\r
81 %token AMPERSAND     "&"\r
82 %token PLUS          "+"\r
83 %token SLASH         "/"\r
84 %token BANG          "!"\r
85 %token ELLIPSIS      "..."\r
86 %token DASH          "-"\r
87 %token OPEN_ANGLE_BRACKET   "<"\r
88 %token CLOSE_ANGLE_BRACKET  ">"\r
89 \r
90 \r
91 \r
92 %token UNKNOWN\r
93 \r
94 \r
95 /* INSTR_* instruction types */\r
96 %token INSTR_NONE\r
97 %token INSTR_VAR\r
98 %token INSTR_I\r
99 %token INSTR_I8\r
100 %token INSTR_R\r
101 %token INSTR_BRTARGET\r
102 %token INSTR_METHOD\r
103 %token INSTR_NEWOBJ\r
104 %token INSTR_FIELD\r
105 %token INSTR_TYPE\r
106 %token INSTR_STRING\r
107 %token INSTR_SIG\r
108 %token INSTR_RVA\r
109 %token INSTR_TOK\r
110 %token INSTR_SWITCH\r
111 %token INSTR_PHI\r
112 %token INSTR_LOCAL\r
113 %token INSTR_PARAM\r
114 \r
115 \r
116 \r
117 \r
118 \r
119 /* Mechanically generated  - DO NOT EDIT! */\r
120 \r
121 \r
122 /* Directives */\r
123 %token D_ADDON\r
124 %token D_ALGORITHM\r
125 %token D_ASSEMBLY\r
126 %token D_BACKING\r
127 %token D_BLOB\r
128 %token D_CAPABILITY\r
129 %token D_CCTOR\r
130 %token D_CLASS\r
131 %token D_COMTYPE\r
132 %token D_CONFIG\r
133 %token D_CONSTRAINT\r
134 %token D_IMAGEBASE\r
135 %token D_CORFLAGS\r
136 %token D_CTOR\r
137 %token D_CUSTOM\r
138 %token D_DATA\r
139 %token D_EMITBYTE\r
140 %token D_ENTRYPOINT\r
141 %token D_EVENT\r
142 %token D_EXELOC\r
143 %token D_EXPORT\r
144 %token D_FIELD\r
145 %token D_FILE\r
146 %token D_FIRE\r
147 %token D_GET\r
148 %token D_HASH\r
149 %token D_IMPLICITCOM\r
150 %token D_LANGUAGE\r
151 %token D_LINE\r
152 %token D_XLINE\r
153 %token D_LOCALE\r
154 %token D_LOCALS\r
155 %token D_MANIFESTRES\r
156 %token D_MAXSTACK\r
157 %token D_METHOD\r
158 %token D_MIME\r
159 %token D_MODULE\r
160 %token D_MRESOURCE\r
161 %token D_NAMESPACE\r
162 %token D_ORIGINATOR\r
163 %token D_OS\r
164 %token D_OTHER\r
165 %token D_OVERRIDE\r
166 %token D_PACK\r
167 %token D_PARAM\r
168 %token D_PERMISSION\r
169 %token D_PERMISSIONSET\r
170 %token D_PROCESSOR\r
171 %token D_PROPERTY\r
172 %token D_PUBLICKEY\r
173 %token D_PUBLICKEYTOKEN\r
174 %token D_REMOVEON\r
175 %token D_SET\r
176 %token D_SIZE\r
177 %token D_SUBSYSTEM\r
178 %token D_TITLE\r
179 %token D_TRY\r
180 %token D_VER\r
181 %token D_VTABLE\r
182 %token D_VTENTRY\r
183 %token D_VTFIXUP\r
184 %token D_ZEROINIT\r
185 \r
186 \r
187 /* Keywords */\r
188 %token K_AT\r
189 %token K_AS\r
190 %token K_IMPLICITCOM\r
191 %token K_IMPLICITRES\r
192 %token K_NOAPPDOMAIN\r
193 %token K_NOPROCESS\r
194 %token K_NOMACHINE\r
195 %token K_EXTERN\r
196 %token K_INSTANCE\r
197 %token K_EXPLICIT\r
198 %token K_DEFAULT\r
199 %token K_VARARG\r
200 %token K_UNMANAGED\r
201 %token K_CDECL\r
202 %token K_STDCALL\r
203 %token K_THISCALL\r
204 %token K_FASTCALL\r
205 %token K_MARSHAL\r
206 %token K_IN\r
207 %token K_OUT\r
208 %token K_OPT\r
209 %token K_LCID\r
210 %token K_RETVAL\r
211 %token K_STATIC\r
212 %token K_PUBLIC\r
213 %token K_PRIVATE\r
214 %token K_FAMILY\r
215 %token K_INITONLY\r
216 %token K_RTSPECIALNAME\r
217 %token K_SPECIALNAME\r
218 %token K_ASSEMBLY\r
219 %token K_FAMANDASSEM\r
220 %token K_FAMORASSEM\r
221 %token K_PRIVATESCOPE\r
222 %token K_LITERAL\r
223 %token K_NOTSERIALIZED\r
224 %token K_VALUE\r
225 %token K_NOT_IN_GC_HEAP\r
226 %token K_INTERFACE\r
227 %token K_SEALED\r
228 %token K_ABSTRACT\r
229 %token K_AUTO\r
230 %token K_SEQUENTIAL\r
231 %token K_ANSI\r
232 %token K_UNICODE\r
233 %token K_AUTOCHAR\r
234 %token K_IMPORT\r
235 %token K_SERIALIZABLE\r
236 %token K_NESTED\r
237 %token K_LATEINIT\r
238 %token K_EXTENDS\r
239 %token K_IMPLEMENTS\r
240 %token K_FINAL\r
241 %token K_VIRTUAL\r
242 %token K_HIDEBYSIG\r
243 %token K_NEWSLOT\r
244 %token K_UNMANAGEDEXP\r
245 %token K_PINVOKEIMPL\r
246 %token K_NOMANGLE\r
247 %token K_OLE\r
248 %token K_LASTERR\r
249 %token K_WINAPI\r
250 %token K_NATIVE\r
251 %token K_IL\r
252 %token K_CIL\r
253 %token K_OPTIL\r
254 %token K_MANAGED\r
255 %token K_FORWARDREF\r
256 %token K_RUNTIME\r
257 %token K_INTERNALCALL\r
258 %token K_SYNCHRONIZED\r
259 %token K_NOINLINING\r
260 %token K_CUSTOM\r
261 %token K_FIXED\r
262 %token K_SYSSTRING\r
263 %token K_ARRAY\r
264 %token K_VARIANT\r
265 %token K_CURRENCY\r
266 %token K_SYSCHAR\r
267 %token K_VOID\r
268 %token K_BOOL\r
269 %token K_INT8\r
270 %token K_INT16\r
271 %token K_INT32\r
272 %token K_INT64\r
273 %token K_FLOAT32\r
274 %token K_FLOAT64\r
275 %token K_ERROR\r
276 %token K_UNSIGNED\r
277 %token K_DECIMAL\r
278 %token K_DATE\r
279 %token K_BSTR\r
280 %token K_LPSTR\r
281 %token K_LPWSTR\r
282 %token K_LPTSTR\r
283 %token K_OBJECTREF\r
284 %token K_IUNKNOWN\r
285 %token K_IDISPATCH\r
286 %token K_STRUCT\r
287 %token K_SAFEARRAY\r
288 %token K_INT\r
289 %token K_BYVALSTR\r
290 %token K_TBSTR\r
291 %token K_LPVOID\r
292 %token K_ANY\r
293 %token K_FLOAT\r
294 %token K_LPSTRUCT\r
295 %token K_NULL\r
296 %token K_PTR\r
297 %token K_VECTOR\r
298 %token K_HRESULT\r
299 %token K_CARRAY\r
300 %token K_USERDEFINED\r
301 %token K_RECORD\r
302 %token K_FILETIME\r
303 %token K_BLOB\r
304 %token K_STREAM\r
305 %token K_STORAGE\r
306 %token K_STREAMED_OBJECT\r
307 %token K_STORED_OBJECT\r
308 %token K_BLOB_OBJECT\r
309 %token K_CF\r
310 %token K_CLSID\r
311 %token K_METHOD\r
312 %token K_CLASS\r
313 %token K_PINNED\r
314 %token K_MODREQ\r
315 %token K_MODOPT\r
316 %token K_TYPEDREF\r
317 %token K_WCHAR\r
318 %token K_CHAR\r
319 %token K_FROMUNMANAGED\r
320 %token K_CALLMOSTDERIVED\r
321 %token K_BYTEARRAY\r
322 %token K_WITH\r
323 %token K_INIT\r
324 %token K_TO\r
325 %token K_CATCH\r
326 %token K_FILTER\r
327 %token K_FINALLY\r
328 %token K_FAULT\r
329 %token K_HANDLER\r
330 %token K_TLS\r
331 %token K_FIELD\r
332 %token K_REQUEST\r
333 %token K_DEMAND\r
334 %token K_ASSERT\r
335 %token K_DENY\r
336 %token K_PERMITONLY\r
337 %token K_LINKCHECK\r
338 %token K_INHERITCHECK\r
339 %token K_REQMIN\r
340 %token K_REQOPT\r
341 %token K_REQREFUSE\r
342 %token K_PREJITGRANT\r
343 %token K_PREJITDENY\r
344 %token K_NONCASDEMAND\r
345 %token K_NONCASLINKDEMAND\r
346 %token K_NONCASINHERITANCE\r
347 %token K_READONLY\r
348 %token K_NOMETADATA\r
349 %token K_ALGORITHM\r
350 %token K_FULLORIGIN\r
351 // %token K_NAN\r
352 // %token K_INF\r
353 %token K_PUBLICKEY\r
354 %token K_ENABLEJITTRACKING\r
355 %token K_DISABLEJITOPTIMIZER\r
356 %token K_PRESERVESIG\r
357 %token K_BEFOREFIELDINIT\r
358 %token K_ALIGNMENT\r
359 %token K_NULLREF\r
360 %token K_VALUETYPE\r
361 %token K_COMPILERCONTROLLED\r
362 %token K_REQSECOBJ\r
363 %token K_ENUM\r
364 %token K_OBJECT\r
365 %token K_STRING\r
366 %token K_TRUE\r
367 %token K_FALSE\r
368 %token K_IS\r
369 \r
370 /* end generated */\r
371 \r
372 \r
373 \r
374 \r
375 \r
376 %start il_file\r
377 \r
378 %%\r
379 \r
380 il_file                 : decls\r
381                         ;\r
382 \r
383 decls                   : /* EMPTY */\r
384                         | decls decl\r
385                         ;\r
386 \r
387 decl                    : class_all\r
388                         | namespace_all\r
389                         | method_all\r
390                         | field_decl\r
391                         | data_decl\r
392                         | vtfixup_decl\r
393                         | file_decl\r
394                         | assembly_all\r
395                         | assemblyref_all\r
396                         | exptype_all\r
397                         | manifestres_all\r
398                         | module_head\r
399                         | sec_decl\r
400                         | customattr_decl\r
401                         | D_SUBSYSTEM int32\r
402                           {\r
403                                 codegen.SetSubSystem ((int) $2);\r
404                           }\r
405                         | D_CORFLAGS int32\r
406                           {\r
407                                 codegen.SetCorFlags ((int) $2);\r
408                           }\r
409                         | D_FILE K_ALIGNMENT int32\r
410                         | D_IMAGEBASE int64\r
411                           {\r
412                                 codegen.SetImageBase ((long) $2);\r
413                           }\r
414                         | extsource_spec\r
415                         | language_decl\r
416                         ;\r
417 \r
418 extsource_spec          : D_LINE int32 SQSTRING\r
419                         | D_LINE int32\r
420                         | D_LINE int32 COLON int32 SQSTRING\r
421                         | D_LINE int32 COLON int32\r
422                         ;\r
423 \r
424 language_decl           : D_LANGUAGE SQSTRING\r
425                         | D_LANGUAGE SQSTRING COMMA SQSTRING\r
426                         | D_LANGUAGE SQSTRING COMMA SQSTRING COMMA SQSTRING\r
427                         ;\r
428 \r
429 constraint_decl         : D_CONSTRAINT BANG int32 K_IS type\r
430                           {\r
431                                 codegen.CurrentTypeDef.AddGenericConstraint ((int) $3, (ITypeRef) $5);\r
432                           }\r
433                         ;\r
434                         \r
435 vtfixup_decl            : D_VTFIXUP OPEN_BRACKET int32 CLOSE_BRACKET \r
436                           vtfixup_attr K_AT id\r
437                         ;\r
438 \r
439 vtfixup_attr            : /* EMPTY */\r
440                         | vtfixup_attr int32\r
441                         | vtfixup_attr int64\r
442                         | vtfixup_attr K_FROMUNMANAGED\r
443                         | vtfixup_attr K_CALLMOSTDERIVED\r
444                         ;\r
445 \r
446 namespace_all           : namespace_head OPEN_BRACE decls CLOSE_BRACE\r
447                           {\r
448                                 codegen.CurrentNameSpace = null;\r
449                           }\r
450                         ;\r
451 \r
452 namespace_head          : D_NAMESPACE comp_name\r
453                           {\r
454                                 codegen.CurrentNameSpace = (string) $2;\r
455                           }\r
456                         ;\r
457 \r
458 class_all               : class_head OPEN_BRACE class_decls CLOSE_BRACE\r
459                           {\r
460                                 codegen.EndTypeDef ();\r
461                           }\r
462                         ;\r
463 \r
464 class_head              : D_CLASS class_attr id formal_typars_clause extends_clause\r
465                           impl_clause\r
466                           {\r
467                                 codegen.BeginTypeDef ((TypeAttr) $2, (string) $3, \r
468                                                 $5 as IClassRef, $6 as ArrayList, null);\r
469                                 \r
470                                 if (is_value_class)\r
471                                         codegen.CurrentTypeDef.MakeValueClass ();\r
472                                 if (is_enum_class)\r
473                                         codegen.CurrentTypeDef.MakeEnumClass ();\r
474 \r
475                                 if ($4 != null) {\r
476                                         ArrayList typars_list = (ArrayList) $4;\r
477                                         foreach (string id in typars_list)\r
478                                                 codegen.CurrentTypeDef.AddGenericParam (id);\r
479                                 }                                \r
480                           }\r
481                         ;\r
482 \r
483 class_attrs             : class_attrs class_attr\r
484                         ;\r
485 \r
486 class_attr              : /* EMPTY */                           \r
487                           { \r
488                                 // Reset some flags\r
489                                 is_value_class = false;\r
490                                 is_enum_class = false;\r
491                                 $$ = new TypeAttr ();\r
492                           }\r
493                         | class_attr K_PUBLIC                   { $$ = (TypeAttr)$1 | TypeAttr.Public; }        \r
494                         | class_attr K_PRIVATE                  { $$ = (TypeAttr)$1 | TypeAttr.Private; }\r
495                         | class_attr K_NESTED K_PRIVATE         { $$ = (TypeAttr)$1 | TypeAttr.NestedPrivate; }\r
496                         | class_attr K_NESTED K_PUBLIC          { $$ = (TypeAttr)$1 | TypeAttr.NestedPublic; }\r
497                         | class_attr K_NESTED K_FAMILY          { $$ = (TypeAttr)$1 | TypeAttr.NestedFamily; }\r
498                         | class_attr K_NESTED K_ASSEMBLY        { $$ = (TypeAttr)$1 | TypeAttr.NestedAssembly;}\r
499                         | class_attr K_NESTED K_FAMANDASSEM     { $$ = (TypeAttr)$1 | TypeAttr.NestedFamAndAssem; }\r
500                         | class_attr K_NESTED K_FAMORASSEM      { $$ = (TypeAttr)$1 | TypeAttr.NestedFamOrAssem; }\r
501                         | class_attr K_VALUE                    { is_value_class = true; }\r
502                         | class_attr K_ENUM                     { is_enum_class = true; is_value_class = true;\r
503                           }\r
504                         | class_attr K_INTERFACE                { $$ = (TypeAttr)$1 | TypeAttr.Interface; }\r
505                         | class_attr K_SEALED                   { $$ = (TypeAttr)$1 | TypeAttr.Sealed; }\r
506                         | class_attr K_ABSTRACT                 { $$ = (TypeAttr)$1 | TypeAttr.Abstract; }\r
507                         | class_attr K_AUTO                     {  }\r
508                         | class_attr K_SEQUENTIAL               { $$ = (TypeAttr)$1 | TypeAttr.SequentialLayout; }\r
509                         | class_attr K_EXPLICIT                 { $$ = (TypeAttr)$1 | TypeAttr.ExplicitLayout; }\r
510                         | class_attr K_ANSI                     {  }\r
511                         | class_attr K_UNICODE                  { $$ = (TypeAttr)$1 | TypeAttr.UnicodeClass; }\r
512                         | class_attr K_AUTOCHAR                 { $$ = (TypeAttr)$1 | TypeAttr.AutoClass; }\r
513                         | class_attr K_IMPORT                   { $$ = (TypeAttr)$1 | TypeAttr.Import; }\r
514                         | class_attr K_SERIALIZABLE             { $$ = (TypeAttr)$1 | TypeAttr.Serializable; }\r
515                         | class_attr K_BEFOREFIELDINIT          { $$ = (TypeAttr)$1 | TypeAttr.BeforeFieldInit; }\r
516                         | class_attr K_SPECIALNAME              { $$ = (TypeAttr)$1 | TypeAttr.SpecialName; }\r
517                         | class_attr K_RTSPECIALNAME            { $$ = (TypeAttr)$1 | TypeAttr.RTSpecialName; }\r
518                         ;\r
519 \r
520 extends_clause          : /* EMPTY */\r
521                         | K_EXTENDS class_ref\r
522                           {\r
523                                 $$ = $2;\r
524                           }\r
525                         ;\r
526 \r
527 impl_clause             : /* EMPTY */\r
528                         | K_IMPLEMENTS class_refs\r
529                           {\r
530                                 $$ = $2;\r
531                           }\r
532                         ;\r
533 \r
534 formal_typars_clause           : /* EMPTY */\r
535                         | OPEN_ANGLE_BRACKET formal_typars CLOSE_ANGLE_BRACKET\r
536                           {\r
537                                 $$ = $2;\r
538                           }\r
539                         ;\r
540 \r
541 typars_clause           : /* EMPTY */\r
542                         | OPEN_ANGLE_BRACKET typars CLOSE_ANGLE_BRACKET\r
543                           {\r
544                                 $$ = $2;\r
545                           }\r
546                         ;\r
547 \r
548 typars                  : type\r
549                           {\r
550                                 ArrayList typars_list = new ArrayList ();\r
551                                 typars_list.Add ($1);\r
552                                 $$ = typars_list;\r
553                           }\r
554                         | typars COMMA type\r
555                           {\r
556                                 ArrayList typars_list = (ArrayList) $1;\r
557                                 typars_list.Add ($3);\r
558                                 $$ = typars_list;\r
559                           }\r
560                         ;\r
561 \r
562 formal_typars           : formal_typar\r
563                           {\r
564                                 ArrayList formal_list = new ArrayList ();\r
565                                 formal_list.Add ($1);\r
566                                 $$ = formal_list;\r
567                           }\r
568                         | formal_typars COMMA formal_typar\r
569                           {\r
570                                 ArrayList formal_list = (ArrayList) $1;\r
571                                 formal_list.Add ($3);\r
572                                 $$ = formal_list;\r
573                           }\r
574                         ;\r
575 \r
576 \r
577 formal_typar            : id\r
578                           {\r
579                                 $$ = $1;\r
580                           }\r
581                         ;\r
582                         \r
583 class_refs              : class_ref\r
584                           {\r
585                                 ArrayList class_list = new ArrayList ();\r
586                                 class_list.Add ($1);\r
587                                 $$ = class_list; \r
588                           }\r
589                         | class_refs COMMA class_ref\r
590                           {\r
591                                 ArrayList class_list = (ArrayList) $1;\r
592                                 class_list.Add ($3);\r
593                           }\r
594                         ;\r
595 \r
596 slashed_name            : comp_name\r
597                         | slashed_name SLASH comp_name\r
598                           {\r
599                                 $$ = String.Format ("{0}/{1}", $1, $3);\r
600                           }\r
601                         ;\r
602 \r
603 class_ref               : OPEN_BRACKET slashed_name CLOSE_BRACKET slashed_name\r
604                           {\r
605                                 if (codegen.IsThisAssembly ((string) $2)) {\r
606                                         $$ = new TypeRef ((string) $4, false, null);\r
607                                 } else {\r
608                                         $$ = codegen.ExternTable.GetTypeRef ((string) $2, (string) $4, false);\r
609                                 }\r
610                           }\r
611                         | OPEN_BRACKET D_MODULE slashed_name CLOSE_BRACKET slashed_name\r
612                         | slashed_name\r
613                           {\r
614                                 PrimitiveTypeRef prim = PrimitiveTypeRef.GetPrimitiveType ((string) $1);\r
615 \r
616                                 if (prim != null)\r
617                                         $$ = prim;\r
618                                 else\r
619                                         $$ = new TypeRef ((string) $1, false, null);\r
620                           }\r
621                       \r
622                         ;\r
623 \r
624 class_decls             : /* EMPTY */\r
625                         | class_decls class_decl\r
626                         ;\r
627 \r
628 class_decl              : method_all\r
629                         | class_all\r
630                         | event_all\r
631                         | prop_all\r
632                         | field_decl\r
633                         | data_decl\r
634                         | sec_decl\r
635                         | extsource_spec\r
636                         | customattr_decl\r
637                           {\r
638                                 codegen.CurrentTypeDef.AddCustomAttribute ((CustomAttr) $1);\r
639                           }\r
640                         | D_SIZE int32\r
641                           {\r
642                                 codegen.CurrentTypeDef.SetSize ((int) $2);\r
643                           }\r
644                         | D_PACK int32\r
645                           {\r
646                                 codegen.CurrentTypeDef.SetPack ((int) $2);\r
647                           }\r
648                         | D_OVERRIDE type_spec DOUBLE_COLON method_name K_WITH call_conv type\r
649                           type_spec DOUBLE_COLON method_name type_list\r
650                           {\r
651                                 //\r
652                                 // My copy of the spec didn't have a type_list but\r
653                                 // it seems pretty crucial\r
654                                 //\r
655                                 ITypeRef owner = (ITypeRef) $2;\r
656                                 ArrayList arg_list = (ArrayList) $11;\r
657                                 ITypeRef[] param_list;\r
658                                 IMethodRef decl;\r
659 \r
660                                 if (arg_list != null)\r
661                                         param_list = (ITypeRef[]) arg_list.ToArray (typeof (ITypeRef));\r
662                                 else\r
663                                         param_list = new ITypeRef[0];\r
664 \r
665                                 decl = owner.GetMethodRef ((ITypeRef) $7,\r
666                                         (CallConv) $6, (string) $4, param_list);\r
667 \r
668                                 string sig = MethodDef.CreateSignature ((string) $10,\r
669                                                                         param_list);\r
670                                 codegen.CurrentTypeDef.AddOverride (sig, decl);                                        \r
671                           }\r
672                           OPEN_PARENS sig_args CLOSE_PARENS\r
673                         | language_decl\r
674                         | constraint_decl\r
675                         ;\r
676 \r
677 type                    : K_CLASS class_ref\r
678                           {\r
679                                 $$ = $2;\r
680                           }\r
681                         | K_OBJECT\r
682                           {\r
683                                 $$ = new PrimitiveTypeRef (PrimitiveType.Object, "System.Object");\r
684                           }\r
685                         | K_STRING\r
686                           {\r
687                                 $$ = new PrimitiveTypeRef (PrimitiveType.String, "System.String");\r
688                           }\r
689                         | K_VALUE K_CLASS class_ref\r
690                           {\r
691                                 IClassRef class_ref = (IClassRef) $3;\r
692                                 class_ref.MakeValueClass ();\r
693                                 $$ = class_ref;\r
694                           }\r
695                         | K_VALUETYPE OPEN_BRACKET slashed_name CLOSE_BRACKET slashed_name\r
696                           {\r
697                                 ExternTypeRef ext_ref = codegen.ExternTable.GetTypeRef ((string) $3, (string) $5, false);\r
698                                 ext_ref.MakeValueClass ();\r
699                                 $$ = ext_ref;\r
700                           }\r
701                         | K_VALUETYPE slashed_name\r
702                           {\r
703                                 TypeRef t_ref = new TypeRef ((string) $2, true, null);\r
704                                 t_ref.MakeValueClass ();\r
705                                 $$ = t_ref;\r
706                           }\r
707                         | type OPEN_BRACKET CLOSE_BRACKET\r
708                           {\r
709                                 ITypeRef base_type = (ITypeRef) $1;\r
710                                 base_type.MakeArray ();\r
711                           }\r
712                         | type OPEN_BRACKET bounds CLOSE_BRACKET\r
713                           {\r
714                                 ITypeRef base_type = (ITypeRef) $1;\r
715                                 ArrayList bound_list = (ArrayList) $3;\r
716                                 base_type.MakeBoundArray (bound_list);\r
717                           }\r
718                         | type AMPERSAND\r
719                           {\r
720                                 ITypeRef base_type = (ITypeRef) $1;\r
721                                 base_type.MakeManagedPointer ();\r
722                           }\r
723                         | type STAR\r
724                           {\r
725                                 ITypeRef base_type = (ITypeRef) $1;\r
726                                 base_type.MakeUnmanagedPointer ();\r
727                           }\r
728                         | type K_PINNED\r
729                           {\r
730                                 ITypeRef base_type = (ITypeRef) $1;\r
731                                 base_type.MakePinned ();\r
732                           }\r
733                         | type K_MODREQ OPEN_PARENS class_ref CLOSE_PARENS\r
734                           {\r
735                                 ITypeRef base_type = (ITypeRef) $1;\r
736                                 IClassRef class_ref = (IClassRef) $4;\r
737                                 base_type.MakeCustomModified (codegen,\r
738                                         CustomModifier.modopt, class_ref);    \r
739                           }\r
740                         | type K_MODOPT OPEN_PARENS class_ref CLOSE_PARENS\r
741                           {\r
742                                 ITypeRef base_type = (ITypeRef) $1;\r
743                                 IClassRef class_ref = (IClassRef) $4;\r
744                                 base_type.MakeCustomModified (codegen,\r
745                                         CustomModifier.modopt, class_ref);    \r
746                           }\r
747                         | K_METHOD call_conv type STAR OPEN_PARENS sig_args CLOSE_PARENS\r
748                         | K_TYPEDREF\r
749                           {\r
750                                 $$ = new PrimitiveTypeRef (PrimitiveType.TypedRef,\r
751                                         "System.TypedReference");\r
752                           }\r
753                         | K_CHAR\r
754                           {\r
755                                 $$ = new PrimitiveTypeRef (PrimitiveType.Char, "System.Char");\r
756                           }\r
757                         | K_VOID\r
758                           {\r
759                                 $$ = new PrimitiveTypeRef (PrimitiveType.Void, "System.Void");\r
760                           }\r
761                         | K_BOOL\r
762                           {\r
763                                 $$ = new PrimitiveTypeRef (PrimitiveType.Boolean, "System.Bool");\r
764                           }\r
765                         | K_INT8\r
766                           {\r
767                                 $$ = new PrimitiveTypeRef (PrimitiveType.Int8, "System.Int8");\r
768                           }\r
769                         | K_INT16\r
770                           {\r
771                                 $$ = new PrimitiveTypeRef (PrimitiveType.Int16, "System.Int16");\r
772                           }\r
773                         | K_INT32\r
774                           {\r
775                                 $$ = new PrimitiveTypeRef (PrimitiveType.Int32, "System.Int32");\r
776                           }\r
777                         | K_INT64\r
778                           {\r
779                                 $$ = new PrimitiveTypeRef (PrimitiveType.Int64, "System.Int64");\r
780                           }\r
781                         | K_FLOAT32\r
782                           {\r
783                                 $$ = new PrimitiveTypeRef (PrimitiveType.Float32, "System.Float32");\r
784                           }\r
785                         | K_FLOAT64\r
786                           {\r
787                                 $$ = new PrimitiveTypeRef (PrimitiveType.Float64, "System.Float64");\r
788                           }\r
789                         | K_UNSIGNED K_INT8\r
790                           {\r
791                                 $$ = new PrimitiveTypeRef (PrimitiveType.UInt8, "System.UInt8");\r
792                           }\r
793                         | K_UNSIGNED K_INT16\r
794                           {\r
795                                 $$ = new PrimitiveTypeRef (PrimitiveType.UInt16, "System.UInt16");     \r
796                           }\r
797                         | K_UNSIGNED K_INT32\r
798                           {\r
799                                 $$ = new PrimitiveTypeRef (PrimitiveType.UInt32, "System.UInt32");\r
800                           }\r
801                         | K_UNSIGNED K_INT64\r
802                           {\r
803                                 $$ = new PrimitiveTypeRef (PrimitiveType.UInt64, "System.UInt64");\r
804                           }\r
805                         | K_NATIVE K_INT\r
806                           {\r
807                                 // TODO: Is this the proper full name\r
808                                 $$ = new PrimitiveTypeRef (PrimitiveType.NativeInt, "System.IntPtr");\r
809                           }\r
810                         \r
811                         | K_NATIVE K_UNSIGNED K_INT\r
812                           {\r
813                                 $$ = new PrimitiveTypeRef (PrimitiveType.NativeUInt, "System.UIntPtr");\r
814                           }\r
815                         | BANG int32\r
816                           {\r
817                                 GenericTypeSpec spec = new GenericTypeSpec ((int) $2);\r
818                                 $$ = new GenericTypeRef (spec, $2.ToString ());\r
819                           }\r
820                         | BANG BANG int32\r
821                           {\r
822                                 MVar mvar = new MVar ((int) $3);\r
823                                 $$ = new GenericTypeRef (mvar, $3.ToString ());\r
824                           }\r
825                         | K_CLASS slashed_name OPEN_ANGLE_BRACKET BANG int32 CLOSE_ANGLE_BRACKET\r
826                           {\r
827                                 $$ = new TypeRef ((string) $2, false, null);\r
828                           }\r
829                         | K_CLASS slashed_name OPEN_ANGLE_BRACKET typars CLOSE_ANGLE_BRACKET\r
830                           {\r
831                                 ArrayList typar_list = (ArrayList) $4;\r
832                                 ITypeRef[] typar_array = (ITypeRef[]) typar_list.ToArray (typeof (ITypeRef));\r
833                                 \r
834                                 $$ = new GenericTypeInst ((string)$2, typar_array);\r
835                           }\r
836                         ;\r
837 \r
838 bounds                  : bound\r
839                           {\r
840                                 ArrayList bound_list = new ArrayList ();\r
841                                 bound_list.Add ($1);\r
842                                 $$ = bound_list;\r
843                           }\r
844                         | bounds COMMA bound\r
845                           {\r
846                                 ArrayList bound_list = (ArrayList) $1;\r
847                                 bound_list.Add ($3);\r
848                           }\r
849                         ;\r
850 \r
851 bound                   : /* EMPTY */\r
852                         | ELLIPSIS\r
853                           {\r
854                                 // No lower bound or size\r
855                                 $$ = new DictionaryEntry (TypeRef.Ellipsis, TypeRef.Ellipsis);\r
856                           }\r
857                         | int32\r
858                           {\r
859                                 // ******** Not sure what this is?\r
860                                 // For now I will say it is size because there\r
861                                 // is allready a way to set lower\r
862                                 $$ = new DictionaryEntry (TypeRef.Ellipsis, $1);\r
863                           }\r
864                         | int32 ELLIPSIS int32\r
865                           {\r
866                                 // lower bound and size\r
867                                 $$ = new DictionaryEntry ($1, $3);\r
868                           }\r
869                         | int32 ELLIPSIS\r
870                           {\r
871                                 // Just lower bound\r
872                                 $$ = new DictionaryEntry ($1, TypeRef.Ellipsis);\r
873                           }\r
874                         ;\r
875 \r
876 call_conv               : K_INSTANCE call_conv\r
877                           {\r
878                                 $$ = (CallConv) $2 | CallConv.Instance;\r
879                           }\r
880                         | K_EXPLICIT call_conv\r
881                           {\r
882                                 $$ = (CallConv) $2 | CallConv.InstanceExplicit;\r
883                           }\r
884                         | call_kind\r
885                         ;\r
886 \r
887 call_kind               : /* EMPTY */\r
888                           {\r
889                                 $$ = new CallConv ();\r
890                           }\r
891                         | K_DEFAULT\r
892                           {\r
893                                 $$ = CallConv.Default;\r
894                           }\r
895                         | K_VARARG\r
896                           {\r
897                                 $$ = CallConv.Vararg;\r
898                           }\r
899                         | K_UNMANAGED K_CDECL\r
900                           {\r
901                                 $$ = CallConv.Cdecl;\r
902                           }\r
903                         | K_UNMANAGED K_STDCALL\r
904                           {\r
905                                 $$ = CallConv.Stdcall;\r
906                           }\r
907                         | K_UNMANAGED K_THISCALL\r
908                           {\r
909                                 $$ = CallConv.Thiscall;\r
910                           }\r
911                         | K_UNMANAGED K_FASTCALL\r
912                           {\r
913                                 $$ = CallConv.Fastcall;\r
914                           }\r
915                         ;\r
916 \r
917 native_type             : /* EMPTY */\r
918                         | K_CUSTOM OPEN_PARENS comp_qstring COMMA comp_qstring CLOSE_PARENS\r
919                         | K_FIXED K_SYSSTRING OPEN_BRACKET int32 CLOSE_BRACKET\r
920                           {\r
921                                 $$ = NativeType.FixedSysString;\r
922                           }\r
923                         | K_FIXED K_ARRAY OPEN_BRACKET int32 CLOSE_BRACKET\r
924                         | K_VARIANT\r
925                         | K_CURRENCY\r
926                           {\r
927                                 $$ = NativeType.Currency;\r
928                           }\r
929                         | K_SYSCHAR\r
930                         | K_VOID\r
931                           {\r
932                                 $$ = NativeType.Void;\r
933                           }\r
934                         | K_BOOL\r
935                           {\r
936                                 $$ = NativeType.Boolean;\r
937                           }\r
938                         | K_INT8\r
939                           {\r
940                                 $$ = NativeType.Int8;\r
941                           }\r
942                         | K_INT16\r
943                           {\r
944                                 $$ = NativeType.Int16;\r
945                           }\r
946                         | K_INT32\r
947                           {\r
948                                 $$ = NativeType.Int32;\r
949                           }\r
950                         | K_INT64\r
951                           {\r
952                                 $$ = NativeType.Int64;\r
953                           }\r
954                         | K_FLOAT32\r
955                           {\r
956                                 $$ = NativeType.Float32;\r
957                           }\r
958                         | K_FLOAT64\r
959                           {\r
960                                 $$ = NativeType.Float64;\r
961                           }\r
962                         | K_ERROR\r
963                         | K_UNSIGNED K_INT8\r
964                           {\r
965                                 $$ = NativeType.UInt8;\r
966                           }\r
967                         | K_UNSIGNED K_INT16\r
968                           {\r
969                                 $$ = NativeType.UInt16;\r
970                           }\r
971                         | K_UNSIGNED K_INT32\r
972                           {\r
973                                 $$ = NativeType.UInt32;\r
974                           }\r
975                         | K_UNSIGNED K_INT64\r
976                           {\r
977                                 $$ = NativeType.UInt64;\r
978                           }\r
979                         | native_type STAR\r
980                         | native_type OPEN_BRACKET CLOSE_BRACKET\r
981                         | native_type OPEN_BRACKET int32 CLOSE_BRACKET\r
982                         | native_type OPEN_BRACKET int32 PLUS int32 CLOSE_BRACKET\r
983                         | native_type OPEN_BRACKET PLUS int32 CLOSE_BRACKET\r
984                         | K_DECIMAL\r
985                         | K_DATE\r
986                         | K_BSTR\r
987                           {\r
988                                 $$ = NativeType.BStr;\r
989                           }\r
990                         | K_LPSTR\r
991                           {\r
992                                 $$ = NativeType.LPStr;\r
993                           }\r
994                         | K_LPWSTR\r
995                           {\r
996                                 $$ = NativeType.LPWStr;\r
997                           }\r
998                         | K_LPTSTR\r
999                           {\r
1000                                 $$ = NativeType.LPTStr;\r
1001                           }\r
1002                         | K_OBJECTREF\r
1003                         | K_IUNKNOWN\r
1004                           {\r
1005                                 $$ = NativeType.IUnknown;\r
1006                           }\r
1007                         | K_IDISPATCH\r
1008                           {\r
1009                                 $$ = NativeType.IDispatch;\r
1010                           }\r
1011                         | K_STRUCT\r
1012                           {\r
1013                                 $$ = NativeType.Struct;\r
1014                           }\r
1015                         | K_INTERFACE\r
1016                           {\r
1017                                 $$ = NativeType.Interface;\r
1018                           }\r
1019                         | K_SAFEARRAY variant_type\r
1020                         | K_SAFEARRAY variant_type COMMA comp_qstring\r
1021                         | K_INT\r
1022                           {\r
1023                                 $$ = NativeType.Int;\r
1024                           }\r
1025                         | K_UNSIGNED K_INT\r
1026                           {\r
1027                                 $$ = NativeType.UInt;\r
1028                           }\r
1029                         | K_NESTED K_STRUCT\r
1030                         | K_BYVALSTR\r
1031                           {\r
1032                                 $$ = NativeType.ByValStr;\r
1033                           }\r
1034                         | K_ANSI K_BSTR\r
1035                           {\r
1036                                 $$ = NativeType.AnsiBStr;\r
1037                           }\r
1038                         | K_TBSTR\r
1039                           {\r
1040                                 $$ = NativeType.TBstr;\r
1041                           }\r
1042                         | K_VARIANT K_BOOL\r
1043                           {\r
1044                                 $$ = NativeType.VariantBool;\r
1045                           }\r
1046                         | K_METHOD\r
1047                         | K_AS K_ANY\r
1048                           {\r
1049                                 $$ = NativeType.AsAny;\r
1050                           }\r
1051                         | K_LPSTRUCT\r
1052                         ;\r
1053 \r
1054 variant_type            : /* EMPTY */\r
1055                         | K_NULL\r
1056                         | K_VARIANT\r
1057                         | K_CURRENCY\r
1058                         | K_VOID\r
1059                         | K_BOOL\r
1060                         | K_INT8\r
1061                         | K_INT16\r
1062                         | K_INT32\r
1063                         | K_INT64\r
1064                         | K_FLOAT32\r
1065                         | K_FLOAT64\r
1066                         | K_UNSIGNED K_INT8\r
1067                         | K_UNSIGNED K_INT16\r
1068                         | K_UNSIGNED K_INT32\r
1069                         | K_UNSIGNED K_INT64\r
1070                         | STAR\r
1071                         | variant_type OPEN_BRACKET CLOSE_BRACKET\r
1072                         | variant_type K_VECTOR\r
1073                         | variant_type AMPERSAND\r
1074                         | K_DECIMAL\r
1075                         | K_DATE\r
1076                         | K_BSTR\r
1077                         | K_LPSTR\r
1078                         | K_LPWSTR\r
1079                         | K_IUNKNOWN\r
1080                         | K_IDISPATCH\r
1081                         | K_SAFEARRAY\r
1082                         | K_INT\r
1083                         | K_UNSIGNED K_INT\r
1084                         | K_ERROR\r
1085                         | K_HRESULT\r
1086                         | K_CARRAY\r
1087                         | K_USERDEFINED\r
1088                         | K_RECORD\r
1089                         | K_FILETIME\r
1090                         | K_BLOB\r
1091                         | K_STREAM\r
1092                         | K_STORAGE\r
1093                         | K_STREAMED_OBJECT\r
1094                         | K_STORED_OBJECT\r
1095                         | K_BLOB_OBJECT\r
1096                         | K_CF\r
1097                         | K_CLSID\r
1098                         ;\r
1099 \r
1100 field_decl              : D_FIELD repeat_opt field_attr type id at_opt init_opt\r
1101                           {\r
1102                                 FieldDef field_def = new FieldDef((FieldAttr) $3, \r
1103                                         (string) $5, (ITypeRef) $4);\r
1104                                 codegen.AddFieldDef (field_def);\r
1105                                 \r
1106                                 if ($2 != null) {\r
1107                                         field_def.SetOffset ((uint) $2);\r
1108                                 }\r
1109                                 \r
1110                                 if ($6 != null) {\r
1111                                         field_def.AddDataValue ((string) $6);\r
1112                                 }\r
1113                                 \r
1114                                 if ($7 != null) {\r
1115                                         field_def.SetValue ((Constant) $7);\r
1116                                 }\r
1117                           }\r
1118                         ;\r
1119 \r
1120 repeat_opt              : /* EMPTY */\r
1121                         | OPEN_BRACKET int32 CLOSE_BRACKET\r
1122                           {\r
1123                                 $$ = $2;\r
1124                           }\r
1125                         ;\r
1126 \r
1127 field_attr              : /* EMPTY */\r
1128                           {\r
1129                                 $$ = new FieldAttr ();\r
1130                           }\r
1131                         | field_attr K_PUBLIC\r
1132                           {\r
1133                                 $$ = (FieldAttr) $1 | FieldAttr.Public;\r
1134                           }\r
1135                         | field_attr K_PRIVATE\r
1136                           {\r
1137                                 $$ = (FieldAttr) $1 | FieldAttr.Private;\r
1138                           }\r
1139                         | field_attr K_FAMILY\r
1140                           {\r
1141                                 $$ = (FieldAttr) $1 | FieldAttr.Family;\r
1142                           }\r
1143                         | field_attr K_ASSEMBLY\r
1144                           {\r
1145                                 $$ = (FieldAttr) $1 | FieldAttr.Assembly;\r
1146                           }\r
1147                         | field_attr K_FAMANDASSEM\r
1148                           {\r
1149                                 $$ = (FieldAttr) $1 | FieldAttr.FamAndAssem;\r
1150                           }\r
1151                         | field_attr K_FAMORASSEM\r
1152                           {\r
1153                                 $$ = (FieldAttr) $1 | FieldAttr.FamOrAssem;\r
1154                           }\r
1155                         | field_attr K_PRIVATESCOPE\r
1156                           {\r
1157                                 // This is just 0x0000\r
1158                           }\r
1159                         | field_attr K_STATIC\r
1160                           {\r
1161                                 $$ = (FieldAttr) $1 | FieldAttr.Static;\r
1162                           }\r
1163                         | field_attr K_INITONLY\r
1164                           {\r
1165                                 $$ = (FieldAttr) $1 | FieldAttr.Initonly;\r
1166                           }\r
1167                         | field_attr K_RTSPECIALNAME\r
1168                           {\r
1169                                 $$ = (FieldAttr) $1 | FieldAttr.RTSpecialName;\r
1170                           }\r
1171                         | field_attr K_SPECIALNAME\r
1172                           {\r
1173                                 $$ = (FieldAttr) $1 | FieldAttr.SpecialName;\r
1174                           }\r
1175                         | field_attr K_MARSHAL OPEN_PARENS native_type CLOSE_PARENS\r
1176                           {\r
1177                                 \r
1178                           }\r
1179                         | field_attr K_LITERAL\r
1180                           {\r
1181                                 $$ = (FieldAttr) $1 | FieldAttr.Literal;\r
1182                           }\r
1183                         | field_attr K_NOTSERIALIZED\r
1184                           {\r
1185                                 $$ = (FieldAttr) $1 | FieldAttr.Notserialized;\r
1186                           }\r
1187                         ;\r
1188 \r
1189 at_opt                  : /* EMPTY */\r
1190                         | K_AT id\r
1191                           {\r
1192                                 $$ = $2;\r
1193                           }\r
1194                         ;\r
1195 \r
1196 init_opt                : /* EMPTY */\r
1197                         | ASSIGN field_init\r
1198                           {\r
1199                                 $$ = $2;\r
1200                           }\r
1201                         ;\r
1202 \r
1203 field_init              : K_FLOAT32 OPEN_PARENS float64 CLOSE_PARENS\r
1204                           {\r
1205                                 $$ = new FloatConst (Convert.ToSingle ($3));\r
1206                           }\r
1207                         | K_FLOAT64 OPEN_PARENS float64 CLOSE_PARENS\r
1208                           {\r
1209                                 $$ = new DoubleConst (Convert.ToDouble ($3));\r
1210                           }\r
1211                         | K_FLOAT32 OPEN_PARENS int64 CLOSE_PARENS\r
1212                           {\r
1213                                 $$ = new FloatConst (Convert.ToSingle ($3));\r
1214                           }\r
1215                         | K_FLOAT64 OPEN_PARENS int64 CLOSE_PARENS\r
1216                           {\r
1217                                 $$ = new DoubleConst (Convert.ToDouble (3));\r
1218                           }\r
1219                         | K_INT64 OPEN_PARENS int64 CLOSE_PARENS\r
1220                           {\r
1221                                 $$ = new IntConst (Convert.ToInt64 ($3));\r
1222                           }\r
1223                         | K_INT32 OPEN_PARENS int64 CLOSE_PARENS\r
1224                           {\r
1225                                 $$ = new IntConst (Convert.ToInt32 ($3));\r
1226                           }\r
1227                         | K_INT16 OPEN_PARENS int64 CLOSE_PARENS\r
1228                           {\r
1229                                 $$ = new IntConst (Convert.ToInt16 ($3));\r
1230                           }\r
1231                         | K_CHAR OPEN_PARENS int64 CLOSE_PARENS\r
1232                           {\r
1233                                 $$ = new CharConst (Convert.ToChar ($3));\r
1234                           }\r
1235                         | K_INT8 OPEN_PARENS int64 CLOSE_PARENS\r
1236                           {\r
1237                                 $$ = new IntConst (Convert.ToByte ($3));\r
1238                           }\r
1239                         | K_BOOL OPEN_PARENS truefalse CLOSE_PARENS\r
1240                           {\r
1241                                 $$ = new BoolConst ((bool) $3);\r
1242                           }\r
1243                         | K_BYTEARRAY OPEN_PARENS bytes CLOSE_PARENS\r
1244                           {\r
1245                                 $$ = new ByteArrConst ((byte[]) $3);\r
1246                           }\r
1247                         | comp_qstring\r
1248                           {\r
1249                                 // ******** THIS IS NOT IN THE DOCUMENTATION ******** //\r
1250                                 $$ = new StringConst ((string) $1);\r
1251                           }\r
1252                         | K_NULLREF\r
1253                           {\r
1254                                 $$ = new NullConst ();\r
1255                           }\r
1256                         ;\r
1257 \r
1258 data_decl               : data_head data_body\r
1259                           {\r
1260                                 DataDef datadef = (DataDef) $1;\r
1261                                 \r
1262                                 if ($2 is ArrayList) {\r
1263                                         ArrayList const_list = (ArrayList) $2;\r
1264                                         DataConstant[] const_arr = new DataConstant[const_list.Count];\r
1265                                         \r
1266                                         for (int i=0; i<const_arr.Length; i++)\r
1267                                                 const_arr[i] = (DataConstant) const_list[i];\r
1268 \r
1269                                         datadef.PeapiConstant = new ArrayConstant (const_arr);\r
1270                                 } else {\r
1271                                         datadef.PeapiConstant = (PEAPI.Constant) $2;\r
1272                                 }\r
1273                                 codegen.AddDataDef (datadef);\r
1274                           }\r
1275                         ;\r
1276 \r
1277 data_head               : D_DATA tls id ASSIGN\r
1278                           {\r
1279                                 $$ = new DataDef ((string) $3, (bool) $2);    \r
1280                           } \r
1281                         | D_DATA tls\r
1282                           {\r
1283                                 $$ = new DataDef (String.Empty, (bool) $2);\r
1284                           }\r
1285                         ;\r
1286 \r
1287 tls                     : /* EMPTY */   { $$ = false; }\r
1288                         | K_TLS         { $$ = true; }\r
1289                         ;\r
1290 \r
1291 data_body               : OPEN_BRACE dataitem_list CLOSE_BRACE\r
1292                         | dataitem\r
1293                         ;\r
1294 \r
1295 dataitem_list           : dataitem\r
1296                           {\r
1297                                 ArrayList dataitem_list = new ArrayList ();\r
1298                                 dataitem_list.Add ($1);\r
1299                                 $$ = dataitem_list;\r
1300                           }\r
1301                         | dataitem_list COMMA dataitem\r
1302                           {\r
1303                                 ArrayList list = (ArrayList) $1;\r
1304                                 list.Add ($3);\r
1305                           }\r
1306                         ;\r
1307 \r
1308 dataitem                : K_CHAR STAR OPEN_PARENS comp_qstring CLOSE_PARENS\r
1309                           {\r
1310                                 $$ = new StringConst ((string) $4);\r
1311                           }\r
1312                         | AMPERSAND OPEN_PARENS id CLOSE_PARENS\r
1313                           {\r
1314                            //     DataDef def = codegen.CurrentTypeDef.GetDataDef ((string) $3);\r
1315                            //     $$ = new AddressConstant ((DataConstant) def.PeapiConstant);\r
1316                           }\r
1317                         | K_BYTEARRAY ASSIGN OPEN_PARENS bytes CLOSE_PARENS\r
1318                           {\r
1319                                 $$ = new ByteArrConst ((byte[]) $4);\r
1320                           }\r
1321                         | K_BYTEARRAY OPEN_PARENS bytes CLOSE_PARENS\r
1322                           {\r
1323                                 // ******** THIS IS NOT IN THE SPECIFICATION ******** //\r
1324                                 $$ = new ByteArrConst ((byte[]) $3);\r
1325                           }\r
1326                         | K_FLOAT32 OPEN_PARENS float64 CLOSE_PARENS repeat_opt\r
1327                           {\r
1328                                 FloatConst float_const = new FloatConst ((float) $3);\r
1329 \r
1330                                 if ($5 != null)\r
1331                                         $$ = new RepeatedConstant (float_const, (int) $5);\r
1332                                 else\r
1333                                         $$ = float_const;\r
1334                           }\r
1335                         | K_FLOAT64 OPEN_PARENS float64 CLOSE_PARENS repeat_opt\r
1336                           {\r
1337                                 DoubleConst double_const = new DoubleConst ((double) $3);\r
1338 \r
1339                                 if ($5 != null)\r
1340                                         $$ = new RepeatedConstant (double_const, (int) $5);\r
1341                                 else\r
1342                                         $$ = double_const;\r
1343                           }\r
1344                         | K_INT64 OPEN_PARENS int64 CLOSE_PARENS repeat_opt\r
1345                           {\r
1346                                 IntConst int_const = new IntConst ((long) $3);\r
1347 \r
1348                                 if ($5 != null)\r
1349                                         $$ = new RepeatedConstant (int_const, (int) $5);\r
1350                                 else\r
1351                                         $$ = int_const;\r
1352                           }\r
1353                         | K_INT32 OPEN_PARENS int32 CLOSE_PARENS repeat_opt\r
1354                           {\r
1355                                 IntConst int_const = new IntConst ((int) $3);\r
1356 \r
1357                                 if ($5 != null)\r
1358                                         $$ = new RepeatedConstant (int_const, (int) $5);\r
1359                                 else\r
1360                                         $$ = int_const;\r
1361                           }\r
1362                         | K_INT16 OPEN_PARENS int32 CLOSE_PARENS repeat_opt\r
1363                           {\r
1364                                 IntConst int_const = new IntConst ((short) $3);\r
1365 \r
1366                                 if ($5 != null)\r
1367                                         $$ = new RepeatedConstant (int_const, (int) $5);\r
1368                                 else\r
1369                                         $$ = int_const;\r
1370                           }\r
1371                         | K_INT8 OPEN_PARENS int32 CLOSE_PARENS repeat_opt\r
1372                           {\r
1373                                 IntConst int_const = new IntConst ((sbyte) $3);\r
1374 \r
1375                                 if ($5 != null)\r
1376                                         $$ = new RepeatedConstant (int_const, (int) $5);\r
1377                                 else\r
1378                                         $$ = int_const;\r
1379                           }\r
1380                         | K_FLOAT32 repeat_opt\r
1381                           {\r
1382                                 FloatConst float_const = new FloatConst (0F);\r
1383 \r
1384                                 if ($2 != null)\r
1385                                         $$ = new RepeatedConstant (float_const, (int) $2);\r
1386                                 else\r
1387                                         $$ = float_const;\r
1388                           }\r
1389                         | K_FLOAT64 repeat_opt\r
1390                           {\r
1391                                 DoubleConst double_const = new DoubleConst (0);\r
1392 \r
1393                                 if ($2 != null)\r
1394                                         $$ = new RepeatedConstant (double_const, (int) $2);\r
1395                                 else\r
1396                                         $$ = double_const;\r
1397                           }\r
1398                         | K_INT64 repeat_opt\r
1399                           {\r
1400                                 IntConst int_const = new IntConst ((long) 0);\r
1401 \r
1402                                 if ($2 != null)\r
1403                                         $$ = new RepeatedConstant (int_const, (int) $2);\r
1404                                 else\r
1405                                         $$ = int_const;\r
1406                           }\r
1407                         | K_INT32 repeat_opt\r
1408                           {\r
1409                                 IntConst int_const = new IntConst ((int) 0);\r
1410 \r
1411                                 if ($2 != null)\r
1412                                         $$ = new RepeatedConstant (int_const, (int) $2);\r
1413                                 else\r
1414                                         $$ = int_const;\r
1415                           }\r
1416                         | K_INT16 repeat_opt\r
1417                           {\r
1418                                 IntConst int_const = new IntConst ((short) 0);\r
1419 \r
1420                                 if ($2 != null)\r
1421                                         $$ = new RepeatedConstant (int_const, (int) $2);\r
1422                                 else\r
1423                                         $$ = int_const;\r
1424                           }\r
1425                         | K_INT8 repeat_opt\r
1426                           {\r
1427                                 IntConst int_const = new IntConst ((sbyte) 0);\r
1428 \r
1429                                 if ($2 != null)\r
1430                                         $$ = new RepeatedConstant (int_const, (int) $2);\r
1431                                 else\r
1432                                         $$ = int_const;\r
1433                           }\r
1434                         ;\r
1435 \r
1436 method_all              : method_head OPEN_BRACE method_decls CLOSE_BRACE\r
1437                           {\r
1438                                 codegen.EndMethodDef ();\r
1439                           }\r
1440                         ;\r
1441 \r
1442 method_head             : D_METHOD meth_attr call_conv param_attr type method_name\r
1443                           formal_typars_clause OPEN_PARENS sig_args CLOSE_PARENS impl_attr\r
1444                           {\r
1445                                 MethodDef methdef = new MethodDef ((MethAttr) $2, (CallConv) $3,\r
1446                                         (ImplAttr) $11, (string) $6, (ITypeRef) $5,\r
1447                                         (ArrayList) $9);\r
1448                                 codegen.BeginMethodDef (methdef);\r
1449 \r
1450                                 if (pinvoke_info) {\r
1451                                         methdef.AddPInvokeInfo (pinvoke_attr, pinvoke_mod, pinvoke_meth);\r
1452                                         pinvoke_info = false;\r
1453                                 }\r
1454 \r
1455                                 if ($7 != null) {\r
1456                                         ArrayList typars_list = (ArrayList) $7;\r
1457                                         foreach (string id in typars_list)\r
1458                                                 methdef.AddGenericParam (id);\r
1459                                 }\r
1460                           }\r
1461                         | D_METHOD meth_attr call_conv param_attr type \r
1462                           K_MARSHAL OPEN_PARENS native_type CLOSE_PARENS method_name\r
1463                           OPEN_PARENS sig_args CLOSE_PARENS impl_attr\r
1464                         ;\r
1465 \r
1466 meth_attr               : /* EMPTY */                   { $$ = new MethAttr (); }\r
1467                         | meth_attr K_STATIC            { $$ = (MethAttr) $1 | MethAttr.Static; }\r
1468                         | meth_attr K_PUBLIC            { $$ = (MethAttr) $1 | MethAttr.Public; }\r
1469                         | meth_attr K_PRIVATE           { $$ = (MethAttr) $1 | MethAttr.Private; }\r
1470                         | meth_attr K_FAMILY            { $$ = (MethAttr) $1 | MethAttr.Family; }\r
1471                         | meth_attr K_ASSEMBLY          { $$ = (MethAttr) $1 | MethAttr.Assembly; }\r
1472                         | meth_attr K_FAMANDASSEM       { $$ = (MethAttr) $1 | MethAttr.FamAndAssem; } \r
1473                         | meth_attr K_FAMORASSEM        { $$ = (MethAttr) $1 | MethAttr.FamOrAssem; } \r
1474                         | meth_attr K_PRIVATESCOPE      { /* CHECK HEADERS */ }\r
1475                         | meth_attr K_FINAL             { $$ = (MethAttr) $1 | MethAttr.Final; } \r
1476                         | meth_attr K_VIRTUAL           { $$ = (MethAttr) $1 | MethAttr.Virtual; }\r
1477                         | meth_attr K_ABSTRACT          { $$ = (MethAttr) $1 | MethAttr.Abstract; }\r
1478                         | meth_attr K_HIDEBYSIG         { $$ = (MethAttr) $1 | MethAttr.HideBySig; }\r
1479                         | meth_attr K_NEWSLOT           { $$ = (MethAttr) $1 | MethAttr.NewSlot; }\r
1480                         | meth_attr K_REQSECOBJ         { $$ = (MethAttr) $1 | MethAttr.RequireSecObject; }\r
1481                         | meth_attr K_SPECIALNAME       { $$ = (MethAttr) $1 | MethAttr.SpecialName; }\r
1482                         | meth_attr K_RTSPECIALNAME     { $$ = (MethAttr) $1 | MethAttr.RTSpecialName; }\r
1483                         | meth_attr K_COMPILERCONTROLLED { /* Do nothing */ }\r
1484                         | meth_attr K_UNMANAGEDEXP      \r
1485                         | meth_attr K_PINVOKEIMPL OPEN_PARENS comp_qstring K_AS\r
1486                                 comp_qstring pinv_attr CLOSE_PARENS\r
1487                           {\r
1488                                 pinvoke_info = true;\r
1489                                 pinvoke_mod = (string) $4;\r
1490                                 pinvoke_meth = (string) $6;\r
1491                                 pinvoke_attr = (PInvokeAttr) $7;\r
1492                           }\r
1493                         | meth_attr K_PINVOKEIMPL OPEN_PARENS comp_qstring pinv_attr CLOSE_PARENS\r
1494                           {\r
1495                                 pinvoke_info = true;\r
1496                                 pinvoke_mod = (string) $4;\r
1497                                 pinvoke_meth = null;\r
1498                                 pinvoke_attr = (PInvokeAttr) $5;\r
1499                           }\r
1500                         | meth_attr K_PINVOKEIMPL OPEN_PARENS pinv_attr CLOSE_PARENS\r
1501                           {\r
1502                                 pinvoke_info = true;\r
1503                                 pinvoke_mod = null;\r
1504                                 pinvoke_meth = null;\r
1505                                 pinvoke_attr = (PInvokeAttr) $4;\r
1506                           }\r
1507                         ;\r
1508 \r
1509 pinv_attr               : /* EMPTY */ { $$ = new PInvokeAttr (); }\r
1510                         | pinv_attr K_NOMANGLE { $$ = (PInvokeAttr) $1 | PInvokeAttr.nomangle; }\r
1511                         | pinv_attr K_ANSI { $$ = (PInvokeAttr) $1 | PInvokeAttr.ansi; }\r
1512                         | pinv_attr K_UNICODE { $$ = (PInvokeAttr) $1 | PInvokeAttr.unicode; }\r
1513                         | pinv_attr K_AUTOCHAR { $$ = (PInvokeAttr) $1 | PInvokeAttr.autochar; }\r
1514                         | pinv_attr K_LASTERR { $$ = (PInvokeAttr) $1 | PInvokeAttr.lasterr; }\r
1515                         | pinv_attr K_WINAPI { $$ = (PInvokeAttr) $1 | PInvokeAttr.winapi; }\r
1516                         | pinv_attr K_CDECL { $$ = (PInvokeAttr) $1 | PInvokeAttr.cdecl; }\r
1517                         | pinv_attr K_STDCALL { $$ = (PInvokeAttr) $1 | PInvokeAttr.stdcall; }\r
1518                         | pinv_attr K_THISCALL { $$ = (PInvokeAttr) $1 | PInvokeAttr.thiscall; }\r
1519                         | pinv_attr K_FASTCALL { $$ = (PInvokeAttr) $1 | PInvokeAttr.fastcall; }\r
1520                         ;\r
1521 \r
1522 method_name             : D_CTOR\r
1523                         | D_CCTOR\r
1524                         | comp_name\r
1525                         ;\r
1526 \r
1527 param_attr              : /* EMPTY */                                   { $$ = new ParamAttr (); }\r
1528                         | param_attr OPEN_BRACKET K_IN CLOSE_BRACKET    { $$ = (ParamAttr) $1 | ParamAttr.In; }\r
1529                         | param_attr OPEN_BRACKET K_OUT CLOSE_BRACKET   { $$ = (ParamAttr) $1 | ParamAttr.Out; }\r
1530                         | param_attr OPEN_BRACKET K_OPT CLOSE_BRACKET   { $$ = (ParamAttr) $1 | ParamAttr.Opt; }\r
1531                         ;\r
1532 \r
1533 impl_attr               : /* EMPTY */                   { $$ = new ImplAttr (); }\r
1534                         | impl_attr K_NATIVE            { $$ = (ImplAttr) $1 | ImplAttr.Native; }\r
1535                         | impl_attr K_CIL               { $$ = (ImplAttr) $1 | ImplAttr.IL; }\r
1536                         | impl_attr K_IL                { $$ = (ImplAttr) $1 | ImplAttr.IL; }\r
1537                         | impl_attr K_OPTIL             { $$ = (ImplAttr) $1 | ImplAttr.Optil; }\r
1538                         | impl_attr K_MANAGED           { /* should this reset? */ }\r
1539                         | impl_attr K_UNMANAGED         { $$ = (ImplAttr) $1 | ImplAttr.Unmanaged; }\r
1540                         | impl_attr K_FORWARDREF        { $$ = (ImplAttr) $1 | ImplAttr.ForwardRef; }\r
1541                         | impl_attr K_PRESERVESIG       { $$ = (ImplAttr) $1 | ImplAttr.PreserveSig; }\r
1542                         | impl_attr K_RUNTIME           { $$ = (ImplAttr) $1 | ImplAttr.Runtime; }\r
1543                         | impl_attr K_INTERNALCALL      { $$ = (ImplAttr) $1 | ImplAttr.InternalCall; }\r
1544                         | impl_attr K_SYNCHRONIZED      { $$ = (ImplAttr) $1 | ImplAttr.Synchronised; }\r
1545                         | impl_attr K_NOINLINING        { $$ = (ImplAttr) $1 | ImplAttr.NoInLining; }\r
1546                         ;\r
1547 \r
1548 sig_args                : /* EMPTY */\r
1549                         | sig_arg_list\r
1550                         ;\r
1551 \r
1552 sig_arg_list            : sig_arg\r
1553                           {\r
1554                                 ArrayList sig_list = new ArrayList ();\r
1555                                 sig_list.Add ($1);\r
1556                                 $$ = sig_list;\r
1557                           }\r
1558                         | sig_arg_list COMMA sig_arg\r
1559                           {\r
1560                                 ArrayList sig_list = (ArrayList) $1;\r
1561                                 sig_list.Add ($3);\r
1562                                 $$ = sig_list;\r
1563                           }\r
1564                         ;\r
1565 \r
1566 sig_arg                 : param_attr type\r
1567                           {\r
1568                                 $$ = new ParamDef ((ParamAttr) $1, null, (ITypeRef) $2);\r
1569                           }\r
1570                         | param_attr type id\r
1571                           {\r
1572                                 $$ = new ParamDef ((ParamAttr) $1, (string) $3, (ITypeRef) $2);\r
1573                           }\r
1574                         | ELLIPSIS\r
1575                           {\r
1576                                 $$ = new ParamDef ((ParamAttr) 0, "...", new SentinelTypeRef ());\r
1577                                 // $$ = ParamDef.Ellipsis;\r
1578                           }\r
1579                         | param_attr type K_MARSHAL OPEN_PARENS native_type CLOSE_PARENS\r
1580                         | param_attr type K_MARSHAL OPEN_PARENS native_type CLOSE_PARENS id\r
1581                         ;\r
1582 \r
1583 type_list               : /* EMPTY */\r
1584                           {\r
1585                                 $$ = new ArrayList (0);\r
1586                           }\r
1587                         | ELLIPSIS\r
1588                           {\r
1589                                 ArrayList type_list = new ArrayList ();\r
1590                                 // type_list.Add (TypeRef.Ellipsis);\r
1591                                 type_list.Add (new SentinelTypeRef ());\r
1592                                 $$ = type_list;\r
1593                           }\r
1594                         | type_list COMMA ELLIPSIS\r
1595                           {\r
1596                                 ArrayList type_list = (ArrayList) $1;\r
1597                                 // type_list.Add (TypeRef.Ellipsis);\r
1598                                 type_list.Add (new SentinelTypeRef ());\r
1599                                 $$ = type_list;\r
1600                           }\r
1601                         | param_attr type opt_id\r
1602                           {\r
1603                                 ArrayList type_list = new ArrayList ();\r
1604                                 type_list.Add ($2);\r
1605                                 $$ = type_list;\r
1606                           }\r
1607                         | type_list COMMA param_attr type opt_id\r
1608                           {\r
1609                                 ArrayList type_list = (ArrayList) $1;\r
1610                                 type_list.Add ($4);\r
1611                           }\r
1612                         ;\r
1613 \r
1614 opt_id                  : /* EMPTY */\r
1615                         | id\r
1616                         ;\r
1617 \r
1618 method_decls            : /* EMPTY */\r
1619                         | method_decls method_decl\r
1620                         ;\r
1621 \r
1622 method_decl             : D_EMITBYTE int32\r
1623                         | D_MAXSTACK int32\r
1624                           {\r
1625                                 codegen.CurrentMethodDef.SetMaxStack ((int) $2);\r
1626                           }\r
1627                         | D_LOCALS OPEN_PARENS local_list CLOSE_PARENS\r
1628                           {\r
1629                                 if ($3 != null) {\r
1630                                         codegen.CurrentMethodDef.AddLocals (\r
1631                                                 (ArrayList) $3);\r
1632                                 }\r
1633                           }\r
1634                         | D_LOCALS K_INIT OPEN_PARENS local_list CLOSE_PARENS\r
1635                           {\r
1636                                 if ($4 != null) {\r
1637                                         codegen.CurrentMethodDef.AddLocals (\r
1638                                                 (ArrayList) $4);\r
1639                                         codegen.CurrentMethodDef.InitLocals ();\r
1640                                 }\r
1641                           }\r
1642                         | D_ENTRYPOINT\r
1643                           {\r
1644                                 codegen.CurrentMethodDef.EntryPoint ();\r
1645                           }\r
1646                         | D_ZEROINIT\r
1647                           {\r
1648                                 codegen.CurrentMethodDef.ZeroInit ();\r
1649                           }\r
1650                         | D_EXPORT OPEN_BRACKET int32 CLOSE_BRACKET\r
1651                         | D_EXPORT OPEN_BRACKET int32 CLOSE_BRACKET K_AS id\r
1652                         | D_VTENTRY int32 COLON int32 \r
1653                         | D_OVERRIDE type_spec DOUBLE_COLON method_name\r
1654                           {\r
1655                                 codegen.CurrentTypeDef.AddOverride (codegen.CurrentMethodDef,\r
1656                                         (ITypeRef) $2, (string) $4);\r
1657                                 \r
1658                           }\r
1659                         | scope_block\r
1660                         | D_PARAM OPEN_BRACKET int32 CLOSE_BRACKET init_opt\r
1661                         | id COLON\r
1662                           {\r
1663                                 codegen.CurrentMethodDef.AddLabel ((string) $1);\r
1664                           }\r
1665                         | seh_block\r
1666                         | instr\r
1667                         | sec_decl\r
1668                         | extsource_spec\r
1669                         | language_decl\r
1670                         | customattr_decl\r
1671                           {\r
1672                                 codegen.CurrentMethodDef.AddCustomAttr ((CustomAttr) $1);\r
1673                           }\r
1674                         | data_decl\r
1675                         ;\r
1676 \r
1677 local_list              : /* EMPTY */\r
1678                         | local\r
1679                           {\r
1680                                 ArrayList local_list = new ArrayList ();\r
1681                                 local_list.Add ($1);\r
1682                                 $$ = local_list;\r
1683                           }\r
1684                         | local_list COMMA local\r
1685                           {\r
1686                                 ArrayList local_list = (ArrayList) $1;\r
1687                                 local_list.Add ($3);\r
1688                           }\r
1689                         ;\r
1690 \r
1691 local                   : type\r
1692                           {\r
1693                                 $$ = new Local (-1, (ITypeRef) $1);\r
1694                           }\r
1695                         | type id\r
1696                           {\r
1697                                 $$ = new Local (-1, (string) $2, (ITypeRef) $1);\r
1698                           }\r
1699                         | slot_num type\r
1700                           {\r
1701                                 $$ = new Local ((int) $1, (ITypeRef) $2);\r
1702                           }\r
1703                         | slot_num type id\r
1704                           {\r
1705                                 $$ = new Local ((int) $1, (string) $3, (ITypeRef) $2);\r
1706                           }\r
1707                         ;\r
1708 \r
1709 slot_num                : OPEN_BRACKET int32 CLOSE_BRACKET\r
1710                           {\r
1711                                 $$ = $2;\r
1712                           }\r
1713                         ;\r
1714 \r
1715 type_spec               : class_ref\r
1716                         | OPEN_BRACKET slashed_name CLOSE_BRACKET\r
1717                           {\r
1718                                 // This is a reference to a global method in another\r
1719                                 // assembly. This is not supported in the MS version of ilasm\r
1720                           }\r
1721                         | OPEN_BRACKET D_MODULE slashed_name CLOSE_BRACKET\r
1722                         | type\r
1723                         ;\r
1724 \r
1725 scope_block             : scope_block_begin method_decls CLOSE_BRACE\r
1726                           {\r
1727                                 $$ = new HandlerBlock ((LabelInfo) $1,\r
1728                                         codegen.CurrentMethodDef.AddLabel ());\r
1729                           }\r
1730                         ;\r
1731 \r
1732 scope_block_begin       : OPEN_BRACE\r
1733                           {\r
1734                                 $$ = codegen.CurrentMethodDef.AddLabel ();\r
1735                           }\r
1736                         ;\r
1737                         \r
1738                         \r
1739 seh_block               : try_block seh_clauses\r
1740                           {\r
1741                                 TryBlock try_block = (TryBlock) $1;\r
1742 \r
1743                                 ArrayList clause_list = (ArrayList) $2;\r
1744                                 foreach (object clause in clause_list)\r
1745                                         try_block.AddSehClause ((ISehClause) clause);\r
1746 \r
1747                                 codegen.CurrentMethodDef.AddInstr (try_block);\r
1748                           }\r
1749                         ;\r
1750 \r
1751 try_block               : D_TRY scope_block\r
1752                           {\r
1753                                 $$ = new TryBlock ((HandlerBlock) $2);\r
1754                           }\r
1755                         | D_TRY id K_TO id\r
1756                           {\r
1757                                 LabelInfo from = codegen.CurrentMethodDef.AddLabelRef ((string) $2);\r
1758                                 LabelInfo to = codegen.CurrentMethodDef.AddLabelRef ((string) $4);\r
1759                                 \r
1760                                 $$ = new TryBlock (new HandlerBlock (from, to));\r
1761                           }\r
1762                         | D_TRY int32 K_TO int32\r
1763                           {\r
1764                                 LabelInfo from = codegen.CurrentMethodDef.AddLabel ((int) $2);\r
1765                                 LabelInfo to = codegen.CurrentMethodDef.AddLabel ((int) $4);\r
1766                                 \r
1767                                 $$ = new TryBlock (new HandlerBlock (from, to));\r
1768                           }\r
1769                         ;\r
1770 \r
1771 seh_clauses             : seh_clause\r
1772                           {\r
1773                                 ArrayList clause_list = new ArrayList ();\r
1774                                 clause_list.Add ($1);\r
1775                                 $$ = clause_list;\r
1776                           }\r
1777                         | seh_clauses seh_clause\r
1778                           {\r
1779                                 ArrayList clause_list = (ArrayList) $1;\r
1780                                 clause_list.Add ($2);\r
1781                           }\r
1782                         ;\r
1783 \r
1784 seh_clause              : K_CATCH class_ref handler_block\r
1785                           {\r
1786                                 IClassRef type = (IClassRef) $2;\r
1787                                 CatchBlock cb = new CatchBlock (type);\r
1788                                 cb.SetHandlerBlock ((HandlerBlock) $3);\r
1789                                 $$ = cb;\r
1790                           }\r
1791                         | K_FINALLY handler_block\r
1792                           {\r
1793                                 FinallyBlock fb = new FinallyBlock ();\r
1794                                 fb.SetHandlerBlock ((HandlerBlock) $2);\r
1795                                 $$ = fb;\r
1796                           }\r
1797                         | K_FAULT handler_block\r
1798                           {\r
1799                                 FaultBlock fb = new FaultBlock ();\r
1800                                 fb.SetHandlerBlock ((HandlerBlock) $2);\r
1801                                 $$ = fb;\r
1802                           }\r
1803                         | filter_clause handler_block\r
1804                           {\r
1805                                 FilterBlock fb = (FilterBlock) $1;\r
1806                                 fb.SetHandlerBlock ((HandlerBlock) $2);\r
1807                           }\r
1808                         ;\r
1809 \r
1810 filter_clause           : K_FILTER scope_block\r
1811                           {\r
1812                                 HandlerBlock block = (HandlerBlock) $2;\r
1813                                 FilterBlock fb = new FilterBlock (block);\r
1814                                 $$ = fb;\r
1815                           }\r
1816                         | K_FILTER id\r
1817                           {\r
1818                                 LabelInfo from = codegen.CurrentMethodDef.AddLabelRef ((string) $2);\r
1819                                 FilterBlock fb = new FilterBlock (new HandlerBlock (from, null));\r
1820                                 $$ = fb;\r
1821                           }\r
1822                         | K_FILTER int32\r
1823                           {\r
1824                                 LabelInfo from = codegen.CurrentMethodDef.AddLabel ((int) $2);\r
1825                                 FilterBlock fb = new FilterBlock (new HandlerBlock (from, null));\r
1826                                 $$ = fb;\r
1827                           }\r
1828                         ;\r
1829 \r
1830 handler_block           : scope_block\r
1831                           {\r
1832                                 \r
1833                           }\r
1834                         | K_HANDLER id K_TO id\r
1835                           {     \r
1836                                 LabelInfo from = codegen.CurrentMethodDef.AddLabelRef ((string) $2);\r
1837                                 LabelInfo to = codegen.CurrentMethodDef.AddLabelRef ((string) $4);\r
1838 \r
1839                                 $$ = new HandlerBlock (from, to);\r
1840                           }\r
1841                         | K_HANDLER int32 K_TO int32\r
1842                           {\r
1843                                 LabelInfo from = codegen.CurrentMethodDef.AddLabelRef ((string) $2);\r
1844                                 LabelInfo to = codegen.CurrentMethodDef.AddLabelRef ((string) $4);\r
1845 \r
1846                                 $$ = new HandlerBlock (from, to);\r
1847                           }\r
1848                         ;\r
1849 \r
1850 instr                   : INSTR_NONE\r
1851                           {\r
1852                                 codegen.CurrentMethodDef.AddInstr (\r
1853                                         new SimpInstr ((Op) $1));\r
1854                           }\r
1855                         | INSTR_LOCAL int32\r
1856                           {\r
1857                                 codegen.CurrentMethodDef.AddInstr (\r
1858                                         new IntInstr ((IntOp) $1, (int) $2));        \r
1859                           }\r
1860                         | INSTR_LOCAL id\r
1861                           {\r
1862                                 int slot = codegen.CurrentMethodDef.GetNamedLocalSlot ((string) $2);\r
1863                                 codegen.CurrentMethodDef.AddInstr (\r
1864                                         new IntInstr ((IntOp) $1, slot));\r
1865                           }\r
1866                         | INSTR_PARAM int32\r
1867                           {\r
1868                                 codegen.CurrentMethodDef.AddInstr (\r
1869                                         new IntInstr ((IntOp) $1, (int) $2));\r
1870                           }\r
1871                         | INSTR_PARAM id\r
1872                           {\r
1873                                 int pos = codegen.CurrentMethodDef.GetNamedParamPos ((string) $2);\r
1874                                 codegen.CurrentMethodDef.AddInstr (\r
1875                                         new IntInstr ((IntOp) $1, pos));\r
1876                           }\r
1877                         | INSTR_I int32\r
1878                           {\r
1879                                 codegen.CurrentMethodDef.AddInstr (new\r
1880                                         IntInstr ((IntOp) $1, (int) $2));\r
1881                           }\r
1882                         | INSTR_I id\r
1883                           {\r
1884                                 int slot = codegen.CurrentMethodDef.GetNamedLocalSlot ((string) $2);\r
1885                                 codegen.CurrentMethodDef.AddInstr (new\r
1886                                         IntInstr ((IntOp) $1, slot));\r
1887                           }\r
1888                         | INSTR_I8 int64\r
1889                           {\r
1890                                 if ($1 is MiscInstr) {\r
1891                                         switch ((MiscInstr) $1) {\r
1892                                         case MiscInstr.ldc_i8:\r
1893                                         codegen.CurrentMethodDef.AddInstr (new LdcInstr ((MiscInstr) $1,\r
1894                                                 (long) $2));\r
1895                                         break;\r
1896                                         }\r
1897                                 }\r
1898                           }\r
1899                         | INSTR_R float64\r
1900                           {\r
1901                                 switch ((MiscInstr) $1) {\r
1902                                 case MiscInstr.ldc_r4:\r
1903                                 case MiscInstr.ldc_r8:\r
1904                                          codegen.CurrentMethodDef.AddInstr (new LdcInstr ((MiscInstr) $1, (double) $2));\r
1905                                          break;\r
1906                                 }\r
1907                           }\r
1908                         | INSTR_R int64\r
1909                           {\r
1910                                 long l = (long) $2;\r
1911                                 \r
1912                                 switch ((MiscInstr) $1) {\r
1913                                         case MiscInstr.ldc_r4:\r
1914                                         case MiscInstr.ldc_r8:\r
1915                                         codegen.CurrentMethodDef.AddInstr (new LdcInstr ((MiscInstr) $1, (double) l));\r
1916                                         break;\r
1917                                 }\r
1918                           }\r
1919                         | INSTR_R OPEN_PARENS bytes CLOSE_PARENS\r
1920                         | INSTR_BRTARGET int32\r
1921                           {\r
1922                                 LabelInfo target = codegen.CurrentMethodDef.AddLabel ((int) $2);\r
1923                                 codegen.CurrentMethodDef.AddInstr (new BranchInstr ((BranchOp) $1,\r
1924                                                                    target));  \r
1925                           }\r
1926                         | INSTR_BRTARGET id\r
1927                           {\r
1928                                 LabelInfo target = codegen.CurrentMethodDef.AddLabelRef ((string) $2);\r
1929                                 codegen.CurrentMethodDef.AddInstr (new BranchInstr ((BranchOp) $1,\r
1930                                                                    target));\r
1931                           }\r
1932                         | INSTR_METHOD method_ref\r
1933                           {\r
1934                                 codegen.CurrentMethodDef.AddInstr (new MethodInstr ((MethodOp) $1,\r
1935                                         (IMethodRef) $2));\r
1936                           }\r
1937                         | INSTR_FIELD type type_spec DOUBLE_COLON id\r
1938                           {\r
1939                                 \r
1940                                 ITypeRef owner = (ITypeRef) $3;\r
1941                                 IFieldRef fieldref = owner.GetFieldRef (\r
1942                                         (ITypeRef) $2, (string) $5);\r
1943 \r
1944                                 codegen.CurrentMethodDef.AddInstr (new FieldInstr ((FieldOp) $1, fieldref));\r
1945                           }\r
1946                         | INSTR_FIELD type id\r
1947                           {\r
1948                                 GlobalFieldRef fieldref = new GlobalFieldRef ((ITypeRef) $2, (string) $3);\r
1949 \r
1950                                 codegen.CurrentMethodDef.AddInstr (new FieldInstr ((FieldOp) $1, fieldref));\r
1951                           }\r
1952                         | INSTR_TYPE type_spec\r
1953                           {\r
1954                                 codegen.CurrentMethodDef.AddInstr (new TypeInstr ((TypeOp) $1,\r
1955                                         (ITypeRef) $2));\r
1956                           }\r
1957                         | INSTR_STRING comp_qstring\r
1958                           {\r
1959                                 if ((MiscInstr) $1 == MiscInstr.ldstr)\r
1960                                         codegen.CurrentMethodDef.AddInstr (new LdstrInstr ((string) $2));\r
1961                           }\r
1962                         | INSTR_STRING K_BYTEARRAY ASSIGN OPEN_PARENS\r
1963                           bytes CLOSE_PARENS\r
1964                           {\r
1965                                 byte[] bs = (byte[]) $5;\r
1966                                 if ((MiscInstr) $1 == MiscInstr.ldstr)\r
1967                                         codegen.CurrentMethodDef.AddInstr (new LdstrInstr (bs));\r
1968                           }\r
1969                         | INSTR_STRING K_BYTEARRAY OPEN_PARENS bytes\r
1970                           CLOSE_PARENS\r
1971                           {\r
1972                                 byte[] bs = (byte[]) $4;\r
1973                                 if ((MiscInstr) $1 == MiscInstr.ldstr)\r
1974                                         codegen.CurrentMethodDef.AddInstr (new LdstrInstr (bs));\r
1975                           }\r
1976                         | INSTR_SIG call_conv type OPEN_PARENS type_list CLOSE_PARENS\r
1977                           {\r
1978                                 ArrayList arg_list = (ArrayList) $5;\r
1979                                 ITypeRef[] arg_array = null;\r
1980 \r
1981                                 if (arg_list != null)\r
1982                                         arg_array = (ITypeRef[]) arg_list.ToArray (typeof (ITypeRef));\r
1983 \r
1984                                 codegen.CurrentMethodDef.AddInstr (new CalliInstr ((CallConv) $2,\r
1985                                         (ITypeRef) $3, arg_array));\r
1986                           }     \r
1987                         | INSTR_TOK owner_type\r
1988                           {\r
1989                                 if ((MiscInstr) $1 == MiscInstr.ldtoken) {\r
1990                                         if ($2 is IMethodRef)\r
1991                                                 codegen.CurrentMethodDef.AddInstr (new LdtokenInstr ((IMethodRef) $2));\r
1992                                         else if ($2 is IFieldRef)\r
1993                                                 codegen.CurrentMethodDef.AddInstr (new LdtokenInstr ((IFieldRef) $2));\r
1994                                         else\r
1995                                                 codegen.CurrentMethodDef.AddInstr (new LdtokenInstr ((ITypeRef) $2));\r
1996                                                 \r
1997                                 }\r
1998                           }\r
1999                         | INSTR_SWITCH OPEN_PARENS labels CLOSE_PARENS\r
2000                           {\r
2001                                 codegen.CurrentMethodDef.AddInstr (new SwitchInstr ((ArrayList) $3));\r
2002                           }\r
2003                         ;\r
2004 \r
2005 method_ref              : call_conv type type_spec DOUBLE_COLON method_name\r
2006                           OPEN_PARENS type_list CLOSE_PARENS \r
2007                           {\r
2008                                 ITypeRef owner = (ITypeRef) $3;\r
2009                                 ArrayList arg_list = (ArrayList) $7;\r
2010                                 ITypeRef[] param_list;\r
2011                                 IMethodRef methref;\r
2012 \r
2013                                 if (arg_list != null)\r
2014                                         param_list = (ITypeRef[]) arg_list.ToArray (typeof (ITypeRef));\r
2015                                 else\r
2016                                         param_list = new ITypeRef[0];\r
2017 \r
2018                                 if (owner.UseTypeSpec) {\r
2019                                         methref = new TypeSpecMethodRef (owner, (ITypeRef) $2,\r
2020                                                 (CallConv) $1, (string) $5, param_list);\r
2021                                 } else {\r
2022                                         methref = owner.GetMethodRef ((ITypeRef) $2,\r
2023                                                 (CallConv) $1, (string) $5, param_list);\r
2024                                 }\r
2025 \r
2026                                 $$ = methref;\r
2027                           }\r
2028                         | call_conv type method_name \r
2029                           OPEN_PARENS type_list CLOSE_PARENS\r
2030                           {\r
2031                                 ArrayList arg_list = (ArrayList) $5;\r
2032                                 ITypeRef[] param_list;\r
2033   \r
2034                                 if (arg_list != null)\r
2035                                         param_list = (ITypeRef[]) arg_list.ToArray (typeof (ITypeRef));\r
2036                                 else\r
2037                                         param_list = new ITypeRef[0];\r
2038 \r
2039                                 $$ = new GlobalMethodRef ((ITypeRef) $2, (CallConv) $1,\r
2040                                         (string) $3, param_list);\r
2041                           }\r
2042                         | call_conv type type_spec DOUBLE_COLON method_name\r
2043                           typars_clause OPEN_PARENS type_list CLOSE_PARENS \r
2044                           {\r
2045                                 ITypeRef owner = (ITypeRef) $3;\r
2046                                 ArrayList arg_list = (ArrayList) $8;\r
2047                                 ITypeRef[] param_list;\r
2048                                 IMethodRef methref;\r
2049 \r
2050                                 if (arg_list != null)\r
2051                                         param_list = (ITypeRef[]) arg_list.ToArray (typeof (ITypeRef));\r
2052                                 else\r
2053                                         param_list = new ITypeRef[0];\r
2054 \r
2055                                 if (owner.UseTypeSpec) {\r
2056                                         methref = new TypeSpecMethodRef (owner, (ITypeRef) $2,\r
2057                                                 (CallConv) $1, (string) $5, param_list);\r
2058                                 } else {\r
2059                                         methref = owner.GetMethodRef ((ITypeRef) $2,\r
2060                                                 (CallConv) $1, (string) $5, param_list);\r
2061                                 }\r
2062 \r
2063                                 if ($6 != null) {\r
2064                                         ArrayList tp = (ArrayList) $6;\r
2065                                         ITypeRef[] ta = (ITypeRef[]) tp.ToArray (typeof (ITypeRef));\r
2066                                         \r
2067                                         methref = new GenericMethodRef (methref, new GenericMethodSig (ta));\r
2068                                 }\r
2069                                 \r
2070                                 $$ = methref;\r
2071                           }\r
2072                         ;\r
2073 \r
2074 labels                  : /* EMPTY */\r
2075                         | id\r
2076                           {\r
2077                                 ArrayList label_list = new ArrayList ();\r
2078                                 label_list.Add ($1);\r
2079                                 $$ = label_list;\r
2080                           }\r
2081                         | int32\r
2082                           {\r
2083                                 ArrayList label_list = new ArrayList ();\r
2084                                 label_list.Add ($1);\r
2085                                 $$ = label_list;\r
2086                           }\r
2087                         | labels COMMA id\r
2088                           {\r
2089                                 ArrayList label_list = (ArrayList) $1;\r
2090                                 label_list.Add ($3);\r
2091                           }\r
2092                         | labels COMMA int32\r
2093                           {\r
2094                                 ArrayList label_list = (ArrayList) $1;\r
2095                                 label_list.Add ($3);\r
2096                           }\r
2097                         ;\r
2098 \r
2099 owner_type              : type_spec\r
2100                         | member_ref\r
2101                         ;\r
2102 \r
2103 member_ref              : K_METHOD method_ref\r
2104                           {\r
2105                                 $$ = $2;\r
2106                           }\r
2107                         | K_FIELD type type_spec DOUBLE_COLON id\r
2108                           {\r
2109                                 ITypeRef owner = (ITypeRef) $3;\r
2110 \r
2111                                 $$ = owner.GetFieldRef (\r
2112                                         (ITypeRef) $2, (string) $5);\r
2113                           }\r
2114                         | K_FIELD type id\r
2115                           {\r
2116                                 $$ = new GlobalFieldRef ((ITypeRef) $2, (string) $3);\r
2117                           }\r
2118                         ;\r
2119 \r
2120 event_all               : event_head OPEN_BRACE event_decls CLOSE_BRACE\r
2121                           {\r
2122                                 codegen.CurrentTypeDef.EndEventDef ();\r
2123                           }\r
2124                         ;\r
2125 \r
2126 event_head              : D_EVENT event_attr type_spec id\r
2127                           {\r
2128                                 EventDef event_def = new EventDef ((FeatureAttr) $2,\r
2129                                         (ITypeRef) $3, (string) $4);\r
2130                                 codegen.CurrentTypeDef.BeginEventDef (event_def);\r
2131                           }\r
2132                         | D_EVENT event_attr id\r
2133                         ;\r
2134 \r
2135 event_attr              : /* EMPTY */\r
2136                           {\r
2137                                 $$ = new FeatureAttr ();\r
2138                           }\r
2139                         | event_attr K_RTSPECIALNAME\r
2140                           {\r
2141                                 $$ = (FeatureAttr) $1 & FeatureAttr.Rtspecialname;\r
2142                           }\r
2143                         | event_attr K_SPECIALNAME\r
2144                           {\r
2145                                 $$ = (FeatureAttr) $1 & FeatureAttr.Specialname;\r
2146                           }\r
2147                         ;\r
2148 \r
2149 event_decls             : /* EMPTY */\r
2150                         | event_decls event_decl\r
2151                         ;\r
2152 \r
2153 event_decl              : D_ADDON method_ref\r
2154                           {\r
2155                                 codegen.CurrentTypeDef.CurrentEvent.AddAddon (\r
2156                                         (MethodRef) $2);                                \r
2157                           }\r
2158                         | D_REMOVEON method_ref\r
2159                           {\r
2160                                 codegen.CurrentTypeDef.CurrentEvent.AddRemoveon (\r
2161                                         (MethodRef) $2);\r
2162                           }\r
2163                         | D_FIRE method_ref\r
2164                           {\r
2165                                 codegen.CurrentTypeDef.CurrentEvent.AddFire (\r
2166                                         (MethodRef) $2);\r
2167                           }\r
2168                         | D_OTHER method_ref\r
2169                           {\r
2170                                 codegen.CurrentTypeDef.CurrentEvent.AddOther (\r
2171                                         (MethodRef) $2);\r
2172                           }\r
2173                         | customattr_decl\r
2174                         | extsource_spec\r
2175                         | language_decl\r
2176                         ;\r
2177 \r
2178 prop_all                : prop_head OPEN_BRACE prop_decls CLOSE_BRACE\r
2179                           {\r
2180                                 codegen.CurrentTypeDef.EndPropertyDef ();\r
2181                           }\r
2182                         ;\r
2183 \r
2184 prop_head               : D_PROPERTY prop_attr type id OPEN_PARENS type_list CLOSE_PARENS init_opt\r
2185                           {\r
2186                                 PropertyDef prop_def = new PropertyDef ((FeatureAttr) $2, (ITypeRef) $3,\r
2187                                         (string) $4, (ArrayList) $6);\r
2188                                 codegen.CurrentTypeDef.BeginPropertyDef (prop_def);\r
2189 \r
2190                                 if ($8 != null) {\r
2191                                         prop_def.AddInitValue ((Constant) $8);\r
2192                                 }\r
2193                           }\r
2194                         ;\r
2195 \r
2196 prop_attr               : /* EMPTY */\r
2197                           {\r
2198                                 $$ = new FeatureAttr ();\r
2199                           }\r
2200                         | prop_attr K_RTSPECIALNAME\r
2201                           {\r
2202                                 $$ = (FeatureAttr) $1 | FeatureAttr.Rtspecialname;\r
2203                           }\r
2204                         | prop_attr K_SPECIALNAME\r
2205                           {\r
2206                                 $$ = (FeatureAttr) $1 | FeatureAttr.Specialname;\r
2207                           }\r
2208                         ;\r
2209 \r
2210 prop_decls              : /* EMPTY */\r
2211                         | prop_decls prop_decl\r
2212                         ;\r
2213 \r
2214 prop_decl               : D_SET method_ref\r
2215                           {\r
2216                                 codegen.CurrentTypeDef.CurrentProperty.AddSet ((MethodRef) $2);\r
2217                           }\r
2218                         | D_GET method_ref\r
2219                           {\r
2220                                 codegen.CurrentTypeDef.CurrentProperty.AddGet ((MethodRef) $2);\r
2221                           }\r
2222                         | D_OTHER method_ref\r
2223                           {\r
2224                                 codegen.CurrentTypeDef.CurrentProperty.AddOther ((MethodRef) $2);\r
2225                           }\r
2226                         | customattr_decl\r
2227                         | extsource_spec\r
2228                         | language_decl\r
2229                         ;\r
2230 \r
2231 customattr_decl         : D_CUSTOM custom_type\r
2232                           {\r
2233                                 $$ = new CustomAttr ((IMethodRef) $2, null);\r
2234                           }\r
2235                         | D_CUSTOM custom_type ASSIGN comp_qstring\r
2236                         | D_CUSTOM custom_type ASSIGN OPEN_PARENS bytes CLOSE_PARENS\r
2237                           {\r
2238                                 $$ = new CustomAttr ((IMethodRef) $2,\r
2239                                         (byte[]) $5);\r
2240                           }\r
2241                         | D_CUSTOM OPEN_PARENS owner_type CLOSE_PARENS custom_type\r
2242                         | D_CUSTOM OPEN_PARENS owner_type CLOSE_PARENS custom_type ASSIGN comp_qstring\r
2243                         | D_CUSTOM OPEN_PARENS owner_type CLOSE_PARENS custom_type ASSIGN\r
2244                           OPEN_PARENS bytes CLOSE_PARENS\r
2245                         ;\r
2246                         \r
2247 custom_type             : call_conv type type_spec DOUBLE_COLON D_CTOR OPEN_PARENS type_list CLOSE_PARENS\r
2248                           {\r
2249                                 ITypeRef owner = (ITypeRef) $3;\r
2250                                 ArrayList arg_list = (ArrayList) $7;\r
2251                                 ITypeRef[] param_list;\r
2252   \r
2253                                 if (arg_list != null)\r
2254                                         param_list = (ITypeRef[]) arg_list.ToArray (typeof (ITypeRef));\r
2255                                 else\r
2256                                         param_list = new ITypeRef[0];\r
2257 \r
2258                                 $$ = owner.GetMethodRef ((ITypeRef) $2,\r
2259                                         (CallConv) $1, (string) $5, param_list);\r
2260                           }\r
2261                         | call_conv type D_CTOR OPEN_PARENS type_list CLOSE_PARENS\r
2262                           {\r
2263                                 ArrayList arg_list = (ArrayList) $5;\r
2264                                 ITypeRef[] param_list;\r
2265   \r
2266                                 if (arg_list != null)\r
2267                                         param_list = (ITypeRef[]) arg_list.ToArray (typeof (ITypeRef));\r
2268                                 else\r
2269                                         param_list = new ITypeRef[0];\r
2270 \r
2271                                 $$ = new GlobalMethodRef ((ITypeRef) $2, (CallConv) $1,\r
2272                                         (string) $3, param_list);\r
2273                           }\r
2274                         ;\r
2275 \r
2276 sec_decl                : D_PERMISSION sec_action type_spec OPEN_PARENS nameval_pairs CLOSE_PARENS\r
2277                         | D_PERMISSION sec_action type_spec\r
2278                         | D_PERMISSIONSET sec_action ASSIGN OPEN_PARENS bytes CLOSE_PARENS\r
2279                         ;\r
2280 \r
2281 nameval_pairs           : nameval_pair \r
2282                         | nameval_pairs COMMA nameval_pair\r
2283                         ;\r
2284 \r
2285 nameval_pair            : comp_qstring ASSIGN cavalue\r
2286                         ;\r
2287 \r
2288 cavalue                 : truefalse\r
2289                         | int32\r
2290                         | int32 OPEN_PARENS int32 CLOSE_PARENS\r
2291                         | comp_qstring \r
2292                         | class_ref OPEN_PARENS K_INT8 COLON int32 CLOSE_PARENS\r
2293                         | class_ref OPEN_PARENS K_INT16 COLON int32 CLOSE_PARENS\r
2294                         | class_ref OPEN_PARENS K_INT32 COLON int32 CLOSE_PARENS\r
2295                         | class_ref OPEN_PARENS int32 CLOSE_PARENS\r
2296                         ;\r
2297 \r
2298 sec_action              : K_REQUEST\r
2299                         | K_DEMAND\r
2300                         | K_ASSERT\r
2301                         | K_DENY\r
2302                         | K_PERMITONLY\r
2303                         | K_LINKCHECK\r
2304                         | K_INHERITCHECK\r
2305                         | K_REQMIN\r
2306                         | K_REQOPT\r
2307                         | K_REQREFUSE\r
2308                         | K_PREJITGRANT\r
2309                         | K_PREJITDENY\r
2310                         | K_NONCASDEMAND\r
2311                         | K_NONCASLINKDEMAND\r
2312                         | K_NONCASINHERITANCE\r
2313                         ;\r
2314 \r
2315 module_head             : D_MODULE\r
2316                         | D_MODULE comp_name\r
2317                         | D_MODULE K_EXTERN comp_name\r
2318                         ;\r
2319 \r
2320 file_decl               : D_FILE file_attr comp_name file_entry D_HASH ASSIGN\r
2321                           OPEN_PARENS bytes CLOSE_PARENS file_entry\r
2322                         | D_FILE file_attr comp_name file_entry\r
2323                         ;\r
2324 \r
2325 file_attr               : /* EMPTY */\r
2326                         | file_attr K_NOMETADATA\r
2327                         ;\r
2328 \r
2329 file_entry              : /* EMPTY */\r
2330                         | D_ENTRYPOINT\r
2331                         ;\r
2332 \r
2333 assembly_all            : assembly_head OPEN_BRACE assembly_decls CLOSE_BRACE\r
2334                         ;\r
2335 \r
2336 assembly_head           : D_ASSEMBLY asm_attr slashed_name\r
2337                           {\r
2338                                 codegen.SetAssemblyName ((string) $3);\r
2339                           }\r
2340                         ;\r
2341 \r
2342 asm_attr                : /* EMPTY */\r
2343                         | asm_attr K_NOAPPDOMAIN\r
2344                         | asm_attr K_NOPROCESS\r
2345                         | asm_attr K_NOMACHINE\r
2346                         ;\r
2347 \r
2348 assembly_decls          : /* EMPTY */\r
2349                         | assembly_decls assembly_decl\r
2350                         ;\r
2351 \r
2352 assembly_decl           : D_HASH K_ALGORITHM int32\r
2353                         | sec_decl\r
2354                         | asm_or_ref_decl\r
2355                         ;\r
2356 \r
2357 asm_or_ref_decl         : D_PUBLICKEY ASSIGN OPEN_PARENS bytes CLOSE_PARENS\r
2358                         | D_VER int32 COLON int32 COLON int32 COLON int32 \r
2359                         | D_LOCALE comp_qstring\r
2360                         | D_LOCALE ASSIGN OPEN_PARENS bytes CLOSE_PARENS\r
2361                         | customattr_decl\r
2362                         ;\r
2363 \r
2364 assemblyref_all         : assemblyref_head OPEN_BRACE assemblyref_decls CLOSE_BRACE\r
2365                         ;\r
2366 \r
2367 assemblyref_head        : D_ASSEMBLY K_EXTERN slashed_name\r
2368                           {\r
2369                                 System.Reflection.AssemblyName asmb_name = \r
2370                                         new System.Reflection.AssemblyName ();\r
2371                                 asmb_name.Name = (string) $3;\r
2372                                 codegen.ExternTable.AddAssembly ((string) $3, asmb_name);\r
2373                           }\r
2374                         | D_ASSEMBLY K_EXTERN slashed_name K_AS slashed_name\r
2375                           {\r
2376                                 System.Reflection.AssemblyName asmb_name = \r
2377                                         new System.Reflection.AssemblyName ();\r
2378                                 asmb_name.Name = (string) $3;\r
2379                                 codegen.ExternTable.AddAssembly ((string) $5, asmb_name);\r
2380                           }\r
2381                         ;\r
2382 \r
2383 assemblyref_decls       : /* EMPTY */\r
2384                         | assemblyref_decls assemblyref_decl\r
2385                         ;\r
2386 \r
2387 assemblyref_decl        : D_HASH ASSIGN OPEN_PARENS bytes CLOSE_PARENS\r
2388                         | asm_or_ref_decl\r
2389                         | D_PUBLICKEYTOKEN ASSIGN OPEN_PARENS bytes CLOSE_PARENS\r
2390                         ;\r
2391 \r
2392 exptype_all             : exptype_head OPEN_BRACE exptype_decls CLOSE_BRACE\r
2393                         ;\r
2394 \r
2395 exptype_head            : D_CLASS K_EXTERN expt_attr comp_name\r
2396                         ;\r
2397 \r
2398 expt_attr               : /* EMPTY */\r
2399                         | expt_attr K_PRIVATE\r
2400                         | expt_attr K_PUBLIC \r
2401                         | expt_attr K_NESTED K_PUBLIC\r
2402                         | expt_attr K_NESTED K_PRIVATE\r
2403                         | expt_attr K_NESTED K_FAMILY\r
2404                         | expt_attr K_NESTED K_ASSEMBLY\r
2405                         | expt_attr K_NESTED K_FAMANDASSEM\r
2406                         | expt_attr K_NESTED K_FAMORASSEM\r
2407                         ;\r
2408 \r
2409 exptype_decls           : /* EMPTY */\r
2410                         | exptype_decls exptype_decl\r
2411                         ;\r
2412 \r
2413 exptype_decl            : D_FILE comp_name\r
2414                         | D_CLASS K_EXTERN comp_name\r
2415                         | D_CLASS int32\r
2416                         | customattr_decl\r
2417                         ;\r
2418 \r
2419 manifestres_all         : manifestres_head OPEN_BRACE manifestres_decls CLOSE_BRACE\r
2420                         ;\r
2421 \r
2422 manifestres_head        : D_MRESOURCE manres_attr comp_name     \r
2423                         ;\r
2424 \r
2425 manres_attr             : /* EMPTY */\r
2426                         | manres_attr K_PUBLIC\r
2427                         | manres_attr K_PRIVATE\r
2428                         ;\r
2429 \r
2430 manifestres_decls       : /* EMPTY */\r
2431                         | manifestres_decls manifestres_decl\r
2432                         ;\r
2433 \r
2434 manifestres_decl        : D_FILE comp_name K_AT int32\r
2435                         | D_ASSEMBLY K_EXTERN slashed_name\r
2436                         | customattr_decl\r
2437                         ;\r
2438 \r
2439 comp_qstring            : QSTRING\r
2440                         | comp_qstring PLUS QSTRING     { $$ = String.Format ("{0}{1}", $1, $3); }\r
2441                         ;\r
2442 \r
2443 int32                   : INT64\r
2444                           {\r
2445                                 long l = (long) $1;\r
2446                                 byte[] intb = BitConverter.GetBytes (l);\r
2447                                 $$ = BitConverter.ToInt32 (intb, 0);\r
2448                           }\r
2449                         ;\r
2450 \r
2451 int64                   : INT64\r
2452                         ;\r
2453 \r
2454 float64                 : FLOAT64\r
2455                         | K_FLOAT32 OPEN_PARENS INT32 CLOSE_PARENS\r
2456                           {\r
2457                                 int i = (int) $3;\r
2458                                 byte[] intb = BitConverter.GetBytes (i);\r
2459                                 $$ = (double) BitConverter.ToSingle (intb, 0);\r
2460                           }\r
2461                         | K_FLOAT32 OPEN_PARENS INT64 CLOSE_PARENS\r
2462                           {\r
2463                                 long l = (long) $3;\r
2464                                 byte[] intb = BitConverter.GetBytes (l);\r
2465                                 $$ = (double) BitConverter.ToSingle (intb, 0);\r
2466                           }\r
2467                         | K_FLOAT64 OPEN_PARENS INT64 CLOSE_PARENS\r
2468                           {\r
2469                                 byte[] intb = BitConverter.GetBytes ((long) $3);\r
2470                                 $$ = BitConverter.ToDouble (intb, 0);\r
2471                           }\r
2472                         | K_FLOAT64 OPEN_PARENS INT32 CLOSE_PARENS\r
2473                           {\r
2474                                 byte[] intb = BitConverter.GetBytes ((int) $3);\r
2475                                 $$ = (double) BitConverter.ToSingle (intb, 0);\r
2476                           }\r
2477                         ;\r
2478 \r
2479 hexbyte                 : HEXBYTE       { }\r
2480                         | INT64\r
2481                           {\r
2482                                 long l = (long) $1;\r
2483                                 byte b = Byte.Parse (l.ToString (), NumberStyles.HexNumber);\r
2484                                 $$ = b;\r
2485                           }\r
2486                         | ID\r
2487                           {\r
2488                                 $$ = Byte.Parse ((string) $1, NumberStyles.HexNumber);\r
2489                           }\r
2490                         ;\r
2491 \r
2492 bytes                   : /* EMPTY */   { $$ = new byte[0]; }\r
2493                         | hexbytes\r
2494                           {\r
2495                                 ArrayList byte_list = (ArrayList) $1;\r
2496                                 $$ = byte_list.ToArray (typeof (byte));\r
2497                           }\r
2498                         ;\r
2499 \r
2500 hexbytes                : hexbyte\r
2501                           {\r
2502                                 ArrayList byte_list = new ArrayList ();\r
2503                                 byte_list.Add (Convert.ToByte ($1));\r
2504                                 $$ = byte_list;\r
2505                           }\r
2506                         | hexbytes hexbyte\r
2507                           {\r
2508                                 ArrayList byte_list = (ArrayList) $1;\r
2509                                 byte_list.Add (Convert.ToByte ($2));\r
2510                           }\r
2511                         ;\r
2512 \r
2513 truefalse               : K_TRUE\r
2514                         | K_FALSE\r
2515                         ;\r
2516 \r
2517 id                      : ID\r
2518                         | SQSTRING\r
2519                         ;\r
2520 \r
2521 comp_name               : id\r
2522                         | comp_name DOT id\r
2523                           {\r
2524                                 $$ = (string) $1 + '.' + (string) $3;\r
2525                           }\r
2526                         | COMP_NAME\r
2527                         ;\r
2528 \r
2529 %%\r
2530 \r
2531 }\r
2532 \r