Add status messages during command line processing (#4725)

* add status bar messages

* missed semicolon
This commit is contained in:
David Shiflet
2019-03-27 15:44:57 -04:00
committed by GitHub
parent 37ab493b78
commit a360bebd9d
5 changed files with 26 additions and 6 deletions

View File

@@ -21,6 +21,8 @@ import { warn } from 'sql/base/common/log';
import { ipcRenderer as ipc} from 'electron'; import { ipcRenderer as ipc} from 'electron';
import { IConnectionProfile } from 'sql/platform/connection/common/interfaces'; import { IConnectionProfile } from 'sql/platform/connection/common/interfaces';
import { IConfigurationService } from 'vs/platform/configuration/common/configuration'; import { IConfigurationService } from 'vs/platform/configuration/common/configuration';
import { IStatusbarService, StatusbarAlignment } from 'vs/platform/statusbar/common/statusbar';
import { localize } from 'vs/nls';
export class CommandLineService implements ICommandLineProcessing { export class CommandLineService implements ICommandLineProcessing {
public _serviceBrand: any; public _serviceBrand: any;
@@ -33,7 +35,8 @@ export class CommandLineService implements ICommandLineProcessing {
@IObjectExplorerService private _objectExplorerService: IObjectExplorerService, @IObjectExplorerService private _objectExplorerService: IObjectExplorerService,
@IEditorService private _editorService: IEditorService, @IEditorService private _editorService: IEditorService,
@ICommandService private _commandService: ICommandService, @ICommandService private _commandService: ICommandService,
@IConfigurationService private _configurationService: IConfigurationService @IConfigurationService private _configurationService: IConfigurationService,
@IStatusbarService private _statusBarService: IStatusbarService
) { ) {
if (ipc) { if (ipc) {
ipc.on('ads:processCommandLine', (event: any, args: ParsedArgs) => this.onLaunched(args)); ipc.on('ads:processCommandLine', (event: any, args: ParsedArgs) => this.onLaunched(args));
@@ -85,6 +88,10 @@ export class CommandLineService implements ICommandLineProcessing {
} }
let connectedContext: azdata.ConnectedContext = undefined; let connectedContext: azdata.ConnectedContext = undefined;
if (profile) { if (profile) {
if (this._statusBarService)
{
this._statusBarService.setStatusMessage(localize('connectingLabel','Connecting:') + profile.serverName, 2500);
}
try { try {
await this._connectionManagementService.connectIfNotConnected(profile, 'connection', true); await this._connectionManagementService.connectIfNotConnected(profile, 'connection', true);
// Before sending to extensions, we should a) serialize to IConnectionProfile or things will fail, // Before sending to extensions, we should a) serialize to IConnectionProfile or things will fail,
@@ -96,8 +103,16 @@ export class CommandLineService implements ICommandLineProcessing {
} }
} }
if (commandName) { if (commandName) {
if (this._statusBarService)
{
this._statusBarService.setStatusMessage(localize('runningCommandLabel','Running command:') + commandName, 2500);
}
await this._commandService.executeCommand(commandName, connectedContext); await this._commandService.executeCommand(commandName, connectedContext);
} else if (profile) { } else if (profile) {
if (this._statusBarService)
{
this._statusBarService.setStatusMessage(localize('openingNewQueryLabel','Opening new query:') + profile.serverName, 2500);
}
// Default to showing new query // Default to showing new query
try { try {
await TaskUtilities.newQuery(profile, await TaskUtilities.newQuery(profile,

View File

@@ -466,7 +466,7 @@ export class ObjectExplorerService implements IObjectExplorerService {
if (finalResult) { if (finalResult) {
if (errorMessages.length > 0) { if (errorMessages.length > 0) {
if (errorMessages.length > 1) { if (errorMessages.length > 1) {
errorMessages.unshift(nls.localize('nodeExpansionError', 'Mulitiple errors:')); errorMessages.unshift(nls.localize('nodeExpansionError', 'Multiple errors:'));
} }
errorNode.errorMessage = errorMessages.join('\n'); errorNode.errorMessage = errorMessages.join('\n');
errorNode.label = errorNode.errorMessage; errorNode.label = errorNode.errorMessage;

View File

@@ -116,7 +116,8 @@ suite('commandLineService tests', () => {
undefined, undefined,
undefined, undefined,
commandService, commandService,
configurationService configurationService,
undefined
); );
return service; return service;
} }

View File

@@ -46,6 +46,8 @@ import { WorkbenchContextKeysHandler } from 'vs/workbench/browser/contextkeys';
import { coalesce } from 'vs/base/common/arrays'; import { coalesce } from 'vs/base/common/arrays';
import { InstantiationService } from 'vs/platform/instantiation/common/instantiationService'; import { InstantiationService } from 'vs/platform/instantiation/common/instantiationService';
import { Layout } from 'vs/workbench/browser/layout'; import { Layout } from 'vs/workbench/browser/layout';
import { ICommandLineProcessing } from 'sql/workbench/services/commandLine/common/commandLine';
import { CommandLineService } from 'sql/workbench/services/commandLine/common/commandLineService';
export class Workbench extends Layout { export class Workbench extends Layout {
@@ -186,6 +188,11 @@ export class Workbench extends Layout {
const instantiationService = new InstantiationService(serviceCollection, true); const instantiationService = new InstantiationService(serviceCollection, true);
// {{SQL CARBON EDIT }}
// TODO@Davidshi commandLineService currently has no referents, so force its creation
serviceCollection.set(ICommandLineProcessing, instantiationService.createInstance(CommandLineService));
// {{SQL CARBON EDIT}} - End
// Wrap up // Wrap up
instantiationService.invokeFunction(accessor => { instantiationService.invokeFunction(accessor => {
const lifecycleService = accessor.get(ILifecycleService); const lifecycleService = accessor.get(ILifecycleService);

View File

@@ -224,8 +224,6 @@ import { IDashboardService } from 'sql/platform/dashboard/browser/dashboardServi
import { DashboardService } from 'sql/platform/dashboard/browser/dashboardServiceImpl'; import { DashboardService } from 'sql/platform/dashboard/browser/dashboardServiceImpl';
import { NotebookService } from 'sql/workbench/services/notebook/common/notebookServiceImpl'; import { NotebookService } from 'sql/workbench/services/notebook/common/notebookServiceImpl';
import { INotebookService } from 'sql/workbench/services/notebook/common/notebookService'; import { INotebookService } from 'sql/workbench/services/notebook/common/notebookService';
import { ICommandLineProcessing } from 'sql/workbench/services/commandLine/common/commandLine';
import { CommandLineService } from 'sql/workbench/services/commandLine/common/commandLineService';
import { OEShimService, IOEShimService } from 'sql/parts/objectExplorer/common/objectExplorerViewTreeShim'; import { OEShimService, IOEShimService } from 'sql/parts/objectExplorer/common/objectExplorerViewTreeShim';
registerSingleton(IDashboardService, DashboardService); registerSingleton(IDashboardService, DashboardService);
@@ -265,7 +263,6 @@ registerSingleton(IInsightsDialogService, InsightsDialogService);
registerSingleton(INotebookService, NotebookService); registerSingleton(INotebookService, NotebookService);
registerSingleton(IAccountPickerService, AccountPickerService); registerSingleton(IAccountPickerService, AccountPickerService);
registerSingleton(IProfilerService, ProfilerService); registerSingleton(IProfilerService, ProfilerService);
registerSingleton(ICommandLineProcessing, CommandLineService);
registerSingleton(IDacFxService, DacFxService); registerSingleton(IDacFxService, DacFxService);
// {{SQL CARBON EDIT}} - End // {{SQL CARBON EDIT}} - End