From a1f1756a5b3e740a1b84310fb902da9c437abea8 Mon Sep 17 00:00:00 2001 From: Jan Kassens Date: Wed, 3 Jul 2024 17:19:36 -0400 Subject: [PATCH] yarn prettier-all --- .../playground/__tests__/e2e/page.spec.ts | 28 +- compiler/apps/playground/app/index.tsx | 22 +- compiler/apps/playground/app/layout.tsx | 19 +- compiler/apps/playground/app/page.tsx | 11 +- compiler/apps/playground/babel.config.js | 6 +- compiler/apps/playground/colors.js | 132 +- .../components/Editor/EditorImpl.tsx | 130 +- .../playground/components/Editor/Input.tsx | 55 +- .../playground/components/Editor/Output.tsx | 109 +- .../playground/components/Editor/index.tsx | 4 +- .../components/Editor/monacoOptions.ts | 16 +- .../apps/playground/components/Header.tsx | 41 +- .../components/Icons/IconGitHub.tsx | 9 +- compiler/apps/playground/components/Logo.tsx | 5 +- .../apps/playground/components/Message.tsx | 24 +- .../playground/components/StoreContext.tsx | 24 +- .../playground/components/TabbedWindow.tsx | 23 +- compiler/apps/playground/components/index.ts | 6 +- compiler/apps/playground/hooks/index.ts | 2 +- .../apps/playground/hooks/useMountEffect.ts | 4 +- compiler/apps/playground/lib/createContext.ts | 6 +- compiler/apps/playground/lib/defaultStore.ts | 4 +- .../lib/reactCompilerMonacoDiagnostics.ts | 26 +- compiler/apps/playground/lib/stores/index.ts | 4 +- .../apps/playground/lib/stores/messages.ts | 6 +- compiler/apps/playground/lib/stores/store.ts | 20 +- compiler/apps/playground/next.config.js | 16 +- compiler/apps/playground/playwright.config.js | 18 +- .../apps/playground/scripts/downloadFonts.js | 8 +- compiler/apps/playground/tailwind.config.js | 28 +- .../jest.config.js | 2 +- .../rollup.config.js | 34 +- .../babel-plugin-annotate-react-code.ts | 92 +- .../scripts/build-react-hooks-fixures.js | 52 +- .../eslint-plugin-react-hooks-test-cases.js | 6 +- .../scripts/jest/e2e-classic.config.js | 4 +- .../scripts/jest/e2e-forget.config.js | 6 +- .../scripts/jest/main.config.js | 8 +- .../scripts/jest/makeE2EConfig.js | 22 +- .../scripts/jest/makeSnapshotResolver.js | 4 +- .../scripts/jest/makeTransform.ts | 62 +- .../scripts/jest/setupEnvE2E.js | 2 +- .../jest/snapshot-resolver-no-forget.js | 2 +- .../jest/snapshot-resolver-with-forget.js | 2 +- .../scripts/jest/transform-no-forget.js | 2 +- .../scripts/jest/transform-with-forget.js | 2 +- .../src/Babel/BabelPlugin.ts | 14 +- .../src/Babel/RunReactCompilerBabelPlugin.ts | 30 +- .../src/CompilerError.ts | 60 +- .../src/Entrypoint/Gating.ts | 41 +- .../src/Entrypoint/Imports.ts | 62 +- .../src/Entrypoint/Options.ts | 48 +- .../src/Entrypoint/Pipeline.ts | 242 +-- .../src/Entrypoint/Program.ts | 306 +-- .../src/Entrypoint/Reanimated.ts | 18 +- .../src/Entrypoint/Suppression.ts | 46 +- .../src/Entrypoint/index.ts | 12 +- .../src/HIR/AssertConsistentIdentifiers.ts | 12 +- .../src/HIR/AssertTerminalBlocksExist.ts | 18 +- .../src/HIR/AssertValidBlockNesting.ts | 24 +- .../src/HIR/AssertValidMutableRanges.ts | 10 +- .../src/HIR/BuildHIR.ts | 1714 ++++++++--------- .../src/HIR/BuildReactiveScopeTerminalsHIR.ts | 36 +- .../src/HIR/ComputeUnconditionalBlocks.ts | 6 +- .../src/HIR/Dominator.ts | 24 +- .../src/HIR/Environment.ts | 104 +- .../src/HIR/FindContextIdentifiers.ts | 54 +- .../src/HIR/Globals.ts | 296 +-- .../src/HIR/HIR.ts | 414 ++-- .../src/HIR/HIRBuilder.ts | 134 +- .../src/HIR/MergeConsecutiveBlocks.ts | 24 +- .../HIR/MergeOverlappingReactiveScopesHIR.ts | 40 +- .../src/HIR/ObjectShape.ts | 214 +- .../src/HIR/PrintHIR.ts | 492 ++--- .../src/HIR/PruneUnusedLabelsHIR.ts | 20 +- .../src/HIR/Types.ts | 72 +- .../src/HIR/index.ts | 28 +- .../src/HIR/visitors.ts | 586 +++--- .../src/Inference/AnalyseFunctions.ts | 46 +- .../src/Inference/DropManualMemoization.ts | 100 +- .../src/Inference/InferAlias.ts | 24 +- .../src/Inference/InferAliasForPhis.ts | 6 +- .../src/Inference/InferAliasForStores.ts | 14 +- .../Inference/InferMutableContextVariables.ts | 20 +- .../src/Inference/InferMutableLifetimes.ts | 24 +- .../src/Inference/InferMutableRanges.ts | 14 +- .../Inference/InferMutableRangesForAlias.ts | 8 +- .../src/Inference/InferReactivePlaces.ts | 48 +- .../src/Inference/InferReferenceEffects.ts | 406 ++-- .../src/Inference/InferTryCatchAliases.ts | 12 +- ...neImmediatelyInvokedFunctionExpressions.ts | 38 +- .../src/Inference/index.ts | 12 +- .../src/Optimization/ConstantPropagation.ts | 222 +-- .../src/Optimization/DeadCodeElimination.ts | 126 +- .../src/Optimization/InstructionReordering.ts | 86 +- .../src/Optimization/PruneMaybeThrows.ts | 22 +- .../src/Optimization/index.ts | 6 +- .../ReactiveScopes/AlignMethodCallScopes.ts | 16 +- .../ReactiveScopes/AlignObjectMethodScopes.ts | 30 +- .../AlignReactiveScopesToBlockScopes.ts | 18 +- .../AlignReactiveScopesToBlockScopesHIR.ts | 54 +- .../AssertScopeInstructionsWithinScope.ts | 18 +- .../AssertWellFormedBreakTargets.ts | 12 +- .../src/ReactiveScopes/BuildReactiveBlocks.ts | 60 +- .../ReactiveScopes/BuildReactiveFunction.ts | 360 ++-- .../ReactiveScopes/CodegenReactiveFunction.ts | 985 +++++----- .../CollectReactiveIdentifiers.ts | 12 +- .../CollectReferencedGlobals.ts | 14 +- .../DeriveMinimalDependencies.ts | 86 +- ...tractScopeDeclarationsFromDestructuring.ts | 28 +- .../ReactiveScopes/FlattenReactiveLoops.ts | 44 +- .../ReactiveScopes/FlattenReactiveLoopsHIR.ts | 56 +- .../FlattenScopesWithHooksOrUse.ts | 20 +- .../FlattenScopesWithHooksOrUseHIR.ts | 30 +- .../InferReactiveScopeVariables.ts | 126 +- .../MemoizeFbtAndMacroOperandsInSameScope.ts | 56 +- .../MergeOverlappingReactiveScopes.ts | 34 +- ...rgeReactiveScopesThatInvalidateTogether.ts | 108 +- .../ReactiveScopes/PrintReactiveFunction.ts | 170 +- .../ReactiveScopes/PromoteUsedTemporaries.ts | 32 +- .../ReactiveScopes/PropagateEarlyReturns.ts | 82 +- .../PropagateScopeDependencies.ts | 173 +- .../ReactiveScopes/PruneAllReactiveScopes.ts | 8 +- .../PruneAlwaysInvalidatingScopes.ts | 36 +- .../ReactiveScopes/PruneHoistedContexts.ts | 22 +- .../PruneInitializationDependencies.ts | 98 +- .../ReactiveScopes/PruneNonEscapingScopes.ts | 274 +-- .../PruneNonReactiveDependencies.ts | 24 +- .../ReactiveScopes/PruneTemporaryLValues.ts | 6 +- .../src/ReactiveScopes/PruneUnusedLabels.ts | 22 +- .../src/ReactiveScopes/PruneUnusedScopes.ts | 16 +- .../src/ReactiveScopes/RenameVariables.ts | 22 +- .../src/ReactiveScopes/StabilizeBlockIds.ts | 22 +- .../src/ReactiveScopes/index.ts | 59 +- .../src/ReactiveScopes/visitors.ts | 254 +-- .../src/SSA/EliminateRedundantPhi.ts | 22 +- .../src/SSA/EnterSSA.ts | 52 +- .../src/SSA/LeaveSSA.ts | 96 +- .../src/SSA/index.ts | 6 +- .../src/TypeInference/InferTypes.ts | 272 +-- .../src/TypeInference/index.ts | 2 +- .../src/Utils/ComponentDeclaration.ts | 8 +- .../src/Utils/DisjointSet.ts | 4 +- .../src/Utils/HookDeclaration.ts | 8 +- .../src/Utils/Stack.ts | 2 +- .../src/Utils/logger.ts | 26 +- .../src/Utils/todo.ts | 6 +- .../src/Utils/utils.ts | 16 +- .../ValidateContextVariableLValues.ts | 69 +- .../src/Validation/ValidateHooksUsage.ts | 90 +- .../ValidateLocalsNotReassignedAfterRender.ts | 48 +- .../ValidateMemoizedEffectDependencies.ts | 20 +- .../Validation/ValidateNoCapitalizedCalls.ts | 20 +- .../Validation/ValidateNoRefAccesInRender.ts | 78 +- .../Validation/ValidateNoSetStateInRender.ts | 42 +- .../ValidatePreservedManualMemoization.ts | 124 +- .../src/Validation/ValidateUseMemo.ts | 30 +- .../src/Validation/index.ts | 16 +- .../src/__tests__/DisjointSet-test.ts | 22 +- .../src/__tests__/Logger-test.ts | 60 +- .../src/__tests__/Result-test.ts | 114 +- .../src/__tests__/e2e/constant-prop.e2e.js | 32 +- .../src/__tests__/e2e/hello.e2e.js | 18 +- .../src/__tests__/e2e/update-button.e2e.js | 16 +- .../__tests__/e2e/update-expressions.e2e.js | 10 +- .../src/__tests__/e2e/use-state.e2e.js | 22 +- .../src/__tests__/envConfig-test.ts | 22 +- ...s-capture-in-method-receiver-and-mutate.js | 2 +- .../fixtures/compiler/alias-computed-load.js | 4 +- .../align-scope-starts-within-cond.ts | 2 +- ...opes-iife-return-modified-later-logical.ts | 4 +- .../align-scopes-nested-block-structure.ts | 16 +- ...align-scopes-reactive-scope-overlaps-if.ts | 14 +- ...gn-scopes-reactive-scope-overlaps-label.ts | 14 +- ...lign-scopes-reactive-scope-overlaps-try.ts | 8 +- ...copes-trycatch-nested-overlapping-range.ts | 2 +- ...opes-within-nested-valueblock-in-array.tsx | 10 +- ...ng-logical-expression-instruction-scope.ts | 4 +- ...llocating-primitive-as-dep-nested-scope.js | 12 +- ...mutation-in-effect-indirect-usecallback.js | 2 +- ...llow-global-mutation-in-effect-indirect.js | 2 +- ...llow-global-mutation-unused-usecallback.js | 2 +- ...-global-reassignment-in-effect-indirect.js | 2 +- .../allow-global-reassignment-in-effect.js | 2 +- .../allow-modify-global-in-callback-jsx.js | 18 +- .../allow-mutate-global-in-effect-fixpoint.js | 6 +- ...ref-in-callback-passed-to-jsx-indirect.tsx | 4 +- ...mutating-ref-in-callback-passed-to-jsx.tsx | 4 +- ...rty-in-callback-passed-to-jsx-indirect.tsx | 4 +- ...ref-property-in-callback-passed-to-jsx.tsx | 4 +- .../allow-ref-access-in-effect-indirect.js | 6 +- .../compiler/allow-ref-access-in-effect.js | 6 +- ...ow-ref-access-in-unused-callback-nested.js | 6 +- .../compiler/array-access-assignment.js | 14 +- .../compiler/array-concat-should-capture.ts | 10 +- .../compiler/array-expression-spread.js | 4 +- .../__tests__/fixtures/compiler/array-join.js | 2 +- .../array-map-captures-receiver-noAlias.js | 6 +- .../array-map-frozen-array-noAlias.js | 2 +- .../compiler/array-map-frozen-array.js | 2 +- ...p-mutable-array-mutating-lambda-noAlias.js | 2 +- ...array-map-mutable-array-mutating-lambda.js | 2 +- ...rray-non-mutating-lambda-mutated-result.js | 2 +- .../array-map-noAlias-escaping-function.js | 4 +- .../fixtures/compiler/array-pattern-params.js | 6 +- .../fixtures/compiler/array-properties.js | 6 +- .../fixtures/compiler/array-property-call.js | 6 +- .../fixtures/compiler/array-push-effect.js | 2 +- .../fixtures/compiler/arrow-expr-directive.js | 6 +- .../arrow-function-one-line-directive.js | 2 +- .../assignment-expression-computed.js | 4 +- .../assignment-expression-nested-path.js | 4 +- .../assignment-variations-complex-lvalue.js | 2 +- .../compiler/babel-existing-react-import.js | 2 +- ...babel-existing-react-kitchensink-import.js | 4 +- .../babel-existing-react-namespace-import.js | 4 +- .../block-scoping-switch-dead-code.js | 2 +- .../block-scoping-switch-variable-scoping.js | 6 +- .../compiler/bug-codegen-inline-iife.ts | 4 +- .../bug-invalid-hoisting-functionexpr.tsx | 6 +- .../capitalized-function-allowlist.js | 4 +- .../capture-indirect-mutate-alias-iife.js | 2 +- .../compiler/capture-indirect-mutate-alias.js | 6 +- .../fixtures/compiler/capture-param-mutate.js | 10 +- .../capture-ref-for-later-mutation.tsx | 12 +- .../capture_mutate-across-fns-iife.js | 2 +- .../compiler/capture_mutate-across-fns.js | 6 +- .../compiler/capturing-arrow-function-1.js | 6 +- ...turing-fun-alias-captured-mutate-2-iife.js | 10 +- .../capturing-fun-alias-captured-mutate-2.js | 6 +- ...ng-fun-alias-captured-mutate-arr-2-iife.js | 8 +- ...pturing-fun-alias-captured-mutate-arr-2.js | 4 +- ...ing-func-alias-captured-mutate-arr-iife.js | 8 +- ...apturing-func-alias-captured-mutate-arr.js | 4 +- ...pturing-func-alias-captured-mutate-iife.js | 10 +- .../capturing-func-alias-captured-mutate.js | 6 +- ...pturing-func-alias-computed-mutate-iife.js | 8 +- .../capturing-func-alias-computed-mutate.js | 4 +- .../capturing-func-alias-mutate-iife.js | 6 +- .../compiler/capturing-func-alias-mutate.js | 2 +- ...unc-alias-receiver-computed-mutate-iife.js | 8 +- ...ing-func-alias-receiver-computed-mutate.js | 4 +- ...pturing-func-alias-receiver-mutate-iife.js | 6 +- .../capturing-func-alias-receiver-mutate.js | 2 +- .../compiler/capturing-func-mutate-2.js | 6 +- .../compiler/capturing-func-mutate-3.js | 8 +- .../compiler/capturing-func-mutate-nested.js | 6 +- .../compiler/capturing-func-mutate.js | 8 +- .../capturing-func-simple-alias-iife.js | 6 +- .../compiler/capturing-func-simple-alias.js | 2 +- .../fixtures/compiler/capturing-function-1.js | 6 +- ...ing-function-alias-computed-load-2-iife.js | 2 +- ...apturing-function-alias-computed-load-2.js | 2 +- ...ing-function-alias-computed-load-4-iife.js | 2 +- ...apturing-function-alias-computed-load-4.js | 2 +- ...uring-function-alias-computed-load-iife.js | 2 +- .../capturing-function-alias-computed-load.js | 4 +- ...ring-function-capture-ref-before-rename.js | 6 +- ...ing-function-conditional-capture-mutate.js | 2 +- .../compiler/capturing-function-decl.js | 6 +- ...apturing-function-member-expr-arguments.js | 2 +- .../capturing-function-member-expr-call.js | 2 +- .../capturing-function-renamed-ref.js | 4 +- .../capturing-function-runs-inference.js | 2 +- .../capturing-function-shadow-captured.js | 2 +- .../capturing-function-skip-computed-path.js | 8 +- .../capturing-function-within-block.js | 6 +- .../compiler/capturing-member-expr.js | 6 +- .../compiler/capturing-nested-member-call.js | 6 +- ...uring-nested-member-expr-in-nested-func.js | 6 +- .../compiler/capturing-nested-member-expr.js | 6 +- .../capturing-reference-changes-type.js | 2 +- .../capturing-variable-in-nested-block.js | 6 +- .../capturing-variable-in-nested-function.js | 6 +- .../chained-assignment-context-variable.js | 2 +- .../chained-assignment-expressions.js | 6 +- .../codegen-instrument-forget-gating-test.js | 4 +- .../codegen-instrument-forget-test.js | 4 +- .../fixtures/compiler/complex-while.js | 4 +- ...omponent-inner-function-with-many-args.tsx | 4 +- .../__tests__/fixtures/compiler/component.js | 4 +- .../computed-call-evaluation-order.js | 10 +- .../fixtures/compiler/computed-store-alias.js | 6 +- .../fixtures/compiler/concise-arrow-expr.js | 2 +- .../compiler/conditional-break-labeled.js | 4 +- .../compiler/conditional-early-return.js | 2 +- .../conditional-set-state-in-render.js | 4 +- .../conflicting-dollar-sign-variable.js | 4 +- .../fixtures/compiler/consecutive-use-memo.ts | 10 +- .../fixtures/compiler/console-readonly.js | 4 +- .../compiler/const-propagation-phi-nodes.ts | 2 +- .../fixtures/compiler/constant-computed.js | 8 +- .../constant-prop-across-objectmethod-def.js | 2 +- .../constant-prop-colliding-identifier.js | 4 +- .../constant-prop-to-object-method.js | 2 +- ...constant-propagate-global-phis-constant.js | 8 +- .../constant-propagate-global-phis.js | 8 +- .../compiler/constant-propagation-bit-ops.js | 2 +- .../compiler/constant-propagation-phi.js | 4 +- .../constant-propagation-string-concat.js | 4 +- .../compiler/constant-propagation-unary.js | 12 +- .../fixtures/compiler/constant-propagation.js | 2 +- .../context-variable-as-jsx-element-tag.js | 6 +- .../context-variable-only-chained-assign.js | 2 +- ...variable-reactive-explicit-control-flow.js | 8 +- ...variable-reactive-implicit-control-flow.js | 8 +- ...ontext-variable-reassigned-objectmethod.js | 6 +- ...t-variable-reassigned-outside-of-lambda.js | 2 +- ...xt-variable-reassigned-reactive-capture.js | 8 +- ...context-variable-reassigned-two-lambdas.js | 12 +- .../fixtures/compiler/controlled-input.js | 4 +- .../fixtures/compiler/createElement-freeze.js | 8 +- .../__tests__/fixtures/compiler/dce-loop.js | 2 +- .../fixtures/compiler/dce-unused-const.js | 2 +- .../compiler/dce-unused-postfix-update.js | 2 +- .../compiler/dce-unused-prefix-update.js | 2 +- .../fixtures/compiler/debugger-memoized.js | 4 +- .../__tests__/fixtures/compiler/debugger.js | 4 +- .../declare-reassign-variable-in-closure.js | 4 +- .../default-param-calls-global-function.js | 4 +- ...default-param-with-reorderable-callback.js | 2 +- .../compiler/delete-computed-property.js | 8 +- .../fixtures/compiler/delete-property.js | 6 +- .../fixtures/compiler/dependencies-outputs.js | 4 +- .../fixtures/compiler/dependencies.js | 4 +- ...ructure-array-assignment-to-context-var.js | 6 +- ...ucture-array-declaration-to-context-var.js | 6 +- .../compiler/destructure-capture-global.js | 4 +- .../destructure-default-array-with-unary.js | 2 +- .../destructure-direct-reassignment.js | 6 +- .../compiler/destructure-in-branch-ssa.ts | 4 +- .../destructure-mixed-property-key-types.js | 6 +- ...ucture-object-assignment-to-context-var.js | 8 +- ...cture-object-declaration-to-context-var.js | 8 +- ...m-string-literal-key-invalid-identifier.js | 4 +- .../destructure-param-string-literal-key.js | 4 +- ...literal-invalid-identifier-property-key.js | 2 +- ...destructure-string-literal-property-key.js | 2 +- .../compiler/destructuring-array-default.js | 6 +- .../destructuring-array-param-default.js | 4 +- .../destructuring-assignment-array-default.js | 6 +- .../compiler/destructuring-assignment.js | 8 +- .../destructuring-default-at-array-hole.js | 2 +- .../destructuring-default-at-explicit-null.js | 2 +- ...ructuring-default-at-explicit-undefined.js | 2 +- ...destructuring-default-past-end-of-array.js | 2 +- ...-scope-and-local-variables-with-default.js | 14 +- ...ing-mixed-scope-declarations-and-locals.js | 4 +- .../compiler/destructuring-object-default.js | 6 +- .../destructuring-object-param-default.js | 6 +- ...estructuring-object-pattern-within-rest.js | 4 +- .../destructuring-property-inference.js | 2 +- ...ucturing-same-property-identifier-names.js | 6 +- ...uring-with-conditional-as-default-value.js | 2 +- .../fixtures/compiler/destructuring.js | 6 +- .../fixtures/compiler/do-while-break.js | 4 +- .../compiler/do-while-compound-test.js | 4 +- .../__tests__/fixtures/compiler/dominator.js | 10 +- ...-is-inner-declaration-of-previous-scope.js | 14 +- ...erlapping-scopes-store-const-used-later.js | 4 +- ...g-scopes-with-intermediate-reassignment.js | 4 +- .../compiler/drop-methodcall-usecallback.js | 4 +- .../compiler/drop-methodcall-usememo.js | 4 +- ...sted-early-return-within-reactive-scope.js | 2 +- ...declarations-reassignments-dependencies.js | 20 +- .../early-return-within-reactive-scope.js | 18 +- .../fixtures/compiler/early-return.js | 4 +- .../compiler/empty-catch-statement.ts | 2 +- ...rror._todo.computed-lval-in-destructure.js | 2 +- ...r.bailout-on-suppression-of-custom-rule.js | 2 +- ...or.codegen-error-on-conflicting-imports.js | 2 +- .../error.dont-hoist-inline-reference.js | 2 +- .../compiler/error.gating-use-before-decl.js | 2 +- .../error.hoisted-function-declaration.js | 2 +- .../error.hook-property-load-local-hook.js | 2 +- ...-ref-in-callback-invoked-during-render-.js | 4 +- ...id-conditional-call-aliased-hook-import.js | 2 +- ...lid-conditional-call-aliased-react-hook.js | 2 +- ...ditional-call-non-hook-imported-as-hook.js | 2 +- ...nvalid-destructure-assignment-to-global.js | 2 +- ...tion-expression-mutates-immutable-value.js | 4 +- ...or.invalid-global-reassignment-indirect.js | 2 +- ...invalid-mutate-props-in-effect-fixpoint.js | 2 +- .../error.invalid-mutation-in-closure.js | 2 +- ...lid-read-ref-prop-in-render-destructure.js | 2 +- ...lid-reassign-local-in-hook-return-value.js | 2 +- ...assign-local-variable-in-async-callback.js | 2 +- ...valid-reassign-local-variable-in-effect.js | 14 +- ...eassign-local-variable-in-hook-argument.js | 16 +- ...reassign-local-variable-in-jsx-callback.js | 10 +- ...d-ref-in-callback-invoked-during-render.js | 4 +- ...-read-ref-nested-property-during-render.js | 2 +- .../error.invalid-sketchy-code-use-forget.js | 2 +- ...ror.invalid-unclosed-eslint-suppression.js | 2 +- ...-use-ref-added-to-dep-without-type-info.js | 6 +- ...rror.invalid-useEffect-dep-not-memoized.js | 2 +- ...lid-useInsertionEffect-dep-not-memoized.js | 2 +- ...nvalid-useLayoutEffect-dep-not-memoized.js | 2 +- .../error.invalid-useMemo-callback-args.js | 2 +- ...valid-write-but-dont-read-ref-in-render.js | 2 +- .../fixtures/compiler/error.modify-state-2.js | 4 +- .../fixtures/compiler/error.modify-state.js | 2 +- .../compiler/error.modify-useReducer-state.js | 4 +- .../error.mutate-captured-arg-separately.js | 2 +- .../error.mutate-function-property.js | 4 +- .../error.not-useEffect-external-mutate.js | 2 +- .../compiler/error.ref-like-name-not-Ref.js | 4 +- .../compiler/error.ref-like-name-not-a-ref.js | 4 +- .../compiler/error.todo-for-await-loops.js | 2 +- ...-in-loop-with-context-variable-iterator.js | 4 +- ...-of-loop-with-context-variable-iterator.js | 4 +- .../compiler/error.todo-kitchensink.js | 10 +- ...alls-lower-property-load-into-temporary.js | 2 +- .../error.todo-new-target-meta-property.js | 2 +- ...during-after-construction-sequence-expr.js | 4 +- ...-key-modified-during-after-construction.js | 4 +- ...ey-mutate-key-while-constructing-object.js | 4 +- ...error.todo-object-expression-get-syntax.js | 6 +- ...error.todo-object-expression-set-syntax.js | 4 +- ...odo-optional-call-chain-in-logical-expr.ts | 6 +- ...or.todo-optional-call-chain-in-optional.ts | 6 +- ...ror.todo-optional-call-chain-in-ternary.ts | 6 +- .../compiler/error.todo-reassign-const.js | 4 +- ...-callback-captured-in-context-variable.tsx | 16 +- ...later-via-function-preserve-memoization.js | 6 +- ...ref-modified-later-preserve-memoization.js | 6 +- ...nal-set-state-in-render-with-loop-throw.js | 2 +- .../error.useMemo-non-literal-depslist.ts | 10 +- ...oized-effect-deps-invalidated-dep-value.js | 4 +- ...error.validate-mutate-ref-arg-in-render.js | 2 +- ...cape-analysis-destructured-rest-element.js | 6 +- .../compiler/escape-analysis-jsx-child.js | 4 +- .../compiler/escape-analysis-logical.js | 4 +- ...aping-interleaved-allocating-dependency.js | 4 +- ...nterleaved-allocating-nested-dependency.js | 4 +- ...caping-interleaved-primitive-dependency.js | 4 +- .../escape-analysis-not-conditional-test.js | 4 +- .../compiler/escape-analysis-not-if-test.js | 4 +- .../escape-analysis-not-switch-case.js | 4 +- .../escape-analysis-not-switch-test.js | 4 +- .../existing-variables-with-c-name.js | 4 +- .../expression-with-assignment-dynamic.js | 4 +- .../fixtures/compiler/extend-scopes-if.js | 4 +- ...refresh-dont-refresh-const-changes-prod.js | 6 +- ...st-refresh-refresh-on-const-changes-dev.js | 6 +- .../compiler/fast-refresh-reloading.js | 4 +- .../fbt/error.todo-fbt-unknown-enum-value.js | 8 +- .../fbt/error.todo-locally-require-fbt.js | 4 +- .../fixtures/compiler/fbt/fbs-params.js | 9 +- .../fbt/fbt-call-complex-param-value.js | 10 +- .../fixtures/compiler/fbt/fbt-call.js | 8 +- .../fbt-no-whitespace-btw-text-and-param.tsx | 6 +- .../fbt/fbt-param-with-leading-whitespace.js | 24 +- .../fbt/fbt-param-with-trailing-whitespace.js | 24 +- .../fbt/fbt-params-complex-param-value.js | 4 +- .../fixtures/compiler/fbt/fbt-params.js | 8 +- .../compiler/fbt/fbt-preserve-jsxtext.js | 10 +- .../compiler/fbt/fbt-preserve-whitespace.tsx | 6 +- .../fbt-single-space-btw-param-and-text.tsx | 6 +- .../fbt/fbt-template-string-same-scope.js | 10 +- .../fixtures/compiler/fbt/fbt-to-string.js | 6 +- .../fbt/fbt-whitespace-around-param-value.tsx | 6 +- .../fbt/fbt-whitespace-within-text.tsx | 6 +- ...aram-text-must-use-expression-container.js | 4 +- .../fbt/fbtparam-with-jsx-element-content.js | 4 +- .../fbt/fbtparam-with-jsx-fragment-value.js | 4 +- .../fixtures/compiler/fbt/lambda-with-fbt.js | 8 +- .../compiler/flag-enable-emit-hook-guards.ts | 10 +- .../flatten-scopes-with-methodcall-hook.js | 2 +- .../for-empty-update-with-continue.js | 4 +- .../fixtures/compiler/for-empty-update.js | 4 +- .../for-in-statement-body-always-returns.js | 2 +- .../compiler/for-in-statement-break.js | 6 +- .../compiler/for-in-statement-continue.js | 22 +- .../compiler/for-in-statement-empty-body.js | 2 +- .../for-in-statement-type-inference.js | 6 +- .../fixtures/compiler/for-in-statement.js | 6 +- .../fixtures/compiler/for-logical.js | 4 +- .../compiler/for-loop-let-undefined-decl.js | 4 +- .../for-loop-with-value-block-initializer.js | 24 +- ...le-variable-declarations-in-initializer.js | 2 +- ...ction-mutate-later-value-initially-null.js | 2 +- ...e-item-of-local-collection-mutate-later.js | 2 +- .../fixtures/compiler/for-of-destructure.js | 4 +- .../compiler/for-of-immutable-collection.js | 10 +- ...for-of-iterator-of-immutable-collection.js | 10 +- .../for-of-mutate-item-of-local-collection.js | 2 +- .../fixtures/compiler/for-of-mutate.tsx | 2 +- ...or-of-nonmutating-loop-local-collection.js | 14 +- .../__tests__/fixtures/compiler/for-return.js | 4 +- .../compiler/for-with-assignment-as-update.js | 2 +- .../compiler/function-declaration-simple.js | 6 +- .../compiler/function-expr-directive.js | 6 +- ...ression-captures-value-later-frozen-jsx.js | 2 +- ...tion-expression-prototype-call-mutating.js | 12 +- .../function-expression-prototype-call.js | 2 +- .../function-param-assignment-pattern.js | 6 +- ...tionexpr\342\200\223conditional-access.js" | 2 +- .../gating-preserves-function-properties.tsx | 4 +- .../gating-test-export-default-function.js | 4 +- ...gating-test-export-function-and-default.js | 4 +- .../compiler/gating-test-export-function.js | 4 +- .../fixtures/compiler/gating-test.js | 4 +- .../fixtures/compiler/globals-Boolean.js | 4 +- .../fixtures/compiler/globals-Number.js | 4 +- .../fixtures/compiler/globals-String.js | 4 +- .../globals-dont-resolve-local-useState.js | 8 +- .../hoisted-declaration-with-scope.tsx | 10 +- .../hoisting-computed-member-expression.js | 8 +- .../compiler/hoisting-member-expression.js | 4 +- .../hoisting-nested-block-statements.js | 2 +- .../hoisting-recursive-call-within-lambda.js | 4 +- .../compiler/hoisting-recursive-call.ts | 4 +- .../fixtures/compiler/holey-array-expr.js | 4 +- .../compiler/holey-array-pattern-dce-2.js | 4 +- .../compiler/holey-array-pattern-dce.js | 4 +- .../fixtures/compiler/holey-array.js | 4 +- .../fixtures/compiler/hook-noAlias.js | 6 +- .../fixtures/compiler/hooks-with-prefix.js | 6 +- .../fixtures/compiler/ignore-use-no-forget.js | 4 +- .../iife-return-modified-later-phi.js | 2 +- .../compiler/iife-return-modified-later.js | 2 +- .../inadvertent-mutability-readonly-lambda.js | 2 +- .../incompatible-destructuring-kinds.js | 8 +- .../independently-memoize-object-property.js | 6 +- ...nfer-compile-hooks-with-multiple-params.js | 2 +- .../compiler/infer-function-React-memo.js | 2 +- .../compiler/infer-function-assignment.js | 2 +- ...r-function-expression-React-memo-gating.js | 2 +- .../compiler/infer-function-forwardRef.js | 2 +- .../fixtures/compiler/infer-global-object.js | 6 +- .../compiler/infer-no-component-annot.ts | 2 +- .../compiler/infer-no-component-obj-return.js | 2 +- .../fixtures/compiler/inverted-if-else.js | 4 +- .../fixtures/compiler/inverted-if.js | 4 +- .../__tests__/fixtures/compiler/issue852.js | 2 +- .../issue933-disjoint-set-infinite-loop.js | 4 +- .../jsx-attribute-default-to-true.tsx | 2 +- .../jsx-attribute-with-jsx-element-value.js | 15 +- .../fixtures/compiler/jsx-empty-expression.js | 2 +- .../fixtures/compiler/jsx-fragment.js | 6 +- .../__tests__/fixtures/compiler/jsx-freeze.js | 8 +- .../jsx-local-memberexpr-tag-conditional.js | 6 +- .../compiler/jsx-local-memberexpr-tag.js | 2 +- .../compiler/jsx-local-tag-in-lambda.js | 2 +- .../compiler/jsx-memberexpr-tag-in-lambda.js | 2 +- .../fixtures/compiler/jsx-namespaced-name.js | 4 +- .../compiler/jsx-preserve-whitespace.tsx | 2 +- ...sx-reactive-local-variable-member-expr.tsx | 10 +- .../__tests__/fixtures/compiler/jsx-spread.js | 2 +- ...x-string-attribute-expression-container.js | 14 +- .../jsx-string-attribute-non-ascii.js | 2 +- .../jsx-tag-evaluation-order-non-global.js | 4 +- .../compiler/jsx-tag-evaluation-order.tsx | 6 +- .../compiler/jsx-ternary-local-variable.tsx | 6 +- .../labeled-break-within-label-switch.ts | 2 +- ...ambda-array-access-member-expr-captured.ts | 4 +- .../lambda-array-access-member-expr-param.ts | 4 +- .../compiler/lambda-capture-returned-alias.js | 2 +- ...lambda-mutated-non-reactive-to-reactive.js | 6 +- .../lambda-mutated-ref-non-reactive.js | 4 +- .../compiler/lambda-return-expression.ts | 2 +- .../compiler/log-pruned-memoization.js | 4 +- .../compiler/logical-expression-object.js | 6 +- .../fixtures/compiler/logical-expression.js | 4 +- .../maybe-mutate-object-in-callback.js | 6 +- ...e-scopes-dont-merge-with-different-deps.js | 6 +- .../fixtures/compiler/memoization-comments.js | 4 +- .../merge-consecutive-nested-scopes.js | 6 +- ...consecutive-scopes-deps-subset-of-decls.js | 2 +- .../merge-consecutive-scopes-no-deps.js | 4 +- .../merge-consecutive-scopes-objects.js | 14 +- .../merge-consecutive-scopes-reordering.js | 6 +- .../compiler/merge-consecutive-scopes.js | 6 +- .../merge-nested-scopes-with-same-inputs.js | 4 +- .../compiler/merge-scopes-callback.js | 4 +- .../merged-scopes-are-valid-effect-deps.js | 4 +- .../repro-cx-assigned-to-temporary.js | 10 +- ...epro-cx-namespace-assigned-to-temporary.js | 10 +- .../meta-isms/repro-cx-namespace-nesting.js | 8 +- .../fixtures/compiler/method-call.js | 4 +- .../compiler/module-scoped-bindings.js | 4 +- ...i-arrow-expr-export-default-gating-test.js | 2 +- .../multi-arrow-expr-export-gating-test.js | 2 +- .../compiler/multi-arrow-expr-gating-test.js | 2 +- .../fixtures/compiler/multi-directive.js | 4 +- ...to-hoisted-callback-from-other-callback.js | 4 +- .../compiler/mutable-lifetime-loops.js | 6 +- .../mutable-lifetime-with-aliasing.js | 4 +- .../mutate-outer-scope-within-value-block.ts | 8 +- .../mutation-during-jsx-construction.js | 4 +- ...tation-within-capture-and-mutablerange.tsx | 8 +- .../mutation-within-jsx-and-break.tsx | 10 +- .../fixtures/compiler/mutation-within-jsx.tsx | 10 +- .../nested-function-shadowed-identifiers.js | 8 +- ...sted-scopes-begin-same-instr-valueblock.ts | 15 +- .../compiler/new-does-not-mutate-class.ts | 6 +- .../compiler/noAlias-filter-on-array-prop.js | 14 +- .../fixtures/compiler/non-null-assertion.ts | 2 +- ...ting-capture-in-unsplittable-memo-block.ts | 14 +- ...noptional-load-from-optional-memberexpr.js | 4 +- ...endency-can-inline-into-consuming-scope.js | 5 +- .../compiler/obj-literal-cached-in-if-else.js | 4 +- .../obj-literal-mutated-after-if-else.js | 4 +- .../object-computed-access-assignment.js | 6 +- ...expression-computed-key-constant-number.js | 4 +- ...expression-computed-key-constant-string.js | 6 +- ...ct-expression-computed-key-non-reactive.js | 4 +- ...ssion-computed-key-object-mutated-later.js | 4 +- .../object-expression-computed-key.js | 6 +- .../object-expression-string-literal-key.js | 6 +- ...ect-literal-method-call-in-ternary-test.js | 6 +- ...al-method-derived-in-ternary-consequent.js | 6 +- ...ct-literal-method-in-ternary-consequent.js | 6 +- .../object-literal-method-in-ternary-test.js | 10 +- .../compiler/object-literal-spread-element.js | 6 +- .../compiler/object-method-maybe-alias.js | 6 +- .../compiler/object-method-shorthand-3.js | 6 +- ...t-method-shorthand-aliased-mutate-after.js | 8 +- .../object-method-shorthand-derived-value.js | 8 +- .../object-method-shorthand-hook-dep.js | 4 +- .../object-method-shorthand-mutated-after.js | 8 +- .../compiler/object-method-shorthand.js | 2 +- ...ted-in-consequent-alternate-both-return.js | 4 +- .../compiler/object-pattern-params.js | 12 +- .../fixtures/compiler/object-properties.js | 2 +- .../compiler/object-shorthand-method-1.js | 6 +- .../compiler/object-shorthand-method-2.js | 8 +- .../object-shorthand-method-nested.js | 8 +- .../option-enable-change-variable-codegen.js | 2 +- .../compiler/optional-call-logical.js | 2 +- .../optional-member-expression-chain.js | 6 +- ...ng-logical-expression-instruction-scope.ts | 4 +- .../bug-hoisted-declaration-with-scope.tsx | 10 +- ...ting-capture-in-unsplittable-memo-block.ts | 14 +- .../capture-ref-for-later-mutation.tsx | 12 +- ...opes-within-nested-valueblock-in-array.tsx | 10 +- .../mutate-outer-scope-within-value-block.ts | 8 +- ...tation-within-capture-and-mutablerange.tsx | 8 +- .../mutation-within-jsx-and-break.tsx | 10 +- .../mutation-within-jsx.tsx | 10 +- ...locating-ternary-test-instruction-scope.ts | 6 +- ...rlapping-scopes-interleaved-by-terminal.js | 4 +- .../overlapping-scopes-interleaved.js | 4 +- .../compiler/overlapping-scopes-shadowed.js | 4 +- ...erlapping-scopes-shadowing-within-block.js | 4 +- .../compiler/overlapping-scopes-while.js | 4 +- .../overlapping-scopes-within-block.js | 4 +- ...tial-early-return-within-reactive-scope.js | 2 +- .../compiler/phi-reference-effects.ts | 6 +- .../compiler/phi-type-inference-array-push.js | 8 +- .../phi-type-inference-property-store.js | 4 +- ...serve-jsxtext-stringliteral-distinction.js | 2 +- ...alse-positive-useMemo-infer-mutate-deps.ts | 4 +- ...useCallback-captures-reassigned-context.ts | 4 +- ...maybe-invalid-useCallback-read-maybeRef.ts | 2 +- ...ror.maybe-invalid-useMemo-read-maybeRef.ts | 2 +- ...useCallback-captures-invalidating-value.ts | 2 +- ....useCallback-conditional-access-noAlloc.ts | 6 +- ...-infer-less-specific-conditional-access.ts | 6 +- .../error.useCallback-property-call-dep.ts | 4 +- .../error.useMemo-dep-not-recognized.ts | 6 +- ...-infer-less-specific-conditional-access.ts | 6 +- ...r-less-specific-conditional-value-block.ts | 6 +- ...or.useMemo-property-call-chained-object.ts | 4 +- .../error.useMemo-property-call-dep.ts | 4 +- ....useMemo-unrelated-mutation-in-depslist.ts | 2 +- ...invalid-useMemo-no-memoblock-sideeffect.ts | 6 +- ...-ensure-constant-prop-decls-get-removed.ts | 2 +- .../useCallback-alias-property-load-dep.ts | 8 +- ...k-captures-reassigned-context-property.tsx | 8 +- ...useCallback-captures-reassigned-context.ts | 4 +- ...seCallback-conditional-access-own-scope.ts | 6 +- .../useCallback-in-other-reactive-block.ts | 6 +- ...eCallback-infer-conditional-value-block.ts | 6 +- .../useCallback-infer-fewer-deps.ts | 2 +- .../useCallback-infer-more-specific.ts | 4 +- .../useCallback-infer-read-dep.ts | 4 +- .../useCallback-infer-scope-global.ts | 4 +- ...caping-invoked-callback-escaping-return.js | 6 +- .../useCallback-nonescaping.js | 6 +- ...allback-reordering-deplist-controlflow.tsx | 14 +- ...allback-reordering-depslist-assignment.tsx | 6 +- .../useCallback-with-no-depslist.ts | 6 +- .../useMemo-alias-property-load-dep.ts | 8 +- .../useMemo-conditional-access-alloc.ts | 8 +- .../useMemo-conditional-access-noAlloc.ts | 6 +- .../useMemo-conditional-access-own-scope.ts | 6 +- .../useMemo-constant-prop.ts | 4 +- ...eMemo-dropped-infer-always-invalidating.ts | 4 +- .../useMemo-in-other-reactive-block.ts | 6 +- .../useMemo-infer-fewer-deps.ts | 2 +- .../useMemo-infer-more-specific.ts | 4 +- .../useMemo-infer-nonallocating.ts | 2 +- .../useMemo-infer-scope-global.ts | 4 +- .../useMemo-inner-decl.ts | 8 +- .../useMemo-invoke-prop.ts | 6 +- .../useMemo-reordering-depslist-assignment.ts | 4 +- ...seMemo-reordering-depslist-controlflow.tsx | 14 +- .../useMemo-with-no-depslist.ts | 6 +- .../compiler/primitive-alias-mutate.js | 6 +- .../compiler/primitive-as-dep-nested-scope.js | 12 +- .../compiler/prop-capturing-function-1.js | 6 +- .../property-call-evaluation-order.js | 8 +- ...rune-scopes-whose-deps-invalidate-array.js | 4 +- .../prune-scopes-whose-deps-invalidate-jsx.js | 4 +- .../prune-scopes-whose-deps-invalidate-new.js | 8 +- ...une-scopes-whose-deps-invalidate-object.js | 8 +- ...-scopes-whose-deps-may-invalidate-array.js | 4 +- .../fixtures/compiler/react-namespace.js | 4 +- ...ve-control-dependency-do-while-indirect.js | 16 +- ...active-control-dependency-do-while-test.js | 16 +- .../reactive-control-dependency-for-init.js | 16 +- .../reactive-control-dependency-for-test.js | 16 +- .../reactive-control-dependency-for-update.js | 16 +- ...ive-control-dependency-forin-collection.js | 16 +- ...ive-control-dependency-forof-collection.js | 16 +- ...cy-from-interleaved-reactivity-do-while.js | 2 +- ...ency-from-interleaved-reactivity-for-in.js | 4 +- ...cy-from-interleaved-reactivity-for-init.js | 2 +- ...ency-from-interleaved-reactivity-for-of.js | 2 +- ...cy-from-interleaved-reactivity-for-test.js | 2 +- ...-from-interleaved-reactivity-for-update.js | 2 +- ...pendency-from-interleaved-reactivity-if.js | 2 +- ...ency-from-interleaved-reactivity-switch.js | 2 +- ...dency-from-interleaved-reactivity-while.js | 2 +- .../reactive-control-dependency-if.js | 16 +- ...-control-dependency-on-context-variable.js | 18 +- ...ve-control-dependency-phi-setState-type.js | 30 +- ...trol-dependency-reactive-after-fixpoint.js | 16 +- ...ive-control-dependency-switch-case-test.js | 16 +- ...ive-control-dependency-switch-condition.js | 18 +- ...tive-control-dependency-via-mutation-if.js | 16 +- ...-control-dependency-via-mutation-switch.js | 16 +- .../reactive-control-dependency-while-test.js | 16 +- .../compiler/reactive-dependency-fixpoint.js | 2 +- ...ency-nonreactive-captured-with-reactive.js | 2 +- ...y-object-captured-with-reactive-mutated.js | 4 +- .../fixtures/compiler/reactive-scopes-if.js | 4 +- .../fixtures/compiler/reactive-scopes.js | 4 +- ...ctivity-analysis-interleaved-reactivity.js | 4 +- ...-reactive-via-mutation-of-computed-load.js | 2 +- ...-reactive-via-mutation-of-property-load.js | 2 +- .../reactivity-via-aliased-mutation-array.js | 16 +- .../reactivity-via-aliased-mutation-lambda.js | 18 +- ...-aliased-mutation-through-property-load.js | 16 +- ...ity-via-readonly-alias-of-mutable-value.js | 16 +- ...only-object-method-calls-mutable-lambda.js | 2 +- .../compiler/readonly-object-method-calls.js | 2 +- .../reassign-in-while-loop-condition.js | 2 +- .../compiler/reassignment-separate-scopes.js | 4 +- ...educe-reactive-cond-deps-break-in-scope.ts | 8 +- ...eactive-cond-deps-cfg-nested-testifelse.ts | 12 +- ...duce-reactive-cond-deps-return-in-scope.ts | 8 +- .../reduce-reactive-deps/cfg-condexpr.js | 4 +- .../reduce-reactive-deps/cfg-ifelse.js | 4 +- .../cfg-nested-ifelse-missing.js | 4 +- .../reduce-reactive-deps/cfg-nested-ifelse.js | 4 +- .../cfg-switch-exhaustive.js | 4 +- .../cfg-switch-missing-case.js | 4 +- .../cfg-switch-missing-default.js | 4 +- .../reduce-reactive-deps/cond-scope.js | 2 +- .../conditional-member-expr.js | 2 +- .../join-uncond-scopes-cond-deps.js | 4 +- .../jump-poisoned/break-in-scope.ts | 14 +- .../break-poisons-outer-scope.ts | 20 +- .../jump-poisoned/loop-break-in-scope.ts | 14 +- .../reduce-if-nonexhaustive-poisoned-deps.ts | 18 +- .../reduce-if-nonexhaustive-poisoned-deps1.ts | 16 +- .../jump-poisoned/return-in-scope.ts | 14 +- .../return-poisons-outer-scope.ts | 20 +- .../else-branch-scope-unpoisoned.ts | 20 +- .../jump-target-within-scope-label.ts | 18 +- .../jump-target-within-scope-loop-break.ts | 16 +- .../reduce-if-exhaustive-nonpoisoned-deps.ts | 6 +- .../reduce-if-exhaustive-nonpoisoned-deps1.ts | 16 +- .../return-before-scope-starts.ts | 22 +- .../throw-before-scope-starts.ts | 22 +- .../memberexpr-join-optional-chain.ts | 2 +- .../memberexpr-join-optional-chain2.ts | 2 +- .../reduce-reactive-deps/no-uncond.js | 18 +- .../reduce-reactive-deps/promote-uncond.js | 4 +- .../reduce-if-exhaustive-poisoned-deps.ts | 6 +- .../reduce-reactive-deps/subpath-order1.js | 4 +- .../reduce-reactive-deps/subpath-order2.js | 4 +- .../reduce-reactive-deps/superpath-order1.js | 18 +- .../reduce-reactive-deps/superpath-order2.js | 18 +- .../uncond-nonoverlap-descendant.js | 2 +- .../uncond-nonoverlap-direct.js | 2 +- .../uncond-overlap-descendant.js | 2 +- .../uncond-overlap-direct.js | 2 +- .../uncond-subpath-order1.js | 2 +- .../uncond-subpath-order2.js | 2 +- .../uncond-subpath-order3.js | 2 +- .../ref-current-aliased-not-added-to-dep-2.js | 4 +- ...ef-current-field-write-not-added-to-dep.js | 6 +- .../ref-current-not-added-to-dep-2.js | 4 +- .../fixtures/compiler/ref-in-effect.js | 2 +- .../compiler/ref-like-name-in-effect.js | 4 +- .../ref-like-name-in-useCallback-2.js | 4 +- .../compiler/ref-like-name-in-useCallback.js | 4 +- .../ref-parameter-mutate-in-effect.js | 4 +- ...rename-source-variables-nested-function.js | 12 +- ...e-source-variables-nested-object-method.js | 12 +- .../compiler/rename-source-variables.ts | 12 +- .../compiler/reordering-across-blocks.js | 8 +- ...locating-ternary-test-instruction-scope.ts | 6 +- .../compiler/repro-dce-circular-reference.js | 10 +- ...ize-array-with-capturing-map-after-hook.js | 10 +- ...moize-array-with-mutable-map-after-hook.js | 10 +- .../repro-duplicate-import-specifier.ts | 6 +- ...struction-from-merge-consecutive-scopes.js | 4 +- .../compiler/repro-duplicate-type-import.tsx | 2 +- .../repro-hoisting-variable-collision.js | 4 +- .../fixtures/compiler/repro-hoisting.js | 4 +- ...-memoized-property-load-for-method-call.js | 6 +- ...nstruction-part-of-already-closed-scope.js | 6 +- ...alid-pruned-scope-leaks-value-via-alias.ts | 17 +- .../repro-invalid-pruned-scope-leaks-value.ts | 17 +- .../repro-invalid-reactivity-value-block.ts | 4 +- ...epro-invalid-scope-merging-value-blocks.ts | 2 +- ...ize-array-with-immutable-map-after-hook.js | 6 +- ...epro-missing-dependency-if-within-while.js | 20 +- ...ro-mutable-range-extending-into-ternary.js | 22 +- ...ating-import-without-compiled-functions.js | 2 +- ...porary-reactive-scope-with-early-return.js | 8 +- .../repro-non-identifier-object-keys.ts | 10 +- .../fixtures/compiler/repro-object-pattern.js | 6 +- ...ds-undefined-try-catch-return-primitive.js | 4 +- .../compiler/repro-ref-mutable-range.tsx | 4 +- .../repro-renaming-conflicting-decls.js | 9 +- .../repro-retain-source-when-bailout.js | 4 +- .../repro-scope-missing-mutable-range.js | 2 +- .../repro-separate-scopes-for-divs.js | 20 +- .../repro-slow-validate-preserve-memo.ts | 14 +- ...ed-expression-of-jsxexpressioncontainer.js | 12 +- ...-call-merge-overlapping-reactive-scopes.js | 14 +- ...nreachable-code-early-return-in-useMemo.js | 26 +- .../src/__tests__/fixtures/compiler/repro.js | 4 +- ...esolve-react-hooks-based-on-import-name.js | 4 +- .../compiler/rest-param-with-array-pattern.js | 2 +- .../compiler/rest-param-with-identifier.js | 2 +- .../rest-param-with-object-spread-pattern.js | 4 +- .../fixtures/compiler/return-conditional.js | 4 +- .../fixtures/compiler/return-undefined.js | 4 +- .../fixtures/compiler/reverse-postorder.js | 4 +- .../allow-locals-named-like-hooks.js | 2 +- .../allow-props-named-like-hooks.js | 6 +- .../error.bail.rules-of-hooks-8503ca76d6f8.js | 2 +- ...onditionally-call-local-named-like-hook.js | 2 +- ...conditionally-call-prop-named-like-hook.js | 2 +- ...y-methodcall-hooklike-property-of-local.js | 2 +- ...ionally-call-hooklike-property-of-local.js | 2 +- .../error.invalid-hook-as-prop.js | 2 +- .../error.invalid-hook-from-hook-return.js | 2 +- ...nvalid-hook-from-property-of-other-hook.js | 2 +- ...d-function-expression-object-expression.js | 2 +- ...or.invalid-hook-in-nested-object-method.js | 2 +- .../error.invalid-hook-optional-methodcall.js | 2 +- .../error.invalid-hook-optional-property.js | 2 +- .../error.invalid-hook-optionalcall.js | 2 +- ...ror.invalid-rules-of-hooks-9718e30b856c.js | 4 +- ...ror.invalid-rules-of-hooks-f3d6c5e9c83d.js | 4 +- ...ror.invalid-rules-of-hooks-f69800950ff0.js | 2 +- .../rules-of-hooks-0592bd574811.js | 2 +- .../rules-of-hooks-0e2214abc294.js | 2 +- .../rules-of-hooks-69521d94fa03.js | 2 +- .../todo.bail.rules-of-hooks-28a78701970c.js | 2 +- ...lid.invalid-rules-of-hooks-28a7111f56a7.js | 4 +- ...iable-as-dep-and-redeclare-maybe-frozen.js | 4 +- .../same-variable-as-dep-and-redeclare.js | 4 +- ...turing-assignment-to-scope-declarations.js | 12 +- ...-both-mixed-local-and-scope-declaration.js | 12 +- ...onstant-progagatable-if-test-conditions.js | 8 +- ...out-without-compilation-annotation-mode.js | 6 +- ...-bailout-without-compilation-infer-mode.js | 4 +- .../fixtures/compiler/simple-scope.js | 4 +- .../fixtures/compiler/skip-useMemoCache.js | 4 +- .../fixtures/compiler/ssa-arrayexpression.js | 4 +- .../compiler/ssa-cascading-eliminated-phis.js | 4 +- .../__tests__/fixtures/compiler/ssa-for-of.js | 4 +- .../fixtures/compiler/ssa-multiple-phis.js | 4 +- .../compiler/ssa-nested-loops-no-reassign.js | 4 +- .../compiler/ssa-nested-partial-phi.js | 4 +- .../ssa-nested-partial-reassignment.js | 4 +- .../compiler/ssa-non-empty-initializer.js | 4 +- .../compiler/ssa-objectexpression-phi.js | 2 +- .../fixtures/compiler/ssa-objectexpression.js | 6 +- .../compiler/ssa-property-alias-if.js | 4 +- .../fixtures/compiler/ssa-property-call.js | 2 +- .../fixtures/compiler/ssa-reassign.js | 4 +- ...aming-ternary-destruction-with-mutation.js | 2 +- .../ssa-renaming-ternary-destruction.js | 6 +- .../fixtures/compiler/ssa-renaming-ternary.js | 4 +- ...ing-unconditional-ternary-with-mutation.js | 10 +- .../ssa-renaming-unconditional-ternary.js | 4 +- ...enaming-via-destructuring-with-mutation.js | 6 +- .../ssa-renaming-via-destructuring.js | 10 +- .../fixtures/compiler/ssa-renaming.js | 4 +- .../fixtures/compiler/ssa-shadowing.js | 6 +- .../fixtures/compiler/ssa-sibling-phis.js | 4 +- .../compiler/switch-with-fallthrough.js | 4 +- .../compiler/switch-with-only-default.js | 6 +- .../compiler/ternary-assignment-expression.js | 4 +- .../fixtures/compiler/ternary-expression.js | 4 +- ...-expression-captures-value-later-frozen.js | 2 +- .../todo.error.object-pattern-computed-key.js | 6 +- ...ction-reassign-local-variable-in-effect.js | 14 +- .../todo.unnecessary-lambda-memoization.js | 2 +- .../compiler/transitive-freeze-array.js | 2 +- .../transitive-freeze-function-expressions.js | 4 +- .../__tests__/fixtures/compiler/trivial.js | 4 +- .../compiler/try-catch-alias-try-values.js | 2 +- .../fixtures/compiler/try-catch-empty-try.js | 2 +- .../compiler/try-catch-in-nested-scope.ts | 20 +- .../compiler/try-catch-mutate-outer-value.js | 8 +- .../try-catch-try-immediately-returns.js | 2 +- ...ately-throws-after-constant-propagation.js | 2 +- ...ch-try-value-modified-in-catch-escaping.js | 4 +- .../try-catch-try-value-modified-in-catch.js | 4 +- .../compiler/try-catch-with-catch-param.js | 2 +- .../compiler/try-catch-with-return.js | 2 +- ...unction-expression-returns-caught-value.js | 4 +- .../try-catch-within-mutable-range.js | 4 +- ...thin-object-method-returns-caught-value.js | 4 +- .../__tests__/fixtures/compiler/try-catch.js | 4 +- .../compiler/type-alias-declaration.ts | 6 +- .../compiler/type-alias-used-as-annotation.ts | 2 +- .../type-alias-used-as-variable-annotation.ts | 4 +- .../todo_type-annotations-props.ts | 2 +- .../type-annotation-as-array.ts | 4 +- .../type-annotation-as-number.ts | 6 +- .../type-annotation-var-array.ts | 4 +- .../type-args-test-binary-operator.js | 4 +- .../fixtures/compiler/type-field-load.js | 2 +- .../type-test-field-load-binary-op.js | 2 +- .../__tests__/fixtures/compiler/unary-expr.js | 8 +- .../compiler/unconditional-break-label.js | 4 +- .../unlabeled-break-within-label-switch.ts | 2 +- ...tive-dependency-is-pruned-as-dependency.js | 4 +- .../compiler/unused-array-middle-element.js | 4 +- .../compiler/unused-array-rest-element.js | 4 +- .../fixtures/compiler/unused-conditional.js | 4 +- .../fixtures/compiler/unused-logical.js | 4 +- .../unused-object-element-with-rest.js | 6 +- .../compiler/unused-object-element.js | 6 +- .../update-expression-constant-propagation.js | 2 +- .../compiler/update-expression-in-sequence.js | 2 +- ...date-expression-on-function-parameter-1.js | 4 +- ...date-expression-on-function-parameter-3.js | 4 +- .../fixtures/compiler/update-expression.ts | 6 +- .../fixtures/compiler/use-memo-simple.js | 4 +- .../compiler/use-no-forget-module-level.js | 2 +- ...forget-multiple-with-eslint-suppression.js | 8 +- .../use-no-forget-with-eslint-suppression.js | 6 +- .../compiler/use-no-memo-module-level.js | 2 +- .../fixtures/compiler/use-no-memo-simple.js | 4 +- .../compiler/use-operator-call-expression.js | 24 +- .../compiler/use-operator-conditional.js | 22 +- .../compiler/use-operator-method-call.js | 26 +- ...ate-dispatch-considered-as-non-reactive.js | 2 +- ...mutable-value-dont-preserve-memoization.js | 4 +- ...aybe-mutable-value-preserve-memoization.js | 4 +- ...ble-dont-preserve-memoization-guarantee.js | 11 +- ...variable-preserve-memoization-guarantee.js | 11 +- ...modifying-same-ref-preserve-memoization.js | 6 +- ...sted-property-dont-preserve-memoization.js | 6 +- ...ef-nested-property-preserve-memoization.js | 6 +- .../useCallback-set-ref-nested-property.js | 6 +- ...set-ref-value-dont-preserve-memoization.js | 4 +- ...back-set-ref-value-preserve-memoization.js | 4 +- ...ontext-maybe-mutate-context-in-callback.js | 10 +- ...t-read-context-in-callback-if-condition.js | 6 +- .../useContext-read-context-in-callback.js | 6 +- .../compiler/useEffect-arg-memoized.js | 2 +- .../compiler/useEffect-external-mutate.js | 4 +- .../compiler/useEffect-global-pruned.js | 2 +- .../compiler/useEffect-namespace-pruned.js | 2 +- .../compiler/useEffect-nested-lambdas.js | 2 +- .../fixtures/compiler/useEffect-snap-test.js | 6 +- .../compiler/useMemo-inlining-block-return.js | 6 +- .../fixtures/compiler/useMemo-inverted-if.js | 4 +- ...-labeled-statement-unconditional-return.js | 4 +- .../fixtures/compiler/useMemo-logical.js | 4 +- ...le-dont-preserve-memoization-guarantees.js | 11 +- ...ariable-preserve-memoization-guarantees.js | 11 +- ...er-dont-preserve-memoization-guarantees.js | 4 +- ...d-later-preserve-memoization-guarantees.js | 4 +- .../compiler/useMemo-multiple-if-else.js | 4 +- .../compiler/useMemo-named-function.ts | 4 +- .../fixtures/compiler/useMemo-nested-ifs.js | 4 +- .../useMemo-simple-preserved-nomemo.js | 6 +- .../compiler/useMemo-simple-preserved.js | 6 +- .../compiler/useMemo-switch-no-fallthrough.js | 6 +- .../compiler/useMemo-switch-return.js | 12 +- ...cer-returned-dispatcher-is-non-reactive.js | 2 +- ...tate-and-other-hook-unpruned-dependency.js | 4 +- ...seState-pruned-dependency-change-detect.js | 2 +- .../compiler/useState-unpruned-dependency.js | 4 +- .../compiler/userspace-use-memo-cache.js | 3 +- ...ed-function-with-mutable-range-is-valid.js | 8 +- ...ambda-which-conditionally-sets-state-ok.js | 4 +- .../value-block-mutates-outer-value.ts | 8 +- .../fixtures/compiler/while-break.js | 4 +- .../compiler/while-conditional-continue.js | 4 +- .../fixtures/compiler/while-logical.js | 4 +- .../fixtures/compiler/while-property.js | 4 +- .../src/__tests__/parseConfigPragma-test.ts | 8 +- .../test-utils/validateNoUseBeforeDefine.ts | 24 +- .../babel-plugin-react-compiler/src/index.ts | 12 +- .../__tests__/ReactCompilerRule-test.ts | 38 +- .../ReactCompilerRuleTypescript-test.ts | 24 +- .../babel.config.js | 8 +- .../rollup.config.js | 38 +- .../eslint-plugin-react-compiler/src/index.ts | 4 +- .../src/rules/ReactCompilerRule.ts | 72 +- .../make-read-only-util/jest.config.js | 4 +- .../src/__tests__/makeReadOnly-test.ts | 136 +- .../make-read-only-util/src/makeReadOnly.ts | 48 +- .../rollup.config.js | 48 +- .../src/checks/libraryCompat.ts | 4 +- .../src/checks/reactCompiler.ts | 48 +- .../src/checks/strictMode.ts | 6 +- .../react-compiler-healthcheck/src/config.ts | 2 +- .../react-compiler-healthcheck/src/index.ts | 42 +- .../react-compiler-runtime/rollup.config.js | 30 +- .../react-compiler-runtime/src/index.ts | 136 +- .../packages/snap/src/SproutTodoFilter.ts | 898 ++++----- compiler/packages/snap/src/compiler.ts | 240 ++- compiler/packages/snap/src/constants.ts | 34 +- compiler/packages/snap/src/fixture-utils.ts | 76 +- compiler/packages/snap/src/main.ts | 28 +- compiler/packages/snap/src/reporter.ts | 70 +- compiler/packages/snap/src/runner-watch.ts | 72 +- compiler/packages/snap/src/runner-worker.ts | 52 +- compiler/packages/snap/src/runner.ts | 112 +- .../packages/snap/src/sprout/evaluator.ts | 100 +- compiler/packages/snap/src/sprout/index.ts | 32 +- .../snap/src/sprout/shared-runtime.ts | 64 +- compiler/scripts/copyright.js | 28 +- compiler/scripts/release/prompt-for-otp.js | 6 +- compiler/scripts/release/publish-manual.js | 90 +- compiler/scripts/update-commit-message.js | 52 +- 1043 files changed, 9890 insertions(+), 10017 deletions(-) diff --git a/compiler/apps/playground/__tests__/e2e/page.spec.ts b/compiler/apps/playground/__tests__/e2e/page.spec.ts index 3bb6637f95419..bc93352a0992a 100644 --- a/compiler/apps/playground/__tests__/e2e/page.spec.ts +++ b/compiler/apps/playground/__tests__/e2e/page.spec.ts @@ -5,8 +5,8 @@ * LICENSE file in the root directory of this source tree. */ -import { expect, test } from "@playwright/test"; -import { encodeStore, type Store } from "../../lib/stores"; +import {expect, test} from '@playwright/test'; +import {encodeStore, type Store} from '../../lib/stores'; const STORE: Store = { source: `export default function TestComponent({ x }) { @@ -17,33 +17,33 @@ const STORE: Store = { const HASH = encodeStore(STORE); function concat(data: Array): string { - return data.join(""); + return data.join(''); } -test("editor should compile successfully", async ({ page }) => { - await page.goto(`/#${HASH}`, { waitUntil: "networkidle" }); +test('editor should compile successfully', async ({page}) => { + await page.goto(`/#${HASH}`, {waitUntil: 'networkidle'}); await page.screenshot({ fullPage: true, - path: "test-results/00-on-networkidle.png", + path: 'test-results/00-on-networkidle.png', }); // User input from hash compiles await page.screenshot({ fullPage: true, - path: "test-results/01-show-js-before.png", + path: 'test-results/01-show-js-before.png', }); const userInput = - (await page.locator(".monaco-editor").nth(2).allInnerTexts()) ?? []; - expect(concat(userInput)).toMatchSnapshot("user-input.txt"); + (await page.locator('.monaco-editor').nth(2).allInnerTexts()) ?? []; + expect(concat(userInput)).toMatchSnapshot('user-input.txt'); // Reset button works - page.on("dialog", (dialog) => dialog.accept()); - await page.getByRole("button", { name: "Reset" }).click(); + page.on('dialog', dialog => dialog.accept()); + await page.getByRole('button', {name: 'Reset'}).click(); await page.screenshot({ fullPage: true, - path: "test-results/02-show-js-after.png", + path: 'test-results/02-show-js-after.png', }); const defaultInput = - (await page.locator(".monaco-editor").nth(2).allInnerTexts()) ?? []; - expect(concat(defaultInput)).toMatchSnapshot("default-input.txt"); + (await page.locator('.monaco-editor').nth(2).allInnerTexts()) ?? []; + expect(concat(defaultInput)).toMatchSnapshot('default-input.txt'); }); diff --git a/compiler/apps/playground/app/index.tsx b/compiler/apps/playground/app/index.tsx index 75411cd36ef8d..3bbf2e9b5558c 100644 --- a/compiler/apps/playground/app/index.tsx +++ b/compiler/apps/playground/app/index.tsx @@ -5,25 +5,24 @@ * LICENSE file in the root directory of this source tree. */ -import type { NextPage } from "next"; -import Head from "next/head"; -import { SnackbarProvider } from "notistack"; -import { Editor, Header, StoreProvider } from "../components"; -import MessageSnackbar from "../components/Message"; +import type {NextPage} from 'next'; +import Head from 'next/head'; +import {SnackbarProvider} from 'notistack'; +import {Editor, Header, StoreProvider} from '../components'; +import MessageSnackbar from '../components/Message'; const Home: NextPage = () => { return (
- {process.env.NODE_ENV === "development" - ? "[DEV] React Compiler Playground" - : "React Compiler Playground"} + {process.env.NODE_ENV === 'development' + ? '[DEV] React Compiler Playground' + : 'React Compiler Playground'} + content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=0"> { + Components={{message: MessageSnackbar}}>
diff --git a/compiler/apps/playground/app/layout.tsx b/compiler/apps/playground/app/layout.tsx index be0d04e932d90..3e888ae955a89 100644 --- a/compiler/apps/playground/app/layout.tsx +++ b/compiler/apps/playground/app/layout.tsx @@ -5,26 +5,21 @@ * LICENSE file in the root directory of this source tree. */ -import "../styles/globals.css"; +import '../styles/globals.css'; -export default function RootLayout({ - children, -}: { - children: React.ReactNode; -}) { - "use no memo"; +export default function RootLayout({children}: {children: React.ReactNode}) { + 'use no memo'; return ( - {process.env.NODE_ENV === "development" - ? "[DEV] React Compiler Playground" - : "React Compiler Playground"} + {process.env.NODE_ENV === 'development' + ? '[DEV] React Compiler Playground' + : 'React Compiler Playground'} + content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=0"> + Components={{message: MessageSnackbar}}>
diff --git a/compiler/apps/playground/babel.config.js b/compiler/apps/playground/babel.config.js index 900b52dd3028c..0edf2e9b72d70 100644 --- a/compiler/apps/playground/babel.config.js +++ b/compiler/apps/playground/babel.config.js @@ -8,12 +8,12 @@ module.exports = function (api) { api.cache(true); return { - presets: ["next/babel"], + presets: ['next/babel'], plugins: [ [ - "babel-plugin-react-compiler", + 'babel-plugin-react-compiler', { - runtimeModule: "react-compiler-runtime", + runtimeModule: 'react-compiler-runtime', }, ], ], diff --git a/compiler/apps/playground/colors.js b/compiler/apps/playground/colors.js index 7259e1f32bc8f..bd5f1426f5ed7 100644 --- a/compiler/apps/playground/colors.js +++ b/compiler/apps/playground/colors.js @@ -11,86 +11,86 @@ module.exports = { // Text colors - primary: "#23272F", // gray-90 - "primary-dark": "#F6F7F9", // gray-5 - secondary: "#404756", // gray-70 - "secondary-dark": "#EBECF0", // gray-10 - link: "#087EA4", // blue-50 - "link-dark": "#149ECA", // blue-40 - syntax: "#EBECF0", // gray-10 - wash: "#FFFFFF", - "wash-dark": "#23272F", // gray-90 - card: "#F6F7F9", // gray-05 - "card-dark": "#343A46", // gray-80 - highlight: "#E6F7FF", // blue-10 - "highlight-dark": "rgba(88,175,223,.1)", - border: "#EBECF0", // gray-10 - "border-dark": "#343A46", // gray-80 - "secondary-button": "#EBECF0", // gray-10 - "secondary-button-dark": "#404756", // gray-70 + primary: '#23272F', // gray-90 + 'primary-dark': '#F6F7F9', // gray-5 + secondary: '#404756', // gray-70 + 'secondary-dark': '#EBECF0', // gray-10 + link: '#087EA4', // blue-50 + 'link-dark': '#149ECA', // blue-40 + syntax: '#EBECF0', // gray-10 + wash: '#FFFFFF', + 'wash-dark': '#23272F', // gray-90 + card: '#F6F7F9', // gray-05 + 'card-dark': '#343A46', // gray-80 + highlight: '#E6F7FF', // blue-10 + 'highlight-dark': 'rgba(88,175,223,.1)', + border: '#EBECF0', // gray-10 + 'border-dark': '#343A46', // gray-80 + 'secondary-button': '#EBECF0', // gray-10 + 'secondary-button-dark': '#404756', // gray-70 // Gray - "gray-95": "#16181D", - "gray-90": "#23272F", - "gray-80": "#343A46", - "gray-70": "#404756", - "gray-60": "#4E5769", - "gray-50": "#5E687E", // unused - "gray-40": "#78839B", - "gray-30": "#99A1B3", - "gray-20": "#BCC1CD", - "gray-10": "#EBECF0", - "gray-5": "#F6F7F9", + 'gray-95': '#16181D', + 'gray-90': '#23272F', + 'gray-80': '#343A46', + 'gray-70': '#404756', + 'gray-60': '#4E5769', + 'gray-50': '#5E687E', // unused + 'gray-40': '#78839B', + 'gray-30': '#99A1B3', + 'gray-20': '#BCC1CD', + 'gray-10': '#EBECF0', + 'gray-5': '#F6F7F9', // Blue - "blue-60": "#045975", - "blue-50": "#087EA4", - "blue-40": "#149ECA", // Brand Blue - "blue-30": "#58C4DC", // unused - "blue-20": "#ABE2ED", - "blue-10": "#E6F7FF", // todo: doesn't match illustrations - "blue-5": "#E6F6FA", + 'blue-60': '#045975', + 'blue-50': '#087EA4', + 'blue-40': '#149ECA', // Brand Blue + 'blue-30': '#58C4DC', // unused + 'blue-20': '#ABE2ED', + 'blue-10': '#E6F7FF', // todo: doesn't match illustrations + 'blue-5': '#E6F6FA', // Yellow - "yellow-60": "#B65700", - "yellow-50": "#C76A15", - "yellow-40": "#DB7D27", // unused - "yellow-30": "#FABD62", // unused - "yellow-20": "#FCDEB0", // unused - "yellow-10": "#FDE7C7", - "yellow-5": "#FEF5E7", + 'yellow-60': '#B65700', + 'yellow-50': '#C76A15', + 'yellow-40': '#DB7D27', // unused + 'yellow-30': '#FABD62', // unused + 'yellow-20': '#FCDEB0', // unused + 'yellow-10': '#FDE7C7', + 'yellow-5': '#FEF5E7', // Purple - "purple-60": "#2B3491", // unused - "purple-50": "#575FB7", - "purple-40": "#6B75DB", - "purple-30": "#8891EC", - "purple-20": "#C3C8F5", // unused - "purple-10": "#E7E9FB", - "purple-5": "#F3F4FD", + 'purple-60': '#2B3491', // unused + 'purple-50': '#575FB7', + 'purple-40': '#6B75DB', + 'purple-30': '#8891EC', + 'purple-20': '#C3C8F5', // unused + 'purple-10': '#E7E9FB', + 'purple-5': '#F3F4FD', // Green - "green-60": "#2B6E62", - "green-50": "#388F7F", - "green-40": "#44AC99", - "green-30": "#7FCCBF", - "green-20": "#ABDED5", - "green-10": "#E5F5F2", - "green-5": "#F4FBF9", + 'green-60': '#2B6E62', + 'green-50': '#388F7F', + 'green-40': '#44AC99', + 'green-30': '#7FCCBF', + 'green-20': '#ABDED5', + 'green-10': '#E5F5F2', + 'green-5': '#F4FBF9', // RED - "red-60": "#712D28", - "red-50": "#A6423A", // unused - "red-40": "#C1554D", - "red-30": "#D07D77", - "red-20": "#E5B7B3", // unused - "red-10": "#F2DBD9", // unused - "red-5": "#FAF1F0", + 'red-60': '#712D28', + 'red-50': '#A6423A', // unused + 'red-40': '#C1554D', + 'red-30': '#D07D77', + 'red-20': '#E5B7B3', // unused + 'red-10': '#F2DBD9', // unused + 'red-5': '#FAF1F0', // MISC - "code-block": "#99a1b30f", // gray-30 @ 6% - "gradient-blue": "#58C4DC", // Only used for the landing gradient for now. + 'code-block': '#99a1b30f', // gray-30 @ 6% + 'gradient-blue': '#58C4DC', // Only used for the landing gradient for now. github: { - highlight: "#fffbdd", + highlight: '#fffbdd', }, }; diff --git a/compiler/apps/playground/components/Editor/EditorImpl.tsx b/compiler/apps/playground/components/Editor/EditorImpl.tsx index 312492b48c3c1..9fe9be08d0ec9 100644 --- a/compiler/apps/playground/components/Editor/EditorImpl.tsx +++ b/compiler/apps/playground/components/Editor/EditorImpl.tsx @@ -5,10 +5,10 @@ * LICENSE file in the root directory of this source tree. */ -import { parse as babelParse, ParserPlugin } from "@babel/parser"; -import * as HermesParser from "hermes-parser"; -import traverse, { NodePath } from "@babel/traverse"; -import * as t from "@babel/types"; +import {parse as babelParse, ParserPlugin} from '@babel/parser'; +import * as HermesParser from 'hermes-parser'; +import traverse, {NodePath} from '@babel/traverse'; +import * as t from '@babel/types'; import { CompilerError, CompilerErrorDetail, @@ -20,49 +20,49 @@ import { run, ValueKind, type Hook, -} from "babel-plugin-react-compiler/src"; -import { type ReactFunctionType } from "babel-plugin-react-compiler/src/HIR/Environment"; -import clsx from "clsx"; -import invariant from "invariant"; -import { useSnackbar } from "notistack"; -import { useDeferredValue, useMemo } from "react"; -import { useMountEffect } from "../../hooks"; -import { defaultStore } from "../../lib/defaultStore"; +} from 'babel-plugin-react-compiler/src'; +import {type ReactFunctionType} from 'babel-plugin-react-compiler/src/HIR/Environment'; +import clsx from 'clsx'; +import invariant from 'invariant'; +import {useSnackbar} from 'notistack'; +import {useDeferredValue, useMemo} from 'react'; +import {useMountEffect} from '../../hooks'; +import {defaultStore} from '../../lib/defaultStore'; import { createMessage, initStoreFromUrlOrLocalStorage, MessageLevel, MessageSource, type Store, -} from "../../lib/stores"; -import { useStore, useStoreDispatch } from "../StoreContext"; -import Input from "./Input"; +} from '../../lib/stores'; +import {useStore, useStoreDispatch} from '../StoreContext'; +import Input from './Input'; import { CompilerOutput, default as Output, PrintedCompilerPipelineValue, -} from "./Output"; +} from './Output'; -function parseInput(input: string, language: "flow" | "typescript") { +function parseInput(input: string, language: 'flow' | 'typescript') { // Extract the first line to quickly check for custom test directives - if (language === "flow") { + if (language === 'flow') { return HermesParser.parse(input, { babel: true, - flow: "all", - sourceType: "module", + flow: 'all', + sourceType: 'module', enableExperimentalComponentSyntax: true, }); } else { return babelParse(input, { - plugins: ["typescript", "jsx"], - sourceType: "module", + plugins: ['typescript', 'jsx'], + sourceType: 'module', }); } } function parseFunctions( source: string, - language: "flow" | "typescript" + language: 'flow' | 'typescript', ): Array< NodePath< t.FunctionDeclaration | t.ArrowFunctionExpression | t.FunctionExpression @@ -103,7 +103,7 @@ function parseFunctions( const COMMON_HOOKS: Array<[string, Hook]> = [ [ - "useFragment", + 'useFragment', { valueKind: ValueKind.Frozen, effectKind: Effect.Freeze, @@ -112,7 +112,7 @@ const COMMON_HOOKS: Array<[string, Hook]> = [ }, ], [ - "usePaginationFragment", + 'usePaginationFragment', { valueKind: ValueKind.Frozen, effectKind: Effect.Freeze, @@ -121,7 +121,7 @@ const COMMON_HOOKS: Array<[string, Hook]> = [ }, ], [ - "useRefetchableFragment", + 'useRefetchableFragment', { valueKind: ValueKind.Frozen, effectKind: Effect.Freeze, @@ -130,7 +130,7 @@ const COMMON_HOOKS: Array<[string, Hook]> = [ }, ], [ - "useLazyLoadQuery", + 'useLazyLoadQuery', { valueKind: ValueKind.Frozen, effectKind: Effect.Freeze, @@ -139,7 +139,7 @@ const COMMON_HOOKS: Array<[string, Hook]> = [ }, ], [ - "usePreloadedQuery", + 'usePreloadedQuery', { valueKind: ValueKind.Frozen, effectKind: Effect.Freeze, @@ -154,22 +154,22 @@ function isHookName(s: string): boolean { } function getReactFunctionType( - id: NodePath + id: NodePath, ): ReactFunctionType { if (id && id.node && id.isIdentifier()) { if (isHookName(id.node.name)) { - return "Hook"; + return 'Hook'; } const isPascalCaseNameSpace = /^[A-Z].*/; if (isPascalCaseNameSpace.test(id.node.name)) { - return "Component"; + return 'Component'; } } - return "Other"; + return 'Other'; } -function compile(source: string): [CompilerOutput, "flow" | "typescript"] { +function compile(source: string): [CompilerOutput, 'flow' | 'typescript'] { const results = new Map(); const error = new CompilerError(); const upsert = (result: PrintedCompilerPipelineValue) => { @@ -180,15 +180,15 @@ function compile(source: string): [CompilerOutput, "flow" | "typescript"] { results.set(result.name, [result]); } }; - let language: "flow" | "typescript"; + let language: 'flow' | 'typescript'; if (source.match(/\@flow/)) { - language = "flow"; + language = 'flow'; } else { - language = "typescript"; + language = 'typescript'; } try { // Extract the first line to quickly check for custom test directives - const pragma = source.substring(0, source.indexOf("\n")); + const pragma = source.substring(0, source.indexOf('\n')); const config = parseConfigPragma(pragma); for (const fn of parseFunctions(source, language)) { @@ -197,16 +197,16 @@ function compile(source: string): [CompilerOutput, "flow" | "typescript"] { new CompilerErrorDetail({ reason: `Unexpected function type ${fn.node.type}`, description: - "Playground only supports parsing function declarations", + 'Playground only supports parsing function declarations', severity: ErrorSeverity.Todo, loc: fn.node.loc ?? null, suggestions: null, - }) + }), ); continue; } - const id = fn.get("id"); + const id = fn.get('id'); for (const result of run( fn, { @@ -214,20 +214,20 @@ function compile(source: string): [CompilerOutput, "flow" | "typescript"] { customHooks: new Map([...COMMON_HOOKS]), }, getReactFunctionType(id), - "_c", + '_c', + null, null, null, - null )) { const fnName = fn.node.id?.name ?? null; switch (result.kind) { - case "ast": { + case 'ast': { upsert({ - kind: "ast", + kind: 'ast', fnName, name: result.name, value: { - type: "FunctionDeclaration", + type: 'FunctionDeclaration', id: result.value.id, async: result.value.async, generator: result.value.generator, @@ -237,27 +237,27 @@ function compile(source: string): [CompilerOutput, "flow" | "typescript"] { }); break; } - case "hir": { + case 'hir': { upsert({ - kind: "hir", + kind: 'hir', fnName, name: result.name, value: printHIR(result.value.body), }); break; } - case "reactive": { + case 'reactive': { upsert({ - kind: "reactive", + kind: 'reactive', fnName, name: result.name, value: printReactiveFunction(result.value), }); break; } - case "debug": { + case 'debug': { upsert({ - kind: "debug", + kind: 'debug', fnName, name: result.name, value: result.value, @@ -286,24 +286,24 @@ function compile(source: string): [CompilerOutput, "flow" | "typescript"] { reason: `Unexpected failure when transforming input! ${err}`, loc: null, suggestions: null, - }) + }), ); } } if (error.hasErrors()) { - return [{ kind: "err", results, error: error }, language]; + return [{kind: 'err', results, error: error}, language]; } - return [{ kind: "ok", results }, language]; + return [{kind: 'ok', results}, language]; } export default function Editor() { const store = useStore(); const deferredStore = useDeferredValue(store); const dispatchStore = useStoreDispatch(); - const { enqueueSnackbar } = useSnackbar(); + const {enqueueSnackbar} = useSnackbar(); const [compilerOutput, language] = useMemo( () => compile(deferredStore.source), - [deferredStore.source] + [deferredStore.source], ); useMountEffect(() => { @@ -311,35 +311,35 @@ export default function Editor() { try { mountStore = initStoreFromUrlOrLocalStorage(); } catch (e) { - invariant(e instanceof Error, "Only Error may be caught."); + invariant(e instanceof Error, 'Only Error may be caught.'); enqueueSnackbar(e.message, { - variant: "message", + variant: 'message', ...createMessage( - "Bad URL - fell back to the default Playground.", + 'Bad URL - fell back to the default Playground.', MessageLevel.Info, - MessageSource.Playground + MessageSource.Playground, ), }); mountStore = defaultStore; } dispatchStore({ - type: "setStore", - payload: { store: mountStore }, + type: 'setStore', + payload: {store: mountStore}, }); }); return ( <>
-
+
-
+
diff --git a/compiler/apps/playground/components/Editor/Input.tsx b/compiler/apps/playground/components/Editor/Input.tsx index 219f13ba239f8..c2ce8efc70d3f 100644 --- a/compiler/apps/playground/components/Editor/Input.tsx +++ b/compiler/apps/playground/components/Editor/Input.tsx @@ -5,28 +5,28 @@ * LICENSE file in the root directory of this source tree. */ -import MonacoEditor, { loader, type Monaco } from "@monaco-editor/react"; -import { CompilerErrorDetail } from "babel-plugin-react-compiler/src"; -import invariant from "invariant"; -import type { editor } from "monaco-editor"; -import * as monaco from "monaco-editor"; -import { Resizable } from "re-resizable"; -import { useEffect, useState } from "react"; -import { renderReactCompilerMarkers } from "../../lib/reactCompilerMonacoDiagnostics"; -import { useStore, useStoreDispatch } from "../StoreContext"; -import { monacoOptions } from "./monacoOptions"; +import MonacoEditor, {loader, type Monaco} from '@monaco-editor/react'; +import {CompilerErrorDetail} from 'babel-plugin-react-compiler/src'; +import invariant from 'invariant'; +import type {editor} from 'monaco-editor'; +import * as monaco from 'monaco-editor'; +import {Resizable} from 're-resizable'; +import {useEffect, useState} from 'react'; +import {renderReactCompilerMarkers} from '../../lib/reactCompilerMonacoDiagnostics'; +import {useStore, useStoreDispatch} from '../StoreContext'; +import {monacoOptions} from './monacoOptions'; // TODO: Make TS recognize .d.ts files, in addition to loading them with webpack. // @ts-ignore -import React$Types from "../../node_modules/@types/react/index.d.ts"; +import React$Types from '../../node_modules/@types/react/index.d.ts'; -loader.config({ monaco }); +loader.config({monaco}); type Props = { errors: CompilerErrorDetail[]; - language: "flow" | "typescript"; + language: 'flow' | 'typescript'; }; -export default function Input({ errors, language }: Props) { +export default function Input({errors, language}: Props) { const [monaco, setMonaco] = useState(null); const store = useStore(); const dispatchStore = useStoreDispatch(); @@ -36,11 +36,11 @@ export default function Input({ errors, language }: Props) { if (!monaco) return; const uri = monaco.Uri.parse(`file:///index.js`); const model = monaco.editor.getModel(uri); - invariant(model, "Model must exist for the selected input file."); - renderReactCompilerMarkers({ monaco, model, details: errors }); + invariant(model, 'Model must exist for the selected input file.'); + renderReactCompilerMarkers({monaco, model, details: errors}); // N.B. that `tabSize` is a model property, not an editor property. // So, the tab size has to be set per model. - model.updateOptions({ tabSize: 2 }); + model.updateOptions({tabSize: 2}); }, [monaco, errors]); const flowDiagnosticDisable = [ @@ -64,11 +64,11 @@ export default function Input({ errors, language }: Props) { 8011, 8012, 8013, - ...(language === "flow" ? flowDiagnosticDisable : []), + ...(language === 'flow' ? flowDiagnosticDisable : []), ], noSemanticValidation: true, // Monaco can't validate Flow component syntax - noSyntaxValidation: language === "flow", + noSyntaxValidation: language === 'flow', }); }, [monaco, language]); @@ -76,7 +76,7 @@ export default function Input({ errors, language }: Props) { if (!value) return; dispatchStore({ - type: "updateFile", + type: 'updateFile', payload: { source: value, }, @@ -91,11 +91,11 @@ export default function Input({ errors, language }: Props) { target: monaco.languages.typescript.ScriptTarget.ES2015, moduleResolution: monaco.languages.typescript.ModuleResolutionKind.NodeJs, jsx: monaco.languages.typescript.JsxEmit.Preserve, - typeRoots: ["node_modules/@types"], + typeRoots: ['node_modules/@types'], allowSyntheticDefaultImports: true, }; monaco.languages.typescript.javascriptDefaults.setCompilerOptions( - tscOptions + tscOptions, ); monaco.languages.typescript.typescriptDefaults.setCompilerOptions({ ...tscOptions, @@ -106,7 +106,7 @@ export default function Input({ errors, language }: Props) { // Add React type declarations to Monaco const reactLib = [ React$Types, - "file:///node_modules/@types/react/index.d.ts", + 'file:///node_modules/@types/react/index.d.ts', ] as [any, string]; monaco.languages.typescript.javascriptDefaults.addExtraLib(...reactLib); monaco.languages.typescript.typescriptDefaults.addExtraLib(...reactLib); @@ -124,17 +124,16 @@ export default function Input({ errors, language }: Props) {
+ className="!h-[calc(100vh_-_3.5rem)]"> } + | {kind: 'ok'; results: Map} | { - kind: "err"; + kind: 'err'; results: Map; error: CompilerError; }; @@ -63,7 +63,7 @@ async function tabify(source: string, compilerOutput: CompilerOutput) { for (const [passName, results] of compilerOutput.results) { for (const result of results) { switch (result.kind) { - case "hir": { + case 'hir': { const prev = concattedResults.get(result.name); const next = result.value; const identName = `function ${result.fnName}`; @@ -74,7 +74,7 @@ async function tabify(source: string, compilerOutput: CompilerOutput) { } break; } - case "reactive": { + case 'reactive': { const prev = concattedResults.get(passName); const next = result.value; if (prev != null) { @@ -84,30 +84,29 @@ async function tabify(source: string, compilerOutput: CompilerOutput) { } break; } - case "ast": + case 'ast': topLevelFnDecls.push(result.value); break; - case "debug": { + case 'debug': { concattedResults.set(passName, result.value); break; } default: { const _: never = result; - throw new Error("Unexpected result kind"); + throw new Error('Unexpected result kind'); } } } } let lastPassOutput: string | null = null; - let nonDiffPasses = ["HIR", "BuildReactiveFunction", "EnvironmentConfig"]; + let nonDiffPasses = ['HIR', 'BuildReactiveFunction', 'EnvironmentConfig']; for (const [passName, text] of concattedResults) { tabs.set( passName, + showInfoPanel={!nonDiffPasses.includes(passName)}>, ); lastPassOutput = text; } @@ -116,25 +115,24 @@ async function tabify(source: string, compilerOutput: CompilerOutput) { // Make a synthetic Program so we can have a single AST with all the top level // FunctionDeclarations const ast = t.program(topLevelFnDecls); - const { code, sourceMapUrl } = await codegen(ast, source); + const {code, sourceMapUrl} = await codegen(ast, source); reorderedTabs.set( - "JS", + 'JS', + showInfoPanel={false}>, ); if (sourceMapUrl) { reorderedTabs.set( - "SourceMap", + 'SourceMap', <>