Skip to content

Commit

Permalink
WIP fix #3312: complete support of source breakpoints
Browse files Browse the repository at this point in the history
Signed-off-by: Anton Kosyakov <anton.kosyakov@typefox.io>
  • Loading branch information
akosyakov committed Dec 11, 2018
1 parent 558d4b5 commit d32444e
Show file tree
Hide file tree
Showing 11 changed files with 619 additions and 18 deletions.
10 changes: 4 additions & 6 deletions packages/debug/src/browser/breakpoint/breakpoint-manager.ts
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
********************************************************************************/

import { injectable, inject } from 'inversify';
import { DebugProtocol } from 'vscode-debugprotocol';
import { StorageService } from '@theia/core/lib/browser';
import { MarkerManager } from '@theia/markers/lib/browser/marker-manager';
import URI from '@theia/core/lib/common/uri';
Expand Down Expand Up @@ -48,17 +49,14 @@ export class BreakpointManager extends MarkerManager<SourceBreakpoint> {
this.setMarkers(uri, this.owner, breakpoints.sort((a, b) => a.raw.line - b.raw.line));
}

addBreakpoint(uri: URI, line: number, column?: number): void {
addBreakpoint(uri: URI, data: DebugProtocol.SourceBreakpoint): void {
const breakpoints = this.getBreakpoints(uri);
const newBreakpoints = breakpoints.filter(({ raw }) => raw.line !== line);
const newBreakpoints = breakpoints.filter(({ raw }) => raw.line !== data.line);
if (breakpoints.length === newBreakpoints.length) {
newBreakpoints.push({
uri: uri.toString(),
enabled: true,
raw: {
line,
column
}
raw: data
});
this.setBreakpoints(uri, newBreakpoints);
}
Expand Down
113 changes: 110 additions & 3 deletions packages/debug/src/browser/debug-frontend-application-contribution.ts
Original file line number Diff line number Diff line change
Expand Up @@ -135,6 +135,16 @@ export namespace DebugCommands {
category: DEBUG_CATEGORY,
label: 'Toggle Breakpoint',
};
export const ADD_CONDITIONAL_BREAKPOINT: Command = {
id: 'debug.breakpoint.add.conditional',
category: DEBUG_CATEGORY,
label: 'Add Conditional Breakpoint...',
};
export const ADD_LOGPOINT: Command = {
id: 'debug.breakpoint.add.logpoint',
category: DEBUG_CATEGORY,
label: 'Add Logpoint...',
};
export const ENABLE_ALL_BREAKPOINTS: Command = {
id: 'debug.breakpoint.enableAll',
category: DEBUG_CATEGORY,
Expand Down Expand Up @@ -237,15 +247,44 @@ export namespace DebugEditorContextCommands {
export const ADD_BREAKPOINT = {
id: 'debug.editor.context.addBreakpoint'
};
export const ADD_CONDITIONAL_BREAKPOINT = {
id: 'debug.editor.context.addBreakpoint.conditional'
};
export const ADD_LOGPOINT = {
id: 'debug.editor.context.add.logpoint'
};
export const REMOVE_BREAKPOINT = {
id: 'debug.editor.context.removeBreakpoint'
};
export const EDIT_BREAKPOINT = {
id: 'debug.editor.context.edit.breakpoint'
};
export const ENABLE_BREAKPOINT = {
id: 'debug.editor.context.enableBreakpoint'
};
export const DISABLE_BREAKPOINT = {
id: 'debug.editor.context.disableBreakpoint'
};
export const REMOVE_LOGPOINT = {
id: 'debug.editor.context.logpoint.remove'
};
export const EDIT_LOGPOINT = {
id: 'debug.editor.context.logpoint.edit'
};
export const ENABLE_LOGPOINT = {
id: 'debug.editor.context.logpoint.enable'
};
export const DISABLE_LOGPOINT = {
id: 'debug.editor.context.logpoint.disable'
};
}
export namespace DebugBreakpointWidgetCommands {
export const ACCEPT = {
id: 'debug.breakpointWidget.accept'
}
export const CLOSE = {
id: 'debug.breakpointWidget.close'
}
}

const darkCss = require('../../src/browser/style/debug-dark.useable.css');
Expand Down Expand Up @@ -467,9 +506,16 @@ export class DebugFrontendApplicationContribution extends AbstractViewContributi

registerMenuActions(DebugEditorModel.CONTEXT_MENU,
{ ...DebugEditorContextCommands.ADD_BREAKPOINT, label: 'Add Breakpoint' },
{ ...DebugEditorContextCommands.ADD_CONDITIONAL_BREAKPOINT, label: DebugCommands.ADD_CONDITIONAL_BREAKPOINT.label },
{ ...DebugEditorContextCommands.ADD_LOGPOINT, label: DebugCommands.ADD_LOGPOINT.label },
{ ...DebugEditorContextCommands.REMOVE_BREAKPOINT, label: 'Remove Breakpoint' },
{ ...DebugEditorContextCommands.EDIT_BREAKPOINT, label: 'Edit Breakpoint...' },
{ ...DebugEditorContextCommands.ENABLE_BREAKPOINT, label: 'Enable Breakpoint' },
{ ...DebugEditorContextCommands.DISABLE_BREAKPOINT, label: 'Disable Breakpoint' }
{ ...DebugEditorContextCommands.DISABLE_BREAKPOINT, label: 'Disable Breakpoint' },
{ ...DebugEditorContextCommands.REMOVE_LOGPOINT, label: 'Remove Logpoint' },
{ ...DebugEditorContextCommands.EDIT_LOGPOINT, label: 'Edit Logpoint...' },
{ ...DebugEditorContextCommands.ENABLE_LOGPOINT, label: 'Enable Logpoint' },
{ ...DebugEditorContextCommands.DISABLE_LOGPOINT, label: 'Disable Logpoint' }
);
}

Expand Down Expand Up @@ -608,6 +654,14 @@ export class DebugFrontendApplicationContribution extends AbstractViewContributi
execute: () => this.editors.toggleBreakpoint(),
isEnabled: () => !!this.editors.model
});
registry.registerCommand(DebugCommands.ADD_CONDITIONAL_BREAKPOINT, {
execute: () => this.editors.addBreakpoint('condition'),
isEnabled: () => !!this.editors.model && !this.editors.anyBreakpoint
});
registry.registerCommand(DebugCommands.ADD_LOGPOINT, {
execute: () => this.editors.addBreakpoint('logMessage'),
isEnabled: () => !!this.editors.model && !this.editors.anyBreakpoint
});
registry.registerCommand(DebugCommands.ENABLE_ALL_BREAKPOINTS, {
execute: () => this.breakpointManager.enableAllBreakpoints(true),
isEnabled: () => !!this.breakpointManager.getUris().next().value
Expand Down Expand Up @@ -669,14 +723,29 @@ export class DebugFrontendApplicationContribution extends AbstractViewContributi

registry.registerCommand(DebugEditorContextCommands.ADD_BREAKPOINT, {
execute: () => this.editors.toggleBreakpoint(),
isEnabled: () => !this.editors.breakpoint,
isVisible: () => !this.editors.breakpoint
isEnabled: () => !this.editors.anyBreakpoint,
isVisible: () => !this.editors.anyBreakpoint
});
registry.registerCommand(DebugEditorContextCommands.ADD_CONDITIONAL_BREAKPOINT, {
execute: () => this.editors.addBreakpoint('condition'),
isEnabled: () => !this.editors.anyBreakpoint,
isVisible: () => !this.editors.anyBreakpoint
});
registry.registerCommand(DebugEditorContextCommands.ADD_LOGPOINT, {
execute: () => this.editors.addBreakpoint('logMessage'),
isEnabled: () => !this.editors.anyBreakpoint,
isVisible: () => !this.editors.anyBreakpoint
});
registry.registerCommand(DebugEditorContextCommands.REMOVE_BREAKPOINT, {
execute: () => this.editors.toggleBreakpoint(),
isEnabled: () => !!this.editors.breakpoint,
isVisible: () => !!this.editors.breakpoint
});
registry.registerCommand(DebugEditorContextCommands.EDIT_BREAKPOINT, {
execute: () => this.editors.editBreakpoint(),
isEnabled: () => !!this.editors.breakpoint,
isVisible: () => !!this.editors.breakpoint
});
registry.registerCommand(DebugEditorContextCommands.ENABLE_BREAKPOINT, {
execute: () => this.editors.setBreakpointEnabled(true),
isEnabled: () => this.editors.breakpointEnabled === false,
Expand All @@ -687,6 +756,33 @@ export class DebugFrontendApplicationContribution extends AbstractViewContributi
isEnabled: () => !!this.editors.breakpointEnabled,
isVisible: () => !!this.editors.breakpointEnabled
});
registry.registerCommand(DebugEditorContextCommands.REMOVE_LOGPOINT, {
execute: () => this.editors.toggleBreakpoint(),
isEnabled: () => !!this.editors.logpoint,
isVisible: () => !!this.editors.logpoint
});
registry.registerCommand(DebugEditorContextCommands.EDIT_LOGPOINT, {
execute: () => this.editors.editBreakpoint(),
isEnabled: () => !!this.editors.logpoint,
isVisible: () => !!this.editors.logpoint
});
registry.registerCommand(DebugEditorContextCommands.ENABLE_LOGPOINT, {
execute: () => this.editors.setBreakpointEnabled(true),
isEnabled: () => this.editors.logpointEnabled === false,
isVisible: () => this.editors.logpointEnabled === false
});
registry.registerCommand(DebugEditorContextCommands.DISABLE_LOGPOINT, {
execute: () => this.editors.setBreakpointEnabled(false),
isEnabled: () => !!this.editors.logpointEnabled,
isVisible: () => !!this.editors.logpointEnabled
});

registry.registerCommand(DebugBreakpointWidgetCommands.ACCEPT, {
execute: () => this.editors.acceptBreakpoint()
});
registry.registerCommand(DebugBreakpointWidgetCommands.CLOSE, {
execute: () => this.editors.closeBreakpoint()
});
}

registerKeybindings(keybindings: KeybindingRegistry): void {
Expand Down Expand Up @@ -741,6 +837,17 @@ export class DebugFrontendApplicationContribution extends AbstractViewContributi
keybinding: 'f9',
context: EditorKeybindingContexts.editorTextFocus
});

