[threadpool] Use threadpool->threads instead of threadpool->counters to wait on clean...
[mono.git] / mono / metadata / loader.h
index ae0ca4417737da07e3487f333c08cbc8fd0eaa95..328cb5ac7583312904112bbfb933f779f8a9c402 100644 (file)
@@ -3,36 +3,37 @@
 
 #include <mono/metadata/metadata.h>
 #include <mono/metadata/image.h>
+#include <mono/utils/mono-error.h>
 
 MONO_BEGIN_DECLS
 
 typedef mono_bool (*MonoStackWalk)     (MonoMethod *method, int32_t native_offset, int32_t il_offset, mono_bool managed, void* data);
 
-MONO_API MonoMethod *
+MONO_RT_EXTERNAL_ONLY MONO_API MonoMethod *
 mono_get_method             (MonoImage *image, uint32_t token, MonoClass *klass);
 
-MONO_API MonoMethod *
+MONO_RT_EXTERNAL_ONLY MONO_API MonoMethod *
 mono_get_method_full        (MonoImage *image, uint32_t token, MonoClass *klass,
                             MonoGenericContext *context);
 
-MONO_API MonoMethod *
+MONO_RT_EXTERNAL_ONLY MONO_API MonoMethod *
 mono_get_method_constrained (MonoImage *image, uint32_t token, MonoClass *constrained_class,
                             MonoGenericContext *context, MonoMethod **cil_method);
 
 MONO_API void               
 mono_free_method           (MonoMethod *method);
 
-MONO_API MonoMethodSignature*
+MONO_RT_EXTERNAL_ONLY MONO_API MonoMethodSignature*
 mono_method_get_signature_full (MonoMethod *method, MonoImage *image, uint32_t token,
                                MonoGenericContext *context);
 
-MONO_API MonoMethodSignature* 
+MONO_RT_EXTERNAL_ONLY MONO_API MonoMethodSignature* 
 mono_method_get_signature  (MonoMethod *method, MonoImage *image, uint32_t token);
 
 MONO_API MonoMethodSignature* 
 mono_method_signature      (MonoMethod *method);
 
-MONO_API MonoMethodHeader* 
+MONO_RT_EXTERNAL_ONLY MONO_API MonoMethodHeader* 
 mono_method_get_header     (MonoMethod *method);
 
 MONO_API const char*
@@ -59,6 +60,9 @@ mono_add_internal_call     (const char *name, const void* method);
 MONO_API void*
 mono_lookup_internal_call (MonoMethod *method);
 
+void*
+mono_lookup_internal_call_full (MonoMethod *method, mono_bool *uses_handles);
+
 MONO_API const char*
 mono_lookup_icall_symbol (MonoMethod *m);
 
@@ -90,8 +94,12 @@ mono_stack_walk         (MonoStackWalk func, void* user_data);
 MONO_API void
 mono_stack_walk_no_il   (MonoStackWalk func, void* user_data);
 
+typedef mono_bool (*MonoStackWalkAsyncSafe)     (MonoMethod *method, MonoDomain *domain, void *base_address, int offset, void* data);
 MONO_API void
-mono_stack_walk_async_safe   (MonoStackWalk func, void* user_data);
+mono_stack_walk_async_safe   (MonoStackWalkAsyncSafe func, void *initial_sig_context, void* user_data);
+
+MONO_API MonoMethodHeader*
+mono_method_get_header_checked (MonoMethod *method, MonoError *error);
 
 MONO_END_DECLS