Xamarin Public Jenkins (auto-signing) e79aa3c0ed Imported Upstream version 4.6.0.125
Former-commit-id: a2155e9bd80020e49e72e86c44da02a8ac0e57a4
2016-08-03 10:59:49 +00:00

97 lines
3.7 KiB
C#

//-----------------------------------------------------------------------------
// Copyright (c) Microsoft Corporation. All rights reserved.
//-----------------------------------------------------------------------------
namespace System.ServiceModel.Dispatcher
{
using System;
using System.ServiceModel;
using System.ServiceModel.Channels;
internal class SingletonInstanceContextProvider : InstanceContextProviderBase
{
InstanceContext singleton;
object thisLock;
internal SingletonInstanceContextProvider(DispatchRuntime dispatchRuntime)
: base(dispatchRuntime)
{
this.thisLock = new Object();
}
internal InstanceContext SingletonInstance
{
get
{
if (this.singleton == null)
{
lock (this.thisLock)
{
if (this.singleton == null)
{
InstanceContext instanceContext = this.DispatchRuntime.SingletonInstanceContext;
if (instanceContext == null)
{
instanceContext = new InstanceContext(this.DispatchRuntime.ChannelDispatcher.Host, false);
instanceContext.Open();
}
else if (instanceContext.State != CommunicationState.Opened)
{
// we need to lock against the instance context for open since two different endpoints could
// share the same instance context, but different providers. So the provider lock does not guard
// the open process
lock (instanceContext.ThisLock)
{
if (instanceContext.State != CommunicationState.Opened)
{
instanceContext.Open();
}
}
}
//Set the IsUsercreated flag to false for singleton mode even in cases when users create their own runtime.
instanceContext.IsUserCreated = false;
//Delay assigning the potentially newly created InstanceContext (till after its opened) to this.Singleton
//to ensure that it is opened only once.
this.singleton = instanceContext;
}
}
}
return this.singleton;
}
}
#region IInstanceContextProvider Members
public override InstanceContext GetExistingInstanceContext(Message message, IContextChannel channel)
{
ServiceChannel serviceChannel = this.GetServiceChannelFromProxy(channel);
if (serviceChannel != null && serviceChannel.HasSession)
{
this.SingletonInstance.BindIncomingChannel(serviceChannel);
}
return this.SingletonInstance;
}
public override void InitializeInstanceContext(InstanceContext instanceContext, Message message, IContextChannel channel)
{
//no-op
}
public override bool IsIdle(InstanceContext instanceContext)
{
//By default return false
return false;
}
public override void NotifyIdle(InstanceContextIdleCallback callback, InstanceContext instanceContext)
{
//no-op
}
#endregion
}
}