Skip to content

Commit

Permalink
add smartSuggestionsOnly settings, fixes #5574
Browse files Browse the repository at this point in the history
  • Loading branch information
jrieken committed Apr 27, 2016
1 parent 48a0447 commit 4858b59
Show file tree
Hide file tree
Showing 6 changed files with 60 additions and 14 deletions.
12 changes: 10 additions & 2 deletions src/vs/editor/common/config/commonEditorConfig.ts
Original file line number Diff line number Diff line change
Expand Up @@ -96,7 +96,8 @@ export class InternalEditorOptions implements editorCommon.IInternalEditorOption
hover:boolean;
contextmenu:boolean;
quickSuggestions:boolean;
quickSuggestionsDelay:number;
quickSuggestionsDelay: number;
smartSuggestionsOnly: boolean;
iconsInSuggestions:boolean;
autoClosingBrackets:boolean;
formatOnType:boolean;
Expand Down Expand Up @@ -165,7 +166,8 @@ export class InternalEditorOptions implements editorCommon.IInternalEditorOption
this.hover = Boolean(input.hover);
this.contextmenu = Boolean(input.contextmenu);
this.quickSuggestions = Boolean(input.quickSuggestions);
this.quickSuggestionsDelay = Number(input.quickSuggestionsDelay)|0;
this.quickSuggestionsDelay = Number(input.quickSuggestionsDelay) | 0;
this.smartSuggestionsOnly = Boolean(input.smartSuggestionsOnly);
this.iconsInSuggestions = Boolean(input.iconsInSuggestions);
this.autoClosingBrackets = Boolean(input.autoClosingBrackets);
this.formatOnType = Boolean(input.formatOnType);
Expand Down Expand Up @@ -357,6 +359,7 @@ class InternalEditorOptionsHelper {
contextmenu: toBoolean(opts.contextmenu),
quickSuggestions: toBoolean(opts.quickSuggestions),
quickSuggestionsDelay: toInteger(opts.quickSuggestionsDelay),
smartSuggestionsOnly: toBoolean(opts.smartSuggestionsOnly),
iconsInSuggestions: toBoolean(opts.iconsInSuggestions),
autoClosingBrackets: toBoolean(opts.autoClosingBrackets),
formatOnType: toBoolean(opts.formatOnType),
Expand Down Expand Up @@ -874,6 +877,11 @@ let editorConfiguration:IConfigurationNode = {
'minimum': 0,
'description': nls.localize('quickSuggestionsDelay', "Controls the delay in ms after which quick suggestions will show up")
},
'editor.smartSuggestionsOnly' : {
'type': 'boolean',
'default': DefaultConfig.editor.smartSuggestionsOnly,
'description': nls.localize('smartSuggestionsOnly', "Controls if less smart suggestions show up when a language service cannot compute them")
},
'editor.autoClosingBrackets' : {
'type': 'boolean',
'default': DefaultConfig.editor.autoClosingBrackets,
Expand Down
1 change: 1 addition & 0 deletions src/vs/editor/common/config/defaultConfig.ts
Original file line number Diff line number Diff line change
Expand Up @@ -69,6 +69,7 @@ class ConfigClass implements IConfiguration {
mouseWheelScrollSensitivity: 1,
quickSuggestions: true,
quickSuggestionsDelay: 10,
smartSuggestionsOnly: false,
iconsInSuggestions: true,
autoClosingBrackets: true,
formatOnType: false,
Expand Down
8 changes: 7 additions & 1 deletion src/vs/editor/common/editorCommon.ts
Original file line number Diff line number Diff line change
Expand Up @@ -468,7 +468,12 @@ export interface IEditorOptions {
* Quick suggestions show delay (in ms)
* Defaults to 500 (ms)
*/
quickSuggestionsDelay?:number;
quickSuggestionsDelay?: number;
/**
* Don't fallback to providers that only propose textual completions.
* Default to true.
*/
smartSuggestionsOnly?: boolean;
/**
* Render icons in suggestions box.
* Defaults to true.
Expand Down Expand Up @@ -638,6 +643,7 @@ export interface IInternalEditorOptions {
contextmenu:boolean;
quickSuggestions:boolean;
quickSuggestionsDelay:number;
smartSuggestionsOnly: boolean;
iconsInSuggestions:boolean;
autoClosingBrackets:boolean;
formatOnType:boolean;
Expand Down
5 changes: 4 additions & 1 deletion src/vs/editor/contrib/suggest/browser/suggestModel.ts
Original file line number Diff line number Diff line change
Expand Up @@ -311,7 +311,10 @@ export class SuggestModel implements IDisposable {

const position = this.editor.getPosition();

this.requestPromise = suggest(model, position, triggerCharacter, groups).then(all => {
this.requestPromise = suggest(model, position, triggerCharacter,
this.editor.getConfiguration().smartSuggestionsOnly,
groups
).then(all => {
this.requestPromise = null;

if (this.state === State.Idle) {
Expand Down
13 changes: 9 additions & 4 deletions src/vs/editor/contrib/suggest/common/suggest.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,6 @@
'use strict';

import {sequence} from 'vs/base/common/async';
import {isFalsyOrEmpty} from 'vs/base/common/arrays';
import {illegalArgument, onUnexpectedError} from 'vs/base/common/errors';
import {TPromise} from 'vs/base/common/winjs.base';
import {IModel, IPosition} from 'vs/editor/common/editorCommon';
Expand All @@ -21,7 +20,7 @@ export interface ISuggestResult2 extends ISuggestResult {
support?: ISuggestSupport;
}

export function suggest(model: IModel, position: IPosition, triggerCharacter: string, groups?: ISuggestSupport[][]): TPromise<ISuggestResult2[]> {
export function suggest(model: IModel, position: IPosition, triggerCharacter: string, acceptEmptyArray: boolean, groups?: ISuggestSupport[][]): TPromise<ISuggestResult2[]> {

if (!groups) {
groups = SuggestRegistry.orderedGroups(model);
Expand All @@ -48,7 +47,13 @@ export function suggest(model: IModel, position: IPosition, triggerCharacter: st

for (let suggestResult of values) {

if (!suggestResult || isFalsyOrEmpty(suggestResult.suggestions)) {
if (!suggestResult || !Array.isArray(suggestResult.suggestions)) {
// unacceptable result
continue;
}

if (suggestResult.suggestions.length === 0 && !acceptEmptyArray) {
// empty result -> check configuration
continue;
}

Expand Down Expand Up @@ -80,5 +85,5 @@ CommonEditorRegistry.registerDefaultLanguageCommand('_executeCompletionItemProvi
throw illegalArgument('triggerCharacter');
}

return suggest(model, position, triggerCharacter);
return suggest(model, position, triggerCharacter, false);
});
35 changes: 29 additions & 6 deletions src/vs/workbench/test/node/api/extHostLanguageFeatures.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -824,7 +824,7 @@ suite('ExtHostLanguageFeatures', function() {
}, []));

threadService.sync().then(() => {
suggest(model, { lineNumber: 1, column: 1 }, ',').then(value => {
suggest(model, { lineNumber: 1, column: 1 }, ',', false).then(value => {
assert.ok(value.length >= 1); // check for min because snippets and others contribute
let [first] = value;
assert.equal(first.suggestions.length, 1);
Expand All @@ -834,7 +834,7 @@ suite('ExtHostLanguageFeatures', function() {
});
});

test('Suggest, order 2/3', function(done) {
test('Suggest, order 2/3 (!smartSuggestionsOnly)', function(done) {

disposables.push(extHost.registerCompletionItemProvider('*', <vscode.CompletionItemProvider>{
provideCompletionItems(): any {
Expand All @@ -849,7 +849,7 @@ suite('ExtHostLanguageFeatures', function() {
}, []));

threadService.sync().then(() => {
suggest(model, { lineNumber: 1, column: 1 }, ',').then(value => {
suggest(model, { lineNumber: 1, column: 1 }, ',', false).then(value => {
assert.ok(value.length >= 1);
let [first] = value;
assert.equal(first.suggestions.length, 1);
Expand All @@ -859,6 +859,29 @@ suite('ExtHostLanguageFeatures', function() {
});
});

test('Suggest, order 2/3 (smartSuggestionsOnly)', function() {

disposables.push(extHost.registerCompletionItemProvider('*', <vscode.CompletionItemProvider>{
provideCompletionItems(): any {
return [new types.CompletionItem('weak-selector')]; // weaker selector but result
}
}, []));

disposables.push(extHost.registerCompletionItemProvider(defaultSelector, <vscode.CompletionItemProvider>{
provideCompletionItems(): any {
return []; // stronger selector but not a good result;
}
}, []));

return threadService.sync().then(() => {
return suggest(model, { lineNumber: 1, column: 1 }, ',', true).then(value => {
assert.ok(value.length >= 1);
let [first] = value;
assert.equal(first.suggestions.length, 0);
});
});
});

test('Suggest, order 2/3', function(done) {

disposables.push(extHost.registerCompletionItemProvider(defaultSelector, <vscode.CompletionItemProvider>{
Expand All @@ -875,7 +898,7 @@ suite('ExtHostLanguageFeatures', function() {
}, []));

threadService.sync().then(() => {
suggest(model, { lineNumber: 1, column: 1 }, ',').then(value => {
suggest(model, { lineNumber: 1, column: 1 }, ',', false).then(value => {
assert.ok(value.length >= 2);
let [first, second] = value;
assert.equal(first.suggestions.length, 1);
Expand Down Expand Up @@ -904,7 +927,7 @@ suite('ExtHostLanguageFeatures', function() {

threadService.sync().then(() => {

suggest(model, { lineNumber: 1, column: 1 }, ',').then(value => {
suggest(model, { lineNumber: 1, column: 1 }, ',', false).then(value => {
assert.equal(value[0].incomplete, undefined);
done();
});
Expand All @@ -921,7 +944,7 @@ suite('ExtHostLanguageFeatures', function() {

return threadService.sync().then(() => {

suggest(model, { lineNumber: 1, column: 1 }, ',').then(value => {
suggest(model, { lineNumber: 1, column: 1 }, ',', false).then(value => {
assert.equal(value[0].incomplete, true);
});
});
Expand Down

0 comments on commit 4858b59

Please sign in to comment.