blob: 3554cf376303e3d7e9052a8db97a9acc5d393e50 [file] [log] [blame]
#region Apache License
//
// Licensed to the Apache Software Foundation (ASF) under one or more
// contributor license agreements. See the NOTICE file distributed with
// this work for additional information regarding copyright ownership.
// The ASF licenses this file to you under the Apache License, Version 2.0
// (the "License"); you may not use this file except in compliance with
// the License. You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//
#endregion
#if !NETCF
using System;
using System.Collections;
namespace log4net.Util
{
/// <summary>
/// Implementation of Stacks collection for the <see cref="log4net.LogicalThreadContext"/>
/// </summary>
/// <remarks>
/// <para>
/// Implementation of Stacks collection for the <see cref="log4net.LogicalThreadContext"/>
/// </para>
/// </remarks>
/// <author>Nicko Cadell</author>
public sealed class LogicalThreadContextStacks
{
private readonly LogicalThreadContextProperties m_properties;
#region Public Instance Constructors
/// <summary>
/// Internal constructor
/// </summary>
/// <remarks>
/// <para>
/// Initializes a new instance of the <see cref="ThreadContextStacks" /> class.
/// </para>
/// </remarks>
internal LogicalThreadContextStacks(LogicalThreadContextProperties properties)
{
m_properties = properties;
}
#endregion Public Instance Constructors
#region Public Instance Properties
/// <summary>
/// Gets the named thread context stack
/// </summary>
/// <value>
/// The named stack
/// </value>
/// <remarks>
/// <para>
/// Gets the named thread context stack
/// </para>
/// </remarks>
public LogicalThreadContextStack this[string key]
{
get
{
LogicalThreadContextStack stack = null;
object propertyValue = m_properties[key];
if (propertyValue == null)
{
// Stack does not exist, create
#if NET_2_0 || MONO_2_0
stack = new LogicalThreadContextStack(key, registerNew);
#else
stack = new LogicalThreadContextStack(key, new TwoArgAction(registerNew));
#endif
m_properties[key] = stack;
}
else
{
// Look for existing stack
stack = propertyValue as LogicalThreadContextStack;
if (stack == null)
{
// Property is not set to a stack!
string propertyValueString = SystemInfo.NullText;
try
{
propertyValueString = propertyValue.ToString();
}
catch
{
}
LogLog.Error(declaringType, "ThreadContextStacks: Request for stack named [" + key + "] failed because a property with the same name exists which is a [" + propertyValue.GetType().Name + "] with value [" + propertyValueString + "]");
#if NET_2_0 || MONO_2_0
stack = new LogicalThreadContextStack(key, registerNew);
#else
stack = new LogicalThreadContextStack(key, new TwoArgAction(registerNew));
#endif
}
}
return stack;
}
}
#endregion Public Instance Properties
#region Private Instance Fields
private void registerNew(string stackName, LogicalThreadContextStack stack)
{
m_properties[stackName] = stack;
}
#endregion Private Instance Fields
#region Private Static Fields
/// <summary>
/// The fully qualified type of the ThreadContextStacks class.
/// </summary>
/// <remarks>
/// Used by the internal logger to record the Type of the
/// log message.
/// </remarks>
private readonly static Type declaringType = typeof(LogicalThreadContextStacks);
#endregion Private Static Fields
}
}
#endif