[netcore] Make the load hook ALC-aware (#16012)
[mono-project.git] / mono / metadata / assembly.h
bloba4fffaf6578c33ac67154fdcd0c5349a2db51a8a
1 /**
2 * \file
3 */
5 #ifndef _MONONET_METADATA_ASSEMBLY_H_
6 #define _MONONET_METADATA_ASSEMBLY_H_
8 #include <mono/utils/mono-error.h>
9 #include <mono/metadata/image.h>
11 MONO_BEGIN_DECLS
13 MONO_API void mono_assemblies_init (void);
14 MONO_API void mono_assemblies_cleanup (void);
15 MONO_API MONO_RT_EXTERNAL_ONLY
16 MonoAssembly *mono_assembly_open (const char *filename,
17 MonoImageOpenStatus *status);
18 MONO_API MONO_RT_EXTERNAL_ONLY
19 MonoAssembly *mono_assembly_open_full (const char *filename,
20 MonoImageOpenStatus *status,
21 mono_bool refonly);
22 MONO_API MonoAssembly* mono_assembly_load (MonoAssemblyName *aname,
23 const char *basedir,
24 MonoImageOpenStatus *status);
25 MONO_API MONO_RT_EXTERNAL_ONLY
26 MonoAssembly* mono_assembly_load_full (MonoAssemblyName *aname,
27 const char *basedir,
28 MonoImageOpenStatus *status,
29 mono_bool refonly);
30 MONO_API MONO_RT_EXTERNAL_ONLY
31 MonoAssembly* mono_assembly_load_from (MonoImage *image, const char *fname,
32 MonoImageOpenStatus *status);
33 MONO_API MONO_RT_EXTERNAL_ONLY
34 MonoAssembly* mono_assembly_load_from_full (MonoImage *image, const char *fname,
35 MonoImageOpenStatus *status,
36 mono_bool refonly);
38 MONO_API MONO_RT_EXTERNAL_ONLY
39 MonoAssembly* mono_assembly_load_with_partial_name (const char *name, MonoImageOpenStatus *status);
41 MONO_API MONO_RT_EXTERNAL_ONLY
42 MonoAssembly* mono_assembly_loaded (MonoAssemblyName *aname);
43 MONO_API MONO_RT_EXTERNAL_ONLY
44 MonoAssembly* mono_assembly_loaded_full (MonoAssemblyName *aname, mono_bool refonly);
45 MONO_API void mono_assembly_get_assemblyref (MonoImage *image, int index, MonoAssemblyName *aname);
46 MONO_API void mono_assembly_load_reference (MonoImage *image, int index);
47 MONO_API void mono_assembly_load_references (MonoImage *image, MonoImageOpenStatus *status);
48 MONO_API MONO_RT_EXTERNAL_ONLY MonoImage* mono_assembly_load_module (MonoAssembly *assembly, uint32_t idx);
49 MONO_API void mono_assembly_close (MonoAssembly *assembly);
50 MONO_API void mono_assembly_setrootdir (const char *root_dir);
51 MONO_API MONO_CONST_RETURN char *mono_assembly_getrootdir (void);
52 MONO_API char *mono_native_getrootdir (void);
53 MONO_API void mono_assembly_foreach (MonoFunc func, void* user_data);
54 MONO_API void mono_assembly_set_main (MonoAssembly *assembly);
55 MONO_API MonoAssembly *mono_assembly_get_main (void);
56 MONO_API MONO_RT_EXTERNAL_ONLY
57 MonoImage *mono_assembly_get_image (MonoAssembly *assembly);
58 MONO_API MONO_RT_EXTERNAL_ONLY
59 MonoAssemblyName *mono_assembly_get_name (MonoAssembly *assembly);
60 MONO_API mono_bool mono_assembly_fill_assembly_name (MonoImage *image, MonoAssemblyName *aname);
61 MONO_API mono_bool mono_assembly_names_equal (MonoAssemblyName *l, MonoAssemblyName *r);
62 MONO_API char* mono_stringify_assembly_name (MonoAssemblyName *aname);
64 /* Installs a function which is called each time a new assembly is loaded. */
65 typedef void (*MonoAssemblyLoadFunc) (MonoAssembly *assembly, void* user_data);
66 MONO_API MONO_RT_EXTERNAL_ONLY void
67 mono_install_assembly_load_hook (MonoAssemblyLoadFunc func, void* user_data);
69 /*
70 * Installs a new function which is used to search the list of loaded
71 * assemblies for a given assembly name.
73 typedef MonoAssembly *(*MonoAssemblySearchFunc) (MonoAssemblyName *aname, void* user_data);
74 MONO_API MONO_RT_EXTERNAL_ONLY
75 void mono_install_assembly_search_hook (MonoAssemblySearchFunc func, void* user_data);
76 MONO_API MONO_RT_EXTERNAL_ONLY
77 void mono_install_assembly_refonly_search_hook (MonoAssemblySearchFunc func, void* user_data);
79 MONO_API MONO_RT_EXTERNAL_ONLY
80 MonoAssembly* mono_assembly_invoke_search_hook (MonoAssemblyName *aname);
83 * Installs a new search function which is used as a last resort when loading
84 * an assembly fails. This could invoke AssemblyResolve events.
86 MONO_API MONO_RT_EXTERNAL_ONLY
87 void
88 mono_install_assembly_postload_search_hook (MonoAssemblySearchFunc func, void* user_data);
90 MONO_API MONO_RT_EXTERNAL_ONLY
91 void
92 mono_install_assembly_postload_refonly_search_hook (MonoAssemblySearchFunc func, void* user_data);
95 /* Installs a function which is called before a new assembly is loaded
96 * The hook are invoked from last hooked to first. If any of them returns
97 * a non-null value, that will be the value returned in mono_assembly_load */
98 typedef MonoAssembly * (*MonoAssemblyPreLoadFunc) (MonoAssemblyName *aname,
99 char **assemblies_path,
100 void* user_data);
102 MONO_API void mono_install_assembly_preload_hook (MonoAssemblyPreLoadFunc func,
103 void* user_data);
104 MONO_API void mono_install_assembly_refonly_preload_hook (MonoAssemblyPreLoadFunc func,
105 void* user_data);
107 MONO_API MONO_RT_EXTERNAL_ONLY void
108 mono_assembly_invoke_load_hook (MonoAssembly *ass);
110 MONO_API MonoAssemblyName* mono_assembly_name_new (const char *name);
111 MONO_API const char* mono_assembly_name_get_name (MonoAssemblyName *aname);
112 MONO_API const char* mono_assembly_name_get_culture (MonoAssemblyName *aname);
113 MONO_API uint16_t mono_assembly_name_get_version (MonoAssemblyName *aname,
114 uint16_t *minor, uint16_t *build, uint16_t *revision);
115 MONO_API mono_byte* mono_assembly_name_get_pubkeytoken (MonoAssemblyName *aname);
116 MONO_API void mono_assembly_name_free (MonoAssemblyName *aname);
118 typedef struct {
119 const char *name;
120 const unsigned char *data;
121 unsigned int size;
122 } MonoBundledAssembly;
124 MONO_API void mono_register_bundled_assemblies (const MonoBundledAssembly **assemblies);
125 MONO_API void mono_register_config_for_assembly (const char* assembly_name, const char* config_xml);
126 MONO_API void mono_register_symfile_for_assembly (const char* assembly_name, const mono_byte *raw_contents, int size);
127 MONO_API void mono_register_machine_config (const char *config_xml);
129 MONO_API void mono_set_rootdir (void);
130 MONO_API void mono_set_dirs (const char *assembly_dir, const char *config_dir);
131 MONO_API void mono_set_assemblies_path (const char* path);
132 MONO_END_DECLS
134 #endif