// @flow import type { ReactFrame } from '../effects/proxyConsole'; function stripInlineStacktrace(message: string): string { return message.split('\n').filter(line => !line.match(/^\s*in/)).join('\n'); // " in Foo" } function massage( warning: string, frames: ReactFrame[] ): { message: string, stack: string } { let message = stripInlineStacktrace(warning); // Reassemble the stack with full filenames provided by React let stack = ''; let lastFilename; let lastLineNumber; for (let index = 0; index < frames.length; ++index) { const { fileName, lineNumber } = frames[index]; if (fileName == null || lineNumber == null) { continue; } // TODO: instead, collapse them in the UI if ( fileName === lastFilename && typeof lineNumber === 'number' && typeof lastLineNumber === 'number' && Math.abs(lineNumber - lastLineNumber) < 3 ) { continue; } lastFilename = fileName; lastLineNumber = lineNumber; let { functionName } = frames[index]; functionName = functionName || '(anonymous function)'; stack += `in ${functionName} (at ${fileName}:${lineNumber})\n`; } return { message, stack }; } export { massage };