2006-06-08 Zoltan Varga <vargaz@gmail.com>
[mono.git] / mono / metadata / metadata.h
index 333458cbdeacc9dcf204fd8f68d55bfde258e563..1149c4082b13b33006c73672c300c43cc654555c 100644 (file)
@@ -161,6 +161,7 @@ typedef enum {
        MONO_MARSHAL_CONV_LPTSTR_SB,
        MONO_MARSHAL_CONV_LPWSTR_SB,
        MONO_MARSHAL_CONV_ARRAY_BYVALARRAY,
+       MONO_MARSHAL_CONV_ARRAY_BYVALCHARARRAY,
        MONO_MARSHAL_CONV_ARRAY_SAVEARRAY,
        MONO_MARSHAL_CONV_ARRAY_LPARRAY,
        MONO_MARSHAL_CONV_OBJECT_INTERFACE,
@@ -169,7 +170,8 @@ typedef enum {
        MONO_MARSHAL_CONV_OBJECT_STRUCT,
        MONO_MARSHAL_CONV_DEL_FTN,
        MONO_MARSHAL_CONV_FTN_DEL,
-       MONO_MARSHAL_FREE_ARRAY
+       MONO_MARSHAL_FREE_ARRAY,
+       MONO_MARSHAL_CONV_BSTR_STR
 } MonoMarshalConv;
 
 typedef struct {
@@ -259,6 +261,8 @@ guint32     mono_metadata_get_constant_index (MonoImage *meta, guint32 token, gu
  */
 guint32 mono_metadata_decode_value     (const char            *ptr,
                                         const char           **rptr);
+gint32 mono_metadata_decode_signed_value (const char *ptr, const char **rptr);
+
 guint32 mono_metadata_decode_blob_size (const char            *ptr,
                                         const char           **rptr);
 
@@ -346,21 +350,7 @@ struct _MonoMethodSignature {
        MonoType     *params [MONO_ZERO_LEN_ARRAY];
 };
 
-/*
- * This structure is an internal runtime detail: use the mono_method_header_*
- * accessors below, because it will go away from the public header.
- */
-typedef struct {
-       guint32      code_size;
-       const unsigned char  *code;
-       guint16      max_stack;
-       unsigned int num_clauses : 15;
-       /* if num_locals != 0, then the following apply: */
-       unsigned int init_locals : 1;
-       guint16      num_locals;
-       MonoExceptionClause *clauses;
-       MonoType    *locals [MONO_ZERO_LEN_ARRAY];
-} MonoMethodHeader;
+typedef struct _MonoMethodHeader MonoMethodHeader;
 
 typedef enum {
        MONO_PARSE_TYPE,
@@ -446,6 +436,7 @@ int            mono_type_size                  (MonoType        *type,
 int            mono_type_stack_size            (MonoType        *type, 
                                                int             *alignment);
 
+gboolean       mono_type_generic_inst_is_valuetype      (MonoType *type);
 gboolean       mono_metadata_generic_class_is_valuetype (MonoGenericClass *gclass);
 guint          mono_metadata_generic_class_hash  (MonoGenericClass *gclass);
 gboolean       mono_metadata_generic_class_equal (MonoGenericClass *g1, MonoGenericClass *g2);