Diff
checker
Texte
Texte
Images
Documents
Excel
Dossiers
Legal
Enterprise
Application de bureau
Prix
Se connecter
Télécharger Diffchecker Desktop
Comparer le texte
Trouver la différence entre deux fichiers texte
Outils
Historique
Éditeur live
Cacher identiques
Sans retour à la ligne
Vue
Divisé
Unifié
Niveau de précision
Intelligent
Mot
Caractère
Coloration syntaxique
Choisir la syntaxe
Ignorer
Transformer le texte
Aller au premier écart
Modifier l'entrée
Diffchecker Desktop
La façon la plus sécurisée d'utiliser Diffchecker. Obtenez l'application Diffchecker Desktop : vos diffs ne quittent jamais votre ordinateur !
Obtenir Desktop
linkedErrors integrations
Créé
il y a 5 ans
Le diff n'expire jamais
Effacer
Exporter
Partager
Expliquer
16 suppressions
Lignes
Total
Supprimé
Caractères
Total
Supprimé
Pour continuer à utiliser cette fonctionnalité, passez à
Diff
checker
Pro
Voir les prix
78 lignes
Copier tout
45 ajouts
Lignes
Total
Ajouté
Caractères
Total
Ajouté
Pour continuer à utiliser cette fonctionnalité, passez à
Diff
checker
Pro
Voir les prix
98 lignes
Copier tout
import { addGlobalEventProcessor, getCurrentHub } from '@sentry/core';
import { addGlobalEventProcessor, getCurrentHub } from '@sentry/core';
import { Event, EventHint, Exception, ExtendedError, Integration } from '@sentry/types';
import { Event, EventHint, Exception, ExtendedError, Integration } from '@sentry/types';
Copier
Copié
Copier
Copié
import { isInstanceOf
} from '@sentry/utils';
import { isInstanceOf
, SyncPromise
} from '@sentry/utils';
Copier
Copié
Copier
Copié
import {
exceptionFromStacktrace
} from '../parsers';
import {
getExceptionFromError
} from '../parsers';
import { computeStackTrace } from '../tracekit';
const DEFAULT_KEY = 'cause';
const DEFAULT_KEY = 'cause';
const DEFAULT_LIMIT = 5;
const DEFAULT_LIMIT = 5;
/** Adds SDK info to an event. */
/** Adds SDK info to an event. */
export class LinkedErrors implements Integration {
export class LinkedErrors implements Integration {
/**
/**
* @inheritDoc
* @inheritDoc
*/
*/
public static id: string = 'LinkedErrors';
public static id: string = 'LinkedErrors';
/**
/**
* @inheritDoc
* @inheritDoc
*/
*/
public readonly name: string = LinkedErrors.id;
public readonly name: string = LinkedErrors.id;
/**
/**
* @inheritDoc
* @inheritDoc
*/
*/
private readonly _key: string;
private readonly _key: string;
/**
/**
* @inheritDoc
* @inheritDoc
*/
*/
private readonly _limit: number;
private readonly _limit: number;
/**
/**
* @inheritDoc
* @inheritDoc
*/
*/
public constructor(options: { key?: string; limit?: number } = {}) {
public constructor(options: { key?: string; limit?: number } = {}) {
this._key = options.key || DEFAULT_KEY;
this._key = options.key || DEFAULT_KEY;
this._limit = options.limit || DEFAULT_LIMIT;
this._limit = options.limit || DEFAULT_LIMIT;
}
}
/**
/**
* @inheritDoc
* @inheritDoc
*/
*/
public setupOnce(): void {
public setupOnce(): void {
addGlobalEventProcessor((event: Event, hint?: EventHint) => {
addGlobalEventProcessor((event: Event, hint?: EventHint) => {
const self = getCurrentHub().getIntegration(LinkedErrors);
const self = getCurrentHub().getIntegration(LinkedErrors);
if (self) {
if (self) {
Copier
Copié
Copier
Copié
return
self._
handler(event, hint)
;
const handler = self._handler && self._handler.bind(self);
return
typeof handler === 'function' ?
handler(event, hint)
: event
;
}
}
return event;
return event;
});
});
}
}
/**
/**
* @inheritDoc
* @inheritDoc
*/
*/
Copier
Copié
Copier
Copié
private _handler(event: Event, hint?: EventHint):
Event
| null
{
private _handler(event: Event, hint?: EventHint):
PromiseLike<
Event
>
{
if (!event.exception || !event.exception.values || !hint || !isInstanceOf(hint.originalException, Error)) {
if (!event.exception || !event.exception.values || !hint || !isInstanceOf(hint.originalException, Error)) {
Copier
Copié
Copier
Copié
return
event
;
return
SyncPromise.resolve(
event
)
;
}
}
Copier
Copié
Copier
Copié
const linkedErrors =
this._walkErrorTree(hint.originalException as
ExtendedError
, this._key)
;
event.exception.values = [...linkedErrors, ...event.exception.values];
return new SyncPromise<Event>(resolve => {
return event;
void
this._walkErrorTree(hint.originalException as
Error
, this._key)
.then((linkedErrors: Exception[]) => {
if (event && event.exception && event.exception.values) {
event.exception.values = [...linkedErrors, ...event.exception.values];
}
resolve(event);
})
.then(null, () => {
resolve(event);
});
});
}
}
/**
/**
* @inheritDoc
* @inheritDoc
*/
*/
Copier
Copié
Copier
Copié
private _walkErrorTree(error: ExtendedError, key: string, stack: Exception[] = []):
Exception[]
{
private _walkErrorTree(error: ExtendedError, key: string, stack: Exception[] = []):
PromiseLike<
Exception[]
>
{
if (!isInstanceOf(error[key], Error) || stack.length + 1 >= this._limit) {
if (!isInstanceOf(error[key], Error) || stack.length + 1 >= this._limit) {
Copier
Copié
Copier
Copié
return
stack
;
return
SyncPromise.resolve(
stack
)
;
}
}
Copier
Copié
Copier
Copié
const stacktrace = computeStackTrace
(error[key])
;
return new SyncPromise<Exception[]>((resolve, reject) => {
const
exception
= exceptionFromStacktrace(stacktrace);
void getExceptionFromError
(error[key])
return
this._walkErrorTree(error[key], key, [exception, ...stack]
);
.then((
exception
: Exception) => {
void
this._walkErrorTree(error[key], key, [exception, ...stack]
)
.then(resolve)
.then(null, () => {
reject();
});
})
.then(null, () => {
reject();
});
});
}
}
}
}
Différences enregistrées
Texte d'origine
Ouvrir un fichier
import { addGlobalEventProcessor, getCurrentHub } from '@sentry/core'; import { Event, EventHint, Exception, ExtendedError, Integration } from '@sentry/types'; import { isInstanceOf } from '@sentry/utils'; import { exceptionFromStacktrace } from '../parsers'; import { computeStackTrace } from '../tracekit'; const DEFAULT_KEY = 'cause'; const DEFAULT_LIMIT = 5; /** Adds SDK info to an event. */ export class LinkedErrors implements Integration { /** * @inheritDoc */ public static id: string = 'LinkedErrors'; /** * @inheritDoc */ public readonly name: string = LinkedErrors.id; /** * @inheritDoc */ private readonly _key: string; /** * @inheritDoc */ private readonly _limit: number; /** * @inheritDoc */ public constructor(options: { key?: string; limit?: number } = {}) { this._key = options.key || DEFAULT_KEY; this._limit = options.limit || DEFAULT_LIMIT; } /** * @inheritDoc */ public setupOnce(): void { addGlobalEventProcessor((event: Event, hint?: EventHint) => { const self = getCurrentHub().getIntegration(LinkedErrors); if (self) { return self._handler(event, hint); } return event; }); } /** * @inheritDoc */ private _handler(event: Event, hint?: EventHint): Event | null { if (!event.exception || !event.exception.values || !hint || !isInstanceOf(hint.originalException, Error)) { return event; } const linkedErrors = this._walkErrorTree(hint.originalException as ExtendedError, this._key); event.exception.values = [...linkedErrors, ...event.exception.values]; return event; } /** * @inheritDoc */ private _walkErrorTree(error: ExtendedError, key: string, stack: Exception[] = []): Exception[] { if (!isInstanceOf(error[key], Error) || stack.length + 1 >= this._limit) { return stack; } const stacktrace = computeStackTrace(error[key]); const exception = exceptionFromStacktrace(stacktrace); return this._walkErrorTree(error[key], key, [exception, ...stack]); } }
Texte modifié
Ouvrir un fichier
import { addGlobalEventProcessor, getCurrentHub } from '@sentry/core'; import { Event, EventHint, Exception, ExtendedError, Integration } from '@sentry/types'; import { isInstanceOf, SyncPromise } from '@sentry/utils'; import { getExceptionFromError } from '../parsers'; const DEFAULT_KEY = 'cause'; const DEFAULT_LIMIT = 5; /** Adds SDK info to an event. */ export class LinkedErrors implements Integration { /** * @inheritDoc */ public static id: string = 'LinkedErrors'; /** * @inheritDoc */ public readonly name: string = LinkedErrors.id; /** * @inheritDoc */ private readonly _key: string; /** * @inheritDoc */ private readonly _limit: number; /** * @inheritDoc */ public constructor(options: { key?: string; limit?: number } = {}) { this._key = options.key || DEFAULT_KEY; this._limit = options.limit || DEFAULT_LIMIT; } /** * @inheritDoc */ public setupOnce(): void { addGlobalEventProcessor((event: Event, hint?: EventHint) => { const self = getCurrentHub().getIntegration(LinkedErrors); if (self) { const handler = self._handler && self._handler.bind(self); return typeof handler === 'function' ? handler(event, hint) : event; } return event; }); } /** * @inheritDoc */ private _handler(event: Event, hint?: EventHint): PromiseLike<Event> { if (!event.exception || !event.exception.values || !hint || !isInstanceOf(hint.originalException, Error)) { return SyncPromise.resolve(event); } return new SyncPromise<Event>(resolve => { void this._walkErrorTree(hint.originalException as Error, this._key) .then((linkedErrors: Exception[]) => { if (event && event.exception && event.exception.values) { event.exception.values = [...linkedErrors, ...event.exception.values]; } resolve(event); }) .then(null, () => { resolve(event); }); }); } /** * @inheritDoc */ private _walkErrorTree(error: ExtendedError, key: string, stack: Exception[] = []): PromiseLike<Exception[]> { if (!isInstanceOf(error[key], Error) || stack.length + 1 >= this._limit) { return SyncPromise.resolve(stack); } return new SyncPromise<Exception[]>((resolve, reject) => { void getExceptionFromError(error[key]) .then((exception: Exception) => { void this._walkErrorTree(error[key], key, [exception, ...stack]) .then(resolve) .then(null, () => { reject(); }); }) .then(null, () => { reject(); }); }); } }
Trouver la différence