diff options
author | Joe Shaw <joeshaw@novell.com> | 2005-03-15 23:30:55 +0000 |
---|---|---|
committer | Joe Shaw <joeshaw@novell.com> | 2005-03-15 23:30:55 +0000 |
commit | bcdd18548392c46ea33dc5e15da8c8c82414a486 (patch) | |
tree | e128975539b1d24e9b6b215aa9be8f24d2b53388 /mono | |
parent | 42287b94d1cee1d16a643efadd78dacffa911cad (diff) |
2005-03-15 Joe Shaw <joeshaw@novell.com>
* mono/ProxyBuilder.cs (BuildFinalizer): Fix some invalid IL when
generating the finalizer. Fixes from Ben Maurer.
Diffstat (limited to 'mono')
-rw-r--r-- | mono/ProxyBuilder.cs | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/mono/ProxyBuilder.cs b/mono/ProxyBuilder.cs index 8d374ae0..7a3de959 100644 --- a/mono/ProxyBuilder.cs +++ b/mono/ProxyBuilder.cs @@ -468,7 +468,7 @@ namespace DBus generator.Emit(OpCodes.Ret); } - public void BuildFinalizer (TypeBuilder tb, FieldInfo fi) + public void BuildFinalizer (TypeBuilder tb, FieldInfo serviceF, FieldInfo deleF) { // Note that this is a *HORRIBLE* example of how to build a finalizer // It doesn't use the try/finally to chain to Object::Finalize. However, @@ -485,8 +485,10 @@ namespace DBus //generator.EmitWriteLine("this.service.SignalCalled -= this.delegate_created"); generator.Emit (OpCodes.Ldarg_0); - generator.Emit (OpCodes.Ldfld, fi); - generator.Emit (OpCodes.Call, Service_RemoveSignalCalledMI); + generator.Emit (OpCodes.Ldfld, serviceF); + generator.Emit (OpCodes.Ldarg_0); + generator.Emit (OpCodes.Ldfld, deleF); + generator.EmitCall (OpCodes.Callvirt, Service_RemoveSignalCalledMI, null); generator.Emit (OpCodes.Ret); } @@ -556,7 +558,7 @@ namespace DBus FieldBuilder deleF = typeB.DefineField("delegate_created", typeof(Service.SignalCalledHandler), FieldAttributes.Private); - BuildFinalizer (typeB, deleF); + BuildFinalizer (typeB, serviceF, deleF); MethodInfo signalCalledMI = BuildSignalCalled(ref typeB, serviceF, pathF); BuildConstructor(ref typeB, serviceF, pathF, signalCalledMI, deleF); |