You've already forked linux-packaging-mono
							
							
		
			
	
	
		
			428 lines
		
	
	
		
			13 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
		
		
			
		
	
	
			428 lines
		
	
	
		
			13 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
|   | <?xml version="1.0" encoding="utf-8"?><span> | |||
|  | <html xmlns="http://www.w3.org/1999/xhtml"> | |||
|  | <head> | |||
|  |    <title>mono-api-embedding.html</title> | |||
|  |    <style type="text/css"> | |||
|  | 
 | |||
|  | 
 | |||
|  |    h3 {  | |||
|  |        font-size: 18px; | |||
|  |        padding-bottom: 4pt; | |||
|  |        border-bottom: 2px solid #dddddd; | |||
|  |    } | |||
|  |         | |||
|  |    .api { | |||
|  |      border: 1px solid; | |||
|  |      padding: 10pt; | |||
|  |      margin: 10pt; | |||
|  |    }  | |||
|  | 
 | |||
|  |    .api-entry {  | |||
|  |        border-bottom: none; | |||
|  |        font-size: 18px; | |||
|  |    } | |||
|  | 
 | |||
|  |    .prototype { | |||
|  |      border: 1px solid; | |||
|  |      background-color: #f2f2f2; | |||
|  |      padding: 5pt; | |||
|  |      margin-top: 5pt; | |||
|  |      margin-bottom: 5pt;   | |||
|  |    }  | |||
|  | 
 | |||
|  |    .header { | |||
|  |      border: 1px solid; | |||
|  |      padding: 0 0 5pt 5pt; | |||
|  |      margin: 10pt; | |||
|  |      white-space: pre; | |||
|  |        font-family: monospace; | |||
|  |    } | |||
|  |      | |||
|  |    .code { | |||
|  |      border: 1px solid; | |||
|  |      padding: 0 0 5pt 5pt; | |||
|  |      margin: 10pt; | |||
|  |      white-space: pre; | |||
|  |        font-family: monospace; | |||
|  |    } | |||
|  |     | |||
|  | 
 | |||
|  | </style> | |||
|  | </head> | |||
|  | <body> | |||
|  | <h2>Embedding Mono</h2> | |||
|  | 
 | |||
|  | 	<p />The simplest way of embedding Mono is illustrated here: | |||
|  | <pre> | |||
|  | int main (int argc, char *argv) | |||
|  | { | |||
|  | 	/* | |||
|  | 	 * Load the default Mono configuration file, this is needed | |||
|  | 	 * if you are planning on using the dllmaps defined on the | |||
|  | 	 * system configuration | |||
|  | 	 */ | |||
|  | 	mono_config_parse (NULL); | |||
|  | 
 | |||
|  | 	/* | |||
|  | 	 * mono_jit_init() creates a domain: each assembly is | |||
|  | 	 * loaded and run in a MonoDomain. | |||
|  | 	 */ | |||
|  | 	MonoDomain *domain = mono_jit_init ("startup.exe"); | |||
|  | 
 | |||
|  | 	/* | |||
|  | 	 * Optionally, add an internal call that your startup.exe | |||
|  | 	 * code can call, this will bridge startup.exe to Mono | |||
|  | 	 */ | |||
|  | 	mono_add_internal_call ("Sample::GetMessage", getMessage); | |||
|  | 
 | |||
|  | 	/* | |||
|  | 	 * Open the executable, and run the Main method declared | |||
|  | 	 * in the executable | |||
|  | 	 */ | |||
|  | 	MonoAssembly *assembly = mono_domain_assembly_open (domain, "startup.exe"); | |||
|  | 
 | |||
|  | 	if (!assembly) | |||
|  | 		exit (2); | |||
|  | 	/* | |||
|  | 	 * mono_jit_exec() will run the Main() method in the assembly. | |||
|  | 	 * The return value needs to be looked up from | |||
|  | 	 * System.Environment.ExitCode. | |||
|  | 	 */ | |||
|  | 	mono_jit_exec (domain, assembly, argc, argv); | |||
|  | } | |||
|  | 
 | |||
|  | /* The C# signature for this method is: string GetMessage () in class Sample */ | |||
|  | MonoString* | |||
|  | getMessage () | |||
|  | { | |||
|  | 	return mono_string_new (mono_domain_get (), "Hello, world"); | |||
|  | } | |||
|  | </pre> | |||
|  | 
 | |||
