2 * get.c: Functions to get stringified values from the metadata tables.
5 * Miguel de Icaza (miguel@ximian.com)
7 * (C) 2001 Ximian, Inc.
19 #include <mono/metadata/class.h>
20 #include <mono/metadata/marshal.h>
22 extern gboolean substitute_with_mscorlib_p;
24 static MonoGenericContext *
25 get_memberref_context (MonoImage *m, guint32 mrp_token, MonoGenericContext *context);
28 get_memberref_parent (MonoImage *m, guint32 mrp_token, MonoGenericContext *context);
30 GHashTable *key_table = NULL;
31 gboolean show_method_tokens = FALSE;
32 gboolean show_tokens = FALSE;
35 get_typedef (MonoImage *m, int idx)
37 guint32 cols [MONO_TYPEDEF_SIZE];
39 char *tstring, *result;
42 mono_metadata_decode_row (&m->tables [MONO_TABLE_TYPEDEF], idx - 1, cols, MONO_TYPEDEF_SIZE);
44 ns = mono_metadata_string_heap (m, cols [MONO_TYPEDEF_NAMESPACE]);
46 /* Check if this is a nested type */
47 token = MONO_TOKEN_TYPE_DEF | (idx);
48 token = mono_metadata_nested_in_typedef (m, token);
49 tstring = show_tokens ? g_strdup_printf ("/*%08x*/", token) : NULL;
53 outer = get_typedef (m, mono_metadata_token_index (token));
54 result = g_strdup_printf (
56 mono_metadata_string_heap (m, cols [MONO_TYPEDEF_NAME]),
57 tstring ? tstring : "");
64 result = g_strdup_printf (
65 "%s%s%s%s", ns, *ns?".":"",
66 mono_metadata_string_heap (m, cols [MONO_TYPEDEF_NAME]),
67 tstring ? tstring : "");
74 get_module (MonoImage *m, int idx)
76 guint32 cols [MONO_MODULE_SIZE];
79 * There MUST BE only one module in the Module table
83 mono_metadata_decode_row (&m->tables [MONO_TABLE_MODULE], idx - 1, cols, MONO_MODULE_SIZE);
85 return g_strdup (mono_metadata_string_heap (m, cols [MONO_MODULE_NAME]));
89 get_moduleref (MonoImage *m, int idx)
91 guint32 cols [MONO_MODULEREF_SIZE];
93 mono_metadata_decode_row (&m->tables [MONO_TABLE_MODULEREF], idx - 1, cols, MONO_MODULEREF_SIZE);
95 return g_strdup (mono_metadata_string_heap (m, cols [MONO_MODULEREF_NAME]));
99 get_assemblyref (MonoImage *m, int idx)
101 guint32 cols [MONO_ASSEMBLYREF_SIZE];
103 mono_metadata_decode_row (&m->tables [MONO_TABLE_ASSEMBLYREF], idx - 1, cols, MONO_ASSEMBLYREF_SIZE);
105 return g_strdup (mono_metadata_string_heap (m, cols [MONO_ASSEMBLYREF_NAME]));
110 * Returns a string representing the ArrayShape (22.2.16).
113 get_array_shape (MonoImage *m, const char *ptr, char **result)
115 GString *res = g_string_new ("[");
116 guint32 rank, num_sizes, num_lo_bounds;
117 guint32 *sizes = NULL, *lo_bounds = NULL;
121 rank = mono_metadata_decode_value (ptr, &ptr);
122 num_sizes = mono_metadata_decode_value (ptr, &ptr);
125 sizes = g_new (guint32, num_sizes);
127 for (i = 0; i < num_sizes; i++)
128 sizes [i] = mono_metadata_decode_value (ptr, &ptr);
130 num_lo_bounds = mono_metadata_decode_value (ptr, &ptr);
131 if (num_lo_bounds > 0)
132 lo_bounds = g_new (guint32, num_lo_bounds);
134 for (i = 0; i < num_lo_bounds; i++)
135 lo_bounds [i] = mono_metadata_decode_value (ptr, &ptr);
137 for (r = 0; r < rank; r++){
139 if (r < num_lo_bounds){
140 sprintf (buffer, "%d..%d", lo_bounds [r], lo_bounds [r] + sizes [r] - 1);
142 sprintf (buffer, "0..%d", sizes [r] - 1);
147 g_string_append (res, buffer);
149 g_string_append (res, ", ");
151 g_string_append (res, "]");
160 g_string_free (res, FALSE);
167 * @m: metadata context
168 * @blob_idx: index into the blob heap
170 * Returns the stringified representation of a TypeSpec signature (22.2.17)
173 get_typespec (MonoImage *m, guint32 idx, gboolean is_def, MonoGenericContext *context)
175 guint32 cols [MONO_TYPESPEC_SIZE];
178 GString *res = g_string_new ("");
183 type = mono_type_create_from_typespec_full (m, context, idx);
185 mono_metadata_decode_row (&m->tables [MONO_TABLE_TYPESPEC], idx-1, cols, MONO_TYPESPEC_SIZE);
186 ptr = mono_metadata_blob_heap (m, cols [MONO_TYPESPEC_SIGNATURE]);
187 len = mono_metadata_decode_value (ptr, &ptr);
191 ptr = get_custom_mod (m, ptr, &s);
193 g_string_append (res, s);
194 g_string_append_c (res, ' ');
198 if (*ptr == MONO_TYPE_VOID)
199 g_string_append (res, "void");
201 ptr = get_type (m, ptr, &s, context);
203 g_string_append (res, s);
205 g_string_append (res, "*");
208 case MONO_TYPE_FNPTR:
209 s = dis_stringify_function_ptr (m, type->data.method);
210 g_string_append (res, "method ");
211 g_string_append (res, s);
215 case MONO_TYPE_ARRAY:
216 ptr = get_type (m, ptr, &s, context);
217 g_string_append (res, s);
219 g_string_append_c (res, ' ');
220 ptr = get_array_shape (m, ptr, &s);
221 g_string_append (res, s);
225 case MONO_TYPE_SZARRAY:
226 ptr = get_custom_mod (m, ptr, &s);
228 g_string_append (res, s);
229 g_string_append_c (res, ' ');
232 ptr = get_type (m, ptr, &s, context);
233 g_string_append (res, s);
234 g_string_append (res, "[]");
239 s = dis_stringify_type (m, type, is_def);
240 g_string_append (res, s);
246 int token = mono_metadata_make_token (MONO_TABLE_TYPESPEC, idx);
247 result = g_strdup_printf ("%s/*%08x*/", res->str, token);
251 g_string_free (res, FALSE);
257 get_typeref (MonoImage *m, int idx)
259 guint32 cols [MONO_TYPEREF_SIZE];
262 guint32 rs_idx, table;
264 mono_metadata_decode_row (&m->tables [MONO_TABLE_TYPEREF], idx - 1, cols, MONO_TYPEREF_SIZE);
266 t = mono_metadata_string_heap (m, cols [MONO_TYPEREF_NAME]);
267 s = mono_metadata_string_heap (m, cols [MONO_TYPEREF_NAMESPACE]);
269 rs_idx = cols [MONO_TYPEREF_SCOPE] >> MONO_RESOLTION_SCOPE_BITS;
270 table = cols [MONO_TYPEREF_SCOPE] & MONO_RESOLTION_SCOPE_MASK;
273 case MONO_RESOLTION_SCOPE_MODULE: /* Module */
274 x = get_module (m, rs_idx);
275 ret = g_strdup_printf ("[%s] %s%s%s", x, s, *s?".":"", t);
279 case MONO_RESOLTION_SCOPE_MODULEREF: /* ModuleRef */
280 x = get_moduleref (m, rs_idx);
281 ret = g_strdup_printf ("[.module %s]%s%s%s", x, s, *s ? "." : "", t);
284 case MONO_RESOLTION_SCOPE_ASSEMBLYREF: /*
285 * AssemblyRef (ECMA docs claim it is 3, but it looks to
286 * me like it is 2 (tokens are prefixed with 0x23)
288 x = get_assemblyref (m, rs_idx);
289 ret = g_strdup_printf ("[%s]%s%s%s", x, s, *s?".":"", t);
293 case MONO_RESOLTION_SCOPE_TYPEREF: /* TypeRef */
294 x = get_typeref (m, rs_idx);
295 ret = g_strdup_printf ("%s/%s", x, t);
300 ret = g_strdup_printf ("Unknown table in TypeRef %d", table);
304 int token = mono_metadata_make_token (MONO_TABLE_TYPEREF, idx);
305 char *temp = g_strdup_printf ("%s/*%08x*/", ret, token);
314 * get_typedef_or_ref:
315 * @m: metadata context
316 * @dor_token: def or ref encoded index
318 * Low two bits contain table to lookup from
319 * high bits contain the index into the def or ref table
321 * Returns: a stringified version of the MethodDef or MethodRef
322 * at (dor_token >> 2)
325 get_typedef_or_ref (MonoImage *m, guint32 dor_token, MonoGenericContext *context)
327 char *temp = NULL, *s = NULL;
331 * low 2 bits contain encoding
333 table = dor_token & MONO_TYPEDEFORREF_MASK;
334 idx = dor_token >> MONO_TYPEDEFORREF_BITS;
337 case 0: /* TypeDef */
338 temp = get_typedef (m, idx);
339 s = g_strdup_printf ("%s", temp);
342 case 1: /* TypeRef */
343 temp = get_typeref (m, idx);
344 s = g_strdup_printf ("%s", temp);
347 case 2: /* TypeSpec */
348 s = get_typespec (m, idx, FALSE, context);
352 g_error ("Unhandled encoding for typedef-or-ref coded index 0x%08x", dor_token);
363 * get_type_or_methdef
364 * @m: metadata context
365 * @dor_token: type or method def encoded index
367 * Low bit contains the table to lookup from
368 * high bits contain the index into the type def or method def table
370 * Returns: a stringified version of the TypeOrMethodDef token
373 get_type_or_methdef (MonoImage *m, guint32 dor_token)
375 if (dor_token & MONO_TYPEORMETHOD_METHOD) /* MethodDef */
376 return get_methoddef (m, dor_token >> MONO_TYPEORMETHOD_BITS);
378 return get_typedef (m, dor_token >> MONO_TYPEORMETHOD_BITS);
382 * get_encoded_typedef_or_ref:
383 * @m: metadata context
384 * @ptr: location to decode from.
385 * @result: pointer to string where resulting decoded string is stored
387 * result will point to a g_malloc()ed string.
389 * Returns: the new ptr to continue decoding
392 get_encoded_typedef_or_ref (MonoImage *m, const char *ptr, char **result)
396 token = mono_metadata_decode_value (ptr, &ptr);
398 *result = get_typedef_or_ref (m, token, NULL);
406 * Decodes a CustomMod (22.2.7)
408 * Returns: updated pointer location
411 get_custom_mod (MonoImage *m, const char *ptr, char **return_value)
416 *return_value = NULL;
417 while ((*ptr == MONO_TYPE_CMOD_OPT) ||
418 (*ptr == MONO_TYPE_CMOD_REQD)) {
419 reqd = (*ptr == MONO_TYPE_CMOD_REQD) ? "reqd" : "opt";
421 ptr = get_encoded_typedef_or_ref (m, ptr, &s);
423 if (*return_value == NULL)
424 *return_value = g_strconcat (reqd, " ", s, NULL);
426 *return_value = g_strconcat (*return_value, " ", reqd, " ", s, NULL);
433 static dis_map_t element_type_map [] = {
434 { MONO_TYPE_END , "end" },
435 { MONO_TYPE_VOID , "void" },
436 { MONO_TYPE_BOOLEAN , "bool" },
437 { MONO_TYPE_CHAR , "char" },
438 { MONO_TYPE_I1 , "int8" },
439 { MONO_TYPE_U1 , "unsigned int8" },
440 { MONO_TYPE_I2 , "int16" },
441 { MONO_TYPE_U2 , "unsigned int16" },
442 { MONO_TYPE_I4 , "int32" },
443 { MONO_TYPE_U4 , "unsigned int32" },
444 { MONO_TYPE_I8 , "int64" },
445 { MONO_TYPE_U8 , "unsigned int64" },
446 { MONO_TYPE_R4 , "float32" },
447 { MONO_TYPE_R8 , "float64" },
448 { MONO_TYPE_STRING , "string" },
449 { MONO_TYPE_TYPEDBYREF , "typedref" },
450 { MONO_TYPE_I , "native int" },
451 { MONO_TYPE_U , "native unsigned int" },
452 { MONO_TYPE_OBJECT , "object" },
456 static dis_map_t call_conv_type_map [] = {
457 { MONO_CALL_DEFAULT , "default" },
458 { MONO_CALL_C , "unmanaged cdecl" },
459 { MONO_CALL_STDCALL , "unmanaged stdcall" },
460 { MONO_CALL_THISCALL , "unmanaged thiscall" },
461 { MONO_CALL_FASTCALL , "unmanaged fastcall" },
462 { MONO_CALL_VARARG , "vararg" },
467 dis_stringify_token (MonoImage *m, guint32 token)
469 guint idx = token & 0xffffff;
470 switch (token >> 24) {
471 case MONO_TABLE_TYPEDEF: return get_typedef (m, idx);
472 case MONO_TABLE_TYPEREF: return get_typeref (m, idx);
473 case MONO_TABLE_TYPESPEC: return get_typespec (m, idx, FALSE, NULL);
477 return g_strdup_printf("0x%08x", token);
481 dis_stringify_array (MonoImage *m, MonoArrayType *array, gboolean is_def)
484 GString *s = g_string_new("");
487 type = dis_stringify_type (m, &array->eklass->byval_arg, is_def);
488 g_string_append (s, type);
490 g_string_append_c (s, '[');
491 for (i = 0; i < array->rank; ++i) {
493 g_string_append_c (s, ',');
494 if (i < array->numsizes) {
495 if (i < array->numlobounds && array->lobounds[i] != 0)
496 g_string_sprintfa (s, "%d..%d", array->lobounds[i], array->sizes[i]);
498 g_string_sprintfa (s, "%d", array->sizes[i]);
501 g_string_append_c (s, ']');
503 g_string_free (s, FALSE);
508 dis_stringify_modifiers (MonoImage *m, int n, MonoCustomMod *mod)
510 GString *s = g_string_new("");
513 for (i = 0; i < n; ++i) {
514 char *tok = dis_stringify_token (m, mod[i].token);
516 g_string_sprintfa (s, " ");
517 g_string_sprintfa (s, "%s (%s)", mod[i].required ? "modreq": "modopt", tok);
520 g_string_append_c (s, ' ');
522 g_string_free (s, FALSE);
527 dis_stringify_param (MonoImage *m, MonoType *param)
532 const char *in = param->attrs & PARAM_ATTRIBUTE_IN ? "[in]" : "";
533 const char *out = param->attrs & PARAM_ATTRIBUTE_OUT ? "[out]": "";
534 const char *opt = param->attrs & PARAM_ATTRIBUTE_OPTIONAL ? "[opt]": "";
535 attribs = g_strconcat(in, out, opt, NULL);
536 t = dis_stringify_type (m, param, TRUE);
537 result = g_strjoin(attribs[0] ? " ":"", attribs, t, NULL);
544 dis_stringify_variant_type (MonoMarshalVariant variant)
547 case MONO_VARIANT_EMPTY:
548 return g_strdup ("");
549 case MONO_VARIANT_NULL:
550 return g_strdup ("null");
551 case MONO_VARIANT_I2:
552 return g_strdup ("int16");
553 case MONO_VARIANT_I4:
554 return g_strdup ("int32");
555 case MONO_VARIANT_R4:
556 return g_strdup ("float32");
557 case MONO_VARIANT_R8:
558 return g_strdup ("float64");
559 case MONO_VARIANT_CY:
560 return g_strdup ("currency");
561 case MONO_VARIANT_DATE:
562 return g_strdup ("date");
563 case MONO_VARIANT_BSTR:
564 return g_strdup ("bstr");
565 case MONO_VARIANT_DISPATCH:
566 return g_strdup ("idispatch");
567 case MONO_VARIANT_ERROR:
568 return g_strdup ("error");
569 case MONO_VARIANT_BOOL:
570 return g_strdup ("bool");
571 case MONO_VARIANT_VARIANT:
572 return g_strdup ("variant");
573 case MONO_VARIANT_UNKNOWN:
574 return g_strdup ("iunknown");
575 case MONO_VARIANT_DECIMAL:
576 return g_strdup ("decimal");
577 case MONO_VARIANT_I1:
578 return g_strdup ("int8");
579 case MONO_VARIANT_UI1:
580 return g_strdup ("unsigned int8");
581 case MONO_VARIANT_UI2:
582 return g_strdup ("unsigned int16");
583 case MONO_VARIANT_UI4:
584 return g_strdup ("unsigned int32");
585 case MONO_VARIANT_I8:
586 return g_strdup ("int64");
587 case MONO_VARIANT_UI8:
588 return g_strdup ("unsigned int64");
589 case MONO_VARIANT_INT:
590 return g_strdup ("int");
591 case MONO_VARIANT_UINT:
592 return g_strdup ("unsigned int");
593 case MONO_VARIANT_VOID:
594 return g_strdup ("void");
595 case MONO_VARIANT_HRESULT:
596 return g_strdup ("hresult");
597 case MONO_VARIANT_PTR:
598 return g_strdup ("*");
599 case MONO_VARIANT_SAFEARRAY:
600 return g_strdup ("safearray");
601 case MONO_VARIANT_CARRAY:
602 return g_strdup ("carray");
603 case MONO_VARIANT_USERDEFINED:
604 return g_strdup ("userdefined");
605 case MONO_VARIANT_LPSTR:
606 return g_strdup ("lpstr");
607 case MONO_VARIANT_LPWSTR:
608 return g_strdup ("lpwstr");
609 case MONO_VARIANT_RECORD:
610 return g_strdup ("record");
611 case MONO_VARIANT_FILETIME:
612 return g_strdup ("filetime");
613 case MONO_VARIANT_BLOB:
614 return g_strdup ("blob");
615 case MONO_VARIANT_STREAM:
616 return g_strdup ("stream");
617 case MONO_VARIANT_STORAGE:
618 return g_strdup ("storage");
619 case MONO_VARIANT_STREAMED_OBJECT:
620 return g_strdup ("streamed_object");
621 case MONO_VARIANT_STORED_OBJECT:
622 return g_strdup ("stored_object");
623 case MONO_VARIANT_BLOB_OBJECT:
624 return g_strdup ("blob_object");
625 case MONO_VARIANT_CF:
626 return g_strdup ("cf");
627 case MONO_VARIANT_CLSID:
628 return g_strdup ("clsid");
629 case MONO_VARIANT_VECTOR:
630 /* FIXME: output: <v_type> vector */
631 return g_strdup ("vector");
632 case MONO_VARIANT_ARRAY:
633 /* FIXME: output: <v_type> [ ] */
634 return g_strdup ("[]");
635 case MONO_VARIANT_BYREF:
636 /* FIXME: output: <v_type> & */
637 return g_strdup ("&");
639 return g_strdup ("unknown");
644 dis_stringify_native_type (MonoMarshalNative native)
647 case MONO_NATIVE_BOOLEAN:
648 return g_strdup ("bool");
650 return g_strdup ("int8");
652 return g_strdup ("unsigned int8");
654 return g_strdup ("int16");
656 return g_strdup ("unsigned int16");
658 return g_strdup ("int32");
660 return g_strdup ("unsigned int32");
662 return g_strdup ("int64");
664 return g_strdup ("unsigned int64");
666 return g_strdup ("float32");
668 return g_strdup ("float64");
669 case MONO_NATIVE_CURRENCY:
670 return g_strdup ("currency");
671 case MONO_NATIVE_BSTR:
672 return g_strdup ("bstr");
673 case MONO_NATIVE_LPSTR:
674 return g_strdup ("lpstr");
675 case MONO_NATIVE_LPWSTR:
676 return g_strdup ("lpwstr");
677 case MONO_NATIVE_LPTSTR:
678 return g_strdup ("lptstr");
679 case MONO_NATIVE_IUNKNOWN:
680 return g_strdup ("iunknown");
681 case MONO_NATIVE_IDISPATCH:
682 return g_strdup ("idispatch");
683 case MONO_NATIVE_STRUCT:
684 return g_strdup ("struct");
685 case MONO_NATIVE_INTERFACE:
686 return g_strdup ("interface");
687 case MONO_NATIVE_SAFEARRAY:
688 return g_strdup ("safearray");
689 case MONO_NATIVE_INT:
690 return g_strdup ("int");
691 case MONO_NATIVE_UINT:
692 return g_strdup ("unsigned int");
693 case MONO_NATIVE_VBBYREFSTR:
694 return g_strdup ("vbbyrefstr");
695 case MONO_NATIVE_ANSIBSTR:
696 return g_strdup ("ansi bstr");
697 case MONO_NATIVE_TBSTR:
698 return g_strdup ("tbstr");
699 case MONO_NATIVE_VARIANTBOOL:
700 return g_strdup ("variant bool");
701 case MONO_NATIVE_FUNC:
702 return g_strdup ("method");
703 case MONO_NATIVE_ASANY:
704 return g_strdup ("as any");
705 case MONO_NATIVE_LPSTRUCT:
706 return g_strdup ("lpstruct");
707 case MONO_NATIVE_CUSTOM:
708 return g_strdup ("custom");
709 case MONO_NATIVE_ERROR:
710 return g_strdup ("error");
711 case MONO_NATIVE_MAX:
712 return g_strdup ("");
714 return g_strdup ("unknown");
719 dis_stringify_marshal_spec (MonoMarshalSpec *spec)
721 switch (spec->native) {
722 case MONO_NATIVE_BYVALTSTR:
723 return g_strdup_printf (" marshal (fixed sysstring [%d])", spec->data.array_data.num_elem);
724 case MONO_NATIVE_BYVALARRAY:
725 return g_strdup_printf (" marshal (fixed array [%d])", spec->data.array_data.num_elem);
726 case MONO_NATIVE_LPARRAY: {
727 char *elem_type, *elems, *ret;
728 guint32 num_elem = spec->data.array_data.num_elem;
729 guint32 param_num = spec->data.array_data.param_num;
731 elem_type = dis_stringify_native_type (spec->data.array_data.elem_type);
732 if (num_elem == -1 && param_num == -1)
733 elems = g_strdup ("");
734 else if ((param_num == -1) || (spec->data.array_data.elem_mult == 0))
735 elems = g_strdup_printf ("%d", num_elem);
736 else if ((num_elem == -1) || (num_elem == 0))
737 elems = g_strdup_printf ("+ %d", param_num);
739 elems = g_strdup_printf ("%d + %d", num_elem, param_num);
741 ret = g_strdup_printf (" marshal (%s[%s])", elem_type, elems);
746 case MONO_NATIVE_SAFEARRAY: {
747 char *elem_type = NULL, *ret;
749 if (spec->data.safearray_data.elem_type != 0)
750 elem_type = dis_stringify_variant_type (spec->data.safearray_data.elem_type);
751 ret = g_strdup_printf (" marshal (safearray %s)", elem_type ? elem_type : "");
756 case MONO_NATIVE_CUSTOM:
757 return g_strdup_printf (" marshal (custom (\"%s\", \"%s\"))",
758 spec->data.custom_data.custom_name ? spec->data.custom_data.custom_name : "",
759 spec->data.custom_data.cookie ? spec->data.custom_data.cookie : "");
761 char *native_type, *ret;
762 native_type = dis_stringify_native_type (spec->native);
763 ret = g_strdup_printf (" marshal (%s)", native_type);
764 g_free (native_type);
772 * @m: metadata context
773 * @table_type: The type of table we are getting generics for (0 for typedef, 1 for method)
774 * @row: The row in the table
776 * Returns: Allocated stringified generic parameters
779 get_generic_param (MonoImage *m, MonoGenericContainer *container)
788 result = g_string_new ("");
790 g_string_append_c (result, '<');
791 for (i = 0; i < container->type_argc; i++) {
792 MonoGenericParam *param = &container->type_params [i];
799 g_string_append (result, ",");
801 flags = param->flags & GENERIC_PARAMETER_ATTRIBUTE_SPECIAL_CONSTRAINTS_MASK;
802 if (flags == GENERIC_PARAMETER_ATTRIBUTE_REFERENCE_TYPE_CONSTRAINT)
803 g_string_append (result, "class ");
804 else if (flags == GENERIC_PARAMETER_ATTRIBUTE_VALUE_TYPE_CONSTRAINT)
805 g_string_append (result, "valuetype ");
806 else if (flags == GENERIC_PARAMETER_ATTRIBUTE_CONSTRUCTOR_CONSTRAINT)
807 g_string_append (result, ".ctor ");
809 for (constr = param->constraints; constr && *constr; constr++) {
813 g_string_append_c (result, '(');
816 g_string_append (result, ", ");
817 sig = dis_stringify_type (m, &((*constr)->byval_arg), TRUE);
818 g_string_append (result, sig);
823 g_string_append (result, ") ");
825 esname = get_escaped_name (param->name);
826 g_string_append (result, esname);
830 g_string_append_c (result, '>');
832 retval = result->str;
833 g_string_free (result, FALSE);
838 dis_stringify_method_signature (MonoImage *m, MonoMethodSignature *method, int methoddef_row,
839 MonoGenericContext *context, gboolean fully_qualified)
841 guint32 cols [MONO_METHOD_SIZE];
842 guint32 pcols [MONO_PARAM_SIZE];
843 guint32 param_index = 0, next_param_index = 0;
844 gboolean has_param_row;
845 const char *name = "", *method_name = "";
847 char *retval, *esname;
849 char *marshal_info = NULL, *ret_marshal_info = NULL;
850 char *gen_param = NULL;
851 GString *result = g_string_new ("");
852 GString *result_ret = g_string_new ("");
853 MonoGenericContainer *container = NULL;
856 g_assert (method || methoddef_row);
859 mono_metadata_decode_row (&m->tables [MONO_TABLE_METHOD], methoddef_row -1, cols, MONO_METHOD_SIZE);
861 type = get_typedef (m, mono_metadata_typedef_from_method (m, methoddef_row));
862 method_name = mono_metadata_string_heap (m, cols [MONO_METHOD_NAME]);
863 param_index = cols [MONO_METHOD_PARAMLIST];
865 const char *sig = mono_metadata_blob_heap (m, cols [MONO_METHOD_SIGNATURE]);
867 container = mono_metadata_load_generic_params (
868 m, MONO_TOKEN_METHOD_DEF | methoddef_row, context ? context->container : NULL);
870 context = (MonoGenericContext *) container;
872 mono_metadata_decode_blob_size (sig, &sig);
873 method = mono_metadata_parse_method_signature_full (m, context, methoddef_row, sig, &sig);
876 container = context->container;
878 if (container && container->is_method)
879 gen_param = get_generic_param (m, container);
881 if (methoddef_row < m->tables [MONO_TABLE_METHOD].rows) {
882 mono_metadata_decode_row (&m->tables [MONO_TABLE_METHOD], methoddef_row, cols, MONO_METHOD_SIZE);
883 next_param_index = cols [MONO_METHOD_PARAMLIST];
885 next_param_index = m->tables [MONO_TABLE_PARAM].rows + 1;
889 start = method->hasthis ? 0 : 1;
890 for (i = 0; i < method->param_count + 1; ++i) {
893 has_param_row = param_index && param_index < next_param_index;
895 if (method->param_count == 0 && !has_param_row)
896 /* method has zero parameters, and no row for return val in the PARAM table */
900 mono_metadata_decode_row (&m->tables [MONO_TABLE_PARAM], param_index - 1, pcols, MONO_PARAM_SIZE);
902 if (has_param_row && i == pcols [MONO_PARAM_SEQUENCE]) {
904 name = mono_metadata_string_heap (m, pcols [MONO_PARAM_NAME]);
906 if (pcols [MONO_PARAM_FLAGS] & PARAM_ATTRIBUTE_HAS_FIELD_MARSHAL) {
908 MonoMarshalSpec *spec;
909 tp = mono_metadata_get_marshal_info (m, param_index - 1, FALSE);
911 spec = mono_metadata_parse_marshal_spec (m, tp);
914 marshal_info = dis_stringify_marshal_spec (spec);
916 ret_marshal_info = dis_stringify_marshal_spec (spec);
921 name = g_strdup_printf ("A_%i", i - start);
928 g_string_append (result, ", ");
930 retval = dis_stringify_param (m, method->params [i - 1]);
932 esname = get_escaped_name (name);
933 g_string_append_printf (result, "%s%s %s", retval, marshal_info ? marshal_info : "", esname);
936 g_free (marshal_info);
938 g_string_append (result, ") ");
940 retval = dis_stringify_param (m, method->ret);
943 g_string_append (result_ret, "instance ");
944 g_string_append (result_ret, map (method->call_convention, call_conv_type_map));
945 g_string_sprintfa (result_ret, " %s%s ", retval, ret_marshal_info ? ret_marshal_info :"");
946 g_free (ret_marshal_info);
948 char *estype = get_escaped_name (type);
949 g_string_sprintfa (result_ret, "%s::", estype);
952 esname = get_escaped_name (method_name);
953 g_string_append (result_ret, esname);
956 g_string_append (result_ret, gen_param);
959 g_string_append (result_ret, " (");
962 g_string_prepend (result, result_ret->str);
963 g_string_free (result_ret, FALSE);
965 if (show_method_tokens && methoddef_row)
966 g_string_append_printf (result, " /* 0x%X */ ",
967 (methoddef_row >> MONO_TYPEORMETHOD_BITS) | MONO_TOKEN_METHOD_DEF);
970 mono_metadata_free_method_signature (method);
971 retval = result->str;
972 g_string_free (result, FALSE);
978 dis_stringify_function_ptr (MonoImage *m, MonoMethodSignature *method)
981 GString *result = g_string_new ("");
986 g_string_append (result, map (method->call_convention, call_conv_type_map));
988 retval = dis_stringify_param (m, method->ret);
989 g_string_sprintfa (result, " %s ", retval);
992 g_string_append (result, " *(");
993 for (i = 0; i < method->param_count; ++i) {
995 g_string_append (result, ", ");
996 retval = dis_stringify_param (m, method->params [i]);
997 g_string_append (result, retval);
1000 g_string_append (result, ") ");
1002 retval = result->str;
1003 g_string_free (result, FALSE);
1009 get_escaped_class_name (MonoClass *c)
1011 char *result, *esname;
1013 if (c->rank || c->byval_arg.type == MONO_TYPE_PTR)
1016 esname = get_escaped_name (c->name);
1019 char *part_a = get_escaped_class_name (c->nested_in);
1021 result = g_strdup_printf ("%s/%s", part_a, esname);
1023 } else if (*c->name_space)
1024 result = g_strdup_printf ("%s.%s", c->name_space, esname);
1026 result = g_strdup (esname);
1033 dis_stringify_object_with_class (MonoImage *m, MonoClass *c, gboolean prefix, gboolean is_def)
1035 /* FIXME: handle MONO_TYPE_OBJECT ... */
1036 MonoType *type = &c->byval_arg;
1037 const char *otype = type->type == MONO_TYPE_VALUETYPE ? "valuetype " : "class " ;
1038 char *assemblyref = NULL, *result, *esname, *generic = NULL;
1040 if (m != c->image) {
1041 if (c->image->assembly_name) {
1043 if (substitute_with_mscorlib_p && !strcmp ("corlib", c->image->assembly_name))
1044 assemblyref = g_strdup_printf ("[%s]", "mscorlib");
1046 char *esc = get_escaped_name (c->image->assembly->aname.name);
1048 assemblyref = g_strdup_printf ("[%s]", esc);
1052 assemblyref = g_strdup_printf ("[.module %s]", c->image->module_name);
1056 esname = get_escaped_class_name (c);
1058 if (c->generic_class) {
1059 MonoGenericClass *gclass = c->generic_class;
1060 GString *str = g_string_new ("");
1063 for (i = 0; i < gclass->inst->type_argc; i++){
1064 char *t = dis_stringify_type (m, gclass->inst->type_argv [i], is_def);
1066 g_string_append (str, t);
1067 if (i+1 != gclass->inst->type_argc)
1068 g_string_append (str, ", ");
1071 generic = g_strdup_printf ("<%s>", str->str);
1072 g_string_free (str, TRUE);
1076 result = g_strdup_printf ("%s%s%s%s", prefix ? otype : "", assemblyref?assemblyref:"",
1077 esname, generic?generic:"");
1080 g_free (assemblyref);
1087 dis_stringify_object (MonoImage *m, MonoType *type, gboolean is_def)
1089 MonoClass *c = mono_class_from_mono_type (type);
1090 return dis_stringify_object_with_class (m, c, TRUE, is_def);
1094 dis_stringify_type (MonoImage *m, MonoType *type, gboolean is_def)
1096 const char *pinned = "", *byref = "";
1097 char *bare = NULL, *mods = NULL;
1101 mods = dis_stringify_modifiers (m, type->num_mods, type->modifiers);
1103 switch (type->type){
1104 case MONO_TYPE_BOOLEAN:
1105 case MONO_TYPE_CHAR:
1118 case MONO_TYPE_STRING:
1119 case MONO_TYPE_OBJECT:
1120 case MONO_TYPE_TYPEDBYREF:
1121 bare = g_strdup (map (type->type, element_type_map));
1124 case MONO_TYPE_VALUETYPE:
1125 case MONO_TYPE_CLASS:
1126 bare = dis_stringify_object (m, type, is_def);
1128 case MONO_TYPE_FNPTR: {
1130 child_type = dis_stringify_function_ptr (m, type->data.method);
1131 bare = g_strdup_printf ("method %s", child_type);
1132 g_free (child_type);
1135 case MONO_TYPE_PTR: {
1137 child_type = dis_stringify_type (m, type->data.type, is_def);
1139 bare = g_strdup_printf ("%s*", child_type);
1140 g_free (child_type);
1143 case MONO_TYPE_SZARRAY: {
1145 child_type = dis_stringify_type (m, &type->data.klass->byval_arg, is_def);
1147 bare = g_strdup_printf ("%s[]", child_type);
1148 g_free (child_type);
1151 case MONO_TYPE_ARRAY:
1152 bare = dis_stringify_array (m, type->data.array, is_def);
1154 case MONO_TYPE_VOID:
1155 bare = g_strdup ("void");
1157 case MONO_TYPE_MVAR:
1159 g_assert (type->data.generic_param->name);
1160 bare = g_strdup_printf ("!!%s", type->data.generic_param->name);
1162 bare = g_strdup_printf ("!!%d", type->data.generic_param->num);
1166 g_assert (type->data.generic_param->name);
1167 bare = g_strdup_printf ("!%s", type->data.generic_param->name);
1169 bare = g_strdup_printf ("!%d", type->data.generic_param->num);
1171 case MONO_TYPE_GENERICINST: {
1172 GString *str = g_string_new ("");
1174 char *generic_type = dis_stringify_type (
1175 m, &type->data.generic_class->container_class->byval_arg, is_def);
1177 for (i = 0; i < type->data.generic_class->inst->type_argc; i++){
1178 char *t = dis_stringify_type (m, type->data.generic_class->inst->type_argv [i], is_def);
1180 g_string_append (str, t);
1181 if (i+1 != type->data.generic_class->inst->type_argc)
1182 g_string_append (str, ", ");
1185 bare = g_strdup_printf ("%s<%s>", generic_type, str->str);
1186 g_string_free (str, TRUE);
1191 g_error ("Do not know how to stringify type 0x%x", type->type);
1200 result = g_strconcat (mods ? mods : "", bare, byref, pinned, NULL);
1209 * @m: metadata context
1210 * @ptr: location to decode from.
1211 * @result: pointer to string where resulting decoded string is stored
1213 * This routine returs in @result the stringified type pointed by @ptr.
1216 * Returns: the new ptr to continue decoding
1219 get_type (MonoImage *m, const char *ptr, char **result, MonoGenericContext *context)
1221 const char *start = ptr;
1225 if (*ptr == MONO_TYPE_BYREF)
1228 type = mono_metadata_decode_value (ptr, &ptr);
1231 case MONO_TYPE_VALUETYPE:
1232 case MONO_TYPE_CLASS: {
1233 guint32 token = mono_metadata_parse_typedef_or_ref (m, ptr, &ptr);
1234 MonoClass *klass = mono_class_get (m, token);
1235 char *temp = dis_stringify_object_with_class (m, klass, TRUE, FALSE);
1238 *result = g_strdup_printf ("%s/*%08x*/", temp, token);
1245 case MONO_TYPE_GENERICINST: {
1246 GString *str = g_string_new ("");
1250 ptr = get_type (m, ptr, &temp, context);
1251 g_string_append (str, temp);
1254 count = mono_metadata_decode_value (ptr, &ptr);
1255 g_string_append (str, "<");
1257 for (i = 0; i < count; i++) {
1259 g_string_append (str, ",");
1260 ptr = get_type (m, ptr, &temp, context);
1261 g_string_append (str, temp);
1264 g_string_append (str, ">");
1266 g_string_free (str, FALSE);
1271 t = mono_metadata_parse_type_full (m, context, MONO_PARSE_TYPE, 0, start, &ptr);
1272 *result = dis_stringify_type (m, t, FALSE);
1273 mono_metadata_free_type (t);
1282 * Returns a stringified representation of a FieldSig (22.2.4)
1285 get_field_signature (MonoImage *m, guint32 blob_signature, MonoGenericContext *context)
1287 char *allocated_modifier_string, *allocated_type_string;
1288 const char *ptr = mono_metadata_blob_heap (m, blob_signature);
1293 len = mono_metadata_decode_value (ptr, &ptr);
1296 g_assert (*ptr == 0x06);
1297 /* hex_dump (ptr, 0, len); */
1300 ptr = get_custom_mod (m, ptr, &allocated_modifier_string);
1301 ptr = get_type (m, ptr, &allocated_type_string, context);
1303 res = g_strdup_printf (
1305 allocated_modifier_string ? allocated_modifier_string : "",
1306 allocated_type_string);
1308 if (allocated_modifier_string)
1309 g_free (allocated_modifier_string);
1310 if (allocated_type_string)
1311 g_free (allocated_type_string);
1317 get_field_literal_type (MonoImage *m, guint32 blob_signature)
1319 const char *ptr = mono_metadata_blob_heap (m, blob_signature);
1321 char *allocated_modifier_string;
1323 len = mono_metadata_decode_value (ptr, &ptr);
1326 g_assert (*ptr == 0x06);
1329 ptr = get_custom_mod (m, ptr, &allocated_modifier_string);
1330 if (allocated_modifier_string)
1331 g_free (allocated_modifier_string);
1333 return (MonoTypeEnum) *ptr;
1339 * @m: metadata context
1340 * @token: token to decode
1342 * decodes the literal indexed by @token.
1345 decode_literal (MonoImage *m, guint32 token)
1347 return g_strdup ("LITERAL_VALUE");
1352 * @m: metadata context
1353 * @ptr: location to decode from.
1354 * @result: pointer to string where resulting decoded string is stored
1356 * This routine returns in @result the stringified RetType (22.2.11)
1358 * Returns: the new ptr to continue decoding.
1361 get_ret_type (MonoImage *m, const char *ptr, char **ret_type, MonoGenericContext *context)
1363 GString *str = g_string_new ("");
1365 char *allocated_type_string;
1368 ptr = get_custom_mod (m, ptr, &mod);
1370 g_string_append (str, mod);
1371 g_string_append_c (str, ' ');
1375 if (*ptr == MONO_TYPE_TYPEDBYREF){
1376 g_string_append (str, "typedref");
1378 } else if (*ptr == MONO_TYPE_VOID){
1379 g_string_append (str, "void");
1382 if (*ptr == MONO_TYPE_BYREF){
1387 ptr = get_type (m, ptr, &allocated_type_string, context);
1388 g_string_append (str, allocated_type_string);
1390 g_string_append (str, "& ");
1391 g_free (allocated_type_string);
1394 *ret_type = str->str;
1395 g_string_free (str, FALSE);
1402 * @m: metadata context
1403 * @ptr: location to decode from.
1404 * @result: pointer to string where resulting decoded string is stored
1406 * This routine returns in @result the stringified Param (22.2.10)
1408 * Returns: the new ptr to continue decoding.
1411 get_param (MonoImage *m, const char *ptr, char **retval, MonoGenericContext *context)
1413 GString *str = g_string_new ("");
1414 char *allocated_mod_string, *allocated_type_string;
1416 ptr = get_custom_mod (m, ptr, &allocated_mod_string);
1417 if (allocated_mod_string){
1418 g_string_append (str, allocated_mod_string);
1419 g_string_append_c (str, ' ');
1420 g_free (allocated_mod_string);
1423 if (*ptr == MONO_TYPE_TYPEDBYREF){
1424 g_string_append (str, " typedref ");
1427 gboolean by_ref = 0;
1428 if (*ptr == MONO_TYPE_BYREF){
1429 g_string_append (str, "[out] ");
1433 ptr = get_type (m, ptr, &allocated_type_string, context);
1434 g_string_append (str, allocated_type_string);
1436 g_string_append_c (str, '&');
1437 g_free (allocated_type_string);
1441 g_string_free (str, FALSE);
1448 * Returns: An allocated escaped name. A name needs to be escaped
1449 * because it might be an ilasm keyword.
1452 get_escaped_name (const char *name)
1457 g_assert (key_table);
1459 if (strlen (name) == 0)
1460 return g_strdup (name);
1462 for (s = name; *s; s++) {
1463 char *first, *result;
1468 first = g_strndup (name, s-name);
1469 result = g_strdup_printf ("%s/%s", get_escaped_name (first), get_escaped_name (s+1));
1475 for (s = name; *s; s++) {
1476 if (isalnum (*s) || *s == '_' || *s == '$' || *s == '@' ||
1477 *s == '?' || *s == '.' || *s == 0 || *s == '!')
1480 return g_strdup_printf ("'%s'", name);
1483 if (g_hash_table_lookup (key_table, name))
1484 return g_strdup_printf ("'%s'", name);
1486 return g_strdup (name);
1489 static dis_map_t param_map [] = {
1490 { PARAM_ATTRIBUTE_IN, "[in] " },
1491 { PARAM_ATTRIBUTE_OUT, "[out] " },
1492 { PARAM_ATTRIBUTE_OPTIONAL, "optional " },
1493 { PARAM_ATTRIBUTE_HAS_DEFAULT, "hasdefault " },
1494 { PARAM_ATTRIBUTE_HAS_FIELD_MARSHAL, "fieldmarshal " },
1499 param_flags (guint32 f)
1501 return g_strdup (flags (f, param_map));
1504 static dis_map_t field_access_map [] = {
1505 { FIELD_ATTRIBUTE_COMPILER_CONTROLLED, "privatescope " },
1506 { FIELD_ATTRIBUTE_PRIVATE, "private " },
1507 { FIELD_ATTRIBUTE_FAM_AND_ASSEM, "famandassem " },
1508 { FIELD_ATTRIBUTE_ASSEMBLY, "assembly " },
1509 { FIELD_ATTRIBUTE_FAMILY, "family " },
1510 { FIELD_ATTRIBUTE_FAM_OR_ASSEM, "famorassem " },
1511 { FIELD_ATTRIBUTE_PUBLIC, "public " },
1515 static dis_map_t field_flags_map [] = {
1516 { FIELD_ATTRIBUTE_STATIC, "static " },
1517 { FIELD_ATTRIBUTE_INIT_ONLY, "initonly " },
1518 { FIELD_ATTRIBUTE_LITERAL, "literal " },
1519 { FIELD_ATTRIBUTE_NOT_SERIALIZED, "notserialized " },
1520 { FIELD_ATTRIBUTE_SPECIAL_NAME, "specialname " },
1521 { FIELD_ATTRIBUTE_PINVOKE_IMPL, "FIXME:pinvokeimpl " },
1522 { FIELD_ATTRIBUTE_RT_SPECIAL_NAME, "rtspecialname " },
1523 /*{ FIELD_ATTRIBUTE_HAS_FIELD_MARSHAL, "hasfieldmarshal " },*/
1530 * Returns a stringified version of a Field's flags
1533 field_flags (guint32 f)
1536 int access = f & FIELD_ATTRIBUTE_FIELD_ACCESS_MASK;
1540 strcat (buffer, map (access, field_access_map));
1541 strcat (buffer, flags (f, field_flags_map));
1542 return g_strdup (buffer);
1546 * Returns a stringifed representation of a MethodRefSig (22.2.2)
1549 get_methodref_signature (MonoImage *m, guint32 blob_signature, const char *fancy_name,
1550 MonoGenericContext *context)
1552 GString *res = g_string_new ("");
1553 const char *ptr = mono_metadata_blob_heap (m, blob_signature);
1554 char *allocated_ret_type, *s;
1555 const char *cconv_str;
1556 gboolean seen_vararg = 0;
1557 int param_count, signature_len;
1558 int i, gen_count = 0;
1561 signature_len = mono_metadata_decode_value (ptr, &ptr);
1565 g_string_append (res, "explicit-this ");
1567 g_string_append (res, "instance "); /* has-this */
1572 cconv = *ptr & 0x0f;
1573 cconv_str = map (cconv, call_conv_type_map);
1574 if (strcmp (cconv_str, "default") != 0) {
1575 g_string_append (res, cconv_str);
1576 g_string_append (res, " ");
1581 gen_count = mono_metadata_decode_value (ptr, &ptr);
1582 param_count = mono_metadata_decode_value (ptr, &ptr);
1584 ptr = get_ret_type (m, ptr, &allocated_ret_type, context);
1585 g_string_append (res, allocated_ret_type);
1586 g_free (allocated_ret_type);
1590 g_string_append_c (res, ' ');
1591 g_string_append (res, fancy_name);
1594 g_string_append (res, "(");
1597 * param_count describes parameters *before* and *after*
1598 * the vararg sentinel
1600 for (i = 0; i < param_count; i++){
1604 * If ptr is a SENTINEL
1608 g_string_append (res, "..., ");
1615 ptr = get_param (m, ptr, ¶m, context);
1616 g_string_append (res, param);
1617 if (i+1 != param_count)
1618 g_string_append (res, ", ");
1621 g_string_append (res, ")");
1624 * cleanup and return
1627 g_string_free (res, FALSE);
1632 * Returns a stringifed representation of a field ref
1635 get_fieldref_signature (MonoImage *m, int idx, MonoGenericContext *context)
1637 guint32 cols [MONO_MEMBERREF_SIZE];
1638 MonoGenericContext *new_context;
1639 char *type, *esname;
1643 mono_metadata_decode_row (&m->tables [MONO_TABLE_MEMBERREF],
1644 idx - 1, cols, MONO_MEMBERREF_SIZE);
1646 new_context = get_memberref_context (m, cols [MONO_MEMBERREF_CLASS], context);
1647 sig = get_field_signature (m, cols [MONO_MEMBERREF_SIGNATURE], new_context);
1649 type = get_memberref_parent (m, cols [MONO_MEMBERREF_CLASS], context);
1650 esname = get_escaped_name (mono_metadata_string_heap (m, cols [MONO_MEMBERREF_NAME]));
1652 full_sig = g_strdup_printf ("%s %s::%s", sig, type, esname);
1662 * @m: metadata context
1663 * @token: a FIELD_DEF token
1665 * This routine has to locate the TypeDef that "owns" this Field.
1666 * Since there is no backpointer in the Field table, we have to scan
1667 * the TypeDef table and locate the actual "owner" of the field
1670 get_field (MonoImage *m, guint32 token, MonoGenericContext *context)
1672 int idx = mono_metadata_token_index (token);
1673 guint32 cols [MONO_FIELD_SIZE];
1674 char *sig, *res, *type, *estype, *esname;
1678 * We can get here also with a MenberRef token (for a field
1679 * defined in another module/assembly, just like in get_method ()
1681 if (mono_metadata_token_code (token) == MONO_TOKEN_MEMBER_REF) {
1682 return get_fieldref_signature (m, idx, context);
1684 g_assert (mono_metadata_token_code (token) == MONO_TOKEN_FIELD_DEF);
1686 mono_metadata_decode_row (&m->tables [MONO_TABLE_FIELD], idx - 1, cols, MONO_FIELD_SIZE);
1687 sig = get_field_signature (m, cols [MONO_FIELD_SIGNATURE], context);
1690 * To locate the actual "container" for this field, we have to scan
1691 * the TypeDef table. LAME!
1693 type_idx = mono_metadata_typedef_from_field (m, idx);
1695 type = get_typedef (m, type_idx);
1696 estype = get_escaped_name (type);
1697 esname = get_escaped_name (mono_metadata_string_heap (m, cols [MONO_FIELD_NAME]));
1698 res = g_strdup_printf ("%s %s::%s",
1699 sig, estype, esname);
1709 static MonoGenericContext *
1710 get_memberref_context (MonoImage *m, guint32 mrp_token, MonoGenericContext *context)
1715 * mrp_index is a MemberRefParent coded index
1717 guint32 table = mrp_token & 7;
1718 guint32 idx = mrp_token >> 3;
1721 case 0: /* TypeDef */
1722 return (MonoGenericContext *) mono_metadata_load_generic_params (
1723 m, MONO_TOKEN_TYPE_DEF | idx, NULL);
1725 case 1: /* TypeRef */
1728 case 4: /* TypeSpec */
1729 klass = mono_class_get_full (m, MONO_TOKEN_TYPE_SPEC | idx, context);
1731 return klass->generic_class ? klass->generic_class->context : NULL;
1733 g_assert_not_reached ();
1738 get_memberref_parent (MonoImage *m, guint32 mrp_token, MonoGenericContext *context)
1741 * mrp_index is a MemberRefParent coded index
1743 guint32 table = mrp_token & 7;
1744 guint32 idx = mrp_token >> 3;
1747 case 0: /* TypeDef */
1748 return get_typedef (m, idx);
1750 case 1: /* TypeRef */
1751 return get_typeref (m, idx);
1753 case 2: /* ModuleRef */
1754 return g_strdup_printf ("TODO:MemberRefParent-ModuleRef");
1756 case 3: /* MethodDef */
1757 return g_strdup ("TODO:MethodDef");
1759 case 4: /* TypeSpec */
1760 return get_typespec (m, idx, FALSE, context);
1762 g_assert_not_reached ();
1768 * @m: metadata context
1769 * @token: a METHOD_DEF or MEMBER_REF token
1771 * This routine has to locate the TypeDef that "owns" this Field.
1772 * Since there is no backpointer in the Field table, we have to scan
1773 * the TypeDef table and locate the actual "owner" of the field
1776 get_method_core (MonoImage *m, guint32 token, gboolean fullsig, MonoGenericContext *context)
1778 int idx = mono_metadata_token_index (token);
1779 guint32 member_cols [MONO_MEMBERREF_SIZE], method_cols [MONO_METHOD_SIZE];
1780 char *sig = NULL, *esname;
1785 mh = mono_get_method_full (m, token, NULL, context);
1787 if (mono_method_signature (mh)->is_inflated)
1788 context = ((MonoMethodInflated *) mh)->context;
1789 esname = get_escaped_name (mh->name);
1790 sig = dis_stringify_type (m, &mh->klass->byval_arg, TRUE);
1792 name = g_strdup_printf ("%s/*%08x*/::%s", sig, token, esname);
1794 name = g_strdup_printf ("%s::%s", sig, esname);
1800 switch (mono_metadata_token_code (token)){
1801 case MONO_TOKEN_METHOD_DEF:
1802 mono_metadata_decode_row (&m->tables [MONO_TABLE_METHOD],
1803 idx - 1, method_cols, MONO_METHOD_SIZE);
1805 sig = get_methodref_signature (m, method_cols [MONO_METHOD_SIGNATURE], name, context);
1808 case MONO_TOKEN_MEMBER_REF: {
1809 mono_metadata_decode_row (&m->tables [MONO_TABLE_MEMBERREF],
1810 idx - 1, member_cols, MONO_MEMBERREF_SIZE);
1812 name = g_strdup_printf ("%s::%s",
1813 get_memberref_parent (m, member_cols [MONO_MEMBERREF_CLASS], context),
1814 mono_metadata_string_heap (m, member_cols [MONO_MEMBERREF_NAME]));
1815 sig = get_methodref_signature (
1816 m, member_cols [MONO_MEMBERREF_SIGNATURE], name, context);
1819 case MONO_TOKEN_METHOD_SPEC: {
1820 mono_metadata_decode_row (&m->tables [MONO_TABLE_METHODSPEC],
1821 idx - 1, member_cols, MONO_METHODSPEC_SIZE);
1822 token = member_cols [MONO_METHODSPEC_METHOD];
1823 sig = get_methodspec (m, idx, token, name, context);
1828 g_assert_not_reached ();
1839 char *retval = g_strdup_printf ("%s /* %08x */", sig, token);
1847 get_method (MonoImage *m, guint32 token, MonoGenericContext *context)
1849 return get_method_core (m, token, TRUE, context);
1854 * @m: metadata context
1855 * @idx: index into the method table
1857 * Returns: A stringified version of the method signature.
1860 get_methoddef (MonoImage *m, guint32 idx)
1862 guint32 cols [MONO_METHOD_SIZE];
1868 mh = mono_get_method (m, MONO_TOKEN_METHOD_DEF | idx, NULL);
1870 sig = dis_stringify_type (m, &mh->klass->byval_arg, FALSE);
1871 name = g_strdup_printf ("%s::%s", sig, mh->name);
1875 mono_metadata_decode_row (&m->tables [MONO_TABLE_METHOD],
1876 idx - 1, cols, MONO_METHOD_SIZE);
1877 sig = get_methodref_signature (m, cols [MONO_METHOD_SIGNATURE], name, NULL);
1883 get_method_type_param (MonoImage *m, guint32 blob_signature, MonoGenericContext *context)
1885 GString *res = g_string_new ("");
1886 const char *ptr = mono_metadata_blob_heap (m, blob_signature);
1891 mono_metadata_decode_value (ptr, &ptr);
1893 param_count = mono_metadata_decode_value (ptr, &ptr);
1895 g_string_append_c (res, '<');
1897 for (i = 0; i < param_count; i++){
1900 ptr = get_param (m, ptr, ¶m, context);
1901 g_string_append (res, param);
1902 if (i+1 != param_count)
1903 g_string_append (res, ", ");
1906 g_string_append_c (res, '>');
1909 g_string_free (res, FALSE);
1916 * Returns: An allocated stringified version of the methodspec signature.
1920 get_methodspec (MonoImage *m, int idx, guint32 token, const char *fancy_name, MonoGenericContext *context)
1922 GString *res = g_string_new ("");
1923 guint32 member_cols [MONO_MEMBERREF_SIZE], method_cols [MONO_METHOD_SIZE];
1924 char *s, *type_param;
1927 int param_count, cconv, i, gen_count = 0;
1929 switch (token & MONO_METHODDEFORREF_MASK) {
1930 case MONO_METHODDEFORREF_METHODDEF:
1931 mono_metadata_decode_row (&m->tables [MONO_TABLE_METHOD],
1932 (token >> MONO_METHODDEFORREF_BITS) - 1,
1933 method_cols, MONO_METHOD_SIZE);
1934 sig = method_cols [MONO_METHOD_SIGNATURE];
1936 case MONO_METHODDEFORREF_METHODREF:
1937 mono_metadata_decode_row (&m->tables [MONO_TABLE_MEMBERREF],
1938 (token >> MONO_METHODDEFORREF_BITS) - 1,
1939 member_cols, MONO_MEMBERREF_SIZE);
1940 sig = member_cols [MONO_MEMBERREF_SIGNATURE];
1943 g_assert_not_reached ();
1946 ptr = mono_metadata_blob_heap (m, sig);
1947 mono_metadata_decode_value (ptr, &ptr);
1951 g_string_append (res, "explicit-this ");
1953 g_string_append (res, "instance "); /* has-this */
1958 cconv = *ptr & 0x0f;
1961 gen_count = mono_metadata_decode_value (ptr, &ptr);
1962 param_count = mono_metadata_decode_value (ptr, &ptr);
1964 char *allocated_ret_type;
1965 ptr = get_ret_type (m, ptr, &allocated_ret_type, context);
1966 g_string_append (res, allocated_ret_type);
1967 g_free (allocated_ret_type);
1971 g_string_append_c (res, ' ');
1972 g_string_append (res, fancy_name);
1975 mono_metadata_decode_row (&m->tables [MONO_TABLE_METHODSPEC],
1976 idx - 1, member_cols, MONO_METHODSPEC_SIZE);
1977 token = member_cols [MONO_METHODSPEC_SIGNATURE];
1978 type_param = get_method_type_param (m, token, context);
1979 g_string_append (res, type_param);
1980 g_string_append (res, " (");
1983 * methodspecs can not be varargs so we don't need to worry about that here
1986 for (i = 0; i < param_count; i++){
1989 ptr = get_param (m, ptr, ¶m, context);
1990 g_string_append (res, param);
1991 if (i+1 != param_count)
1992 g_string_append (res, ", ");
1995 g_string_append (res, ")");
1998 * cleanup and return
2001 g_string_free (res, FALSE);
2006 * get_encoded_user_string_bytearray:
2007 * @ptr: pointer into the US heap
2008 * @len: length of string in the heap.
2010 * Strings on the US heap are encoded using UTF-16. Print a bytearray.
2013 get_encoded_user_string_bytearray (const unsigned char* ptr, int len)
2016 int i, j, tspaces = (len % 16);
2020 return g_strdup_printf ("\"\"");
2022 res = g_string_new ("bytearray (\n\t");
2024 for (i = 1; i <= len; ++i) {
2025 g_string_append_printf (res, "%02x ", ptr [i-1]);
2029 g_string_append (res, ")// ");
2031 g_string_append (res, " // ");
2033 for(j = i - 16; j < i; ++j)
2034 g_string_append_printf (res, "%c", isprint (ptr [j]) ? ptr [j] : '.');
2035 g_string_append (res, "\n\t");
2040 g_string_append (res, ") ");
2041 for (i = tspaces + 1; i < 16; ++i)
2042 g_string_append_printf (res, " ");
2044 g_string_append (res, " // ");
2045 for(i = len - tspaces; i < len; ++i)
2046 g_string_append_printf (res, "%c", isprint (ptr [i]) ? ptr [i] : '.');
2047 g_string_append (res, "\n\t");
2051 g_string_free (res, FALSE);
2056 * get_encoded_user_string_or_bytearray:
2057 * @ptr: pointer into the US heap
2059 * Strings on the US heap are encoded using UTF-16. Print as string
2060 * if possible, else emit a bytearray.
2063 get_encoded_user_string_or_bytearray (const unsigned char *ptr, int len)
2065 unsigned char *res, *eres, *result;
2068 res = g_malloc ((len >> 1) + 1);
2071 * I should really use some kind of libunicode here
2073 for (i = 0; i + 1 < len; i += 2) {
2075 (!isprint (ptr [i]) && ptr [i] != '\\' && ptr [i] != '"' &&
2076 ptr [i] != '\r' && ptr [i] != '\n' && ptr [i] != '\t')) {
2078 return get_encoded_user_string_bytearray (ptr, len);
2081 res [i >> 1] = ptr [i];
2086 eres = g_strescape (res, NULL);
2087 result = g_strdup_printf ("\"%s\"", eres);
2096 * @m: metadata context
2097 * @blob_index: index into the blob where the constant is stored
2099 * Returns: An allocated value representing a stringified version of the
2103 get_constant (MonoImage *m, MonoTypeEnum t, guint32 blob_index)
2105 const unsigned char *ptr = mono_metadata_blob_heap (m, blob_index);
2108 len = mono_metadata_decode_value (ptr, (const char**)&ptr);
2111 case MONO_TYPE_BOOLEAN:
2112 return g_strdup_printf ("%s", *ptr ? "bool(true)" : "bool(false)");
2114 case MONO_TYPE_CHAR:
2115 return g_strdup_printf ("char(0x%04x)", read16(ptr));
2119 return g_strdup_printf ("int8(0x%02x)", (int) (*ptr));
2124 return g_strdup_printf ("int16(0x%08x)", (int) read16 (ptr));
2128 return g_strdup_printf ("int32(0x%08x)", read32 (ptr));
2131 case MONO_TYPE_I8: {
2134 high = read32 (ptr + 4);
2135 return g_strdup_printf ("int64(0x%08x%08x)", high, low);
2137 case MONO_TYPE_R4: {
2141 return g_strdup_printf ("float32(0x%08x)", read32 (ptr));
2143 return g_strdup_printf ("float32(%.20g)", r);
2145 case MONO_TYPE_R8: {
2148 if (! isnormal (r)) {
2151 high = read32 (ptr + 4);
2152 return g_strdup_printf ("float64(0x%08x%08x)", high, low);
2154 return g_strdup_printf ("float64(%.20g)", r);
2157 case MONO_TYPE_STRING:
2158 return get_encoded_user_string_or_bytearray (ptr, len);
2160 case MONO_TYPE_CLASS:
2161 return g_strdup ("nullref");
2164 g_error ("Unknown MONO_TYPE (%d) on constant at Blob index (0x%08x)\n",
2165 (int) *ptr, blob_index);
2166 return g_strdup_printf ("Unknown");
2173 * @m: metadata context
2174 * @token: token that we want to decode.
2176 * Returns: An allocated value representing a stringified version of the
2180 get_token (MonoImage *m, guint32 token, MonoGenericContext *context)
2182 char *temp, *result;
2183 guint32 idx = mono_metadata_token_index (token);
2185 switch (mono_metadata_token_code (token)){
2186 case MONO_TOKEN_FIELD_DEF:
2187 temp = get_field (m, token, context);
2188 result = g_strdup_printf ("field %s", temp);
2191 case MONO_TOKEN_TYPE_DEF:
2192 temp = get_typedef (m, idx);
2193 result = get_escaped_name (temp);
2196 case MONO_TOKEN_TYPE_REF:
2197 return get_typeref (m, idx);
2198 case MONO_TOKEN_TYPE_SPEC:
2199 return get_typespec (m, idx, TRUE, context);
2200 case MONO_TOKEN_MEMBER_REF: {
2201 guint32 cols [MONO_MEMBERREF_SIZE];
2203 mono_metadata_decode_row (&m->tables [MONO_TABLE_MEMBERREF], mono_metadata_token_index (token) - 1, cols, MONO_MEMBERREF_SIZE);
2204 sig = mono_metadata_blob_heap (m, cols [MONO_MEMBERREF_SIGNATURE]);
2205 mono_metadata_decode_blob_size (sig, &sig);
2206 if (*sig == 0x6) { /* it's a field */
2207 temp = get_field (m, token, context);
2208 result = g_strdup_printf ("field %s", temp);
2212 temp = get_method (m, token, context);
2213 result = g_strdup_printf ("method %s", temp);
2220 g_error ("Do not know how to decode tokens of type 0x%08x", token);
2223 g_assert_not_reached ();
2224 return g_strdup ("ERROR");
2229 * @m: metadata context
2230 * @token: the token can belong to any of the following tables:
2231 * MONO_TOKEN_TYPE_REF, MONO_TOKEN_TYPE_DEF, MONO_TOKEN_TYPE_SPEC
2233 * Returns: a stringified version of the MethodDef or MethodRef or TypeSpecn
2234 * at (token & 0xffffff)
2237 get_token_type (MonoImage *m, guint32 token, MonoGenericContext *context)
2239 char *temp = NULL, *s = NULL;
2242 idx = mono_metadata_token_index (token);
2244 switch (mono_metadata_token_code (token)){
2245 case MONO_TOKEN_TYPE_DEF:
2246 temp = get_typedef (m, idx);
2247 s = g_strdup_printf ("%s", temp);
2250 case MONO_TOKEN_TYPE_REF:
2251 temp = get_typeref (m, idx);
2252 s = g_strdup_printf ("%s", temp);
2255 case MONO_TOKEN_TYPE_SPEC:
2256 s = get_typespec (m, idx, FALSE, context);
2260 g_error ("Unhandled encoding for token 0x%08x", token);
2271 get_guid (MonoImage *m, guint32 guid_index)
2273 const unsigned char *guid;
2276 guid = mono_metadata_guid_heap (m, guid_index);
2278 result = g_strdup_printf ("{%02X%02X%02X%02X-%02X%02X-%02X%02X-%02X%02X-%02X%02X%02X%02X%02X%02X}",
2279 guid [3], guid [2], guid [1], guid [0], guid [5], guid [4], guid [7], guid [6],
2280 guid [8], guid [9], guid [10], guid [11], guid [12], guid [13], guid [14], guid [15]);
2285 dis_get_custom_attrs (MonoImage *m, guint32 token)
2288 guint32 idx, i, len, mtoken;
2289 guint32 cols [MONO_CUSTOM_ATTR_SIZE];
2295 idx = mono_metadata_token_index (token);
2296 idx <<= MONO_CUSTOM_ATTR_BITS;
2298 switch (mono_metadata_token_table (token)) {
2299 case MONO_TABLE_TYPEDEF:
2300 idx |= MONO_CUSTOM_ATTR_TYPEDEF;
2302 case MONO_TABLE_ASSEMBLY:
2303 idx |= MONO_CUSTOM_ATTR_ASSEMBLY;
2305 case MONO_TABLE_ASSEMBLYREF:
2306 idx |= MONO_CUSTOM_ATTR_ASSEMBLYREF;
2308 case MONO_TABLE_MODULE:
2309 idx |= MONO_CUSTOM_ATTR_MODULE;
2311 case MONO_TABLE_PROPERTY:
2312 idx |= MONO_CUSTOM_ATTR_PROPERTY;
2314 case MONO_TABLE_EVENT:
2315 idx |= MONO_CUSTOM_ATTR_EVENT;
2317 case MONO_TABLE_FIELD:
2318 idx |= MONO_CUSTOM_ATTR_FIELDDEF;
2320 case MONO_TABLE_METHOD:
2321 idx |= MONO_CUSTOM_ATTR_METHODDEF;
2323 case MONO_TABLE_PARAM:
2324 idx |= MONO_CUSTOM_ATTR_PARAMDEF;
2327 g_print ("Missing custom attr get support for token 0x%08x\n", token);
2331 ca = &m->tables [MONO_TABLE_CUSTOMATTRIBUTE];
2332 /* the table is not sorted */
2333 for (i = 0; i < ca->rows; ++i) {
2335 mono_metadata_decode_row (ca, i, cols, MONO_CUSTOM_ATTR_SIZE);
2336 if (cols [MONO_CUSTOM_ATTR_PARENT] != idx)
2338 mtoken = cols [MONO_CUSTOM_ATTR_TYPE] >> MONO_CUSTOM_ATTR_TYPE_BITS;
2339 switch (cols [MONO_CUSTOM_ATTR_TYPE] & MONO_CUSTOM_ATTR_TYPE_MASK) {
2340 case MONO_CUSTOM_ATTR_TYPE_METHODDEF:
2341 mtoken |= MONO_TOKEN_METHOD_DEF;
2343 case MONO_CUSTOM_ATTR_TYPE_MEMBERREF:
2344 mtoken |= MONO_TOKEN_MEMBER_REF;
2347 g_error ("Unknown table for custom attr type %08x", cols [MONO_CUSTOM_ATTR_TYPE]);
2350 method = get_method (m, mtoken, NULL);
2351 val = mono_metadata_blob_heap (m, cols [MONO_CUSTOM_ATTR_VALUE]);
2352 len = mono_metadata_decode_value (val, &val);
2353 attr = g_string_new (".custom ");
2354 dump = data_dump (val, len, "\t\t");
2355 g_string_sprintfa (attr, "%s = %s", method, dump);
2357 list = g_list_append (list, attr->str);
2358 g_string_free (attr, FALSE);
2365 get_marshal_info (MonoImage *m, const char *blob) {
2368 len = mono_metadata_decode_blob_size (blob, &blob);
2371 case MONO_NATIVE_BOOLEAN:
2372 return g_strdup ("bool");
2373 case MONO_NATIVE_I1:
2374 return g_strdup ("int8");
2375 case MONO_NATIVE_U1:
2376 return g_strdup ("unsigned int8");
2377 case MONO_NATIVE_I2:
2378 return g_strdup ("int16");
2379 case MONO_NATIVE_U2:
2380 return g_strdup ("unsigned int16");
2381 case MONO_NATIVE_I4:
2382 return g_strdup ("int32");
2383 case MONO_NATIVE_U4:
2384 return g_strdup ("unsigned int32");
2385 case MONO_NATIVE_I8:
2386 return g_strdup ("int64");
2387 case MONO_NATIVE_U8:
2388 return g_strdup ("unsigned int64");
2389 case MONO_NATIVE_R4:
2390 return g_strdup ("float32");
2391 case MONO_NATIVE_R8:
2392 return g_strdup ("float64");
2393 case MONO_NATIVE_CURRENCY:
2394 return g_strdup ("currency");
2395 case MONO_NATIVE_BSTR:
2396 return g_strdup ("bstr");
2397 case MONO_NATIVE_LPSTR:
2398 return g_strdup ("lpstr");
2399 case MONO_NATIVE_LPWSTR:
2400 return g_strdup ("lpwstr");
2401 case MONO_NATIVE_LPTSTR:
2402 return g_strdup ("lptstr");
2403 case MONO_NATIVE_BYVALTSTR:
2404 size = mono_metadata_decode_value (blob + 1, &blob);
2405 return g_strdup_printf ("fixed sysstring [%d]", size);
2406 case MONO_NATIVE_IUNKNOWN:
2407 return g_strdup ("iunknown");
2408 case MONO_NATIVE_IDISPATCH:
2409 return g_strdup ("idispatch");
2410 case MONO_NATIVE_STRUCT:
2411 return g_strdup ("struct");
2412 case MONO_NATIVE_INTERFACE:
2413 return g_strdup ("interface");
2414 case MONO_NATIVE_SAFEARRAY:
2415 return g_strdup ("safearray");
2416 case MONO_NATIVE_BYVALARRAY:
2417 size = mono_metadata_decode_value (blob + 1, &blob);
2418 return g_strdup_printf ("fixed array [%d]", size);
2419 case MONO_NATIVE_INT:
2420 return g_strdup ("int");
2421 case MONO_NATIVE_UINT:
2422 return g_strdup ("unsigned int");
2423 case MONO_NATIVE_VBBYREFSTR:
2424 return g_strdup ("vbbyrefstr");
2425 case MONO_NATIVE_ANSIBSTR:
2426 return g_strdup ("ansi bstr");
2427 case MONO_NATIVE_TBSTR:
2428 return g_strdup ("tbstr");
2429 case MONO_NATIVE_VARIANTBOOL:
2430 return g_strdup ("variant bool");
2431 case MONO_NATIVE_FUNC:
2432 return g_strdup ("method");
2433 case MONO_NATIVE_ASANY:
2434 return g_strdup ("as any");
2435 case MONO_NATIVE_LPARRAY:
2436 return g_strdup ("[]");
2437 case MONO_NATIVE_LPSTRUCT:
2438 return g_strdup ("lpstruct");
2439 case MONO_NATIVE_CUSTOM:
2440 return g_strdup ("custom");
2441 case MONO_NATIVE_ERROR:
2442 return g_strdup ("error");
2444 return g_strdup ("unknown");
2449 init_key_table (void)
2451 key_table = g_hash_table_new (g_str_hash, g_str_equal);
2453 g_hash_table_insert (key_table, (char *) "9", GINT_TO_POINTER (TRUE));
2454 g_hash_table_insert (key_table, (char *) "abstract", GINT_TO_POINTER (TRUE));
2455 g_hash_table_insert (key_table, (char *) "add", GINT_TO_POINTER (TRUE));
2456 g_hash_table_insert (key_table, (char *) "add.ovf", GINT_TO_POINTER (TRUE));
2457 g_hash_table_insert (key_table, (char *) "add.ovf.un", GINT_TO_POINTER (TRUE));
2458 g_hash_table_insert (key_table, (char *) "algorithm", GINT_TO_POINTER (TRUE));
2459 g_hash_table_insert (key_table, (char *) "alignment", GINT_TO_POINTER (TRUE));
2460 g_hash_table_insert (key_table, (char *) "and", GINT_TO_POINTER (TRUE));
2461 g_hash_table_insert (key_table, (char *) "ansi", GINT_TO_POINTER (TRUE));
2462 g_hash_table_insert (key_table, (char *) "any", GINT_TO_POINTER (TRUE));
2463 g_hash_table_insert (key_table, (char *) "arglist", GINT_TO_POINTER (TRUE));
2464 g_hash_table_insert (key_table, (char *) "array", GINT_TO_POINTER (TRUE));
2465 g_hash_table_insert (key_table, (char *) "as", GINT_TO_POINTER (TRUE));
2466 g_hash_table_insert (key_table, (char *) "assembly", GINT_TO_POINTER (TRUE));
2467 g_hash_table_insert (key_table, (char *) "assert", GINT_TO_POINTER (TRUE));
2468 g_hash_table_insert (key_table, (char *) "at", GINT_TO_POINTER (TRUE));
2469 g_hash_table_insert (key_table, (char *) "autochar", GINT_TO_POINTER (TRUE));
2470 g_hash_table_insert (key_table, (char *) "auto", GINT_TO_POINTER (TRUE));
2471 g_hash_table_insert (key_table, (char *) "beforefieldinit", GINT_TO_POINTER (TRUE));
2472 g_hash_table_insert (key_table, (char *) "beq", GINT_TO_POINTER (TRUE));
2473 g_hash_table_insert (key_table, (char *) "beq.s", GINT_TO_POINTER (TRUE));
2474 g_hash_table_insert (key_table, (char *) "bge", GINT_TO_POINTER (TRUE));
2475 g_hash_table_insert (key_table, (char *) "bge.s", GINT_TO_POINTER (TRUE));
2476 g_hash_table_insert (key_table, (char *) "bge.un", GINT_TO_POINTER (TRUE));
2477 g_hash_table_insert (key_table, (char *) "bge.un.s", GINT_TO_POINTER (TRUE));
2478 g_hash_table_insert (key_table, (char *) "bgt", GINT_TO_POINTER (TRUE));
2479 g_hash_table_insert (key_table, (char *) "bgt.s", GINT_TO_POINTER (TRUE));
2480 g_hash_table_insert (key_table, (char *) "bgt.un", GINT_TO_POINTER (TRUE));
2481 g_hash_table_insert (key_table, (char *) "bgt.un.s", GINT_TO_POINTER (TRUE));
2482 g_hash_table_insert (key_table, (char *) "ble", GINT_TO_POINTER (TRUE));
2483 g_hash_table_insert (key_table, (char *) "ble.s", GINT_TO_POINTER (TRUE));
2484 g_hash_table_insert (key_table, (char *) "ble.un", GINT_TO_POINTER (TRUE));
2485 g_hash_table_insert (key_table, (char *) "ble.un.s", GINT_TO_POINTER (TRUE));
2486 g_hash_table_insert (key_table, (char *) "blob", GINT_TO_POINTER (TRUE));
2487 g_hash_table_insert (key_table, (char *) "blob_object", GINT_TO_POINTER (TRUE));
2488 g_hash_table_insert (key_table, (char *) "blt", GINT_TO_POINTER (TRUE));
2489 g_hash_table_insert (key_table, (char *) "blt.s", GINT_TO_POINTER (TRUE));
2490 g_hash_table_insert (key_table, (char *) "blt.un", GINT_TO_POINTER (TRUE));
2491 g_hash_table_insert (key_table, (char *) "blt.un.s", GINT_TO_POINTER (TRUE));
2492 g_hash_table_insert (key_table, (char *) "bne.un", GINT_TO_POINTER (TRUE));
2493 g_hash_table_insert (key_table, (char *) "bne.un.s", GINT_TO_POINTER (TRUE));
2494 g_hash_table_insert (key_table, (char *) "bool", GINT_TO_POINTER (TRUE));
2495 g_hash_table_insert (key_table, (char *) "box", GINT_TO_POINTER (TRUE));
2496 g_hash_table_insert (key_table, (char *) "break", GINT_TO_POINTER (TRUE));
2497 g_hash_table_insert (key_table, (char *) "brfalse", GINT_TO_POINTER (TRUE));
2498 g_hash_table_insert (key_table, (char *) "brfalse.s", GINT_TO_POINTER (TRUE));
2499 g_hash_table_insert (key_table, (char *) "br", GINT_TO_POINTER (TRUE));
2500 g_hash_table_insert (key_table, (char *) "brinst", GINT_TO_POINTER (TRUE));
2501 g_hash_table_insert (key_table, (char *) "brinst.s", GINT_TO_POINTER (TRUE));
2502 g_hash_table_insert (key_table, (char *) "brnull", GINT_TO_POINTER (TRUE));
2503 g_hash_table_insert (key_table, (char *) "brnull.s", GINT_TO_POINTER (TRUE));
2504 g_hash_table_insert (key_table, (char *) "br.s", GINT_TO_POINTER (TRUE));
2505 g_hash_table_insert (key_table, (char *) "brtrue", GINT_TO_POINTER (TRUE));
2506 g_hash_table_insert (key_table, (char *) "brtrue.s", GINT_TO_POINTER (TRUE));
2507 g_hash_table_insert (key_table, (char *) "brzero", GINT_TO_POINTER (TRUE));
2508 g_hash_table_insert (key_table, (char *) "brzero.s", GINT_TO_POINTER (TRUE));
2509 g_hash_table_insert (key_table, (char *) "bstr", GINT_TO_POINTER (TRUE));
2510 g_hash_table_insert (key_table, (char *) "bytearray", GINT_TO_POINTER (TRUE));
2511 g_hash_table_insert (key_table, (char *) "byvalstr", GINT_TO_POINTER (TRUE));
2512 g_hash_table_insert (key_table, (char *) "call", GINT_TO_POINTER (TRUE));
2513 g_hash_table_insert (key_table, (char *) "calli", GINT_TO_POINTER (TRUE));
2514 g_hash_table_insert (key_table, (char *) "callmostderived", GINT_TO_POINTER (TRUE));
2515 g_hash_table_insert (key_table, (char *) "callvirt", GINT_TO_POINTER (TRUE));
2516 g_hash_table_insert (key_table, (char *) "carray", GINT_TO_POINTER (TRUE));
2517 g_hash_table_insert (key_table, (char *) "castclass", GINT_TO_POINTER (TRUE));
2518 g_hash_table_insert (key_table, (char *) "catch", GINT_TO_POINTER (TRUE));
2519 g_hash_table_insert (key_table, (char *) "cdecl", GINT_TO_POINTER (TRUE));
2520 g_hash_table_insert (key_table, (char *) "ceq", GINT_TO_POINTER (TRUE));
2521 g_hash_table_insert (key_table, (char *) "cf", GINT_TO_POINTER (TRUE));
2522 g_hash_table_insert (key_table, (char *) "cgt", GINT_TO_POINTER (TRUE));
2523 g_hash_table_insert (key_table, (char *) "cgt.un", GINT_TO_POINTER (TRUE));
2524 g_hash_table_insert (key_table, (char *) "char", GINT_TO_POINTER (TRUE));
2525 g_hash_table_insert (key_table, (char *) "cil", GINT_TO_POINTER (TRUE));
2526 g_hash_table_insert (key_table, (char *) "ckfinite", GINT_TO_POINTER (TRUE));
2527 g_hash_table_insert (key_table, (char *) "class", GINT_TO_POINTER (TRUE));
2528 g_hash_table_insert (key_table, (char *) "clsid", GINT_TO_POINTER (TRUE));
2529 g_hash_table_insert (key_table, (char *) "clt", GINT_TO_POINTER (TRUE));
2530 g_hash_table_insert (key_table, (char *) "clt.un", GINT_TO_POINTER (TRUE));
2531 g_hash_table_insert (key_table, (char *) "Compilercontrolled", GINT_TO_POINTER (TRUE));
2532 g_hash_table_insert (key_table, (char *) "const", GINT_TO_POINTER (TRUE));
2533 g_hash_table_insert (key_table, (char *) "conv.i1", GINT_TO_POINTER (TRUE));
2534 g_hash_table_insert (key_table, (char *) "conv.i2", GINT_TO_POINTER (TRUE));
2535 g_hash_table_insert (key_table, (char *) "conv.i4", GINT_TO_POINTER (TRUE));
2536 g_hash_table_insert (key_table, (char *) "conv.i8", GINT_TO_POINTER (TRUE));
2537 g_hash_table_insert (key_table, (char *) "conv.i", GINT_TO_POINTER (TRUE));
2538 g_hash_table_insert (key_table, (char *) "conv.ovf.i1", GINT_TO_POINTER (TRUE));
2539 g_hash_table_insert (key_table, (char *) "conv.ovf.i1.un", GINT_TO_POINTER (TRUE));
2540 g_hash_table_insert (key_table, (char *) "conv.ovf.i2", GINT_TO_POINTER (TRUE));
2541 g_hash_table_insert (key_table, (char *) "conv.ovf.i2.un", GINT_TO_POINTER (TRUE));
2542 g_hash_table_insert (key_table, (char *) "conv.ovf.i4", GINT_TO_POINTER (TRUE));
2543 g_hash_table_insert (key_table, (char *) "conv.ovf.i4.un", GINT_TO_POINTER (TRUE));
2544 g_hash_table_insert (key_table, (char *) "conv.ovf.i8", GINT_TO_POINTER (TRUE));
2545 g_hash_table_insert (key_table, (char *) "conv.ovf.i8.un", GINT_TO_POINTER (TRUE));
2546 g_hash_table_insert (key_table, (char *) "conv.ovf.i", GINT_TO_POINTER (TRUE));
2547 g_hash_table_insert (key_table, (char *) "conv.ovf.i.un", GINT_TO_POINTER (TRUE));
2548 g_hash_table_insert (key_table, (char *) "conv.ovf.u1", GINT_TO_POINTER (TRUE));
2549 g_hash_table_insert (key_table, (char *) "conv.ovf.u1.un", GINT_TO_POINTER (TRUE));
2550 g_hash_table_insert (key_table, (char *) "conv.ovf.u2", GINT_TO_POINTER (TRUE));
2551 g_hash_table_insert (key_table, (char *) "conv.ovf.u2.un", GINT_TO_POINTER (TRUE));
2552 g_hash_table_insert (key_table, (char *) "conv.ovf.u4", GINT_TO_POINTER (TRUE));
2553 g_hash_table_insert (key_table, (char *) "conv.ovf.u4.un", GINT_TO_POINTER (TRUE));
2554 g_hash_table_insert (key_table, (char *) "conv.ovf.u8", GINT_TO_POINTER (TRUE));
2555 g_hash_table_insert (key_table, (char *) "conv.ovf.u8.un", GINT_TO_POINTER (TRUE));
2556 g_hash_table_insert (key_table, (char *) "conv.ovf.u", GINT_TO_POINTER (TRUE));
2557 g_hash_table_insert (key_table, (char *) "conv.ovf.u.un", GINT_TO_POINTER (TRUE));
2558 g_hash_table_insert (key_table, (char *) "conv.r4", GINT_TO_POINTER (TRUE));
2559 g_hash_table_insert (key_table, (char *) "conv.r8", GINT_TO_POINTER (TRUE));
2560 g_hash_table_insert (key_table, (char *) "conv.r.un", GINT_TO_POINTER (TRUE));
2561 g_hash_table_insert (key_table, (char *) "conv.u1", GINT_TO_POINTER (TRUE));
2562 g_hash_table_insert (key_table, (char *) "conv.u2", GINT_TO_POINTER (TRUE));
2563 g_hash_table_insert (key_table, (char *) "conv.u4", GINT_TO_POINTER (TRUE));
2564 g_hash_table_insert (key_table, (char *) "conv.u8", GINT_TO_POINTER (TRUE));
2565 g_hash_table_insert (key_table, (char *) "conv.u", GINT_TO_POINTER (TRUE));
2566 g_hash_table_insert (key_table, (char *) "cpblk", GINT_TO_POINTER (TRUE));
2567 g_hash_table_insert (key_table, (char *) "cpobj", GINT_TO_POINTER (TRUE));
2568 g_hash_table_insert (key_table, (char *) "currency", GINT_TO_POINTER (TRUE));
2569 g_hash_table_insert (key_table, (char *) "custom", GINT_TO_POINTER (TRUE));
2570 g_hash_table_insert (key_table, (char *) "date", GINT_TO_POINTER (TRUE));
2571 g_hash_table_insert (key_table, (char *) "decimal", GINT_TO_POINTER (TRUE));
2572 g_hash_table_insert (key_table, (char *) "default", GINT_TO_POINTER (TRUE));
2573 g_hash_table_insert (key_table, (char *) "demand", GINT_TO_POINTER (TRUE));
2574 g_hash_table_insert (key_table, (char *) "deny", GINT_TO_POINTER (TRUE));
2575 g_hash_table_insert (key_table, (char *) "div", GINT_TO_POINTER (TRUE));
2576 g_hash_table_insert (key_table, (char *) "div.un", GINT_TO_POINTER (TRUE));
2577 g_hash_table_insert (key_table, (char *) "dup", GINT_TO_POINTER (TRUE));
2578 g_hash_table_insert (key_table, (char *) "endfault", GINT_TO_POINTER (TRUE));
2579 g_hash_table_insert (key_table, (char *) "endfilter", GINT_TO_POINTER (TRUE));
2580 g_hash_table_insert (key_table, (char *) "endfinally", GINT_TO_POINTER (TRUE));
2581 g_hash_table_insert (key_table, (char *) "endmac", GINT_TO_POINTER (TRUE));
2582 g_hash_table_insert (key_table, (char *) "enum", GINT_TO_POINTER (TRUE));
2583 g_hash_table_insert (key_table, (char *) "error", GINT_TO_POINTER (TRUE));
2584 g_hash_table_insert (key_table, (char *) "explicit", GINT_TO_POINTER (TRUE));
2585 g_hash_table_insert (key_table, (char *) "extends", GINT_TO_POINTER (TRUE));
2586 g_hash_table_insert (key_table, (char *) "extern", GINT_TO_POINTER (TRUE));
2587 g_hash_table_insert (key_table, (char *) "false", GINT_TO_POINTER (TRUE));
2588 g_hash_table_insert (key_table, (char *) "famandassem", GINT_TO_POINTER (TRUE));
2589 g_hash_table_insert (key_table, (char *) "family", GINT_TO_POINTER (TRUE));
2590 g_hash_table_insert (key_table, (char *) "famorassem", GINT_TO_POINTER (TRUE));
2591 g_hash_table_insert (key_table, (char *) "fastcall", GINT_TO_POINTER (TRUE));
2592 g_hash_table_insert (key_table, (char *) "fault", GINT_TO_POINTER (TRUE));
2593 g_hash_table_insert (key_table, (char *) "field", GINT_TO_POINTER (TRUE));
2594 g_hash_table_insert (key_table, (char *) "filetime", GINT_TO_POINTER (TRUE));
2595 g_hash_table_insert (key_table, (char *) "filter", GINT_TO_POINTER (TRUE));
2596 g_hash_table_insert (key_table, (char *) "final", GINT_TO_POINTER (TRUE));
2597 g_hash_table_insert (key_table, (char *) "finally", GINT_TO_POINTER (TRUE));
2598 g_hash_table_insert (key_table, (char *) "fixed", GINT_TO_POINTER (TRUE));
2599 g_hash_table_insert (key_table, (char *) "float32", GINT_TO_POINTER (TRUE));
2600 g_hash_table_insert (key_table, (char *) "float64", GINT_TO_POINTER (TRUE));
2601 g_hash_table_insert (key_table, (char *) "float", GINT_TO_POINTER (TRUE));
2602 g_hash_table_insert (key_table, (char *) "forwardref", GINT_TO_POINTER (TRUE));
2603 g_hash_table_insert (key_table, (char *) "fromunmanaged", GINT_TO_POINTER (TRUE));
2604 g_hash_table_insert (key_table, (char *) "handler", GINT_TO_POINTER (TRUE));
2605 g_hash_table_insert (key_table, (char *) "hidebysig", GINT_TO_POINTER (TRUE));
2606 g_hash_table_insert (key_table, (char *) "hresult", GINT_TO_POINTER (TRUE));
2607 g_hash_table_insert (key_table, (char *) "idispatch", GINT_TO_POINTER (TRUE));
2608 g_hash_table_insert (key_table, (char *) "il", GINT_TO_POINTER (TRUE));
2609 g_hash_table_insert (key_table, (char *) "illegal", GINT_TO_POINTER (TRUE));
2610 g_hash_table_insert (key_table, (char *) "implements", GINT_TO_POINTER (TRUE));
2611 g_hash_table_insert (key_table, (char *) "implicitcom", GINT_TO_POINTER (TRUE));
2612 g_hash_table_insert (key_table, (char *) "implicitres", GINT_TO_POINTER (TRUE));
2613 g_hash_table_insert (key_table, (char *) "import", GINT_TO_POINTER (TRUE));
2614 g_hash_table_insert (key_table, (char *) "in", GINT_TO_POINTER (TRUE));
2615 g_hash_table_insert (key_table, (char *) "inheritcheck", GINT_TO_POINTER (TRUE));
2616 g_hash_table_insert (key_table, (char *) "initblk", GINT_TO_POINTER (TRUE));
2617 g_hash_table_insert (key_table, (char *) "init", GINT_TO_POINTER (TRUE));
2618 g_hash_table_insert (key_table, (char *) "initobj", GINT_TO_POINTER (TRUE));
2619 g_hash_table_insert (key_table, (char *) "initonly", GINT_TO_POINTER (TRUE));
2620 g_hash_table_insert (key_table, (char *) "instance", GINT_TO_POINTER (TRUE));
2621 g_hash_table_insert (key_table, (char *) "int16", GINT_TO_POINTER (TRUE));
2622 g_hash_table_insert (key_table, (char *) "int32", GINT_TO_POINTER (TRUE));
2623 g_hash_table_insert (key_table, (char *) "int64", GINT_TO_POINTER (TRUE));
2624 g_hash_table_insert (key_table, (char *) "int8", GINT_TO_POINTER (TRUE));
2625 g_hash_table_insert (key_table, (char *) "interface", GINT_TO_POINTER (TRUE));
2626 g_hash_table_insert (key_table, (char *) "internalcall", GINT_TO_POINTER (TRUE));
2627 g_hash_table_insert (key_table, (char *) "int", GINT_TO_POINTER (TRUE));
2628 g_hash_table_insert (key_table, (char *) "isinst", GINT_TO_POINTER (TRUE));
2629 g_hash_table_insert (key_table, (char *) "iunknown", GINT_TO_POINTER (TRUE));
2630 g_hash_table_insert (key_table, (char *) "jmp", GINT_TO_POINTER (TRUE));
2631 g_hash_table_insert (key_table, (char *) "lasterr", GINT_TO_POINTER (TRUE));
2632 g_hash_table_insert (key_table, (char *) "lcid", GINT_TO_POINTER (TRUE));
2633 g_hash_table_insert (key_table, (char *) "ldarg.0", GINT_TO_POINTER (TRUE));
2634 g_hash_table_insert (key_table, (char *) "ldarg.1", GINT_TO_POINTER (TRUE));
2635 g_hash_table_insert (key_table, (char *) "ldarg.2", GINT_TO_POINTER (TRUE));
2636 g_hash_table_insert (key_table, (char *) "ldarg.3", GINT_TO_POINTER (TRUE));
2637 g_hash_table_insert (key_table, (char *) "ldarga", GINT_TO_POINTER (TRUE));
2638 g_hash_table_insert (key_table, (char *) "ldarga.s", GINT_TO_POINTER (TRUE));
2639 g_hash_table_insert (key_table, (char *) "ldarg", GINT_TO_POINTER (TRUE));
2640 g_hash_table_insert (key_table, (char *) "ldarg.s", GINT_TO_POINTER (TRUE));
2641 g_hash_table_insert (key_table, (char *) "ldc.i4.0", GINT_TO_POINTER (TRUE));
2642 g_hash_table_insert (key_table, (char *) "ldc.i4.1", GINT_TO_POINTER (TRUE));
2643 g_hash_table_insert (key_table, (char *) "ldc.i4.2", GINT_TO_POINTER (TRUE));
2644 g_hash_table_insert (key_table, (char *) "ldc.i4.3", GINT_TO_POINTER (TRUE));
2645 g_hash_table_insert (key_table, (char *) "ldc.i4.4", GINT_TO_POINTER (TRUE));
2646 g_hash_table_insert (key_table, (char *) "ldc.i4.5", GINT_TO_POINTER (TRUE));
2647 g_hash_table_insert (key_table, (char *) "ldc.i4.6", GINT_TO_POINTER (TRUE));
2648 g_hash_table_insert (key_table, (char *) "ldc.i4.7", GINT_TO_POINTER (TRUE));
2649 g_hash_table_insert (key_table, (char *) "ldc.i4.8", GINT_TO_POINTER (TRUE));
2650 g_hash_table_insert (key_table, (char *) "ldc.i4", GINT_TO_POINTER (TRUE));
2651 g_hash_table_insert (key_table, (char *) "ldc.i4.m1", GINT_TO_POINTER (TRUE));
2652 g_hash_table_insert (key_table, (char *) "ldc.i4.M1", GINT_TO_POINTER (TRUE));
2653 g_hash_table_insert (key_table, (char *) "ldc.i4.s", GINT_TO_POINTER (TRUE));
2654 g_hash_table_insert (key_table, (char *) "ldc.i8", GINT_TO_POINTER (TRUE));
2655 g_hash_table_insert (key_table, (char *) "ldc.r4", GINT_TO_POINTER (TRUE));
2656 g_hash_table_insert (key_table, (char *) "ldc.r8", GINT_TO_POINTER (TRUE));
2657 g_hash_table_insert (key_table, (char *) "ldelem", GINT_TO_POINTER (TRUE));
2658 g_hash_table_insert (key_table, (char *) "ldelema", GINT_TO_POINTER (TRUE));
2659 g_hash_table_insert (key_table, (char *) "ldelem.i1", GINT_TO_POINTER (TRUE));
2660 g_hash_table_insert (key_table, (char *) "ldelem.i2", GINT_TO_POINTER (TRUE));
2661 g_hash_table_insert (key_table, (char *) "ldelem.i4", GINT_TO_POINTER (TRUE));
2662 g_hash_table_insert (key_table, (char *) "ldelem.i8", GINT_TO_POINTER (TRUE));
2663 g_hash_table_insert (key_table, (char *) "ldelem.i", GINT_TO_POINTER (TRUE));
2664 g_hash_table_insert (key_table, (char *) "ldelem.r4", GINT_TO_POINTER (TRUE));
2665 g_hash_table_insert (key_table, (char *) "ldelem.r8", GINT_TO_POINTER (TRUE));
2666 g_hash_table_insert (key_table, (char *) "ldelem.ref", GINT_TO_POINTER (TRUE));
2667 g_hash_table_insert (key_table, (char *) "ldelem.u1", GINT_TO_POINTER (TRUE));
2668 g_hash_table_insert (key_table, (char *) "ldelem.u2", GINT_TO_POINTER (TRUE));
2669 g_hash_table_insert (key_table, (char *) "ldelem.u4", GINT_TO_POINTER (TRUE));
2670 g_hash_table_insert (key_table, (char *) "ldelem.u8", GINT_TO_POINTER (TRUE));
2671 g_hash_table_insert (key_table, (char *) "ldflda", GINT_TO_POINTER (TRUE));
2672 g_hash_table_insert (key_table, (char *) "ldfld", GINT_TO_POINTER (TRUE));
2673 g_hash_table_insert (key_table, (char *) "ldftn", GINT_TO_POINTER (TRUE));
2674 g_hash_table_insert (key_table, (char *) "ldind.i1", GINT_TO_POINTER (TRUE));
2675 g_hash_table_insert (key_table, (char *) "ldind.i2", GINT_TO_POINTER (TRUE));
2676 g_hash_table_insert (key_table, (char *) "ldind.i4", GINT_TO_POINTER (TRUE));
2677 g_hash_table_insert (key_table, (char *) "ldind.i8", GINT_TO_POINTER (TRUE));
2678 g_hash_table_insert (key_table, (char *) "ldind.i", GINT_TO_POINTER (TRUE));
2679 g_hash_table_insert (key_table, (char *) "ldind.r4", GINT_TO_POINTER (TRUE));
2680 g_hash_table_insert (key_table, (char *) "ldind.r8", GINT_TO_POINTER (TRUE));
2681 g_hash_table_insert (key_table, (char *) "ldind.ref", GINT_TO_POINTER (TRUE));
2682 g_hash_table_insert (key_table, (char *) "ldind.u1", GINT_TO_POINTER (TRUE));
2683 g_hash_table_insert (key_table, (char *) "ldind.u2", GINT_TO_POINTER (TRUE));
2684 g_hash_table_insert (key_table, (char *) "ldind.u4", GINT_TO_POINTER (TRUE));
2685 g_hash_table_insert (key_table, (char *) "ldind.u8", GINT_TO_POINTER (TRUE));
2686 g_hash_table_insert (key_table, (char *) "ldlen", GINT_TO_POINTER (TRUE));
2687 g_hash_table_insert (key_table, (char *) "ldloc.0", GINT_TO_POINTER (TRUE));
2688 g_hash_table_insert (key_table, (char *) "ldloc.1", GINT_TO_POINTER (TRUE));
2689 g_hash_table_insert (key_table, (char *) "ldloc.2", GINT_TO_POINTER (TRUE));
2690 g_hash_table_insert (key_table, (char *) "ldloc.3", GINT_TO_POINTER (TRUE));
2691 g_hash_table_insert (key_table, (char *) "ldloca", GINT_TO_POINTER (TRUE));
2692 g_hash_table_insert (key_table, (char *) "ldloca.s", GINT_TO_POINTER (TRUE));
2693 g_hash_table_insert (key_table, (char *) "ldloc", GINT_TO_POINTER (TRUE));
2694 g_hash_table_insert (key_table, (char *) "ldloc.s", GINT_TO_POINTER (TRUE));
2695 g_hash_table_insert (key_table, (char *) "ldnull", GINT_TO_POINTER (TRUE));
2696 g_hash_table_insert (key_table, (char *) "ldobj", GINT_TO_POINTER (TRUE));
2697 g_hash_table_insert (key_table, (char *) "ldsflda", GINT_TO_POINTER (TRUE));
2698 g_hash_table_insert (key_table, (char *) "ldsfld", GINT_TO_POINTER (TRUE));
2699 g_hash_table_insert (key_table, (char *) "ldstr", GINT_TO_POINTER (TRUE));
2700 g_hash_table_insert (key_table, (char *) "ldtoken", GINT_TO_POINTER (TRUE));
2701 g_hash_table_insert (key_table, (char *) "ldvirtftn", GINT_TO_POINTER (TRUE));
2702 g_hash_table_insert (key_table, (char *) "leave", GINT_TO_POINTER (TRUE));
2703 g_hash_table_insert (key_table, (char *) "leave.s", GINT_TO_POINTER (TRUE));
2704 g_hash_table_insert (key_table, (char *) "linkcheck", GINT_TO_POINTER (TRUE));
2705 g_hash_table_insert (key_table, (char *) "literal", GINT_TO_POINTER (TRUE));
2706 g_hash_table_insert (key_table, (char *) "localloc", GINT_TO_POINTER (TRUE));
2707 g_hash_table_insert (key_table, (char *) "lpstr", GINT_TO_POINTER (TRUE));
2708 g_hash_table_insert (key_table, (char *) "lpstruct", GINT_TO_POINTER (TRUE));
2709 g_hash_table_insert (key_table, (char *) "lptstr", GINT_TO_POINTER (TRUE));
2710 g_hash_table_insert (key_table, (char *) "lpvoid", GINT_TO_POINTER (TRUE));
2711 g_hash_table_insert (key_table, (char *) "lpwstr", GINT_TO_POINTER (TRUE));
2712 g_hash_table_insert (key_table, (char *) "managed", GINT_TO_POINTER (TRUE));
2713 g_hash_table_insert (key_table, (char *) "marshal", GINT_TO_POINTER (TRUE));
2714 g_hash_table_insert (key_table, (char *) "method", GINT_TO_POINTER (TRUE));
2715 g_hash_table_insert (key_table, (char *) "mkrefany", GINT_TO_POINTER (TRUE));
2716 g_hash_table_insert (key_table, (char *) "modopt", GINT_TO_POINTER (TRUE));
2717 g_hash_table_insert (key_table, (char *) "modreq", GINT_TO_POINTER (TRUE));
2718 g_hash_table_insert (key_table, (char *) "mul", GINT_TO_POINTER (TRUE));
2719 g_hash_table_insert (key_table, (char *) "mul.ovf", GINT_TO_POINTER (TRUE));
2720 g_hash_table_insert (key_table, (char *) "mul.ovf.un", GINT_TO_POINTER (TRUE));
2721 g_hash_table_insert (key_table, (char *) "native", GINT_TO_POINTER (TRUE));
2722 g_hash_table_insert (key_table, (char *) "neg", GINT_TO_POINTER (TRUE));
2723 g_hash_table_insert (key_table, (char *) "nested", GINT_TO_POINTER (TRUE));
2724 g_hash_table_insert (key_table, (char *) "newarr", GINT_TO_POINTER (TRUE));
2725 g_hash_table_insert (key_table, (char *) "newobj", GINT_TO_POINTER (TRUE));
2726 g_hash_table_insert (key_table, (char *) "newslot", GINT_TO_POINTER (TRUE));
2727 g_hash_table_insert (key_table, (char *) "noappdomain", GINT_TO_POINTER (TRUE));
2728 g_hash_table_insert (key_table, (char *) "noinlining", GINT_TO_POINTER (TRUE));
2729 g_hash_table_insert (key_table, (char *) "nomachine", GINT_TO_POINTER (TRUE));
2730 g_hash_table_insert (key_table, (char *) "nomangle", GINT_TO_POINTER (TRUE));
2731 g_hash_table_insert (key_table, (char *) "nometadata", GINT_TO_POINTER (TRUE));
2732 g_hash_table_insert (key_table, (char *) "noncasdemand", GINT_TO_POINTER (TRUE));
2733 g_hash_table_insert (key_table, (char *) "noncasinheritance", GINT_TO_POINTER (TRUE));
2734 g_hash_table_insert (key_table, (char *) "noncaslinkdemand", GINT_TO_POINTER (TRUE));
2735 g_hash_table_insert (key_table, (char *) "nop", GINT_TO_POINTER (TRUE));
2736 g_hash_table_insert (key_table, (char *) "noprocess", GINT_TO_POINTER (TRUE));
2737 g_hash_table_insert (key_table, (char *) "not", GINT_TO_POINTER (TRUE));
2738 g_hash_table_insert (key_table, (char *) "not_in_gc_heap", GINT_TO_POINTER (TRUE));
2739 g_hash_table_insert (key_table, (char *) "notremotable", GINT_TO_POINTER (TRUE));
2740 g_hash_table_insert (key_table, (char *) "notserialized", GINT_TO_POINTER (TRUE));
2741 g_hash_table_insert (key_table, (char *) "null", GINT_TO_POINTER (TRUE));
2742 g_hash_table_insert (key_table, (char *) "nullref", GINT_TO_POINTER (TRUE));
2743 g_hash_table_insert (key_table, (char *) "object", GINT_TO_POINTER (TRUE));
2744 g_hash_table_insert (key_table, (char *) "objectref", GINT_TO_POINTER (TRUE));
2745 g_hash_table_insert (key_table, (char *) "opt", GINT_TO_POINTER (TRUE));
2746 g_hash_table_insert (key_table, (char *) "optil", GINT_TO_POINTER (TRUE));
2747 g_hash_table_insert (key_table, (char *) "or", GINT_TO_POINTER (TRUE));
2748 g_hash_table_insert (key_table, (char *) "out", GINT_TO_POINTER (TRUE));
2749 g_hash_table_insert (key_table, (char *) "permitonly", GINT_TO_POINTER (TRUE));
2750 g_hash_table_insert (key_table, (char *) "pinned", GINT_TO_POINTER (TRUE));
2751 g_hash_table_insert (key_table, (char *) "pinvokeimpl", GINT_TO_POINTER (TRUE));
2752 g_hash_table_insert (key_table, (char *) "pop", GINT_TO_POINTER (TRUE));
2753 g_hash_table_insert (key_table, (char *) "prefix1", GINT_TO_POINTER (TRUE));
2754 g_hash_table_insert (key_table, (char *) "prefix2", GINT_TO_POINTER (TRUE));
2755 g_hash_table_insert (key_table, (char *) "prefix3", GINT_TO_POINTER (TRUE));
2756 g_hash_table_insert (key_table, (char *) "prefix4", GINT_TO_POINTER (TRUE));
2757 g_hash_table_insert (key_table, (char *) "prefix5", GINT_TO_POINTER (TRUE));
2758 g_hash_table_insert (key_table, (char *) "prefix6", GINT_TO_POINTER (TRUE));
2759 g_hash_table_insert (key_table, (char *) "prefix7", GINT_TO_POINTER (TRUE));
2760 g_hash_table_insert (key_table, (char *) "prefixref", GINT_TO_POINTER (TRUE));
2761 g_hash_table_insert (key_table, (char *) "prejitdeny", GINT_TO_POINTER (TRUE));
2762 g_hash_table_insert (key_table, (char *) "prejitgrant", GINT_TO_POINTER (TRUE));
2763 g_hash_table_insert (key_table, (char *) "preservesig", GINT_TO_POINTER (TRUE));
2764 g_hash_table_insert (key_table, (char *) "private", GINT_TO_POINTER (TRUE));
2765 g_hash_table_insert (key_table, (char *) "privatescope", GINT_TO_POINTER (TRUE));
2766 g_hash_table_insert (key_table, (char *) "protected", GINT_TO_POINTER (TRUE));
2767 g_hash_table_insert (key_table, (char *) "public", GINT_TO_POINTER (TRUE));
2768 g_hash_table_insert (key_table, (char *) "readonly", GINT_TO_POINTER (TRUE));
2769 g_hash_table_insert (key_table, (char *) "record", GINT_TO_POINTER (TRUE));
2770 g_hash_table_insert (key_table, (char *) "refany", GINT_TO_POINTER (TRUE));
2771 g_hash_table_insert (key_table, (char *) "refanytype", GINT_TO_POINTER (TRUE));
2772 g_hash_table_insert (key_table, (char *) "refanyval", GINT_TO_POINTER (TRUE));
2773 g_hash_table_insert (key_table, (char *) "rem", GINT_TO_POINTER (TRUE));
2774 g_hash_table_insert (key_table, (char *) "rem.un", GINT_TO_POINTER (TRUE));
2775 g_hash_table_insert (key_table, (char *) "reqmin", GINT_TO_POINTER (TRUE));
2776 g_hash_table_insert (key_table, (char *) "reqopt", GINT_TO_POINTER (TRUE));
2777 g_hash_table_insert (key_table, (char *) "reqrefuse", GINT_TO_POINTER (TRUE));
2778 g_hash_table_insert (key_table, (char *) "reqsecobj", GINT_TO_POINTER (TRUE));
2779 g_hash_table_insert (key_table, (char *) "request", GINT_TO_POINTER (TRUE));
2780 g_hash_table_insert (key_table, (char *) "ret", GINT_TO_POINTER (TRUE));
2781 g_hash_table_insert (key_table, (char *) "rethrow", GINT_TO_POINTER (TRUE));
2782 g_hash_table_insert (key_table, (char *) "retval", GINT_TO_POINTER (TRUE));
2783 g_hash_table_insert (key_table, (char *) "rtspecialname", GINT_TO_POINTER (TRUE));
2784 g_hash_table_insert (key_table, (char *) "runtime", GINT_TO_POINTER (TRUE));
2785 g_hash_table_insert (key_table, (char *) "safearray", GINT_TO_POINTER (TRUE));
2786 g_hash_table_insert (key_table, (char *) "sealed", GINT_TO_POINTER (TRUE));
2787 g_hash_table_insert (key_table, (char *) "sequential", GINT_TO_POINTER (TRUE));
2788 g_hash_table_insert (key_table, (char *) "serializable", GINT_TO_POINTER (TRUE));
2789 g_hash_table_insert (key_table, (char *) "shl", GINT_TO_POINTER (TRUE));
2790 g_hash_table_insert (key_table, (char *) "shr", GINT_TO_POINTER (TRUE));
2791 g_hash_table_insert (key_table, (char *) "shr.un", GINT_TO_POINTER (TRUE));
2792 g_hash_table_insert (key_table, (char *) "sizeof", GINT_TO_POINTER (TRUE));
2793 g_hash_table_insert (key_table, (char *) "special", GINT_TO_POINTER (TRUE));
2794 g_hash_table_insert (key_table, (char *) "specialname", GINT_TO_POINTER (TRUE));
2795 g_hash_table_insert (key_table, (char *) "starg", GINT_TO_POINTER (TRUE));
2796 g_hash_table_insert (key_table, (char *) "starg.s", GINT_TO_POINTER (TRUE));
2797 g_hash_table_insert (key_table, (char *) "static", GINT_TO_POINTER (TRUE));
2798 g_hash_table_insert (key_table, (char *) "stdcall", GINT_TO_POINTER (TRUE));
2799 g_hash_table_insert (key_table, (char *) "stelem", GINT_TO_POINTER (TRUE));
2800 g_hash_table_insert (key_table, (char *) "stelem.i1", GINT_TO_POINTER (TRUE));
2801 g_hash_table_insert (key_table, (char *) "stelem.i2", GINT_TO_POINTER (TRUE));
2802 g_hash_table_insert (key_table, (char *) "stelem.i4", GINT_TO_POINTER (TRUE));
2803 g_hash_table_insert (key_table, (char *) "stelem.i8", GINT_TO_POINTER (TRUE));
2804 g_hash_table_insert (key_table, (char *) "stelem.i", GINT_TO_POINTER (TRUE));
2805 g_hash_table_insert (key_table, (char *) "stelem.r4", GINT_TO_POINTER (TRUE));
2806 g_hash_table_insert (key_table, (char *) "stelem.r8", GINT_TO_POINTER (TRUE));
2807 g_hash_table_insert (key_table, (char *) "stelem.ref", GINT_TO_POINTER (TRUE));
2808 g_hash_table_insert (key_table, (char *) "stfld", GINT_TO_POINTER (TRUE));
2809 g_hash_table_insert (key_table, (char *) "stind.i1", GINT_TO_POINTER (TRUE));
2810 g_hash_table_insert (key_table, (char *) "stind.i2", GINT_TO_POINTER (TRUE));
2811 g_hash_table_insert (key_table, (char *) "stind.i4", GINT_TO_POINTER (TRUE));
2812 g_hash_table_insert (key_table, (char *) "stind.i8", GINT_TO_POINTER (TRUE));
2813 g_hash_table_insert (key_table, (char *) "stind.i", GINT_TO_POINTER (TRUE));
2814 g_hash_table_insert (key_table, (char *) "stind.r4", GINT_TO_POINTER (TRUE));
2815 g_hash_table_insert (key_table, (char *) "stind.r8", GINT_TO_POINTER (TRUE));
2816 g_hash_table_insert (key_table, (char *) "stloc", GINT_TO_POINTER (TRUE));
2817 g_hash_table_insert (key_table, (char *) "stobj", GINT_TO_POINTER (TRUE));
2818 g_hash_table_insert (key_table, (char *) "storage", GINT_TO_POINTER (TRUE));
2819 g_hash_table_insert (key_table, (char *) "stored_object", GINT_TO_POINTER (TRUE));
2820 g_hash_table_insert (key_table, (char *) "streamed_object", GINT_TO_POINTER (TRUE));
2821 g_hash_table_insert (key_table, (char *) "stream", GINT_TO_POINTER (TRUE));
2822 g_hash_table_insert (key_table, (char *) "strict", GINT_TO_POINTER (TRUE));
2823 g_hash_table_insert (key_table, (char *) "string", GINT_TO_POINTER (TRUE));
2824 g_hash_table_insert (key_table, (char *) "struct", GINT_TO_POINTER (TRUE));
2825 g_hash_table_insert (key_table, (char *) "stsfld", GINT_TO_POINTER (TRUE));
2826 g_hash_table_insert (key_table, (char *) "sub", GINT_TO_POINTER (TRUE));
2827 g_hash_table_insert (key_table, (char *) "sub.ovf", GINT_TO_POINTER (TRUE));
2828 g_hash_table_insert (key_table, (char *) "sub.ovf.un", GINT_TO_POINTER (TRUE));
2829 g_hash_table_insert (key_table, (char *) "synchronized", GINT_TO_POINTER (TRUE));
2830 g_hash_table_insert (key_table, (char *) "syschar", GINT_TO_POINTER (TRUE));
2831 g_hash_table_insert (key_table, (char *) "sysstring", GINT_TO_POINTER (TRUE));
2832 g_hash_table_insert (key_table, (char *) "tbstr", GINT_TO_POINTER (TRUE));
2833 g_hash_table_insert (key_table, (char *) "thiscall", GINT_TO_POINTER (TRUE));
2834 g_hash_table_insert (key_table, (char *) "tls", GINT_TO_POINTER (TRUE));
2835 g_hash_table_insert (key_table, (char *) "to", GINT_TO_POINTER (TRUE));
2836 g_hash_table_insert (key_table, (char *) "true", GINT_TO_POINTER (TRUE));
2837 g_hash_table_insert (key_table, (char *) "type", GINT_TO_POINTER (TRUE));
2838 g_hash_table_insert (key_table, (char *) "typedref", GINT_TO_POINTER (TRUE));
2839 g_hash_table_insert (key_table, (char *) "unbox", GINT_TO_POINTER (TRUE));
2840 g_hash_table_insert (key_table, (char *) "unicode", GINT_TO_POINTER (TRUE));
2841 g_hash_table_insert (key_table, (char *) "unmanagedexp", GINT_TO_POINTER (TRUE));
2842 g_hash_table_insert (key_table, (char *) "unmanaged", GINT_TO_POINTER (TRUE));
2843 g_hash_table_insert (key_table, (char *) "unsigned", GINT_TO_POINTER (TRUE));
2844 g_hash_table_insert (key_table, (char *) "userdefined", GINT_TO_POINTER (TRUE));
2845 g_hash_table_insert (key_table, (char *) "value", GINT_TO_POINTER (TRUE));
2846 g_hash_table_insert (key_table, (char *) "valuetype", GINT_TO_POINTER (TRUE));
2847 g_hash_table_insert (key_table, (char *) "vararg", GINT_TO_POINTER (TRUE));
2848 g_hash_table_insert (key_table, (char *) "variant", GINT_TO_POINTER (TRUE));
2849 g_hash_table_insert (key_table, (char *) "vector", GINT_TO_POINTER (TRUE));
2850 g_hash_table_insert (key_table, (char *) "virtual", GINT_TO_POINTER (TRUE));
2851 g_hash_table_insert (key_table, (char *) "void", GINT_TO_POINTER (TRUE));
2852 g_hash_table_insert (key_table, (char *) "wchar", GINT_TO_POINTER (TRUE));
2853 g_hash_table_insert (key_table, (char *) "winapi", GINT_TO_POINTER (TRUE));
2854 g_hash_table_insert (key_table, (char *) "with", GINT_TO_POINTER (TRUE));
2855 g_hash_table_insert (key_table, (char *) "xor", GINT_TO_POINTER (TRUE));
2859 method_dor_to_token (guint32 idx) {
2860 switch (idx & MONO_METHODDEFORREF_MASK) {
2861 case MONO_METHODDEFORREF_METHODDEF:
2862 return MONO_TOKEN_METHOD_DEF | (idx >> MONO_METHODDEFORREF_BITS);
2863 case MONO_METHODDEFORREF_METHODREF:
2864 return MONO_TOKEN_MEMBER_REF | (idx >> MONO_METHODDEFORREF_BITS);
2870 get_method_override (MonoImage *m, guint32 token, MonoGenericContext *context)
2872 MonoTableInfo *t = &m->tables [MONO_TABLE_METHODIMPL];
2875 for (i = 1; i <= t->rows; i++){
2876 guint32 cols [MONO_METHODIMPL_SIZE];
2879 mono_metadata_decode_row (t, i - 1, cols, MONO_METHODIMPL_SIZE);
2881 impl = method_dor_to_token (cols [MONO_METHODIMPL_BODY]);
2882 decl = method_dor_to_token (cols [MONO_METHODIMPL_DECLARATION]);
2885 return get_method_core (m, decl, FALSE, context);