2009-06-01 Rodrigo Kumpera <rkumpera@novell.com>
[mono.git] / mono / metadata / appdomain.h
index a678b3774717e9bf8ec52da025529e40c544191d..e4da4e4404bb0df47065cb1820d3ec3124295b64 100644 (file)
 #include <mono/metadata/reflection.h>
 #include <mono/metadata/mempool.h>
 
-typedef void (*MonoThreadStartCB) (guint32 tid, gpointer stack_start,
+G_BEGIN_DECLS
+
+typedef void (*MonoThreadStartCB) (gsize tid, gpointer stack_start,
                                   gpointer func);
-typedef void (*MonoThreadAttachCB) (guint32 tid, gpointer stack_start);
+typedef void (*MonoThreadAttachCB) (gsize tid, gpointer stack_start);
 
 typedef struct _MonoAppDomain MonoAppDomain;
-typedef struct _MonoAppContext MonoAppContext;
 typedef struct _MonoJitInfo MonoJitInfo;
 
 typedef void (*MonoDomainFunc) (MonoDomain *domain, gpointer user_data);
@@ -51,6 +52,9 @@ mono_install_runtime_cleanup (MonoDomainFunc func);
 void
 mono_runtime_quit (void);
 
+void
+mono_runtime_set_shutting_down (void);
+
 gboolean
 mono_runtime_is_shutting_down (void);
 
@@ -60,24 +64,33 @@ mono_check_corlib_version (void);
 MonoDomain *
 mono_domain_create         (void);
 
-inline MonoDomain *
+MonoDomain *
+mono_domain_create_appdomain (char *friendly_name, char *configuration_file);
+
+MonoDomain *
 mono_domain_get            (void);
 
-inline MonoDomain *
+MonoDomain *
 mono_domain_get_by_id      (gint32 domainid);
 
 gint32
 mono_domain_get_id         (MonoDomain *domain);
 
-inline gboolean
+gboolean
 mono_domain_set            (MonoDomain *domain, gboolean force);
 
-inline void
+void
 mono_domain_set_internal   (MonoDomain *domain);
 
+void
+mono_domain_unload (MonoDomain *domain);
+
 gboolean
 mono_domain_is_unloading   (MonoDomain *domain);
 
+MonoDomain *
+mono_domain_from_appdomain (MonoAppDomain *appdomain);
+
 void
 mono_domain_foreach        (MonoDomainFunc func, gpointer user_data);
 
@@ -96,18 +109,33 @@ mono_domain_has_type_resolve (MonoDomain *domain);
 MonoReflectionAssembly *
 mono_domain_try_type_resolve (MonoDomain *domain, char *name, MonoObject *tb);
 
+gboolean
+mono_domain_owns_vtable_slot (MonoDomain *domain, gpointer vtable_slot);
+
 void
 mono_context_init                                 (MonoDomain *domain);
 
-inline void 
+void 
 mono_context_set                                  (MonoAppContext *new_context);
 
-inline MonoAppContext * 
+MonoAppContext * 
 mono_context_get                                  (void);
 
 MonoJitInfo *
 mono_jit_info_table_find   (MonoDomain *domain, char *addr);
 
+/* MonoJitInfo accessors */
+
+gpointer
+mono_jit_info_get_code_start (MonoJitInfo* ji);
+
+int
+mono_jit_info_get_code_size (MonoJitInfo* ji);
+
+MonoMethod*
+mono_jit_info_get_method (MonoJitInfo* ji);
+
+
 MonoImage*
 mono_get_corlib            (void);
 
@@ -174,5 +202,14 @@ mono_get_thread_class       (void);
 MonoClass*
 mono_get_exception_class    (void);
 
+void
+mono_security_enable_core_clr (void);
+
+typedef gboolean (*MonoCoreClrPlatformCB) (const char *image_name);
+
+void
+mono_security_set_core_clr_platform_callback (MonoCoreClrPlatformCB callback);
+
+G_END_DECLS
 #endif /* _MONO_METADATA_APPDOMAIN_H_ */