/// <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); // Add the command to convert SQL to FetchXML var dte = (DTE2) await GetServiceAsync(typeof(EnvDTE.DTE)); await Sql2FetchXmlCommand.InitializeAsync(this, dte); await FetchXml2SqlCommand.InitializeAsync(this, dte); await Sql2MCommand.InitializeAsync(this, dte); // Intercept query execution DmlExecute.Initialize(this, dte); CrmServiceClient.AuthOverrideHook = AuthOverrideHook.Instance; // Check for an updated version VersionChecker.Check(); }
public static void Initialize(Sql4CdsPackage package, DTE2 dte) { Instance = new DmlExecute(package, dte); }