예제 #1
0
        /// <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 AddTranslationCommand.InitializeAsync(this).ConfigureAwait(false);
        }
예제 #2
0
        /// <summary>
        /// Initializes the singleton instance of the command.
        /// </summary>
        /// <param name="package">Owner package, not null.</param>
        public static async Task InitializeAsync(AsyncPackage package)
        {
#warning Try to find out better solution, this seems like a workaround.
            // For some reason, not all DLLs are loaded in extension (this how VS experimental instance loads them),
            // so here we manually load assembly and then resources.
            try
            {
                System.Reflection.Assembly.Load("AddTranslation.Core");

                Application.Current.Resources.MergedDictionaries.Add(new ResourceDictionary()
                {
                    Source = new Uri(@"pack://*****:*****@"pack://application:,,,/AddTranslation.Core;component/UserInterfaceResources/SmallStylesForControls.xaml", UriKind.RelativeOrAbsolute)
                });
                Application.Current.Resources.MergedDictionaries.Add(new ResourceDictionary()
                {
                    Source = new Uri(@"pack://*****:*****@"pack://application:,,,/AddTranslation.Core;component/UserInterfaceResources/ScrollBar.xaml", UriKind.RelativeOrAbsolute)
                });
                Application.Current.Resources.MergedDictionaries.Add(new ResourceDictionary()
                {
                    Source = new Uri(@"pack://*****:*****@"pack://application:,,,/AddTranslation.Core;component/UserInterfaceResources/DataGridStylesAndTemplates.xaml", UriKind.RelativeOrAbsolute)
                });
            }
            catch (Exception ex)
            {
                _logger.Error($"Could not load AddTranslation.Core assembly.", ex);
                MessageBox.Show($"Could not load AddTranslation.Core assembly.\nException: {ex.Message}\nPlease report this at GitHub repo https://github.com/mturczyn/TranslationExtension/issues", "Error", MessageBoxButton.OK, MessageBoxImage.Error);
                return;
            }

            // Switch to the main thread - the call to AddCommand in AddTranslationCommand's constructor requires
            // the UI thread.
            await ThreadHelper.JoinableTaskFactory.SwitchToMainThreadAsync(package.DisposalToken);

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

            Assumes.Present(commandService);
            // Get Visual Studio extensibility object.
            var dte = (DTE)await package.GetServiceAsync(typeof(DTE));

            Assumes.Present(dte);

            Instance = new AddTranslationCommand(commandService, package);
        }