195 lines
5.3 KiB
C#
195 lines
5.3 KiB
C#
|
//
|
||
|
// TraceSource.cs
|
||
|
//
|
||
|
// Authors:
|
||
|
// Atsushi Enomoto <atsushi@ximian.com>
|
||
|
// Marek Safar (marek.safar@gmail.com)
|
||
|
//
|
||
|
// Copyright (C) 2007 Novell, Inc.
|
||
|
// Copyright 2013 Xamarin Inc
|
||
|
//
|
||
|
// Permission is hereby granted, free of charge, to any person obtaining
|
||
|
// a copy of this software and associated documentation files (the
|
||
|
// "Software"), to deal in the Software without restriction, including
|
||
|
// without limitation the rights to use, copy, modify, merge, publish,
|
||
|
// distribute, sublicense, and/or sell copies of the Software, and to
|
||
|
// permit persons to whom the Software is furnished to do so, subject to
|
||
|
// the following conditions:
|
||
|
//
|
||
|
// The above copyright notice and this permission notice shall be
|
||
|
// included in all copies or substantial portions of the Software.
|
||
|
//
|
||
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||
|
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||
|
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||
|
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
||
|
// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
||
|
// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
||
|
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||
|
//
|
||
|
|
||
|
using System;
|
||
|
using System.Collections;
|
||
|
using System.Collections.Specialized;
|
||
|
using System.Configuration;
|
||
|
|
||
|
namespace System.Diagnostics
|
||
|
{
|
||
|
public class TraceSource
|
||
|
{
|
||
|
SourceSwitch source_switch;
|
||
|
TraceListenerCollection listeners;
|
||
|
|
||
|
public TraceSource (string name)
|
||
|
: this (name, SourceLevels.Off)
|
||
|
{
|
||
|
}
|
||
|
|
||
|
public TraceSource (string name, SourceLevels defaultLevel)
|
||
|
{
|
||
|
if (name == null)
|
||
|
throw new ArgumentNullException ("name");
|
||
|
if (name.Length == 0)
|
||
|
throw new ArgumentException ("name");
|
||
|
|
||
|
Hashtable sources = DiagnosticsConfiguration.Settings ["sources"] as Hashtable;
|
||
|
TraceSourceInfo info = sources != null ? sources [name] as TraceSourceInfo : null;
|
||
|
source_switch = new SourceSwitch (name);
|
||
|
|
||
|
if (info == null) {
|
||
|
listeners = new TraceListenerCollection ();
|
||
|
source_switch.Level = defaultLevel;
|
||
|
} else {
|
||
|
source_switch.Level = info.Levels;
|
||
|
listeners = info.Listeners;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public StringDictionary Attributes {
|
||
|
get { return source_switch.Attributes; }
|
||
|
}
|
||
|
|
||
|
public TraceListenerCollection Listeners {
|
||
|
get { return listeners; }
|
||
|
}
|
||
|
|
||
|
public string Name {
|
||
|
get { return source_switch.DisplayName; }
|
||
|
}
|
||
|
|
||
|
public SourceSwitch Switch {
|
||
|
get { return source_switch; }
|
||
|
set {
|
||
|
if (value == null)
|
||
|
throw new ArgumentNullException ("value");
|
||
|
source_switch = value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public void Close ()
|
||
|
{
|
||
|
lock (((ICollection) listeners).SyncRoot) {
|
||
|
foreach (TraceListener tl in listeners)
|
||
|
tl.Close ();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public void Flush ()
|
||
|
{
|
||
|
lock (((ICollection) listeners).SyncRoot) {
|
||
|
foreach (TraceListener tl in listeners)
|
||
|
tl.Flush ();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
[Conditional ("TRACE")]
|
||
|
public void TraceData (
|
||
|
TraceEventType eventType, int id, object data)
|
||
|
{
|
||
|
if (!source_switch.ShouldTrace (eventType))
|
||
|
return;
|
||
|
lock (((ICollection) listeners).SyncRoot) {
|
||
|
foreach (TraceListener tl in listeners)
|
||
|
tl.TraceData (new TraceEventCache(), Name, eventType, id, data);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
[Conditional ("TRACE")]
|
||
|
public void TraceData (
|
||
|
TraceEventType eventType, int id, params object [] data)
|
||
|
{
|
||
|
if (!source_switch.ShouldTrace (eventType))
|
||
|
return;
|
||
|
lock (((ICollection) listeners).SyncRoot) {
|
||
|
foreach (TraceListener tl in listeners)
|
||
|
tl.TraceData (new TraceEventCache(), Name, eventType, id, data);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
[Conditional ("TRACE")]
|
||
|
public void TraceEvent (TraceEventType eventType, int id)
|
||
|
{
|
||
|
if (!source_switch.ShouldTrace (eventType))
|
||
|
return;
|
||
|
lock (((ICollection) listeners).SyncRoot) {
|
||
|
foreach (TraceListener tl in listeners)
|
||
|
tl.TraceEvent (new TraceEventCache(), Name, eventType, id);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
[Conditional ("TRACE")]
|
||
|
public void TraceEvent (TraceEventType eventType,
|
||
|
int id, string message)
|
||
|
{
|
||
|
if (!source_switch.ShouldTrace (eventType))
|
||
|
return;
|
||
|
lock (((ICollection) listeners).SyncRoot) {
|
||
|
foreach (TraceListener tl in listeners)
|
||
|
tl.TraceEvent (new TraceEventCache(), Name, eventType, id, message);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
[Conditional ("TRACE")]
|
||
|
public void TraceEvent (TraceEventType eventType,
|
||
|
int id, string format, params object [] args)
|
||
|
{
|
||
|
if (!source_switch.ShouldTrace (eventType))
|
||
|
return;
|
||
|
lock (((ICollection) listeners).SyncRoot) {
|
||
|
foreach (TraceListener tl in listeners)
|
||
|
tl.TraceEvent (new TraceEventCache(), Name, eventType, id, format, args);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
[Conditional ("TRACE")]
|
||
|
public void TraceInformation (string format)
|
||
|
{
|
||
|
TraceEvent (TraceEventType.Information, 0, format);
|
||
|
}
|
||
|
|
||
|
[Conditional ("TRACE")]
|
||
|
public void TraceInformation (
|
||
|
string format, params object [] args)
|
||
|
{
|
||
|
TraceEvent (TraceEventType.Information, 0, format, args);
|
||
|
}
|
||
|
|
||
|
[Conditional ("TRACE")]
|
||
|
public void TraceTransfer (int id, string message, Guid relatedActivityId)
|
||
|
{
|
||
|
if (!source_switch.ShouldTrace (TraceEventType.Transfer ))
|
||
|
return;
|
||
|
lock (((ICollection) listeners).SyncRoot) {
|
||
|
foreach (TraceListener tl in listeners)
|
||
|
tl.TraceTransfer (new TraceEventCache(), Name, id, message, relatedActivityId);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
protected virtual string [] GetSupportedAttributes ()
|
||
|
{
|
||
|
return null;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|