warnings.js 1.19 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
// @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 = '';
16
17
  let lastFilename;
  let lastLineNumber;
18
19
20
21
22
  for (let index = 0; index < frames.length; ++index) {
    const { fileName, lineNumber } = frames[index];
    if (fileName == null || lineNumber == null) {
      continue;
    }
23
24
25
26
27
28
29
30
31
32
33
34
35

    // 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;

36
37
38
39
40
41
42
43
44
    let { functionName } = frames[index];
    functionName = functionName || '(anonymous function)';
    stack += `in ${functionName} (at ${fileName}:${lineNumber})\n`;
  }

  return { message, stack };
}

export { massage };