2004-09-09 Martin Baulig <martin@ximian.com>
[mono.git] / mono / metadata / loader.h
index 1f4e2dc2f10541e5820cd7088a89eb5aea3febe3..4a169212dd137d311fea140f78ec40f5ae584fc0 100644 (file)
@@ -1,60 +1,72 @@
 #ifndef _MONO_METADATA_LOADER_H_
 #define _MONO_METADATA_LOADER_H_ 1
 
-#include <ffi.h>
 #include <mono/metadata/metadata.h>
 #include <mono/metadata/image.h>
 
-typedef struct {
-       guint16 flags;  /* method flags */
-       guint16 iflags; /* method implementation flags */
-       MonoImage *image;
-       MonoMethodSignature *signature;
-       gpointer addr;
-       /* name is useful mostly for debugging */
-       const char *name; 
-} MonoMethod;
-
-typedef struct {
-       MonoMethod method;
-       MonoMethodHeader *header;
-} MonoMethodNormal;
-
-typedef struct {
-       MonoMethod method;
-       guint16 piflags;  /* pinvoke flags */
-       ffi_cif *cif;
-} MonoMethodPInvoke;
-
-typedef struct {
-       MonoImage *corlib;
-       guint32    array_token;
-       guint32    string_token;
-       guint32    char_token;
-} MonoDefaults;
-
-extern MonoDefaults mono_defaults;
+typedef struct _MonoMethod MonoMethod;
 
-void
-mono_init                  (void);
+typedef gboolean (*MonoStackWalk)     (MonoMethod *method, gint32 native_offset, gint32 il_offset, gboolean managed, gpointer data);
+
+MonoMethod *
+mono_get_method            (MonoImage *image, guint32 token, MonoClass *klass);
 
 MonoMethod *
-mono_get_method            (MonoImage *image, guint32 token);
+mono_get_method_full       (MonoImage *image, guint32 token, MonoClass *klass, MonoGenericContext *context);
+
+MonoMethod *
+mono_get_method_constrained (MonoImage *image, guint32 token, MonoClass *constrained_class, MonoGenericContext *context);
 
 void               
 mono_free_method           (MonoMethod *method);
 
-guint32            
-mono_typedef_from_name     (MonoImage *image, const char *name, 
-                           const char *nspace, guint32 *mlist);
+MonoMethodSignature* 
+mono_method_get_signature  (MonoMethod *method, MonoImage *image, guint32 token);
+
+MonoMethodSignature* 
+mono_method_signature      (MonoMethod *method);
+
+const char*
+mono_method_get_name       (MonoMethod *method);
+
+MonoClass*
+mono_method_get_class      (MonoMethod *method);
+
+guint32
+mono_method_get_token      (MonoMethod *method);
+
+guint32
+mono_method_get_flags      (MonoMethod *method, guint32 *iflags);
 
 MonoImage *
-mono_load_image            (const char *fname, enum MonoImageOpenStatus *status);
+mono_load_image            (const char *fname, MonoImageOpenStatus *status);
 
 void
-mono_add_internal_call     (const char *name, gpointer method);
+mono_add_internal_call     (const char *name, gconstpointer method);
 
 gpointer
-mono_lookup_internal_call  (const char *name);
+mono_lookup_internal_call (MonoMethod *method);
+
+void
+mono_dllmap_insert (MonoImage *assembly, const char *dll, const char *func, const char *tdll, const char *tfunc);
+
+gpointer
+mono_lookup_pinvoke_call (MonoMethod *method, const char **exc_class, const char **exc_arg);
+
+void
+mono_method_get_param_names (MonoMethod *method, const char **names);
+
+void
+mono_method_get_marshal_info (MonoMethod *method, MonoMarshalSpec **mspecs);
+
+gboolean
+mono_method_has_marshal_info (MonoMethod *method);
+
+MonoMethod*
+mono_method_get_last_managed  (void);
+
+void
+mono_stack_walk         (MonoStackWalk func, gpointer user_data);
 
 #endif
+