Merge pull request #3591 from directhex/mono_libdir_fallback
[mono.git] / mono / metadata / assembly.h
index a4832f9995cc5a702b7748a3268ac77c72a7d99c..6126feda0e1c9053ddc792e2a466a1aa60dd2953 100644 (file)
@@ -1,89 +1,98 @@
 #ifndef _MONONET_METADATA_ASSEMBLY_H_ 
 #define _MONONET_METADATA_ASSEMBLY_H_
 
-#include <glib.h>
-
+#include <mono/utils/mono-error.h>
 #include <mono/metadata/image.h>
 
-G_BEGIN_DECLS
+MONO_BEGIN_DECLS
 
-void          mono_assemblies_init     (void);
-void          mono_assemblies_cleanup  (void);
-MonoAssembly *mono_assembly_open       (const char *filename,
+MONO_API void          mono_assemblies_init     (void);
+MONO_API void          mono_assemblies_cleanup  (void);
+MONO_API MonoAssembly *mono_assembly_open       (const char *filename,
                                        MonoImageOpenStatus *status);
-MonoAssembly *mono_assembly_open_full (const char *filename,
+MONO_API MonoAssembly *mono_assembly_open_full (const char *filename,
                                        MonoImageOpenStatus *status,
-                                       gboolean refonly);
-MonoAssembly* mono_assembly_load       (MonoAssemblyName *aname, 
+                                       mono_bool refonly);
+MONO_API MonoAssembly* mono_assembly_load       (MonoAssemblyName *aname, 
                                                const char       *basedir, 
                                        MonoImageOpenStatus *status);
-MonoAssembly* mono_assembly_load_full (MonoAssemblyName *aname, 
+MONO_API MonoAssembly* mono_assembly_load_full (MonoAssemblyName *aname, 
                                                const char       *basedir, 
                                        MonoImageOpenStatus *status,
-                                       gboolean refonly);
-MonoAssembly* mono_assembly_load_from  (MonoImage *image, const char *fname,
+                                       mono_bool refonly);
+MONO_API MonoAssembly* mono_assembly_load_from  (MonoImage *image, const char *fname,
                                        MonoImageOpenStatus *status);
-MonoAssembly* mono_assembly_load_from_full  (MonoImage *image, const char *fname,
+MONO_API MonoAssembly* mono_assembly_load_from_full  (MonoImage *image, const char *fname,
                                        MonoImageOpenStatus *status,
-                                       gboolean refonly);
-
-MonoAssembly* mono_assembly_load_with_partial_name (const char *name, MonoImageOpenStatus *status);
-
-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);
-void          mono_assembly_close      (MonoAssembly *assembly);
-void          mono_assembly_setrootdir (const char *root_dir);
-G_CONST_RETURN gchar *mono_assembly_getrootdir (void);
-void         mono_assembly_foreach    (GFunc func, gpointer user_data);
-void          mono_assembly_set_main   (MonoAssembly *assembly);
-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);
+                                       mono_bool refonly);
+
+MONO_API MonoAssembly* mono_assembly_load_with_partial_name (const char *name, MonoImageOpenStatus *status);
+
+MONO_API MonoAssembly* mono_assembly_loaded     (MonoAssemblyName *aname);
+MONO_API MonoAssembly* mono_assembly_loaded_full (MonoAssemblyName *aname, mono_bool refonly);
+MONO_API void          mono_assembly_get_assemblyref (MonoImage *image, int index, MonoAssemblyName *aname);
+MONO_API void          mono_assembly_load_reference (MonoImage *image, int index);
+MONO_API void          mono_assembly_load_references (MonoImage *image, MonoImageOpenStatus *status);
+MONO_RT_EXTERNAL_ONLY MONO_API MonoImage*    mono_assembly_load_module (MonoAssembly *assembly, uint32_t idx);
+MONO_API void          mono_assembly_close      (MonoAssembly *assembly);
+MONO_API void          mono_assembly_setrootdir (const char *root_dir);
+MONO_API MONO_CONST_RETURN char *mono_assembly_getrootdir (void);
+MONO_API MONO_CONST_RETURN char *mono_native_getrootdir (void);
+MONO_API void        mono_assembly_foreach    (MonoFunc func, void* user_data);
+MONO_API void          mono_assembly_set_main   (MonoAssembly *assembly);
+MONO_API MonoAssembly *mono_assembly_get_main   (void);
+MONO_API MonoImage    *mono_assembly_get_image  (MonoAssembly *assembly);
+MONO_API MonoAssemblyName *mono_assembly_get_name (MonoAssembly *assembly);
+MONO_API mono_bool      mono_assembly_fill_assembly_name (MonoImage *image, MonoAssemblyName *aname);
+MONO_API mono_bool      mono_assembly_names_equal (MonoAssemblyName *l, MonoAssemblyName *r);
+MONO_API 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);
-void          mono_install_assembly_load_hook (MonoAssemblyLoadFunc func, gpointer user_data);
+typedef void  (*MonoAssemblyLoadFunc)         (MonoAssembly *assembly, void* user_data);
+MONO_API void          mono_install_assembly_load_hook (MonoAssemblyLoadFunc func, void* user_data);
 
 /* 
  * Installs a new function which is used to search the list of loaded 
  * assemblies for a given assembly name.
  */
