Merge pull request #7567 from Microsoft/contextual-type-parameters

show completion in destructured parameter if containing function was contextually typed
This commit is contained in:
Vladimir Matveev 2016-03-17 16:30:20 -07:00
commit 279fec7a7d
2 changed files with 47 additions and 1 deletions

View file

@ -3504,7 +3504,18 @@ namespace ts {
// We don't want to complete using the type acquired by the shape
// of the binding pattern; we are only interested in types acquired
// through type declaration or inference.
if (rootDeclaration.initializer || rootDeclaration.type) {
// Also proceed if rootDeclaration is parameter and if its containing function expression\arrow function is contextually typed -
// type of parameter will flow in from the contextual type of the function
let canGetType = !!(rootDeclaration.initializer || rootDeclaration.type);
if (!canGetType && rootDeclaration.kind === SyntaxKind.Parameter) {
if (isExpression(rootDeclaration.parent)) {
canGetType = !!typeChecker.getContextualType(<Expression>rootDeclaration.parent);
}
else if (rootDeclaration.parent.kind === SyntaxKind.MethodDeclaration || rootDeclaration.parent.kind === SyntaxKind.SetAccessor) {
canGetType = isExpression(rootDeclaration.parent.parent) && !!typeChecker.getContextualType(<Expression>rootDeclaration.parent.parent);
}
}
if (canGetType) {
typeForObject = typeChecker.getTypeAtLocation(objectLikeContainer);
existingMembers = (<BindingPattern>objectLikeContainer).elements;
}

View file

@ -0,0 +1,35 @@
/// <reference path="fourslash.ts"/>
////interface I { x1: number; x2: string }
////function f(cb: (ev: I) => any) { }
////f(({/*1*/}) => 0);
////[<I>null].reduce(({/*2*/}, b) => b);
////interface Foo {
//// m(x: { x1: number, x2: number }): void;
//// prop: I;
////}
////let x: Foo = {
//// m({ /*3*/ }) {
//// },
//// get prop(): I { return undefined; },
//// set prop({ /*4*/ }) {
//// }
////};
goTo.marker("1");
verify.completionListContains("x1");
verify.completionListContains("x2");
goTo.marker("2");
verify.completionListContains("x1");
verify.completionListContains("x2");
goTo.marker("3");
verify.completionListContains("x1");
verify.completionListContains("x2");
goTo.marker("4");
verify.completionListContains("x1");
verify.completionListContains("x2");