Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / whidbey / NetFxQFE / ndp / fx / src / Services / Monitoring / system / Diagnosticts / EventLogTraceListener.cs / 1 / EventLogTraceListener.cs
//------------------------------------------------------------------------------
//
// Copyright (c) Microsoft Corporation. All rights reserved.
//
//-----------------------------------------------------------------------------
/*
*/
namespace System.Diagnostics {
using System;
using System.Security;
using System.Security.Permissions;
using System.IO;
using System.Text;
using System.Globalization;
using System.Runtime.InteropServices;
///
/// Provides a simple listener for directing tracing or
/// debugging output to a or to a , such as or
/// .
///
[HostProtection(SecurityAction.LinkDemand, Synchronization=true)]
public sealed class EventLogTraceListener : TraceListener {
private EventLog eventLog;
private bool nameSet;
///
/// Initializes a new instance of the class without a trace
/// listener.
///
public EventLogTraceListener() {
}
///
/// Initializes a new instance of the class using the
/// specified event log.
///
public EventLogTraceListener(EventLog eventLog)
: base((eventLog != null) ? eventLog.Source : string.Empty) {
this.eventLog = eventLog;
}
///
/// Initializes a new instance of the class using the
/// specified source.
///
public EventLogTraceListener(string source) {
eventLog = new EventLog();
eventLog.Source = source;
}
///
/// Gets or sets the event log to write to.
///
public EventLog EventLog {
get {
return eventLog;
}
set {
eventLog = value;
}
}
///
/// Gets or sets the
/// name of this trace listener.
///
public override string Name {
get {
if (nameSet == false && eventLog != null) {
nameSet = true;
base.Name = eventLog.Source;
}
return base.Name;
}
set {
nameSet = true;
base.Name = value;
}
}
///
/// Closes the text writer so that it no longer receives tracing or
/// debugging output.
///
public override void Close() {
if (eventLog != null)
eventLog.Close();
}
///
///
///
protected override void Dispose(bool disposing) {
if (disposing)
this.Close();
}
///
/// Writes a message to this instance's event log.
///
public override void Write(string message) {
if (eventLog != null) eventLog.WriteEntry(message);
}
///
/// Writes a message to this instance's event log followed by a line terminator.
/// The default line terminator is a carriage return followed by a line feed
/// (\r\n).
///
public override void WriteLine(string message) {
Write(message);
}
[
ComVisible(false)
]
public override void TraceEvent(TraceEventCache eventCache, string source, TraceEventType severity, int id,
string format, params object[] args)
{
if (Filter != null && !Filter.ShouldTrace(eventCache, source, severity, id, format, args))
return;
EventInstance data = CreateEventInstance(severity, id);
if (args == null) {
eventLog.WriteEvent(data, format);
}
else if(String.IsNullOrEmpty(format)) {
string[] strings = new string[args.Length];
for (int i=0; i ushort.MaxValue)
id = ushort.MaxValue;
// Ideally we need to pick a value other than '0' as zero is
// a commonly used EventId by most applications
if (id < ushort.MinValue)
id = ushort.MinValue;
EventInstance data = new EventInstance(id, 0);
if (severity == TraceEventType.Error || severity == TraceEventType.Critical)
data.EntryType = EventLogEntryType.Error;
else if (severity == TraceEventType.Warning)
data.EntryType = EventLogEntryType.Warning;
else
data.EntryType = EventLogEntryType.Information;
return data;
}
}
}
// File provided for Reference Use Only by Microsoft Corporation (c) 2007.
//------------------------------------------------------------------------------
//
// Copyright (c) Microsoft Corporation. All rights reserved.
//
//-----------------------------------------------------------------------------
/*
*/
namespace System.Diagnostics {
using System;
using System.Security;
using System.Security.Permissions;
using System.IO;
using System.Text;
using System.Globalization;
using System.Runtime.InteropServices;
///
/// Provides a simple listener for directing tracing or
/// debugging output to a or to a , such as or
/// .
///
[HostProtection(SecurityAction.LinkDemand, Synchronization=true)]
public sealed class EventLogTraceListener : TraceListener {
private EventLog eventLog;
private bool nameSet;
///
/// Initializes a new instance of the class without a trace
/// listener.
///
public EventLogTraceListener() {
}
///
/// Initializes a new instance of the class using the
/// specified event log.
///
public EventLogTraceListener(EventLog eventLog)
: base((eventLog != null) ? eventLog.Source : string.Empty) {
this.eventLog = eventLog;
}
///
/// Initializes a new instance of the class using the
/// specified source.
///
public EventLogTraceListener(string source) {
eventLog = new EventLog();
eventLog.Source = source;
}
///
/// Gets or sets the event log to write to.
///
public EventLog EventLog {
get {
return eventLog;
}
set {
eventLog = value;
}
}
///
/// Gets or sets the
/// name of this trace listener.
///
public override string Name {
get {
if (nameSet == false && eventLog != null) {
nameSet = true;
base.Name = eventLog.Source;
}
return base.Name;
}
set {
nameSet = true;
base.Name = value;
}
}
///
/// Closes the text writer so that it no longer receives tracing or
/// debugging output.
///
public override void Close() {
if (eventLog != null)
eventLog.Close();
}
///
///
///
protected override void Dispose(bool disposing) {
if (disposing)
this.Close();
}
///
/// Writes a message to this instance's event log.
///
public override void Write(string message) {
if (eventLog != null) eventLog.WriteEntry(message);
}
///
/// Writes a message to this instance's event log followed by a line terminator.
/// The default line terminator is a carriage return followed by a line feed
/// (\r\n).
///
public override void WriteLine(string message) {
Write(message);
}
[
ComVisible(false)
]
public override void TraceEvent(TraceEventCache eventCache, string source, TraceEventType severity, int id,
string format, params object[] args)
{
if (Filter != null && !Filter.ShouldTrace(eventCache, source, severity, id, format, args))
return;
EventInstance data = CreateEventInstance(severity, id);
if (args == null) {
eventLog.WriteEvent(data, format);
}
else if(String.IsNullOrEmpty(format)) {
string[] strings = new string[args.Length];
for (int i=0; i ushort.MaxValue)
id = ushort.MaxValue;
// Ideally we need to pick a value other than '0' as zero is
// a commonly used EventId by most applications
if (id < ushort.MinValue)
id = ushort.MinValue;
EventInstance data = new EventInstance(id, 0);
if (severity == TraceEventType.Error || severity == TraceEventType.Critical)
data.EntryType = EventLogEntryType.Error;
else if (severity == TraceEventType.Warning)
data.EntryType = EventLogEntryType.Warning;
else
data.EntryType = EventLogEntryType.Information;
return data;
}
}
}
// File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- BamlLocalizabilityResolver.cs
- CompoundFileStreamReference.cs
- ContainsRowNumberChecker.cs
- Size.cs
- ResXFileRef.cs
- CompilerError.cs
- ApplicationBuildProvider.cs
- EntityViewGenerator.cs
- ContractsBCL.cs
- MenuItemBinding.cs
- Sequence.cs
- _DynamicWinsockMethods.cs
- HtmlImage.cs
- ChannelTracker.cs
- CombinedGeometry.cs
- ReadContentAsBinaryHelper.cs
- DecoderFallbackWithFailureFlag.cs
- HttpCookie.cs
- HotSpotCollection.cs
- ClassValidator.cs
- ProfileGroupSettingsCollection.cs
- BaseResourcesBuildProvider.cs
- StylusEventArgs.cs
- SiteMapDataSourceView.cs
- UriScheme.cs
- BitmapEffectDrawing.cs
- QilTargetType.cs
- GroupBox.cs
- IODescriptionAttribute.cs
- uribuilder.cs
- XmlExpressionDumper.cs
- Tile.cs
- CodeFieldReferenceExpression.cs
- FigureParaClient.cs
- CodeParameterDeclarationExpressionCollection.cs
- FileCodeGroup.cs
- TypeSystem.cs
- FacetValueContainer.cs
- _ConnectOverlappedAsyncResult.cs
- ComponentFactoryHelpers.cs
- ByteKeyFrameCollection.cs
- NativeObjectSecurity.cs
- FileRecordSequenceHelper.cs
- QilInvoke.cs
- HashHelper.cs
- MessageBox.cs
- RootBrowserWindow.cs
- WmpBitmapDecoder.cs
- DynamicResourceExtension.cs
- ObjectTag.cs
- StateInitialization.cs
- StringToken.cs
- PenThread.cs
- CompiledAction.cs
- HttpCookieCollection.cs
- HostProtectionException.cs
- FocusManager.cs
- GetReadStreamResult.cs
- RoutedCommand.cs
- Directory.cs
- DateTimeConstantAttribute.cs
- XmlCharCheckingReader.cs
- SessionEndingEventArgs.cs
- MailMessageEventArgs.cs
- SudsCommon.cs
- SizeAnimationBase.cs
- CodeExporter.cs
- ReadOnlyCollectionBase.cs
- SourceFileBuildProvider.cs
- SqlNotificationEventArgs.cs
- SystemResourceHost.cs
- TCPClient.cs
- RuntimeConfig.cs
- PropertyItem.cs
- ExternalCalls.cs
- WorkflowMarkupSerializationManager.cs
- XmlCharCheckingWriter.cs
- FlowchartDesignerCommands.cs
- ProxyGenerator.cs
- ContentPlaceHolder.cs
- HttpPostLocalhostServerProtocol.cs
- ServiceDesigner.cs
- CharacterHit.cs
- ColorTypeConverter.cs
- Section.cs
- MD5CryptoServiceProvider.cs
- LogLogRecord.cs
- SqlBuffer.cs
- WorkflowStateRollbackService.cs
- ValueUtilsSmi.cs
- ToolConsole.cs
- Point3DKeyFrameCollection.cs
- RootProjectionNode.cs
- RelationHandler.cs
- UnmanagedHandle.cs
- VisualBasicSettingsHandler.cs
- DataControlField.cs
- MenuItemAutomationPeer.cs
- SqlConnectionManager.cs
- HttpModuleAction.cs