From 41f8aade8ebab56a02f960083b2aa26e15f086a7 Mon Sep 17 00:00:00 2001 From: Anders Hejlsberg Date: Fri, 25 Sep 2015 14:51:41 -0700 Subject: [PATCH] Write "this" as "any" when "this" reference would be an error --- src/compiler/checker.ts | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/src/compiler/checker.ts b/src/compiler/checker.ts index f10960f4bbb..6fd6651f103 100644 --- a/src/compiler/checker.ts +++ b/src/compiler/checker.ts @@ -1594,6 +1594,7 @@ namespace ts { function buildTypeDisplay(type: Type, writer: SymbolWriter, enclosingDeclaration?: Node, globalFlags?: TypeFormatFlags, symbolStack?: Symbol[]) { let globalFlagsToPass = globalFlags & TypeFormatFlags.WriteOwnNameForAnyLike; + let inObjectTypeLiteral = false; return writeType(type, globalFlags); function writeType(type: Type, flags: TypeFormatFlags) { @@ -1605,7 +1606,7 @@ namespace ts { : (type).intrinsicName); } else if (type.flags & TypeFlags.ThisType) { - writer.writeKeyword("this"); + writer.writeKeyword(inObjectTypeLiteral ? "any" : "this"); } else if (type.flags & TypeFlags.Reference) { writeTypeReference(type, flags); @@ -1821,6 +1822,8 @@ namespace ts { } } + let saveInObjectTypeLiteral = inObjectTypeLiteral; + inObjectTypeLiteral = true; writePunctuation(writer, SyntaxKind.OpenBraceToken); writer.writeLine(); writer.increaseIndent(); @@ -1893,6 +1896,7 @@ namespace ts { } writer.decreaseIndent(); writePunctuation(writer, SyntaxKind.CloseBraceToken); + inObjectTypeLiteral = saveInObjectTypeLiteral; } }