Add a more functional (i.e. fewer-stubs) implementation of System.Data.Linq.
[mono.git] / mono / metadata / object.h
index 1a93d7c179ca769e5f0051f08dee88fb6ca4222b..2e2a8657b38451513bc53dd807e535f88f53e344 100644 (file)
@@ -28,9 +28,21 @@ typedef struct {
        MonoThreadsSync *synchronisation;
 } MonoObject;
 
+#ifdef MONO_BIG_ARRAYS
+typedef guint64 mono_array_size_t;
+typedef gint64 mono_array_lower_bound_t;
+#define MONO_ARRAY_MAX_INDEX G_MAXINT64
+#define MONO_ARRAY_MAX_SIZE  G_MAXUINT64
+#else
+typedef guint32 mono_array_size_t;
+typedef gint32 mono_array_lower_bound_t;
+#define MONO_ARRAY_MAX_INDEX ((gint32) 0x7fffffff)
+#define MONO_ARRAY_MAX_SIZE  ((guint32) 0xffffffff)
+#endif
+
 typedef struct {
-       guint32 length;
-       guint32 lower_bound;
+       mono_array_size_t length;
+       mono_array_lower_bound_t lower_bound;
 } MonoArrayBounds;
 
 typedef struct {
@@ -38,7 +50,7 @@ typedef struct {
        /* bounds is NULL for szarrays */
        MonoArrayBounds *bounds;
        /* total number of elements of the array */
-       guint32 max_length; 
+       mono_array_size_t max_length; 
        /* we use double to ensure proper alignment on platforms that need it */
        double vector [MONO_ZERO_LEN_ARRAY];
 } MonoArray;
@@ -108,14 +120,14 @@ MonoObject *
 mono_object_new_from_token  (MonoDomain *domain, MonoImage *image, guint32 token);
 
 MonoArray*
-mono_array_new             (MonoDomain *domain, MonoClass *eclass, guint32 n);
+mono_array_new             (MonoDomain *domain, MonoClass *eclass, mono_array_size_t n);
 
 MonoArray*
 mono_array_new_full        (MonoDomain *domain, MonoClass *array_class,
-                            guint32 *lengths, guint32 *lower_bounds);
+                            mono_array_size_t *lengths, mono_array_size_t *lower_bounds);
 
 MonoArray *
-mono_array_new_specific            (MonoVTable *vtable, guint32 n);
+mono_array_new_specific            (MonoVTable *vtable, mono_array_size_t n);
 
 MonoArray*
 mono_array_clone           (MonoArray *array);
@@ -231,6 +243,9 @@ MonoObject*
 mono_runtime_invoke_array   (MonoMethod *method, void *obj, MonoArray *params,
                             MonoObject **exc);
 
+gpointer
+mono_method_get_unmanaged_thunk (MonoMethod *method);
+
 MonoArray*
 mono_runtime_get_main_args  (void);