|  |  <a name="api:mono_jit_init"></a> | |||
|  |  <div class="api"> | |||
|  |     <div class="api-entry">mono_jit_init</div> | |||
|  | 
 | |||
|  |     <div class="prototype">Prototype: mono_jit_init</div> | |||
|  | <p /> | |||
|  | 
 | |||
|  | </div> <a name="api:mono_jit_exec"></a> | |||
|  |  <div class="api"> | |||
|  |     <div class="api-entry">mono_jit_exec</div> | |||
|  | 
 | |||
|  |     <div class="prototype">int  | |||
|  | mono_jit_exec (MonoDomain *domain, MonoAssembly *assembly, int argc, char *argv[]) | |||
|  | 
 | |||
|  | </div> | |||
|  | <p /> | |||
|  | <b>Parameters</b> | |||
|  | <blockquote><dt><i>assembly:</i></dt><dd> reference to an assembly</dd><dt><i>argc:</i></dt><dd> argument count</dd><dt><i>argv:</i></dt><dd> argument vector</dd></blockquote> | |||
|  | <b>Remarks</b> | |||
|  | <p />	  | |||
|  | 	 Start execution of a program. | |||
|  | 
 | |||
|  | </div> <a name="api:mono_set_dirs"></a> | |||
|  |  <div class="api"> | |||
|  |     <div class="api-entry">mono_set_dirs</div> | |||
|  | 
 | |||
|  |     <div class="prototype">void | |||
|  | mono_set_dirs (const char *assembly_dir, const char *config_dir) | |||
|  | 
 | |||
|  | </div> | |||
|  | <p /> | |||
|  | <b>Parameters</b> | |||
|  | <blockquote><dt><i>assembly_dir:</i></dt><dd> the base directory for assemblies</dd><dt><i>config_dir:</i></dt><dd> the base directory for configuration files</dd></blockquote> | |||
|  | <b>Remarks</b> | |||
|  | <p />	  | |||
|  | 	 This routine is used internally and by developers embedding | |||
|  | 	 the runtime into their own applications. | |||
|  | 	 | |||
|  | 	 There are a number of cases to consider: Mono as a system-installed | |||
|  | 	 package that is available on the location preconfigured or Mono in | |||
|  | 	 a relocated location. | |||
|  | 	 | |||
|  | 	 If you are using a system-installed Mono, you can pass NULL | |||
|  | 	 to both parameters.  If you are not, you should compute both | |||
|  | 	 directory values and call this routine. | |||
|  | 	 | |||
|  | 	 The values for a given PREFIX are: | |||
|  | 	 | |||
|  | 	    assembly_dir: PREFIX/lib | |||
|  | 	    config_dir:   PREFIX/etc | |||
|  | 	 | |||
|  | 	 Notice that embedders that use Mono in a relocated way must | |||
|  | 	 compute the location at runtime, as they will be in control | |||
|  | 	 of where Mono is installed. | |||
|  | 
 | |||
|  | </div> <a name="api:mono_main"></a> | |||
|  |  <div class="api"> | |||
|  |     <div class="api-entry">mono_main</div> | |||
|  | 
 | |||
|  |     <div class="prototype">int | |||
|  | mono_main (int argc, char* argv[]) | |||
|  | 
 | |||
|  | </div> | |||
|  | <p /> | |||
|  | <b>Parameters</b> | |||
|  | <blockquote><dt><i>argc:</i></dt><dd> number of arguments in the argv array</dd><dt><i>argv:</i></dt><dd> array of strings containing the startup arguments</dd></blockquote> | |||
|  | <b>Remarks</b> | |||
|  | <p />	  | |||
|  | 	 Launches the Mono JIT engine and parses all the command line options | |||
|  | 	 in the same way that the mono command line VM would. | |||
|  | 
 | |||
|  | </div> <a name="api:mono_parse_default_optimizations"></a> | |||
|  |  <div class="api"> | |||
|  |     <div class="api-entry">mono_parse_default_optimizations</div> | |||
|  | 
 | |||
|  |     <div class="prototype">Prototype: mono_parse_default_optimizations</div> | |||
|  | <p /> | |||
|  | 
 | |||
|  | 
 | |||
