/// <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>
        protected override void Initialize()
        {
            try
            {
                SmartTestsWindowCommand.Initialize(this);
                base.Initialize();

                ThreadHelper.ThrowIfNotOnUIThread();
                var dte = (DTE)GetService(typeof(DTE));

                var compositionService = (IComponentModel)ServiceProvider.GlobalProvider.GetService(typeof(SComponentModel));
                compositionService.DefaultCompositionService.SatisfyImportsOnce(this);


                var solutionEvents = dte.Events.SolutionEvents;
                solutionEvents.Opened += () => SolutionEventsOnOpened(dte.Solution);
                if (dte.Solution != null)
                {
                    SolutionEventsOnOpened(dte.Solution);   // Force detection of current solution
                }
            }
            catch (Exception e)
            {
                Trace.TraceError(e.Message + Environment.NewLine + e.StackTrace);
                throw;
            }
        }
        /// <summary>
        ///     Initializes the singleton instance of the command.
        /// </summary>
        /// <param name="package">Owner package, not null.</param>
        public static async Task InitializeAsync(AsyncPackage package)
        {
            // Switch to the main thread - the call to AddCommand in SmartTestsWindowCommand's constructor requires
            // the UI thread.
            await ThreadHelper.JoinableTaskFactory.SwitchToMainThreadAsync(package.DisposalToken);

            OleMenuCommandService commandService = await package.GetServiceAsync((typeof(IMenuCommandService))) as OleMenuCommandService;

            Instance = new SmartTestsWindowCommand(package, commandService);
        }
        /// <summary>
        ///     The async initialization portion of the package initialization process. This method is invoked from a background
        ///     thread.
        /// </summary>
        /// <param name="cancellationToken">
        ///     A cancellation token to monitor for initialization cancellation, which can occur when
        ///     VS is shutting down.
        /// </param>
        /// <param name="progress">The callback to notify for progress.</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 JoinableTaskFactory.SwitchToMainThreadAsync(cancellationToken);

            await SmartTestsWindowCommand.InitializeAsync(this);

            //var compositionService = (IComponentModel)await GetServiceAsync(typeof(SComponentModel));
            //compositionService.DefaultCompositionService.SatisfyImportsOnce(this);

            var dte = (DTE) await GetServiceAsync(typeof(DTE));

            var solutionEvents = dte.Events.SolutionEvents;

            solutionEvents.Opened += () => SolutionEventsOnOpened(dte.Solution);
            if (dte.Solution != null)
            {
                SolutionEventsOnOpened(dte.Solution);   // Force detection of current solution
            }
        }
Example #4
0
 /// <summary>
 ///     Initializes the singleton instance of the command.
 /// </summary>
 /// <param name="package">Owner package, not null.</param>
 public static void Initialize(Package package)
 {
     Instance = new SmartTestsWindowCommand(package);
 }