Profiler.cs 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. using System;
  2. using System.Diagnostics;
  3. using System.Linq;
  4. using System.Runtime.CompilerServices;
  5. using InABox.Core;
  6. namespace InABox.Core
  7. {
  8. public class Profiler : IDisposable
  9. {
  10. private Stopwatch _stopwatch;
  11. protected string MethodName { get; set; }
  12. public string? ClassName { get; set; }
  13. private bool _logOnDispose = false;
  14. public Profiler(bool logOnDispose, [CallerMemberName] string methodName = "") : base()
  15. {
  16. _logOnDispose = logOnDispose;
  17. MethodName = methodName;
  18. _stopwatch = new Stopwatch();
  19. _stopwatch.Start();
  20. }
  21. public long GetElapsedMilliseconds() => _stopwatch.ElapsedMilliseconds;
  22. public void Pause() => _stopwatch.Stop();
  23. public void Resume() => _stopwatch.Start();
  24. public void Restart() => _stopwatch.Restart();
  25. public void Log()
  26. {
  27. _stopwatch.Stop();
  28. Logger.Send(LogType.Information, "", $"- {MethodName}{ClassName}() returned in {_stopwatch.ElapsedMilliseconds}ms");
  29. _stopwatch.Restart();
  30. }
  31. public void Log(int count)
  32. {
  33. _stopwatch.Stop();
  34. Logger.Send(LogType.Information, "", $"- {MethodName}{ClassName}() returned {count} items in {_stopwatch.ElapsedMilliseconds}ms");
  35. _stopwatch.Restart();
  36. }
  37. public void Log(string name)
  38. {
  39. _stopwatch.Stop();
  40. Logger.Send(LogType.Information, "", $"- {MethodName}{ClassName}() [{name}] returned in {_stopwatch.ElapsedMilliseconds}ms");
  41. _stopwatch.Restart();
  42. }
  43. public void Log(string format, params object[] values)
  44. {
  45. _stopwatch.Stop();
  46. Logger.Send(LogType.Information, "", $"- [{String.Format(format,values)}] returned in {_stopwatch.ElapsedMilliseconds}ms");
  47. _stopwatch.Restart();
  48. }
  49. public void Dispose()
  50. {
  51. if (_logOnDispose)
  52. Log();
  53. _stopwatch.Stop();
  54. _stopwatch = null;
  55. }
  56. public void Dispose(int count)
  57. {
  58. if (_logOnDispose)
  59. Log(count);
  60. _stopwatch.Stop();
  61. _stopwatch = null;
  62. }
  63. }
  64. public class Profiler<T> : Profiler
  65. {
  66. public Profiler(bool logOnDispose, [CallerMemberName] string methodName = "") : base(logOnDispose, methodName)
  67. {
  68. ClassName = typeof(T).Name.Split('.').Last();
  69. }
  70. }
  71. }