-
Notifications
You must be signed in to change notification settings - Fork 0
/
LogWrapperCommandPackage.cs
89 lines (80 loc) · 3.68 KB
/
LogWrapperCommandPackage.cs
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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
using System;
using System.Runtime.InteropServices;
using System.Threading;
using Microsoft.VisualStudio.Shell;
using Task = System.Threading.Tasks.Task;
namespace LogWrapperCommand
{
/// <summary>
/// This is the class that implements the package exposed by this assembly.
/// </summary>
/// <remarks>
/// <para>
/// The minimum requirement for a class to be considered a valid package for Visual Studio
/// is to implement the IVsPackage interface and register itself with the shell.
/// This package uses the helper classes defined inside the Managed Package Framework (MPF)
/// to do it: it derives from the Package class that provides the implementation of the
/// IVsPackage interface and uses the registration attributes defined in the framework to
/// register itself and its components with the shell. These attributes tell the pkgdef creation
/// utility what data to put into .pkgdef file.
/// </para>
/// <para>
/// To get loaded into VS, the package must be referred by <Asset Type="Microsoft.VisualStudio.VsPackage" ...> in .vsixmanifest file.
/// </para>
/// </remarks>
[PackageRegistration(UseManagedResourcesOnly = true, AllowsBackgroundLoading = true)]
[Guid(LogWrapperCommandPackage.PackageGuidString)]
[ProvideMenuResource("Menus.ctmenu", 1)]
[ProvideOptionPage(typeof(OptionsPageGrid), "LogWrapper", "Settings", 0,0, true)]
public sealed class LogWrapperCommandPackage : AsyncPackage
{
/// <summary>
/// LogWrapperCommandPackage GUID string.
/// </summary>
public const string PackageGuidString = "e17e8d9d-1c6a-4eba-b523-5d324b5a58a6";
#region Package Members
/// <summary>
/// Initialization of the package; this method is called right after the package is sited, so this is the place
/// where you can put all the initialization code that rely on services provided by VisualStudio.
/// </summary>
/// <param name="cancellationToken">A cancellation token to monitor for initialization cancellation, which can occur when VS is shutting down.</param>
/// <param name="progress">A provider for progress updates.</param>
/// <returns>A task representing the async work of package initialization, or an already completed task if there is none. Do not return null from this method.</returns>
protected override async Task InitializeAsync(CancellationToken cancellationToken, IProgress<ServiceProgressData> progress)
{
// When initialized asynchronously, the current thread may be a background thread at this point.
// Do any initialization that requires the UI thread after switching to the UI thread.
await this.JoinableTaskFactory.SwitchToMainThreadAsync(cancellationToken);
await LogWrapperCommand.InitializeAsync(this);
}
/// <summary>
/// Gets the user settings for 'prolog' text.
/// </summary>
/// <value>
/// The user settings for 'prolog' text.
/// </value>
public string PrologText
{
get
{
var page = (OptionsPageGrid)GetDialogPage(typeof(OptionsPageGrid));
return page.PrologText;
}
}
/// <summary>
/// Gets the user settings for 'epilog' text.
/// </summary>
/// <value>
/// The user settings for 'epilog' text.
/// </value>
public string EpilogText
{
get
{
var page = (OptionsPageGrid)GetDialogPage(typeof(OptionsPageGrid));
return page.EpilogText;
}
}
#endregion
}
}