1 #ifndef _MONO_CLI_OBJECT_H_
2 #define _MONO_CLI_OBJECT_H_
4 #include <mono/metadata/class.h>
5 #include <mono/utils/mono-error.h>
9 typedef mono_byte MonoBoolean;
11 typedef struct _MonoString MonoString;
12 typedef struct _MonoArray MonoArray;
13 typedef struct _MonoReflectionMethod MonoReflectionMethod;
14 typedef struct _MonoReflectionAssembly MonoReflectionAssembly;
15 typedef struct _MonoReflectionModule MonoReflectionModule;
16 typedef struct _MonoReflectionField MonoReflectionField;
17 typedef struct _MonoReflectionProperty MonoReflectionProperty;
18 typedef struct _MonoReflectionEvent MonoReflectionEvent;
19 typedef struct _MonoReflectionType MonoReflectionType;
20 typedef struct _MonoDelegate MonoDelegate;
21 typedef struct _MonoException MonoException;
22 typedef struct _MonoThreadsSync MonoThreadsSync;
23 typedef struct _MonoThread MonoThread;
24 typedef struct _MonoDynamicAssembly MonoDynamicAssembly;
25 typedef struct _MonoDynamicImage MonoDynamicImage;
26 typedef struct _MonoReflectionMethodBody MonoReflectionMethodBody;
27 typedef struct _MonoAppContext MonoAppContext;
29 typedef struct _MonoObject {
31 MonoThreadsSync *synchronisation;
34 typedef MonoObject* (*MonoInvokeFunc) (MonoMethod *method, void *obj, void **params, MonoObject **exc, MonoError *error);
35 typedef void* (*MonoCompileFunc) (MonoMethod *method);
36 typedef void (*MonoMainThreadFunc) (void* user_data);
38 #define MONO_OBJECT_SETREF(obj,fieldname,value) do { \
39 g_assert (sizeof((obj)->fieldname) == sizeof (gpointer*)); \
40 mono_gc_wbarrier_set_field ((MonoObject*)(obj), &((obj)->fieldname), (MonoObject*)value); \
41 /*(obj)->fieldname = (value);*/ \
44 /* This should be used if 's' can reside on the heap */
45 #define MONO_STRUCT_SETREF(s,field,value) do { \
46 mono_gc_wbarrier_generic_store (&((s)->field), (MonoObject*)(value)); \
49 #define mono_array_addr(array,type,index) ((type*)(void*) mono_array_addr_with_size (array, sizeof (type), index))
50 #define mono_array_get(array,type,index) ( *(type*)mono_array_addr ((array), type, (index)) )
51 #define mono_array_set(array,type,index,value) \
53 type *__p = (type *) mono_array_addr ((array), type, (index)); \
56 #define mono_array_setref(array,index,value) \
58 void **__p = (void **) mono_array_addr ((array), void*, (index)); \
59 mono_gc_wbarrier_set_arrayref ((array), __p, (MonoObject*)(value)); \
60 /* *__p = (value);*/ \
62 #define mono_array_memcpy_refs(dest,destidx,src,srcidx,count) \
64 void **__p = (void **) mono_array_addr ((dest), void*, (destidx)); \
65 void **__s = mono_array_addr ((src), void*, (srcidx)); \
66 mono_gc_wbarrier_arrayref_copy (__p, __s, (count)); \
69 MONO_API mono_unichar2 *mono_string_chars (MonoString *s);
70 MONO_API int mono_string_length (MonoString *s);
72 MONO_RT_EXTERNAL_ONLY MONO_API MonoObject *
73 mono_object_new (MonoDomain *domain, MonoClass *klass);
77 mono_object_new_specific (MonoVTable *vtable);
79 /* can be used for classes without finalizer in non-profiling mode */
82 mono_object_new_fast (MonoVTable *vtable);
86 mono_object_new_alloc_specific (MonoVTable *vtable);
90 mono_object_new_from_token (MonoDomain *domain, MonoImage *image, uint32_t token);
94 mono_array_new (MonoDomain *domain, MonoClass *eclass, uintptr_t n);
98 mono_array_new_full (MonoDomain *domain, MonoClass *array_class,
99 uintptr_t *lengths, intptr_t *lower_bounds);
101 MONO_RT_EXTERNAL_ONLY
103 mono_array_new_specific (MonoVTable *vtable, uintptr_t n);
105 MONO_RT_EXTERNAL_ONLY
107 mono_array_clone (MonoArray *array);
110 mono_array_addr_with_size (MonoArray *array, int size, uintptr_t idx);
113 mono_array_length (MonoArray *array);
115 MONO_RT_EXTERNAL_ONLY
117 mono_string_new_utf16 (MonoDomain *domain, const mono_unichar2 *text, int32_t len);
119 MONO_RT_EXTERNAL_ONLY
121 mono_string_new_size (MonoDomain *domain, int32_t len);
123 MONO_RT_EXTERNAL_ONLY
125 mono_ldstr (MonoDomain *domain, MonoImage *image, uint32_t str_index);
128 mono_string_is_interned (MonoString *str);
130 MONO_RT_EXTERNAL_ONLY
132 mono_string_intern (MonoString *str);
135 mono_string_new (MonoDomain *domain, const char *text);
138 mono_string_new_wrapper (const char *text);
140 MONO_RT_EXTERNAL_ONLY
142 mono_string_new_len (MonoDomain *domain, const char *text, unsigned int length);
144 MONO_RT_EXTERNAL_ONLY
146 mono_string_new_utf32 (MonoDomain *domain, const mono_unichar4 *text, int32_t len);
148 MONO_RT_EXTERNAL_ONLY
150 mono_string_to_utf8 (MonoString *string_obj);
153 mono_string_to_utf8_checked (MonoString *string_obj, MonoError *error);
155 MONO_API mono_unichar2 *
156 mono_string_to_utf16 (MonoString *string_obj);
158 MONO_API mono_unichar4 *
159 mono_string_to_utf32 (MonoString *string_obj);
161 MONO_RT_EXTERNAL_ONLY
162 MONO_API MonoString *
163 mono_string_from_utf16 (mono_unichar2 *data);
165 MONO_RT_EXTERNAL_ONLY
166 MONO_API MonoString *
167 mono_string_from_utf32 (mono_unichar4 *data);
170 mono_string_equal (MonoString *s1, MonoString *s2);
172 MONO_API unsigned int
173 mono_string_hash (MonoString *s);
176 mono_object_hash (MonoObject* obj);
178 MONO_RT_EXTERNAL_ONLY
179 MONO_API MonoString *
180 mono_object_to_string (MonoObject *obj, MonoObject **exc);
182 MONO_RT_EXTERNAL_ONLY
183 MONO_API MonoObject *
184 mono_value_box (MonoDomain *domain, MonoClass *klass, void* val);
187 mono_value_copy (void* dest, void* src, MonoClass *klass);
190 mono_value_copy_array (MonoArray *dest, int dest_idx, void* src, int count);
193 mono_object_get_domain (MonoObject *obj);
196 mono_object_get_class (MonoObject *obj);
199 mono_object_unbox (MonoObject *obj);
201 MONO_RT_EXTERNAL_ONLY
202 MONO_API MonoObject *
203 mono_object_clone (MonoObject *obj);
205 MONO_RT_EXTERNAL_ONLY
206 MONO_API MonoObject *
207 mono_object_isinst (MonoObject *obj, MonoClass *klass);
209 MONO_RT_EXTERNAL_ONLY
210 MONO_API MonoObject *
211 mono_object_isinst_mbyref (MonoObject *obj, MonoClass *klass);
213 MONO_RT_EXTERNAL_ONLY
214 MONO_API MonoObject *
215 mono_object_castclass_mbyref (MonoObject *obj, MonoClass *klass);
218 mono_monitor_try_enter (MonoObject *obj, uint32_t ms);
221 mono_monitor_enter (MonoObject *obj);
224 mono_monitor_enter_v4 (MonoObject *obj, char *lock_taken);
226 MONO_API unsigned int
227 mono_object_get_size (MonoObject *o);
230 mono_monitor_exit (MonoObject *obj);
233 mono_raise_exception (MonoException *ex);
235 MONO_RT_EXTERNAL_ONLY
237 mono_runtime_object_init (MonoObject *this_obj);
239 MONO_RT_EXTERNAL_ONLY
241 mono_runtime_class_init (MonoVTable *vtable);
244 mono_object_get_virtual_method (MonoObject *obj, MonoMethod *method);
246 MONO_RT_EXTERNAL_ONLY
248 mono_runtime_invoke (MonoMethod *method, void *obj, void **params,
251 MONO_API MonoMethod *
252 mono_get_delegate_invoke (MonoClass *klass);
254 MONO_API MonoMethod *
255 mono_get_delegate_begin_invoke (MonoClass *klass);
257 MONO_API MonoMethod *
258 mono_get_delegate_end_invoke (MonoClass *klass);
260 MONO_RT_EXTERNAL_ONLY
262 mono_runtime_delegate_invoke (MonoObject *delegate, void **params,
265 MONO_RT_EXTERNAL_ONLY
267 mono_runtime_invoke_array (MonoMethod *method, void *obj, MonoArray *params,
271 mono_method_get_unmanaged_thunk (MonoMethod *method);
273 MONO_RT_EXTERNAL_ONLY
275 mono_runtime_get_main_args (void);
278 mono_runtime_exec_managed_code (MonoDomain *domain,
279 MonoMainThreadFunc main_func,
283 mono_runtime_run_main (MonoMethod *method, int argc, char* argv[],
287 mono_runtime_exec_main (MonoMethod *method, MonoArray *args,
291 mono_runtime_set_main_args (int argc, char* argv[]);
293 /* The following functions won't be available with mono was configured with remoting disabled. */
294 /*#ifndef DISABLE_REMOTING */
295 MONO_RT_EXTERNAL_ONLY
297 mono_load_remote_field (MonoObject *this_obj, MonoClass *klass, MonoClassField *field, void **res);
299 MONO_RT_EXTERNAL_ONLY
300 MONO_API MonoObject *
301 mono_load_remote_field_new (MonoObject *this_obj, MonoClass *klass, MonoClassField *field);
303 MONO_RT_EXTERNAL_ONLY
305 mono_store_remote_field (MonoObject *this_obj, MonoClass *klass, MonoClassField *field, void* val);
307 MONO_RT_EXTERNAL_ONLY
309 mono_store_remote_field_new (MonoObject *this_obj, MonoClass *klass, MonoClassField *field, MonoObject *arg);
314 mono_unhandled_exception (MonoObject *exc);
317 mono_print_unhandled_exception (MonoObject *exc);
319 MONO_RT_EXTERNAL_ONLY
321 mono_compile_method (MonoMethod *method);
323 /* accessors for fields and properties */
325 mono_field_set_value (MonoObject *obj, MonoClassField *field, void *value);
328 mono_field_static_set_value (MonoVTable *vt, MonoClassField *field, void *value);
331 mono_field_get_value (MonoObject *obj, MonoClassField *field, void *value);
333 MONO_RT_EXTERNAL_ONLY
335 mono_field_static_get_value (MonoVTable *vt, MonoClassField *field, void *value);
337 MONO_RT_EXTERNAL_ONLY
338 MONO_API MonoObject *
339 mono_field_get_value_object (MonoDomain *domain, MonoClassField *field, MonoObject *obj);
341 MONO_RT_EXTERNAL_ONLY
343 mono_property_set_value (MonoProperty *prop, void *obj, void **params, MonoObject **exc);
345 MONO_RT_EXTERNAL_ONLY
347 mono_property_get_value (MonoProperty *prop, void *obj, void **params, MonoObject **exc);
349 /* GC handles support
351 * A handle can be created to refer to a managed object and either prevent it
352 * from being garbage collected or moved or to be able to know if it has been
353 * collected or not (weak references).
354 * mono_gchandle_new () is used to prevent an object from being garbage collected
355 * until mono_gchandle_free() is called. Use a TRUE value for the pinned argument to
356 * prevent the object from being moved (this should be avoided as much as possible
357 * and this should be used only for shorts periods of time or performance will suffer).
358 * To create a weakref use mono_gchandle_new_weakref (): track_resurrection should
359 * usually be false (see the GC docs for more details).
360 * mono_gchandle_get_target () can be used to get the object referenced by both kinds
361 * of handle: for a weakref handle, if an object has been collected, it will return NULL.
363 MONO_API uint32_t mono_gchandle_new (MonoObject *obj, mono_bool pinned);
364 MONO_API uint32_t mono_gchandle_new_weakref (MonoObject *obj, mono_bool track_resurrection);
365 MONO_API MonoObject* mono_gchandle_get_target (uint32_t gchandle);
366 MONO_API void mono_gchandle_free (uint32_t gchandle);
368 /* Reference queue support
370 * A reference queue is used to get notifications of when objects are collected.
371 * Call mono_gc_reference_queue_new to create a new queue and pass the callback that
372 * will be invoked when registered objects are collected.
373 * Call mono_gc_reference_queue_add to register a pair of objects and data within a queue.
374 * The callback will be triggered once an object is both unreachable and finalized.
377 typedef void (*mono_reference_queue_callback) (void *user_data);
378 typedef struct _MonoReferenceQueue MonoReferenceQueue;
380 MONO_API MonoReferenceQueue* mono_gc_reference_queue_new (mono_reference_queue_callback callback);
381 MONO_API void mono_gc_reference_queue_free (MonoReferenceQueue *queue);
382 MONO_API mono_bool mono_gc_reference_queue_add (MonoReferenceQueue *queue, MonoObject *obj, void *user_data);
386 /* GC write barriers support */
387 MONO_API void mono_gc_wbarrier_set_field (MonoObject *obj, void* field_ptr, MonoObject* value);
388 MONO_API void mono_gc_wbarrier_set_arrayref (MonoArray *arr, void* slot_ptr, MonoObject* value);
389 MONO_API void mono_gc_wbarrier_arrayref_copy (void* dest_ptr, void* src_ptr, int count);
390 MONO_API void mono_gc_wbarrier_generic_store (void* ptr, MonoObject* value);
391 MONO_API void mono_gc_wbarrier_generic_store_atomic (void *ptr, MonoObject *value);
392 MONO_API void mono_gc_wbarrier_generic_nostore (void* ptr);
393 MONO_API void mono_gc_wbarrier_value_copy (void* dest, void* src, int count, MonoClass *klass);
394 MONO_API void mono_gc_wbarrier_object_copy (MonoObject* obj, MonoObject *src);