mirror of
https://github.com/status-im/react-native.git
synced 2025-01-28 02:04:55 +00:00
Second part of updates from Wed 24 Jun
This commit is contained in:
commit
0898bb427f
@ -26,6 +26,7 @@
|
|||||||
|
|
||||||
jest
|
jest
|
||||||
.dontMock('EmitterSubscription')
|
.dontMock('EmitterSubscription')
|
||||||
|
.dontMock('EventSubscription')
|
||||||
.dontMock('EventEmitter')
|
.dontMock('EventEmitter')
|
||||||
.dontMock('EventSubscriptionVendor')
|
.dontMock('EventSubscriptionVendor')
|
||||||
.dontMock('NavigationContext')
|
.dontMock('NavigationContext')
|
||||||
|
@ -73,6 +73,7 @@ function renderApplication<D, P, S>(
|
|||||||
<AppContainer rootTag={rootTag}>
|
<AppContainer rootTag={rootTag}>
|
||||||
<RootComponent
|
<RootComponent
|
||||||
{...initialProps}
|
{...initialProps}
|
||||||
|
rootTag={rootTag}
|
||||||
/>
|
/>
|
||||||
</AppContainer>,
|
</AppContainer>,
|
||||||
rootTag
|
rootTag
|
||||||
|
@ -187,7 +187,7 @@ NSNumber *RCTConvertEnumValue(const char *typeName, NSDictionary *mapping, NSNum
|
|||||||
}
|
}
|
||||||
id value = mapping[json];
|
id value = mapping[json];
|
||||||
if (!value && [json description].length > 0) {
|
if (!value && [json description].length > 0) {
|
||||||
RCTLogError(@"Invalid %s '%@'. should be one of: %@", typeName, json, [mapping allKeys]);
|
RCTLogError(@"Invalid %s '%@'. should be one of: %@", typeName, json, [[mapping allKeys] sortedArrayUsingSelector: @selector(caseInsensitiveCompare:)]);
|
||||||
}
|
}
|
||||||
return value ?: defaultValue;
|
return value ?: defaultValue;
|
||||||
}
|
}
|
||||||
@ -550,27 +550,29 @@ RCT_CGSTRUCT_CONVERTER(CGAffineTransform, (@[
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Parse color
|
// Parse color
|
||||||
uint32_t red = 0, green = 0, blue = 0;
|
double red = 0, green = 0, blue = 0;
|
||||||
CGFloat alpha = 1.0;
|
double alpha = 1.0;
|
||||||
if ([colorString hasPrefix:@"#"]) {
|
if ([colorString hasPrefix:@"#"]) {
|
||||||
|
uint32_t redInt = 0, greenInt = 0, blueInt = 0;
|
||||||
if (colorString.length == 4) { // 3 digit hex
|
if (colorString.length == 4) { // 3 digit hex
|
||||||
sscanf([colorString UTF8String], "#%01x%01x%01x", &red, &green, &blue);
|
sscanf([colorString UTF8String], "#%01x%01x%01x", &redInt, &greenInt, &blueInt);
|
||||||
// expand to 6 digit hex
|
// expand to 6 digit hex
|
||||||
red = red | (red << 4);
|
red = redInt | (redInt << 4);
|
||||||
green = green | (green << 4);
|
green = greenInt | (greenInt << 4);
|
||||||
blue = blue | (blue << 4);
|
blue = blueInt | (blueInt << 4);
|
||||||
} else if (colorString.length == 7) { // 6 digit hex
|
} else if (colorString.length == 7) { // 6 digit hex
|
||||||
sscanf(colorString.UTF8String, "#%02x%02x%02x", &red, &green, &blue);
|
sscanf(colorString.UTF8String, "#%02x%02x%02x", &redInt, &greenInt, &blueInt);
|
||||||
|
red = redInt;
|
||||||
|
green = greenInt;
|
||||||
|
blue = blueInt;
|
||||||
} else {
|
} else {
|
||||||
RCTLogError(@"Invalid hex color %@. Hex colors should be 3 or 6 digits long.", colorString);
|
RCTLogError(@"Invalid hex color %@. Hex colors should be 3 or 6 digits long.", colorString);
|
||||||
alpha = -1;
|
alpha = -1;
|
||||||
}
|
}
|
||||||
} else if ([colorString hasPrefix:@"rgba("]) {
|
} else if ([colorString hasPrefix:@"rgba("]) {
|
||||||
double tmpAlpha;
|
sscanf(colorString.UTF8String, "rgba(%lf,%lf,%lf,%lf)", &red, &green, &blue, &alpha);
|
||||||
sscanf(colorString.UTF8String, "rgba(%u,%u,%u,%lf)", &red, &green, &blue, &tmpAlpha);
|
|
||||||
alpha = tmpAlpha;
|
|
||||||
} else if ([colorString hasPrefix:@"rgb("]) {
|
} else if ([colorString hasPrefix:@"rgb("]) {
|
||||||
sscanf(colorString.UTF8String, "rgb(%u,%u,%u)", &red, &green, &blue);
|
sscanf(colorString.UTF8String, "rgb(%lf,%lf,%lf)", &red, &green, &blue);
|
||||||
} else {
|
} else {
|
||||||
RCTLogError(@"Unrecognized color format '%@', must be one of #hex|rgba|rgb or a valid CSS color name.", colorString);
|
RCTLogError(@"Unrecognized color format '%@', must be one of #hex|rgba|rgb or a valid CSS color name.", colorString);
|
||||||
alpha = -1;
|
alpha = -1;
|
||||||
|
@ -34,6 +34,11 @@
|
|||||||
*/
|
*/
|
||||||
- (void)registerRootView:(UIView *)rootView;
|
- (void)registerRootView:(UIView *)rootView;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the view associated with a reactTag.
|
||||||
|
*/
|
||||||
|
- (UIView *)viewForReactTag:(NSNumber *)reactTag;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Update the frame of a root view. This might be in response to a screen rotation
|
* Update the frame of a root view. This might be in response to a screen rotation
|
||||||
* or some other layout event outside of the React-managed view hierarchy.
|
* or some other layout event outside of the React-managed view hierarchy.
|
||||||
|
@ -359,6 +359,12 @@ static NSDictionary *RCTViewConfigForModule(Class managerClass)
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
- (UIView *)viewForReactTag:(NSNumber *)reactTag
|
||||||
|
{
|
||||||
|
RCTAssertMainThread();
|
||||||
|
return _viewRegistry[reactTag];
|
||||||
|
}
|
||||||
|
|
||||||
- (void)setFrame:(CGRect)frame forRootView:(UIView *)rootView
|
- (void)setFrame:(CGRect)frame forRootView:(UIView *)rootView
|
||||||
{
|
{
|
||||||
RCTAssertMainThread();
|
RCTAssertMainThread();
|
||||||
|
@ -13,7 +13,6 @@
|
|||||||
|
|
||||||
#import "RCTAssert.h"
|
#import "RCTAssert.h"
|
||||||
#import "RCTLog.h"
|
#import "RCTLog.h"
|
||||||
#import "RCTWrapperViewController.h"
|
|
||||||
|
|
||||||
@implementation UIView (React)
|
@implementation UIView (React)
|
||||||
|
|
||||||
@ -91,8 +90,11 @@
|
|||||||
- (UIViewController *)backingViewController
|
- (UIViewController *)backingViewController
|
||||||
{
|
{
|
||||||
id responder = [self nextResponder];
|
id responder = [self nextResponder];
|
||||||
if ([responder isKindOfClass:[RCTWrapperViewController class]]) {
|
while (responder) {
|
||||||
return responder;
|
if ([responder isKindOfClass:[UIViewController class]]) {
|
||||||
|
return responder;
|
||||||
|
}
|
||||||
|
responder = [responder nextResponder];
|
||||||
}
|
}
|
||||||
return nil;
|
return nil;
|
||||||
}
|
}
|
||||||
|
@ -11,12 +11,352 @@
|
|||||||
*
|
*
|
||||||
* @provides console
|
* @provides console
|
||||||
* @polyfill
|
* @polyfill
|
||||||
|
* @nolint
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*eslint global-strict:0*/
|
|
||||||
(function(global) {
|
(function(global) {
|
||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
|
var inspect = (function() {
|
||||||
|
// Copyright Joyent, Inc. and other Node contributors.
|
||||||
|
//
|
||||||
|
// Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
// copy of this software and associated documentation files (the
|
||||||
|
// "Software"), to deal in the Software without restriction, including
|
||||||
|
// without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
// distribute, sublicense, and/or sell copies of the Software, and to permit
|
||||||
|
// persons to whom the Software is furnished to do so, subject to the
|
||||||
|
// following conditions:
|
||||||
|
//
|
||||||
|
// The above copyright notice and this permission notice shall be included
|
||||||
|
// in all copies or substantial portions of the Software.
|
||||||
|
//
|
||||||
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
||||||
|
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||||
|
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
|
||||||
|
// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
|
||||||
|
// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
||||||
|
// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
|
||||||
|
// USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
//
|
||||||
|
// https://github.com/joyent/node/blob/master/lib/util.js
|
||||||
|
|
||||||
|
function inspect(obj, opts) {
|
||||||
|
var ctx = {
|
||||||
|
seen: [],
|
||||||
|
stylize: stylizeNoColor
|
||||||
|
};
|
||||||
|
return formatValue(ctx, obj, opts.depth);
|
||||||
|
}
|
||||||
|
|
||||||
|
function stylizeNoColor(str, styleType) {
|
||||||
|
return str;
|
||||||
|
}
|
||||||
|
|
||||||
|
function arrayToHash(array) {
|
||||||
|
var hash = {};
|
||||||
|
|
||||||
|
array.forEach(function(val, idx) {
|
||||||
|
hash[val] = true;
|
||||||
|
});
|
||||||
|
|
||||||
|
return hash;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function formatValue(ctx, value, recurseTimes) {
|
||||||
|
// Primitive types cannot have properties
|
||||||
|
var primitive = formatPrimitive(ctx, value);
|
||||||
|
if (primitive) {
|
||||||
|
return primitive;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Look up the keys of the object.
|
||||||
|
var keys = Object.keys(value);
|
||||||
|
var visibleKeys = arrayToHash(keys);
|
||||||
|
|
||||||
|
// IE doesn't make error fields non-enumerable
|
||||||
|
// http://msdn.microsoft.com/en-us/library/ie/dww52sbt(v=vs.94).aspx
|
||||||
|
if (isError(value)
|
||||||
|
&& (keys.indexOf('message') >= 0 || keys.indexOf('description') >= 0)) {
|
||||||
|
return formatError(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Some type of object without properties can be shortcutted.
|
||||||
|
if (keys.length === 0) {
|
||||||
|
if (isFunction(value)) {
|
||||||
|
var name = value.name ? ': ' + value.name : '';
|
||||||
|
return ctx.stylize('[Function' + name + ']', 'special');
|
||||||
|
}
|
||||||
|
if (isRegExp(value)) {
|
||||||
|
return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');
|
||||||
|
}
|
||||||
|
if (isDate(value)) {
|
||||||
|
return ctx.stylize(Date.prototype.toString.call(value), 'date');
|
||||||
|
}
|
||||||
|
if (isError(value)) {
|
||||||
|
return formatError(value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var base = '', array = false, braces = ['{', '}'];
|
||||||
|
|
||||||
|
// Make Array say that they are Array
|
||||||
|
if (isArray(value)) {
|
||||||
|
array = true;
|
||||||
|
braces = ['[', ']'];
|
||||||
|
}
|
||||||
|
|
||||||
|
// Make functions say that they are functions
|
||||||
|
if (isFunction(value)) {
|
||||||
|
var n = value.name ? ': ' + value.name : '';
|
||||||
|
base = ' [Function' + n + ']';
|
||||||
|
}
|
||||||
|
|
||||||
|
// Make RegExps say that they are RegExps
|
||||||
|
if (isRegExp(value)) {
|
||||||
|
base = ' ' + RegExp.prototype.toString.call(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Make dates with properties first say the date
|
||||||
|
if (isDate(value)) {
|
||||||
|
base = ' ' + Date.prototype.toUTCString.call(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Make error with message first say the error
|
||||||
|
if (isError(value)) {
|
||||||
|
base = ' ' + formatError(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (keys.length === 0 && (!array || value.length == 0)) {
|
||||||
|
return braces[0] + base + braces[1];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (recurseTimes < 0) {
|
||||||
|
if (isRegExp(value)) {
|
||||||
|
return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');
|
||||||
|
} else {
|
||||||
|
return ctx.stylize('[Object]', 'special');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ctx.seen.push(value);
|
||||||
|
|
||||||
|
var output;
|
||||||
|
if (array) {
|
||||||
|
output = formatArray(ctx, value, recurseTimes, visibleKeys, keys);
|
||||||
|
} else {
|
||||||
|
output = keys.map(function(key) {
|
||||||
|
return formatProperty(ctx, value, recurseTimes, visibleKeys, key, array);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
ctx.seen.pop();
|
||||||
|
|
||||||
|
return reduceToSingleString(output, base, braces);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function formatPrimitive(ctx, value) {
|
||||||
|
if (isUndefined(value))
|
||||||
|
return ctx.stylize('undefined', 'undefined');
|
||||||
|
if (isString(value)) {
|
||||||
|
var simple = '\'' + JSON.stringify(value).replace(/^"|"$/g, '')
|
||||||
|
.replace(/'/g, "\\'")
|
||||||
|
.replace(/\\"/g, '"') + '\'';
|
||||||
|
return ctx.stylize(simple, 'string');
|
||||||
|
}
|
||||||
|
if (isNumber(value))
|
||||||
|
return ctx.stylize('' + value, 'number');
|
||||||
|
if (isBoolean(value))
|
||||||
|
return ctx.stylize('' + value, 'boolean');
|
||||||
|
// For some reason typeof null is "object", so special case here.
|
||||||
|
if (isNull(value))
|
||||||
|
return ctx.stylize('null', 'null');
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function formatError(value) {
|
||||||
|
return '[' + Error.prototype.toString.call(value) + ']';
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function formatArray(ctx, value, recurseTimes, visibleKeys, keys) {
|
||||||
|
var output = [];
|
||||||
|
for (var i = 0, l = value.length; i < l; ++i) {
|
||||||
|
if (hasOwnProperty(value, String(i))) {
|
||||||
|
output.push(formatProperty(ctx, value, recurseTimes, visibleKeys,
|
||||||
|
String(i), true));
|
||||||
|
} else {
|
||||||
|
output.push('');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
keys.forEach(function(key) {
|
||||||
|
if (!key.match(/^\d+$/)) {
|
||||||
|
output.push(formatProperty(ctx, value, recurseTimes, visibleKeys,
|
||||||
|
key, true));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
return output;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function formatProperty(ctx, value, recurseTimes, visibleKeys, key, array) {
|
||||||
|
var name, str, desc;
|
||||||
|
desc = Object.getOwnPropertyDescriptor(value, key) || { value: value[key] };
|
||||||
|
if (desc.get) {
|
||||||
|
if (desc.set) {
|
||||||
|
str = ctx.stylize('[Getter/Setter]', 'special');
|
||||||
|
} else {
|
||||||
|
str = ctx.stylize('[Getter]', 'special');
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (desc.set) {
|
||||||
|
str = ctx.stylize('[Setter]', 'special');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!hasOwnProperty(visibleKeys, key)) {
|
||||||
|
name = '[' + key + ']';
|
||||||
|
}
|
||||||
|
if (!str) {
|
||||||
|
if (ctx.seen.indexOf(desc.value) < 0) {
|
||||||
|
if (isNull(recurseTimes)) {
|
||||||
|
str = formatValue(ctx, desc.value, null);
|
||||||
|
} else {
|
||||||
|
str = formatValue(ctx, desc.value, recurseTimes - 1);
|
||||||
|
}
|
||||||
|
if (str.indexOf('\n') > -1) {
|
||||||
|
if (array) {
|
||||||
|
str = str.split('\n').map(function(line) {
|
||||||
|
return ' ' + line;
|
||||||
|
}).join('\n').substr(2);
|
||||||
|
} else {
|
||||||
|
str = '\n' + str.split('\n').map(function(line) {
|
||||||
|
return ' ' + line;
|
||||||
|
}).join('\n');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
str = ctx.stylize('[Circular]', 'special');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (isUndefined(name)) {
|
||||||
|
if (array && key.match(/^\d+$/)) {
|
||||||
|
return str;
|
||||||
|
}
|
||||||
|
name = JSON.stringify('' + key);
|
||||||
|
if (name.match(/^"([a-zA-Z_][a-zA-Z_0-9]*)"$/)) {
|
||||||
|
name = name.substr(1, name.length - 2);
|
||||||
|
name = ctx.stylize(name, 'name');
|
||||||
|
} else {
|
||||||
|
name = name.replace(/'/g, "\\'")
|
||||||
|
.replace(/\\"/g, '"')
|
||||||
|
.replace(/(^"|"$)/g, "'");
|
||||||
|
name = ctx.stylize(name, 'string');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return name + ': ' + str;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function reduceToSingleString(output, base, braces) {
|
||||||
|
var numLinesEst = 0;
|
||||||
|
var length = output.reduce(function(prev, cur) {
|
||||||
|
numLinesEst++;
|
||||||
|
if (cur.indexOf('\n') >= 0) numLinesEst++;
|
||||||
|
return prev + cur.replace(/\u001b\[\d\d?m/g, '').length + 1;
|
||||||
|
}, 0);
|
||||||
|
|
||||||
|
if (length > 60) {
|
||||||
|
return braces[0] +
|
||||||
|
(base === '' ? '' : base + '\n ') +
|
||||||
|
' ' +
|
||||||
|
output.join(',\n ') +
|
||||||
|
' ' +
|
||||||
|
braces[1];
|
||||||
|
}
|
||||||
|
|
||||||
|
return braces[0] + base + ' ' + output.join(', ') + ' ' + braces[1];
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// NOTE: These type checking functions intentionally don't use `instanceof`
|
||||||
|
// because it is fragile and can be easily faked with `Object.create()`.
|
||||||
|
function isArray(ar) {
|
||||||
|
return Array.isArray(ar);
|
||||||
|
}
|
||||||
|
|
||||||
|
function isBoolean(arg) {
|
||||||
|
return typeof arg === 'boolean';
|
||||||
|
}
|
||||||
|
|
||||||
|
function isNull(arg) {
|
||||||
|
return arg === null;
|
||||||
|
}
|
||||||
|
|
||||||
|
function isNullOrUndefined(arg) {
|
||||||
|
return arg == null;
|
||||||
|
}
|
||||||
|
|
||||||
|
function isNumber(arg) {
|
||||||
|
return typeof arg === 'number';
|
||||||
|
}
|
||||||
|
|
||||||
|
function isString(arg) {
|
||||||
|
return typeof arg === 'string';
|
||||||
|
}
|
||||||
|
|
||||||
|
function isSymbol(arg) {
|
||||||
|
return typeof arg === 'symbol';
|
||||||
|
}
|
||||||
|
|
||||||
|
function isUndefined(arg) {
|
||||||
|
return arg === void 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
function isRegExp(re) {
|
||||||
|
return isObject(re) && objectToString(re) === '[object RegExp]';
|
||||||
|
}
|
||||||
|
|
||||||
|
function isObject(arg) {
|
||||||
|
return typeof arg === 'object' && arg !== null;
|
||||||
|
}
|
||||||
|
|
||||||
|
function isDate(d) {
|
||||||
|
return isObject(d) && objectToString(d) === '[object Date]';
|
||||||
|
}
|
||||||
|
|
||||||
|
function isError(e) {
|
||||||
|
return isObject(e) &&
|
||||||
|
(objectToString(e) === '[object Error]' || e instanceof Error);
|
||||||
|
}
|
||||||
|
|
||||||
|
function isFunction(arg) {
|
||||||
|
return typeof arg === 'function';
|
||||||
|
}
|
||||||
|
|
||||||
|
function isPrimitive(arg) {
|
||||||
|
return arg === null ||
|
||||||
|
typeof arg === 'boolean' ||
|
||||||
|
typeof arg === 'number' ||
|
||||||
|
typeof arg === 'string' ||
|
||||||
|
typeof arg === 'symbol' || // ES6 symbol
|
||||||
|
typeof arg === 'undefined';
|
||||||
|
}
|
||||||
|
|
||||||
|
function objectToString(o) {
|
||||||
|
return Object.prototype.toString.call(o);
|
||||||
|
}
|
||||||
|
|
||||||
|
function hasOwnProperty(obj, prop) {
|
||||||
|
return Object.prototype.hasOwnProperty.call(obj, prop);
|
||||||
|
}
|
||||||
|
|
||||||
|
return inspect;
|
||||||
|
})();
|
||||||
|
|
||||||
|
|
||||||
var OBJECT_COLUMN_NAME = '(index)';
|
var OBJECT_COLUMN_NAME = '(index)';
|
||||||
var LOG_LEVELS = {
|
var LOG_LEVELS = {
|
||||||
trace: 0,
|
trace: 0,
|
||||||
@ -27,7 +367,6 @@
|
|||||||
};
|
};
|
||||||
|
|
||||||
function setupConsole(global) {
|
function setupConsole(global) {
|
||||||
|
|
||||||
if (!global.nativeLoggingHook) {
|
if (!global.nativeLoggingHook) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -35,34 +374,7 @@
|
|||||||
function getNativeLogFunction(level) {
|
function getNativeLogFunction(level) {
|
||||||
return function() {
|
return function() {
|
||||||
var str = Array.prototype.map.call(arguments, function(arg) {
|
var str = Array.prototype.map.call(arguments, function(arg) {
|
||||||
var ret;
|
return inspect(arg, {depth: 10});
|
||||||
var type = typeof arg;
|
|
||||||
if (arg === null) {
|
|
||||||
ret = 'null';
|
|
||||||
} else if (arg === undefined) {
|
|
||||||
ret = 'undefined';
|
|
||||||
} else if (type === 'string') {
|
|
||||||
ret = '"' + arg + '"';
|
|
||||||
} else if (type === 'function') {
|
|
||||||
try {
|
|
||||||
ret = arg.toString();
|
|
||||||
} catch (e) {
|
|
||||||
ret = '[function unknown]';
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
// Perform a try catch, just in case the object has a circular
|
|
||||||
// reference or stringify throws for some other reason.
|
|
||||||
try {
|
|
||||||
ret = JSON.stringify(arg);
|
|
||||||
} catch (e) {
|
|
||||||
if (typeof arg.toString === 'function') {
|
|
||||||
try {
|
|
||||||
ret = arg.toString();
|
|
||||||
} catch (E) {}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return ret || '["' + type + '" failed to stringify]';
|
|
||||||
}).join(', ');
|
}).join(', ');
|
||||||
global.nativeLoggingHook(str, level);
|
global.nativeLoggingHook(str, level);
|
||||||
};
|
};
|
||||||
|
Loading…
x
Reference in New Issue
Block a user