Diff
checker
Texto
Texto
Imagens
Documentos
Excel
Pastas
Legal
Enterprise
Aplicativo para desktop
Preços
Fazer login
Baixar o Diffchecker Desktop
Comparar texto
Encontre a diferença entre dois arquivos de texto
Ferramentas
Histórico
Editor live
Recolher inalteradas
Sem quebra de linha
Layout
Dividido
Unificado
Nível de detalhe
Inteligente
Palavra
Caractere
Realce de sintaxe
Escolher sintaxe
Ignorar
Transformar texto
Ir à primeira mudança
Editar entrada
Diffchecker Desktop
A maneira mais segura de usar o Diffchecker. Obtenha o aplicativo Diffchecker Desktop: seus diffs nunca saem do seu computador!
Obter Desktop
linkedErrors integrations
Criado
há 5 anos
O diff nunca expira
Limpar
Exportar
Compartilhar
Explicar
16 remoções
Linhas
Total
Removido
Caracteres
Total
Removido
Para continuar usando este recurso, atualize para
Diff
checker
Pro
Ver preços
78 linhas
Copiar tudo
45 adições
Linhas
Total
Adicionado
Caracteres
Total
Adicionado
Para continuar usando este recurso, atualize para
Diff
checker
Pro
Ver preços
98 linhas
Copiar tudo
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';
Copiar
Copiado
Copiar
Copiado
import { isInstanceOf
} from '@sentry/utils';
import { isInstanceOf
, SyncPromise
} from '@sentry/utils';
Copiar
Copiado
Copiar
Copiado
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) {
Copiar
Copiado
Copiar
Copiado
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
*/
*/
Copiar
Copiado
Copiar
Copiado
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)) {
Copiar
Copiado
Copiar
Copiado
return
event
;
return
SyncPromise.resolve(
event
)
;
}
}
Copiar
Copiado
Copiar
Copiado
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
*/
*/
Copiar
Copiado
Copiar
Copiado
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) {
Copiar
Copiado
Copiar
Copiado
return
stack
;
return
SyncPromise.resolve(
stack
)
;
}
}
Copiar
Copiado
Copiar
Copiado
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();
});
});
}
}
}
}
Diferenças salvas
Texto original
Abrir arquivo
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]); } }
Texto alterado
Abrir arquivo
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(); }); }); } }
Encontrar Diferença