-typedef MonoAssembly *(*MonoAssemblySearchFunc)         (MonoAssemblyName *aname, gpointer user_data);
-void          mono_install_assembly_search_hook (MonoAssemblySearchFunc func, gpointer user_data);
-void         mono_install_assembly_refonly_search_hook (MonoAssemblySearchFunc func, gpointer user_data);
+typedef MonoAssembly *(*MonoAssemblySearchFunc)         (MonoAssemblyName *aname, void* user_data);
+MONO_API void          mono_install_assembly_search_hook (MonoAssemblySearchFunc func, void* user_data);
+MONO_API void        mono_install_assembly_refonly_search_hook (MonoAssemblySearchFunc func, void* user_data);
 
-MonoAssembly* mono_assembly_invoke_search_hook (MonoAssemblyName *aname);
+MONO_API 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);
+MONO_API void          
+mono_install_assembly_postload_search_hook (MonoAssemblySearchFunc func, void* user_data);
 
-void          
-mono_install_assembly_postload_refonly_search_hook (MonoAssemblySearchFunc func, gpointer user_data);
+MONO_API void          
+mono_install_assembly_postload_refonly_search_hook (MonoAssemblySearchFunc func, void* 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 */
 typedef MonoAssembly * (*MonoAssemblyPreLoadFunc) (MonoAssemblyName *aname,
-                                                  gchar **assemblies_path,
-                                                  gpointer user_data);
+                                                  char **assemblies_path,
+                                                  void* user_data);
+
+MONO_API void          mono_install_assembly_preload_hook (MonoAssemblyPreLoadFunc func,
+                                                 void* user_data);
+MONO_API void          mono_install_assembly_refonly_preload_hook (MonoAssemblyPreLoadFunc func,
+                                                 void* user_data);
 
-void          mono_install_assembly_preload_hook (MonoAssemblyPreLoadFunc func,
-                                                 gpointer user_data);
-void          mono_install_assembly_refonly_preload_hook (MonoAssemblyPreLoadFunc func,
-                                                 gpointer user_data);
+MONO_API void          mono_assembly_invoke_load_hook (MonoAssembly *ass);
 
-void          mono_assembly_invoke_load_hook (MonoAssembly *ass);
+MONO_API MonoAssemblyName* mono_assembly_name_new             (const char *name);
+MONO_API const char*       mono_assembly_name_get_name        (MonoAssemblyName *aname);
+MONO_API const char*       mono_assembly_name_get_culture     (MonoAssemblyName *aname);
+MONO_API uint16_t          mono_assembly_name_get_version     (MonoAssemblyName *aname,
+                                                     uint16_t *minor, uint16_t *build, uint16_t *revision);
+MONO_API mono_byte*        mono_assembly_name_get_pubkeytoken (MonoAssemblyName *aname);
+MONO_API void              mono_assembly_name_free            (MonoAssemblyName *aname);
 
 typedef struct {
        const char *name;
@@ -91,11 +100,15 @@ typedef struct {
        const unsigned int size;
 } MonoBundledAssembly;
 
-void          mono_register_bundled_assemblies (const MonoBundledAssembly **assemblies);
-void          mono_register_config_for_assembly (const char* assembly_name, const char* config_xml);
+MONO_API void          mono_register_bundled_assemblies (const MonoBundledAssembly **assemblies);
+MONO_API void          mono_register_config_for_assembly (const char* assembly_name, const char* config_xml);
+MONO_API void          mono_register_symfile_for_assembly (const char* assembly_name, const mono_byte *raw_contents, int size);
+MONO_API void        mono_register_machine_config (const char *config_xml);
+
+MONO_API void          mono_set_rootdir (void);
+MONO_API void          mono_set_dirs (const char *assembly_dir, const char *config_dir);
+MONO_API void          mono_set_assemblies_path (const char* path);
+MONO_END_DECLS
 
-void          mono_set_rootdir (void);
-void          mono_set_dirs (const char *assembly_dir, const char *config_dir);
-G_END_DECLS
 #endif