From 074a4ff807921953706e9c50727d87f75f28d873 Mon Sep 17 00:00:00 2001 From: thefiddler Date: Mon, 1 Sep 2014 18:09:46 +0200 Subject: [PATCH] [Rewrite] Cast int32 overloads to native int Int32 parameters should be converted to native int when the native signature expects the latter. --- Source/Generator.Rewrite/Program.cs | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/Source/Generator.Rewrite/Program.cs b/Source/Generator.Rewrite/Program.cs index f0eae33d..94a7284f 100644 --- a/Source/Generator.Rewrite/Program.cs +++ b/Source/Generator.Rewrite/Program.cs @@ -260,7 +260,7 @@ namespace OpenTK.Rewrite // Patch convenience wrappers if (wrapper.Parameters.Count == native.Parameters.Count) { - EmitParameters(wrapper, body, il); + EmitParameters(wrapper, native, body, il); } else { @@ -715,7 +715,7 @@ namespace OpenTK.Rewrite // return result; // } body.Variables.Add(new VariableDefinition(wrapper.ReturnType)); - EmitParameters(wrapper, body, il); + EmitParameters(wrapper, native, body, il); il.Emit(OpCodes.Ldloca, body.Variables.Count - 1); } else @@ -743,7 +743,7 @@ namespace OpenTK.Rewrite } } - static int EmitParameters(MethodDefinition method, MethodBody body, ILProcessor il) + static int EmitParameters(MethodDefinition method, MethodDefinition native, MethodBody body, ILProcessor il) { int i; for (i = 0; i < method.Parameters.Count; i++) @@ -752,7 +752,13 @@ namespace OpenTK.Rewrite var p = method.Module.Import(method.Parameters[i].ParameterType); il.Emit(OpCodes.Ldarg, i); - if (p.Name == "StringBuilder") + if (p.Name.Contains("Int32") && native.Parameters[i].ParameterType.Name.Contains("IntPtr")) + { + // This is a convenience Int32 overload for an IntPtr (size_t) parameter. + // We need to convert the loaded argument to IntPtr. + il.Emit(OpCodes.Conv_I); + } + else if (p.Name == "StringBuilder") { EmitStringBuilderParameter(method, parameter, body, il); }