// -----------------------------------------------------------------------
//
// Copyright 2011-2012 GRNET S.A. All rights reserved.
//
// Redistribution and use in source and binary forms, with or
// without modification, are permitted provided that the following
// conditions are met:
//
// 1. Redistributions of source code must retain the above
// copyright notice, this list of conditions and the following
// disclaimer.
//
// 2. Redistributions in binary form must reproduce the above
// copyright notice, this list of conditions and the following
// disclaimer in the documentation and/or other materials
// provided with the distribution.
//
// THIS SOFTWARE IS PROVIDED BY GRNET S.A. ``AS IS'' AND ANY EXPRESS
// OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
// WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
// PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL GRNET S.A OR
// CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
// USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
// AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
// LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
// ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
// POSSIBILITY OF SUCH DAMAGE.
//
// The views and conclusions contained in the software and
// documentation are those of the authors and should not be
// interpreted as representing official policies, either expressed
// or implied, of GRNET S.A.
//
// -----------------------------------------------------------------------
using System;
using System.Diagnostics;
namespace Caliburn.Micro.Logging
{
///
/// Implementation of the ILog and ILogExtended interfaces using
/// .
///
public class DebugLogger : ILog//, ILogExtended
{
#region Constants
private const string ErrorText = "ERROR";
private const string WarnText = "WARN";
private const string InfoText = "INFO";
#endregion
#region Fields
private readonly Type _type;
#endregion
#region Constructors
public DebugLogger(Type type)
{
_type = type;
}
#endregion
#region Helper Methods
private string CreateLogMessage(string format, params object[] args)
{
return string.Format("[{0}] {1}", DateTime.Now.ToString("o"), string.Format(format, args));
}
#endregion
#region ILog Members
///
/// Logs the exception.
///
/// The exception.
public void Error(Exception exception)
{
Debug.WriteLine(CreateLogMessage(exception.ToString()), ErrorText);
}
///
/// Logs the message as info.
///
/// A formatted message.Parameters to be injected into the formatted message.
public void Info(string format, params object[] args)
{
Debug.WriteLine(CreateLogMessage(format, args), InfoText);
}
///
/// Logs the message as a warning.
///
/// A formatted message.Parameters to be injected into the formatted message.
public void Warn(string format, params object[] args)
{
Debug.WriteLine(CreateLogMessage(format, args), WarnText);
}
#endregion
#region Implementation of ILogExtended
///
/// Logs the message as error.
///
/// A formatted message.
/// Parameters to be injected into the formatted message.
public void Error(string format, params object[] args)
{
Debug.WriteLine(CreateLogMessage(format, args), ErrorText);
}
///
/// Logs the exception.
///
/// The exception.
/// A formatted message.
/// Parameters to be injected into the formatted message.
public void Error(Exception exception, string format, params object[] args)
{
Debug.WriteLine(CreateLogMessage(format + " - Exception = " + exception.ToString(), args), ErrorText);
}
#endregion
}
}