Merge pull request #1167 from Microsoft/formatting_templates

formatting: handle templates spans
This commit is contained in:
Vladimir Matveev 2014-11-14 16:24:12 -08:00
commit 647ff4b06a
2 changed files with 26 additions and 2 deletions

View file

@ -1,3 +1,4 @@
/// <reference path="..\formatting.ts"/>
/// <reference path="..\..\compiler\scanner.ts"/>
module ts.formatting {
@ -14,7 +15,8 @@ module ts.formatting {
const enum ScanAction{
Scan,
RescanGreaterThanToken,
RescanSlashToken
RescanSlashToken,
RescanTemplateToken
}
export function getFormattingScanner(sourceFile: SourceFile, startPos: number, endPos: number): FormattingScanner {
@ -111,6 +113,10 @@ module ts.formatting {
return container.kind === SyntaxKind.RegularExpressionLiteral;
}
function shouldRescanTemplateToken(container: Node): boolean {
return container.kind === SyntaxKind.TemplateSpan;
}
function startsWithSlashToken(t: SyntaxKind): boolean {
return t === SyntaxKind.SlashToken || t === SyntaxKind.SlashEqualsToken;
}
@ -132,7 +138,9 @@ module ts.formatting {
? ScanAction.RescanGreaterThanToken
: shouldRescanSlashToken(n)
? ScanAction.RescanSlashToken
: ScanAction.Scan
: shouldRescanTemplateToken(n)
? ScanAction.RescanTemplateToken
: ScanAction.Scan
if (lastTokenInfo && expectedScanAction === lastScanAction) {
// readTokenInfo was called before with the same expected scan action.
@ -159,6 +167,10 @@ module ts.formatting {
Debug.assert(n.kind === currentToken);
lastScanAction = ScanAction.RescanSlashToken;
}
else if (expectedScanAction === ScanAction.RescanTemplateToken && currentToken === SyntaxKind.CloseBraceToken) {
currentToken = scanner.reScanTemplateToken();
lastScanAction = ScanAction.RescanTemplateToken;
}
else {
lastScanAction = ScanAction.Scan;
}

View file

@ -0,0 +1,12 @@
///<reference path="fourslash.ts"/>
////String.call `${123}`/*1*/
////String.call `${123} ${456}`/*2*/
goTo.marker("1");
edit.insert(";");
verify.currentLineContentIs("String.call `${123}`;");
goTo.marker("2");
edit.insert(";");
verify.currentLineContentIs("String.call `${123} ${456}`;");