Imported Upstream version 5.2.0.175

Former-commit-id: bb0468d0f257ff100aa895eb5fe583fb5dfbf900
This commit is contained in:
Xamarin Public Jenkins (auto-signing) 2017-06-07 13:16:24 +00:00
parent 4bdbaf4a88
commit 966bba02bb
8776 changed files with 346420 additions and 149650 deletions

View File

@ -45,9 +45,6 @@ dist-hook:
rm -f `find $(top_distdir)/external -path '*\.exe' -not -path '*/roslyn-binaries/*'`
rm -f `find $(top_distdir)/external -path '*\.dll' -not -path '*/binary-reference-assemblies/*' -not -path '*/roslyn-binaries/*'`
mac-sdk-package:
external/bockbuild/bb MacSDK --package
pkgconfigdir = $(libdir)/pkgconfig
noinst_DATA = mono-uninstalled.pc
DISTCLEANFILES= mono-uninstalled.pc

View File

@ -948,9 +948,6 @@ dist-hook:
rm -rf `find $(top_distdir)/external -path '*\.git'`
rm -f `find $(top_distdir)/external -path '*\.exe' -not -path '*/roslyn-binaries/*'`
rm -f `find $(top_distdir)/external -path '*\.dll' -not -path '*/binary-reference-assemblies/*' -not -path '*/roslyn-binaries/*'`
mac-sdk-package:
external/bockbuild/bb MacSDK --package
.PHONY: get-monolite-latest
get-monolite-latest:
-rm -fr $(mcslib)/monolite/$(MONO_CORLIB_VERSION)

View File

