2015-03-23 13:28:42 -07:00
|
|
|
/**
|
|
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* This source code is licensed under the BSD-style license found in the
|
|
|
|
* LICENSE file in the root directory of this source tree. An additional grant
|
|
|
|
* of patent rights can be found in the PATENTS file in the same directory.
|
|
|
|
*/
|
2015-02-19 20:10:52 -08:00
|
|
|
|
|
|
|
#import "RCTExceptionsManager.h"
|
|
|
|
|
2015-04-09 10:39:28 -07:00
|
|
|
#import "RCTLog.h"
|
2015-02-19 20:10:52 -08:00
|
|
|
#import "RCTRedBox.h"
|
2015-04-09 10:39:28 -07:00
|
|
|
#import "RCTRootView.h"
|
2015-02-19 20:10:52 -08:00
|
|
|
|
|
|
|
@implementation RCTExceptionsManager
|
2015-03-11 13:53:30 -07:00
|
|
|
{
|
|
|
|
__weak id<RCTExceptionsManagerDelegate> _delegate;
|
2015-04-09 10:39:28 -07:00
|
|
|
NSUInteger _reloadRetries;
|
2015-03-11 13:53:30 -07:00
|
|
|
}
|
|
|
|
|
2015-04-08 05:42:43 -07:00
|
|
|
RCT_EXPORT_MODULE()
|
|
|
|
|
2015-03-11 13:53:30 -07:00
|
|
|
- (instancetype)initWithDelegate:(id<RCTExceptionsManagerDelegate>)delegate
|
|
|
|
{
|
|
|
|
if ((self = [super init])) {
|
|
|
|
_delegate = delegate;
|
2015-04-09 10:39:28 -07:00
|
|
|
_maxReloadAttempts = 0;
|
2015-03-11 13:53:30 -07:00
|
|
|
}
|
|
|
|
return self;
|
|
|
|
}
|
|
|
|
|
|
|
|
- (instancetype)init
|
|
|
|
{
|
|
|
|
return [self initWithDelegate:nil];
|
|
|
|
}
|
2015-02-19 20:10:52 -08:00
|
|
|
|
2015-04-08 21:23:24 -07:00
|
|
|
RCT_EXPORT_METHOD(reportUnhandledException:(NSString *)message
|
2015-04-08 08:52:48 -07:00
|
|
|
stack:(NSArray *)stack)
|
2015-02-19 20:10:52 -08:00
|
|
|
{
|
2015-03-11 13:53:30 -07:00
|
|
|
if (_delegate) {
|
|
|
|
[_delegate unhandledJSExceptionWithMessage:message stack:stack];
|
2015-04-09 10:39:28 -07:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2015-04-19 12:55:46 -07:00
|
|
|
#if DEBUG
|
|
|
|
|
2015-04-18 10:43:20 -07:00
|
|
|
[[RCTRedBox sharedInstance] showErrorMessage:message withStack:stack];
|
2015-04-19 12:55:46 -07:00
|
|
|
|
2015-04-09 10:39:28 -07:00
|
|
|
#else
|
2015-04-19 12:55:46 -07:00
|
|
|
|
|
|
|
static NSUInteger reloadRetries = 0;
|
|
|
|
const NSUInteger maxMessageLength = 75;
|
|
|
|
|
|
|
|
if (reloadRetries < _maxReloadAttempts) {
|
|
|
|
|
|
|
|
reloadRetries++;
|
|
|
|
[[NSNotificationCenter defaultCenter] postNotificationName:RCTReloadNotification
|
|
|
|
object:nil];
|
|
|
|
|
2015-04-09 10:39:28 -07:00
|
|
|
} else {
|
2015-04-19 12:55:46 -07:00
|
|
|
|
2015-04-09 10:39:28 -07:00
|
|
|
// Filter out numbers so the same base errors are mapped to the same categories independent of incorrect values.
|
|
|
|
NSString *pattern = @"[+-]?\\d+[,.]?\\d*";
|
2015-04-19 12:55:46 -07:00
|
|
|
NSString *sanitizedMessage = [message stringByReplacingOccurrencesOfString:pattern withString:@"<num>" options:NSRegularExpressionSearch range:(NSRange){0, message.length}];
|
|
|
|
|
|
|
|
if (sanitizedMessage.length > maxMessageLength) {
|
|
|
|
sanitizedMessage = [[sanitizedMessage substringToIndex:maxMessageLength] stringByAppendingString:@"..."];
|
2015-04-09 10:39:28 -07:00
|
|
|
}
|
2015-04-19 12:55:46 -07:00
|
|
|
|
|
|
|
NSMutableString *prettyStack = [NSMutableString stringWithString:@"\n"];
|
2015-04-09 10:39:28 -07:00
|
|
|
for (NSDictionary *frame in stack) {
|
|
|
|
[prettyStack appendFormat:@"%@@%@:%@\n", frame[@"methodName"], frame[@"lineNumber"], frame[@"column"]];
|
|
|
|
}
|
|
|
|
|
|
|
|
NSString *name = [@"Unhandled JS Exception: " stringByAppendingString:sanitizedMessage];
|
|
|
|
[NSException raise:name format:@"Message: %@, stack: %@", message, prettyStack];
|
2015-03-11 13:53:30 -07:00
|
|
|
}
|
2015-04-19 12:55:46 -07:00
|
|
|
|
2015-04-09 10:39:28 -07:00
|
|
|
#endif
|
2015-04-19 12:55:46 -07:00
|
|
|
|
2015-02-19 20:10:52 -08:00
|
|
|
}
|
|
|
|
|
2015-04-08 08:52:48 -07:00
|
|
|
RCT_EXPORT_METHOD(updateExceptionMessage:(NSString *)message
|
|
|
|
stack:(NSArray *)stack)
|
2015-02-19 20:10:52 -08:00
|
|
|
{
|
2015-04-19 12:55:46 -07:00
|
|
|
|
|
|
|
#if DEBUG
|
|
|
|
|
2015-02-19 20:10:52 -08:00
|
|
|
[[RCTRedBox sharedInstance] updateErrorMessage:message withStack:stack];
|
2015-04-19 12:55:46 -07:00
|
|
|
|
|
|
|
#endif
|
|
|
|
|
2015-02-19 20:10:52 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
@end
|