forked from facebook/react
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add RN fork of consoleWithStackDev so we can improve the mainline one (…
…facebook#30305) We're removing this wrapper from the mainline but RN is still using component stacks to filter out warnings. This is unfortunate since it'll be hard to keep track of the interplay with these, DevTools and how you're supposed to implement error dialogs in userspace.
- Loading branch information
1 parent
2d3f81b
commit 9647333
Showing
2 changed files
with
62 additions
and
0 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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,59 @@ | ||
/** | ||
* Copyright (c) Meta Platforms, Inc. and affiliates. | ||
* | ||
* This source code is licensed under the MIT license found in the | ||
* LICENSE file in the root directory of this source tree. | ||
*/ | ||
|
||
import ReactSharedInternals from 'shared/ReactSharedInternals'; | ||
|
||
let suppressWarning = false; | ||
export function setSuppressWarning(newSuppressWarning) { | ||
if (__DEV__) { | ||
suppressWarning = newSuppressWarning; | ||
} | ||
} | ||
|
||
// In DEV, calls to console.warn and console.error get replaced | ||
// by calls to these methods by a Babel plugin. | ||
// | ||
// In PROD (or in packages without access to React internals), | ||
// they are left as they are instead. | ||
|
||
export function warn(format, ...args) { | ||
if (__DEV__) { | ||
if (!suppressWarning) { | ||
printWarning('warn', format, args, new Error('react-stack-top-frame')); | ||
} | ||
} | ||
} | ||
|
||
export function error(format, ...args) { | ||
if (__DEV__) { | ||
if (!suppressWarning) { | ||
printWarning('error', format, args, new Error('react-stack-top-frame')); | ||
} | ||
} | ||
} | ||
|
||
export let isWritingAppendedStack = false; | ||
|
||
function printWarning(level, format, args, currentStack) { | ||
if (__DEV__) { | ||
if (ReactSharedInternals.getCurrentStack) { | ||
const stack = ReactSharedInternals.getCurrentStack(currentStack); | ||
if (stack !== '') { | ||
isWritingAppendedStack = true; | ||
format += '%s'; | ||
args = args.concat([stack]); | ||
} | ||
} | ||
|
||
args.unshift(format); | ||
// We intentionally don't use spread (or .apply) directly because it | ||
// breaks IE9: https://github.com/facebook/react/issues/13610 | ||
// eslint-disable-next-line react-internal/no-production-logging | ||
Function.prototype.apply.call(console[level], console, args); | ||
isWritingAppendedStack = false; | ||
} | ||
} |
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