Skip to content

Commit

Permalink
feat(compiler): Support import.meta MetaProperty
Browse files Browse the repository at this point in the history
Resolves #29737
  • Loading branch information
nikeee committed Jun 5, 2024
1 parent a8ba5c4 commit 020e5a0
Show file tree
Hide file tree
Showing 14 changed files with 146 additions and 1 deletion.
15 changes: 15 additions & 0 deletions compiler/packages/babel-plugin-react-compiler/src/HIR/BuildHIR.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2427,6 +2427,21 @@ function lowerExpression(
let expr = exprPath as NodePath<t.TSNonNullExpression>;
return lowerExpression(builder, expr.get("expression"));
}
case "MetaProperty": {
let expr = exprPath as NodePath<t.MetaProperty>;
if (
expr.node.meta.name === "import" &&
expr.node.property.name === "meta"
) {
return {
kind: "MetaProperty",
meta: expr.node.meta.name,
property: expr.node.property.name,
loc: expr.node.loc ?? GeneratedSource,
};
}
return { kind: "UnsupportedNode", node: exprNode, loc: exprLoc };
}
default: {
builder.errors.push({
reason: `(BuildHIR::lowerExpression) Handle ${exprPath.type} expressions`,
Expand Down
6 changes: 6 additions & 0 deletions compiler/packages/babel-plugin-react-compiler/src/HIR/HIR.ts
Original file line number Diff line number Diff line change
Expand Up @@ -898,6 +898,12 @@ export type InstructionValue =
flags: string;
loc: SourceLocation;
}
| {
kind: "MetaProperty";
meta: string;
property: string;
loc: SourceLocation;
}

// store `object.property = value`
| {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -636,6 +636,10 @@ export function printInstructionValue(instrValue: ReactiveValue): string {
value = `RegExp /${instrValue.pattern}/${instrValue.flags}`;
break;
}
case "MetaProperty": {
value = `MetaProperty ${instrValue.meta}.${instrValue.property}`;
break;
}
case "Await": {
value = `Await ${printPlace(instrValue.value)}`;
break;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -242,6 +242,7 @@ export function* eachInstructionValueOperand(
}
case "Debugger":
case "RegExpLiteral":
case "MetaProperty":
case "LoadGlobal":
case "UnsupportedNode":
case "Primitive":
Expand Down Expand Up @@ -566,6 +567,7 @@ export function mapInstructionValueOperands(
}
case "Debugger":
case "RegExpLiteral":
case "MetaProperty":
case "LoadGlobal":
case "UnsupportedNode":
case "Primitive":
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -1204,6 +1204,7 @@ function inferBlock(
};
break;
}
case "MetaProperty":
case "LoadGlobal":
valueKind = {
kind: ValueKind.Global,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -350,6 +350,7 @@ function pruneableValue(value: InstructionValue, state: State): boolean {
return false;
}
case "RegExpLiteral":
case "MetaProperty":
case "LoadGlobal":
case "ArrayExpression":
case "BinaryExpression":
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2021,6 +2021,13 @@ function codegenInstructionValue(
value = t.regExpLiteral(instrValue.pattern, instrValue.flags);
break;
}
case "MetaProperty": {
value = t.metaProperty(
t.identifier(instrValue.meta),
t.identifier(instrValue.property)
);
break;
}
case "Await": {
value = t.awaitExpression(codegenPlaceToExpression(cx, instrValue.value));
break;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -199,6 +199,7 @@ function mayAllocate(env: Environment, instruction: Instruction): boolean {
case "DeclareContext":
case "StoreLocal":
case "LoadGlobal":
case "MetaProperty":
case "TypeCastExpression":
case "LoadLocal":
case "LoadContext":
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -459,6 +459,7 @@ function computeMemoizationInputs(
case "ComputedDelete":
case "PropertyDelete":
case "LoadGlobal":
case "MetaProperty":
case "TemplateLiteral":
case "Primitive":
case "JSXText":
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -338,6 +338,7 @@ function* generateInstructionTypes(
case "DeclareLocal":
case "NewExpression":
case "RegExpLiteral":
case "MetaProperty":
case "PropertyStore":
case "ComputedStore":
case "ComputedLoad":
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,67 @@

## Input

```javascript
function a() {
return import.meta.url;
}

function b() {
let a = 0;
if (import.meta.url) {
a = 1;
}
return a;
}

function c() {
let a = 0;
if (import.meta.foo) {
a = 1;
}
return a;
}

function d() {
let a = 0;
if (import.meta) {
a = 1;
}
return a;
}

```
## Code
```javascript
function a() {
return import.meta.url;
}

function b() {
let a = 0;
if (import.meta.url) {
a = 1;
}
return a;
}

function c() {
let a = 0;
if (import.meta.foo) {
a = 1;
}
return a;
}

function d() {
let a = 0;
if (import.meta) {
a = 1;
}
return a;
}

```
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
function a() {
return import.meta.url;
}

function b() {
let a = 0;
if (import.meta.url) {
a = 1;
}
return a;
}

function c() {
let a = 0;
if (import.meta.foo) {
a = 1;
}
return a;
}

function d() {
let a = 0;
if (import.meta) {
a = 1;
}
return a;
}
3 changes: 3 additions & 0 deletions compiler/packages/snap/src/SproutTodoFilter.ts
Original file line number Diff line number Diff line change
Expand Up @@ -499,6 +499,9 @@ const skipFilter = new Set([
"useState-unpruned-dependency",
"useState-and-other-hook-unpruned-dependency",
"change-detect-reassign",

// needs to be executed as a module
"meta-property",
]);

export default skipFilter;
11 changes: 10 additions & 1 deletion compiler/packages/snap/src/fixture-utils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,16 @@ import * as glob from "glob";
import path from "path";
import { FILTER_PATH, FIXTURES_PATH, SNAPSHOT_EXTENSION } from "./constants";

const INPUT_EXTENSIONS = [".js", ".cjs", ".mjs", ".ts", ".cts", ".mts", ".jsx", ".tsx"];
const INPUT_EXTENSIONS = [
".js",
".cjs",
".mjs",
".ts",
".cts",
".mts",
".jsx",
".tsx",
];

export type TestFilter = {
debug: boolean;
Expand Down

0 comments on commit 020e5a0

Please sign in to comment.