The main use case for the generated source maps is to give errors a meaningful context in terms of the original source that the user wrote. Related changes that are included in this commit: * renamed virtual folders used for jit: * ng://<module type>/module.ngfactory.js * ng://<module type>/<comp type>.ngfactory.js * ng://<module type>/<comp type>.html (for inline templates) * error logging: * all errors that happen in templates are logged from the place of the nearest element. * instead of logging error messages and stacks separately, we log the actual error. This is needed so that browsers apply source maps to the stack correctly. * error type and error is logged as one log entry. Note that long-stack-trace zone has a bug that disables source maps for stack traces, see https://github.com/angular/zone.js/issues/661. BREAKING CHANGE: - DebugNode.source no more returns the source location of a node. Closes 14013
43 lines
1.6 KiB
TypeScript
43 lines
1.6 KiB
TypeScript
/**
|
|
* @license
|
|
* Copyright Google Inc. All Rights Reserved.
|
|
*
|
|
* Use of this source code is governed by an MIT-style license that can be
|
|
* found in the LICENSE file at https://angular.io/license
|
|
*/
|
|
|
|
import {escapeIdentifier} from '@angular/compiler/src/output/abstract_emitter';
|
|
|
|
export function main() {
|
|
describe('AbstractEmitter', () => {
|
|
describe('escapeIdentifier', () => {
|
|
it('should escape single quotes',
|
|
() => { expect(escapeIdentifier(`'`, false)).toEqual(`'\\''`); });
|
|
|
|
it('should escape backslash',
|
|
() => { expect(escapeIdentifier('\\', false)).toEqual(`'\\\\'`); });
|
|
|
|
it('should escape newlines',
|
|
() => { expect(escapeIdentifier('\n', false)).toEqual(`'\\n'`); });
|
|
|
|
it('should escape carriage returns',
|
|
() => { expect(escapeIdentifier('\r', false)).toEqual(`'\\r'`); });
|
|
|
|
it('should escape $', () => { expect(escapeIdentifier('$', true)).toEqual(`'\\$'`); });
|
|
it('should not escape $', () => { expect(escapeIdentifier('$', false)).toEqual(`'$'`); });
|
|
it('should add quotes for non-identifiers',
|
|
() => { expect(escapeIdentifier('==', false, false)).toEqual(`'=='`); });
|
|
it('does not escape class (but it probably should)',
|
|
() => { expect(escapeIdentifier('class', false, false)).toEqual('class'); });
|
|
});
|
|
});
|
|
}
|
|
|
|
export function stripSourceMapAndNewLine(source: string): string {
|
|
if (source.endsWith('\n')) {
|
|
source = source.substring(0, source.length - 1);
|
|
}
|
|
const smi = source.lastIndexOf('\n//#');
|
|
if (smi == -1) return source;
|
|
return source.slice(0, smi);
|
|
} |