Teach JS stack-parsing regex about alternative formats

Reviewed By: adamjernst

Differential Revision: D7706535

fbshipit-source-id: 83cc2defbcad3faa6bdbf4a5b2072b9c023e1c04
This commit is contained in:
Peter Ammon 2018-04-20 08:56:02 -07:00 committed by Facebook Github Bot
parent fc694fef66
commit 9bbe736f23

View File

@ -10,13 +10,40 @@
#import "RCTLog.h" #import "RCTLog.h"
#import "RCTUtils.h" #import "RCTUtils.h"
/**
* The RegEx used to parse Error.stack.
*
* JavaScriptCore has the following format:
*
* Exception: Error: argh
* func1@/path/to/file.js:2:18
* func2@/path/to/file.js:6:8
* eval@[native code]
* global code@/path/to/file.js:13:5
*
* Another supported format:
*
* Error: argh
* at func1 (/path/to/file.js:2:18)
* at func2 (/path/to/file.js:6:8)
* at eval (native)
* at global (/path/to/file.js:13:5)
*/
static NSRegularExpression *RCTJSStackFrameRegex() static NSRegularExpression *RCTJSStackFrameRegex()
{ {
static dispatch_once_t onceToken; static dispatch_once_t onceToken;
static NSRegularExpression *_regex; static NSRegularExpression *_regex;
dispatch_once(&onceToken, ^{ dispatch_once(&onceToken, ^{
NSString *pattern =
@"\\s*(?:at)?\\s*" // Skip leading "at" and whitespace, noncapturing
@"(.+?)" // Capture the function name (group 1)
@"\\s*[@(]" // Skip whitespace, then @ or (
@"(.*):" // Capture the file name (group 2), then colon
@"(\\d+):(\\d+)" // Line and column number (groups 3 and 4)
@"\\)?$" // Optional closing paren and EOL
;
NSError *regexError; NSError *regexError;
_regex = [NSRegularExpression regularExpressionWithPattern:@"^(?:([^@]+)@)?(.*):(\\d+):(\\d+)$" options:0 error:&regexError]; _regex = [NSRegularExpression regularExpressionWithPattern:pattern options:0 error:&regexError];
if (regexError) { if (regexError) {
RCTLogError(@"Failed to build regex: %@", [regexError localizedDescription]); RCTLogError(@"Failed to build regex: %@", [regexError localizedDescription]);
} }