@ -29,6 +29,7 @@ The Mono project is part of the [.NET Foundation](http://www.dotnetfoundation.or
| Windows | amd64 | [![windows-amd64][15]][16] |
| Windows | i386 | [![windows-amd64][17]][18] |
| CentOS | s390x (cs) | [![centos-s390x][19]][20] |
| Debian 8 | ppc64el (cs) | [![debian-8-ppc64el][21]][22]|
_(cs) = community supported architecture_
@ -50,8 +51,10 @@ _(cs) = community supported architecture_
[16]: https://jenkins.mono-project.com/job/z/label=w64/
[17]: https://jenkins.mono-project.com/job/z/label=w32/badge/icon
[18]: https://jenkins.mono-project.com/job/z/label=w32/
[19]: https://jenkins.mono-project.com/job/z/label=centos-s390x/badge/icon
[20]: https://jenkins.mono-project.com/job/z/label=centos-s390x
[19]: https://jenkins.mono-project.com/job/test-mono-mainline-community/label=centos-s390x/badge/icon
[20]: https://jenkins.mono-project.com/job/test-mono-mainline-community/label=centos-s390x
[21]: https://jenkins.mono-project.com/job/test-mono-mainline-community-chroot/label=debian-8-ppc64el/badge/icon
[22]: https://jenkins.mono-project.com/job/test-mono-mainline-community-chroot/label=debian-8-ppc64el
Compilation and Installation
============================

View File

@ -18,7 +18,7 @@
{
"name": "ms-test-suite",
"url": "git@github.com:xamarin/ms-test-suite.git",
"rev": "55b6637eb1de61c743323ec82db1e0cadfee5b32",
"rev": "73c155f76b55839f26ba707d6d40091060e4f5d8",
"remote-branch": "origin/master",
"branch": "master",
"directory": "ms-test-suite"

View File

@ -15,9 +15,6 @@
/* Disable support for multiple appdomains. */
#undef DISABLE_APPDOMAINS
/* Disable assembly remapping. */
#undef DISABLE_ASSEMBLY_REMAPPING
/* Disable agent attach support */
#undef DISABLE_ATTACH
@ -30,6 +27,9 @@
/* Disable System.Decimal support */
#undef DISABLE_DECIMAL
/* Disable desktop assembly loader semantics. */
#undef DISABLE_DESKTOP_LOADER
/* Disable generics support */
#undef DISABLE_GENERICS
@ -142,7 +142,7 @@
/* Icall symbol map enabled */
#undef ENABLE_ICALL_SYMBOL_MAP
/* Enable interpreter in the runtime. */
/* Enable Interpreter */
#undef ENABLE_INTERPRETER
/* Enable the LLVM back end */
@ -488,6 +488,9 @@
/* Define to 1 if you have the <linux/serial.h> header file. */
#undef HAVE_LINUX_SERIAL_H
/* Define to 1 if you have the `localtime_r' function. */
#undef HAVE_LOCALTIME_R
/* Define to 1 if you have the `lockf' function. */
#undef HAVE_LOCKF
@ -503,6 +506,9 @@
/* Have mincore */
#undef HAVE_MINCORE
/* Define to 1 if you have the `mkdtemp' function. */
#undef HAVE_MKDTEMP
/* Define to 1 if you have the `mknodat' function. */
#undef HAVE_MKNODAT
@ -824,6 +830,9 @@
/* Define to 1 if you have the <sys/epoll.h> header file. */
#undef HAVE_SYS_EPOLL_H
/* Define to 1 if you have the <sys/errno.h> header file. */
#undef HAVE_SYS_ERRNO_H
/* Define to 1 if you have the <sys/event.h> header file. */
#undef HAVE_SYS_EVENT_H
@ -1037,7 +1046,7 @@
/* Enable lazy gc thread creation by the embedding host. */
#undef LAZY_GC_THREAD_CREATION
/* Full version of LLVM libraties */
/* Full version of LLVM libraries */
#undef LLVM_VERSION
/* Define to the sub-directory in which libtool stores uninstalled libraries.

View File

@ -1 +1 @@
54cea42c8c6bfe077b1977bc3905769ad937e124
48d34844b9ae0c66ad031a44de6c7687c4c9b49b

View File

@ -1 +1 @@
3ac346edc244dc2c78aa095b77807d043420bd49
0256ba4d773c9c56b5f4df4ca3befad03ba0df26

View File

@ -18,8 +18,14 @@
<dllmap dll="sqlite3" target="@SQLITE3@" os="!windows"/>
<dllmap dll="libX11" target="@X11@" os="!windows" />
<dllmap dll="libgdk-x11-2.0" target="@GDKX11@" os="!windows"/>
<dllmap dll="libgdk_pixbuf-2.0" target="libgdk_pixbuf-2.0.so.0" os="!windows"/>
<dllmap dll="libgtk-x11-2.0" target="@GTKX11@" os="!windows"/>
<dllmap dll="libglib-2.0" target="libglib-2.0.so.0" os="!windows"/>
<dllmap dll="libgobject-2.0" target="libgobject-2.0.so.0" os="!windows"/>
<dllmap dll="libgnomeui-2" target="libgnomeui-2.so.0" os="!windows"/>
<dllmap dll="librsvg-2" target="librsvg-2.so.2" os="!windows"/>
<dllmap dll="libXinerama" target="@XINERAMA@" os="!windows" />
<dllmap dll="libasound" target="libasound.so.2" os="!windows" />
<dllmap dll="libcairo-2.dll" target="libcairo.so.2" os="!windows"/>
<dllmap dll="libcairo-2.dll" target="libcairo.2.dylib" os="osx"/>
<dllmap dll="libcups" target="libcups.so.2" os="!windows"/>

View File

@ -9,16 +9,38 @@ def print_frames(thread, num_frames, current_thread):
for frame in thread.frames[:+num_frames]:
pc = str(frame.addr)
fmt = ' %c %s'
var = frame
if pc[0] == '0':
function_name = frame.GetFunctionName()
if function_name == "ves_exec_method_with_context":
try:
s = 'frame->runtime_method->method'
klassname = frame.EvaluateExpression('(char*) ' + s + '->klass->name').summary[1:-1]
methodname = frame.EvaluateExpression('(char*) ' + s + '->name').summary[1:-1]
ipoffset = frame.EvaluateExpression('ip').GetValueAsUnsigned()
insn = ''
if ipoffset != 0:
ipoffset -= frame.EvaluateExpression('rtm->code').GetValueAsUnsigned()
insn = "\"" + frame.EvaluateExpression('mono_interp_opname [*ip]').summary[1:-1] + "\""
var = '%s::%s @ %d %s || %s' % (klassname, methodname, ipoffset, insn, frame)
except Exception as e:
print "DBG: execfail:" + str(e)
elif function_name == "mono_interp_transform_method":
try:
s = 'runtime_method->method'
klassname = frame.EvaluateExpression('(char*) ' + s + '->klass->name').summary[1:-1]
methodname = frame.EvaluateExpression('(char*) ' + s + '->name').summary[1:-1]
var = 'transforming %s::%s || %s' % (klassname, methodname, frame)
except Exception as e:
print "DBG: transformfail:" + str(e)
elif pc[0] == '0':
try:
framestr = frame.EvaluateExpression('(char*)mono_pmip((void*)%s)' % pc).summary[1:-1]
var = 'frame #%i: %s%s' % (frame.idx, pc, framestr)
except:
pass
print fmt % ('*' if current_thread and frame.idx == selected_frame.idx else ' ', var)
print ' %c %s' % ('*' if current_thread and frame.idx == selected_frame.idx else ' ', var)
def monobt(debugger, command, result, dict):
opts = {'all_bt': False, 'num_frames': None}
@ -53,4 +75,5 @@ def __lldb_init_module (debugger, dict):
# This initializer is being run from LLDB in the embedded command interpreter
# Add any commands contained in this module to LLDB
debugger.HandleCommand('command script add -f monobt.monobt monobt')
print '"monobt" command installed'
debugger.HandleCommand('command alias mbt monobt')
print '"monobt" command installed'

View File

@ -87,7 +87,7 @@ mono-file-formats.zip: mono-file-formats.tree
mono-file-formats.tree: $(srcdir)/docs.make $(srcdir)/Makefile.am $(srcdir)/deploy/.stamp
$(TOOL_MAKE) $@
deploy/.stamp: convert.exe Makefile.am
deploy/.stamp: convert.exe Makefile.am exdoc
$(mkdir_p) html
runtimedir=`cd ../runtime && pwd`; export runtimedir; \
MONO_PATH=$(CLASS) perl $(srcdir)/exdoc -h $(srcdir) -t . $(srcdir)/../mono/*/*.c

View File

@ -666,7 +666,7 @@ mono-file-formats.zip: mono-file-formats.tree
mono-file-formats.tree: $(srcdir)/docs.make $(srcdir)/Makefile.am $(srcdir)/deploy/.stamp
$(TOOL_MAKE) $@
deploy/.stamp: convert.exe Makefile.am
deploy/.stamp: convert.exe Makefile.am exdoc
$(mkdir_p) html
runtimedir=`cd ../runtime && pwd`; export runtimedir; \
MONO_PATH=$(CLASS) perl $(srcdir)/exdoc -h $(srcdir) -t . $(srcdir)/../mono/*/*.c

View File

@ -26,7 +26,7 @@ some combination of the two.
To be clearer, and give an idea of what the algorithm can and
cannot do without describing it in detail... keep in mind that
only "redunant" checks cannot be removed. By "redundant", I
only "redundant" checks cannot be removed. By "redundant", I
mean "already explicitly checked" in the method code.
Unfortunately, analyzing complex expressions is not so easy
@ -136,7 +136,7 @@ some combination of the two.
In the first case, the BB has exactly two exit BBs, and their
execution conditions are easy to get from the condition of the
branch (see the "get_relation_from_branch_instruction"
function, and expecially the end of "analyze_block" in
function, and especially the end of "analyze_block" in
abcremoval.c.
If there is a switch, the jump condition of every exit BB is
@ -303,7 +303,7 @@ some combination of the two.
each BB tried to examine all possible conditions between all
variables, filling a sort of "evaluation matrix". The problem
was that the complexity of this evaluation was quadratic (or
worse) on the number of variables, and that many wariables
worse) on the number of variables, and that many variables
were examined even if they were not involved in any array
access.
@ -332,7 +332,7 @@ some combination of the two.
[1b] Prepare the evaluation graph (empty)
[1b] Summarize each varible definition, and put
[1b] Summarize each variable definition, and put
the resulting relations in the evaluation
graph

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

View File

@ -243,11 +243,8 @@ mono_counters_dump (int section_mask, FILE *outfile)
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>section_mask</i><td> The sections to dump counters for</td></td></tr><tr><td><i>outfile</i><td> a FILE to dump the results to</td></td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> <p />
Displays the counts of all the enabled counters registered.
To filter by variance, you can OR one or more variance with the specific section you want.
Use MONO_COUNTER_SECTION_MASK to dump all categories of a specific variance.</div>
<table class="mapi-parameters"><tbody><tr><td><i>section_mask</i></td><td> The sections to dump counters for</td></tr><tr><td><i>outfile</i></td><td> a FILE to dump the results to</td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> Displays the counts of all the enabled counters registered. To filter by variance, you can OR one or more variance with the specific section you want. Use <code>MONO_COUNTER_SECTION_MASK</code> to dump all categories of a specific variance.</div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -267,11 +264,7 @@ mono_counters_enable (int section_mask)
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>section_mask</i><td> a mask listing the sections that will be displayed</td></td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> <p />
This is used to track which counters will be displayed.</div>
<table class="mapi-parameters"><tbody><tr><td><i>sectionmask</i></td><td> a mask listing the sections that will be displayed</td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> This is used to track which counters will be displayed.</div>
</div><!--mapi-description -->
</div><!--height container -->
</div>
</div></body>
</html>

View File

@ -234,7 +234,11 @@
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_debug_open_mono_symbols</div>
<div class="mapi-prototype">MonoSymbolFile*
mono_debug_open_mono_symbols (MonoDebugHandle *handle, const uint8_t *raw_contents,
int size, gboolean in_the_debugger)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -249,8 +253,13 @@
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_debug_symfile_free_location</div>
<div class="mapi-prototype">void
mono_debug_symfile_free_location (MonoDebugSourceLocation *location)
</div>
<p />
<div class="mapi-section">Description</div>
<div> <p /> Free a <code>MonoDebugSourceLocation</code> returned by <code>mono_debug_symfile_lookup_location</code></div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -264,7 +273,10 @@
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_debug_symfile_is_loaded</div>
<div class="mapi-prototype">mono_bool
mono_debug_symfile_is_loaded (MonoSymbolFile *symfile)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -279,8 +291,13 @@
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_debug_symfile_lookup_locals</div>
<div class="mapi-prototype">MonoDebugLocalsInfo*
mono_debug_symfile_lookup_locals (MonoDebugMethodInfo *minfo)
</div>
<p />
<div class="mapi-section">Description</div>
<div> <p /> Return information about the local variables of <i>minfo</i> from the symbol file. Return <code>NULL</code> if no information can be found. The result should be freed using <code>mono_debug_symfile_free_locals</code>.</div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -300,13 +317,8 @@ mono_debug_symfile_lookup_location (MonoDebugMethodInfo *minfo, uint32_t offset)
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>minfo</i><td> A `MonoDebugMethodInfo' which can be retrieved by</td></td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> mono_debug_lookup_method().
<i>offset</i>: IL offset within the corresponding method's CIL code.
<p />
This function is similar to mono_debug_lookup_location(), but we
already looked up the method and also already did the
`native address -&gt; IL offset' mapping.</div>
<table class="mapi-parameters"><tbody><tr><td><i>minfo</i></td><td> A <code>MonoDebugMethodInfo</code> which can be retrieved by <code>mono_debug_lookup_method</code>.</td></tr><tr><td><i>offset</i></td><td> IL offset within the corresponding method's CIL code.</td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> <p /> This function is similar to <code>mono_debug_lookup_location</code>, but we already looked up the method and also already did the native address -&gt; IL offset mapping.</div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -320,7 +332,10 @@ mono_debug_symfile_lookup_location (MonoDebugMethodInfo *minfo, uint32_t offset)
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_debug_symfile_lookup_method</div>
<div class="mapi-prototype">MonoDebugMethodInfo*
mono_debug_symfile_lookup_method (MonoDebugHandle *handle, MonoMethod *method)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -338,7 +353,10 @@ mono_debug_symfile_lookup_location (MonoDebugMethodInfo *minfo, uint32_t offset)
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_debug_add_delegate_trampoline</div>
<div class="mapi-prototype">void
mono_debug_add_delegate_trampoline (gpointer code, int size)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -353,7 +371,10 @@ mono_debug_symfile_lookup_location (MonoDebugMethodInfo *minfo, uint32_t offset)
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_debug_close_image</div>
<div class="mapi-prototype">void
mono_debug_close_image (MonoImage *image)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -368,7 +389,10 @@ mono_debug_symfile_lookup_location (MonoDebugMethodInfo *minfo, uint32_t offset)
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_debug_domain_create</div>
<div class="mapi-prototype">void
mono_debug_domain_create (MonoDomain *domain)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -404,8 +428,7 @@ mono_debug_enabled (void)
</div>
<p />
<div class="mapi-section">Description</div>
<div> <p />
Returns true is debug information is enabled. This doesn't relate if a debugger is present or not.</div>
<div> <p /> Returns true is debug information is enabled. This doesn't relate if a debugger is present or not.</div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -440,9 +463,8 @@ mono_debug_free_source_location (MonoDebugSourceLocation *location)
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>location</i><td> A `MonoDebugSourceLocation'.</td></td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> <p />
Frees the <i>location</i>.</div>
<table class="mapi-parameters"><tbody><tr><td><i>location</i></td><td> A <code>MonoDebugSourceLocation</code></td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> Frees the <i>location</i>.</div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -477,10 +499,7 @@ mono_debug_lookup_method (MonoMethod *method)
</div>
<p />
<div class="mapi-section">Description</div>
<div> <p />
Lookup symbol file information for the method <i>method</i>. The returned
`MonoDebugMethodInfo' is a private structure, but it can be passed to
mono_debug_symfile_lookup_location().</div>
<div> <p /> Lookup symbol file information for the method <i>method</i>. The returned <code>MonoDebugMethodInfo</code> is a private structure, but it can be passed to <code>mono_debug_symfile_lookup_location</code>.</div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -515,14 +534,8 @@ mono_debug_lookup_source_location (MonoMethod *method, guint32 address, MonoDoma
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>address</i><td> Native offset within the <i>method</i>'s machine code.</td></td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> <p />
Lookup the source code corresponding to the machine instruction located at
native offset <i>address</i> within <i>method</i>.
<p />
The returned `MonoDebugSourceLocation' contains both file / line number
information and the corresponding IL offset. It must be freed by
mono_debug_free_source_location().</div>
<table class="mapi-parameters"><tbody><tr><td><i>address</i></td><td> Native offset within the <i>method</i>'s machine code.</td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> Lookup the source code corresponding to the machine instruction located at native offset <i>address</i> within <i>method</i>. The returned <code>MonoDebugSourceLocation</code> contains both file / line number information and the corresponding IL offset. It must be freed by <code>mono_debug_free_source_location</code>.</div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -557,10 +570,8 @@ mono_debug_print_stack_frame (MonoMethod *method, guint32 native_offset, MonoDom
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>native_offset</i><td> Native offset within the <i>method</i>'s machine code.</td></td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> <p />
Conventient wrapper around mono_debug_lookup_source_location() which can be
used if you only want to use the location to print a stack frame.</div>
<table class="mapi-parameters"><tbody><tr><td><i>native_offset</i></td><td> Native offset within the <i>method</i>'s machine code.</td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> Conventient wrapper around <code>mono_debug_lookup_source_location</code> which can be used if you only want to use the location to print a stack frame.</div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -595,9 +606,7 @@ mono_debug_il_offset_from_address (MonoMethod *method, MonoDomain *domain, guint
</div>
<p />
<div class="mapi-section">Description</div>
<div> <p />
Compute the IL offset corresponding to NATIVE_OFFSET inside the native
code of METHOD in DOMAIN.</div>
<div> <p /> Compute the IL offset corresponding to <i>native_offset</i> inside the native code of <i>method</i> in <i>domain</i>.</div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -611,7 +620,10 @@ mono_debug_il_offset_from_address (MonoMethod *method, MonoDomain *domain, guint
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_debug_add_method</div>
<div class="mapi-prototype">MonoDebugMethodAddress*
mono_debug_add_method (MonoMethod *method, MonoDebugMethodJitInfo *jit, MonoDomain *domain)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -626,10 +638,10 @@ mono_debug_il_offset_from_address (MonoMethod *method, MonoDomain *domain, guint
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_debug_close_mono_symbol_file</div>
<div class="mapi-prototype">void
mono_debug_close_mono_symbol_file (MonoSymbolFile *symfile)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
</div>
</div></body>
</html>

View File

@ -202,43 +202,6 @@ typedef struct _MonoDomain MonoDomain;
/* Represents System.Runtime.Remoting.Contexts.Context */
typedef struct _MonoAppContext MonoAppContext
MonoAssembly* <a href="#api:mono_domain_assembly_open">mono_domain_assembly_open</a> (MonoDomain *domain,
const char *name);
MonoDomain* <a href="#api:mono_domain_create">mono_domain_create</a> (void);
MonoDomain* <a href="#api:mono_domain_create_appdomain">mono_domain_create_appdomain</a> (char *friendly_name,
char *configuration_file);
gboolean <a href="#api:mono_domain_finalize">mono_domain_finalize</a> (MonoDomain *domain,
guint32 timeout) ;
void <a href="#api:mono_domain_foreach">mono_domain_foreach</a> (MonoDomainFunc func,
gpointer user_data);
void <a href="#api:mono_domain_free">mono_domain_free</a> (MonoDomain *domain,
gboolean force);
<a href="#api:mono_domain_from_appdomain">mono_domain_from_appdomain</a>
MonoDomain* <a href="#api:mono_domain_get_by_id">mono_domain_get_by_id</a> (gint32 domainid) ;
<a href="#api:mono_domain_get_friendly_name">mono_domain_get_friendly_name</a>
<a href="#api:mono_domain_get_id">mono_domain_get_id</a>
MonoDomain* <a href="#api:mono_domain_get">mono_domain_get</a> ();
gboolean <a href="#api:mono_domain_has_type_resolve">mono_domain_has_type_resolve</a> (MonoDomain *domain);
<a href="#api:mono_domain_is_unloading">mono_domain_is_unloading</a>
gboolean <a href="#api:mono_domain_owns_vtable_slot">mono_domain_owns_vtable_slot</a> (MonoDomain *domain,
gpointer vtable_slot);
void <a href="#api:mono_domain_set_config">mono_domain_set_config</a> (MonoDomain *domain,
const char *base_dir,
const char *config_file_name);
void <a href="#api:mono_domain_set_internal">mono_domain_set_internal</a> (MonoDomain *domain);
gboolean <a href="#api:mono_domain_set">mono_domain_set</a> (MonoDomain *domain,
gboolean force);
MonoReflectionAssembly* <a href="#api:mono_domain_try_type_resolve">mono_domain_try_type_resolve</a> (MonoDomain *domain,
char *name,
MonoObject *tb);
<a href="#api:mono_domain_try_unload">mono_domain_try_unload</a>
<a href="#api:mono_domain_unload">mono_domain_unload</a>
void <a href="#api:mono_context_init">mono_context_init</a> (MonoDomain *domain);
MonoAppContext* <a href="#api:mono_context_get">mono_context_get</a> (void);
gint32 <a href="#api:mono_context_get_domain_id">mono_context_get_domain_id</a> (MonoAppContext *context);
gint32 <a href="#api:mono_context_get_id">mono_context_get_id</a> (MonoAppContext *context);
<a href="#api:mono_context_set">mono_context_set</a>
<a href="#api:mono_context_get_desc">mono_context_get_desc</a>
</div>
@ -271,10 +234,7 @@ mono_domain_assembly_open (MonoDomain *domain, const char *name)
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>domain</i><td> the application domain</td></td></tr><tr><td><i>name</i><td> file name of the assembly</td></td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> <p />
fixme: maybe we should integrate this with mono_assembly_open ??</div>
</div><!--mapi-description -->
<table class="mapi-parameters"><tbody><tr><td><i>domain</i></td><td> the application domain</td></tr><tr><td><i>name</i></td><td> file name of the assembly</td></tr></tbody></table> </div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -293,26 +253,11 @@ mono_domain_create (void)
</div>
<p />
<div class="mapi-section">Return value</div>
<div> New initialized MonoDomain, with no configuration or assemblies
<div> New initialized <code>MonoDomain</code>, with no configuration or assemblies
loaded into it.</div>
<div class="mapi-section">Description</div>
<div> <p />
Creates a new application domain, the unmanaged representation
of the actual domain. Usually you will want to create the
<p />
Application domains provide an isolation facilty for assemblies. You
can load assemblies and execute code in them that will not be visible
to other application domains. This is a runtime-based virtualization
technology.
<p />
It is possible to unload domains, which unloads the assemblies and
data that was allocated in that domain.
<p />
When a domain is created a mempool is allocated for domain-specific
structures, along a dedicated code manager to hold code that is
associated with the domain.
<p /></div>
<div> <p /> Creates a new application domain, the unmanaged representation of the actual domain. <p /> Application domains provide an isolation facilty for assemblies. You can load assemblies and execute code in them that will not be visible to other application domains. This is a runtime-based virtualization technology. <p /> It is possible to unload domains, which unloads the assemblies and data that was allocated in that domain. <p /> When a domain is created a mempool is allocated for domain-specific structures, along a dedicated code manager to hold code that is associated with the domain. <p /></div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -332,9 +277,9 @@ mono_domain_create_appdomain (char *friendly_name, char *configuration_file)
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>friendly_name</i><td> The friendly name of the appdomain to create</td></td></tr><tr><td><i>configuration_file</i><td> The configuration file to initialize the appdomain with</td></td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> <p />
Returns a MonoDomain initialized with the appdomain</div>
<table class="mapi-parameters"><tbody><tr><td><i>friendly_name</i></td><td> The friendly name of the appdomain to create</td></tr><tr><td><i>configuration_file</i></td><td> The configuration file to initialize the appdomain with</td></tr></tbody></table> <div class="mapi-section">Return value</div>
<div> a <code>MonoDomain</code> initialized with the appdomain
</div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -348,21 +293,17 @@ mono_domain_create_appdomain (char *friendly_name, char *configuration_file)
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">
gboolean
<div class="mapi-prototype">gboolean
mono_domain_finalize (MonoDomain *domain, guint32 timeout)
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>domain</i><td> the domain to finalize</td></td></tr><tr><td><i>timeout</i><td> msects to wait for the finalization to complete, -1 to wait indefinitely</td></td></tr></tbody></table> <div class="mapi-section">Return value</div>
<div> <code>TRUE</code> if succeeded, <code>FALSE</code> if there was a timeout
<table class="mapi-parameters"><tbody><tr><td><i>domain</i></td><td> the domain to finalize</td></tr><tr><td><i>timeout</i></td><td> msecs to wait for the finalization to complete, <code>-1</code> to wait indefinitely</td></tr></tbody></table> <div class="mapi-section">Return value</div>
<div> <code>TRUE</code> if succeeded, <code>FALSE</code> if there was a timeout
</div>
<div class="mapi-section">Description</div>
<div> <p />
Request finalization of all finalizable objects inside <i>domain</i>. Wait
<i>timeout</i> msecs for the finalization to complete.
<p /></div>
<div> <p /> Request finalization of all finalizable objects inside <i>domain</i>. Wait <i>timeout</i> msecs for the finalization to complete. <p /></div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -382,12 +323,8 @@ mono_domain_foreach (MonoDomainFunc func, gpointer user_data)
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>func</i><td> function to invoke with the domain data</td></td></tr><tr><td><i>user_data</i><td> user-defined pointer that is passed to the supplied <i>func</i> fo reach domain</td></td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> <p />
Use this method to safely iterate over all the loaded application
domains in the current runtime. The provided <i>func</i> is invoked with a
pointer to the MonoDomain and is given the value of the <i>user_data</i>
parameter which can be used to pass state to your called routine.</div>
<table class="mapi-parameters"><tbody><tr><td><i>func</i></td><td> function to invoke with the domain data</td></tr><tr><td><i>user_data</i></td><td> user-defined pointer that is passed to the supplied <i>func</i> fo reach domain</td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> <p /> Use this method to safely iterate over all the loaded application domains in the current runtime. The provided <i>func</i> is invoked with a pointer to the <code>MonoDomain</code> and is given the value of the <i>user_data</i> parameter which can be used to pass state to your called routine.</div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -407,11 +344,8 @@ mono_domain_free (MonoDomain *domain, gboolean force)
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>domain</i><td> the domain to release</td></td></tr><tr><td><i>force</i><td> if true, it allows the root domain to be released (used at shutdown only).</td></td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> <p />
This releases the resources associated with the specific domain.
This is a low-level function that is invoked by the AppDomain infrastructure
when necessary.</div>
<table class="mapi-parameters"><tbody><tr><td><i>domain</i></td><td> the domain to release</td></tr><tr><td><i>force</i></td><td> if <code>TRUE</code>, it allows the root domain to be released (used at shutdown only).</td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> <p /> This releases the resources associated with the specific domain. This is a low-level function that is invoked by the AppDomain infrastructure when necessary.</div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -425,7 +359,10 @@ mono_domain_free (MonoDomain *domain, gboolean force)
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_domain_from_appdomain</div>
<div class="mapi-prototype">MonoDomain*
mono_domain_from_appdomain (MonoAppDomain *appdomain_raw)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -446,11 +383,9 @@ mono_domain_get_by_id (gint32 domainid)
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>domainid</i><td> the ID</td></td></tr></tbody></table> <div class="mapi-section">Return value</div>
<div> the domain for a specific domain id.
<table class="mapi-parameters"><tbody><tr><td><i>domainid</i></td><td> the ID</td></tr></tbody></table> <div class="mapi-section">Return value</div>
<div> the domain for a specific domain id.
</div>
<div class="mapi-section">Description</div>
<div> <p /> </div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -464,8 +399,16 @@ mono_domain_get_by_id (gint32 domainid)
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_domain_get_friendly_name</div>
<div class="mapi-prototype">const char *
mono_domain_get_friendly_name (MonoDomain *domain)
</div>
<p />
<div class="mapi-section">Return value</div>
<div> The friendly name of <i>domain</i>. Can be <code>NULL</code> if not yet set.
</div>
<div class="mapi-section">Description</div>
<div> <p /> The returned string's lifetime is the same as <i>domain</i>'s. Consider copying it if you need to store it somewhere. <p /></div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -479,8 +422,16 @@ mono_domain_get_by_id (gint32 domainid)
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_domain_get_id</div>
<div class="mapi-prototype">gint32
mono_domain_get_id (MonoDomain *domain)
</div>
<p />
<div class="mapi-section">Return value</div>
<div> The unique ID for <i>domain</i>.
</div>
<div class="mapi-section">Description</div>
<div> <p /> A domain ID is guaranteed to be unique for as long as the domain using it is alive. It may be reused later once the domain has been unloaded. <p /></div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -500,14 +451,10 @@ mono_domain_get ()
</div>
<p />
<div class="mapi-section">Return value</div>
<div> the current domain
<div> the current domain
</div>
<div class="mapi-section">Description</div>
<div> <p />
This method returns the value of the current MonoDomain that this thread
and code are running under. To obtain the root domain use
mono_get_root_domain() API.
<p /></div>
<div> <p /> This method returns the value of the current <code>MonoDomain</code> that this thread and code are running under. To obtain the root domain use <code>mono_get_root_domain</code> API. <p /></div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -527,12 +474,11 @@ mono_domain_has_type_resolve (MonoDomain *domain)
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>domain</i><td> application domains being looked up</td></td></tr></tbody></table> <div class="mapi-section">Return value</div>
<div> <code>TRUE</code> if the AppDomain.TypeResolve field has been
set.</div>
<table class="mapi-parameters"><tbody><tr><td><i>domain</i></td><td> application domain being looked up</td></tr></tbody></table> <div class="mapi-section">Return value</div>
<div> <code>TRUE</code> if the <code>AppDomain.TypeResolve</code> field has been set.
</div>
<div class="mapi-section">Description</div>
<div> <p /> </div>
<div> <p /></div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -546,7 +492,10 @@ mono_domain_has_type_resolve (MonoDomain *domain)
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_domain_is_unloading</div>
<div class="mapi-prototype">gboolean
mono_domain_is_unloading (MonoDomain *domain)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -566,9 +515,9 @@ mono_domain_owns_vtable_slot (MonoDomain *domain, gpointer vtable_slot)
</div>
<p />
<div class="mapi-section">Description</div>
<div> <p />
Returns whenever VTABLE_SLOT is inside a vtable which belongs to DOMAIN.</div>
<div class="mapi-section">Return value</div>
<div> Whether <i>vtable_slot</i> is inside a vtable which belongs to <i>domain</i>.
</div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -588,13 +537,8 @@ mono_domain_set_config (MonoDomain *domain, const char *base_dir, const char *co
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>domain</i><td> MonoDomain initialized with the appdomain we want to change</td></td></tr><tr><td><i>base_dir</i><td> new base directory for the appdomain</td></td></tr><tr><td><i>config_file_name</i><td> path to the new configuration for the app domain</td></td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> <p />
Used to set the system configuration for an appdomain
<p />
Without using this, embedded builds will get 'System.Configuration.ConfigurationErrorsException:
Error Initializing the configuration system. ---&gt; System.ArgumentException:
The 'ExeConfigFilename' argument cannot be null.' for some managed calls.</div>
<table class="mapi-parameters"><tbody><tr><td><i>domain</i></td><td> <code>MonoDomain</code> initialized with the appdomain we want to change</td></tr><tr><td><i>base_dir</i></td><td> new base directory for the appdomain</td></tr><tr><td><i>config_file_name</i></td><td> path to the new configuration for the app domain</td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> <p /> Used to set the system configuration for an appdomain <p /> Without using this, embedded builds will get 'System.Configuration.ConfigurationErrorsException: Error Initializing the configuration system. ---&gt; System.ArgumentException: The 'ExeConfigFilename' argument cannot be null.' for some managed calls.</div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -614,9 +558,8 @@ mono_domain_set_internal (MonoDomain *domain)
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>domain</i><td> the new domain</td></td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> <p />
Sets the current domain to <i>domain</i>.</div>
<table class="mapi-parameters"><tbody><tr><td><i>domain</i></td><td> the new domain</td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> <p /> Sets the current domain to <i>domain</i>.</div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -636,16 +579,11 @@ mono_domain_set (MonoDomain *domain, gboolean force)
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>domain</i><td> domain</td></td></tr><tr><td><i>force</i><td> force setting.</td></td></tr></tbody></table> <div class="mapi-section">Return value</div>
<div>
<code>TRUE</code> on success;
<code>FALSE</code> if the domain is unloaded</div>
<table class="mapi-parameters"><tbody><tr><td><i>domain</i></td><td> domain</td></tr><tr><td><i>force</i></td><td> force setting.</td></tr></tbody></table> <div class="mapi-section">Return value</div>
<div> <code>TRUE</code> on success; <code>FALSE</code> if the domain is unloaded
</div>
<div class="mapi-section">Description</div>
<div> <p />
Set the current appdomain to <i>domain</i>. If <i>force</i> is set, set it even
if it is being unloaded.
<p /></div>
<div> <p /> Set the current appdomain to <i>domain</i>. If <i>force</i> is set, set it even if it is being unloaded. <p /></div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -665,16 +603,11 @@ mono_domain_try_type_resolve (MonoDomain *domain, char *name, MonoObject *tb)
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>domain</i><td> application domainwhere the name where the type is going to be resolved</td></td></tr><tr><td><i>name</i><td> the name of the type to resolve or <code>NULL</code>.</td></td></tr><tr><td><i>tb</i><td> A System.Reflection.Emit.TypeBuilder, used if name is <code>NULL</code>.</td></td></tr></tbody></table> <div class="mapi-section">Return value</div>
<div> A MonoReflectionAssembly or <code>NULL</code> if not found
<table class="mapi-parameters"><tbody><tr><td><i>domain</i></td><td> application domainwhere the name where the type is going to be resolved</td></tr><tr><td><i>name</i></td><td> the name of the type to resolve or <code>NULL</code>.</td></tr><tr><td><i>tb</i></td><td> A <code>System.Reflection.Emit.TypeBuilder</code>, used if name is <code>NULL</code>.</td></tr></tbody></table> <div class="mapi-section">Return value</div>
<div> A <code>MonoReflectionAssembly</code> or <code>NULL</code> if not found
</div>
<div class="mapi-section">Description</div>
<div> <p />
This routine invokes the internal System.AppDomain.DoTypeResolve and returns
the assembly that matches name.
<p />
If <i>name</i> is null, the value of ((TypeBuilder)tb).FullName is used instead
<p /></div>
<div> <p /> This routine invokes the internal <code>System.AppDomain.DoTypeResolve</code> and returns the assembly that matches name. <p /> If <i>name</i> is null, the value of <code>((TypeBuilder)tb).FullName</code> is used instead <p /></div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -703,8 +636,14 @@ mono_domain_try_type_resolve (MonoDomain *domain, char *name, MonoObject *tb)
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_domain_unload</div>
<div class="mapi-prototype">void
mono_domain_try_unload (MonoDomain *domain, MonoObject **exc)
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>domain</i></td><td> The domain to unload</td></tr><tr><td><i>exc</i></td><td> Exception information</td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> <p /> Unloads an appdomain. Follows the process outlined in: http://blogs.gotdotnet.com/cbrumme <p /> If doing things the 'right' way is too hard or complex, we do it the 'simple' way, which means do everything needed to avoid crashes and memory leaks, but not much else. <p /> It is required to pass a valid reference to the exc argument, upon return from this function *exc will be set to the exception thrown, if any. <p /> If this method is not called from an icall (embedded scenario for instance), it must not be called with any managed frames on the stack, since the unload process could end up trying to abort the current thread.</div>
</div><!--mapi-description -->
</div><!--height container -->
@ -727,9 +666,8 @@ mono_context_init (MonoDomain *domain)
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>domain</i><td> The domain where the System.Runtime.Remoting.Context.Context is initialized</td></td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> <p />
Initializes the <i>domain</i>'s default System.Runtime.Remoting's Context.</div>
<table class="mapi-parameters"><tbody><tr><td><i>domain</i></td><td> The domain where the <code>System.Runtime.Remoting.Context.Context</code> is initialized</td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> Initializes the <i>domain</i>'s default <code>System.Runtime.Remoting</code> 's Context.</div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -749,10 +687,10 @@ mono_context_get (void)
</div>
<p />
<div class="mapi-section">Return value</div>
<div> the current Mono Application Context.
<div> the current Mono Application Context.
</div>
<div class="mapi-section">Description</div>
<div> <p /> </div>
<div> <p /></div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -772,11 +710,9 @@ mono_context_get_domain_id (MonoAppContext *context)
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>context</i><td> the context to operate on.</td></td></tr></tbody></table> <div class="mapi-section">Return value</div>
<div> The ID of the domain that <i>context</i> was created in.
<table class="mapi-parameters"><tbody><tr><td><i>context</i></td><td> the context to operate on.</td></tr></tbody></table> <div class="mapi-section">Return value</div>
<div> The ID of the domain that <i>context</i> was created in.
</div>
<div class="mapi-section">Description</div>
<div> <p /> </div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -796,14 +732,11 @@ mono_context_get_id (MonoAppContext *context)
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>context</i><td> the context to operate on.</td></td></tr></tbody></table> <div class="mapi-section">Return value</div>
<div> The unique ID for <i>context</i>.
<table class="mapi-parameters"><tbody><tr><td><i>context</i></td><td> the context to operate on.</td></tr></tbody></table> <div class="mapi-section">Return value</div>
<div> The unique ID for <i>context</i>.
</div>
<div class="mapi-section">Description</div>
<div> <p />
Context IDs are guaranteed to be unique for the duration of a Mono
process; they are never reused.
<p /></div>
<div> <p /> Context IDs are guaranteed to be unique for the duration of a Mono process; they are never reused. <p /></div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -817,10 +750,10 @@ mono_context_get_id (MonoAppContext *context)
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_context_set</div>
<div class="mapi-prototype">void
mono_context_set (MonoAppContext * new_context)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
</div>
</div></body>
</html>

View File

@ -276,7 +276,10 @@ MonoMethod *adder ()
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_mb_new</div>
<div class="mapi-prototype">MonoMethodBuilder*
mono_mb_new (MonoClass *klass, const char *name, MonoWrapperType type)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -326,7 +329,10 @@ MonoMethod *adder ()
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_mb_emit_add_to_local</div>
<div class="mapi-prototype">void
mono_mb_emit_add_to_local (MonoMethodBuilder *mb, guint16 local, gint32 incr)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -341,7 +347,10 @@ MonoMethod *adder ()
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_mb_emit_branch</div>
<div class="mapi-prototype">guint32
mono_mb_emit_branch (MonoMethodBuilder *mb, guint8 op)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -356,7 +365,10 @@ MonoMethod *adder ()
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_mb_emit_byte</div>
<div class="mapi-prototype">void
mono_mb_emit_byte (MonoMethodBuilder *mb, guint8 op)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -371,7 +383,10 @@ MonoMethod *adder ()
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_mb_emit_exception</div>
<div class="mapi-prototype">void
mono_mb_emit_exception (MonoMethodBuilder *mb, const char *exc_name, const char *msg)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -386,7 +401,10 @@ MonoMethod *adder ()
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_mb_emit_i2</div>
<div class="mapi-prototype">void
mono_mb_emit_i2 (MonoMethodBuilder *mb, gint16 data)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -401,7 +419,10 @@ MonoMethod *adder ()
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_mb_emit_i4</div>
<div class="mapi-prototype">void
mono_mb_emit_i4 (MonoMethodBuilder *mb, gint32 data)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -416,7 +437,10 @@ MonoMethod *adder ()
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_mb_emit_icon</div>
<div class="mapi-prototype">void
mono_mb_emit_icon (MonoMethodBuilder *mb, gint32 value)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -431,7 +455,10 @@ MonoMethod *adder ()
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_mb_emit_ldarg_addr</div>
<div class="mapi-prototype">void
mono_mb_emit_ldarg_addr (MonoMethodBuilder *mb, guint argnum)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -446,7 +473,10 @@ MonoMethod *adder ()
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_mb_emit_ldarg</div>
<div class="mapi-prototype">void
mono_mb_emit_ldarg (MonoMethodBuilder *mb, guint argnum)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -461,7 +491,10 @@ MonoMethod *adder ()
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_mb_emit_ldflda</div>
<div class="mapi-prototype">void
mono_mb_emit_ldflda (MonoMethodBuilder *mb, gint32 offset)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -476,7 +509,10 @@ MonoMethod *adder ()
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_mb_emit_ldloc_addr</div>
<div class="mapi-prototype">void
mono_mb_emit_ldloc_addr (MonoMethodBuilder *mb, guint locnum)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -491,7 +527,10 @@ MonoMethod *adder ()
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_mb_emit_ldloc</div>
<div class="mapi-prototype">void
mono_mb_emit_ldloc (MonoMethodBuilder *mb, guint num)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -506,7 +545,10 @@ MonoMethod *adder ()
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_mb_emit_ldstr</div>
<div class="mapi-prototype">void
mono_mb_emit_ldstr (MonoMethodBuilder *mb, char *str)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -521,7 +563,10 @@ MonoMethod *adder ()
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_mb_emit_managed_call</div>
<div class="mapi-prototype">void
mono_mb_emit_managed_call (MonoMethodBuilder *mb, MonoMethod *method, MonoMethodSignature *opt_sig)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -536,7 +581,10 @@ MonoMethod *adder ()
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_mb_emit_native_call</div>
<div class="mapi-prototype">void
mono_mb_emit_native_call (MonoMethodBuilder *mb, MonoMethodSignature *sig, gpointer func)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -551,7 +599,10 @@ MonoMethod *adder ()
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_mb_emit_stloc</div>
<div class="mapi-prototype">void
mono_mb_emit_stloc (MonoMethodBuilder *mb, guint num)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -574,12 +625,10 @@ mono_mb_create_method (MonoMethodBuilder *mb, MonoMethodSignature *signature, in
</div>
<p />
<div class="mapi-section">Return value</div>
<div> the newly created method.
<p /></div>
<div> the newly created method.
</div>
<div class="mapi-section">Description</div>
<div> <p />
Create a MonoMethod from this method builder.</div>
<div> Create a <code>MonoMethod</code> from this method builder.</div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -593,7 +642,10 @@ mono_mb_create_method (MonoMethodBuilder *mb, MonoMethodSignature *signature, in
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_mb_add_data</div>
<div class="mapi-prototype">guint32
mono_mb_add_data (MonoMethodBuilder *mb, gpointer data)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -608,7 +660,10 @@ mono_mb_create_method (MonoMethodBuilder *mb, MonoMethodSignature *signature, in
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_mb_add_local</div>
<div class="mapi-prototype">int
mono_mb_add_local (MonoMethodBuilder *mb, MonoType *type)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -623,7 +678,10 @@ mono_mb_create_method (MonoMethodBuilder *mb, MonoMethodSignature *signature, in
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_mb_free</div>
<div class="mapi-prototype">void
mono_mb_free (MonoMethodBuilder *mb)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -640,7 +698,10 @@ mono_mb_create_method (MonoMethodBuilder *mb, MonoMethodSignature *signature, in
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_mb_patch_addr</div>
<div class="mapi-prototype">void
mono_mb_patch_addr (MonoMethodBuilder *mb, int pos, int value)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -655,7 +716,10 @@ mono_mb_create_method (MonoMethodBuilder *mb, MonoMethodSignature *signature, in
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_mb_patch_addr_s</div>
<div class="mapi-prototype">void
mono_mb_patch_addr_s (MonoMethodBuilder *mb, int pos, gint8 value)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -672,8 +736,17 @@ mono_mb_create_method (MonoMethodBuilder *mb, MonoMethodSignature *signature, in
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_metadata_signature_alloc</div>
<div class="mapi-prototype">MonoMethodSignature*
mono_metadata_signature_alloc (MonoImage *m, guint32 nparams)
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>image</i></td><td> metadata context</td></tr><tr><td><i>nparams</i></td><td> number of parameters in the signature</td></tr></tbody></table> <div class="mapi-section">Return value</div>
<div> the new <code>MonoMethodSignature</code> structure.
</div>
<div class="mapi-section">Description</div>
<div> <p /> Allocate a <code>MonoMethodSignature</code> structure with the specified number of params. The return type and the params types need to be filled later. This is a Mono runtime internal function. <p /> LOCKING: Assumes the loader lock is held. <p /></div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -687,10 +760,16 @@ mono_mb_create_method (MonoMethodBuilder *mb, MonoMethodSignature *signature, in
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_metadata_signature_dup</div>
<div class="mapi-prototype">MonoMethodSignature*
mono_metadata_signature_dup (MonoMethodSignature *sig)
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>sig</i></td><td> method signature</td></tr></tbody></table> <div class="mapi-section">Return value</div>
<div> the new <code>MonoMethodSignature</code> structure.
</div>
<div class="mapi-section">Description</div>
<div> <p /> Duplicate an existing <code>MonoMethodSignature</code> so it can be modified. This is a Mono runtime internal function. <p /></div>
</div><!--mapi-description -->
</div><!--height container -->
</div>
</div></body>
</html>

View File

@ -258,7 +258,10 @@ getMessage ()
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_jit_init</div>
<div class="mapi-prototype">MonoDomain*
mono_jit_init (const char *file)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -273,8 +276,13 @@ getMessage ()
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_jit_parse_options</div>
<div class="mapi-prototype">void
mono_jit_parse_options (int argc, char * argv[])
</div>
<p />
<div class="mapi-section">Description</div>
<div> <p /> Process the command line options in <i>argv</i> as done by the runtime executable. This should be called before <code>mono_jit_init</code>.</div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -294,9 +302,8 @@ mono_jit_exec (MonoDomain *domain, MonoAssembly *assembly, int argc, char *argv[
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>assembly</i><td> reference to an assembly</td></td></tr><tr><td><i>argc</i><td> argument count</td></td></tr><tr><td><i>argv</i><td> argument vector</td></td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> <p />
Start execution of a program.</div>
<table class="mapi-parameters"><tbody><tr><td><i>assembly</i></td><td> reference to an assembly</td></tr><tr><td><i>argc</i></td><td> argument count</td></tr><tr><td><i>argv</i></td><td> argument vector</td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> Start execution of a program.</div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -316,27 +323,8 @@ mono_set_dirs (const char *assembly_dir, const char *config_dir)
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>assembly_dir</i><td> the base directory for assemblies</td></td></tr><tr><td><i>config_dir</i><td> the base directory for configuration files</td></td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> <p />
This routine is used internally and by developers embedding
the runtime into their own applications.
<p />
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.
<p />
If you are using a system-installed Mono, you can pass <code>NULL</code>
to both parameters. If you are not, you should compute both
directory values and call this routine.
<p />
The values for a given PREFIX are:
<p />
assembly_dir: PREFIX/lib
config_dir: PREFIX/etc
<p />
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>
<table class="mapi-parameters"><tbody><tr><td><i>assembly_dir</i></td><td> the base directory for assemblies</td></tr><tr><td><i>config_dir</i></td><td> the base directory for configuration files</td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> <p /> This routine is used internally and by developers embedding the runtime into their own applications. <p /> 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. <p /> If you are using a system-installed Mono, you can pass <code>NULL</code> to both parameters. If you are not, you should compute both directory values and call this routine. <p /> The values for a given PREFIX are: <p /> assembly_dir: PREFIX/lib config_dir: PREFIX/etc <p /> 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>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -350,7 +338,10 @@ mono_set_dirs (const char *assembly_dir, const char *config_dir)
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_parse_default_optimizations</div>
<div class="mapi-prototype">int
mono_parse_default_optimizations (const char* p)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -371,10 +362,8 @@ mono_runtime_set_main_args (int argc, char* argv[])
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>argc</i><td> number of arguments from the command line</td></td></tr><tr><td><i>argv</i><td> array of strings from the command line</td></td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> <p />
Set the command line arguments from an embedding application that doesn't otherwise call
mono_runtime_run_main ().</div>
<table class="mapi-parameters"><tbody><tr><td><i>argc</i></td><td> number of arguments from the command line</td></tr><tr><td><i>argv</i></td><td> array of strings from the command line</td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> Set the command line arguments from an embedding application that doesn't otherwise call <code>mono_runtime_run_main</code>.</div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -388,7 +377,10 @@ mono_runtime_set_main_args (int argc, char* argv[])
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_jit_cleanup</div>
<div class="mapi-prototype">void
mono_jit_cleanup (MonoDomain *domain)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -409,14 +401,11 @@ mono_jit_set_trace_options (const char* options)
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>options</i><td> string representing the trace options</td></td></tr></tbody></table> <div class="mapi-section">Return value</div>
<div> #<code>TRUE</code> if the options where parsed and set correctly, #<code>FALSE</code> otherwise.
<table class="mapi-parameters"><tbody><tr><td><i>options</i></td><td> string representing the trace options</td></tr></tbody></table> <div class="mapi-section">Return value</div>
<div> <code>TRUE</code> if the options were parsed and set correctly, <code>FALSE</code> otherwise.
</div>
<div class="mapi-section">Description</div>
<div> <p />
Set the options of the tracing engine. This function can be called before initializing
the mono runtime. See the --trace mono(1) manpage for the options format.
<p /></div>
<div> Set the options of the tracing engine. This function can be called before initializing the mono runtime. See the --trace mono(1) manpage for the options format. <p /></div>
</div><!--mapi-description -->
</div><!--height container -->
@ -455,38 +444,8 @@ mono_add_internal_call (const char *name, gconstpointer method)
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>name</i><td> method specification to surface to the managed world</td></td></tr><tr><td><i>method</i><td> pointer to a C method to invoke when the method is called</td></td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> <p />
This method surfaces the C function pointed by <i>method</i> as a method
that has been surfaced in managed code with the method specified in
<i>name</i> as an internal call.
<p />
Internal calls are surfaced to all app domains loaded and they are
accessibly by a type with the specified name.
<p />
You must provide a fully qualified type name, that is namespaces
and type name, followed by a colon and the method name, with an
optional signature to bind.
<p />
For example, the following are all valid declarations:
<p />
&quot;MyApp.Services.ScriptService:Accelerate&quot;
&quot;MyApp.Services.ScriptService:Slowdown(int,bool)&quot;
<p />
You use method parameters in cases where there might be more than
one surface method to managed code. That way you can register different
internal calls for different method overloads.
<p />
The internal calls are invoked with no marshalling. This means that .NET
types like System.String are exposed as `MonoString *` parameters. This is
different than the way that strings are surfaced in P/Invoke.
<p />
For more information on how the parameters are marshalled, see the
<a href="http://www.mono-project.com/docs/advanced/embedding/">Mono Embedding</a>
page.
<p />
See the <a href="mono-api-methods.html&lt;code&gt;method&lt;/code&gt;-desc">Method Description</a>
reference for more information on the format of method descriptions.</div>
<table class="mapi-parameters"><tbody><tr><td><i>name</i></td><td> method specification to surface to the managed world</td></tr><tr><td><i>method</i></td><td> pointer to a C method to invoke when the method is called</td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> <p /> This method surfaces the C function pointed by <i>method</i> as a method that has been surfaced in managed code with the method specified in <i>name</i> as an internal call. <p /> Internal calls are surfaced to all app domains loaded and they are accessibly by a type with the specified name. <p /> You must provide a fully qualified type name, that is namespaces and type name, followed by a colon and the method name, with an optional signature to bind. <p /> For example, the following are all valid declarations: <p /> <code>MyApp.Services.ScriptService:Accelerate</code> <p /> <code>MyApp.Services.ScriptService:Slowdown(int,bool)</code> <p /> You use method parameters in cases where there might be more than one surface method to managed code. That way you can register different internal calls for different method overloads. <p /> The internal calls are invoked with no marshalling. This means that .NET types like <code>System.String</code> are exposed as <code>MonoString*</code> parameters. This is different than the way that strings are surfaced in P/Invoke. <p /> For more information on how the parameters are marshalled, see the <a href="http://www.mono-project.com/docs/advanced/embedding/">Mono Embedding</a> page. <p /> See the <a href="mono-api-methods.html&lt;code&gt;method&lt;/code&gt;-desc">Method Description</a> reference for more information on the format of method descriptions.</div>
</div><!--mapi-description -->
</div><!--height container -->
@ -566,7 +525,10 @@ mono_add_internal_call (const char *name, gconstpointer method)
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_config_cleanup</div>
<div class="mapi-prototype">void
mono_config_cleanup (void)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -581,7 +543,10 @@ mono_add_internal_call (const char *name, gconstpointer method)
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_config_is_server_mode</div>
<div class="mapi-prototype">mono_bool
mono_config_is_server_mode (void)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -601,10 +566,8 @@ mono_config_parse (const char *filename)
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>filename</i><td> the filename to load the configuration variables from.</td></td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> <p />
Pass a <code>NULL</code> filename to parse the default config files
(or the file in the MONO_CONFIG env var).</div>
<table class="mapi-parameters"><tbody><tr><td><i>filename</i></td><td> the filename to load the configuration variables from.</td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> Pass a <code>NULL</code> filename to parse the default config files (or the file in the <code>MONO_CONFIG</code> env var).</div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -624,9 +587,8 @@ mono_config_parse_memory (const char *buffer)
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>buffer</i><td> a pointer to an string XML representation of the configuration</td></td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> <p />
Parses the configuration from a buffer</div>
<table class="mapi-parameters"><tbody><tr><td><i>buffer</i></td><td> a pointer to an string XML representation of the configuration</td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> Parses the configuration from a buffer</div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -640,7 +602,10 @@ mono_config_parse_memory (const char *buffer)
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_config_set_server_mode</div>
<div class="mapi-prototype">void
mono_config_set_server_mode (mono_bool server_mode)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -655,7 +620,10 @@ mono_config_parse_memory (const char *buffer)
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_config_string_for_assembly_file</div>
<div class="mapi-prototype">const char *
mono_config_string_for_assembly_file (const char *filename)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -670,7 +638,10 @@ mono_config_parse_memory (const char *buffer)
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_get_config_dir</div>
<div class="mapi-prototype">const char*
mono_get_config_dir (void)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -685,7 +656,10 @@ mono_config_parse_memory (const char *buffer)
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_get_machine_config</div>
<div class="mapi-prototype">const char *
mono_get_machine_config (void)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -700,7 +674,10 @@ mono_config_parse_memory (const char *buffer)
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_register_machine_config</div>
<div class="mapi-prototype">void
mono_register_machine_config (const char *config_xml)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -715,8 +692,13 @@ mono_config_parse_memory (const char *buffer)
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_set_config_dir</div>
<div class="mapi-prototype">void
mono_set_config_dir (const char *dir)
</div>
<p />
<div class="mapi-section">Description</div>
<div> Invoked during startup</div>
</div><!--mapi-description -->
</div><!--height container -->
@ -745,17 +727,8 @@ mono_runtime_exec_managed_code (MonoDomain *domain,
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>domain</i><td> Application domain</td></td></tr><tr><td><i>main_func</i><td> function to invoke from the execution thread</td></td></tr><tr><td><i>main_args</i><td> parameter to the main_func</td></td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> <p />
Launch a new thread to execute a function
<p />
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>
<table class="mapi-parameters"><tbody><tr><td><i>domain</i></td><td> Application domain</td></tr><tr><td><i>main_func</i></td><td> function to invoke from the execution thread</td></tr><tr><td><i>main_args</i></td><td> parameter to the main_func</td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> Launch a new thread to execute a function <p /> <i>main_func</i> is called back from the thread with main_args as the parameter. The callback function is expected to start <code>Main</code> eventually. This function then waits for all managed threads to finish. It is not necessary 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>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -790,16 +763,10 @@ mono_init (const char *domain_name)
</div>
<p />
<div class="mapi-section">Return value</div>
<div> the initial domain.
<div> the initial domain.
</div>
<div class="mapi-section">Description</div>
<div> <p />
Creates the initial application domain and initializes the mono_defaults
structure.
<p />
This function is guaranteed to not run any IL code.
The runtime is initialized using the default runtime version.
<p /></div>
<div> <p /> Creates the initial application domain and initializes the mono_defaults structure. <p /> This function is guaranteed to not run any IL code. The runtime is initialized using the default runtime version. <p /></div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -819,20 +786,11 @@ mono_init_from_assembly (const char *domain_name, const char *filename)
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>domain_name</i><td> name to give to the initial domain</td></td></tr><tr><td><i>filename</i><td> filename to load on startup</td></td></tr></tbody></table> <div class="mapi-section">Return value</div>
<div> the initial domain.
<table class="mapi-parameters"><tbody><tr><td><i>domain_name</i></td><td> name to give to the initial domain</td></tr><tr><td><i>filename</i></td><td> filename to load on startup</td></tr></tbody></table> <div class="mapi-section">Return value</div>
<div> the initial domain.
</div>
<div class="mapi-section">Description</div>
<div> <p />
Used by the runtime, users should use mono_jit_init instead.
<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 runtime version required by the
provided executable. The version is determined by looking at the exe
configuration file and the version PE field)
<p /></div>
<div> <p /> Used by the runtime, users should use mono_jit_init instead. <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 runtime version required by the provided executable. The version is determined by looking at the exe configuration file and the version PE field) <p /></div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -852,18 +810,10 @@ mono_init_version (const char *domain_name, const char *version)
</div>
<p />
<div class="mapi-section">Return value</div>
<div> the initial domain.
<div> the initial domain.
</div>
<div class="mapi-section">Description</div>
<div> <p />
Used by the runtime, users should use mono_jit_init instead.
<p />
Creates the initial application domain and initializes the mono_defaults
structure.
<p />
This function is guaranteed to not run any IL code.
The runtime is initialized using the provided rutime version.
<p /></div>
<div> <p /> Used by the runtime, users should use <code>mono_jit_init</code> instead. <p /> Creates the initial application domain and initializes the <code>mono_defaults</code> structure. <p /> This function is guaranteed to not run any IL code. The runtime is initialized using the provided rutime version. <p /></div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -883,9 +833,8 @@ mono_jit_exec (MonoDomain *domain, MonoAssembly *assembly, int argc, char *argv[
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>assembly</i><td> reference to an assembly</td></td></tr><tr><td><i>argc</i><td> argument count</td></td></tr><tr><td><i>argv</i><td> argument vector</td></td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> <p />
Start execution of a program.</div>
<table class="mapi-parameters"><tbody><tr><td><i>assembly</i></td><td> reference to an assembly</td></tr><tr><td><i>argc</i></td><td> argument count</td></tr><tr><td><i>argv</i></td><td> argument vector</td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> Start execution of a program.</div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -899,7 +848,10 @@ mono_jit_exec (MonoDomain *domain, MonoAssembly *assembly, int argc, char *argv[
<div class="mapi-ptr"></div>
<div class="mapi-declaration mapi-section">Syntax</div>
<div class="mapi-prototype">mono_jit_set_aot_mode</div>
<div class="mapi-prototype">void
mono_jit_set_aot_mode (MonoAotMode mode)
</div>
<p />
</div><!--mapi-description -->
</div><!--height container -->
@ -920,18 +872,8 @@ mono_set_break_policy (MonoBreakPolicyFunc policy_callback)
</div>
<p />
<div class="mapi-section">Parameters</div>
<table class="mapi-parameters"><tbody><tr><td><i>policy_callback</i><td> the new callback function</td></td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> <p />
Allow embedders to decide wherther to actually obey breakpoint instructions
(both break IL instructions and Debugger.Break () method calls), for example
to not allow an app to be aborted by a perfectly valid IL opcode when executing
untrusted or semi-trusted code.
<p />
<i>policy_callback</i> will be called every time a break point instruction needs to
be inserted with the method argument being the method that calls Debugger.Break()
or has the IL break instruction. The callback should return <code>MONO_BREAK_POLICY_NEVER</code>
if it wants the breakpoint to not be effective in the given method.
<code>MONO_BREAK_POLICY_ALWAYS</code> is the default.</div>
<table class="mapi-parameters"><tbody><tr><td><i>policy_callback</i></td><td> the new callback function</td></tr></tbody></table> <div class="mapi-section">Description</div>
<div> <p /> Allow embedders to decide wherther to actually obey breakpoint instructions (both break IL instructions and <code>Debugger.Break</code> method calls), for example to not allow an app to be aborted by a perfectly valid IL opcode when executing untrusted or semi-trusted code. <p /> <i>policy_callback</i> will be called every time a break point instruction needs to be inserted with the method argument being the method that calls <code>Debugger.Break</code> or has the IL <code>break</code> instruction. The callback should return <code>MONO_BREAK_POLICY_NEVER</code> if it wants the breakpoint to not be effective in the given method. <code>MONO_BREAK_POLICY_ALWAYS</code> is the default.</div>
</div><!--mapi-description -->
</div><!--height container -->
</div> <!-- class=mapi -->
@ -950,11 +892,11 @@ mono_get_runtime_build_info (void)
</div>
<p />
<div class="mapi-section">Return value</div>
<div> the runtime version + build date in string format.
</div>
<div class="mapi-section">Description</div>
<div> <p />
Return the runtime version + build date in string format.
The returned string is owned by the caller. The returned string
format is &quot;VERSION (FULL_VERSION BUILD_DATE)&quot; and build date is optional.</div>
<div> The returned string is owned by the caller. The returned string format is <code>VERSION (FULL_VERSION BUILD_DATE)</code> and build date is optional.</div>
</div><!--mapi-description -->
</div><!--height container -->
@ -977,18 +919,6 @@ mono_set_signal_chaining (gboolean chain_signals)
</div>
<p />
<div class="mapi-section">Description</div>
<div> <p />
Enable/disable signal chaining. This should be called before mono_jit_init ().
If signal chaining is enabled, the runtime saves the original signal handlers before
installing its own handlers, and calls the original ones in the following cases:
- a SIGSEGV/SIGABRT signal received while executing native (i.e. not JITted) code.
- SIGPROF
- SIGFPE
- SIGQUIT
- SIGUSR2
Signal chaining only works on POSIX platforms.</div>
<div> <p /> Enable/disable signal chaining. This should be called before <code>mono_jit_init</code>. If signal chaining is enabled, the runtime saves the original signal handlers before installing its own handlers, and calls the original ones in the following cases: - a <code>SIGSEGV</code> / <code>SIGABRT</code> signal received while executing native (i.e. not JITted) code. - <code>SIGPROF</code> - <code>SIGFPE</code> - <code>SIGQUIT</code> - <code>SIGUSR2</code> Signal chaining only works on POSIX platforms.</div>
</div><!--mapi-description -->
</div><!--height container -->
</div>
</div></body>
</html>

File diff suppressed because it is too large Load Diff

Some files were not shown because too many files have changed in this diff Show More