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; ////// [HostProtection(SecurityAction.LinkDemand, Synchronization=true)] public sealed class EventLogTraceListener : TraceListener { private EventLog eventLog; private bool nameSet; ///Provides a simple listener for directing tracing or /// debugging output to a ///or to a , such as or /// . /// public EventLogTraceListener() { } ///Initializes a new instance of the ///class without a trace /// listener. /// public EventLogTraceListener(EventLog eventLog) : base((eventLog != null) ? eventLog.Source : string.Empty) { this.eventLog = eventLog; } ///Initializes a new instance of the ///class using the /// specified event log. /// public EventLogTraceListener(string source) { eventLog = new EventLog(); eventLog.Source = source; } ///Initializes a new instance of the ///class using the /// specified source. /// public EventLog EventLog { get { return eventLog; } set { eventLog = value; } } ///Gets or sets the event log to write to. ////// 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; } } ///Gets or sets the /// name of this trace listener. ////// public override void Close() { if (eventLog != null) eventLog.Close(); } ///Closes the text writer so that it no longer receives tracing or /// debugging output. ////// /// protected override void Dispose(bool disposing) { if (disposing) this.Close(); } ////// public override void Write(string message) { if (eventLog != null) eventLog.WriteEntry(message); } ///Writes a message to this instance's event log. ////// 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; iWrites 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). ///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; ////// [HostProtection(SecurityAction.LinkDemand, Synchronization=true)] public sealed class EventLogTraceListener : TraceListener { private EventLog eventLog; private bool nameSet; ///Provides a simple listener for directing tracing or /// debugging output to a ///or to a , such as or /// . /// public EventLogTraceListener() { } ///Initializes a new instance of the ///class without a trace /// listener. /// public EventLogTraceListener(EventLog eventLog) : base((eventLog != null) ? eventLog.Source : string.Empty) { this.eventLog = eventLog; } ///Initializes a new instance of the ///class using the /// specified event log. /// public EventLogTraceListener(string source) { eventLog = new EventLog(); eventLog.Source = source; } ///Initializes a new instance of the ///class using the /// specified source. /// public EventLog EventLog { get { return eventLog; } set { eventLog = value; } } ///Gets or sets the event log to write to. ////// 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; } } ///Gets or sets the /// name of this trace listener. ////// public override void Close() { if (eventLog != null) eventLog.Close(); } ///Closes the text writer so that it no longer receives tracing or /// debugging output. ////// /// protected override void Dispose(bool disposing) { if (disposing) this.Close(); } ////// public override void Write(string message) { if (eventLog != null) eventLog.WriteEntry(message); } ///Writes a message to this instance's event log. ////// 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; iWrites 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). ///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
- ContentHostHelper.cs
- DataGridSortCommandEventArgs.cs
- EntityConnectionStringBuilder.cs
- TextLineResult.cs
- dbdatarecord.cs
- MetadataItemEmitter.cs
- InfiniteIntConverter.cs
- FixedTextPointer.cs
- EditableRegion.cs
- X509Chain.cs
- JsonFormatMapping.cs
- GroupBoxRenderer.cs
- TimeSpanSecondsConverter.cs
- PaintValueEventArgs.cs
- DependencyProperty.cs
- brushes.cs
- TileBrush.cs
- BadImageFormatException.cs
- SqlRecordBuffer.cs
- AgileSafeNativeMemoryHandle.cs
- CompositionTarget.cs
- PackageRelationshipSelector.cs
- Attributes.cs
- versioninfo.cs
- SiteMapDataSource.cs
- ToolStripComboBox.cs
- BamlRecords.cs
- Pair.cs
- XmlIgnoreAttribute.cs
- ProxyWebPartConnectionCollection.cs
- DataBinder.cs
- ScriptReference.cs
- ProfileServiceManager.cs
- XmlSchemaComplexType.cs
- EntityContainerEmitter.cs
- XmlSchemaComplexContentRestriction.cs
- SeverityFilter.cs
- ConfigurationPropertyAttribute.cs
- BitSet.cs
- RelativeSource.cs
- ColumnMapVisitor.cs
- SimpleWebHandlerParser.cs
- HostedTransportConfigurationManager.cs
- XmlHierarchicalEnumerable.cs
- RepeatInfo.cs
- StorageEntityContainerMapping.cs
- DataPointer.cs
- ValueExpressions.cs
- InfoCardRSACryptoProvider.cs
- URI.cs
- InfoCardClaimCollection.cs
- MonikerUtility.cs
- BaseInfoTable.cs
- PropertyMap.cs
- SchemaImporter.cs
- RawUIStateInputReport.cs
- HMACSHA384.cs
- EntityContainerAssociationSetEnd.cs
- _CommandStream.cs
- MobileUserControl.cs
- TransformGroup.cs
- LinkLabelLinkClickedEvent.cs
- CompressedStack.cs
- WebPartConnection.cs
- Common.cs
- HtmlUtf8RawTextWriter.cs
- SQLDateTimeStorage.cs
- FileLogRecord.cs
- RowSpanVector.cs
- WebEvents.cs
- MetadataProperty.cs
- RowsCopiedEventArgs.cs
- WaitHandleCannotBeOpenedException.cs
- TreeNodeCollectionEditorDialog.cs
- DTCTransactionManager.cs
- CodeIndexerExpression.cs
- LazyTextWriterCreator.cs
- Cloud.cs
- LineSegment.cs
- IisTraceWebEventProvider.cs
- FloatMinMaxAggregationOperator.cs
- KeyboardDevice.cs
- SqlAggregateChecker.cs
- TextSpanModifier.cs
- LOSFormatter.cs
- BinaryObjectInfo.cs
- OdbcHandle.cs
- UInt16Storage.cs
- FixedSOMSemanticBox.cs
- JsonObjectDataContract.cs
- CustomWebEventKey.cs
- Window.cs
- SplineKeyFrames.cs
- EndpointAddressMessageFilter.cs
- ResourceManager.cs
- JavascriptCallbackMessageInspector.cs
- OutKeywords.cs
- StringFreezingAttribute.cs
- EnumConverter.cs
- RefreshResponseInfo.cs