File: System\Runtime\DurableInstancing\InstanceHandleReference.cs
Project: ndp\cdf\src\NetFx40\System.Runtime.DurableInstancing\System.Runtime.DurableInstancing.csproj (System.Runtime.DurableInstancing)
//----------------------------------------------------------------
// Copyright (c) Microsoft Corporation.  All rights reserved.
//----------------------------------------------------------------
 
namespace System.Runtime.DurableInstancing
{
    // This class serves as a reference back to an InstanceHandle from the perspective of an InstanceOwner for tracking lock binds in progress.
    // It works in two modes, one as a pure cancelable handle reference (where cancelling means nulling out the reference) and the
    // other as a queue position marker for determining when all of the in-progress requests at one point in time are all done.  In the
    // marker mode (InstanceOwner.LockResolutionMarker), it carries some additional context for maintaining the state of the
    // InstancePersistenceContext.ResolveExistingLock operation.
    class InstanceHandleReference
    {
        internal InstanceHandleReference(InstanceHandle instanceHandle)
        {
            Fx.Assert(instanceHandle != null, "Null instanceHandle provided to InstanceHandleReference.");
            InstanceHandle = instanceHandle;
        }
 
        // This is set to null when the InstanceHandleReference is detached from the InstanceHandle - i.e. it is
        // no longer in use, and exists just to make it possible to lazily drain out of the various queues.
        internal InstanceHandle InstanceHandle { get; private set; }
 
        internal void Cancel()
        {
            Fx.Assert(InstanceHandle != null, "InstanceHandleReference already cancelled.");
            InstanceHandle = null;
        }
    }
}