angular2
Version:
Angular 2 - a web framework for modern web apps
130 lines • 18.3 kB
JavaScript
;var lang_1 = require('angular2/src/facade/lang');
var exceptions_1 = require('angular2/src/facade/exceptions');
var collection_1 = require('angular2/src/facade/collection');
var _ArrayLogger = (function () {
function _ArrayLogger() {
this.res = [];
}
_ArrayLogger.prototype.log = function (s) { this.res.push(s); };
_ArrayLogger.prototype.logError = function (s) { this.res.push(s); };
_ArrayLogger.prototype.logGroup = function (s) { this.res.push(s); };
_ArrayLogger.prototype.logGroupEnd = function () { };
;
return _ArrayLogger;
})();
/**
* Provides a hook for centralized exception handling.
*
* The default implementation of `ExceptionHandler` prints error messages to the `Console`. To
* intercept error handling,
* write a custom exception handler that replaces this default as appropriate for your app.
*
* ### Example
*
* ```javascript
*
* class MyExceptionHandler implements ExceptionHandler {
* call(error, stackTrace = null, reason = null) {
* // do something with the exception
* }
* }
*
* bootstrap(MyApp, [provide(ExceptionHandler, {useClass: MyExceptionHandler})])
*
* ```
*/
var ExceptionHandler = (function () {
function ExceptionHandler(_logger, _rethrowException) {
if (_rethrowException === void 0) { _rethrowException = true; }
this._logger = _logger;
this._rethrowException = _rethrowException;
}
ExceptionHandler.exceptionToString = function (exception, stackTrace, reason) {
if (stackTrace === void 0) { stackTrace = null; }
if (reason === void 0) { reason = null; }
var l = new _ArrayLogger();
var e = new ExceptionHandler(l, false);
e.call(exception, stackTrace, reason);
return l.res.join("\n");
};
ExceptionHandler.prototype.call = function (exception, stackTrace, reason) {
if (stackTrace === void 0) { stackTrace = null; }
if (reason === void 0) { reason = null; }
var originalException = this._findOriginalException(exception);
var originalStack = this._findOriginalStack(exception);
var context = this._findContext(exception);
this._logger.logGroup("EXCEPTION: " + this._extractMessage(exception));
if (lang_1.isPresent(stackTrace) && lang_1.isBlank(originalStack)) {
this._logger.logError("STACKTRACE:");
this._logger.logError(this._longStackTrace(stackTrace));
}
if (lang_1.isPresent(reason)) {
this._logger.logError("REASON: " + reason);
}
if (lang_1.isPresent(originalException)) {
this._logger.logError("ORIGINAL EXCEPTION: " + this._extractMessage(originalException));
}
if (lang_1.isPresent(originalStack)) {
this._logger.logError("ORIGINAL STACKTRACE:");
this._logger.logError(this._longStackTrace(originalStack));
}
if (lang_1.isPresent(context)) {
this._logger.logError("ERROR CONTEXT:");
this._logger.logError(context);
}
this._logger.logGroupEnd();
// We rethrow exceptions, so operations like 'bootstrap' will result in an error
// when an exception happens. If we do not rethrow, bootstrap will always succeed.
if (this._rethrowException)
throw exception;
};
/** @internal */
ExceptionHandler.prototype._extractMessage = function (exception) {
return exception instanceof exceptions_1.WrappedException ? exception.wrapperMessage : exception.toString();
};
/** @internal */
ExceptionHandler.prototype._longStackTrace = function (stackTrace) {
return collection_1.isListLikeIterable(stackTrace) ? stackTrace.join("\n\n-----async gap-----\n") :
stackTrace.toString();
};
/** @internal */
ExceptionHandler.prototype._findContext = function (exception) {
try {
if (!(exception instanceof exceptions_1.WrappedException))
return null;
return lang_1.isPresent(exception.context) ? exception.context :
this._findContext(exception.originalException);
}
catch (e) {
// exception.context can throw an exception. if it happens, we ignore the context.
return null;
}
};
/** @internal */
ExceptionHandler.prototype._findOriginalException = function (exception) {
if (!(exception instanceof exceptions_1.WrappedException))
return null;
var e = exception.originalException;
while (e instanceof exceptions_1.WrappedException && lang_1.isPresent(e.originalException)) {
e = e.originalException;
}
return e;
};
/** @internal */
ExceptionHandler.prototype._findOriginalStack = function (exception) {
if (!(exception instanceof exceptions_1.WrappedException))
return null;
var e = exception;
var stack = exception.originalStack;
while (e instanceof exceptions_1.WrappedException && lang_1.isPresent(e.originalException)) {
e = e.originalException;
if (e instanceof exceptions_1.WrappedException && lang_1.isPresent(e.originalException)) {
stack = e.originalStack;
}
}
return stack;
};
return ExceptionHandler;
})();
exports.ExceptionHandler = ExceptionHandler;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"exception_handler.js","sourceRoot":"","sources":["angular2/src/facade/exception_handler.ts"],"names":["_ArrayLogger","_ArrayLogger.constructor","_ArrayLogger.log","_ArrayLogger.logError","_ArrayLogger.logGroup","_ArrayLogger.logGroupEnd","ExceptionHandler","ExceptionHandler.constructor","ExceptionHandler.exceptionToString","ExceptionHandler.call","ExceptionHandler._extractMessage","ExceptionHandler._longStackTrace","ExceptionHandler._findContext","ExceptionHandler._findOriginalException","ExceptionHandler._findOriginalStack"],"mappings":"AAAA,qBAAwC,0BAA0B,CAAC,CAAA;AACnE,2BAA8C,gCAAgC,CAAC,CAAA;AAC/E,2BAA8C,gCAAgC,CAAC,CAAA;AAE/E;IAAAA;QACEC,QAAGA,GAAUA,EAAEA,CAACA;IAKlBA,CAACA;IAJCD,0BAAGA,GAAHA,UAAIA,CAAMA,IAAUE,IAAIA,CAACA,GAAGA,CAACA,IAAIA,CAACA,CAACA,CAACA,CAACA,CAACA,CAACA;IACvCF,+BAAQA,GAARA,UAASA,CAAMA,IAAUG,IAAIA,CAACA,GAAGA,CAACA,IAAIA,CAACA,CAACA,CAACA,CAACA,CAACA,CAACA;IAC5CH,+BAAQA,GAARA,UAASA,CAAMA,IAAUI,IAAIA,CAACA,GAAGA,CAACA,IAAIA,CAACA,CAACA,CAACA,CAACA,CAACA,CAACA;IAC5CJ,kCAAWA,GAAXA,cAAcK,CAACA;;IACjBL,mBAACA;AAADA,CAACA,AAND,IAMC;AAED;;;;;;;;;;;;;;;;;;;;GAoBG;AACH;IACEM,0BAAoBA,OAAYA,EAAUA,iBAAiCA;QAAzCC,iCAAyCA,GAAzCA,wBAAyCA;QAAvDA,YAAOA,GAAPA,OAAOA,CAAKA;QAAUA,sBAAiBA,GAAjBA,iBAAiBA,CAAgBA;IAAGA,CAACA;IAExED,kCAAiBA,GAAxBA,UAAyBA,SAAcA,EAAEA,UAAsBA,EAAEA,MAAqBA;QAA7CE,0BAAsBA,GAAtBA,iBAAsBA;QAAEA,sBAAqBA,GAArBA,aAAqBA;QACpFA,IAAIA,CAACA,GAAGA,IAAIA,YAAYA,EAAEA,CAACA;QAC3BA,IAAIA,CAACA,GAAGA,IAAIA,gBAAgBA,CAACA,CAACA,EAAEA,KAAKA,CAACA,CAACA;QACvCA,CAACA,CAACA,IAAIA,CAACA,SAASA,EAAEA,UAAUA,EAAEA,MAAMA,CAACA,CAACA;QACtCA,MAAMA,CAACA,CAACA,CAACA,GAAGA,CAACA,IAAIA,CAACA,IAAIA,CAACA,CAACA;IAC1BA,CAACA;IAEDF,+BAAIA,GAAJA,UAAKA,SAAcA,EAAEA,UAAsBA,EAAEA,MAAqBA;QAA7CG,0BAAsBA,GAAtBA,iBAAsBA;QAAEA,sBAAqBA,GAArBA,aAAqBA;QAChEA,IAAIA,iBAAiBA,GAAGA,IAAIA,CAACA,sBAAsBA,CAACA,SAASA,CAACA,CAACA;QAC/DA,IAAIA,aAAaA,GAAGA,IAAIA,CAACA,kBAAkBA,CAACA,SAASA,CAACA,CAACA;QACvDA,IAAIA,OAAOA,GAAGA,IAAIA,CAACA,YAAYA,CAACA,SAASA,CAACA,CAACA;QAE3CA,IAAIA,CAACA,OAAOA,CAACA,QAAQA,CAACA,gBAAcA,IAAIA,CAACA,eAAeA,CAACA,SAASA,CAAGA,CAACA,CAACA;QAEvEA,EAAEA,CAACA,CAACA,gBAASA,CAACA,UAAUA,CAACA,IAAIA,cAAOA,CAACA,aAAaA,CAACA,CAACA,CAACA,CAACA;YACpDA,IAAIA,CAACA,OAAOA,CAACA,QAAQA,CAACA,aAAaA,CAACA,CAACA;YACrCA,IAAIA,CAACA,OAAOA,CAACA,QAAQA,CAACA,IAAIA,CAACA,eAAeA,CAACA,UAAUA,CAACA,CAACA,CAACA;QAC1DA,CAACA;QAEDA,EAAEA,CAACA,CAACA,gBAASA,CAACA,MAAMA,CAACA,CAACA,CAACA,CAACA;YACtBA,IAAIA,CAACA,OAAOA,CAACA,QAAQA,CAACA,aAAWA,MAAQA,CAACA,CAACA;QAC7CA,CAACA;QAEDA,EAAEA,CAACA,CAACA,gBAASA,CAACA,iBAAiBA,CAACA,CAACA,CAACA,CAACA;YACjCA,IAAIA,CAACA,OAAOA,CAACA,QAAQA,CAACA,yBAAuBA,IAAIA,CAACA,eAAeA,CAACA,iBAAiBA,CAAGA,CAACA,CAACA;QAC1FA,CAACA;QAEDA,EAAEA,CAACA,CAACA,gBAASA,CAACA,aAAaA,CAACA,CAACA,CAACA,CAACA;YAC7BA,IAAIA,CAACA,OAAOA,CAACA,QAAQA,CAACA,sBAAsBA,CAACA,CAACA;YAC9CA,IAAIA,CAACA,OAAOA,CAACA,QAAQA,CAACA,IAAIA,CAACA,eAAeA,CAACA,aAAaA,CAACA,CAACA,CAACA;QAC7DA,CAACA;QAEDA,EAAEA,CAACA,CAACA,gBAASA,CAACA,OAAOA,CAACA,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","sourcesContent":["import {isPresent, isBlank, print} from 'angular2/src/facade/lang';\nimport {BaseException, WrappedException} from 'angular2/src/facade/exceptions';\nimport {ListWrapper, isListLikeIterable} from 'angular2/src/facade/collection';\n\nclass _ArrayLogger {\n  res: any[] = [];\n  log(s: any): void { this.res.push(s); }\n  logError(s: any): void { this.res.push(s); }\n  logGroup(s: any): void { this.res.push(s); }\n  logGroupEnd(){};\n}\n\n/**\n * Provides a hook for centralized exception handling.\n *\n * The default implementation of `ExceptionHandler` prints error messages to the `Console`. To\n * intercept error handling,\n * write a custom exception handler that replaces this default as appropriate for your app.\n *\n * ### Example\n *\n * ```javascript\n *\n * class MyExceptionHandler implements ExceptionHandler {\n *   call(error, stackTrace = null, reason = null) {\n *     // do something with the exception\n *   }\n * }\n *\n * bootstrap(MyApp, [provide(ExceptionHandler, {useClass: MyExceptionHandler})])\n *\n * ```\n */\nexport class ExceptionHandler {\n  constructor(private _logger: any, private _rethrowException: boolean = true) {}\n\n  static exceptionToString(exception: any, stackTrace: any = null, reason: string = null): string {\n    var l = new _ArrayLogger();\n    var e = new ExceptionHandler(l, false);\n    e.call(exception, stackTrace, reason);\n    return l.res.join(\"\\n\");\n  }\n\n  call(exception: any, stackTrace: any = null, reason: string = null): void {\n    var originalException = this._findOriginalException(exception);\n    var originalStack = this._findOriginalStack(exception);\n    var context = this._findContext(exception);\n\n    this._logger.logGroup(`EXCEPTION: ${this._extractMessage(exception)}`);\n\n    if (isPresent(stackTrace) && isBlank(originalStack)) {\n      this._logger.logError(\"STACKTRACE:\");\n      this._logger.logError(this._longStackTrace(stackTrace));\n    }\n\n    if (isPresent(reason)) {\n      this._logger.logError(`REASON: ${reason}`);\n    }\n\n    if (isPresent(originalException)) {\n      this._logger.logError(`ORIGINAL EXCEPTION: ${this._extractMessage(originalException)}`);\n    }\n\n    if (isPresent(originalStack)) {\n      this._logger.logError(\"ORIGINAL STACKTRACE:\");\n      this._logger.logError(this._longStackTrace(originalStack));\n    }\n\n    if (isPresent(context)) {\n      this._logger.logError(\"ERROR CONTEXT:\");\n      this._logger.logError(context);\n    }\n\n    this._logger.logGroupEnd();\n\n    // We rethrow exceptions, so operations like 'bootstrap' will result in an error\n    // when an exception happens. If we do not rethrow, bootstrap will always succeed.\n    if (this._rethrowException) throw exception;\n  }\n\n  /** @internal */\n  _extractMessage(exception: any): string {\n    return exception instanceof WrappedException ? exception.wrapperMessage : exception.toString();\n  }\n\n  /** @internal */\n  _longStackTrace(stackTrace: any): any {\n    return isListLikeIterable(stackTrace) ? (<any[]>stackTrace).join(\"\\n\\n-----async gap-----\\n\") :\n                                            stackTrace.toString();\n  }\n\n  /** @internal */\n  _findContext(exception: any): any {\n    try {\n      if (!(exception instanceof WrappedException)) return null;\n      return isPresent(exception.context) ? exception.context :\n                                            this._findContext(exception.originalException);\n    } catch (e) {\n      // exception.context can throw an exception. if it happens, we ignore the context.\n      return null;\n    }\n  }\n\n  /** @internal */\n  _findOriginalException(exception: any): any {\n    if (!(exception instanceof WrappedException)) return null;\n\n    var e = exception.originalException;\n    while (e instanceof WrappedException && isPresent(e.originalException)) {\n      e = e.originalException;\n    }\n\n    return e;\n  }\n\n  /** @internal */\n  _findOriginalStack(exception: any): any {\n    if (!(exception instanceof WrappedException)) return null;\n\n    var e = exception;\n    var stack = exception.originalStack;\n    while (e instanceof WrappedException && isPresent(e.originalException)) {\n      e = e.originalException;\n      if (e instanceof WrappedException && isPresent(e.originalException)) {\n        stack = e.originalStack;\n      }\n    }\n\n    return stack;\n  }\n}\n"]}