Add files
This commit is contained in:
commit
bb80829159
18195 changed files with 2122994 additions and 0 deletions
18
509bba0_unpacked_with_node_modules/~/raven-js/src/configError.js
generated
Executable file
18
509bba0_unpacked_with_node_modules/~/raven-js/src/configError.js
generated
Executable file
|
@ -0,0 +1,18 @@
|
|||
'use strict';
|
||||
|
||||
function RavenConfigError(message) {
|
||||
this.name = 'RavenConfigError';
|
||||
this.message = message;
|
||||
}
|
||||
RavenConfigError.prototype = new Error();
|
||||
RavenConfigError.prototype.constructor = RavenConfigError;
|
||||
|
||||
module.exports = RavenConfigError;
|
||||
|
||||
|
||||
|
||||
//////////////////
|
||||
// WEBPACK FOOTER
|
||||
// ./~/raven-js/src/configError.js
|
||||
// module id = 2688
|
||||
// module chunks = 4
|
45
509bba0_unpacked_with_node_modules/~/raven-js/src/console.js
generated
Executable file
45
509bba0_unpacked_with_node_modules/~/raven-js/src/console.js
generated
Executable file
|
@ -0,0 +1,45 @@
|
|||
'use strict';
|
||||
|
||||
var wrapMethod = function(console, level, callback) {
|
||||
var originalConsoleLevel = console[level];
|
||||
var originalConsole = console;
|
||||
|
||||
if (!(level in console)) {
|
||||
return;
|
||||
}
|
||||
|
||||
var sentryLevel = level === 'warn'
|
||||
? 'warning'
|
||||
: level;
|
||||
|
||||
console[level] = function () {
|
||||
var args = [].slice.call(arguments);
|
||||
|
||||
var msg = '' + args.join(' ');
|
||||
var data = {level: sentryLevel, logger: 'console', extra: {'arguments': args}};
|
||||
callback && callback(msg, data);
|
||||
|
||||
// this fails for some browsers. :(
|
||||
if (originalConsoleLevel) {
|
||||
// IE9 doesn't allow calling apply on console functions directly
|
||||
// See: https://stackoverflow.com/questions/5472938/does-ie9-support-console-log-and-is-it-a-real-function#answer-5473193
|
||||
Function.prototype.apply.call(
|
||||
originalConsoleLevel,
|
||||
originalConsole,
|
||||
args
|
||||
);
|
||||
}
|
||||
};
|
||||
};
|
||||
|
||||
module.exports = {
|
||||
wrapMethod: wrapMethod
|
||||
};
|
||||
|
||||
|
||||
|
||||
//////////////////
|
||||
// WEBPACK FOOTER
|
||||
// ./~/raven-js/src/console.js
|
||||
// module id = 2689
|
||||
// module chunks = 4
|
1973
509bba0_unpacked_with_node_modules/~/raven-js/src/raven.js
generated
Executable file
1973
509bba0_unpacked_with_node_modules/~/raven-js/src/raven.js
generated
Executable file
File diff suppressed because it is too large
Load diff
41
509bba0_unpacked_with_node_modules/~/raven-js/src/singleton.js
generated
Executable file
41
509bba0_unpacked_with_node_modules/~/raven-js/src/singleton.js
generated
Executable file
|
@ -0,0 +1,41 @@
|
|||
/**
|
||||
* Enforces a single instance of the Raven client, and the
|
||||
* main entry point for Raven. If you are a consumer of the
|
||||
* Raven library, you SHOULD load this file (vs raven.js).
|
||||
**/
|
||||
|
||||
'use strict';
|
||||
|
||||
var RavenConstructor = require('./raven');
|
||||
|
||||
// This is to be defensive in environments where window does not exist (see https://github.com/getsentry/raven-js/pull/785)
|
||||
var _window = typeof window !== 'undefined' ? window
|
||||
: typeof global !== 'undefined' ? global
|
||||
: typeof self !== 'undefined' ? self
|
||||
: {};
|
||||
var _Raven = _window.Raven;
|
||||
|
||||
var Raven = new RavenConstructor();
|
||||
|
||||
/*
|
||||
* Allow multiple versions of Raven to be installed.
|
||||
* Strip Raven from the global context and returns the instance.
|
||||
*
|
||||
* @return {Raven}
|
||||
*/
|
||||
Raven.noConflict = function () {
|
||||
_window.Raven = _Raven;
|
||||
return Raven;
|
||||
};
|
||||
|
||||
Raven.afterLoad();
|
||||
|
||||
module.exports = Raven;
|
||||
|
||||
|
||||
|
||||
//////////////////
|
||||
// WEBPACK FOOTER
|
||||
// ./~/raven-js/src/singleton.js
|
||||
// module id = 477
|
||||
// module chunks = 4
|
27
509bba0_unpacked_with_node_modules/~/raven-js/src/utils.js
generated
Executable file
27
509bba0_unpacked_with_node_modules/~/raven-js/src/utils.js
generated
Executable file
|
@ -0,0 +1,27 @@
|
|||
'use strict';
|
||||
|
||||
function isObject(what) {
|
||||
return typeof what === 'object' && what !== null;
|
||||
}
|
||||
|
||||
// Sorta yanked from https://github.com/joyent/node/blob/aa3b4b4/lib/util.js#L560
|
||||
// with some tiny modifications
|
||||
function isError(what) {
|
||||
var toString = {}.toString.call(what);
|
||||
return isObject(what) &&
|
||||
toString === '[object Error]' ||
|
||||
toString === '[object Exception]' || // Firefox NS_ERROR_FAILURE Exceptions
|
||||
what instanceof Error;
|
||||
}
|
||||
|
||||
module.exports = {
|
||||
isObject: isObject,
|
||||
isError: isError
|
||||
};
|
||||
|
||||
|
||||
//////////////////
|
||||
// WEBPACK FOOTER
|
||||
// ./~/raven-js/src/utils.js
|
||||
// module id = 1111
|
||||
// module chunks = 4
|
624
509bba0_unpacked_with_node_modules/~/raven-js/vendor/TraceKit/tracekit.js
generated
vendored
Executable file
624
509bba0_unpacked_with_node_modules/~/raven-js/vendor/TraceKit/tracekit.js
generated
vendored
Executable file
|
@ -0,0 +1,624 @@
|
|||
'use strict';
|
||||
|
||||
var utils = require('../../src/utils');
|
||||
|
||||
/*
|
||||
TraceKit - Cross brower stack traces
|
||||
|
||||
This was originally forked from github.com/occ/TraceKit, but has since been
|
||||
largely re-written and is now maintained as part of raven-js. Tests for
|
||||
this are in test/vendor.
|
||||
|
||||
MIT license
|
||||
*/
|
||||
|
||||
var TraceKit = {
|
||||
collectWindowErrors: true,
|
||||
debug: false
|
||||
};
|
||||
|
||||
// This is to be defensive in environments where window does not exist (see https://github.com/getsentry/raven-js/pull/785)
|
||||
var _window = typeof window !== 'undefined' ? window
|
||||
: typeof global !== 'undefined' ? global
|
||||
: typeof self !== 'undefined' ? self
|
||||
: {};
|
||||
|
||||
// global reference to slice
|
||||
var _slice = [].slice;
|
||||
var UNKNOWN_FUNCTION = '?';
|
||||
|
||||
// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Error#Error_types
|
||||
var ERROR_TYPES_RE = /^(?:[Uu]ncaught (?:exception: )?)?(?:((?:Eval|Internal|Range|Reference|Syntax|Type|URI|)Error): )?(.*)$/;
|
||||
|
||||
function getLocationHref() {
|
||||
if (typeof document === 'undefined' || typeof document.location === 'undefined')
|
||||
return '';
|
||||
|
||||
return document.location.href;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* TraceKit.report: cross-browser processing of unhandled exceptions
|
||||
*
|
||||
* Syntax:
|
||||
* TraceKit.report.subscribe(function(stackInfo) { ... })
|
||||
* TraceKit.report.unsubscribe(function(stackInfo) { ... })
|
||||
* TraceKit.report(exception)
|
||||
* try { ...code... } catch(ex) { TraceKit.report(ex); }
|
||||
*
|
||||
* Supports:
|
||||
* - Firefox: full stack trace with line numbers, plus column number
|
||||
* on top frame; column number is not guaranteed
|
||||
* - Opera: full stack trace with line and column numbers
|
||||
* - Chrome: full stack trace with line and column numbers
|
||||
* - Safari: line and column number for the top frame only; some frames
|
||||
* may be missing, and column number is not guaranteed
|
||||
* - IE: line and column number for the top frame only; some frames
|
||||
* may be missing, and column number is not guaranteed
|
||||
*
|
||||
* In theory, TraceKit should work on all of the following versions:
|
||||
* - IE5.5+ (only 8.0 tested)
|
||||
* - Firefox 0.9+ (only 3.5+ tested)
|
||||
* - Opera 7+ (only 10.50 tested; versions 9 and earlier may require
|
||||
* Exceptions Have Stacktrace to be enabled in opera:config)
|
||||
* - Safari 3+ (only 4+ tested)
|
||||
* - Chrome 1+ (only 5+ tested)
|
||||
* - Konqueror 3.5+ (untested)
|
||||
*
|
||||
* Requires TraceKit.computeStackTrace.
|
||||
*
|
||||
* Tries to catch all unhandled exceptions and report them to the
|
||||
* subscribed handlers. Please note that TraceKit.report will rethrow the
|
||||
* exception. This is REQUIRED in order to get a useful stack trace in IE.
|
||||
* If the exception does not reach the top of the browser, you will only
|
||||
* get a stack trace from the point where TraceKit.report was called.
|
||||
*
|
||||
* Handlers receive a stackInfo object as described in the
|
||||
* TraceKit.computeStackTrace docs.
|
||||
*/
|
||||
TraceKit.report = (function reportModuleWrapper() {
|
||||
var handlers = [],
|
||||
lastArgs = null,
|
||||
lastException = null,
|
||||
lastExceptionStack = null;
|
||||
|
||||
/**
|
||||
* Add a crash handler.
|
||||
* @param {Function} handler
|
||||
*/
|
||||
function subscribe(handler) {
|
||||
installGlobalHandler();
|
||||
handlers.push(handler);
|
||||
}
|
||||
|
||||
/**
|
||||
* Remove a crash handler.
|
||||
* @param {Function} handler
|
||||
*/
|
||||
function unsubscribe(handler) {
|
||||
for (var i = handlers.length - 1; i >= 0; --i) {
|
||||
if (handlers[i] === handler) {
|
||||
handlers.splice(i, 1);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Remove all crash handlers.
|
||||
*/
|
||||
function unsubscribeAll() {
|
||||
uninstallGlobalHandler();
|
||||
handlers = [];
|
||||
}
|
||||
|
||||
/**
|
||||
* Dispatch stack information to all handlers.
|
||||
* @param {Object.<string, *>} stack
|
||||
*/
|
||||
function notifyHandlers(stack, isWindowError) {
|
||||
var exception = null;
|
||||
if (isWindowError && !TraceKit.collectWindowErrors) {
|
||||
return;
|
||||
}
|
||||
for (var i in handlers) {
|
||||
if (handlers.hasOwnProperty(i)) {
|
||||
try {
|
||||
handlers[i].apply(null, [stack].concat(_slice.call(arguments, 2)));
|
||||
} catch (inner) {
|
||||
exception = inner;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (exception) {
|
||||
throw exception;
|
||||
}
|
||||
}
|
||||
|
||||
var _oldOnerrorHandler, _onErrorHandlerInstalled;
|
||||
|
||||
/**
|
||||
* Ensures all global unhandled exceptions are recorded.
|
||||
* Supported by Gecko and IE.
|
||||
* @param {string} message Error message.
|
||||
* @param {string} url URL of script that generated the exception.
|
||||
* @param {(number|string)} lineNo The line number at which the error
|
||||
* occurred.
|
||||
* @param {?(number|string)} colNo The column number at which the error
|
||||
* occurred.
|
||||
* @param {?Error} ex The actual Error object.
|
||||
*/
|
||||
function traceKitWindowOnError(message, url, lineNo, colNo, ex) {
|
||||
var stack = null;
|
||||
|
||||
if (lastExceptionStack) {
|
||||
TraceKit.computeStackTrace.augmentStackTraceWithInitialElement(lastExceptionStack, url, lineNo, message);
|
||||
processLastException();
|
||||
} else if (ex && utils.isError(ex)) {
|
||||
// non-string `ex` arg; attempt to extract stack trace
|
||||
|
||||
// New chrome and blink send along a real error object
|
||||
// Let's just report that like a normal error.
|
||||
// See: https://mikewest.org/2013/08/debugging-runtime-errors-with-window-onerror
|
||||
stack = TraceKit.computeStackTrace(ex);
|
||||
notifyHandlers(stack, true);
|
||||
} else {
|
||||
var location = {
|
||||
'url': url,
|
||||
'line': lineNo,
|
||||
'column': colNo
|
||||
};
|
||||
|
||||
var name = undefined;
|
||||
var msg = message; // must be new var or will modify original `arguments`
|
||||
var groups;
|
||||
if ({}.toString.call(message) === '[object String]') {
|
||||
var groups = message.match(ERROR_TYPES_RE);
|
||||
if (groups) {
|
||||
name = groups[1];
|
||||
msg = groups[2];
|
||||
}
|
||||
}
|
||||
|
||||
location.func = UNKNOWN_FUNCTION;
|
||||
|
||||
stack = {
|
||||
'name': name,
|
||||
'message': msg,
|
||||
'url': getLocationHref(),
|
||||
'stack': [location]
|
||||
};
|
||||
notifyHandlers(stack, true);
|
||||
}
|
||||
|
||||
if (_oldOnerrorHandler) {
|
||||
return _oldOnerrorHandler.apply(this, arguments);
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
function installGlobalHandler ()
|
||||
{
|
||||
if (_onErrorHandlerInstalled) {
|
||||
return;
|
||||
}
|
||||
_oldOnerrorHandler = _window.onerror;
|
||||
_window.onerror = traceKitWindowOnError;
|
||||
_onErrorHandlerInstalled = true;
|
||||
}
|
||||
|
||||
function uninstallGlobalHandler ()
|
||||
{
|
||||
if (!_onErrorHandlerInstalled) {
|
||||
return;
|
||||
}
|
||||
_window.onerror = _oldOnerrorHandler;
|
||||
_onErrorHandlerInstalled = false;
|
||||
_oldOnerrorHandler = undefined;
|
||||
}
|
||||
|
||||
function processLastException() {
|
||||
var _lastExceptionStack = lastExceptionStack,
|
||||
_lastArgs = lastArgs;
|
||||
lastArgs = null;
|
||||
lastExceptionStack = null;
|
||||
lastException = null;
|
||||
notifyHandlers.apply(null, [_lastExceptionStack, false].concat(_lastArgs));
|
||||
}
|
||||
|
||||
/**
|
||||
* Reports an unhandled Error to TraceKit.
|
||||
* @param {Error} ex
|
||||
* @param {?boolean} rethrow If false, do not re-throw the exception.
|
||||
* Only used for window.onerror to not cause an infinite loop of
|
||||
* rethrowing.
|
||||
*/
|
||||
function report(ex, rethrow) {
|
||||
var args = _slice.call(arguments, 1);
|
||||
if (lastExceptionStack) {
|
||||
if (lastException === ex) {
|
||||
return; // already caught by an inner catch block, ignore
|
||||
} else {
|
||||
processLastException();
|
||||
}
|
||||
}
|
||||
|
||||
var stack = TraceKit.computeStackTrace(ex);
|
||||
lastExceptionStack = stack;
|
||||
lastException = ex;
|
||||
lastArgs = args;
|
||||
|
||||
// If the stack trace is incomplete, wait for 2 seconds for
|
||||
// slow slow IE to see if onerror occurs or not before reporting
|
||||
// this exception; otherwise, we will end up with an incomplete
|
||||
// stack trace
|
||||
setTimeout(function () {
|
||||
if (lastException === ex) {
|
||||
processLastException();
|
||||
}
|
||||
}, (stack.incomplete ? 2000 : 0));
|
||||
|
||||
if (rethrow !== false) {
|
||||
throw ex; // re-throw to propagate to the top level (and cause window.onerror)
|
||||
}
|
||||
}
|
||||
|
||||
report.subscribe = subscribe;
|
||||
report.unsubscribe = unsubscribe;
|
||||
report.uninstall = unsubscribeAll;
|
||||
return report;
|
||||
}());
|
||||
|
||||
/**
|
||||
* TraceKit.computeStackTrace: cross-browser stack traces in JavaScript
|
||||
*
|
||||
* Syntax:
|
||||
* s = TraceKit.computeStackTrace(exception) // consider using TraceKit.report instead (see below)
|
||||
* Returns:
|
||||
* s.name - exception name
|
||||
* s.message - exception message
|
||||
* s.stack[i].url - JavaScript or HTML file URL
|
||||
* s.stack[i].func - function name, or empty for anonymous functions (if guessing did not work)
|
||||
* s.stack[i].args - arguments passed to the function, if known
|
||||
* s.stack[i].line - line number, if known
|
||||
* s.stack[i].column - column number, if known
|
||||
*
|
||||
* Supports:
|
||||
* - Firefox: full stack trace with line numbers and unreliable column
|
||||
* number on top frame
|
||||
* - Opera 10: full stack trace with line and column numbers
|
||||
* - Opera 9-: full stack trace with line numbers
|
||||
* - Chrome: full stack trace with line and column numbers
|
||||
* - Safari: line and column number for the topmost stacktrace element
|
||||
* only
|
||||
* - IE: no line numbers whatsoever
|
||||
*
|
||||
* Tries to guess names of anonymous functions by looking for assignments
|
||||
* in the source code. In IE and Safari, we have to guess source file names
|
||||
* by searching for function bodies inside all page scripts. This will not
|
||||
* work for scripts that are loaded cross-domain.
|
||||
* Here be dragons: some function names may be guessed incorrectly, and
|
||||
* duplicate functions may be mismatched.
|
||||
*
|
||||
* TraceKit.computeStackTrace should only be used for tracing purposes.
|
||||
* Logging of unhandled exceptions should be done with TraceKit.report,
|
||||
* which builds on top of TraceKit.computeStackTrace and provides better
|
||||
* IE support by utilizing the window.onerror event to retrieve information
|
||||
* about the top of the stack.
|
||||
*
|
||||
* Note: In IE and Safari, no stack trace is recorded on the Error object,
|
||||
* so computeStackTrace instead walks its *own* chain of callers.
|
||||
* This means that:
|
||||
* * in Safari, some methods may be missing from the stack trace;
|
||||
* * in IE, the topmost function in the stack trace will always be the
|
||||
* caller of computeStackTrace.
|
||||
*
|
||||
* This is okay for tracing (because you are likely to be calling
|
||||
* computeStackTrace from the function you want to be the topmost element
|
||||
* of the stack trace anyway), but not okay for logging unhandled
|
||||
* exceptions (because your catch block will likely be far away from the
|
||||
* inner function that actually caused the exception).
|
||||
*
|
||||
*/
|
||||
TraceKit.computeStackTrace = (function computeStackTraceWrapper() {
|
||||
/**
|
||||
* Escapes special characters, except for whitespace, in a string to be
|
||||
* used inside a regular expression as a string literal.
|
||||
* @param {string} text The string.
|
||||
* @return {string} The escaped string literal.
|
||||
*/
|
||||
function escapeRegExp(text) {
|
||||
return text.replace(/[\-\[\]{}()*+?.,\\\^$|#]/g, '\\$&');
|
||||
}
|
||||
|
||||
/**
|
||||
* Escapes special characters in a string to be used inside a regular
|
||||
* expression as a string literal. Also ensures that HTML entities will
|
||||
* be matched the same as their literal friends.
|
||||
* @param {string} body The string.
|
||||
* @return {string} The escaped string.
|
||||
*/
|
||||
function escapeCodeAsRegExpForMatchingInsideHTML(body) {
|
||||
return escapeRegExp(body).replace('<', '(?:<|<)').replace('>', '(?:>|>)').replace('&', '(?:&|&)').replace('"', '(?:"|")').replace(/\s+/g, '\\s+');
|
||||
}
|
||||
|
||||
// Contents of Exception in various browsers.
|
||||
//
|
||||
// SAFARI:
|
||||
// ex.message = Can't find variable: qq
|
||||
// ex.line = 59
|
||||
// ex.sourceId = 580238192
|
||||
// ex.sourceURL = http://...
|
||||
// ex.expressionBeginOffset = 96
|
||||
// ex.expressionCaretOffset = 98
|
||||
// ex.expressionEndOffset = 98
|
||||
// ex.name = ReferenceError
|
||||
//
|
||||
// FIREFOX:
|
||||
// ex.message = qq is not defined
|
||||
// ex.fileName = http://...
|
||||
// ex.lineNumber = 59
|
||||
// ex.columnNumber = 69
|
||||
// ex.stack = ...stack trace... (see the example below)
|
||||
// ex.name = ReferenceError
|
||||
//
|
||||
// CHROME:
|
||||
// ex.message = qq is not defined
|
||||
// ex.name = ReferenceError
|
||||
// ex.type = not_defined
|
||||
// ex.arguments = ['aa']
|
||||
// ex.stack = ...stack trace...
|
||||
//
|
||||
// INTERNET EXPLORER:
|
||||
// ex.message = ...
|
||||
// ex.name = ReferenceError
|
||||
//
|
||||
// OPERA:
|
||||
// ex.message = ...message... (see the example below)
|
||||
// ex.name = ReferenceError
|
||||
// ex.opera#sourceloc = 11 (pretty much useless, duplicates the info in ex.message)
|
||||
// ex.stacktrace = n/a; see 'opera:config#UserPrefs|Exceptions Have Stacktrace'
|
||||
|
||||
/**
|
||||
* Computes stack trace information from the stack property.
|
||||
* Chrome and Gecko use this property.
|
||||
* @param {Error} ex
|
||||
* @return {?Object.<string, *>} Stack trace information.
|
||||
*/
|
||||
function computeStackTraceFromStackProp(ex) {
|
||||
if (typeof ex.stack === 'undefined' || !ex.stack) return;
|
||||
|
||||
var chrome = /^\s*at (.*?) ?\(((?:file|https?|blob|chrome-extension|native|eval|<anonymous>).*?)(?::(\d+))?(?::(\d+))?\)?\s*$/i,
|
||||
gecko = /^\s*(.*?)(?:\((.*?)\))?(?:^|@)((?:file|https?|blob|chrome|resource|\[native).*?)(?::(\d+))?(?::(\d+))?\s*$/i,
|
||||
winjs = /^\s*at (?:((?:\[object object\])?.+) )?\(?((?:file|ms-appx|https?|blob):.*?):(\d+)(?::(\d+))?\)?\s*$/i,
|
||||
lines = ex.stack.split('\n'),
|
||||
stack = [],
|
||||
parts,
|
||||
element,
|
||||
reference = /^(.*) is undefined$/.exec(ex.message);
|
||||
|
||||
for (var i = 0, j = lines.length; i < j; ++i) {
|
||||
if ((parts = chrome.exec(lines[i]))) {
|
||||
var isNative = parts[2] && parts[2].indexOf('native') !== -1;
|
||||
element = {
|
||||
'url': !isNative ? parts[2] : null,
|
||||
'func': parts[1] || UNKNOWN_FUNCTION,
|
||||
'args': isNative ? [parts[2]] : [],
|
||||
'line': parts[3] ? +parts[3] : null,
|
||||
'column': parts[4] ? +parts[4] : null
|
||||
};
|
||||
} else if ( parts = winjs.exec(lines[i]) ) {
|
||||
element = {
|
||||
'url': parts[2],
|
||||
'func': parts[1] || UNKNOWN_FUNCTION,
|
||||
'args': [],
|
||||
'line': +parts[3],
|
||||
'column': parts[4] ? +parts[4] : null
|
||||
};
|
||||
} else if ((parts = gecko.exec(lines[i]))) {
|
||||
element = {
|
||||
'url': parts[3],
|
||||
'func': parts[1] || UNKNOWN_FUNCTION,
|
||||
'args': parts[2] ? parts[2].split(',') : [],
|
||||
'line': parts[4] ? +parts[4] : null,
|
||||
'column': parts[5] ? +parts[5] : null
|
||||
};
|
||||
} else {
|
||||
continue;
|
||||
}
|
||||
|
||||
if (!element.func && element.line) {
|
||||
element.func = UNKNOWN_FUNCTION;
|
||||
}
|
||||
|
||||
stack.push(element);
|
||||
}
|
||||
|
||||
if (!stack.length) {
|
||||
return null;
|
||||
}
|
||||
|
||||
if (!stack[0].column && typeof ex.columnNumber !== 'undefined') {
|
||||
// FireFox uses this awesome columnNumber property for its top frame
|
||||
// Also note, Firefox's column number is 0-based and everything else expects 1-based,
|
||||
// so adding 1
|
||||
stack[0].column = ex.columnNumber + 1;
|
||||
}
|
||||
|
||||
return {
|
||||
'name': ex.name,
|
||||
'message': ex.message,
|
||||
'url': getLocationHref(),
|
||||
'stack': stack
|
||||
};
|
||||
}
|
||||
|
||||
/**
|
||||
* Adds information about the first frame to incomplete stack traces.
|
||||
* Safari and IE require this to get complete data on the first frame.
|
||||
* @param {Object.<string, *>} stackInfo Stack trace information from
|
||||
* one of the compute* methods.
|
||||
* @param {string} url The URL of the script that caused an error.
|
||||
* @param {(number|string)} lineNo The line number of the script that
|
||||
* caused an error.
|
||||
* @param {string=} message The error generated by the browser, which
|
||||
* hopefully contains the name of the object that caused the error.
|
||||
* @return {boolean} Whether or not the stack information was
|
||||
* augmented.
|
||||
*/
|
||||
function augmentStackTraceWithInitialElement(stackInfo, url, lineNo, message) {
|
||||
var initial = {
|
||||
'url': url,
|
||||
'line': lineNo
|
||||
};
|
||||
|
||||
if (initial.url && initial.line) {
|
||||
stackInfo.incomplete = false;
|
||||
|
||||
if (!initial.func) {
|
||||
initial.func = UNKNOWN_FUNCTION;
|
||||
}
|
||||
|
||||
if (stackInfo.stack.length > 0) {
|
||||
if (stackInfo.stack[0].url === initial.url) {
|
||||
if (stackInfo.stack[0].line === initial.line) {
|
||||
return false; // already in stack trace
|
||||
} else if (!stackInfo.stack[0].line && stackInfo.stack[0].func === initial.func) {
|
||||
stackInfo.stack[0].line = initial.line;
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
stackInfo.stack.unshift(initial);
|
||||
stackInfo.partial = true;
|
||||
return true;
|
||||
} else {
|
||||
stackInfo.incomplete = true;
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Computes stack trace information by walking the arguments.caller
|
||||
* chain at the time the exception occurred. This will cause earlier
|
||||
* frames to be missed but is the only way to get any stack trace in
|
||||
* Safari and IE. The top frame is restored by
|
||||
* {@link augmentStackTraceWithInitialElement}.
|
||||
* @param {Error} ex
|
||||
* @return {?Object.<string, *>} Stack trace information.
|
||||
*/
|
||||
function computeStackTraceByWalkingCallerChain(ex, depth) {
|
||||
var functionName = /function\s+([_$a-zA-Z\xA0-\uFFFF][_$a-zA-Z0-9\xA0-\uFFFF]*)?\s*\(/i,
|
||||
stack = [],
|
||||
funcs = {},
|
||||
recursion = false,
|
||||
parts,
|
||||
item,
|
||||
source;
|
||||
|
||||
for (var curr = computeStackTraceByWalkingCallerChain.caller; curr && !recursion; curr = curr.caller) {
|
||||
if (curr === computeStackTrace || curr === TraceKit.report) {
|
||||
// console.log('skipping internal function');
|
||||
continue;
|
||||
}
|
||||
|
||||
item = {
|
||||
'url': null,
|
||||
'func': UNKNOWN_FUNCTION,
|
||||
'line': null,
|
||||
'column': null
|
||||
};
|
||||
|
||||
if (curr.name) {
|
||||
item.func = curr.name;
|
||||
} else if ((parts = functionName.exec(curr.toString()))) {
|
||||
item.func = parts[1];
|
||||
}
|
||||
|
||||
if (typeof item.func === 'undefined') {
|
||||
try {
|
||||
item.func = parts.input.substring(0, parts.input.indexOf('{'));
|
||||
} catch (e) { }
|
||||
}
|
||||
|
||||
if (funcs['' + curr]) {
|
||||
recursion = true;
|
||||
}else{
|
||||
funcs['' + curr] = true;
|
||||
}
|
||||
|
||||
stack.push(item);
|
||||
}
|
||||
|
||||
if (depth) {
|
||||
// console.log('depth is ' + depth);
|
||||
// console.log('stack is ' + stack.length);
|
||||
stack.splice(0, depth);
|
||||
}
|
||||
|
||||
var result = {
|
||||
'name': ex.name,
|
||||
'message': ex.message,
|
||||
'url': getLocationHref(),
|
||||
'stack': stack
|
||||
};
|
||||
augmentStackTraceWithInitialElement(result, ex.sourceURL || ex.fileName, ex.line || ex.lineNumber, ex.message || ex.description);
|
||||
return result;
|
||||
}
|
||||
|
||||
/**
|
||||
* Computes a stack trace for an exception.
|
||||
* @param {Error} ex
|
||||
* @param {(string|number)=} depth
|
||||
*/
|
||||
function computeStackTrace(ex, depth) {
|
||||
var stack = null;
|
||||
depth = (depth == null ? 0 : +depth);
|
||||
|
||||
try {
|
||||
stack = computeStackTraceFromStackProp(ex);
|
||||
if (stack) {
|
||||
return stack;
|
||||
}
|
||||
} catch (e) {
|
||||
if (TraceKit.debug) {
|
||||
throw e;
|
||||
}
|
||||
}
|
||||
|
||||
try {
|
||||
stack = computeStackTraceByWalkingCallerChain(ex, depth + 1);
|
||||
if (stack) {
|
||||
return stack;
|
||||
}
|
||||
} catch (e) {
|
||||
if (TraceKit.debug) {
|
||||
throw e;
|
||||
}
|
||||
}
|
||||
return {
|
||||
'name': ex.name,
|
||||
'message': ex.message,
|
||||
'url': getLocationHref()
|
||||
};
|
||||
}
|
||||
|
||||
computeStackTrace.augmentStackTraceWithInitialElement = augmentStackTraceWithInitialElement;
|
||||
computeStackTrace.computeStackTraceFromStackProp = computeStackTraceFromStackProp;
|
||||
|
||||
return computeStackTrace;
|
||||
}());
|
||||
|
||||
module.exports = TraceKit;
|
||||
|
||||
|
||||
|
||||
//////////////////
|
||||
// WEBPACK FOOTER
|
||||
// ./~/raven-js/vendor/TraceKit/tracekit.js
|
||||
// module id = 2691
|
||||
// module chunks = 4
|
Loading…
Add table
Add a link
Reference in a new issue