Mirror of Svelto.ECS because we're a fan of it
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

152 lines
4.3KB

  1. using System;
  2. #if NETFX_CORE
  3. using Windows.System.Diagnostics;
  4. #else
  5. using System.Diagnostics;
  6. #endif
  7. using System.Text;
  8. namespace Utility
  9. {
  10. public static class Console
  11. {
  12. static StringBuilder _stringBuilder = new StringBuilder(256);
  13. #if UNITY_5_3_OR_NEWER || UNITY_5
  14. public static ILogger logger = new SlowLoggerUnity();
  15. #else
  16. public static ILogger logger = new SimpleLogger();
  17. #endif
  18. public static volatile bool BatchLog = false;
  19. //Hack, have to find the right solution
  20. public static Action<Exception, object, string, string> onException;
  21. static Console()
  22. {
  23. onException = (e, obj, message, stack) =>
  24. {
  25. UnityEngine.Debug.LogException(e, (UnityEngine.Object)obj);
  26. };
  27. }
  28. public static void Log(string txt)
  29. {
  30. logger.Log(txt);
  31. }
  32. public static void LogError(string txt)
  33. {
  34. string toPrint;
  35. lock (_stringBuilder)
  36. {
  37. _stringBuilder.Length = 0;
  38. _stringBuilder.Append("-!!!!!!-> ");
  39. _stringBuilder.Append(txt);
  40. toPrint = _stringBuilder.ToString();
  41. }
  42. logger.Log(toPrint, null, LogType.Error);
  43. }
  44. public static void LogError(string txt, string stack)
  45. {
  46. string toPrint;
  47. lock (_stringBuilder)
  48. {
  49. _stringBuilder.Length = 0;
  50. _stringBuilder.Append("-!!!!!!-> ");
  51. _stringBuilder.Append(txt);
  52. toPrint = _stringBuilder.ToString();
  53. }
  54. logger.Log(toPrint, stack, LogType.Error);
  55. }
  56. public static void LogException(Exception e)
  57. {
  58. LogException(e, null);
  59. }
  60. public static void LogException(Exception e, UnityEngine.Object obj)
  61. {
  62. string toPrint;
  63. string stackTrace;
  64. lock (_stringBuilder)
  65. {
  66. _stringBuilder.Length = 0;
  67. _stringBuilder.Append("-!!!!!!-> ").Append(e.Message);
  68. stackTrace = e.StackTrace;
  69. if (e.InnerException != null)
  70. {
  71. e = e.InnerException;
  72. _stringBuilder.Append(" Inner Message: ").Append(e.Message).Append(" Inner Stacktrace:")
  73. .Append(e.StackTrace);
  74. stackTrace = e.StackTrace;
  75. }
  76. toPrint = _stringBuilder.ToString();
  77. }
  78. onException(e, obj, toPrint, stackTrace);
  79. }
  80. public static void LogWarning(string txt)
  81. {
  82. string toPrint;
  83. lock (_stringBuilder)
  84. {
  85. _stringBuilder.Length = 0;
  86. _stringBuilder.Append("------> ");
  87. _stringBuilder.Append(txt);
  88. toPrint = _stringBuilder.ToString();
  89. }
  90. logger.Log(toPrint, null, LogType.Warning);
  91. }
  92. /// <summary>
  93. /// Use this function if you don't want the message to be batched
  94. /// </summary>
  95. /// <param name="txt"></param>
  96. public static void SystemLog(string txt)
  97. {
  98. string toPrint;
  99. lock (_stringBuilder)
  100. {
  101. #if NETFX_CORE
  102. string currentTimeString = DateTime.UtcNow.ToString("dd/mm/yy hh:ii:ss");
  103. string processTimeString = (DateTime.UtcNow - ProcessDiagnosticInfo.GetForCurrentProcess().ProcessStartTime.DateTime).ToString();
  104. #else
  105. string currentTimeString = DateTime.UtcNow.ToLongTimeString(); //ensure includes seconds
  106. string processTimeString = (DateTime.Now - Process.GetCurrentProcess().StartTime).ToString();
  107. #endif
  108. _stringBuilder.Length = 0;
  109. _stringBuilder.Append("[").Append(currentTimeString);
  110. _stringBuilder.Append("][").Append(processTimeString);
  111. _stringBuilder.Length = _stringBuilder.Length - 3; //remove some precision that we don't need
  112. _stringBuilder.Append("] ").AppendLine(txt);
  113. toPrint = _stringBuilder.ToString();
  114. }
  115. #if !UNITY_EDITOR && !NETFX_CORE
  116. System.Console.WriteLine(toPrint);
  117. #else
  118. UnityEngine.Debug.Log(toPrint);
  119. #endif
  120. }
  121. }
  122. }