|  | </div> <a name="api:mono_jit_cleanup"></a> | |||
|  |  <div class="api"> | |||
|  |     <div class="api-entry">mono_jit_cleanup</div> | |||
|  | 
 | |||
|  |     <div class="prototype">Prototype: mono_jit_cleanup</div> | |||
|  | <p /> | |||
|  | 
 | |||
|  | </div> <a name="api:mono_set_defaults"></a> | |||
|  |  <div class="api"> | |||
|  |     <div class="api-entry">mono_set_defaults</div> | |||
|  | 
 | |||
|  |     <div class="prototype">Prototype: mono_set_defaults</div> | |||
|  | <p /> | |||
|  | 
 | |||
|  | 
 | |||
|  | </div><h3>Internal Calls</h3> | |||
|  | 
 | |||
|  | 	<p />The Mono runtime provides two mechanisms to expose C code | |||
|  | 	to the CIL universe: internal calls and native C | |||
|  | 	code. Internal calls are tightly integrated with the runtime, | |||
|  | 	and have the least overhead, as they use the same data types | |||
|  | 	that the runtime uses. | |||
|  | 
 | |||
|  | 	<p />The other option is to use the Platform Invoke (P/Invoke) | |||
|  | 	to call C code from the CIL universe, using the standard | |||
|  | 	<a href="http://www.mono-project.com/Interop_with_Native_Libraries">P/Invoke</a> | |||
|  | 	mechanisms. | |||
|  | 
 | |||
|  | 	<p />To register an internal call, use this call you use the | |||
|  | 	<a href="#api:mono_add_internal_call"><tt>mono_add_internal_call</tt> | |||
|  | 	routine. | |||
|  | 
 | |||
|  |  <a name="api:mono_add_internal_call"></a> | |||
|  |  <div class="api"> | |||
|  |     <div class="api-entry">mono_add_internal_call</div> | |||
|  | 
 | |||
|  |     <div class="prototype">Prototype: mono_add_internal_call</div> | |||
|  | <p /> | |||
|  | 
 | |||
|  | 
 | |||
|  | </div><h3>P/Invoke with embedded applications</h3> | |||
|  | 
 | |||
|  | 	<p />Unlike internal calls, Platform/Invoke is easier to use and | |||
|  | 	more portable.  It allows you to share code with Windows and | |||
|  | 	.NET that have a different setup for internal calls to their | |||
|  | 	own runtime. | |||
|  | 
 | |||
|  | 	<p />Usually P/Invoke declarations reference external libraries | |||
|  | 	like: | |||
|  | 
 | |||
|  | 	<pre> | |||
|  | 	[DllImport ("opengl")] | |||
|  | 	void glBegin (GLEnum mode) | |||
|  | 	</pre> | |||
|  | 
 | |||
|  | 	<p />Mono extends P/Invoke to support looking up symbols not in | |||
|  | 	an external library, but looking up those symbols into the | |||
|  | 	same address space as your program, to do this, use the | |||
|  | 	special library name "__Internal".   This will direct Mono to | |||
|  | 	lookup the method in your own process. | |||
|  | 
 | |||
|  | 	<p />There are situations where the host operating system does | |||
|  | 	not support looking up symbols on the process address space. | |||
|  | 	For situations like this you can use | |||
|  | 	the <a href="#api:mono_dl_register_library">mono_dl_register_library</a>.  | |||
|  | 
 | |||
|  | <h4><a name="api:mono_dl_register_library">mono_dl_register_library</a></h4> | |||
|  | 	 | |||
|  | <h3>Data Marshalling</h3> | |||
|  | 
 | |||
|  | 	<p />Managed objects are represented as <tt>MonoObject*</tt> | |||
|  | 	types.  Those objects that the runtime consumes directly have | |||
|  | 	more specific C definitions (for example strings are of type | |||
|  | 	<tt>MonoString *</tt>, delegates are of type | |||
|  | 	<tt>MonoDelegate*</tt> but they are still <tt>MonoObject | |||
|  | 	*</tt>s). | |||
|  | 
 | |||
|  | 	<p />As of Mono 1.2.x types defined in mscorlib.dll do not have | |||
|  | 	their fields reordered in any way.   But other libraries might | |||
|  | 	have their fields reordered.   In these cases, Managed | |||
|  | 	structures and objects have the same layout in the C# code as | |||
|  | 	they do in the unmanaged world. | |||
|  | 
 | |||
