Skip to content

Commit 8e55aa0

Browse files
committed
Do not incorrectly add line separators for non-synthetic nodes when emitting node list
As of 3c32f6e, a line separator is added between nodes if the nodes are not synthetic and on separate lines. This it push s wrong and previously only happened if the non-synthetic nodes were on different lines but had the same parent. Fixes #44068.
1 parent 7aacd6b commit 8e55aa0

10 files changed

+43
-19
lines changed

src/compiler/emitter.ts

Lines changed: 9 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -4564,15 +4564,15 @@ namespace ts {
45644564
// JsxText will be written with its leading whitespace, so don't add more manually.
45654565
return 0;
45664566
}
4567-
else if (preserveSourceNewlines && siblingNodePositionsAreComparable(previousNode, nextNode)) {
4568-
return getEffectiveLines(
4569-
includeComments => getLinesBetweenRangeEndAndRangeStart(
4570-
previousNode,
4571-
nextNode,
4572-
currentSourceFile!,
4573-
includeComments));
4574-
}
4575-
else if (!preserveSourceNewlines && !nodeIsSynthesized(previousNode) && !nodeIsSynthesized(nextNode)) {
4567+
else if (siblingNodePositionsAreComparable(previousNode, nextNode)) {
4568+
if (preserveSourceNewlines) {
4569+
return getEffectiveLines(
4570+
includeComments => getLinesBetweenRangeEndAndRangeStart(
4571+
previousNode,
4572+
nextNode,
4573+
currentSourceFile!,
4574+
includeComments));
4575+
}
45764576
return rangeEndIsOnSameLineAsRangeStart(previousNode, nextNode, currentSourceFile!) ? 0 : 1;
45774577
}
45784578
else if (synthesizedNodeStartsOnNewLine(previousNode, format) || synthesizedNodeStartsOnNewLine(nextNode, format)) {

src/testRunner/unittests/transform.ts

Lines changed: 20 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -154,6 +154,26 @@ namespace ts {
154154
}).outputText;
155155
});
156156

