/// <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) { try { Debug.WriteLine(string.Format(CultureInfo.CurrentCulture, "InitializeAsync CppCoverage")); // 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 JoinableTaskFactory.SwitchToMainThreadAsync(cancellationToken); //Critical initialization solutionService = await GetServiceAsync(typeof(SVsSolution)) as IVsSolution; // Get DTE InitializeDTE(); // Restore parameters var options = (CoverageOptionPageGrid)GetDialogPage(typeof(CoverageOptionPageGrid)); if (options != null) { options.LoadSettingsFromStorage(); } // Add event tracker eventSolution = new SolutionEvent(solutionService, dte); // Build menu / dialog await CoverageMenu.InitializeAsync(this, dte as EnvDTE80.DTE2); await NubiloSoft.CoverageExt.CoverageSelectorCommand.InitializeAsync(this); // Call auto load eventSolution.OnAfterOpenSolution(null, 0); Debug.WriteLine(string.Format(CultureInfo.CurrentCulture, "InitializeAsync CppCoverage done")); } catch (Exception) { Debug.WriteLine(string.Format(CultureInfo.CurrentCulture, "InitializeAsync Error")); } }