linux-packaging-mono/docs/deploy/mono-api-object.html
Xamarin Public Jenkins 4c37e28ac4 Imported Upstream version 4.2.1.102
Former-commit-id: 2d1ae6ac7b9e9737da1189c7f5f700500550c9ea
2015-11-12 04:30:02 -05:00

1134 lines
38 KiB
HTML

<?xml version="1.0" encoding="us-ascii"?><span>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>mono-api-object.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>
<h1>Object API</h1>
<p />The object API deals with all the operations shared by
<a href="#objects">objects</a>, <a href="#valuetypes">value
types</a>, <a href="#arrays">arrays</a>.
<p />The object API has methods for accessing <a href="#fields">fields</a>, <a href="#properties">properties</a>, <a href="#events">events</a>, <a href="#delegates">delegates</a>.
<p />There are some advanced uses that are useful to document
here dealing with <a href="#remote">remote fields</a>.
<h2>Synopsis</h2>
<div class="header">
#include &lt;metadata/object.h&gt;
typedef struct MonoVTable MonoVTable;
typedef struct _MonoThreadsSync MonoThreadsSync;
typedef struct {
MonoVTable *vtable;
MonoThreadsSync *synchronisation;
} MonoObject;
typedef struct {
guint32 length;
guint32 lower_bound;
} MonoArrayBounds;
typedef struct {
MonoObject obj;
/* bounds is NULL for szarrays */
MonoArrayBounds *bounds;
/* total number of elements of the array */
guint32 max_length;
/* we use double to ensure proper alignment on platforms that need it */
double vector [MONO_ZERO_LEN_ARRAY];
} MonoArray;
MonoObject* <a href="#api:mono_object_new">mono_object_new</a> (MonoDomain *domain,
MonoClass *klass);
<a href="#api:mono_object_new_alloc_specific"></a>
<a href="#api:mono_object_new_fast"></a>
MonoObject* <a href="#api:mono_object_new_from_token">mono_object_new_from_token</a> (MonoDomain *domain,
MonoImage *image,
guint32 token);
MonoObject* <a href="#api:mono_object_new_specific">mono_object_new_specific</a> (MonoVTable *vtable);
MonoObject* <a href="#api:mono_object_clone">mono_object_clone</a> (MonoObject *obj);
MonoClass* <a href="#api:mono_object_get_class">mono_object_get_class</a> (MonoObject *obj);
MonoDomain* <a href="#api:mono_object_get_domain">mono_object_get_domain</a> (MonoObject *obj);
MonoMethod* <a href="#api:mono_object_get_virtual_method">mono_object_get_virtual_method</a> (MonoObject *obj,
MonoMethod *method);
<a href="#api:mono_object_isinst_mbyref"></a>
MonoObject* <a href="#api:mono_object_isinst">mono_object_isinst</a> (MonoObject *obj,
MonoClass *klass);
gpointer <a href="#api:mono_object_unbox">mono_object_unbox</a> (MonoObject *obj);
MonoObject* <a href="#api:mono_object_castclass_mbyref">mono_object_castclass_mbyref</a> (MonoObject *obj,
MonoClass *klass);
<a href="#api:mono_object_is_alive"></a>
guint <a href="#api:mono_object_get_size">mono_object_get_size</a> (MonoObject* o);
MonoObject* <a href="#api:mono_value_box">mono_value_box</a> (MonoDomain *domain,
MonoClass *class,
gpointer value);
<a href="#api:mono_value_copy"></a>
<a href="#api:mono_value_copy_array"></a>
MonoArray* <a href="#api:mono_array_new">mono_array_new</a> (MonoDomain *domain,
MonoClass *eclass,
uintptr_t n);
MonoArray* <a href="#api:mono_array_new_full">mono_array_new_full</a> (MonoDomain *domain,
MonoClass *array_class,
uintptr_t *lengths,
intptr_t *lower_bounds);
MonoArray* <a href="#api:mono_array_new_specific">mono_array_new_specific</a> (MonoVTable *vtable,
uintptr_t n);
MonoClass* <a href="#api:mono_array_class_get">mono_array_class_get</a> (MonoClass *eclass,
guint32 rank);
MonoArray* <a href="#api:mono_array_clone">mono_array_clone</a> (MonoArray *array);
<a href="#api:mono_array_set"></a>
<a href="#api:mono_array_setref"></a>
uintptr_t <a href="#api:mono_array_length">mono_array_length</a> (MonoArray *array);
<a href="#api:mono_array_addr"></a>
char* <a href="#api:mono_array_addr_with_size">mono_array_addr_with_size</a> (MonoArray *array,
int size,
uintptr_t idx);
<a href="#api:mono_array_get"></a>
gint32 <a href="#api:mono_array_element_size">mono_array_element_size</a> (MonoClass *ac);
<a href="#api:mono_field_from_token"></a>
<a href="#api:mono_field_get_flags"></a>
const char* <a href="#api:mono_field_get_name">mono_field_get_name</a> (MonoClassField *field);
MonoClass* <a href="#api:mono_field_get_parent">mono_field_get_parent</a> (MonoClassField *field);
MonoType* <a href="#api:mono_field_get_type">mono_field_get_type</a> (MonoClassField *field);
void <a href="#api:mono_field_get_value">mono_field_get_value</a> (MonoObject *obj,
MonoClassField *field,
void *value);
MonoObject* <a href="#api:mono_field_get_value_object">mono_field_get_value_object</a> (MonoDomain *domain,
MonoClassField *field,
MonoObject *obj);
void <a href="#api:mono_field_set_value">mono_field_set_value</a> (MonoObject *obj,
MonoClassField *field,
void *value);
void <a href="#api:mono_field_static_get_value">mono_field_static_get_value</a> (MonoVTable *vt,
MonoClassField *field,
void *value);
void <a href="#api:mono_field_static_set_value">mono_field_static_set_value</a> (MonoVTable *vt,
MonoClassField *field,
void *value);
<a href="#api:mono_field_get_object"></a>
<a href="#api:mono_property_get_object"></a>
guint32 <a href="#api:mono_property_get_flags">mono_property_get_flags</a> (MonoProperty *prop);
MonoMethod* <a href="#api:mono_property_get_get_method">mono_property_get_get_method</a> (MonoProperty *prop);
<a href="#api:mono_property_get_name"></a>
MonoClass* <a href="#api:mono_property_get_parent">mono_property_get_parent</a> (MonoProperty *prop);
MonoMethod* <a href="#api:mono_property_get_set_method">mono_property_get_set_method</a> (MonoProperty *prop);
MonoObject* <a href="#api:mono_property_get_value">mono_property_get_value</a> (MonoProperty *prop,
void *obj,
void **params,
MonoObject **exc);
void <a href="#api:mono_property_set_value">mono_property_set_value</a> (MonoProperty *prop,
void *obj,
void **params,
MonoObject **exc);
<a href="#api:mono_event_get_object"></a>
MonoMethod* <a href="#api:mono_event_get_add_method">mono_event_get_add_method</a> (MonoEvent *event);
guint32 <a href="#api:mono_event_get_flags">mono_event_get_flags</a> (MonoEvent *event);
const char* <a href="#api:mono_event_get_name">mono_event_get_name</a> (MonoEvent *event);
MonoClass* <a href="#api:mono_event_get_parent">mono_event_get_parent</a> (MonoEvent *event);
MonoMethod* <a href="#api:mono_event_get_raise_method">mono_event_get_raise_method</a> (MonoEvent *event);
MonoMethod* <a href="#api:mono_event_get_remove_method">mono_event_get_remove_method</a> (MonoEvent *event);
gpointer <a href="#api:mono_load_remote_field">mono_load_remote_field</a> (MonoObject *this,
MonoClass *klass,
MonoClassField *field,
gpointer *res);
MonoObject* <a href="#api:mono_load_remote_field_new">mono_load_remote_field_new</a> (MonoObject *this,
MonoClass *klass,
MonoClassField *field);
void <a href="#api:mono_store_remote_field">mono_store_remote_field</a> (MonoObject *this,
MonoClass *klass,
MonoClassField *field,
gpointer val);
void <a href="#api:mono_store_remote_field_new">mono_store_remote_field_new</a> (MonoObject *this,
MonoClass *klass,
MonoClassField *field,
MonoObject *arg);
</div>
<p />MonoObject is the base definition for all managed objects
in the Mono runtime, it represents the <a href="http://www.mono-project.com/monodoc/T:System.Object">System.Object</a>
managed type.
<p />All objects that derive from <a href="http://www.mono-project.com/monodoc/T:System.Object">System.Object</a>
do have this base definition. Derived objects are declared
following the pattern where the parent class is the first
field of a structure definition, for example:
<div class="code">
typedef struct {
MonoObject parent;
int my_new_field;
} MyNewObject
</div>
<a name="objects"></a>
<h2>Core Object Methods</h2>
<a name="api:mono_object_new"></a>
<div class="api">
<div class="api-entry">mono_object_new</div>
<div class="prototype">MonoObject*
mono_object_new (MonoDomain *domain, MonoClass *klass)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>klass:</i></dt><dd> the class of the object that we want to create</dd></blockquote>
<b>Returns</b>
<blockquote> a newly created object whose definition is
looked up using <i>klass</i>. This will not invoke any constructors,
so the consumer of this routine has to invoke any constructors on
its own to initialize the object.
<p />
It returns NULL on failure.</blockquote>
<p />For example, if you wanted to create an object of type
System.Version, you would use a piece of code like this:
<div class="code">
MonoClass *version_class;
MonoObject *result;
/* Get the class from mscorlib */
version_class = mono_class_from_name (mono_get_corlib (),
&quot;System&quot;, &quot;Version&quot;);
/* Create an object of that class */
result = mono_object_new (mono_domain_get (), version_class);
</div>
</div> <a name="api:mono_object_new_alloc_specific"></a>
<div class="api">
<div class="api-entry">mono_object_new_alloc_specific</div>
<div class="prototype">Prototype: mono_object_new_alloc_specific</div>
<p />
</div> <a name="api:mono_object_new_fast"></a>
<div class="api">
<div class="api-entry">mono_object_new_fast</div>
<div class="prototype">Prototype: mono_object_new_fast</div>
<p />
</div> <a name="api:mono_object_new_from_token"></a>
<div class="api">
<div class="api-entry">mono_object_new_from_token</div>
<div class="prototype">MonoObject*
mono_object_new_from_token (MonoDomain *domain, MonoImage *image, guint32 token)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>image:</i></dt><dd> Context where the type_token is hosted</dd><dt><i>token:</i></dt><dd> a token of the type that we want to create</dd></blockquote>
<b>Returns</b>
<blockquote> A newly created object whose definition is
looked up using <i>token</i> in the <i>image</i> image</blockquote>
</div> <a name="api:mono_object_new_specific"></a>
<div class="api">
<div class="api-entry">mono_object_new_specific</div>
<div class="prototype">MonoObject*
mono_object_new_specific (MonoVTable *vtable)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>vtable:</i></dt><dd> the vtable of the object that we want to create</dd></blockquote>
<b>Returns</b>
<blockquote> A newly created object with class and domain specified
by <i>vtable</i></blockquote>
</div> <a name="api:mono_object_clone"></a>
<div class="api">
<div class="api-entry">mono_object_clone</div>
<div class="prototype">MonoObject*
mono_object_clone (MonoObject *obj)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>obj:</i></dt><dd> the object to clone</dd></blockquote>
<b>Returns</b>
<blockquote> A newly created object who is a shallow copy of <i>obj</i>
</blockquote>
</div> <a name="api:mono_object_get_class"></a>
<div class="api">
<div class="api-entry">mono_object_get_class</div>
<div class="prototype">MonoClass*
mono_object_get_class (MonoObject *obj)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>obj:</i></dt><dd> object to query</dd></blockquote>
<b>Returns</b>
<blockquote> the MonOClass of the object.
</blockquote>
<b>Remarks</b>
<p /> <p />
</div> <a name="api:mono_object_get_domain"></a>
<div class="api">
<div class="api-entry">mono_object_get_domain</div>
<div class="prototype">MonoDomain*
mono_object_get_domain (MonoObject *obj)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>obj:</i></dt><dd> object to query</dd></blockquote>
<b>Returns</b>
<blockquote> the MonoDomain where the object is hosted
</blockquote>
<b>Remarks</b>
<p /> <p />
</div> <a name="api:mono_object_get_virtual_method"></a>
<div class="api">
<div class="api-entry">mono_object_get_virtual_method</div>
<div class="prototype">MonoMethod*
mono_object_get_virtual_method (MonoObject *obj, MonoMethod *method)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>obj:</i></dt><dd> object to operate on.</dd><dt><i>method:</i></dt><dd> method </dd></blockquote>
<b>Remarks</b>
<p />
Retrieves the MonoMethod that would be called on obj if obj is passed as
the instance of a callvirt of method.
</div> <a name="api:mono_object_isinst_mbyref"></a>
<div class="api">
<div class="api-entry">mono_object_isinst_mbyref</div>
<div class="prototype">Prototype: mono_object_isinst_mbyref</div>
<p />
</div> <a name="api:mono_object_isinst"></a>
<div class="api">
<div class="api-entry">mono_object_isinst</div>
<div class="prototype">MonoObject*
mono_object_isinst (MonoObject *obj, MonoClass *klass)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>obj:</i></dt><dd> an object</dd><dt><i>klass:</i></dt><dd> a pointer to a class </dd></blockquote>
<b>Returns</b>
<blockquote> <i>obj</i> if <i>obj</i> is derived from <i>klass</i>
</blockquote>
</div> <a name="api:mono_object_unbox"></a>
<div class="api">
<div class="api-entry">mono_object_unbox</div>
<div class="prototype">gpointer
mono_object_unbox (MonoObject *obj)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>obj:</i></dt><dd> object to unbox</dd></blockquote>
<b>Returns</b>
<blockquote> a pointer to the start of the valuetype boxed in this
object.
This method will assert if the object passed is not a valuetype.</blockquote>
<b>Remarks</b>
<p /> <p />
</div> <a name="api:mono_object_castclass_mbyref"></a>
<div class="api">
<div class="api-entry">mono_object_castclass_mbyref</div>
<div class="prototype">MonoObject*
mono_object_castclass_mbyref (MonoObject *obj, MonoClass *klass)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>obj:</i></dt><dd> an object</dd><dt><i>klass:</i></dt><dd> a pointer to a class </dd></blockquote>
<b>Returns</b>
<blockquote> <i>obj</i> if <i>obj</i> is derived from <i>klass</i>, throws an exception otherwise
</blockquote>
</div> <a name="api:mono_object_is_alive"></a>
<div class="api">
<div class="api-entry">mono_object_is_alive</div>
<div class="prototype">Prototype: mono_object_is_alive</div>
<p />
</div> <a name="api:mono_object_get_size"></a>
<div class="api">
<div class="api-entry">mono_object_get_size</div>
<div class="prototype">guint
mono_object_get_size (MonoObject* o)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>o:</i></dt><dd> object to query</dd></blockquote>
<b>Returns</b>
<blockquote> the size, in bytes, of <i>o</i>
</blockquote>
<b>Remarks</b>
<p /> <p />
<a name="valuetypes"></a>
</div><h2>Value Types</h2>
<a name="api:mono_value_box"></a>
<div class="api">
<div class="api-entry">mono_value_box</div>
<div class="prototype">MonoObject*
mono_value_box (MonoDomain *domain, MonoClass *class, gpointer value)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>class:</i></dt><dd> the class of the value</dd><dt><i>value:</i></dt><dd> a pointer to the unboxed data</dd></blockquote>
<b>Returns</b>
<blockquote> A newly created object which contains <i>value</i>.
</blockquote>
</div> <a name="api:mono_value_copy"></a>
<div class="api">
<div class="api-entry">mono_value_copy</div>
<div class="prototype">Prototype: mono_value_copy</div>
<p />
</div> <a name="api:mono_value_copy_array"></a>
<div class="api">
<div class="api-entry">mono_value_copy_array</div>
<div class="prototype">Prototype: mono_value_copy_array</div>
<p />
<a name="arrays"></a>
</div><h2>Array Methods</h2>
<p />Use the <tt>mono_array_new_*</tt> methods to create arrays
of a given type.
<p />For example, the following code creates an array with two
elements of type <tt>System.Byte</tt>, and sets the values
0xca and 0xfe on it:
<pre class="code">
MonoArray *CreateByteArray (MonoDomain *domain)
{
MonoArray *data;
data = mono_array_new (domain, mono_get_byte_class (), 2);
mono_array_set (data, guint8, 0, 0xca);
mono_array_set (data, guint8, 0, 0xfe);
return data;
}
</pre>
<h3>Creating Arrays</h3>
<a name="api:mono_array_new"></a>
<div class="api">
<div class="api-entry">mono_array_new</div>
<div class="prototype">MonoArray*
mono_array_new (MonoDomain *domain, MonoClass *eclass, uintptr_t n)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>domain:</i></dt><dd> domain where the object is created</dd><dt><i>eclass:</i></dt><dd> element class</dd><dt><i>n:</i></dt><dd> number of array elements</dd></blockquote>
<b>Remarks</b>
<p />
This routine creates a new szarray with <i>n</i> elements of type <i>eclass</i>.
</div> <a name="api:mono_array_new_full"></a>
<div class="api">
<div class="api-entry">mono_array_new_full</div>
<div class="prototype">MonoArray*
mono_array_new_full (MonoDomain *domain, MonoClass *array_class, uintptr_t *lengths, intptr_t *lower_bounds)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>domain:</i></dt><dd> domain where the object is created</dd><dt><i>array_class:</i></dt><dd> array class</dd><dt><i>lengths:</i></dt><dd> lengths for each dimension in the array</dd><dt><i>lower_bounds:</i></dt><dd> lower bounds for each dimension in the array (may be NULL)</dd></blockquote>
<b>Remarks</b>
<p />
This routine creates a new array objects with the given dimensions,
lower bounds and type.
</div> <a name="api:mono_array_new_specific"></a>
<div class="api">
<div class="api-entry">mono_array_new_specific</div>
<div class="prototype">MonoArray*
mono_array_new_specific (MonoVTable *vtable, uintptr_t n)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>vtable:</i></dt><dd> a vtable in the appropriate domain for an initialized class</dd><dt><i>n:</i></dt><dd> number of array elements</dd></blockquote>
<b>Remarks</b>
<p />
This routine is a fast alternative to mono_array_new() for code which
can be sure about the domain it operates in.
</div> <a name="api:mono_array_class_get"></a>
<div class="api">
<div class="api-entry">mono_array_class_get</div>
<div class="prototype">MonoClass*
mono_array_class_get (MonoClass *eclass, guint32 rank)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>element_class:</i></dt><dd> element class </dd><dt><i>rank:</i></dt><dd> the dimension of the array class</dd></blockquote>
<b>Returns</b>
<blockquote> a class object describing the array with element type <i>element_type</i> and
dimension <i>rank</i>. </blockquote>
</div> <a name="api:mono_array_clone"></a>
<div class="api">
<div class="api-entry">mono_array_clone</div>
<div class="prototype">MonoArray*
mono_array_clone (MonoArray *array)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>array:</i></dt><dd> the array to clone</dd></blockquote>
<b>Returns</b>
<blockquote> A newly created array who is a shallow copy of <i>array</i>
</blockquote>
</div><h3>Using Arrays</h3>
<a name="api:mono_array_set"></a>
<div class="api">
<div class="api-entry">mono_array_set</div>
<div class="prototype">Prototype: mono_array_set</div>
<p />
</div> <a name="api:mono_array_setref"></a>
<div class="api">
<div class="api-entry">mono_array_setref</div>
<div class="prototype">Prototype: mono_array_setref</div>
<p />
</div> <a name="api:mono_array_length"></a>
<div class="api">
<div class="api-entry">mono_array_length</div>
<div class="prototype">uintptr_t
mono_array_length (MonoArray *array)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>array:</i></dt><dd> a MonoArray*</dd></blockquote>
<b>Remarks</b>
<p />
Returns the total number of elements in the array. This works for
both vectors and multidimensional arrays.
</div> <a name="api:mono_array_addr"></a>
<div class="api">
<div class="api-entry">mono_array_addr</div>
<div class="prototype">Prototype: mono_array_addr</div>
<p />
</div> <a name="api:mono_array_addr_with_size"></a>
<div class="api">
<div class="api-entry">mono_array_addr_with_size</div>
<div class="prototype">char*
mono_array_addr_with_size (MonoArray *array, int size, uintptr_t idx)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>array:</i></dt><dd> a MonoArray*</dd><dt><i>size:</i></dt><dd> size of the array elements</dd><dt><i>idx:</i></dt><dd> index into the array</dd></blockquote>
<b>Remarks</b>
<p />
Returns the address of the <i>idx</i> element in the array.
</div> <a name="api:mono_array_get"></a>
<div class="api">
<div class="api-entry">mono_array_get</div>
<div class="prototype">Prototype: mono_array_get</div>
<p />
</div> <a name="api:mono_array_element_size"></a>
<div class="api">
<div class="api-entry">mono_array_element_size</div>
<div class="prototype">gint32
mono_array_element_size (MonoClass *ac)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>ac:</i></dt><dd> pointer to a #MonoArrayClass</dd></blockquote>
<b>Returns</b>
<blockquote> the size of single array element.
</blockquote>
<a name="fields"></a>
</div><h2>Fields</h2>
<a name="api:mono_field_from_token"></a>
<div class="api">
<div class="api-entry">mono_field_from_token</div>
<div class="prototype">Prototype: mono_field_from_token</div>
<p />
</div> <a name="api:mono_field_get_flags"></a>
<div class="api">
<div class="api-entry">mono_field_get_flags</div>
<div class="prototype">Prototype: mono_field_get_flags</div>
<p />
</div> <a name="api:mono_field_get_name"></a>
<div class="api">
<div class="api-entry">mono_field_get_name</div>
<div class="prototype">const char*
mono_field_get_name (MonoClassField *field)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>field:</i></dt><dd> the MonoClassField to act on</dd></blockquote>
<b>Returns</b>
<blockquote> the name of the field.
</blockquote>
</div> <a name="api:mono_field_get_parent"></a>
<div class="api">
<div class="api-entry">mono_field_get_parent</div>
<div class="prototype">MonoClass*
mono_field_get_parent (MonoClassField *field)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>field:</i></dt><dd> the MonoClassField to act on</dd></blockquote>
<b>Returns</b>
<blockquote> MonoClass where the field was defined.
</blockquote>
</div> <a name="api:mono_field_get_type"></a>
<div class="api">
<div class="api-entry">mono_field_get_type</div>
<div class="prototype">MonoType*
mono_field_get_type (MonoClassField *field)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>field:</i></dt><dd> the MonoClassField to act on</dd></blockquote>
<b>Returns</b>
<blockquote> MonoType of the field.
</blockquote>
</div> <a name="api:mono_field_get_value"></a>
<div class="api">
<div class="api-entry">mono_field_get_value</div>
<div class="prototype">void
mono_field_get_value (MonoObject *obj, MonoClassField *field, void *value)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>obj:</i></dt><dd> Object instance</dd><dt><i>field:</i></dt><dd> MonoClassField describing the field to fetch information from</dd><dt><i>value:</i></dt><dd> pointer to the location where the value will be stored</dd></blockquote>
<b>Remarks</b>
<p />
Use this routine to get the value of the field <i>field</i> in the object
passed.
The pointer provided by value must be of the field type, for reference
types this is a MonoObject*, for value types its the actual pointer to
the value type.
For example:
int i;
mono_field_get_value (obj, int_field, &amp;i);
</div> <a name="api:mono_field_get_value_object"></a>
<div class="api">
<div class="api-entry">mono_field_get_value_object</div>
<div class="prototype">MonoObject*
mono_field_get_value_object (MonoDomain *domain, MonoClassField *field, MonoObject *obj)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>domain:</i></dt><dd> domain where the object will be created (if boxing)</dd><dt><i>field:</i></dt><dd> MonoClassField describing the field to fetch information from</dd><dt><i>obj:</i></dt><dd> The object instance for the field.</dd></blockquote>
<b>Returns</b>
<blockquote> a new MonoObject with the value from the given field. If the
field represents a value type, the value is boxed.
</blockquote>
</div> <a name="api:mono_field_set_value"></a>
<div class="api">
<div class="api-entry">mono_field_set_value</div>
<div class="prototype">void
mono_field_set_value (MonoObject *obj, MonoClassField *field, void *value)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>obj:</i></dt><dd> Instance object</dd><dt><i>field:</i></dt><dd> MonoClassField describing the field to set</dd><dt><i>value:</i></dt><dd> The value to be set</dd></blockquote>
<b>Remarks</b>
<p />
Sets the value of the field described by <i>field</i> in the object instance <i>obj</i>
to the value passed in <i>value</i>. This method should only be used for instance
fields. For static fields, use mono_field_static_set_value.
The value must be on the native format of the field type.
</div> <a name="api:mono_field_static_get_value"></a>
<div class="api">
<div class="api-entry">mono_field_static_get_value</div>
<div class="prototype">void
mono_field_static_get_value (MonoVTable *vt, MonoClassField *field, void *value)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>vt:</i></dt><dd> vtable to the object</dd><dt><i>field:</i></dt><dd> MonoClassField describing the field to fetch information from</dd><dt><i>value:</i></dt><dd> where the value is returned</dd></blockquote>
<b>Remarks</b>
<p />
Use this routine to get the value of the static field <i>field</i> value.
The pointer provided by value must be of the field type, for reference
types this is a MonoObject*, for value types its the actual pointer to
the value type.
For example:
int i;
mono_field_static_get_value (vt, int_field, &amp;i);
</div> <a name="api:mono_field_static_set_value"></a>
<div class="api">
<div class="api-entry">mono_field_static_set_value</div>
<div class="prototype">void
mono_field_static_set_value (MonoVTable *vt, MonoClassField *field, void *value)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>field:</i></dt><dd> MonoClassField describing the field to set</dd><dt><i>value:</i></dt><dd> The value to be set</dd></blockquote>
<b>Remarks</b>
<p />
Sets the value of the static field described by <i>field</i>
to the value passed in <i>value</i>.
The value must be on the native format of the field type.
</div> <a name="api:mono_field_get_object"></a>
<div class="api">
<div class="api-entry">mono_field_get_object</div>
<div class="prototype">Prototype: mono_field_get_object</div>
<p />
<a name="properties"></a>
</div><h2>Properties</h2>
<a name="api:mono_property_get_object"></a>
<div class="api">
<div class="api-entry">mono_property_get_object</div>
<div class="prototype">Prototype: mono_property_get_object</div>
<p />
</div> <a name="api:mono_property_get_flags"></a>
<div class="api">
<div class="api-entry">mono_property_get_flags</div>
<div class="prototype">guint32
mono_property_get_flags (MonoProperty *prop)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>prop:</i></dt><dd> the MonoProperty to act on.</dd></blockquote>
<b>Returns</b>
<blockquote> the flags for the property.
</blockquote>
<b>Remarks</b>
<p />
The metadata flags for a property are encoded using the
PROPERTY_ATTRIBUTE_* constants. See the tabledefs.h file for details.
</div> <a name="api:mono_property_get_get_method"></a>
<div class="api">
<div class="api-entry">mono_property_get_get_method</div>
<div class="prototype">MonoMethod*
mono_property_get_get_method (MonoProperty *prop)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>prop:</i></dt><dd> the MonoProperty to act on.</dd></blockquote>
<b>Returns</b>
<blockquote> the setter method of the property (A MonoMethod)
</blockquote>
</div> <a name="api:mono_property_get_name"></a>
<div class="api">
<div class="api-entry">mono_property_get_name</div>
<div class="prototype">Prototype: mono_property_get_name</div>
<p />
</div> <a name="api:mono_property_get_parent"></a>
<div class="api">
<div class="api-entry">mono_property_get_parent</div>
<div class="prototype">MonoClass*
mono_property_get_parent (MonoProperty *prop)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>prop:</i></dt><dd> the MonoProperty to act on.</dd></blockquote>
<b>Returns</b>
<blockquote> the MonoClass where the property was defined.
</blockquote>
</div> <a name="api:mono_property_get_set_method"></a>
<div class="api">
<div class="api-entry">mono_property_get_set_method</div>
<div class="prototype">MonoMethod*
mono_property_get_set_method (MonoProperty *prop)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>prop:</i></dt><dd> the MonoProperty to act on.</dd></blockquote>
<b>Returns</b>
<blockquote> the setter method of the property (A MonoMethod)
</blockquote>
</div> <a name="api:mono_property_get_value"></a>
<div class="api">
<div class="api-entry">mono_property_get_value</div>
<div class="prototype">MonoObject*
mono_property_get_value (MonoProperty *prop, void *obj, void **params, MonoObject **exc)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>prop:</i></dt><dd> MonoProperty to fetch</dd><dt><i>obj:</i></dt><dd> instance object on which to act</dd><dt><i>params:</i></dt><dd> parameters to pass to the propery</dd><dt><i>exc:</i></dt><dd> optional exception</dd></blockquote>
<b>Returns</b>
<blockquote> the value from invoking the get method on the property.
</blockquote>
<b>Remarks</b>
<p />
Invokes the property's get method with the given arguments on the
object instance obj (or NULL for static properties).
<p />
You can pass NULL as the exc argument if you don't want to
catch exceptions, otherwise, *exc will be set to the exception
thrown, if any. if an exception is thrown, you can't use the
MonoObject* result from the function.
</div> <a name="api:mono_property_set_value"></a>
<div class="api">
<div class="api-entry">mono_property_set_value</div>
<div class="prototype">void
mono_property_set_value (MonoProperty *prop, void *obj, void **params, MonoObject **exc)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>prop:</i></dt><dd> MonoProperty to set</dd><dt><i>obj:</i></dt><dd> instance object on which to act</dd><dt><i>params:</i></dt><dd> parameters to pass to the propery</dd><dt><i>exc:</i></dt><dd> optional exception</dd></blockquote>
<b>Remarks</b>
<p />
Invokes the property's set method with the given arguments on the
object instance obj (or NULL for static properties).
<p />
You can pass NULL as the exc argument if you don't want to
catch exceptions, otherwise, *exc will be set to the exception
thrown, if any. if an exception is thrown, you can't use the
MonoObject* result from the function.
<a name="events"></a>
</div><h2>Events</h2>
<a name="api:mono_event_get_object"></a>
<div class="api">
<div class="api-entry">mono_event_get_object</div>
<div class="prototype">Prototype: mono_event_get_object</div>
<p />
</div> <a name="api:mono_event_get_add_method"></a>
<div class="api">
<div class="api-entry">mono_event_get_add_method</div>
<div class="prototype">MonoMethod*
mono_event_get_add_method (MonoEvent *event)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>event:</i></dt><dd> The MonoEvent to act on.</dd></blockquote>
<b>Returns</b>
<blockquote> the <i>add</i>' method for the event (a MonoMethod).
</blockquote>
</div> <a name="api:mono_event_get_flags"></a>
<div class="api">
<div class="api-entry">mono_event_get_flags</div>
<div class="prototype">guint32
mono_event_get_flags (MonoEvent *event)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>event:</i></dt><dd> the MonoEvent to act on.</dd></blockquote>
<b>Returns</b>
<blockquote> the flags for the event.
</blockquote>
<b>Remarks</b>
<p />
The metadata flags for an event are encoded using the
EVENT_* constants. See the tabledefs.h file for details.
</div> <a name="api:mono_event_get_name"></a>
<div class="api">
<div class="api-entry">mono_event_get_name</div>
<div class="prototype">const char*
mono_event_get_name (MonoEvent *event)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>event:</i></dt><dd> the MonoEvent to act on</dd></blockquote>
<b>Returns</b>
<blockquote> the name of the event.
</blockquote>
</div> <a name="api:mono_event_get_parent"></a>
<div class="api">
<div class="api-entry">mono_event_get_parent</div>
<div class="prototype">MonoClass*
mono_event_get_parent (MonoEvent *event)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>event:</i></dt><dd> the MonoEvent to act on.</dd></blockquote>
<b>Returns</b>
<blockquote> the MonoClass where the event is defined.
</blockquote>
</div> <a name="api:mono_event_get_raise_method"></a>
<div class="api">
<div class="api-entry">mono_event_get_raise_method</div>
<div class="prototype">MonoMethod*
mono_event_get_raise_method (MonoEvent *event)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>event:</i></dt><dd> The MonoEvent to act on.</dd></blockquote>
<b>Returns</b>
<blockquote> the <i>raise</i> method for the event (a MonoMethod).
</blockquote>
</div> <a name="api:mono_event_get_remove_method"></a>
<div class="api">
<div class="api-entry">mono_event_get_remove_method</div>
<div class="prototype">MonoMethod*
mono_event_get_remove_method (MonoEvent *event)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>event:</i></dt><dd> The MonoEvent to act on.</dd></blockquote>
<b>Returns</b>
<blockquote> the <i>remove</i> method for the event (a MonoMethod).
</blockquote>
<a name="remote"></a>
</div><h2>Remote Fields</h2>
<a name="api:mono_load_remote_field"></a>
<div class="api">
<div class="api-entry">mono_load_remote_field</div>
<div class="prototype">gpointer
mono_load_remote_field (MonoObject *this, MonoClass *klass, MonoClassField *field, gpointer *res)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>this:</i></dt><dd> pointer to an object</dd><dt><i>klass:</i></dt><dd> klass of the object containing <i>field</i></dd><dt><i>field:</i></dt><dd> the field to load</dd><dt><i>res:</i></dt><dd> a storage to store the result</dd></blockquote>
<b>Returns</b>
<blockquote> an address pointing to the value of field.
</blockquote>
<b>Remarks</b>
<p />
This method is called by the runtime on attempts to load fields of
transparent proxy objects. <i>this</i> points to such TP, <i>klass</i> is the class of
the object containing <i>field</i>. <i>res</i> is a storage location which can be
used to store the result.
</div> <a name="api:mono_load_remote_field_new"></a>
<div class="api">
<div class="api-entry">mono_load_remote_field_new</div>
<div class="prototype">MonoObject*
mono_load_remote_field_new (MonoObject *this, MonoClass *klass, MonoClassField *field)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>this:</i></dt><dd> </dd><dt><i>klass:</i></dt><dd> </dd><dt><i>field:</i></dt><dd></dd></blockquote>
<b>Remarks</b>
<p />
Missing documentation.
</div> <a name="api:mono_store_remote_field"></a>
<div class="api">
<div class="api-entry">mono_store_remote_field</div>
<div class="prototype">void
mono_store_remote_field (MonoObject *this, MonoClass *klass, MonoClassField *field, gpointer val)
</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>this:</i></dt><dd> pointer to an object</dd><dt><i>klass:</i></dt><dd> klass of the object containing <i>field</i></dd><dt><i>field:</i></dt><dd> the field to load</dd><dt><i>val:</i></dt><dd> the value/object to store</dd></blockquote>
<b>Remarks</b>
<p />
This method is called by the runtime on attempts to store fields of
transparent proxy objects. <i>this</i> points to such TP, <i>klass</i> is the class of
the object containing <i>field</i>. <i>val</i> is the new value to store in <i>field</i>.
</div></body>
</html>
</span>