TraceUtility.cs 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. //-----------------------------------------------------------------------------
  2. // Copyright (c) Microsoft Corporation. All rights reserved.
  3. //-----------------------------------------------------------------------------
  4. namespace System.Runtime.Serialization.Diagnostics
  5. {
  6. using System.Collections.Generic;
  7. using System.Diagnostics;
  8. using System.Globalization;
  9. using System.Runtime;
  10. using System.Runtime.Diagnostics;
  11. using System.ServiceModel.Diagnostics;
  12. static class TraceUtility
  13. {
  14. static Dictionary<int, string> traceCodes = new Dictionary<int, string>(18)
  15. {
  16. { TraceCode.WriteObjectBegin, "WriteObjectBegin" },
  17. { TraceCode.WriteObjectEnd, "WriteObjectEnd" },
  18. { TraceCode.WriteObjectContentBegin, "WriteObjectContentBegin" },
  19. { TraceCode.WriteObjectContentEnd, "WriteObjectContentEnd" },
  20. { TraceCode.ReadObjectBegin, "ReadObjectBegin" },
  21. { TraceCode.ReadObjectEnd, "ReadObjectEnd" },
  22. { TraceCode.ElementIgnored, "ElementIgnored" },
  23. { TraceCode.XsdExportBegin, "XsdExportBegin" },
  24. { TraceCode.XsdExportEnd, "XsdExportEnd" },
  25. { TraceCode.XsdImportBegin, "XsdImportBegin" },
  26. { TraceCode.XsdImportEnd, "XsdImportEnd" },
  27. { TraceCode.XsdExportError, "XsdExportError" },
  28. { TraceCode.XsdImportError, "XsdImportError" },
  29. { TraceCode.XsdExportAnnotationFailed, "XsdExportAnnotationFailed" },
  30. { TraceCode.XsdImportAnnotationFailed, "XsdImportAnnotationFailed" },
  31. { TraceCode.XsdExportDupItems, "XsdExportDupItems" },
  32. { TraceCode.FactoryTypeNotFound, "FactoryTypeNotFound" },
  33. { TraceCode.ObjectWithLargeDepth, "ObjectWithLargeDepth" },
  34. };
  35. internal static void Trace(TraceEventType severity, int traceCode, string traceDescription)
  36. {
  37. Trace(severity, traceCode, traceDescription, null);
  38. }
  39. internal static void Trace(TraceEventType severity, int traceCode, string traceDescription, TraceRecord record)
  40. {
  41. Trace(severity, traceCode, traceDescription, record, null);
  42. }
  43. internal static void Trace(TraceEventType severity, int traceCode, string traceDescription, TraceRecord record, Exception exception)
  44. {
  45. Fx.Assert(traceCodes.ContainsKey(traceCode),
  46. string.Format(CultureInfo.InvariantCulture, "Unsupported trace code: Please add trace code 0x{0} to the dictionary TraceUtility.traceCodes in {1}",
  47. traceCode.ToString("X", CultureInfo.InvariantCulture), typeof(TraceUtility)));
  48. #if !MONO
  49. string msdnTraceCode = System.ServiceModel.Diagnostics.LegacyDiagnosticTrace.GenerateMsdnTraceCode("System.Runtime.Serialization", traceCodes[traceCode]);
  50. #else
  51. string msdnTraceCode = "";
  52. #endif
  53. DiagnosticUtility.DiagnosticTrace.TraceEvent(severity, traceCode, msdnTraceCode, traceDescription, record, exception, null);
  54. }
  55. }
  56. }