|  | 	<p />Structures defined outside corlib must have a specific | |||
|  | 	StructLayout definition, and have it set as sequential if you | |||
|  | 	plan on accessing these fields directly from C code. | |||
|  | 
 | |||
|  | 	<p /><b>Important</b> Internal calls do not provide support for | |||
|  | 	marshalling structures.  This means that any API calls that | |||
|  | 	take a structure (excluding the system types like int32, | |||
|  | 	int64, etc) must be passed as a pointer, in C# this means | |||
|  | 	passing the value as a "ref" or "out" parameter. | |||
|  | 
 | |||
|  | <h3>Mono Runtime Configuration</h3> | |||
|  | 
 | |||
|  | 	<p />Certain features of the Mono runtime, like DLL mapping, are | |||
|  | 	available through a configuration file that is loaded at | |||
|  | 	runtime.   The default Mono implementation loads the | |||
|  | 	configuration file from <tt>$sysconfig/mono/config</tt> | |||
|  | 	(typically this is <tt>/etc/mono/config</tt>). | |||
|  | 
 | |||
|  | 	<p />See the <tt>mono-config(5)</tt> man page for more details | |||
|  | 	on what goes in this file. | |||
|  | 
 | |||
|  | 	<p />The following APIs expose this functionality: | |||
|  | 	 | |||
|  |  <a name="api:mono_config_parse"></a> | |||
|  |  <div class="api"> | |||
|  |     <div class="api-entry">mono_config_parse</div> | |||
|  | 
 | |||
|  |     <div class="prototype">void | |||
|  | mono_config_parse (const char *filename) | |||
|  | </div> | |||
|  | <p /> | |||
|  | <b>Parameters</b> | |||
|  | <blockquote><dt><i>filename:</i></dt><dd> the filename to load the configuration variables from.</dd></blockquote> | |||
|  | <b>Remarks</b> | |||
|  | <p />	  | |||
|  | 	 Pass a NULL filename to parse the default config files | |||
|  | 	 (or the file in the MONO_CONFIG env var). | |||
|  | 
 | |||
|  | </div> <a name="api:mono_config_parse_memory"></a> | |||
|  |  <div class="api"> | |||
|  |     <div class="api-entry">mono_config_parse_memory</div> | |||
|  | 
 | |||
|  |     <div class="prototype">void | |||
|  | mono_config_parse_memory (const char *buffer) | |||
|  | 
 | |||
|  | </div> | |||
|  | <p /> | |||
|  | <b>Parameters</b> | |||
|  | <blockquote><dt><i>buffer:</i></dt><dd> a pointer to an string XML representation of the configuration</dd></blockquote> | |||
|  | <b>Remarks</b> | |||
|  | <p />	  | |||
|  | 	 Parses the configuration from a buffer | |||
|  | 
 | |||
|  | </div> <a name="api:mono_get_config_dir"></a> | |||
|  |  <div class="api"> | |||
|  |     <div class="api-entry">mono_get_config_dir</div> | |||
|  | 
 | |||
|  |     <div class="prototype">Prototype: mono_get_config_dir</div> | |||
|  | <p /> | |||
|  | 
 | |||
|  | 
 | |||
|  | </div><h3>Function Pointers</h3> | |||
|  | 
 | |||
|  | 	<p />To wrap a function pointer into something that the Mono | |||
|  | 	runtime can consume, you should use the mono_create_ftnptr. | |||
|  | 	This is only important if you plan on running on the IA64 | |||
|  | 	architecture.   Otherwise you can just use the function | |||
|  | 	pointer address. | |||
|  | 	 | |||
|  |  <a name="api:mono_create_ftnptr"></a> | |||
|  |  <div class="api"> | |||
|  |     <div class="api-entry">mono_create_ftnptr</div> | |||
|  | 
 | |||
|  |     <div class="prototype">Prototype: mono_create_ftnptr</div> | |||
|  | <p /> | |||
|  | 
 | |||
|  | 
 | |||
|  | </div><h3>Advanced Execution Setups</h3> | |||
|  | 
 | |||
