📄 logimpl.cs
字号:
#region Copyright & License
//
// Copyright 2001-2006 The Apache Software Foundation
//
// Licensed 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
using System;
using System.Globalization;
using log4net.Repository;
using log4net.Util;
namespace log4net.Core
{
/// <summary>
/// Implementation of <see cref="ILog"/> wrapper interface.
/// </summary>
/// <remarks>
/// <para>
/// This implementation of the <see cref="ILog"/> interface
/// forwards to the <see cref="ILogger"/> held by the base class.
/// </para>
/// <para>
/// This logger has methods to allow the caller to log at the following
/// levels:
/// </para>
/// <list type="definition">
/// <item>
/// <term>DEBUG</term>
/// <description>
/// The <see cref="Debug(object)"/> and <see cref="DebugFormat(string, object[])"/> methods log messages
/// at the <c>DEBUG</c> level. That is the level with that name defined in the
/// repositories <see cref="ILoggerRepository.LevelMap"/>. The default value
/// for this level is <see cref="Level.Debug"/>. The <see cref="IsDebugEnabled"/>
/// property tests if this level is enabled for logging.
/// </description>
/// </item>
/// <item>
/// <term>INFO</term>
/// <description>
/// The <see cref="Info(object)"/> and <see cref="InfoFormat(string, object[])"/> methods log messages
/// at the <c>INFO</c> level. That is the level with that name defined in the
/// repositories <see cref="ILoggerRepository.LevelMap"/>. The default value
/// for this level is <see cref="Level.Info"/>. The <see cref="IsInfoEnabled"/>
/// property tests if this level is enabled for logging.
/// </description>
/// </item>
/// <item>
/// <term>WARN</term>
/// <description>
/// The <see cref="Warn(object)"/> and <see cref="WarnFormat(string, object[])"/> methods log messages
/// at the <c>WARN</c> level. That is the level with that name defined in the
/// repositories <see cref="ILoggerRepository.LevelMap"/>. The default value
/// for this level is <see cref="Level.Warn"/>. The <see cref="IsWarnEnabled"/>
/// property tests if this level is enabled for logging.
/// </description>
/// </item>
/// <item>
/// <term>ERROR</term>
/// <description>
/// The <see cref="Error(object)"/> and <see cref="ErrorFormat(string, object[])"/> methods log messages
/// at the <c>ERROR</c> level. That is the level with that name defined in the
/// repositories <see cref="ILoggerRepository.LevelMap"/>. The default value
/// for this level is <see cref="Level.Error"/>. The <see cref="IsErrorEnabled"/>
/// property tests if this level is enabled for logging.
/// </description>
/// </item>
/// <item>
/// <term>FATAL</term>
/// <description>
/// The <see cref="Fatal(object)"/> and <see cref="FatalFormat(string, object[])"/> methods log messages
/// at the <c>FATAL</c> level. That is the level with that name defined in the
/// repositories <see cref="ILoggerRepository.LevelMap"/>. The default value
/// for this level is <see cref="Level.Fatal"/>. The <see cref="IsFatalEnabled"/>
/// property tests if this level is enabled for logging.
/// </description>
/// </item>
/// </list>
/// <para>
/// The values for these levels and their semantic meanings can be changed by
/// configuring the <see cref="ILoggerRepository.LevelMap"/> for the repository.
/// </para>
/// </remarks>
/// <author>Nicko Cadell</author>
/// <author>Gert Driesen</author>
public class LogImpl : LoggerWrapperImpl, ILog
{
#region Public Instance Constructors
/// <summary>
/// Construct a new wrapper for the specified logger.
/// </summary>
/// <param name="logger">The logger to wrap.</param>
/// <remarks>
/// <para>
/// Construct a new wrapper for the specified logger.
/// </para>
/// </remarks>
public LogImpl(ILogger logger) : base(logger)
{
// Listen for changes to the repository
logger.Repository.ConfigurationChanged += new LoggerRepositoryConfigurationChangedEventHandler(LoggerRepositoryConfigurationChanged);
// load the current levels
ReloadLevels(logger.Repository);
}
#endregion Public Instance Constructors
/// <summary>
/// Virtual method called when the configuration of the repository changes
/// </summary>
/// <param name="repository">the repository holding the levels</param>
/// <remarks>
/// <para>
/// Virtual method called when the configuration of the repository changes
/// </para>
/// </remarks>
protected virtual void ReloadLevels(ILoggerRepository repository)
{
LevelMap levelMap = repository.LevelMap;
m_levelDebug = levelMap.LookupWithDefault(Level.Debug);
m_levelInfo = levelMap.LookupWithDefault(Level.Info);
m_levelWarn = levelMap.LookupWithDefault(Level.Warn);
m_levelError = levelMap.LookupWithDefault(Level.Error);
m_levelFatal = levelMap.LookupWithDefault(Level.Fatal);
}
#region Implementation of ILog
/// <summary>
/// Logs a message object with the <c>DEBUG</c> level.
/// </summary>
/// <param name="message">The message object to log.</param>
/// <remarks>
/// <para>
/// This method first checks if this logger is <c>DEBUG</c>
/// enabled by comparing the level of this logger with the
/// <c>DEBUG</c> level. If this logger is
/// <c>DEBUG</c> enabled, then it converts the message object
/// (passed as parameter) to a string by invoking the appropriate
/// <see cref="log4net.ObjectRenderer.IObjectRenderer"/>. It then
/// proceeds to call all the registered appenders in this logger
/// and also higher in the hierarchy depending on the value of the
/// additivity flag.
/// </para>
/// <para>
/// <b>WARNING</b> Note that passing an <see cref="Exception"/>
/// to this method will print the name of the <see cref="Exception"/>
/// but no stack trace. To print a stack trace use the
/// <see cref="Debug(object,Exception)"/> form instead.
/// </para>
/// </remarks>
virtual public void Debug(object message)
{
Logger.Log(ThisDeclaringType, m_levelDebug, message, null);
}
/// <summary>
/// Logs a message object with the <c>DEBUG</c> level
/// </summary>
/// <param name="message">The message object to log.</param>
/// <param name="exception">The exception to log, including its stack trace.</param>
/// <remarks>
/// <para>
/// Logs a message object with the <c>DEBUG</c> level including
/// the stack trace of the <see cref="Exception"/> <paramref name="exception"/> passed
/// as a parameter.
/// </para>
/// <para>
/// See the <see cref="Debug(object)"/> form for more detailed information.
/// </para>
/// </remarks>
/// <seealso cref="Debug(object)"/>
virtual public void Debug(object message, Exception exception)
{
Logger.Log(ThisDeclaringType, m_levelDebug, message, exception);
}
/// <summary>
/// Logs a formatted message string with the <c>DEBUG</c> level.
/// </summary>
/// <param name="format">A String containing zero or more format items</param>
/// <param name="args">An Object array containing zero or more objects to format</param>
/// <remarks>
/// <para>
/// The message is formatted using the <see cref="String.Format(IFormatProvider, string, object[])"/> method. See
/// <c>String.Format</c> for details of the syntax of the format string and the behavior
/// of the formatting.
/// </para>
/// <para>
/// The string is formatted using the <see cref="CultureInfo.InvariantCulture"/>
/// format provider. To specify a localized provider use the
/// <see cref="DebugFormat(IFormatProvider,string,object[])"/> method.
/// </para>
/// <para>
/// This method does not take an <see cref="Exception"/> object to include in the
/// log event. To pass an <see cref="Exception"/> use one of the <see cref="Debug(object)"/>
/// methods instead.
/// </para>
/// </remarks>
virtual public void DebugFormat(string format, params object[] args)
{
if (IsDebugEnabled)
{
Logger.Log(ThisDeclaringType, m_levelDebug, new SystemStringFormat(CultureInfo.InvariantCulture, format, args), null);
}
}
/// <summary>
/// Logs a formatted message string with the <c>DEBUG</c> level.
/// </summary>
/// <param name="format">A String containing zero or more format items</param>
/// <param name="arg0">An Object to format</param>
/// <remarks>
/// <para>
/// The message is formatted using the <see cref="String.Format(IFormatProvider, string, object[])"/> method. See
/// <c>String.Format</c> for details of the syntax of the format string and the behavior
/// of the formatting.
/// </para>
/// <para>
/// The string is formatted using the <see cref="CultureInfo.InvariantCulture"/>
/// format provider. To specify a localized provider use the
/// <see cref="DebugFormat(IFormatProvider,string,object[])"/> method.
/// </para>
/// <para>
/// This method does not take an <see cref="Exception"/> object to include in the
/// log event. To pass an <see cref="Exception"/> use one of the <see cref="Debug(object)"/>
/// methods instead.
/// </para>
/// </remarks>
virtual public void DebugFormat(string format, object arg0)
{
if (IsDebugEnabled)
{
Logger.Log(ThisDeclaringType, m_levelDebug, new SystemStringFormat(CultureInfo.InvariantCulture, format, new object[] { arg0 }), null);
}
}
/// <summary>
/// Logs a formatted message string with the <c>DEBUG</c> level.
/// </summary>
/// <param name="format">A String containing zero or more format items</param>
/// <param name="arg0">An Object to format</param>
/// <param name="arg1">An Object to format</param>
/// <remarks>
/// <para>
/// The message is formatted using the <see cref="String.Format(IFormatProvider, string, object[])"/> method. See
/// <c>String.Format</c> for details of the syntax of the format string and the behavior
/// of the formatting.
/// </para>
/// <para>
/// The string is formatted using the <see cref="CultureInfo.InvariantCulture"/>
/// format provider. To specify a localized provider use the
/// <see cref="DebugFormat(IFormatProvider,string,object[])"/> method.
/// </para>
/// <para>
/// This method does not take an <see cref="Exception"/> object to include in the
/// log event. To pass an <see cref="Exception"/> use one of the <see cref="Debug(object)"/>
/// methods instead.
/// </para>
/// </remarks>
virtual public void DebugFormat(string format, object arg0, object arg1)
{
if (IsDebugEnabled)
{
Logger.Log(ThisDeclaringType, m_levelDebug, new SystemStringFormat(CultureInfo.InvariantCulture, format, new object[] { arg0, arg1 }), null);
}
}
/// <summary>
/// Logs a formatted message string with the <c>DEBUG</c> level.
/// </summary>
/// <param name="format">A String containing zero or more format items</param>
/// <param name="arg0">An Object to format</param>
/// <param name="arg1">An Object to format</param>
/// <param name="arg2">An Object to format</param>
/// <remarks>
/// <para>
/// The message is formatted using the <see cref="String.Format(IFormatProvider, string, object[])"/> method. See
/// <c>String.Format</c> for details of the syntax of the format string and the behavior
/// of the formatting.
/// </para>
/// <para>
/// The string is formatted using the <see cref="CultureInfo.InvariantCulture"/>
/// format provider. To specify a localized provider use the
/// <see cref="DebugFormat(IFormatProvider,string,object[])"/> method.
/// </para>
/// <para>
/// This method does not take an <see cref="Exception"/> object to include in the
/// log event. To pass an <see cref="Exception"/> use one of the <see cref="Debug(object)"/>
/// methods instead.
/// </para>
/// </remarks>
virtual public void DebugFormat(string format, object arg0, object arg1, object arg2)
{
if (IsDebugEnabled)
{
Logger.Log(ThisDeclaringType, m_levelDebug, new SystemStringFormat(CultureInfo.InvariantCulture, format, new object[] { arg0, arg1, arg2 }), null);
}
}
/// <summary>
/// Logs a formatted message string with the <c>DEBUG</c> level.
/// </summary>
/// <param name="provider">An <see cref="IFormatProvider"/> that supplies culture-specific formatting information</param>
/// <param name="format">A String containing zero or more format items</param>
/// <param name="args">An Object array containing zero or more objects to format</param>
/// <remarks>
/// <para>
/// The message is formatted using the <see cref="String.Format(IFormatProvider, string, object[])"/> method. See
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -