Merge update and cancel events to a single change event

pull/65454/head
Matt Bierner 2018-12-19 20:37:25 -08:00
parent 5e2ec87c62
commit cf9e62d373
3 changed files with 15 additions and 22 deletions

View File

@ -5,7 +5,7 @@
import { CancelablePromise, createCancelablePromise, Delayer } from 'vs/base/common/async';
import { onUnexpectedError } from 'vs/base/common/errors';
import { Emitter, Event } from 'vs/base/common/event';
import { Emitter } from 'vs/base/common/event';
import { Disposable } from 'vs/base/common/lifecycle';
import { ICodeEditor } from 'vs/editor/browser/editorBrowser';
import { ICursorSelectionChangedEvent } from 'vs/editor/common/controller/cursorEvents';
@ -18,10 +18,6 @@ export interface TriggerContext {
readonly triggerCharacter?: string;
}
export interface IHintEvent {
readonly hints: modes.SignatureHelp;
}
const DefaultState = new class { readonly state = 'default'; };
const PendingState = new class { readonly state = 'pending'; };
@ -38,11 +34,8 @@ export class ParameterHintsModel extends Disposable {
private static readonly DEFAULT_DELAY = 120; // ms
private readonly _onHint = this._register(new Emitter<IHintEvent>());
public readonly onHint: Event<IHintEvent> = this._onHint.event;
private readonly _onCancel = this._register(new Emitter<void>());
public readonly onCancel: Event<void> = this._onCancel.event;
private readonly _onChangedHints = this._register(new Emitter<modes.SignatureHelp | undefined>());
public readonly onChangedHints = this._onChangedHints.event;
private editor: ICodeEditor;
private enabled: boolean;
@ -82,7 +75,7 @@ export class ParameterHintsModel extends Disposable {
this.throttledDelayer.cancel();
if (!silent) {
this._onCancel.fire(void 0);
this._onChangedHints.fire(undefined);
}
if (this.provideSignatureHelpRequest) {
@ -153,7 +146,7 @@ export class ParameterHintsModel extends Disposable {
state: 'active',
hints: { ...this.state.hints, activeSignature }
};
this._onHint.fire(this.state);
this._onChangedHints.fire(this.state.hints);
}
private doTrigger(triggerContext: modes.SignatureHelpContext): Promise<boolean> {
@ -177,7 +170,7 @@ export class ParameterHintsModel extends Disposable {
return false;
} else {
this.state = new ActiveState(result);
this._onHint.fire(this.state);
this._onChangedHints.fire(this.state.hints);
return true;
}
}).catch(error => {

View File

@ -59,13 +59,13 @@ export class ParameterHintsWidget implements IContentWidget, IDisposable {
this.visible = false;
this.disposables = [];
this.disposables.push(this.model.onHint(e => {
this.show();
this.render(e.hints);
}));
this.disposables.push(this.model.onCancel(() => {
this.hide();
this.disposables.push(this.model.onChangedHints(newParameterHints => {
if (newParameterHints) {
this.show();
this.render(newParameterHints);
} else {
this.hide();
}
}));
}

View File

@ -244,10 +244,10 @@ suite('ParameterHintsModel', () => {
assert.strictEqual(-1, didRequestCancellationOf);
return new Promise((resolve, reject) =>
hintsModel.onHint(e => {
hintsModel.onChangedHints(newParamterHints => {
try {
assert.strictEqual(0, didRequestCancellationOf);
assert.strictEqual('1', e.hints.signatures[0].label);
assert.strictEqual('1', newParamterHints.signatures[0].label);
resolve();
} catch (e) {
reject(e);