|
2 | 2 |
|
3 | 3 | namespace Pretzel.Logic.Extensions |
4 | 4 | { |
| 5 | + /// <summary> |
| 6 | + /// Trace for Pretzel |
| 7 | + /// </summary> |
5 | 8 | public static class Tracing |
6 | 9 | { |
7 | | - [Obsolete("Use Tracing directly instead")] |
8 | | - public enum Category { |
9 | | - Debug, |
10 | | - Info, |
11 | | - Error |
12 | | - } |
| 10 | + private static Action<string, TraceLevel> _trace; |
| 11 | + private static TraceLevel _minLevel; |
13 | 12 |
|
14 | 13 | static Tracing() |
15 | 14 | { |
16 | | - Logger = new Logger(); |
| 15 | + // Do nothing by default |
| 16 | + _trace = (message, TraceLevel) => { }; |
| 17 | + _minLevel = TraceLevel.Info; |
17 | 18 | } |
18 | 19 |
|
19 | | - [Obsolete("Use Tracing directly instead")] |
20 | | - public static Logger Logger { get; set; } |
| 20 | + internal static void SetTrace(Action<string, TraceLevel> trace) |
| 21 | + { |
| 22 | + _trace = trace; |
| 23 | + } |
21 | 24 |
|
22 | | - public static void Debug(string message) |
| 25 | + internal static void SetMinimalLevel(TraceLevel level) |
23 | 26 | { |
24 | | - Logger.Write(message, Category.Debug); |
| 27 | + _minLevel = level; |
25 | 28 | } |
26 | 29 |
|
27 | | - public static void Info(string message) |
| 30 | + /// <summary> |
| 31 | + /// Trace a debug message |
| 32 | + /// </summary> |
| 33 | + /// <param name="message">Message to trace</param> |
| 34 | + /// <param name="messageParameters">Format parameters for the message</param> |
| 35 | + public static void Debug(string message, params object[] messageParameters) |
28 | 36 | { |
29 | | - Logger.Write(message, Category.Info); |
| 37 | + TraceMessage(message, messageParameters, TraceLevel.Debug); |
30 | 38 | } |
31 | 39 |
|
32 | | - public static void Error(string message) |
| 40 | + /// <summary> |
| 41 | + /// Trace an info message |
| 42 | + /// </summary> |
| 43 | + /// <param name="message">Message to trace</param> |
| 44 | + /// <param name="messageParameters">Format parameters for the message</param> |
| 45 | + public static void Info(string message, params object[] messageParameters) |
33 | 46 | { |
34 | | - Logger.Write(message, Category.Error); |
| 47 | + TraceMessage(message, messageParameters, TraceLevel.Info); |
35 | 48 | } |
36 | 49 |
|
37 | | - public static void DebugFormat(string message, params object[] messageParameters) |
| 50 | + /// <summary> |
| 51 | + /// Trace a warning message |
| 52 | + /// </summary> |
| 53 | + /// <param name="message">Message to trace</param> |
| 54 | + /// <param name="messageParameters">Format parameters for the message</param> |
| 55 | + public static void Warning(string message, params object[] messageParameters) |
38 | 56 | { |
39 | | - Logger.WriteFormat(message, Category.Debug, messageParameters); |
| 57 | + TraceMessage(message, messageParameters, TraceLevel.Warning); |
40 | 58 | } |
41 | 59 |
|
42 | | - public static void InfoFormat(string message, params object[] messageParameters) |
| 60 | + /// <summary> |
| 61 | + /// Trace an error message |
| 62 | + /// </summary> |
| 63 | + /// <param name="message">Message to trace</param> |
| 64 | + /// <param name="messageParameters">Format parameters for the message</param> |
| 65 | + public static void Error(string message, params object[] messageParameters) |
43 | 66 | { |
44 | | - Logger.WriteFormat(message, Category.Info, messageParameters); |
| 67 | + TraceMessage(message, messageParameters, TraceLevel.Error); |
45 | 68 | } |
46 | 69 |
|
47 | | - public static void ErrorFormat(string message, params object[] messageParameters) |
| 70 | + private static void TraceMessage(string message, object[] messageParameters, TraceLevel messageLevel) |
48 | 71 | { |
49 | | - Logger.WriteFormat(message, Category.Error, messageParameters); |
| 72 | + if(messageLevel >= _minLevel) |
| 73 | + { |
| 74 | + _trace(string.Format(message, messageParameters), messageLevel); |
| 75 | + } |
50 | 76 | } |
51 | 77 | } |
| 78 | + |
| 79 | + internal enum TraceLevel |
| 80 | + { |
| 81 | + Debug, |
| 82 | + Info, |
| 83 | + Warning, |
| 84 | + Error |
| 85 | + } |
52 | 86 | } |
0 commit comments