keybindings.registerKeybinding({
command: DebugBreakpointWidgetCommands.ACCEPT.id,
keybinding: 'enter',
context: DebugKeybindingContexts.inBreakpointWidget
});
keybindings.registerKeybinding({
command: DebugBreakpointWidgetCommands.CLOSE.id,
keybinding: 'esc',
context: DebugKeybindingContexts.inBreakpointWidget
});
}

protected readonly sessionWidgets = new Map<string, DebugSessionWidget>();
Expand Down
3 changes: 2 additions & 1 deletion packages/debug/src/browser/debug-frontend-module.ts
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ import { BreakpointManager } from './breakpoint/breakpoint-manager';
import { DebugEditorService } from './editor/debug-editor-service';
import { DebugViewOptions } from './view/debug-view-model';
import { DebugSessionWidget, DebugSessionWidgetFactory } from './view/debug-session-widget';
import { InDebugModeContext } from './debug-keybinding-contexts';
import { InDebugModeContext, InBreakpointWidgetContext } from './debug-keybinding-contexts';
import { DebugEditorModelFactory, DebugEditorModel } from './editor/debug-editor-model';
import './debug-monaco-contribution';
import { bindDebugPreferences } from './debug-preferences';
Expand Down Expand Up @@ -63,6 +63,7 @@ export default new ContainerModule((bind: interfaces.Bind) => {
bind(ResourceResolver).toService(DebugResourceResolver);

bind(KeybindingContext).to(InDebugModeContext).inSingletonScope();
bind(KeybindingContext).to(InBreakpointWidgetContext).inSingletonScope();
bindViewContribution(bind, DebugFrontendApplicationContribution);
bind(FrontendApplicationContribution).toService(DebugFrontendApplicationContribution);

Expand Down
18 changes: 18 additions & 0 deletions packages/debug/src/browser/debug-keybinding-contexts.ts
Original file line number Diff line number Diff line change
Expand Up @@ -18,11 +18,14 @@ import { injectable, inject } from 'inversify';
import { KeybindingContext } from '@theia/core/lib/browser';
import { DebugSessionManager } from './debug-session-manager';
import { DebugState } from './debug-session';
import { DebugEditorService } from './editor/debug-editor-service';

export namespace DebugKeybindingContexts {

export const inDebugMode = 'inDebugMode';

export const inBreakpointWidget = 'inBreakpointWidget';

}

@injectable()
Expand All @@ -38,3 +41,18 @@ export class InDebugModeContext implements KeybindingContext {
}

}

@injectable()
export class InBreakpointWidgetContext implements KeybindingContext {

readonly id: string = DebugKeybindingContexts.inBreakpointWidget;

@inject(DebugEditorService)
protected readonly editors: DebugEditorService;

isEnabled(): boolean {
const model = this.editors.model;
return !!model && !!model.breakpointWidget.position;
}

}
Loading

0 comments on commit d32444e

Please sign in to comment.