|  | 	<p />These are not recommended ways of initializing Mono, they | |||
|  | 	are done internally by mono_jit_init, but are here to explain | |||
|  | 	what happens internally. | |||
|  | 	 | |||
|  |  <a name="api:mono_runtime_exec_managed_code"></a> | |||
|  |  <div class="api"> | |||
|  |     <div class="api-entry">mono_runtime_exec_managed_code</div> | |||
|  | 
 | |||
|  |     <div class="prototype">void | |||
|  | mono_runtime_exec_managed_code (MonoDomain *domain, | |||
|  | 				MonoMainThreadFunc main_func, | |||
|  | 				gpointer main_args) | |||
|  | 
 | |||
|  | </div> | |||
|  | <p /> | |||
|  | <b>Parameters</b> | |||
|  | <blockquote><dt><i>domain:</i></dt><dd> Application domain</dd><dt><i>main_func:</i></dt><dd> function to invoke from the execution thread</dd><dt><i>main_args:</i></dt><dd> parameter to the main_func</dd></blockquote> | |||
|  | <b>Remarks</b> | |||
|  | <p />	  | |||
|  | 	 Launch a new thread to execute a function | |||
|  | 	 | |||
|  | 	 main_func is called back from the thread with main_args as the | |||
|  | 	 parameter.  The callback function is expected to start Main() | |||
|  | 	 eventually.  This function then waits for all managed threads to | |||
|  | 	 finish. | |||
|  | 	 It is not necesseray anymore to execute managed code in a subthread, | |||
|  | 	 so this function should not be used anymore by default: just | |||
|  | 	 execute the code and then call mono_thread_manage (). | |||
|  | 
 | |||
|  | </div> <a name="api:mono_runtime_exec_main"></a> | |||
|  |  <div class="api"> | |||
|  |     <div class="api-entry">mono_runtime_exec_main</div> | |||
|  | 
 | |||
|  |     <div class="prototype">Prototype: mono_runtime_exec_main</div> | |||
|  | <p /> | |||
|  | 
 | |||
|  | </div> <a name="api:mono_init_from_assembly"></a> | |||
|  |  <div class="api"> | |||
|  |     <div class="api-entry">mono_init_from_assembly</div> | |||
|  | 
 | |||
|  |     <div class="prototype">MonoDomain* | |||
|  | mono_init_from_assembly (const char *domain_name, const char *filename) | |||
|  | 
 | |||
|  | </div> | |||
|  | <p /> | |||
|  | <b>Parameters</b> | |||
|  | <blockquote><dt><i>domain_name:</i></dt><dd> name to give to the initial domain</dd><dt><i>filename:</i></dt><dd> filename to load on startup</dd></blockquote> | |||
|  | <b>Returns</b> | |||
|  | <blockquote>	  the initial domain. | |||
|  | </blockquote> | |||
|  | <b>Remarks</b> | |||
|  | <p />	  | |||
|  | 	 Used by the runtime, users should use mono_jit_init instead. | |||
|  | 	 | |||
|  | 	 Creates the initial application domain and initializes the mono_defaults | |||
|  | 	 structure. | |||
|  | 	 This function is guaranteed to not run any IL code. | |||
|  | 	 The runtime is initialized using the runtime version required by the | |||
|  | 	 provided executable. The version is determined by looking at the exe  | |||
|  | 	 configuration file and the version PE field) | |||
|  | 	 | |||
|  | 
 | |||
|  | </div> <a name="api:mono_init"></a> | |||
|  |  <div class="api"> | |||
|  |     <div class="api-entry">mono_init</div> | |||
|  | 
 | |||
|  |     <div class="prototype">MonoDomain* | |||
|  | mono_init (const char *domain_name) | |||
|  | 
 | |||
|  | </div> | |||
|  | <p /> | |||
|  | <b>Returns</b> | |||
|  | <blockquote>	  the initial domain. | |||
|  | </blockquote> | |||
|  | <b>Remarks</b> | |||
|  | <p />	 <p /> | |||
|  | 
 | |||
|  | 	 Creates the initial application domain and initializes the mono_defaults | |||
|  | 	 structure. | |||
|  | 	 This function is guaranteed to not run any IL code. | |||
|  | 	 The runtime is initialized using the default runtime version. | |||
|  | 	 | |||
|  | 
 | |||
|  | </div></a></body> | |||
|  | </html> | |||
|  | </span> |