2009-11-04 Sebastien Pouliot <sebastien@ximian.com>
[mono.git] / mono / metadata / appdomain.h
index f2ee91f8ee730884303f8d5197cbaa3fc1fb0b39..4ec0cc28764a5f01912f3d170569583c0cc00004 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);
@@ -29,6 +30,12 @@ typedef void (*MonoDomainFunc) (MonoDomain *domain, gpointer user_data);
 MonoDomain*
 mono_init                  (const char *filename);
 
+MonoDomain *
+mono_init_from_assembly    (const char *domain_name, const char *filename);
+
+MonoDomain *
+mono_init_version          (const char *domain_name, const char *version);
+
 MonoDomain*
 mono_get_root_domain       (void);
 
@@ -40,11 +47,14 @@ void
 mono_runtime_cleanup       (MonoDomain *domain);
 
 void
-mono_runtime_install_cleanup (MonoDomainFunc func);
+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);
 
@@ -54,24 +64,36 @@ 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);
+
+void
+mono_domain_try_unload (MonoDomain *domain, MonoObject **exc);
+
 gboolean
 mono_domain_is_unloading   (MonoDomain *domain);
 
+MonoDomain *
+mono_domain_from_appdomain (MonoAppDomain *appdomain);
+
 void
 mono_domain_foreach        (MonoDomainFunc func, gpointer user_data);
 
@@ -90,18 +112,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);
 
@@ -168,5 +205,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_ */