-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathLogger.cs
More file actions
72 lines (62 loc) · 1.85 KB
/
Logger.cs
File metadata and controls
72 lines (62 loc) · 1.85 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
using System;
using Microsoft.VisualStudio.Shell;
using Microsoft.VisualStudio.Shell.Interop;
namespace CodingWithCalvin.OpenInNotepadPlusPlus.Helpers
{
public static class Logger
{
private static IVsOutputWindowPane _pane;
private static IServiceProvider _provider;
private static string _name;
public static void Initialize(Package provider, string name)
{
_provider = provider;
_name = name;
}
public static void Log(string message)
{
if (string.IsNullOrEmpty(message))
{
return;
}
try
{
if (!EnsurePane())
{
return;
}
ThreadHelper.ThrowIfNotOnUIThread();
_pane.OutputStringThreadSafe(DateTime.Now + ": " + message + Environment.NewLine);
}
catch (Exception ex)
{
System.Diagnostics.Debug.WriteLine(ex);
}
}
public static void Log(Exception ex)
{
if (ex == null)
{
return;
}
ThreadHelper.ThrowIfNotOnUIThread();
Log(ex.ToString());
}
private static bool EnsurePane()
{
ThreadHelper.ThrowIfNotOnUIThread();
if (_pane == null)
{
var guid = Guid.NewGuid();
var output = _provider.GetService(typeof(SVsOutputWindow)) as IVsOutputWindow;
if (output == null)
{
throw new ArgumentNullException(nameof(output));
}
output.CreatePane(ref guid, _name, 1, 1);
output.GetPane(ref guid, out _pane);
}
return _pane != null;
}
}
}