In .:
[mono.git] / mono / metadata / class.h
index f9cae400a45b17138306ece0a9fe5a4d3ad447c3..471967a4ea2cac991e949ed5a8220637677df655 100644 (file)
@@ -5,6 +5,8 @@
 #include <mono/metadata/image.h>
 #include <mono/metadata/loader.h>
 
+G_BEGIN_DECLS
+
 typedef struct MonoVTable MonoVTable;
 
 typedef struct _MonoClassField MonoClassField;
@@ -15,9 +17,9 @@ typedef struct {
        MonoVTable *default_vtable;
        MonoVTable *xdomain_vtable;
        MonoClass *proxy_class;
-       guint interface_count;
-       MonoClass **interfaces;
        char* proxy_class_name;
+       guint interface_count;
+       MonoClass *interfaces [MONO_ZERO_LEN_ARRAY];
 } MonoRemoteClass;
 
 MonoClass *
@@ -26,7 +28,7 @@ mono_class_get             (MonoImage *image, guint32 type_token);
 MonoClass *
 mono_class_get_full        (MonoImage *image, guint32 type_token, MonoGenericContext *context);
 
-void
+gboolean
 mono_class_init            (MonoClass *klass);
 
 MonoVTable *
@@ -38,6 +40,9 @@ mono_class_from_name       (MonoImage *image, const char* name_space, const char
 MonoClass *
 mono_class_from_name_case  (MonoImage *image, const char* name_space, const char *name);
 
+MonoMethod *
+mono_class_get_method_from_name_flags (MonoClass *klass, const char *name, int param_count, int flags);
+
 MonoClass * 
 mono_class_from_typeref    (MonoImage *image, guint32 type_token);
 
@@ -48,7 +53,10 @@ MonoType*
 mono_class_inflate_generic_type (MonoType *type, MonoGenericContext *context);
 
 MonoMethod*
-mono_class_inflate_generic_method (MonoMethod *method, MonoGenericContext *context, MonoClass *klass);
+mono_class_inflate_generic_method (MonoMethod *method, MonoGenericContext *context);
+
+MonoMethod *
+mono_get_inflated_method (MonoMethod *method);
 
 MonoClassField*
 mono_field_from_token      (MonoImage *image, guint32 token, MonoClass **retklass, MonoGenericContext *context);
@@ -114,9 +122,6 @@ mono_ldtoken               (MonoImage *image, guint32 token, MonoClass **retclas
 char*         
 mono_type_get_name         (MonoType *type);
 
-char*         
-mono_type_get_full_name    (MonoType *type);
-
 MonoType*
 mono_type_get_underlying_type (MonoType *type);
 
@@ -157,6 +162,9 @@ mono_class_get_namespace     (MonoClass *klass);
 MonoType*
 mono_class_get_type          (MonoClass *klass);
 
+guint32
+mono_class_get_type_token    (MonoClass *klass);
+
 MonoType*
 mono_class_get_byref_type    (MonoClass *klass);
 
@@ -203,6 +211,12 @@ mono_field_get_parent (MonoClassField *field);
 guint32
 mono_field_get_flags  (MonoClassField *field);
 
+guint32
+mono_field_get_offset  (MonoClassField *field);
+
+const char *
+mono_field_get_data  (MonoClassField *field);
+
 /* MonoProperty acessors */
 const char*
 mono_property_get_name       (MonoProperty *prop);
@@ -244,4 +258,15 @@ mono_event_get_flags         (MonoEvent *event);
 MonoMethod *
 mono_class_get_method_from_name (MonoClass *klass, const char *name, int param_count);
 
+char *
+mono_class_name_from_token (MonoImage *image, guint32 type_token);
+
+gboolean
+mono_method_can_access_field (MonoMethod *method, MonoClassField *field);
+
+gboolean
+mono_method_can_access_method (MonoMethod *method, MonoMethod *called);
+
+G_END_DECLS
+
 #endif /* _MONO_CLI_CLASS_H_ */