views:

374

answers:

3

When Exception is displayed (or more general - when it is converted to String) stack trace is shown. What I want to do is to change the format of source code's file paths shown in such trace.

Specifically I would like to leave filenames only (without full path) or show only that part of path which starts with project's base directory. Full paths are usually unnecessary and clutter the whole message.

How can I do that?

+8  A: 

I asked a similar question, although not entirely the same, here: Print stack trace information in C#.

What you can do is this:

var trace = new System.Diagnostics.StackTrace(exception);

which gives you a StackTrace object that gives you all the information you need. In my case it was about avoiding having to deal with localized exception text, but I'd imagine you can use the same approach for your needs.


Edit: I note that I have added a comment to the accepted answer to my question related to a "needFileInfo" parameter to the constructor. I see this constructor here: StackTrace(Exception e, bool fNeedFileInfo), I can't find the actual code in question right now but I would guess you need to pass true to that argument. I guess experimentation is the key here.

In other words, I guess the code should be this:

var trace = new System.Diagnostics.StackTrace(exception, true);
Lasse V. Karlsen
+1 nice tip about StackTrace class. I never knew it could take an exception as a constructor parameter!
Josh Einstein
How is this different from `exception.StackTrace`?
Chris Marisic
Exception.StackTrace is a String, this is a class that gives programmatic access to the parts of the stack trace, including file names, line numbers, class names, etc. in pieces, not as a single string.
Lasse V. Karlsen
+1  A: 

Check out the System.Diagnostics.StackFrame class and the GetFileName method. You can write a method that will get the stack trace and the names of the source files that you can call in your exception handler.

TLiebe
A: 

You may find this website useful http://www.csharp.hostzi.com It doesn't do exactly what you are asking for, but improves the readability of the stack trace, which you probably aim to achieve.

brava_mi