2004-09-06 Zoltan Varga <vargaz@freemail.hu>
[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 MonoImage    *mono_assembly_get_image  (MonoAssembly *assembly);
29 gboolean      mono_assembly_fill_assembly_name (MonoImage *image, MonoAssemblyName *aname);
30
31 /* Installs a function which is called each time a new assembly is loaded. */
32 typedef void  (*MonoAssemblyLoadFunc)         (MonoAssembly *assembly, gpointer user_data);
33 void          mono_install_assembly_load_hook (MonoAssemblyLoadFunc func, gpointer user_data);
34
35 /* Installs a function which is called before a new assembly is loaded
36  * The hook are invoked from last hooked to first. If any of them returns
37  * a non-null value, that will be the value returned in mono_assembly_load */
38 typedef MonoAssembly * (*MonoAssemblyPreLoadFunc) (MonoAssemblyName *aname,
39                                                    gchar **assemblies_path,
40                                                    gpointer user_data);
41
42 void          mono_install_assembly_preload_hook (MonoAssemblyPreLoadFunc func,
43                                                   gpointer user_data);
44
45 void          mono_assembly_invoke_load_hook (MonoAssembly *ass);
46
47 #endif
48