Skip to content

Commit

Permalink
Warn if outdated JSX transform is detected (#28781)
Browse files Browse the repository at this point in the history
We want to warn if we detect that an app is using an outdated JSX
transform. We can't just warn if `createElement` is called because we
still support `createElement` when it's called manually. We only want to
warn if `createElement` is output by the compiler.

The heuristic is to check for a `__self` prop, which is an optional,
internal prop that older transforms used to pass to `createElement` for
better debugging in development mode.

If `__self` is present, we `console.warn` once with advice to upgrade to
the modern JSX transform. Subsequent elements will not warn.

There's a special case we have to account for: when a static "key" prop
is defined _after_ a spread, the modern JSX transform outputs
`createElement` instead of `jsx`. (This is because with `jsx`, a spread
key always takes precedence over a static key, regardless of the order,
whereas `createElement` respects the order.) To avoid a false positive
warning, we skip the warning whenever a `key` prop is present.

DiffTrain build for [ed3c65c](ed3c65c)
  • Loading branch information
acdlite committed Apr 9, 2024
1 parent 442049b commit 7ea7a3b
Show file tree
Hide file tree
Showing 5 changed files with 71 additions and 4 deletions.
2 changes: 1 addition & 1 deletion compiled/facebook-www/REVISION
Original file line number Diff line number Diff line change
@@ -1 +1 @@
3f9e237a2feb74f1fca23b76d9d2e9e1713e2ba1
ed3c65caf042f75fe2fdc2a5e568a9624c6175fb
24 changes: 23 additions & 1 deletion compiled/facebook-www/React-dev.classic.js
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ if (__DEV__) {
) {
__REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStart(new Error());
}
var ReactVersion = "19.0.0-www-classic-8d3386cf";
var ReactVersion = "19.0.0-www-classic-e2f5fe42";

// ATTENTION
// When adding new symbols to this file,
Expand Down Expand Up @@ -1292,6 +1292,7 @@ if (__DEV__) {
var specialPropRefWarningShown;
var didWarnAboutStringRefs;
var didWarnAboutElementRef;
var didWarnAboutOldJSXRuntime;

{
didWarnAboutStringRefs = {};
Expand Down Expand Up @@ -1894,6 +1895,27 @@ if (__DEV__) {
var ref = null;

if (config != null) {
{
if (
!didWarnAboutOldJSXRuntime &&
"__self" in config && // Do not assume this is the result of an oudated JSX transform if key
// is present, because the modern JSX transform sometimes outputs
// createElement to preserve precedence between a static key and a
// spread key. To avoid false positive warnings, we never warn if
// there's a key.
!("key" in config)
) {
didWarnAboutOldJSXRuntime = true;

warn(
"Your app (or one of its dependencies) is using an outdated JSX " +
"transform. Update to the modern JSX transform for " +
"faster performance: " + // TODO: Create a short link for this
"https://reactjs.org/blog/2020/09/22/introducing-the-new-jsx-transform.html"
);
}
}

if (hasValidRef(config)) {
if (!enableRefAsProp) {
ref = config.ref;
Expand Down
24 changes: 23 additions & 1 deletion compiled/facebook-www/React-dev.modern.js
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ if (__DEV__) {
) {
__REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStart(new Error());
}
var ReactVersion = "19.0.0-www-modern-337e1422";
var ReactVersion = "19.0.0-www-modern-cd353aaf";

// ATTENTION
// When adding new symbols to this file,
Expand Down Expand Up @@ -1294,6 +1294,7 @@ if (__DEV__) {
var specialPropRefWarningShown;
var didWarnAboutStringRefs;
var didWarnAboutElementRef;
var didWarnAboutOldJSXRuntime;

{
didWarnAboutStringRefs = {};
Expand Down Expand Up @@ -1896,6 +1897,27 @@ if (__DEV__) {
var ref = null;

if (config != null) {
{
if (
!didWarnAboutOldJSXRuntime &&
"__self" in config && // Do not assume this is the result of an oudated JSX transform if key
// is present, because the modern JSX transform sometimes outputs
// createElement to preserve precedence between a static key and a
// spread key. To avoid false positive warnings, we never warn if
// there's a key.
!("key" in config)
) {
didWarnAboutOldJSXRuntime = true;

warn(
"Your app (or one of its dependencies) is using an outdated JSX " +
"transform. Update to the modern JSX transform for " +
"faster performance: " + // TODO: Create a short link for this
"https://reactjs.org/blog/2020/09/22/introducing-the-new-jsx-transform.html"
);
}
}

if (hasValidRef(config)) {
if (!enableRefAsProp) {
ref = config.ref;
Expand Down
24 changes: 23 additions & 1 deletion compiled/facebook-www/ReactServer-dev.modern.js
Original file line number Diff line number Diff line change
Expand Up @@ -1018,6 +1018,7 @@ if (__DEV__) {
var specialPropRefWarningShown;
var didWarnAboutStringRefs;
var didWarnAboutElementRef;
var didWarnAboutOldJSXRuntime;

{
didWarnAboutStringRefs = {};
Expand Down Expand Up @@ -1620,6 +1621,27 @@ if (__DEV__) {
var ref = null;

if (config != null) {
{
if (
!didWarnAboutOldJSXRuntime &&
"__self" in config && // Do not assume this is the result of an oudated JSX transform if key
// is present, because the modern JSX transform sometimes outputs
// createElement to preserve precedence between a static key and a
// spread key. To avoid false positive warnings, we never warn if
// there's a key.
!("key" in config)
) {
didWarnAboutOldJSXRuntime = true;

warn(
"Your app (or one of its dependencies) is using an outdated JSX " +
"transform. Update to the modern JSX transform for " +
"faster performance: " + // TODO: Create a short link for this
"https://reactjs.org/blog/2020/09/22/introducing-the-new-jsx-transform.html"
);
}
}

if (hasValidRef(config)) {
if (!enableRefAsProp) {
ref = config.ref;
Expand Down Expand Up @@ -3083,7 +3105,7 @@ if (__DEV__) {

function noop() {}

var ReactVersion = "19.0.0-www-modern-a3494f1d";
var ReactVersion = "19.0.0-www-modern-6d726a4f";

// Patch fetch
var Children = {
Expand Down
1 change: 1 addition & 0 deletions compiled/facebook-www/__test_utils__/ReactAllWarnings.js

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

0 comments on commit 7ea7a3b

Please sign in to comment.