-
-
Notifications
You must be signed in to change notification settings - Fork 492
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat(transformer/logical-assignment-operators): no temp vars for lite…
…rals (#7759) `TransformCtx::duplicate_expression` (introduced in #7754) don't create temp vars for literals. This produces more compact output for the logical assignment operators transform. This diverges from Babel (it's better!) so add an override for one of Babel's fixtures. Also add further tests for all literal types.
- Loading branch information
1 parent
8f8b4c3
commit e010b6a
Showing
10 changed files
with
96 additions
and
8 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
5 changes: 5 additions & 0 deletions
5
...gnment-operators/test/fixtures/logical-assignment/null-coalescing-without-other/output.js
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
var _o, _o2; | ||
let o; | ||
o ?? (o = {}); | ||
(_o = o).a ?? (_o.a = 1); | ||
(_o2 = o)["b"] ?? (_o2["b"] = 2); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,6 +1,6 @@ | ||
commit: 54a8389f | ||
|
||
Passed: 99/111 | ||
Passed: 102/114 | ||
|
||
# All Passed: | ||
* babel-plugin-transform-class-static-block | ||
|
15 changes: 15 additions & 0 deletions
15
...lugin-transform-logical-assignment-operators/test/fixtures/computed-prop-literal/input.js
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
let boundObj; | ||
|
||
boundObj[true] &&= 1; | ||
boundObj[null] &&= 2; | ||
boundObj[123] &&= 3; | ||
boundObj[123n] &&= 4; | ||
boundObj[/abc/g] &&= 5; | ||
boundObj["abc"] &&= 6; | ||
|
||
unboundObj[true] &&= 7; | ||
unboundObj[null] &&= 8; | ||
unboundObj[123] &&= 9; | ||
unboundObj[123n] &&= 10; | ||
unboundObj[/abc/g] &&= 11; | ||
unboundObj["abc"] &&= 12; |
22 changes: 22 additions & 0 deletions
22
...ugin-transform-logical-assignment-operators/test/fixtures/computed-prop-literal/output.js
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
var _unboundObj, | ||
_unboundObj2, | ||
_unboundObj3, | ||
_unboundObj4, | ||
_unboundObj5, | ||
_unboundObj6; | ||
|
||
let boundObj; | ||
|
||
boundObj[true] && (boundObj[true] = 1); | ||
boundObj[null] && (boundObj[null] = 2); | ||
boundObj[123] && (boundObj[123] = 3); | ||
boundObj[123n] && (boundObj[123n] = 4); | ||
boundObj[/abc/g] && (boundObj[/abc/g] = 5); | ||
boundObj["abc"] && (boundObj["abc"] = 6); | ||
|
||
(_unboundObj = unboundObj)[true] && (_unboundObj[true] = 7); | ||
(_unboundObj2 = unboundObj)[null] && (_unboundObj2[null] = 8); | ||
(_unboundObj3 = unboundObj)[123] && (_unboundObj3[123] = 9); | ||
(_unboundObj4 = unboundObj)[123n] && (_unboundObj4[123n] = 10); | ||
(_unboundObj5 = unboundObj)[/abc/g] && (_unboundObj5[/abc/g] = 11); | ||
(_unboundObj6 = unboundObj)["abc"] && (_unboundObj6["abc"] = 12); |
7 changes: 7 additions & 0 deletions
7
...nsform-logical-assignment-operators/test/fixtures/computed-prop-template-literal/input.js
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
let boundObj; | ||
|
||
boundObj[`abc`] &&= 1; | ||
unboundObj[`abc`] &&= 2; | ||
|
||
boundObj[`abc${foo}def`] &&= 3; | ||
unboundObj[`abc${foo}def`] &&= 4; |
12 changes: 12 additions & 0 deletions
12
...sform-logical-assignment-operators/test/fixtures/computed-prop-template-literal/output.js
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,12 @@ | ||
var _unboundObj, | ||
_ref, | ||
_unboundObj2, | ||
_ref2; | ||
|
||
let boundObj; | ||
|
||
boundObj[`abc`] && (boundObj[`abc`] = 1); | ||
(_unboundObj = unboundObj)[`abc`] && (_unboundObj[`abc`] = 2); | ||
|
||
boundObj[_ref = `abc${foo}def`] && (boundObj[_ref] = 3); | ||
(_unboundObj2 = unboundObj)[_ref2 = `abc${foo}def`] && (_unboundObj2[_ref2] = 4); |
5 changes: 5 additions & 0 deletions
5
...n-transform-logical-assignment-operators/test/fixtures/literal-member-expression/input.js
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
let boundProp; | ||
|
||
"abc".length &&= 1; | ||
"abc"[boundProp] &&= 2; | ||
"abc"[unboundProp] &&= 3; |
7 changes: 7 additions & 0 deletions
7
...-transform-logical-assignment-operators/test/fixtures/literal-member-expression/output.js
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
var _unboundProp; | ||
|
||
let boundProp; | ||
|
||
"abc".length && ("abc".length = 1); | ||
"abc"[boundProp] && ("abc"[boundProp] = 2); | ||
"abc"[_unboundProp = unboundProp] && ("abc"[_unboundProp] = 3); |