157+
testBaseline("issue44068", () => {
158+
return transformSourceFile(`
159+
const FirstVar = null;
160+
const SecondVar = null;
161+
`, [
162+
context => file => {
163+
const firstVarName = (file.statements[0] as VariableStatement)
164+
.declarationList.declarations[0].name as Identifier;
165+
const secondVarName = (file.statements[0] as VariableStatement)
166+
.declarationList.declarations[0].name as Identifier;
167+
168+
return context.factory.updateSourceFile(file, file.statements.concat([
169+
context.factory.createExpressionStatement(
170+
context.factory.createArrayLiteralExpression([firstVarName, secondVarName])
171+
),
172+
]));
173+
}
174+
]);
175+
});
176+
157177
testBaseline("rewrittenNamespace", () => {
158178
return transpileModule(`namespace Reflect { const x = 1; }`, {
159179
transformers: {

tests/baselines/reference/decoratorOnClassMethodThisParameter.js

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -30,7 +30,8 @@ var C2 = /** @class */ (function () {
3030
}
3131
C2.prototype.method = function (allowed) { };
3232
__decorate([
33-
__param(0, dec), __param(1, dec)
33+
__param(0, dec),
34+
__param(1, dec)
3435
], C2.prototype, "method", null);
3536
return C2;
3637
}());

tests/baselines/reference/jsxJsxsCjsTransformNestedSelfClosingChild(jsx=react-jsx).js

Lines changed: 1 addition & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -26,6 +26,5 @@ console.log(
2626
exports.__esModule = true;
2727
var jsx_runtime_1 = require("react/jsx-runtime");
2828
console.log(jsx_runtime_1.jsx("div", { children: jsx_runtime_1.jsx("div", {}, void 0) }, void 0));
29-
console.log(jsx_runtime_1.jsxs("div", { children: [jsx_runtime_1.jsx("div", {}, void 0),
30-
jsx_runtime_1.jsx("div", {}, void 0)] }, void 0));
29+
console.log(jsx_runtime_1.jsxs("div", { children: [jsx_runtime_1.jsx("div", {}, void 0), jsx_runtime_1.jsx("div", {}, void 0)] }, void 0));
3130
console.log(jsx_runtime_1.jsx("div", { children: [1, 2].map(function (i) { return jsx_runtime_1.jsx("div", { children: i }, i); }) }, void 0));

tests/baselines/reference/jsxJsxsCjsTransformNestedSelfClosingChild(jsx=react-jsxdev).js

Lines changed: 1 addition & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -28,6 +28,5 @@ exports.__esModule = true;
2828
var jsx_dev_runtime_1 = require("react/jsx-dev-runtime");
2929
var _jsxFileName = "tests/cases/conformance/jsx/jsxs/jsxJsxsCjsTransformNestedSelfClosingChild.tsx";
3030
console.log(jsx_dev_runtime_1.jsxDEV("div", { children: jsx_dev_runtime_1.jsxDEV("div", {}, void 0, false, { fileName: _jsxFileName, lineNumber: 6, columnNumber: 5 }, this) }, void 0, false, { fileName: _jsxFileName, lineNumber: 4, columnNumber: 13 }, this));
31-
console.log(jsx_dev_runtime_1.jsxDEV("div", { children: [jsx_dev_runtime_1.jsxDEV("div", {}, void 0, false, { fileName: _jsxFileName, lineNumber: 12, columnNumber: 5 }, this),
32-
jsx_dev_runtime_1.jsxDEV("div", {}, void 0, false, { fileName: _jsxFileName, lineNumber: 13, columnNumber: 5 }, this)] }, void 0, true, { fileName: _jsxFileName, lineNumber: 10, columnNumber: 13 }, this));
31+
console.log(jsx_dev_runtime_1.jsxDEV("div", { children: [jsx_dev_runtime_1.jsxDEV("div", {}, void 0, false, { fileName: _jsxFileName, lineNumber: 12, columnNumber: 5 }, this), jsx_dev_runtime_1.jsxDEV("div", {}, void 0, false, { fileName: _jsxFileName, lineNumber: 13, columnNumber: 5 }, this)] }, void 0, true, { fileName: _jsxFileName, lineNumber: 10, columnNumber: 13 }, this));
3332
console.log(jsx_dev_runtime_1.jsxDEV("div", { children: [1, 2].map(function (i) { return jsx_dev_runtime_1.jsxDEV("div", { children: i }, i, false, { fileName: _jsxFileName, lineNumber: 19, columnNumber: 21 }, _this); }) }, void 0, false, { fileName: _jsxFileName, lineNumber: 17, columnNumber: 13 }, this));

tests/baselines/reference/objectLiteralShorthandPropertiesErrorFromNotUsingIdentifier.js

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -35,7 +35,8 @@ var y = {
3535
"typeof":
3636
};
3737
var x = (_a = {
38-
a: a, : .b,
38+
a: a,
39+
: .b,
3940
a: a
4041
},
4142
_a["ss"] = ,

tests/baselines/reference/objectLiteralShorthandPropertiesErrorWithModule.js

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -25,7 +25,8 @@ var n;
2525
(function (n) {
2626
var z = 10000;
2727
n.y = {
28-
m: m, : .x // error
28+
m: m,
29+
: .x // error
2930
};
3031
})(n || (n = {}));
3132
m.y.x;

tests/baselines/reference/objectTypesWithOptionalProperties2.js

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -42,5 +42,6 @@ var C2 = /** @class */ (function () {
4242
return C2;
4343
}());
4444
var b = {
45-
x: function () { }, 1: // error
45+
x: function () { },
46+
1: // error
4647
};

tests/baselines/reference/parserErrorRecovery_ObjectLiteral2.js

Lines changed: 1 addition & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -3,5 +3,4 @@ var v = { a
33
return;
44

55
//// [parserErrorRecovery_ObjectLiteral2.js]
6-
var v = { a: a,
7-
"return": };
6+
var v = { a: a, "return": };
Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,3 @@
1+
const FirstVar = null;
2+
const SecondVar = null;
3+
[FirstVar, FirstVar];

0 commit comments

Comments
 (0)