- clog_01_08.zip
- Documentation
- Keys
- OpenSource.snk
- Libraries
- EnterpriseLibrary
- Microsoft.Practices.EnterpriseLibrary.Common.dll
- Microsoft.Practices.EnterpriseLibrary.Data.dll
- Microsoft.Practices.EnterpriseLibrary.Logging.dll
- Microsoft.Practices.ObjectBuilder.dll
- Log4Net
- Microsoft.Silverlight.Testing
- Microsoft.Silverlight.Testing.dll
- Microsoft.VisualStudio.QualityTools.UnitTesting.Silverlight.dll
- RhinoMocks
- Unity
- Source
- Clog
- Core
- Core.sln
- Core.Tests
- Core.vsmdi
- Core
- Core1.vsmdi
- LocalTestRun.testrunconfig
- SilverlightCore
- SilverlightCore.sln
- SilverlightCore.Tests
- SilverlightCore
- SilverlightExamples.Web
- SilverlightExamples
- clog.zip
- Clog
- Source
- Clog.sln
- Logging
- LoggingTests
- LogStrategies
- EnterpriseLibraryLogStrategy
- Log4NetLogStrategy
- TestResults
- Daniel_SOJUZ 2007-12-02 14_17_21.trx
- Daniel_SOJUZ 2007-12-02 14_17_21
- Out
- License.txt
- NOTICE.txt
- Microsoft.Practices.EnterpriseLibrary.Common.dll
- Microsoft.Practices.EnterpriseLibrary.Data.dll
- Microsoft.Practices.EnterpriseLibrary.Logging.dll
- Microsoft.Practices.ObjectBuilder.dll
- LICENSE.txt
- log4net.dll
- NOTICE.txt
- SilverlightEdition
- Documentation
- ReadMe.txt
- Source
- Clog_SilverlightEdition.sln
- Default.snk
- ExampleSilverlightProject
- ExampleWebsite
- LocalTestRun.testrunconfig
- SilverlightLogging.vsmdi
- SilverlightLogging
- SilverlightLogUI
- WpfEdition
- ReadMe.txt
- Source
- Clog_WpfEdition.sln
- Clog_WpfEdition.vsmdi
- ExampleWebsite
- ExampleWpfApplication
- ExampleWpfBrowserApplication
- LocalTestRun.testrunconfig
- silverlightlogging.zip
- SilverlightLogging
- Documentation
- Libraries
- ReadMe.txt
- Source
- Default.snk
- ExampleSilverlightProject
- ExampleWebsite
- LocalTestRun.testrunconfig
- Log4NetLogStrategy
- Logging
- LoggingModule
- LoggingTests
- SilverlightLogging.sln
- SilverlightLogging.vsmdi
- SilverlightLogging
- SilverlightLogUI
|
/*
<File>
<Copyright>Copyright © 2007, Daniel Vaughan. All rights reserved.</Copyright>
<License see="prj:///Documentation/License.txt"/>
<Owner Name="Daniel Vaughan" Email="dbvaughan@gmail.com"/>
<CreationDate>2007/11/27 12:44</CreationDate>
<LastSubmissionDate>$Date: $</LastSubmissionDate>
<Version>$Revision: $</Version>
</File>
*/
using System.Collections.Generic;
using System.Diagnostics;
using Microsoft.Practices.EnterpriseLibrary.Logging;
namespace Orpius.Logging.LogStrategies
{
/// <summary>
/// A log strategy for the Microsoft Patterns and Practices
/// Enterprise Library Logging Application Block.
/// It's fairly rudimentary, and converts
/// <see cref="LogLevel"/>s into Categories,
/// Priorities, and Severities; perhaps
/// oversimplifying the Enterprise Library Logging.
/// </summary>
class EnterpriseLibraryStrategy : ILogStrategy
{
static readonly LogLevel[] logLevels = new LogLevel[]
{
LogLevel.All, LogLevel.Debug, LogLevel.Info,
LogLevel.Warn, LogLevel.Error, LogLevel.Fatal
};
public LogLevel GetLogLevel(IClientInfo clientInfo)
{
foreach (LogLevel level in logLevels)
{
if (ShouldLog(level))
{
return level;
}
}
return LogLevel.None;
}
static bool ShouldLog(LogLevel level)
{
LogEntry entry = new LogEntry();
entry.Priority = (int)level;
return Logger.ShouldLog(entry);
}
public void Write(IClientLogEntry logEntry)
{
LogEntry elEntry = new LogEntry();
elEntry.MachineName = logEntry.MachineName;
elEntry.ManagedThreadName = logEntry.ManagedThreadId.ToString();
elEntry.Message = logEntry.Message;
elEntry.Priority = (int)logEntry.LogLevel;
elEntry.Severity = Convert(logEntry.LogLevel);
elEntry.TimeStamp = logEntry.OccuredAt;
// elEntry.ManagedThreadName
// elEntry.ProcessName
elEntry.Categories.Add("General");
elEntry.Categories.Add(logEntry.LogLevel.ToString("G"));
Dictionary<string, object> properties = new Dictionary<string, object>();
if (logEntry.ExceptionMemento != null)
{
elEntry.AddErrorMessage(logEntry.ExceptionMemento.ToString());
}
properties.Add("CodeLocation", logEntry.CodeLocation);
Logger.Write(elEntry, properties);
}
public void Write(IServerLogEntry logEntry)
{
LogEntry elEntry = new LogEntry();
elEntry.MachineName = logEntry.MachineName;
elEntry.ManagedThreadName = logEntry.ManagedThreadId.ToString();
elEntry.Message = logEntry.Message;
elEntry.Priority = (int)logEntry.LogLevel;
elEntry.Severity = Convert(logEntry.LogLevel);
elEntry.TimeStamp = logEntry.OccuredAt;
elEntry.AppDomainName = logEntry.AppDomain;
/* TODO: Populate these extra bits. */
// elEntry.ManagedThreadName
// elEntry.ProcessName =
elEntry.Categories.Add("General");
elEntry.Categories.Add(logEntry.LogLevel.ToString("G"));
Dictionary<string, object> properties = new Dictionary<string, object>();
if (logEntry.Exception != null)
{
string errorMessage = string.Format("{0}\n{1}",
logEntry.Exception, logEntry.Exception.StackTrace);
elEntry.AddErrorMessage(errorMessage);
}
properties.Add("CodeLocation", logEntry.CodeLocation);
Logger.Write(elEntry, properties);
}
static TraceEventType Convert(LogLevel level)
{
switch (level)
{
case LogLevel.All:
case LogLevel.Debug:
return TraceEventType.Verbose;
case LogLevel.Info:
return TraceEventType.Information;
case LogLevel.Warn:
return TraceEventType.Warning;
case LogLevel.Error:
return TraceEventType.Error;
case LogLevel.Fatal:
return TraceEventType.Critical;
default:
return TraceEventType.Information;
}
}
}
}
|
By viewing downloads associated with this article you agree to the Terms of Service and the article's licence.
If a file you wish to view isn't highlighted, and is a text file (not binary), please
let us know and we'll add colourisation support for it.
Daniel is a former senior engineer in Technology and Research at the Office of the CTO at Microsoft, working on next generation systems.
Previously Daniel was a nine-time Microsoft MVP and co-founder of
Outcoder, a Swiss software and consulting company.
Daniel is the author of Windows Phone 8 Unleashed and Windows Phone 7.5 Unleashed, both published by SAMS.
Daniel is the developer behind several acclaimed mobile apps including
Surfy Browser for Android and Windows Phone. Daniel is the creator of a number of popular open-source projects, most notably
Codon.
Would you like Daniel to bring value to your organisation?
Please contact
Blog |
Twitter
Xamarin Experts
Windows 10 Experts