|
using System;
using System.Security;
using Microsoft.Win32.SafeHandles;
namespace System.Net.NetworkInformation
{
// This class guarantees that any in-progress notifications will be canceled before the AppDomain gets unloaded.
// CancelMibChangeNotify2 guarantees that after it returns, the callback will NEVER be called. It may block
// for a small amount of time if the callback is currently in progress, which is fine (and, intentional).
[SuppressUnmanagedCodeSecurity]
internal class SafeCancelMibChangeNotify : SafeHandleZeroOrMinusOneIsInvalid
{
public SafeCancelMibChangeNotify() : base(true) { }
protected override bool ReleaseHandle()
{
uint err = UnsafeNetInfoNativeMethods.CancelMibChangeNotify2(base.handle);
base.handle = IntPtr.Zero;
return (err == UnsafeNclNativeMethods.ErrorCodes.ERROR_SUCCESS);
}
}
}
|