mirror of https://github.com/ghostfolio/ghostfolio
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
191 lines
7.8 KiB
191 lines
7.8 KiB
'use strict';
|
|
/**
|
|
* @license Angular
|
|
* (c) 2010-2025 Google LLC. https://angular.dev/
|
|
* License: MIT
|
|
*/ (function (g, f) { if (typeof define == "function" && define.amd) {
|
|
define(f);
|
|
}
|
|
else if (typeof exports == "object" && typeof module < "u") {
|
|
module.exports = f();
|
|
}
|
|
else {
|
|
var m = f();
|
|
for (var i in m)
|
|
g[i] = m[i];
|
|
} }(typeof globalThis < "u" ? globalThis : typeof self < "u" ? self : this, function () {
|
|
var exports = {};
|
|
var __exports = exports;
|
|
var module = { exports: exports };
|
|
var __defProp = Object.defineProperty;
|
|
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
var __defNormalProp = function (obj, key, value) { return key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value: value }) : obj[key] = value; };
|
|
var __spreadValues = function (a, b) {
|
|
for (var prop in b || (b = {}))
|
|
if (__hasOwnProp.call(b, prop))
|
|
__defNormalProp(a, prop, b[prop]);
|
|
if (__getOwnPropSymbols)
|
|
for (var _i = 0, _a = __getOwnPropSymbols(b); _i < _a.length; _i++) {
|
|
var prop = _a[_i];
|
|
if (__propIsEnum.call(b, prop))
|
|
__defNormalProp(a, prop, b[prop]);
|
|
}
|
|
return a;
|
|
};
|
|
var __publicField = function (obj, key, value) {
|
|
__defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
return value;
|
|
};
|
|
// packages/zone.js/lib/zone-spec/long-stack-trace.js
|
|
function patchLongStackTrace(Zone2) {
|
|
var NEWLINE = "\n";
|
|
var IGNORE_FRAMES = {};
|
|
var creationTrace = "__creationTrace__";
|
|
var ERROR_TAG = "STACKTRACE TRACKING";
|
|
var SEP_TAG = "__SEP_TAG__";
|
|
var sepTemplate = SEP_TAG + "@[native]";
|
|
var LongStackTrace = /** @class */ (function () {
|
|
function LongStackTrace() {
|
|
__publicField(this, "error", getStacktrace());
|
|
__publicField(this, "timestamp", /* @__PURE__ */ new Date());
|
|
}
|
|
return LongStackTrace;
|
|
}());
|
|
function getStacktraceWithUncaughtError() {
|
|
return new Error(ERROR_TAG);
|
|
}
|
|
function getStacktraceWithCaughtError() {
|
|
try {
|
|
throw getStacktraceWithUncaughtError();
|
|
}
|
|
catch (err) {
|
|
return err;
|
|
}
|
|
}
|
|
var error = getStacktraceWithUncaughtError();
|
|
var caughtError = getStacktraceWithCaughtError();
|
|
var getStacktrace = error.stack ? getStacktraceWithUncaughtError : caughtError.stack ? getStacktraceWithCaughtError : getStacktraceWithUncaughtError;
|
|
function getFrames(error2) {
|
|
return error2.stack ? error2.stack.split(NEWLINE) : [];
|
|
}
|
|
function addErrorStack(lines, error2) {
|
|
var trace = getFrames(error2);
|
|
for (var i = 0; i < trace.length; i++) {
|
|
var frame = trace[i];
|
|
if (!IGNORE_FRAMES.hasOwnProperty(frame)) {
|
|
lines.push(trace[i]);
|
|
}
|
|
}
|
|
}
|
|
function renderLongStackTrace(frames, stack) {
|
|
var longTrace = [stack ? stack.trim() : ""];
|
|
if (frames) {
|
|
var timestamp = ( /* @__PURE__ */new Date()).getTime();
|
|
for (var i = 0; i < frames.length; i++) {
|
|
var traceFrames = frames[i];
|
|
var lastTime = traceFrames.timestamp;
|
|
var separator = "____________________Elapsed ".concat(timestamp - lastTime.getTime(), " ms; At: ").concat(lastTime);
|
|
separator = separator.replace(/[^\w\d]/g, "_");
|
|
longTrace.push(sepTemplate.replace(SEP_TAG, separator));
|
|
addErrorStack(longTrace, traceFrames.error);
|
|
timestamp = lastTime.getTime();
|
|
}
|
|
}
|
|
return longTrace.join(NEWLINE);
|
|
}
|
|
function stackTracesEnabled() {
|
|
return Error.stackTraceLimit > 0;
|
|
}
|
|
Zone2["longStackTraceZoneSpec"] = {
|
|
name: "long-stack-trace",
|
|
longStackTraceLimit: 10,
|
|
// Max number of task to keep the stack trace for.
|
|
// add a getLongStackTrace method in spec to
|
|
// handle handled reject promise error.
|
|
getLongStackTrace: function (error2) {
|
|
if (!error2) {
|
|
return void 0;
|
|
}
|
|
var trace = error2[Zone2.__symbol__("currentTaskTrace")];
|
|
if (!trace) {
|
|
return error2.stack;
|
|
}
|
|
return renderLongStackTrace(trace, error2.stack);
|
|
},
|
|
onScheduleTask: function (parentZoneDelegate, currentZone, targetZone, task) {
|
|
if (stackTracesEnabled()) {
|
|
var currentTask = Zone2.currentTask;
|
|
var trace = currentTask && currentTask.data && currentTask.data[creationTrace] || [];
|
|
trace = [new LongStackTrace()].concat(trace);
|
|
if (trace.length > this.longStackTraceLimit) {
|
|
trace.length = this.longStackTraceLimit;
|
|
}
|
|
if (!task.data)
|
|
task.data = {};
|
|
if (task.type === "eventTask") {
|
|
task.data = __spreadValues({}, task.data);
|
|
}
|
|
task.data[creationTrace] = trace;
|
|
}
|
|
return parentZoneDelegate.scheduleTask(targetZone, task);
|
|
},
|
|
onHandleError: function (parentZoneDelegate, currentZone, targetZone, error2) {
|
|
if (stackTracesEnabled()) {
|
|
var parentTask = Zone2.currentTask || error2.task;
|
|
if (error2 instanceof Error && parentTask) {
|
|
var longStack = renderLongStackTrace(parentTask.data && parentTask.data[creationTrace], error2.stack);
|
|
try {
|
|
error2.stack = error2.longStack = longStack;
|
|
}
|
|
catch (err) {
|
|
}
|
|
}
|
|
}
|
|
return parentZoneDelegate.handleError(targetZone, error2);
|
|
}
|
|
};
|
|
function captureStackTraces(stackTraces, count) {
|
|
if (count > 0) {
|
|
stackTraces.push(getFrames(new LongStackTrace().error));
|
|
captureStackTraces(stackTraces, count - 1);
|
|
}
|
|
}
|
|
function computeIgnoreFrames() {
|
|
if (!stackTracesEnabled()) {
|
|
return;
|
|
}
|
|
var frames = [];
|
|
captureStackTraces(frames, 2);
|
|
var frames1 = frames[0];
|
|
var frames2 = frames[1];
|
|
for (var i = 0; i < frames1.length; i++) {
|
|
var frame1 = frames1[i];
|
|
if (frame1.indexOf(ERROR_TAG) == -1) {
|
|
var match = frame1.match(/^\s*at\s+/);
|
|
if (match) {
|
|
sepTemplate = match[0] + SEP_TAG + " (http://localhost)";
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
for (var i = 0; i < frames1.length; i++) {
|
|
var frame1 = frames1[i];
|
|
var frame2 = frames2[i];
|
|
if (frame1 === frame2) {
|
|
IGNORE_FRAMES[frame1] = true;
|
|
}
|
|
else {
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
computeIgnoreFrames();
|
|
}
|
|
// packages/zone.js/lib/zone-spec/rollup-long-stack-trace.js
|
|
patchLongStackTrace(Zone);
|
|
if (__exports != exports)
|
|
module.exports = exports;
|
|
return module.exports;
|
|
}));
|
|
|