Слушатель трассировки не записывает информацию трассировки - PullRequest
0 голосов
/ 17 февраля 2012
public sealed class Logger
{
    private static TraceSource myTraceSource;

    private Logger()
    {
    }

    public static TraceSource Create()
    {
        if (myTraceSource == null)
            return myTraceSource = new TraceSource("myTraceSource");
        else
            return myTraceSource;
    }

    public static void WriteInfo(string message)
    {
        myTraceSource.TraceEvent(TraceEventType.Information, 0, message);
        myTraceSource.Flush();
    }

    public static void WriteError(Exception ex)
    {
        myTraceSource.TraceEvent(TraceEventType.Error, 1, ex.Message);
        myTraceSource.Flush();            
    }

    public static void WriteError(string message)
    {
        myTraceSource.TraceEvent(TraceEventType.Error, 1, message);
        myTraceSource.Flush();
    }

    public static void WriteWarning(string message)
    {
        myTraceSource.TraceEvent(TraceEventType.Warning, 2, message);
        myTraceSource.Flush();
    }

    public static void AddListener(TraceListener listener)
    {
        myTraceSource.Listeners.Add(listener);
    }

    public static void Close()
    {
        if (myTraceSource != null)
        {
            myTraceSource.Flush();
            myTraceSource.Close();
        }
    }       
}

Ниже приведен код для инициализации источника трассировки и добавления прослушивателя

Logger.Create();
TextWriterTraceListener myTextListener = new TextWriterTraceListener(LogCompletePath);
Logger.AddListener(myTextListener);
Logger.WriteError("error");

Примечание. Я не поместил тег SytemDiagnostic в appconfig, поскольку я хочу сделать это в коде.

1 Ответ

4 голосов
/ 17 февраля 2012

Получил ответ в другом форуме.Я забыл упомянуть Source Level и по умолчанию он отключен

 return myTraceSource = new TraceSource("myTraceSource", SourceLevels.All); 
...