X-Git-Url: http://wien.tomnetworks.com/gitweb/?a=blobdiff_plain;f=mono%2Fmetadata%2Fassembly.h;h=a4832f9995cc5a702b7748a3268ac77c72a7d99c;hb=4e8db5f7f14d1af2daeff2c331b5b724be47e86f;hp=1614cc7aa6c6c5aea63ccf156501c431c7cbf2ec;hpb=ae4362f620dcd35bbb516a4931026e0c3594b968;p=mono.git diff --git a/mono/metadata/assembly.h b/mono/metadata/assembly.h index 1614cc7aa6c..a4832f9995c 100644 --- a/mono/metadata/assembly.h +++ b/mono/metadata/assembly.h @@ -5,7 +5,10 @@ #include +G_BEGIN_DECLS + void mono_assemblies_init (void); +void mono_assemblies_cleanup (void); MonoAssembly *mono_assembly_open (const char *filename, MonoImageOpenStatus *status); MonoAssembly *mono_assembly_open_full (const char *filename, @@ -28,6 +31,7 @@ MonoAssembly* mono_assembly_load_with_partial_name (const char *name, MonoImageO MonoAssembly* mono_assembly_loaded (MonoAssemblyName *aname); MonoAssembly* mono_assembly_loaded_full (MonoAssemblyName *aname, gboolean refonly); +void mono_assembly_get_assemblyref (MonoImage *image, int index, MonoAssemblyName *aname); void mono_assembly_load_reference (MonoImage *image, int index); void mono_assembly_load_references (MonoImage *image, MonoImageOpenStatus *status); MonoImage* mono_assembly_load_module (MonoAssembly *assembly, guint32 idx); @@ -40,6 +44,7 @@ MonoAssembly *mono_assembly_get_main (void); MonoImage *mono_assembly_get_image (MonoAssembly *assembly); gboolean mono_assembly_fill_assembly_name (MonoImage *image, MonoAssemblyName *aname); gboolean mono_assembly_names_equal (MonoAssemblyName *l, MonoAssemblyName *r); +char* mono_stringify_assembly_name (MonoAssemblyName *aname); /* Installs a function which is called each time a new assembly is loaded. */ typedef void (*MonoAssemblyLoadFunc) (MonoAssembly *assembly, gpointer user_data); @@ -55,6 +60,17 @@ void mono_install_assembly_refonly_search_hook (MonoAssemblySearchFunc fu MonoAssembly* mono_assembly_invoke_search_hook (MonoAssemblyName *aname); +/* + * Installs a new search function which is used as a last resort when loading + * an assembly fails. This could invoke AssemblyResolve events. + */ +void +mono_install_assembly_postload_search_hook (MonoAssemblySearchFunc func, gpointer user_data); + +void +mono_install_assembly_postload_refonly_search_hook (MonoAssemblySearchFunc func, gpointer user_data); + + /* Installs a function which is called before a new assembly is loaded * The hook are invoked from last hooked to first. If any of them returns * a non-null value, that will be the value returned in mono_assembly_load */ @@ -76,5 +92,10 @@ typedef struct { } MonoBundledAssembly; void mono_register_bundled_assemblies (const MonoBundledAssembly **assemblies); +void mono_register_config_for_assembly (const char* assembly_name, const char* config_xml); + +void mono_set_rootdir (void); +void mono_set_dirs (const char *assembly_dir, const char *config_dir); +G_END_DECLS #endif