public event ModuleResolveEventHandler ModuleResolve;
}
+ internal class UnmanagedMemoryStreamForModule : UnmanagedMemoryStream
+ {
+ Module module;
+
+ public unsafe UnmanagedMemoryStreamForModule (byte* pointer, long length, Module module)
+ : base (pointer, length)
+ {
+ this.module = module;
+ }
+
+ protected override void Dispose (bool disposing)
+ {
+ if (_isOpen) {
+ /*
+ * The returned pointer points inside metadata, so
+ * we have to increase the refcount of the module, and decrease
+ * it when the stream is finalized.
+ */
+ module = null;
+ }
+
+ base.Dispose (disposing);
+ }
+ }
+
// Note: changes to fields must be reflected in _MonoReflectionAssembly struct (object-internals.h)
#pragma warning disable 649
private IntPtr _mono_assembly;
else {
UnmanagedMemoryStream stream;
unsafe {
- stream = new UnmanagedMemoryStream ((byte*) data, size);
+ stream = new UnmanagedMemoryStreamForModule ((byte*) data, size, module);
}
- /*
- * The returned pointer points inside metadata, so
- * we have to increase the refcount of the module, and decrease
- * it when the stream is finalized.
- */
- stream.Closed += new EventHandler (new ResourceCloseHandler (module).OnClose);
return stream;
}
}
return null;
}
- private class ResourceCloseHandler {
-#pragma warning disable 169, 414
- Module module;
-#pragma warning restore 169, 414
-
- public ResourceCloseHandler (Module module) {
- this.module = module;
- }
-
- public void OnClose (object sender, EventArgs e) {
- // The module dtor will take care of things
- module = null;
- }
- }
-
[MonoTODO ("Currently it always returns zero")]
[ComVisible (false)]
public
ResourceValue = value;
}
}
+
+ unsafe class HGlobalUnmanagedMemoryStream : UnmanagedMemoryStream
+ {
+ IntPtr ptr;
+
+ public HGlobalUnmanagedMemoryStream (byte* pointer, long length, IntPtr ptr)
+ : base (pointer, length, length, FileAccess.ReadWrite)
+ {
+ this.ptr = ptr;
+ }
+
+ protected override void Dispose (bool disposing)
+ {
+ if (_isOpen) {
+ Marshal.FreeHGlobal (ptr);
+ }
+
+ base.Dispose (disposing);
+ }
+ }
BinaryReader reader;
object readerLock = new object ();
} else {
IntPtr ptr = Marshal.AllocHGlobal ((int) slen);
byte* addr = (byte*) ptr.ToPointer ();
- UnmanagedMemoryStream ms = new UnmanagedMemoryStream (addr, slen, slen, FileAccess.ReadWrite);
- // The memory resource must be freed
- // when the stream is disposed.
- ms.Closed += delegate (object o, EventArgs e) {
- Marshal.FreeHGlobal (ptr);
- };
+ UnmanagedMemoryStream ms = new HGlobalUnmanagedMemoryStream (addr, slen, ptr);
byte [] bytes = new byte [slen < 1024 ? slen : 1024];
while (slen > 0 ) {