Make a copy of the old ZipLib
[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 G_BEGIN_DECLS
9
10 void          mono_assemblies_init     (void);
11 MonoAssembly *mono_assembly_open       (const char *filename,
12                                         MonoImageOpenStatus *status);
13 MonoAssembly *mono_assembly_open_full (const char *filename,
14                                         MonoImageOpenStatus *status,
15                                         gboolean refonly);
16 MonoAssembly* mono_assembly_load       (MonoAssemblyName *aname, 
17                                         const char       *basedir, 
18                                         MonoImageOpenStatus *status);
19 MonoAssembly* mono_assembly_load_full (MonoAssemblyName *aname, 
20                                         const char       *basedir, 
21                                         MonoImageOpenStatus *status,
22                                         gboolean refonly);
23 MonoAssembly* mono_assembly_load_from  (MonoImage *image, const char *fname,
24                                         MonoImageOpenStatus *status);
25 MonoAssembly* mono_assembly_load_from_full  (MonoImage *image, const char *fname,
26                                         MonoImageOpenStatus *status,
27                                         gboolean refonly);
28
29 MonoAssembly* mono_assembly_load_with_partial_name (const char *name, MonoImageOpenStatus *status);
30
31 MonoAssembly* mono_assembly_loaded     (MonoAssemblyName *aname);
32 MonoAssembly* mono_assembly_loaded_full (MonoAssemblyName *aname, gboolean refonly);
33 void          mono_assembly_get_assemblyref (MonoImage *image, int index, MonoAssemblyName *aname);
34 void          mono_assembly_load_reference (MonoImage *image, int index);
35 void          mono_assembly_load_references (MonoImage *image, MonoImageOpenStatus *status);
36 MonoImage*    mono_assembly_load_module (MonoAssembly *assembly, guint32 idx);
37 void          mono_assembly_close      (MonoAssembly *assembly);
38 void          mono_assembly_setrootdir (const char *root_dir);
39 G_CONST_RETURN gchar *mono_assembly_getrootdir (void);
40 void          mono_assembly_foreach    (GFunc func, gpointer user_data);
41 void          mono_assembly_set_main   (MonoAssembly *assembly);
42 MonoAssembly *mono_assembly_get_main   (void);
43 MonoImage    *mono_assembly_get_image  (MonoAssembly *assembly);
44 gboolean      mono_assembly_fill_assembly_name (MonoImage *image, MonoAssemblyName *aname);
45 gboolean      mono_assembly_names_equal (MonoAssemblyName *l, MonoAssemblyName *r);
46 char*         mono_stringify_assembly_name (MonoAssemblyName *aname);
47
48 /* Installs a function which is called each time a new assembly is loaded. */
49 typedef void  (*MonoAssemblyLoadFunc)         (MonoAssembly *assembly, gpointer user_data);
50 void          mono_install_assembly_load_hook (MonoAssemblyLoadFunc func, gpointer user_data);
51
52 /* 
53  * Installs a new function which is used to search the list of loaded 
54  * assemblies for a given assembly name.
55  */
56 typedef MonoAssembly *(*MonoAssemblySearchFunc)         (MonoAssemblyName *aname, gpointer user_data);
57 void          mono_install_assembly_search_hook (MonoAssemblySearchFunc func, gpointer user_data);
58 void          mono_install_assembly_refonly_search_hook (MonoAssemblySearchFunc func, gpointer user_data);
59
60 MonoAssembly* mono_assembly_invoke_search_hook (MonoAssemblyName *aname);
61
62 /*
63  * Installs a new search function which is used as a last resort when loading 
64  * an assembly fails. This could invoke AssemblyResolve events.
65  */
66 void          
67 mono_install_assembly_postload_search_hook (MonoAssemblySearchFunc func, gpointer user_data);
68
69 void          
70 mono_install_assembly_postload_refonly_search_hook (MonoAssemblySearchFunc func, gpointer user_data);
71
72
73 /* Installs a function which is called before a new assembly is loaded
74  * The hook are invoked from last hooked to first. If any of them returns
75  * a non-null value, that will be the value returned in mono_assembly_load */
76 typedef MonoAssembly * (*MonoAssemblyPreLoadFunc) (MonoAssemblyName *aname,
77                                                    gchar **assemblies_path,
78                                                    gpointer user_data);
79
80 void          mono_install_assembly_preload_hook (MonoAssemblyPreLoadFunc func,
81                                                   gpointer user_data);
82 void          mono_install_assembly_refonly_preload_hook (MonoAssemblyPreLoadFunc func,
83                                                   gpointer user_data);
84
85 void          mono_assembly_invoke_load_hook (MonoAssembly *ass);
86
87 typedef struct {
88         const char *name;
89         const unsigned char *data;
90         const unsigned int size;
91 } MonoBundledAssembly;
92
93 void          mono_register_bundled_assemblies (const MonoBundledAssembly **assemblies);
94 void          mono_register_config_for_assembly (const char* assembly_name, const char* config_xml);
95
96 G_END_DECLS
97 #endif
98