2009-11-04 Sebastien Pouliot <sebastien@ximian.com>
[mono.git] / mono / metadata / verify.h
index a4a38d94701dacbc50b0a5fe2109d7fe7bbe555c..26559dd8afa40cd09b92ff7eb39535f0a70a5494 100644 (file)
@@ -4,6 +4,7 @@
 #include <mono/metadata/metadata.h>
 #include <mono/metadata/image.h>
 #include <mono/metadata/loader.h>
+#include "mono/utils/mono-compiler.h"
 
 G_BEGIN_DECLS
 
@@ -12,7 +13,32 @@ typedef enum {
        MONO_VERIFY_ERROR,
        MONO_VERIFY_WARNING,
        MONO_VERIFY_CLS = 4,
-       MONO_VERIFY_ALL = 7
+       MONO_VERIFY_ALL = 7,
+
+       /* Status signaling code that is not verifiable.*/
+       MONO_VERIFY_NOT_VERIFIABLE = 8,
+
+       /*OR it with other flags*/
+       
+       /* Abort the verification if the code is not verifiable.
+        * The standard behavior is to abort if the code is not valid.
+        * */
+       MONO_VERIFY_FAIL_FAST = 16,
+
+
+       /* Perform less verification of the code. This flag should be used
+        * if one wants the verifier to be more compatible to the MS runtime.
+        * Mind that this is not to be more compatible with MS peverify, but
+        * with the runtime itself, that has a less strict verifier.
+        */
+       MONO_VERIFY_NON_STRICT = 32,
+
+       /*Skip all visibility related checks*/
+       MONO_VERIFY_SKIP_VISIBILITY = 64,
+
+       /*Skip all visibility related checks*/
+       MONO_VERIFY_REPORT_ALL_ERRORS = 128,
+
 } MonoVerifyStatus;
 
 typedef struct {
@@ -20,6 +46,12 @@ typedef struct {
        MonoVerifyStatus status;
 } MonoVerifyInfo;
 
+typedef struct {
+       MonoVerifyInfo info;
+       guint8 exception_type; /*should be one of MONO_EXCEPTION_* */
+} MonoVerifyInfoExtended;
+
+
 GSList* mono_image_verify_tables (MonoImage *image, int level);
 GSList* mono_method_verify       (MonoMethod *method, int level);
 void    mono_free_verify_list    (GSList *list);