// ----------------------------------------------------------------------- // // 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 } }