3 // Mono::ILASM::ILParser
\r
5 // (C) Sergey Chaban (serge@wildwestsoftware.com)
\r
6 // (C) 2003 Jackson Harper, All rights reserved
\r
12 using System.Collections;
\r
13 using System.Globalization;
\r
15 namespace Mono.ILASM {
\r
17 public class ILParser {
\r
19 private CodeGen codegen;
\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
29 public ILParser (CodeGen codegen, StreamReader stream) {
\r
30 this.codegen = codegen;
\r
31 this.stream = stream;
\r
34 public CodeGen CodeGen {
\r
35 get { return codegen; }
\r
42 /* ID - alpha-numeric identifier */
\r
45 /* QSTRING - quoted string */
\r
48 /* SQSTRING - single quoted string */
\r
51 /* COMP_NAME - A name with dots */
\r
54 /* INT32 - 32 bit integer */
\r
57 /* INT64 - 64 bit integer */
\r
60 /* FLOAT64 - floating point number */
\r
63 /* HEXBYTE - two digit hex number */
\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
77 %token DOUBLE_COLON "::"
\r
78 %token SEMICOLON ";"
\r
81 %token AMPERSAND "&"
\r
85 %token ELLIPSIS "..."
\r
87 %token OPEN_ANGLE_BRACKET "<"
\r
88 %token CLOSE_ANGLE_BRACKET ">"
\r
95 /* INSTR_* instruction types */
\r
101 %token INSTR_BRTARGET
\r
102 %token INSTR_METHOD
\r
103 %token INSTR_NEWOBJ
\r
106 %token INSTR_STRING
\r
110 %token INSTR_SWITCH
\r
119 /* Mechanically generated - DO NOT EDIT! */
\r
128 %token D_CAPABILITY
\r
133 %token D_CONSTRAINT
\r
140 %token D_ENTRYPOINT
\r
149 %token D_IMPLICITCOM
\r
155 %token D_MANIFESTRES
\r
162 %token D_ORIGINATOR
\r
168 %token D_PERMISSION
\r
169 %token D_PERMISSIONSET
\r
173 %token D_PUBLICKEYTOKEN
\r
190 %token K_IMPLICITCOM
\r
191 %token K_IMPLICITRES
\r
192 %token K_NOAPPDOMAIN
\r
216 %token K_RTSPECIALNAME
\r
217 %token K_SPECIALNAME
\r
219 %token K_FAMANDASSEM
\r
220 %token K_FAMORASSEM
\r
221 %token K_PRIVATESCOPE
\r
223 %token K_NOTSERIALIZED
\r
225 %token K_NOT_IN_GC_HEAP
\r
230 %token K_SEQUENTIAL
\r
235 %token K_SERIALIZABLE
\r
239 %token K_IMPLEMENTS
\r
244 %token K_UNMANAGEDEXP
\r
245 %token K_PINVOKEIMPL
\r
255 %token K_FORWARDREF
\r
257 %token K_INTERNALCALL
\r
258 %token K_SYNCHRONIZED
\r
259 %token K_NOINLINING
\r
300 %token K_USERDEFINED
\r
306 %token K_STREAMED_OBJECT
\r
307 %token K_STORED_OBJECT
\r
308 %token K_BLOB_OBJECT
\r
319 %token K_FROMUNMANAGED
\r
320 %token K_CALLMOSTDERIVED
\r
336 %token K_PERMITONLY
\r
338 %token K_INHERITCHECK
\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
348 %token K_NOMETADATA
\r
350 %token K_FULLORIGIN
\r
354 %token K_ENABLEJITTRACKING
\r
355 %token K_DISABLEJITOPTIMIZER
\r
356 %token K_PRESERVESIG
\r
357 %token K_BEFOREFIELDINIT
\r
361 %token K_COMPILERCONTROLLED
\r
370 /* end generated */
\r
383 decls : /* EMPTY */
\r
401 | D_SUBSYSTEM int32
\r
403 codegen.SetSubSystem ((int) $2);
\r
407 codegen.SetCorFlags ((int) $2);
\r
409 | D_FILE K_ALIGNMENT int32
\r
410 | D_IMAGEBASE int64
\r
412 codegen.SetImageBase ((long) $2);
\r
418 extsource_spec : D_LINE int32 SQSTRING
\r
420 | D_LINE int32 COLON int32 SQSTRING
\r
421 | D_LINE int32 COLON int32
\r
424 language_decl : D_LANGUAGE SQSTRING
\r
425 | D_LANGUAGE SQSTRING COMMA SQSTRING
\r
426 | D_LANGUAGE SQSTRING COMMA SQSTRING COMMA SQSTRING
\r
429 constraint_decl : D_CONSTRAINT BANG int32 K_IS type
\r
431 codegen.CurrentTypeDef.AddGenericConstraint ((int) $3, (ITypeRef) $5);
\r
435 vtfixup_decl : D_VTFIXUP OPEN_BRACKET int32 CLOSE_BRACKET
\r
436 vtfixup_attr K_AT id
\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
446 namespace_all : namespace_head OPEN_BRACE decls CLOSE_BRACE
\r
448 codegen.CurrentNameSpace = null;
\r
452 namespace_head : D_NAMESPACE comp_name
\r
454 codegen.CurrentNameSpace = (string) $2;
\r
458 class_all : class_head OPEN_BRACE class_decls CLOSE_BRACE
\r
460 codegen.EndTypeDef ();
\r
464 class_head : D_CLASS class_attr id formal_typars_clause extends_clause
\r
467 codegen.BeginTypeDef ((TypeAttr) $2, (string) $3,
\r
468 $5 as IClassRef, $6 as ArrayList, null);
\r
470 if (is_value_class)
\r
471 codegen.CurrentTypeDef.MakeValueClass ();
\r
473 codegen.CurrentTypeDef.MakeEnumClass ();
\r
476 ArrayList typars_list = (ArrayList) $4;
\r
477 foreach (string id in typars_list)
\r
478 codegen.CurrentTypeDef.AddGenericParam (id);
\r
483 class_attrs : class_attrs class_attr
\r
486 class_attr : /* EMPTY */
\r
488 // Reset some flags
\r
489 is_value_class = false;
\r
490 is_enum_class = false;
\r
491 $$ = new TypeAttr ();
\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
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
520 extends_clause : /* EMPTY */
\r
521 | K_EXTENDS class_ref
\r
527 impl_clause : /* EMPTY */
\r
528 | K_IMPLEMENTS class_refs
\r
534 formal_typars_clause : /* EMPTY */
\r
535 | OPEN_ANGLE_BRACKET formal_typars CLOSE_ANGLE_BRACKET
\r
541 typars_clause : /* EMPTY */
\r
542 | OPEN_ANGLE_BRACKET typars CLOSE_ANGLE_BRACKET
\r
550 ArrayList typars_list = new ArrayList ();
\r
551 typars_list.Add ($1);
\r
554 | typars COMMA type
\r
556 ArrayList typars_list = (ArrayList) $1;
\r
557 typars_list.Add ($3);
\r
562 formal_typars : formal_typar
\r
564 ArrayList formal_list = new ArrayList ();
\r
565 formal_list.Add ($1);
\r
568 | formal_typars COMMA formal_typar
\r
570 ArrayList formal_list = (ArrayList) $1;
\r
571 formal_list.Add ($3);
\r
583 class_refs : class_ref
\r
585 ArrayList class_list = new ArrayList ();
\r
586 class_list.Add ($1);
\r
589 | class_refs COMMA class_ref
\r
591 ArrayList class_list = (ArrayList) $1;
\r
592 class_list.Add ($3);
\r
596 slashed_name : comp_name
\r
597 | slashed_name SLASH comp_name
\r
599 $$ = String.Format ("{0}/{1}", $1, $3);
\r
603 class_ref : OPEN_BRACKET slashed_name CLOSE_BRACKET slashed_name
\r
605 if (codegen.IsThisAssembly ((string) $2)) {
\r
606 $$ = new TypeRef ((string) $4, false, null);
\r
608 $$ = codegen.ExternTable.GetTypeRef ((string) $2, (string) $4, false);
\r
611 | OPEN_BRACKET D_MODULE slashed_name CLOSE_BRACKET slashed_name
\r
614 PrimitiveTypeRef prim = PrimitiveTypeRef.GetPrimitiveType ((string) $1);
\r
619 $$ = new TypeRef ((string) $1, false, null);
\r
624 class_decls : /* EMPTY */
\r
625 | class_decls class_decl
\r
628 class_decl : method_all
\r
638 codegen.CurrentTypeDef.AddCustomAttribute ((CustomAttr) $1);
\r
642 codegen.CurrentTypeDef.SetSize ((int) $2);
\r
646 codegen.CurrentTypeDef.SetPack ((int) $2);
\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
652 // My copy of the spec didn't have a type_list but
\r
653 // it seems pretty crucial
\r
655 ITypeRef owner = (ITypeRef) $2;
\r
656 ArrayList arg_list = (ArrayList) $11;
\r
657 ITypeRef[] param_list;
\r
660 if (arg_list != null)
\r
661 param_list = (ITypeRef[]) arg_list.ToArray (typeof (ITypeRef));
\r
663 param_list = new ITypeRef[0];
\r
665 decl = owner.GetMethodRef ((ITypeRef) $7,
\r
666 (CallConv) $6, (string) $4, param_list);
\r
668 string sig = MethodDef.CreateSignature ((string) $10,
\r
670 codegen.CurrentTypeDef.AddOverride (sig, decl);
\r
672 OPEN_PARENS sig_args CLOSE_PARENS
\r
677 type : K_CLASS class_ref
\r
683 $$ = new PrimitiveTypeRef (PrimitiveType.Object, "System.Object");
\r
687 $$ = new PrimitiveTypeRef (PrimitiveType.String, "System.String");
\r
689 | K_VALUE K_CLASS class_ref
\r
691 IClassRef class_ref = (IClassRef) $3;
\r
692 class_ref.MakeValueClass ();
\r
695 | K_VALUETYPE OPEN_BRACKET slashed_name CLOSE_BRACKET slashed_name
\r
697 ExternTypeRef ext_ref = codegen.ExternTable.GetTypeRef ((string) $3, (string) $5, false);
\r
698 ext_ref.MakeValueClass ();
\r
701 | K_VALUETYPE slashed_name
\r
703 TypeRef t_ref = new TypeRef ((string) $2, true, null);
\r
704 t_ref.MakeValueClass ();
\r
707 | type OPEN_BRACKET CLOSE_BRACKET
\r
709 ITypeRef base_type = (ITypeRef) $1;
\r
710 base_type.MakeArray ();
\r
712 | type OPEN_BRACKET bounds CLOSE_BRACKET
\r
714 ITypeRef base_type = (ITypeRef) $1;
\r
715 ArrayList bound_list = (ArrayList) $3;
\r
716 base_type.MakeBoundArray (bound_list);
\r
720 ITypeRef base_type = (ITypeRef) $1;
\r
721 base_type.MakeManagedPointer ();
\r
725 ITypeRef base_type = (ITypeRef) $1;
\r
726 base_type.MakeUnmanagedPointer ();
\r
730 ITypeRef base_type = (ITypeRef) $1;
\r
731 base_type.MakePinned ();
\r
733 | type K_MODREQ OPEN_PARENS class_ref CLOSE_PARENS
\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
740 | type K_MODOPT OPEN_PARENS class_ref CLOSE_PARENS
\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
747 | K_METHOD call_conv type STAR OPEN_PARENS sig_args CLOSE_PARENS
\r
750 $$ = new PrimitiveTypeRef (PrimitiveType.TypedRef,
\r
751 "System.TypedReference");
\r
755 $$ = new PrimitiveTypeRef (PrimitiveType.Char, "System.Char");
\r
759 $$ = new PrimitiveTypeRef (PrimitiveType.Void, "System.Void");
\r
763 $$ = new PrimitiveTypeRef (PrimitiveType.Boolean, "System.Bool");
\r
767 $$ = new PrimitiveTypeRef (PrimitiveType.Int8, "System.Int8");
\r
771 $$ = new PrimitiveTypeRef (PrimitiveType.Int16, "System.Int16");
\r
775 $$ = new PrimitiveTypeRef (PrimitiveType.Int32, "System.Int32");
\r
779 $$ = new PrimitiveTypeRef (PrimitiveType.Int64, "System.Int64");
\r
783 $$ = new PrimitiveTypeRef (PrimitiveType.Float32, "System.Float32");
\r
787 $$ = new PrimitiveTypeRef (PrimitiveType.Float64, "System.Float64");
\r
789 | K_UNSIGNED K_INT8
\r
791 $$ = new PrimitiveTypeRef (PrimitiveType.UInt8, "System.UInt8");
\r
793 | K_UNSIGNED K_INT16
\r
795 $$ = new PrimitiveTypeRef (PrimitiveType.UInt16, "System.UInt16");
\r
797 | K_UNSIGNED K_INT32
\r
799 $$ = new PrimitiveTypeRef (PrimitiveType.UInt32, "System.UInt32");
\r
801 | K_UNSIGNED K_INT64
\r
803 $$ = new PrimitiveTypeRef (PrimitiveType.UInt64, "System.UInt64");
\r
807 // TODO: Is this the proper full name
\r
808 $$ = new PrimitiveTypeRef (PrimitiveType.NativeInt, "System.IntPtr");
\r
811 | K_NATIVE K_UNSIGNED K_INT
\r
813 $$ = new PrimitiveTypeRef (PrimitiveType.NativeUInt, "System.UIntPtr");
\r
817 GenericTypeSpec spec = new GenericTypeSpec ((int) $2);
\r
818 $$ = new GenericTypeRef (spec, $2.ToString ());
\r
822 MVar mvar = new MVar ((int) $3);
\r
823 $$ = new GenericTypeRef (mvar, $3.ToString ());
\r
825 | K_CLASS slashed_name OPEN_ANGLE_BRACKET BANG int32 CLOSE_ANGLE_BRACKET
\r
827 $$ = new TypeRef ((string) $2, false, null);
\r
829 | K_CLASS slashed_name OPEN_ANGLE_BRACKET typars CLOSE_ANGLE_BRACKET
\r
831 ArrayList typar_list = (ArrayList) $4;
\r
832 ITypeRef[] typar_array = (ITypeRef[]) typar_list.ToArray (typeof (ITypeRef));
\r
834 $$ = new GenericTypeInst ((string)$2, typar_array);
\r
840 ArrayList bound_list = new ArrayList ();
\r
841 bound_list.Add ($1);
\r
844 | bounds COMMA bound
\r
846 ArrayList bound_list = (ArrayList) $1;
\r
847 bound_list.Add ($3);
\r
851 bound : /* EMPTY */
\r
854 // No lower bound or size
\r
855 $$ = new DictionaryEntry (TypeRef.Ellipsis, TypeRef.Ellipsis);
\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
864 | int32 ELLIPSIS int32
\r
866 // lower bound and size
\r
867 $$ = new DictionaryEntry ($1, $3);
\r
871 // Just lower bound
\r
872 $$ = new DictionaryEntry ($1, TypeRef.Ellipsis);
\r
876 call_conv : K_INSTANCE call_conv
\r
878 $$ = (CallConv) $2 | CallConv.Instance;
\r
880 | K_EXPLICIT call_conv
\r
882 $$ = (CallConv) $2 | CallConv.InstanceExplicit;
\r
887 call_kind : /* EMPTY */
\r
889 $$ = new CallConv ();
\r
893 $$ = CallConv.Default;
\r
897 $$ = CallConv.Vararg;
\r
899 | K_UNMANAGED K_CDECL
\r
901 $$ = CallConv.Cdecl;
\r
903 | K_UNMANAGED K_STDCALL
\r
905 $$ = CallConv.Stdcall;
\r
907 | K_UNMANAGED K_THISCALL
\r
909 $$ = CallConv.Thiscall;
\r
911 | K_UNMANAGED K_FASTCALL
\r
913 $$ = CallConv.Fastcall;
\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
921 $$ = NativeType.FixedSysString;
\r
923 | K_FIXED K_ARRAY OPEN_BRACKET int32 CLOSE_BRACKET
\r
927 $$ = NativeType.Currency;
\r
932 $$ = NativeType.Void;
\r
936 $$ = NativeType.Boolean;
\r
940 $$ = NativeType.Int8;
\r
944 $$ = NativeType.Int16;
\r
948 $$ = NativeType.Int32;
\r
952 $$ = NativeType.Int64;
\r
956 $$ = NativeType.Float32;
\r
960 $$ = NativeType.Float64;
\r
963 | K_UNSIGNED K_INT8
\r
965 $$ = NativeType.UInt8;
\r
967 | K_UNSIGNED K_INT16
\r
969 $$ = NativeType.UInt16;
\r
971 | K_UNSIGNED K_INT32
\r
973 $$ = NativeType.UInt32;
\r
975 | K_UNSIGNED K_INT64
\r
977 $$ = NativeType.UInt64;
\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
988 $$ = NativeType.BStr;
\r
992 $$ = NativeType.LPStr;
\r
996 $$ = NativeType.LPWStr;
\r
1000 $$ = NativeType.LPTStr;
\r
1005 $$ = NativeType.IUnknown;
\r
1009 $$ = NativeType.IDispatch;
\r
1013 $$ = NativeType.Struct;
\r
1017 $$ = NativeType.Interface;
\r
1019 | K_SAFEARRAY variant_type
\r
1020 | K_SAFEARRAY variant_type COMMA comp_qstring
\r
1023 $$ = NativeType.Int;
\r
1025 | K_UNSIGNED K_INT
\r
1027 $$ = NativeType.UInt;
\r
1029 | K_NESTED K_STRUCT
\r
1032 $$ = NativeType.ByValStr;
\r
1036 $$ = NativeType.AnsiBStr;
\r
1040 $$ = NativeType.TBstr;
\r
1042 | K_VARIANT K_BOOL
\r
1044 $$ = NativeType.VariantBool;
\r
1049 $$ = NativeType.AsAny;
\r
1054 variant_type : /* EMPTY */
\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
1071 | variant_type OPEN_BRACKET CLOSE_BRACKET
\r
1072 | variant_type K_VECTOR
\r
1073 | variant_type AMPERSAND
\r
1083 | K_UNSIGNED K_INT
\r
1093 | K_STREAMED_OBJECT
\r
1100 field_decl : D_FIELD repeat_opt field_attr type id at_opt init_opt
\r
1102 FieldDef field_def = new FieldDef((FieldAttr) $3,
\r
1103 (string) $5, (ITypeRef) $4);
\r
1104 codegen.AddFieldDef (field_def);
\r
1107 field_def.SetOffset ((uint) $2);
\r
1111 field_def.AddDataValue ((string) $6);
\r
1115 field_def.SetValue ((Constant) $7);
\r
1120 repeat_opt : /* EMPTY */
\r
1121 | OPEN_BRACKET int32 CLOSE_BRACKET
\r
1127 field_attr : /* EMPTY */
\r
1129 $$ = new FieldAttr ();
\r
1131 | field_attr K_PUBLIC
\r
1133 $$ = (FieldAttr) $1 | FieldAttr.Public;
\r
1135 | field_attr K_PRIVATE
\r
1137 $$ = (FieldAttr) $1 | FieldAttr.Private;
\r
1139 | field_attr K_FAMILY
\r
1141 $$ = (FieldAttr) $1 | FieldAttr.Family;
\r
1143 | field_attr K_ASSEMBLY
\r
1145 $$ = (FieldAttr) $1 | FieldAttr.Assembly;
\r
1147 | field_attr K_FAMANDASSEM
\r
1149 $$ = (FieldAttr) $1 | FieldAttr.FamAndAssem;
\r
1151 | field_attr K_FAMORASSEM
\r
1153 $$ = (FieldAttr) $1 | FieldAttr.FamOrAssem;
\r
1155 | field_attr K_PRIVATESCOPE
\r
1157 // This is just 0x0000
\r
1159 | field_attr K_STATIC
\r
1161 $$ = (FieldAttr) $1 | FieldAttr.Static;
\r
1163 | field_attr K_INITONLY
\r
1165 $$ = (FieldAttr) $1 | FieldAttr.Initonly;
\r
1167 | field_attr K_RTSPECIALNAME
\r
1169 $$ = (FieldAttr) $1 | FieldAttr.RTSpecialName;
\r
1171 | field_attr K_SPECIALNAME
\r
1173 $$ = (FieldAttr) $1 | FieldAttr.SpecialName;
\r
1175 | field_attr K_MARSHAL OPEN_PARENS native_type CLOSE_PARENS
\r
1179 | field_attr K_LITERAL
\r
1181 $$ = (FieldAttr) $1 | FieldAttr.Literal;
\r
1183 | field_attr K_NOTSERIALIZED
\r
1185 $$ = (FieldAttr) $1 | FieldAttr.Notserialized;
\r
1189 at_opt : /* EMPTY */
\r
1196 init_opt : /* EMPTY */
\r
1197 | ASSIGN field_init
\r
1203 field_init : K_FLOAT32 OPEN_PARENS float64 CLOSE_PARENS
\r
1205 $$ = new FloatConst (Convert.ToSingle ($3));
\r
1207 | K_FLOAT64 OPEN_PARENS float64 CLOSE_PARENS
\r
1209 $$ = new DoubleConst (Convert.ToDouble ($3));
\r
1211 | K_FLOAT32 OPEN_PARENS int64 CLOSE_PARENS
\r
1213 $$ = new FloatConst (Convert.ToSingle ($3));
\r
1215 | K_FLOAT64 OPEN_PARENS int64 CLOSE_PARENS
\r
1217 $$ = new DoubleConst (Convert.ToDouble (3));
\r
1219 | K_INT64 OPEN_PARENS int64 CLOSE_PARENS
\r
1221 $$ = new IntConst (Convert.ToInt64 ($3));
\r
1223 | K_INT32 OPEN_PARENS int64 CLOSE_PARENS
\r
1225 $$ = new IntConst (Convert.ToInt32 ($3));
\r
1227 | K_INT16 OPEN_PARENS int64 CLOSE_PARENS
\r
1229 $$ = new IntConst (Convert.ToInt16 ($3));
\r
1231 | K_CHAR OPEN_PARENS int64 CLOSE_PARENS
\r
1233 $$ = new CharConst (Convert.ToChar ($3));
\r
1235 | K_INT8 OPEN_PARENS int64 CLOSE_PARENS
\r
1237 $$ = new IntConst (Convert.ToByte ($3));
\r
1239 | K_BOOL OPEN_PARENS truefalse CLOSE_PARENS
\r
1241 $$ = new BoolConst ((bool) $3);
\r
1243 | K_BYTEARRAY OPEN_PARENS bytes CLOSE_PARENS
\r
1245 $$ = new ByteArrConst ((byte[]) $3);
\r
1249 // ******** THIS IS NOT IN THE DOCUMENTATION ******** //
\r
1250 $$ = new StringConst ((string) $1);
\r
1254 $$ = new NullConst ();
\r
1258 data_decl : data_head data_body
\r
1260 DataDef datadef = (DataDef) $1;
\r
1262 if ($2 is ArrayList) {
\r
1263 ArrayList const_list = (ArrayList) $2;
\r
1264 DataConstant[] const_arr = new DataConstant[const_list.Count];
\r
1266 for (int i=0; i<const_arr.Length; i++)
\r
1267 const_arr[i] = (DataConstant) const_list[i];
\r
1269 datadef.PeapiConstant = new ArrayConstant (const_arr);
\r
1271 datadef.PeapiConstant = (PEAPI.Constant) $2;
\r
1273 codegen.AddDataDef (datadef);
\r
1277 data_head : D_DATA tls id ASSIGN
\r
1279 $$ = new DataDef ((string) $3, (bool) $2);
\r
1283 $$ = new DataDef (String.Empty, (bool) $2);
\r
1287 tls : /* EMPTY */ { $$ = false; }
\r
1288 | K_TLS { $$ = true; }
\r
1291 data_body : OPEN_BRACE dataitem_list CLOSE_BRACE
\r
1295 dataitem_list : dataitem
\r
1297 ArrayList dataitem_list = new ArrayList ();
\r
1298 dataitem_list.Add ($1);
\r
1299 $$ = dataitem_list;
\r
1301 | dataitem_list COMMA dataitem
\r
1303 ArrayList list = (ArrayList) $1;
\r
1308 dataitem : K_CHAR STAR OPEN_PARENS comp_qstring CLOSE_PARENS
\r
1310 $$ = new StringConst ((string) $4);
\r
1312 | AMPERSAND OPEN_PARENS id CLOSE_PARENS
\r
1314 // DataDef def = codegen.CurrentTypeDef.GetDataDef ((string) $3);
\r
1315 // $$ = new AddressConstant ((DataConstant) def.PeapiConstant);
\r
1317 | K_BYTEARRAY ASSIGN OPEN_PARENS bytes CLOSE_PARENS
\r
1319 $$ = new ByteArrConst ((byte[]) $4);
\r
1321 | K_BYTEARRAY OPEN_PARENS bytes CLOSE_PARENS
\r
1323 // ******** THIS IS NOT IN THE SPECIFICATION ******** //
\r
1324 $$ = new ByteArrConst ((byte[]) $3);
\r
1326 | K_FLOAT32 OPEN_PARENS float64 CLOSE_PARENS repeat_opt
\r
1328 FloatConst float_const = new FloatConst ((float) $3);
\r
1331 $$ = new RepeatedConstant (float_const, (int) $5);
\r
1335 | K_FLOAT64 OPEN_PARENS float64 CLOSE_PARENS repeat_opt
\r
1337 DoubleConst double_const = new DoubleConst ((double) $3);
\r
1340 $$ = new RepeatedConstant (double_const, (int) $5);
\r
1342 $$ = double_const;
\r
1344 | K_INT64 OPEN_PARENS int64 CLOSE_PARENS repeat_opt
\r
1346 IntConst int_const = new IntConst ((long) $3);
\r
1349 $$ = new RepeatedConstant (int_const, (int) $5);
\r
1353 | K_INT32 OPEN_PARENS int32 CLOSE_PARENS repeat_opt
\r
1355 IntConst int_const = new IntConst ((int) $3);
\r
1358 $$ = new RepeatedConstant (int_const, (int) $5);
\r
1362 | K_INT16 OPEN_PARENS int32 CLOSE_PARENS repeat_opt
\r
1364 IntConst int_const = new IntConst ((short) $3);
\r
1367 $$ = new RepeatedConstant (int_const, (int) $5);
\r
1371 | K_INT8 OPEN_PARENS int32 CLOSE_PARENS repeat_opt
\r
1373 IntConst int_const = new IntConst ((sbyte) $3);
\r
1376 $$ = new RepeatedConstant (int_const, (int) $5);
\r
1380 | K_FLOAT32 repeat_opt
\r
1382 FloatConst float_const = new FloatConst (0F);
\r
1385 $$ = new RepeatedConstant (float_const, (int) $2);
\r
1389 | K_FLOAT64 repeat_opt
\r
1391 DoubleConst double_const = new DoubleConst (0);
\r
1394 $$ = new RepeatedConstant (double_const, (int) $2);
\r
1396 $$ = double_const;
\r
1398 | K_INT64 repeat_opt
\r
1400 IntConst int_const = new IntConst ((long) 0);
\r
1403 $$ = new RepeatedConstant (int_const, (int) $2);
\r
1407 | K_INT32 repeat_opt
\r
1409 IntConst int_const = new IntConst ((int) 0);
\r
1412 $$ = new RepeatedConstant (int_const, (int) $2);
\r
1416 | K_INT16 repeat_opt
\r
1418 IntConst int_const = new IntConst ((short) 0);
\r
1421 $$ = new RepeatedConstant (int_const, (int) $2);
\r
1425 | K_INT8 repeat_opt
\r
1427 IntConst int_const = new IntConst ((sbyte) 0);
\r
1430 $$ = new RepeatedConstant (int_const, (int) $2);
\r
1436 method_all : method_head OPEN_BRACE method_decls CLOSE_BRACE
\r
1438 codegen.EndMethodDef ();
\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
1445 MethodDef methdef = new MethodDef ((MethAttr) $2, (CallConv) $3,
\r
1446 (ImplAttr) $11, (string) $6, (ITypeRef) $5,
\r
1448 codegen.BeginMethodDef (methdef);
\r
1450 if (pinvoke_info) {
\r
1451 methdef.AddPInvokeInfo (pinvoke_attr, pinvoke_mod, pinvoke_meth);
\r
1452 pinvoke_info = false;
\r
1456 ArrayList typars_list = (ArrayList) $7;
\r
1457 foreach (string id in typars_list)
\r
1458 methdef.AddGenericParam (id);
\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
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
1488 pinvoke_info = true;
\r
1489 pinvoke_mod = (string) $4;
\r
1490 pinvoke_meth = (string) $6;
\r
1491 pinvoke_attr = (PInvokeAttr) $7;
\r
1493 | meth_attr K_PINVOKEIMPL OPEN_PARENS comp_qstring pinv_attr CLOSE_PARENS
\r
1495 pinvoke_info = true;
\r
1496 pinvoke_mod = (string) $4;
\r
1497 pinvoke_meth = null;
\r
1498 pinvoke_attr = (PInvokeAttr) $5;
\r
1500 | meth_attr K_PINVOKEIMPL OPEN_PARENS pinv_attr CLOSE_PARENS
\r
1502 pinvoke_info = true;
\r
1503 pinvoke_mod = null;
\r
1504 pinvoke_meth = null;
\r
1505 pinvoke_attr = (PInvokeAttr) $4;
\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
1522 method_name : D_CTOR
\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
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
1548 sig_args : /* EMPTY */
\r
1552 sig_arg_list : sig_arg
\r
1554 ArrayList sig_list = new ArrayList ();
\r
1555 sig_list.Add ($1);
\r
1558 | sig_arg_list COMMA sig_arg
\r
1560 ArrayList sig_list = (ArrayList) $1;
\r
1561 sig_list.Add ($3);
\r
1566 sig_arg : param_attr type
\r
1568 $$ = new ParamDef ((ParamAttr) $1, null, (ITypeRef) $2);
\r
1570 | param_attr type id
\r
1572 $$ = new ParamDef ((ParamAttr) $1, (string) $3, (ITypeRef) $2);
\r
1576 $$ = new ParamDef ((ParamAttr) 0, "...", new SentinelTypeRef ());
\r
1577 // $$ = ParamDef.Ellipsis;
\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
1583 type_list : /* EMPTY */
\r
1585 $$ = new ArrayList (0);
\r
1589 ArrayList type_list = new ArrayList ();
\r
1590 // type_list.Add (TypeRef.Ellipsis);
\r
1591 type_list.Add (new SentinelTypeRef ());
\r
1594 | type_list COMMA ELLIPSIS
\r
1596 ArrayList type_list = (ArrayList) $1;
\r
1597 // type_list.Add (TypeRef.Ellipsis);
\r
1598 type_list.Add (new SentinelTypeRef ());
\r
1601 | param_attr type opt_id
\r
1603 ArrayList type_list = new ArrayList ();
\r
1604 type_list.Add ($2);
\r
1607 | type_list COMMA param_attr type opt_id
\r
1609 ArrayList type_list = (ArrayList) $1;
\r
1610 type_list.Add ($4);
\r
1614 opt_id : /* EMPTY */
\r
1618 method_decls : /* EMPTY */
\r
1619 | method_decls method_decl
\r
1622 method_decl : D_EMITBYTE int32
\r
1623 | D_MAXSTACK int32
\r
1625 codegen.CurrentMethodDef.SetMaxStack ((int) $2);
\r
1627 | D_LOCALS OPEN_PARENS local_list CLOSE_PARENS
\r
1630 codegen.CurrentMethodDef.AddLocals (
\r
1634 | D_LOCALS K_INIT OPEN_PARENS local_list CLOSE_PARENS
\r
1637 codegen.CurrentMethodDef.AddLocals (
\r
1639 codegen.CurrentMethodDef.InitLocals ();
\r
1644 codegen.CurrentMethodDef.EntryPoint ();
\r
1648 codegen.CurrentMethodDef.ZeroInit ();
\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
1655 codegen.CurrentTypeDef.AddOverride (codegen.CurrentMethodDef,
\r
1656 (ITypeRef) $2, (string) $4);
\r
1660 | D_PARAM OPEN_BRACKET int32 CLOSE_BRACKET init_opt
\r
1663 codegen.CurrentMethodDef.AddLabel ((string) $1);
\r
1672 codegen.CurrentMethodDef.AddCustomAttr ((CustomAttr) $1);
\r
1677 local_list : /* EMPTY */
\r
1680 ArrayList local_list = new ArrayList ();
\r
1681 local_list.Add ($1);
\r
1684 | local_list COMMA local
\r
1686 ArrayList local_list = (ArrayList) $1;
\r
1687 local_list.Add ($3);
\r
1693 $$ = new Local (-1, (ITypeRef) $1);
\r
1697 $$ = new Local (-1, (string) $2, (ITypeRef) $1);
\r
1701 $$ = new Local ((int) $1, (ITypeRef) $2);
\r
1703 | slot_num type id
\r
1705 $$ = new Local ((int) $1, (string) $3, (ITypeRef) $2);
\r
1709 slot_num : OPEN_BRACKET int32 CLOSE_BRACKET
\r
1715 type_spec : class_ref
\r
1716 | OPEN_BRACKET slashed_name CLOSE_BRACKET
\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
1721 | OPEN_BRACKET D_MODULE slashed_name CLOSE_BRACKET
\r
1725 scope_block : scope_block_begin method_decls CLOSE_BRACE
\r
1727 $$ = new HandlerBlock ((LabelInfo) $1,
\r
1728 codegen.CurrentMethodDef.AddLabel ());
\r
1732 scope_block_begin : OPEN_BRACE
\r
1734 $$ = codegen.CurrentMethodDef.AddLabel ();
\r
1739 seh_block : try_block seh_clauses
\r
1741 TryBlock try_block = (TryBlock) $1;
\r
1743 ArrayList clause_list = (ArrayList) $2;
\r
1744 foreach (object clause in clause_list)
\r
1745 try_block.AddSehClause ((ISehClause) clause);
\r
1747 codegen.CurrentMethodDef.AddInstr (try_block);
\r
1751 try_block : D_TRY scope_block
\r
1753 $$ = new TryBlock ((HandlerBlock) $2);
\r
1755 | D_TRY id K_TO id
\r
1757 LabelInfo from = codegen.CurrentMethodDef.AddLabelRef ((string) $2);
\r
1758 LabelInfo to = codegen.CurrentMethodDef.AddLabelRef ((string) $4);
\r
1760 $$ = new TryBlock (new HandlerBlock (from, to));
\r
1762 | D_TRY int32 K_TO int32
\r
1764 LabelInfo from = codegen.CurrentMethodDef.AddLabel ((int) $2);
\r
1765 LabelInfo to = codegen.CurrentMethodDef.AddLabel ((int) $4);
\r
1767 $$ = new TryBlock (new HandlerBlock (from, to));
\r
1771 seh_clauses : seh_clause
\r
1773 ArrayList clause_list = new ArrayList ();
\r
1774 clause_list.Add ($1);
\r
1777 | seh_clauses seh_clause
\r
1779 ArrayList clause_list = (ArrayList) $1;
\r
1780 clause_list.Add ($2);
\r
1784 seh_clause : K_CATCH class_ref handler_block
\r
1786 IClassRef type = (IClassRef) $2;
\r
1787 CatchBlock cb = new CatchBlock (type);
\r
1788 cb.SetHandlerBlock ((HandlerBlock) $3);
\r
1791 | K_FINALLY handler_block
\r
1793 FinallyBlock fb = new FinallyBlock ();
\r
1794 fb.SetHandlerBlock ((HandlerBlock) $2);
\r
1797 | K_FAULT handler_block
\r
1799 FaultBlock fb = new FaultBlock ();
\r
1800 fb.SetHandlerBlock ((HandlerBlock) $2);
\r
1803 | filter_clause handler_block
\r
1805 FilterBlock fb = (FilterBlock) $1;
\r
1806 fb.SetHandlerBlock ((HandlerBlock) $2);
\r
1810 filter_clause : K_FILTER scope_block
\r
1812 HandlerBlock block = (HandlerBlock) $2;
\r
1813 FilterBlock fb = new FilterBlock (block);
\r
1818 LabelInfo from = codegen.CurrentMethodDef.AddLabelRef ((string) $2);
\r
1819 FilterBlock fb = new FilterBlock (new HandlerBlock (from, null));
\r
1824 LabelInfo from = codegen.CurrentMethodDef.AddLabel ((int) $2);
\r
1825 FilterBlock fb = new FilterBlock (new HandlerBlock (from, null));
\r
1830 handler_block : scope_block
\r
1834 | K_HANDLER id K_TO id
\r
1836 LabelInfo from = codegen.CurrentMethodDef.AddLabelRef ((string) $2);
\r
1837 LabelInfo to = codegen.CurrentMethodDef.AddLabelRef ((string) $4);
\r
1839 $$ = new HandlerBlock (from, to);
\r
1841 | K_HANDLER int32 K_TO int32
\r
1843 LabelInfo from = codegen.CurrentMethodDef.AddLabelRef ((string) $2);
\r
1844 LabelInfo to = codegen.CurrentMethodDef.AddLabelRef ((string) $4);
\r
1846 $$ = new HandlerBlock (from, to);
\r
1850 instr : INSTR_NONE
\r
1852 codegen.CurrentMethodDef.AddInstr (
\r
1853 new SimpInstr ((Op) $1));
\r
1855 | INSTR_LOCAL int32
\r
1857 codegen.CurrentMethodDef.AddInstr (
\r
1858 new IntInstr ((IntOp) $1, (int) $2));
\r
1862 int slot = codegen.CurrentMethodDef.GetNamedLocalSlot ((string) $2);
\r
1863 codegen.CurrentMethodDef.AddInstr (
\r
1864 new IntInstr ((IntOp) $1, slot));
\r
1866 | INSTR_PARAM int32
\r
1868 codegen.CurrentMethodDef.AddInstr (
\r
1869 new IntInstr ((IntOp) $1, (int) $2));
\r
1873 int pos = codegen.CurrentMethodDef.GetNamedParamPos ((string) $2);
\r
1874 codegen.CurrentMethodDef.AddInstr (
\r
1875 new IntInstr ((IntOp) $1, pos));
\r
1879 codegen.CurrentMethodDef.AddInstr (new
\r
1880 IntInstr ((IntOp) $1, (int) $2));
\r
1884 int slot = codegen.CurrentMethodDef.GetNamedLocalSlot ((string) $2);
\r
1885 codegen.CurrentMethodDef.AddInstr (new
\r
1886 IntInstr ((IntOp) $1, slot));
\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
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
1910 long l = (long) $2;
\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
1919 | INSTR_R OPEN_PARENS bytes CLOSE_PARENS
\r
1920 | INSTR_BRTARGET int32
\r
1922 LabelInfo target = codegen.CurrentMethodDef.AddLabel ((int) $2);
\r
1923 codegen.CurrentMethodDef.AddInstr (new BranchInstr ((BranchOp) $1,
\r
1926 | INSTR_BRTARGET id
\r
1928 LabelInfo target = codegen.CurrentMethodDef.AddLabelRef ((string) $2);
\r
1929 codegen.CurrentMethodDef.AddInstr (new BranchInstr ((BranchOp) $1,
\r
1932 | INSTR_METHOD method_ref
\r
1934 codegen.CurrentMethodDef.AddInstr (new MethodInstr ((MethodOp) $1,
\r
1935 (IMethodRef) $2));
\r
1937 | INSTR_FIELD type type_spec DOUBLE_COLON id
\r
1940 ITypeRef owner = (ITypeRef) $3;
\r
1941 IFieldRef fieldref = owner.GetFieldRef (
\r
1942 (ITypeRef) $2, (string) $5);
\r
1944 codegen.CurrentMethodDef.AddInstr (new FieldInstr ((FieldOp) $1, fieldref));
\r
1946 | INSTR_FIELD type id
\r
1948 GlobalFieldRef fieldref = new GlobalFieldRef ((ITypeRef) $2, (string) $3);
\r
1950 codegen.CurrentMethodDef.AddInstr (new FieldInstr ((FieldOp) $1, fieldref));
\r
1952 | INSTR_TYPE type_spec
\r
1954 codegen.CurrentMethodDef.AddInstr (new TypeInstr ((TypeOp) $1,
\r
1957 | INSTR_STRING comp_qstring
\r
1959 if ((MiscInstr) $1 == MiscInstr.ldstr)
\r
1960 codegen.CurrentMethodDef.AddInstr (new LdstrInstr ((string) $2));
\r
1962 | INSTR_STRING K_BYTEARRAY ASSIGN OPEN_PARENS
\r
1963 bytes CLOSE_PARENS
\r
1965 byte[] bs = (byte[]) $5;
\r
1966 if ((MiscInstr) $1 == MiscInstr.ldstr)
\r
1967 codegen.CurrentMethodDef.AddInstr (new LdstrInstr (bs));
\r
1969 | INSTR_STRING K_BYTEARRAY OPEN_PARENS bytes
\r
1972 byte[] bs = (byte[]) $4;
\r
1973 if ((MiscInstr) $1 == MiscInstr.ldstr)
\r
1974 codegen.CurrentMethodDef.AddInstr (new LdstrInstr (bs));
\r
1976 | INSTR_SIG call_conv type OPEN_PARENS type_list CLOSE_PARENS
\r
1978 ArrayList arg_list = (ArrayList) $5;
\r
1979 ITypeRef[] arg_array = null;
\r
1981 if (arg_list != null)
\r
1982 arg_array = (ITypeRef[]) arg_list.ToArray (typeof (ITypeRef));
\r
1984 codegen.CurrentMethodDef.AddInstr (new CalliInstr ((CallConv) $2,
\r
1985 (ITypeRef) $3, arg_array));
\r
1987 | INSTR_TOK owner_type
\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
1995 codegen.CurrentMethodDef.AddInstr (new LdtokenInstr ((ITypeRef) $2));
\r
1999 | INSTR_SWITCH OPEN_PARENS labels CLOSE_PARENS
\r
2001 codegen.CurrentMethodDef.AddInstr (new SwitchInstr ((ArrayList) $3));
\r
2005 method_ref : call_conv type type_spec DOUBLE_COLON method_name
\r
2006 OPEN_PARENS type_list CLOSE_PARENS
\r
2008 ITypeRef owner = (ITypeRef) $3;
\r
2009 ArrayList arg_list = (ArrayList) $7;
\r
2010 ITypeRef[] param_list;
\r
2011 IMethodRef methref;
\r
2013 if (arg_list != null)
\r
2014 param_list = (ITypeRef[]) arg_list.ToArray (typeof (ITypeRef));
\r
2016 param_list = new ITypeRef[0];
\r
2018 if (owner.UseTypeSpec) {
\r
2019 methref = new TypeSpecMethodRef (owner, (ITypeRef) $2,
\r
2020 (CallConv) $1, (string) $5, param_list);
\r
2022 methref = owner.GetMethodRef ((ITypeRef) $2,
\r
2023 (CallConv) $1, (string) $5, param_list);
\r
2028 | call_conv type method_name
\r
2029 OPEN_PARENS type_list CLOSE_PARENS
\r
2031 ArrayList arg_list = (ArrayList) $5;
\r
2032 ITypeRef[] param_list;
\r
2034 if (arg_list != null)
\r
2035 param_list = (ITypeRef[]) arg_list.ToArray (typeof (ITypeRef));
\r
2037 param_list = new ITypeRef[0];
\r
2039 $$ = new GlobalMethodRef ((ITypeRef) $2, (CallConv) $1,
\r
2040 (string) $3, param_list);
\r
2042 | call_conv type type_spec DOUBLE_COLON method_name
\r
2043 typars_clause OPEN_PARENS type_list CLOSE_PARENS
\r
2045 ITypeRef owner = (ITypeRef) $3;
\r
2046 ArrayList arg_list = (ArrayList) $8;
\r
2047 ITypeRef[] param_list;
\r
2048 IMethodRef methref;
\r
2050 if (arg_list != null)
\r
2051 param_list = (ITypeRef[]) arg_list.ToArray (typeof (ITypeRef));
\r
2053 param_list = new ITypeRef[0];
\r
2055 if (owner.UseTypeSpec) {
\r
2056 methref = new TypeSpecMethodRef (owner, (ITypeRef) $2,
\r
2057 (CallConv) $1, (string) $5, param_list);
\r
2059 methref = owner.GetMethodRef ((ITypeRef) $2,
\r
2060 (CallConv) $1, (string) $5, param_list);
\r
2064 ArrayList tp = (ArrayList) $6;
\r
2065 ITypeRef[] ta = (ITypeRef[]) tp.ToArray (typeof (ITypeRef));
\r
2067 methref = new GenericMethodRef (methref, new GenericMethodSig (ta));
\r
2074 labels : /* EMPTY */
\r
2077 ArrayList label_list = new ArrayList ();
\r
2078 label_list.Add ($1);
\r
2083 ArrayList label_list = new ArrayList ();
\r
2084 label_list.Add ($1);
\r
2089 ArrayList label_list = (ArrayList) $1;
\r
2090 label_list.Add ($3);
\r
2092 | labels COMMA int32
\r
2094 ArrayList label_list = (ArrayList) $1;
\r
2095 label_list.Add ($3);
\r
2099 owner_type : type_spec
\r
2103 member_ref : K_METHOD method_ref
\r
2107 | K_FIELD type type_spec DOUBLE_COLON id
\r
2109 ITypeRef owner = (ITypeRef) $3;
\r
2111 $$ = owner.GetFieldRef (
\r
2112 (ITypeRef) $2, (string) $5);
\r
2116 $$ = new GlobalFieldRef ((ITypeRef) $2, (string) $3);
\r
2120 event_all : event_head OPEN_BRACE event_decls CLOSE_BRACE
\r
2122 codegen.CurrentTypeDef.EndEventDef ();
\r
2126 event_head : D_EVENT event_attr type_spec id
\r
2128 EventDef event_def = new EventDef ((FeatureAttr) $2,
\r
2129 (ITypeRef) $3, (string) $4);
\r
2130 codegen.CurrentTypeDef.BeginEventDef (event_def);
\r
2132 | D_EVENT event_attr id
\r
2135 event_attr : /* EMPTY */
\r
2137 $$ = new FeatureAttr ();
\r
2139 | event_attr K_RTSPECIALNAME
\r
2141 $$ = (FeatureAttr) $1 & FeatureAttr.Rtspecialname;
\r
2143 | event_attr K_SPECIALNAME
\r
2145 $$ = (FeatureAttr) $1 & FeatureAttr.Specialname;
\r
2149 event_decls : /* EMPTY */
\r
2150 | event_decls event_decl
\r
2153 event_decl : D_ADDON method_ref
\r
2155 codegen.CurrentTypeDef.CurrentEvent.AddAddon (
\r
2158 | D_REMOVEON method_ref
\r
2160 codegen.CurrentTypeDef.CurrentEvent.AddRemoveon (
\r
2163 | D_FIRE method_ref
\r
2165 codegen.CurrentTypeDef.CurrentEvent.AddFire (
\r
2168 | D_OTHER method_ref
\r
2170 codegen.CurrentTypeDef.CurrentEvent.AddOther (
\r
2178 prop_all : prop_head OPEN_BRACE prop_decls CLOSE_BRACE
\r
2180 codegen.CurrentTypeDef.EndPropertyDef ();
\r
2184 prop_head : D_PROPERTY prop_attr type id OPEN_PARENS type_list CLOSE_PARENS init_opt
\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
2191 prop_def.AddInitValue ((Constant) $8);
\r
2196 prop_attr : /* EMPTY */
\r
2198 $$ = new FeatureAttr ();
\r
2200 | prop_attr K_RTSPECIALNAME
\r
2202 $$ = (FeatureAttr) $1 | FeatureAttr.Rtspecialname;
\r
2204 | prop_attr K_SPECIALNAME
\r
2206 $$ = (FeatureAttr) $1 | FeatureAttr.Specialname;
\r
2210 prop_decls : /* EMPTY */
\r
2211 | prop_decls prop_decl
\r
2214 prop_decl : D_SET method_ref
\r
2216 codegen.CurrentTypeDef.CurrentProperty.AddSet ((MethodRef) $2);
\r
2218 | D_GET method_ref
\r
2220 codegen.CurrentTypeDef.CurrentProperty.AddGet ((MethodRef) $2);
\r
2222 | D_OTHER method_ref
\r
2224 codegen.CurrentTypeDef.CurrentProperty.AddOther ((MethodRef) $2);
\r
2231 customattr_decl : D_CUSTOM custom_type
\r
2233 $$ = new CustomAttr ((IMethodRef) $2, null);
\r
2235 | D_CUSTOM custom_type ASSIGN comp_qstring
\r
2236 | D_CUSTOM custom_type ASSIGN OPEN_PARENS bytes CLOSE_PARENS
\r
2238 $$ = new CustomAttr ((IMethodRef) $2,
\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
2247 custom_type : call_conv type type_spec DOUBLE_COLON D_CTOR OPEN_PARENS type_list CLOSE_PARENS
\r
2249 ITypeRef owner = (ITypeRef) $3;
\r
2250 ArrayList arg_list = (ArrayList) $7;
\r
2251 ITypeRef[] param_list;
\r
2253 if (arg_list != null)
\r
2254 param_list = (ITypeRef[]) arg_list.ToArray (typeof (ITypeRef));
\r
2256 param_list = new ITypeRef[0];
\r
2258 $$ = owner.GetMethodRef ((ITypeRef) $2,
\r
2259 (CallConv) $1, (string) $5, param_list);
\r
2261 | call_conv type D_CTOR OPEN_PARENS type_list CLOSE_PARENS
\r
2263 ArrayList arg_list = (ArrayList) $5;
\r
2264 ITypeRef[] param_list;
\r
2266 if (arg_list != null)
\r
2267 param_list = (ITypeRef[]) arg_list.ToArray (typeof (ITypeRef));
\r
2269 param_list = new ITypeRef[0];
\r
2271 $$ = new GlobalMethodRef ((ITypeRef) $2, (CallConv) $1,
\r
2272 (string) $3, param_list);
\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
2281 nameval_pairs : nameval_pair
\r
2282 | nameval_pairs COMMA nameval_pair
\r
2285 nameval_pair : comp_qstring ASSIGN cavalue
\r
2288 cavalue : truefalse
\r
2290 | int32 OPEN_PARENS int32 CLOSE_PARENS
\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
2298 sec_action : K_REQUEST
\r
2311 | K_NONCASLINKDEMAND
\r
2312 | K_NONCASINHERITANCE
\r
2315 module_head : D_MODULE
\r
2316 | D_MODULE comp_name
\r
2317 | D_MODULE K_EXTERN comp_name
\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
2325 file_attr : /* EMPTY */
\r
2326 | file_attr K_NOMETADATA
\r
2329 file_entry : /* EMPTY */
\r
2333 assembly_all : assembly_head OPEN_BRACE assembly_decls CLOSE_BRACE
\r
2336 assembly_head : D_ASSEMBLY asm_attr slashed_name
\r
2338 codegen.SetAssemblyName ((string) $3);
\r
2342 asm_attr : /* EMPTY */
\r
2343 | asm_attr K_NOAPPDOMAIN
\r
2344 | asm_attr K_NOPROCESS
\r
2345 | asm_attr K_NOMACHINE
\r
2348 assembly_decls : /* EMPTY */
\r
2349 | assembly_decls assembly_decl
\r
2352 assembly_decl : D_HASH K_ALGORITHM int32
\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
2364 assemblyref_all : assemblyref_head OPEN_BRACE assemblyref_decls CLOSE_BRACE
\r
2367 assemblyref_head : D_ASSEMBLY K_EXTERN slashed_name
\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
2374 | D_ASSEMBLY K_EXTERN slashed_name K_AS slashed_name
\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
2383 assemblyref_decls : /* EMPTY */
\r
2384 | assemblyref_decls assemblyref_decl
\r
2387 assemblyref_decl : D_HASH ASSIGN OPEN_PARENS bytes CLOSE_PARENS
\r
2389 | D_PUBLICKEYTOKEN ASSIGN OPEN_PARENS bytes CLOSE_PARENS
\r
2392 exptype_all : exptype_head OPEN_BRACE exptype_decls CLOSE_BRACE
\r
2395 exptype_head : D_CLASS K_EXTERN expt_attr comp_name
\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
2409 exptype_decls : /* EMPTY */
\r
2410 | exptype_decls exptype_decl
\r
2413 exptype_decl : D_FILE comp_name
\r
2414 | D_CLASS K_EXTERN comp_name
\r
2419 manifestres_all : manifestres_head OPEN_BRACE manifestres_decls CLOSE_BRACE
\r
2422 manifestres_head : D_MRESOURCE manres_attr comp_name
\r
2425 manres_attr : /* EMPTY */
\r
2426 | manres_attr K_PUBLIC
\r
2427 | manres_attr K_PRIVATE
\r
2430 manifestres_decls : /* EMPTY */
\r
2431 | manifestres_decls manifestres_decl
\r
2434 manifestres_decl : D_FILE comp_name K_AT int32
\r
2435 | D_ASSEMBLY K_EXTERN slashed_name
\r
2439 comp_qstring : QSTRING
\r
2440 | comp_qstring PLUS QSTRING { $$ = String.Format ("{0}{1}", $1, $3); }
\r
2445 long l = (long) $1;
\r
2446 byte[] intb = BitConverter.GetBytes (l);
\r
2447 $$ = BitConverter.ToInt32 (intb, 0);
\r
2455 | K_FLOAT32 OPEN_PARENS INT32 CLOSE_PARENS
\r
2458 byte[] intb = BitConverter.GetBytes (i);
\r
2459 $$ = (double) BitConverter.ToSingle (intb, 0);
\r
2461 | K_FLOAT32 OPEN_PARENS INT64 CLOSE_PARENS
\r
2463 long l = (long) $3;
\r
2464 byte[] intb = BitConverter.GetBytes (l);
\r
2465 $$ = (double) BitConverter.ToSingle (intb, 0);
\r
2467 | K_FLOAT64 OPEN_PARENS INT64 CLOSE_PARENS
\r
2469 byte[] intb = BitConverter.GetBytes ((long) $3);
\r
2470 $$ = BitConverter.ToDouble (intb, 0);
\r
2472 | K_FLOAT64 OPEN_PARENS INT32 CLOSE_PARENS
\r
2474 byte[] intb = BitConverter.GetBytes ((int) $3);
\r
2475 $$ = (double) BitConverter.ToSingle (intb, 0);
\r
2479 hexbyte : HEXBYTE { }
\r
2482 long l = (long) $1;
\r
2483 byte b = Byte.Parse (l.ToString (), NumberStyles.HexNumber);
\r
2488 $$ = Byte.Parse ((string) $1, NumberStyles.HexNumber);
\r
2492 bytes : /* EMPTY */ { $$ = new byte[0]; }
\r
2495 ArrayList byte_list = (ArrayList) $1;
\r
2496 $$ = byte_list.ToArray (typeof (byte));
\r
2500 hexbytes : hexbyte
\r
2502 ArrayList byte_list = new ArrayList ();
\r
2503 byte_list.Add (Convert.ToByte ($1));
\r
2506 | hexbytes hexbyte
\r
2508 ArrayList byte_list = (ArrayList) $1;
\r
2509 byte_list.Add (Convert.ToByte ($2));
\r
2513 truefalse : K_TRUE
\r
2522 | comp_name DOT id
\r
2524 $$ = (string) $1 + '.' + (string) $3;
\r