2004-05-12 Gonzalo Paniagua Javier <gonzalo@ximian.com>
[mono.git] / mono / metadata / assembly.h
1 #ifndef _MONONET_METADATA_ASSEMBLY_H_ 
2 #define _MONONET_METADATA_ASSEMBLY_H_
3
4 #include <glib.h>
5
6 #include <mono/metadata/image.h>
7
8 void          mono_assemblies_init     (void);
9 MonoAssembly *mono_assembly_open       (const char *filename,
10                                         MonoImageOpenStatus *status);
11 MonoAssembly* mono_assembly_load       (MonoAssemblyName *aname, 
12                                         const char       *basedir, 
13                                         MonoImageOpenStatus *status);
14 MonoAssembly* mono_assembly_load_from  (MonoImage *image, const char *fname,
15                                         MonoImageOpenStatus *status);
16
17 MonoAssembly* mono_assembly_load_with_partial_name (const char *name, MonoImageOpenStatus *status);
18
19 MonoAssembly* mono_assembly_loaded     (MonoAssemblyName *aname);
20 void          mono_assembly_load_references (MonoImage *image, MonoImageOpenStatus *status);
21 MonoImage*    mono_assembly_load_module (MonoAssembly *assembly, guint32 idx);
22 void          mono_assembly_close      (MonoAssembly *assembly);
23 void          mono_assembly_setrootdir (const char *root_dir);
24 G_CONST_RETURN gchar *mono_assembly_getrootdir (void);
25 void          mono_assembly_foreach    (GFunc func, gpointer user_data);
26 void          mono_assembly_set_main   (MonoAssembly *assembly);
27 MonoAssembly *mono_assembly_get_main   (void);
28 gboolean      mono_assembly_fill_assembly_name (MonoImage *image, MonoAssemblyName *aname);
29
30 /* Installs a function which is called each time a new assembly is loaded. */
31 typedef void  (*MonoAssemblyLoadFunc)         (MonoAssembly *assembly, gpointer user_data);
32 void          mono_install_assembly_load_hook (MonoAssemblyLoadFunc func, gpointer user_data);
33
34 /* Installs a function which is called before a new assembly is loaded
35  * The hook are invoked from last hooked to first. If any of them returns
36  * a non-null value, that will be the value returned in mono_assembly_load */
37 typedef MonoAssembly * (*MonoAssemblyPreLoadFunc) (MonoAssemblyName *aname,
38                                                    gchar **assemblies_path,
39                                                    gpointer user_data);
40
41 void          mono_install_assembly_preload_hook (MonoAssemblyPreLoadFunc func,
42                                                   gpointer user_data);
43
44 void          mono_assembly_invoke_load_hook (MonoAssembly *ass);
45
46 #endif
47