0

我应该如何在自定义 TraceListener 中实现支持缩进?

Trace.Indent();
// or
Trace.Unindent();

即使有以下实现也不起作用:

protected override void WriteIndent() { ... }

在那个自定义 TraceListener 中。

我错过了什么吗?

4

3 回答 3

1

你可以使用一个TextWriterTraceListener类。它支持缩进。

于 2010-02-10T08:35:35.173 回答
1

我认为您必须自己明确调用WriteIndent(如果我正确解释了文档)。此代码按预期工作:

using System;
using System.Xml.Serialization;
using System.Diagnostics;

class Program {

    class TestListener : TraceListener {

        protected override void WriteIndent() {
            if (NeedIndent) {
                string indent = new string(' ',IndentLevel * IndentSize);
                Console.Write(indent);
            }
        }

        public override void Write(string message) {
            WriteIndent();
            Console.Write(message);
        }

        public override void WriteLine(string message) {
            WriteIndent();
            Console.WriteLine(message);
        }
    }


    public static void Main(params string[] args) {

        Trace.Listeners.Add(new TestListener());
        Trace.IndentSize = 2;
        Trace.WriteLine("test");
        Trace.IndentLevel = 4;
        Trace.WriteLine("indented");
    }
}
于 2010-02-10T08:58:34.400 回答
1

我已经想通了,因为 Trace 的这 2 个静态方法更改了 IndentLevel。所以我这样做:

...
if (entry.IndentLevel > 0)
    writer.WriteLine(
        new string(' ', entry.IndentLevel * IndentSize) +
...
于 2010-02-12T22:09:19.023 回答