refactor: remove lang.ts (#14837)

This commit is contained in:
Miško Hevery 2017-03-02 09:37:01 -08:00 committed by Chuck Jazdzewski
parent 84a65cf788
commit 8343fb7740
139 changed files with 406 additions and 676 deletions

View File

@ -1 +0,0 @@
../../facade/src

View File

@ -7,7 +7,6 @@
*/ */
import {Inject, Injectable, InjectionToken} from '@angular/core'; import {Inject, Injectable, InjectionToken} from '@angular/core';
import {print} from '../facade/lang';
import {MeasureValues} from '../measure_values'; import {MeasureValues} from '../measure_values';
import {Reporter} from '../reporter'; import {Reporter} from '../reporter';
import {SampleDescription} from '../sample_description'; import {SampleDescription} from '../sample_description';
@ -23,8 +22,13 @@ export class ConsoleReporter extends Reporter {
static PRINT = new InjectionToken('ConsoleReporter.print'); static PRINT = new InjectionToken('ConsoleReporter.print');
static COLUMN_WIDTH = new InjectionToken('ConsoleReporter.columnWidth'); static COLUMN_WIDTH = new InjectionToken('ConsoleReporter.columnWidth');
static PROVIDERS = [ static PROVIDERS = [
ConsoleReporter, {provide: ConsoleReporter.COLUMN_WIDTH, useValue: 18}, ConsoleReporter, {provide: ConsoleReporter.COLUMN_WIDTH, useValue: 18}, {
{provide: ConsoleReporter.PRINT, useValue: print} provide: ConsoleReporter.PRINT,
useValue: function(v: any) {
// tslint:disable-next-line:no-console
console.log(v);
}
}
]; ];
private static _lpad(value: string, columnWidth: number, fill = ' ') { private static _lpad(value: string, columnWidth: number, fill = ' ') {

View File

@ -9,7 +9,6 @@
import {Provider, ReflectiveInjector} from '@angular/core'; import {Provider, ReflectiveInjector} from '@angular/core';
import {Options} from './common_options'; import {Options} from './common_options';
import {isPresent} from './facade/lang';
import {Metric} from './metric'; import {Metric} from './metric';
import {MultiMetric} from './metric/multi_metric'; import {MultiMetric} from './metric/multi_metric';
import {PerflogMetric} from './metric/perflog_metric'; import {PerflogMetric} from './metric/perflog_metric';
@ -49,16 +48,16 @@ export class Runner {
_DEFAULT_PROVIDERS, this._defaultProviders, {provide: Options.SAMPLE_ID, useValue: id}, _DEFAULT_PROVIDERS, this._defaultProviders, {provide: Options.SAMPLE_ID, useValue: id},
{provide: Options.EXECUTE, useValue: execute} {provide: Options.EXECUTE, useValue: execute}
]; ];
if (isPresent(prepare)) { if (prepare != null) {
sampleProviders.push({provide: Options.PREPARE, useValue: prepare}); sampleProviders.push({provide: Options.PREPARE, useValue: prepare});
} }
if (isPresent(microMetrics)) { if (microMetrics != null) {
sampleProviders.push({provide: Options.MICRO_METRICS, useValue: microMetrics}); sampleProviders.push({provide: Options.MICRO_METRICS, useValue: microMetrics});
} }
if (isPresent(userMetrics)) { if (userMetrics != null) {
sampleProviders.push({provide: Options.USER_METRICS, useValue: userMetrics}); sampleProviders.push({provide: Options.USER_METRICS, useValue: userMetrics});
} }
if (isPresent(providers)) { if (providers != null) {
sampleProviders.push(providers); sampleProviders.push(providers);
} }

View File

@ -9,7 +9,6 @@
import {Inject, Injectable} from '@angular/core'; import {Inject, Injectable} from '@angular/core';
import {Options} from './common_options'; import {Options} from './common_options';
import {isPresent} from './facade/lang';
import {MeasureValues} from './measure_values'; import {MeasureValues} from './measure_values';
import {Metric} from './metric'; import {Metric} from './metric';
import {Reporter} from './reporter'; import {Reporter} from './reporter';
@ -38,7 +37,7 @@ export class Sampler {
sample(): Promise<SampleState> { sample(): Promise<SampleState> {
const loop = (lastState: SampleState): Promise<SampleState> => { const loop = (lastState: SampleState): Promise<SampleState> => {
return this._iterate(lastState).then((newState) => { return this._iterate(lastState).then((newState) => {
if (isPresent(newState.validSample)) { if (newState.validSample != null) {
return newState; return newState;
} else { } else {
return loop(newState); return loop(newState);
@ -68,7 +67,7 @@ export class Sampler {
const completeSample = state.completeSample.concat([measureValues]); const completeSample = state.completeSample.concat([measureValues]);
const validSample = this._validator.validate(completeSample); const validSample = this._validator.validate(completeSample);
let resultPromise = this._reporter.reportMeasureValues(measureValues); let resultPromise = this._reporter.reportMeasureValues(measureValues);
if (isPresent(validSample)) { if (validSample != null) {
resultPromise = resultPromise =
resultPromise.then((_) => this._reporter.reportSample(completeSample, validSample)); resultPromise.then((_) => this._reporter.reportSample(completeSample, validSample));
} }

View File

@ -8,7 +8,6 @@
import {Injectable} from '@angular/core'; import {Injectable} from '@angular/core';
import {isPresent} from '../facade/lang';
import {WebDriverAdapter} from '../web_driver_adapter'; import {WebDriverAdapter} from '../web_driver_adapter';
import {PerfLogEvent, PerfLogFeatures, WebDriverExtension} from '../web_driver_extension'; import {PerfLogEvent, PerfLogFeatures, WebDriverExtension} from '../web_driver_extension';
@ -35,7 +34,7 @@ export class FirefoxDriverExtension extends WebDriverExtension {
timeEnd(name: string, restartName: string = null): Promise<any> { timeEnd(name: string, restartName: string = null): Promise<any> {
let script = 'window.markEnd("' + name + '");'; let script = 'window.markEnd("' + name + '");';
if (isPresent(restartName)) { if (restartName != null) {
script += 'window.markStart("' + restartName + '");'; script += 'window.markStart("' + restartName + '");';
} }
return this._driver.executeScript(script); return this._driver.executeScript(script);

View File

@ -8,7 +8,6 @@
import {Injectable} from '@angular/core'; import {Injectable} from '@angular/core';
import {isBlank, isPresent} from '../facade/lang';
import {WebDriverAdapter} from '../web_driver_adapter'; import {WebDriverAdapter} from '../web_driver_adapter';
import {PerfLogEvent, PerfLogFeatures, WebDriverExtension} from '../web_driver_extension'; import {PerfLogEvent, PerfLogFeatures, WebDriverExtension} from '../web_driver_extension';
@ -26,7 +25,7 @@ export class IOsDriverExtension extends WebDriverExtension {
timeEnd(name: string, restartName: string = null): Promise<any> { timeEnd(name: string, restartName: string = null): Promise<any> {
let script = `console.timeEnd('${name}');`; let script = `console.timeEnd('${name}');`;
if (isPresent(restartName)) { if (restartName != null) {
script += `console.time('${restartName}');`; script += `console.time('${restartName}');`;
} }
return this._driver.executeScript(script); return this._driver.executeScript(script);
@ -76,10 +75,10 @@ export class IOsDriverExtension extends WebDriverExtension {
endEvent = createEndEvent('render', endTime); endEvent = createEndEvent('render', endTime);
} }
// Note: ios used to support GCEvent up until iOS 6 :-( // Note: ios used to support GCEvent up until iOS 6 :-(
if (isPresent(record['children'])) { if (record['children'] != null) {
this._convertPerfRecordsToEvents(record['children'], events); this._convertPerfRecordsToEvents(record['children'], events);
} }
if (isPresent(endEvent)) { if (endEvent != null) {
events.push(endEvent); events.push(endEvent);
} }
}); });
@ -104,7 +103,7 @@ function createEvent(
// the perflog... // the perflog...
'pid': 'pid0' 'pid': 'pid0'
}; };
if (isPresent(args)) { if (args != null) {
result['args'] = args; result['args'] = args;
} }
return result; return result;

View File

@ -10,7 +10,6 @@ import {Provider} from '@angular/core';
import {AsyncTestCompleter, beforeEach, describe, expect, inject, it} from '@angular/core/testing/testing_internal'; import {AsyncTestCompleter, beforeEach, describe, expect, inject, it} from '@angular/core/testing/testing_internal';
import {Metric, Options, PerfLogEvent, PerfLogFeatures, PerflogMetric, ReflectiveInjector, WebDriverExtension} from '../../index'; import {Metric, Options, PerfLogEvent, PerfLogFeatures, PerflogMetric, ReflectiveInjector, WebDriverExtension} from '../../index';
import {isPresent} from '../../src/facade/lang';
import {TraceEventFactory} from '../trace_event_factory'; import {TraceEventFactory} from '../trace_event_factory';
export function main() { export function main() {
@ -48,16 +47,16 @@ export function main() {
useValue: new MockDriverExtension(perfLogs, commandLog, perfLogFeatures) useValue: new MockDriverExtension(perfLogs, commandLog, perfLogFeatures)
} }
]; ];
if (isPresent(forceGc)) { if (forceGc != null) {
providers.push({provide: Options.FORCE_GC, useValue: forceGc}); providers.push({provide: Options.FORCE_GC, useValue: forceGc});
} }
if (isPresent(captureFrames)) { if (captureFrames != null) {
providers.push({provide: Options.CAPTURE_FRAMES, useValue: captureFrames}); providers.push({provide: Options.CAPTURE_FRAMES, useValue: captureFrames});
} }
if (isPresent(receivedData)) { if (receivedData != null) {
providers.push({provide: Options.RECEIVED_DATA, useValue: receivedData}); providers.push({provide: Options.RECEIVED_DATA, useValue: receivedData});
} }
if (isPresent(requestCount)) { if (requestCount != null) {
providers.push({provide: Options.REQUEST_COUNT, useValue: requestCount}); providers.push({provide: Options.REQUEST_COUNT, useValue: requestCount});
} }
return ReflectiveInjector.resolveAndCreate(providers).get(PerflogMetric); return ReflectiveInjector.resolveAndCreate(providers).get(PerflogMetric);

View File

@ -10,7 +10,6 @@ import {Provider} from '@angular/core';
import {describe, expect, it} from '@angular/core/testing/testing_internal'; import {describe, expect, it} from '@angular/core/testing/testing_internal';
import {ConsoleReporter, MeasureValues, ReflectiveInjector, SampleDescription} from '../../index'; import {ConsoleReporter, MeasureValues, ReflectiveInjector, SampleDescription} from '../../index';
import {isBlank, isPresent} from '../../src/facade/lang';
export function main() { export function main() {
describe('console reporter', () => { describe('console reporter', () => {
@ -38,7 +37,7 @@ export function main() {
}, },
{provide: ConsoleReporter.PRINT, useValue: (line: string) => log.push(line)} {provide: ConsoleReporter.PRINT, useValue: (line: string) => log.push(line)}
]; ];
if (isPresent(columnWidth)) { if (columnWidth != null) {
providers.push({provide: ConsoleReporter.COLUMN_WIDTH, useValue: columnWidth}); providers.push({provide: ConsoleReporter.COLUMN_WIDTH, useValue: columnWidth});
} }
reporter = ReflectiveInjector.resolveAndCreate(providers).get(ConsoleReporter); reporter = ReflectiveInjector.resolveAndCreate(providers).get(ConsoleReporter);

View File

@ -9,7 +9,6 @@
import {AsyncTestCompleter, describe, expect, inject, it} from '@angular/core/testing/testing_internal'; import {AsyncTestCompleter, describe, expect, inject, it} from '@angular/core/testing/testing_internal';
import {JsonFileReporter, MeasureValues, Options, ReflectiveInjector, SampleDescription} from '../../index'; import {JsonFileReporter, MeasureValues, Options, ReflectiveInjector, SampleDescription} from '../../index';
import {isPresent} from '../../src/facade/lang';
export function main() { export function main() {
describe('file reporter', () => { describe('file reporter', () => {
@ -50,7 +49,7 @@ export function main() {
[mv(0, 0, {'a': 3, 'b': 6})], [mv(0, 0, {'a': 3, 'b': 6})],
[mv(0, 0, {'a': 3, 'b': 6}), mv(1, 1, {'a': 5, 'b': 9})]); [mv(0, 0, {'a': 3, 'b': 6}), mv(1, 1, {'a': 5, 'b': 9})]);
const regExp = /somePath\/someId_\d+\.json/; const regExp = /somePath\/someId_\d+\.json/;
expect(isPresent(loggedFile['filename'].match(regExp))).toBe(true); expect(loggedFile['filename'].match(regExp) != null).toBe(true);
const parsedContent = JSON.parse(loggedFile['content']); const parsedContent = JSON.parse(loggedFile['content']);
expect(parsedContent).toEqual({ expect(parsedContent).toEqual({
'description': { 'description': {

View File

@ -9,7 +9,6 @@
import {AsyncTestCompleter, describe, expect, inject, it} from '@angular/core/testing/testing_internal'; import {AsyncTestCompleter, describe, expect, inject, it} from '@angular/core/testing/testing_internal';
import {MeasureValues, Metric, Options, ReflectiveInjector, Reporter, Sampler, Validator, WebDriverAdapter} from '../index'; import {MeasureValues, Metric, Options, ReflectiveInjector, Reporter, Sampler, Validator, WebDriverAdapter} from '../index';
import {isBlank, isPresent} from '../src/facade/lang';
export function main() { export function main() {
const EMPTY_EXECUTE = () => {}; const EMPTY_EXECUTE = () => {};
@ -32,7 +31,7 @@ export function main() {
if (!reporter) { if (!reporter) {
reporter = new MockReporter([]); reporter = new MockReporter([]);
} }
if (isBlank(driver)) { if (driver == null) {
driver = new MockDriverAdapter([]); driver = new MockDriverAdapter([]);
} }
const providers = [ const providers = [
@ -41,7 +40,7 @@ export function main() {
{provide: Options.EXECUTE, useValue: execute}, {provide: Validator, useValue: validator}, {provide: Options.EXECUTE, useValue: execute}, {provide: Validator, useValue: validator},
{provide: Options.NOW, useValue: () => new Date(time++)} {provide: Options.NOW, useValue: () => new Date(time++)}
]; ];
if (isPresent(prepare)) { if (prepare != null) {
providers.push({provide: Options.PREPARE, useValue: prepare}); providers.push({provide: Options.PREPARE, useValue: prepare});
} }
@ -227,7 +226,7 @@ function createCountingMetric(log: any[] = []) {
class MockDriverAdapter extends WebDriverAdapter { class MockDriverAdapter extends WebDriverAdapter {
constructor(private _log: any[] = [], private _waitFor: Function = null) { super(); } constructor(private _log: any[] = [], private _waitFor: Function = null) { super(); }
waitFor(callback: Function): Promise<any> { waitFor(callback: Function): Promise<any> {
if (isPresent(this._waitFor)) { if (this._waitFor != null) {
return this._waitFor(callback); return this._waitFor(callback);
} else { } else {
return Promise.resolve(callback()); return Promise.resolve(callback());
@ -239,8 +238,7 @@ class MockDriverAdapter extends WebDriverAdapter {
class MockValidator extends Validator { class MockValidator extends Validator {
constructor(private _log: any[] = [], private _validate: Function = null) { super(); } constructor(private _log: any[] = [], private _validate: Function = null) { super(); }
validate(completeSample: MeasureValues[]): MeasureValues[] { validate(completeSample: MeasureValues[]): MeasureValues[] {
const stableSample = const stableSample = this._validate != null ? this._validate(completeSample) : completeSample;
isPresent(this._validate) ? this._validate(completeSample) : completeSample;
this._log.push(['validate', completeSample, stableSample]); this._log.push(['validate', completeSample, stableSample]);
return stableSample; return stableSample;
} }
@ -253,7 +251,7 @@ class MockMetric extends Metric {
return Promise.resolve(null); return Promise.resolve(null);
} }
endMeasure(restart: boolean) { endMeasure(restart: boolean) {
const measureValues = isPresent(this._endMeasure) ? this._endMeasure() : {}; const measureValues = this._endMeasure != null ? this._endMeasure() : {};
this._log.push(['endMeasure', restart, measureValues]); this._log.push(['endMeasure', restart, measureValues]);
return Promise.resolve(measureValues); return Promise.resolve(measureValues);
} }

View File

@ -7,7 +7,6 @@
*/ */
import {PerfLogEvent} from '../index'; import {PerfLogEvent} from '../index';
import {isPresent} from '../src/facade/lang';
export class TraceEventFactory { export class TraceEventFactory {
constructor(private _cat: string, private _pid: string) {} constructor(private _cat: string, private _pid: string) {}
@ -15,7 +14,7 @@ export class TraceEventFactory {
create(ph: any, name: string, time: number, args: any = null) { create(ph: any, name: string, time: number, args: any = null) {
const res: const res:
PerfLogEvent = {'name': name, 'cat': this._cat, 'ph': ph, 'ts': time, 'pid': this._pid}; PerfLogEvent = {'name': name, 'cat': this._cat, 'ph': ph, 'ts': time, 'pid': this._pid};
if (isPresent(args)) { if (args != null) {
res['args'] = args; res['args'] = args;
} }
return res; return res;

View File

@ -9,7 +9,6 @@
import {AsyncTestCompleter, describe, expect, inject, it} from '@angular/core/testing/testing_internal'; import {AsyncTestCompleter, describe, expect, inject, it} from '@angular/core/testing/testing_internal';
import {Options, ReflectiveInjector, WebDriverExtension} from '../index'; import {Options, ReflectiveInjector, WebDriverExtension} from '../index';
import {isPresent} from '../src/facade/lang';
export function main() { export function main() {
function createExtension(ids: any[], caps: any) { function createExtension(ids: any[], caps: any) {
@ -41,7 +40,7 @@ export function main() {
it('should throw if there is no match', it('should throw if there is no match',
inject([AsyncTestCompleter], (async: AsyncTestCompleter) => { inject([AsyncTestCompleter], (async: AsyncTestCompleter) => {
createExtension(['m1'], {'browser': 'm2'}).catch((err) => { createExtension(['m1'], {'browser': 'm2'}).catch((err) => {
expect(isPresent(err)).toBe(true); expect(err != null).toBe(true);
async.done(); async.done();
}); });
})); }));

View File

@ -9,7 +9,6 @@
import {AsyncTestCompleter, describe, expect, inject, it} from '@angular/core/testing/testing_internal'; import {AsyncTestCompleter, describe, expect, inject, it} from '@angular/core/testing/testing_internal';
import {ChromeDriverExtension, Options, ReflectiveInjector, WebDriverAdapter, WebDriverExtension} from '../../index'; import {ChromeDriverExtension, Options, ReflectiveInjector, WebDriverAdapter, WebDriverExtension} from '../../index';
import {isBlank} from '../../src/facade/lang';
import {TraceEventFactory} from '../trace_event_factory'; import {TraceEventFactory} from '../trace_event_factory';
export function main() { export function main() {
@ -38,7 +37,7 @@ export function main() {
if (!perfRecords) { if (!perfRecords) {
perfRecords = []; perfRecords = [];
} }
if (isBlank(userAgent)) { if (userAgent == null) {
userAgent = CHROME45_USER_AGENT; userAgent = CHROME45_USER_AGENT;
} }
log = []; log = [];

View File

@ -6,8 +6,7 @@
* found in the LICENSE file at https://angular.io/license * found in the LICENSE file at https://angular.io/license
*/ */
import {Directive, DoCheck, ElementRef, Input, IterableChanges, IterableDiffer, IterableDiffers, KeyValueChanges, KeyValueDiffer, KeyValueDiffers, Renderer, ɵisListLikeIterable as isListLikeIterable} from '@angular/core'; import {Directive, DoCheck, ElementRef, Input, IterableChanges, IterableDiffer, IterableDiffers, KeyValueChanges, KeyValueDiffer, KeyValueDiffers, Renderer, ɵisListLikeIterable as isListLikeIterable, ɵstringify as stringify} from '@angular/core';
import {stringify} from '../facade/lang';
/** /**
* @ngModule CommonModule * @ngModule CommonModule

View File

@ -8,8 +8,6 @@
import {ChangeDetectorRef, Directive, DoCheck, EmbeddedViewRef, Input, IterableChangeRecord, IterableChanges, IterableDiffer, IterableDiffers, NgIterable, OnChanges, SimpleChanges, TemplateRef, TrackByFunction, ViewContainerRef, forwardRef, isDevMode} from '@angular/core'; import {ChangeDetectorRef, Directive, DoCheck, EmbeddedViewRef, Input, IterableChangeRecord, IterableChanges, IterableDiffer, IterableDiffers, NgIterable, OnChanges, SimpleChanges, TemplateRef, TrackByFunction, ViewContainerRef, forwardRef, isDevMode} from '@angular/core';
import {getTypeNameForDebugging} from '../facade/lang';
export class NgForOfRow<T> { export class NgForOfRow<T> {
constructor(public $implicit: T, public index: number, public count: number) {} constructor(public $implicit: T, public index: number, public count: number) {}
@ -195,3 +193,7 @@ export type NgFor = NgForOf<any>;
* @deprecated from v4.0.0 - Use NgForOf instead. * @deprecated from v4.0.0 - Use NgForOf instead.
*/ */
export const NgFor = NgForOf; export const NgFor = NgForOf;
export function getTypeNameForDebugging(type: any): string {
return type['name'] || typeof type;
}

View File

@ -1 +0,0 @@
../../facade/src

View File

@ -8,7 +8,6 @@
import {Inject, Injectable, Optional} from '@angular/core'; import {Inject, Injectable, Optional} from '@angular/core';
import {isPresent} from '../facade/lang';
import {Location} from './location'; import {Location} from './location';
import {APP_BASE_HREF, LocationStrategy} from './location_strategy'; import {APP_BASE_HREF, LocationStrategy} from './location_strategy';
@ -40,7 +39,7 @@ export class HashLocationStrategy extends LocationStrategy {
private _platformLocation: PlatformLocation, private _platformLocation: PlatformLocation,
@Optional() @Inject(APP_BASE_HREF) _baseHref?: string) { @Optional() @Inject(APP_BASE_HREF) _baseHref?: string) {
super(); super();
if (isPresent(_baseHref)) { if (_baseHref != null) {
this._baseHref = _baseHref; this._baseHref = _baseHref;
} }
} }
@ -56,7 +55,7 @@ export class HashLocationStrategy extends LocationStrategy {
// the hash value is always prefixed with a `#` // the hash value is always prefixed with a `#`
// and if it is empty then it will stay empty // and if it is empty then it will stay empty
let path = this._platformLocation.hash; let path = this._platformLocation.hash;
if (!isPresent(path)) path = '#'; if (path == null) path = '#';
return path.length > 0 ? path.substring(1) : path; return path.length > 0 ? path.substring(1) : path;
} }

View File

@ -8,7 +8,6 @@
import {Inject, Injectable, Optional} from '@angular/core'; import {Inject, Injectable, Optional} from '@angular/core';
import {isBlank} from '../facade/lang';
import {Location} from './location'; import {Location} from './location';
import {APP_BASE_HREF, LocationStrategy} from './location_strategy'; import {APP_BASE_HREF, LocationStrategy} from './location_strategy';
@ -51,11 +50,11 @@ export class PathLocationStrategy extends LocationStrategy {
@Optional() @Inject(APP_BASE_HREF) href?: string) { @Optional() @Inject(APP_BASE_HREF) href?: string) {
super(); super();
if (isBlank(href)) { if (href == null) {
href = this._platformLocation.getBaseHrefFromDOM(); href = this._platformLocation.getBaseHrefFromDOM();
} }
if (isBlank(href)) { if (href == null) {
throw new Error( throw new Error(
`No base href set. Please provide a value for the APP_BASE_HREF token or add a base element to the document.`); `No base href set. Please provide a value for the APP_BASE_HREF token or add a base element to the document.`);
} }

View File

@ -7,9 +7,9 @@
*/ */
import {Inject, LOCALE_ID, Pipe, PipeTransform} from '@angular/core'; import {Inject, LOCALE_ID, Pipe, PipeTransform} from '@angular/core';
import {NumberWrapper} from '../facade/lang';
import {DateFormatter} from './intl'; import {DateFormatter} from './intl';
import {invalidPipeArgumentError} from './invalid_pipe_argument_error'; import {invalidPipeArgumentError} from './invalid_pipe_argument_error';
import {isNumeric} from './number_pipe';
const ISO8601_DATE_REGEX = const ISO8601_DATE_REGEX =
/^(\d{4})-?(\d\d)-?(\d\d)(?:T(\d\d)(?::?(\d\d)(?::?(\d\d)(?:\.(\d+))?)?)?(Z|([+-])(\d\d):?(\d\d))?)?$/; /^(\d{4})-?(\d\d)-?(\d\d)(?:T(\d\d)(?::?(\d\d)(?::?(\d\d)(?:\.(\d+))?)?)?(Z|([+-])(\d\d):?(\d\d))?)?$/;
@ -111,7 +111,7 @@ export class DatePipe implements PipeTransform {
if (isDate(value)) { if (isDate(value)) {
date = value; date = value;
} else if (NumberWrapper.isNumeric(value)) { } else if (isNumeric(value)) {
date = new Date(parseFloat(value)); date = new Date(parseFloat(value));
} else if (typeof value === 'string' && /^(\d{4}-\d{1,2}-\d{1,2})$/.test(value)) { } else if (typeof value === 'string' && /^(\d{4}-\d{1,2}-\d{1,2})$/.test(value)) {
/** /**

View File

@ -6,9 +6,7 @@
* found in the LICENSE file at https://angular.io/license * found in the LICENSE file at https://angular.io/license
*/ */
import {Type} from '@angular/core'; import {Type, ɵstringify as stringify} from '@angular/core';
import {stringify} from '../facade/lang';
export function invalidPipeArgumentError(type: Type<any>, value: Object) { export function invalidPipeArgumentError(type: Type<any>, value: Object) {
return Error(`InvalidPipeArgument: '${value}' for pipe '${stringify(type)}'`); return Error(`InvalidPipeArgument: '${value}' for pipe '${stringify(type)}'`);

View File

@ -7,9 +7,6 @@
*/ */
import {Inject, LOCALE_ID, Pipe, PipeTransform, Type} from '@angular/core'; import {Inject, LOCALE_ID, Pipe, PipeTransform, Type} from '@angular/core';
import {NumberWrapper} from '../facade/lang';
import {NumberFormatStyle, NumberFormatter} from './intl'; import {NumberFormatStyle, NumberFormatter} from './intl';
import {invalidPipeArgumentError} from './invalid_pipe_argument_error'; import {invalidPipeArgumentError} from './invalid_pipe_argument_error';
@ -21,7 +18,7 @@ function formatNumber(
if (value == null) return null; if (value == null) return null;
// Convert strings to numbers // Convert strings to numbers
value = typeof value === 'string' && NumberWrapper.isNumeric(value) ? +value : value; value = typeof value === 'string' && isNumeric(value) ? +value : value;
if (typeof value !== 'number') { if (typeof value !== 'number') {
throw invalidPipeArgumentError(pipe, value); throw invalidPipeArgumentError(pipe, value);
} }
@ -42,13 +39,13 @@ function formatNumber(
throw new Error(`${digits} is not a valid digit info for number pipes`); throw new Error(`${digits} is not a valid digit info for number pipes`);
} }
if (parts[1] != null) { // min integer digits if (parts[1] != null) { // min integer digits
minInt = NumberWrapper.parseIntAutoRadix(parts[1]); minInt = parseIntAutoRadix(parts[1]);
} }
if (parts[3] != null) { // min fraction digits if (parts[3] != null) { // min fraction digits
minFraction = NumberWrapper.parseIntAutoRadix(parts[3]); minFraction = parseIntAutoRadix(parts[3]);
} }
if (parts[5] != null) { // max fraction digits if (parts[5] != null) { // max fraction digits
maxFraction = NumberWrapper.parseIntAutoRadix(parts[5]); maxFraction = parseIntAutoRadix(parts[5]);
} }
} }
@ -162,3 +159,15 @@ export class CurrencyPipe implements PipeTransform {
symbolDisplay); symbolDisplay);
} }
} }
function parseIntAutoRadix(text: string): number {
const result: number = parseInt(text);
if (isNaN(result)) {
throw new Error('Invalid integer literal when parsing ' + text);
}
return result;
}
export function isNumeric(value: any): boolean {
return !isNaN(value - parseFloat(value));
}

View File

@ -7,6 +7,7 @@
*/ */
import {CurrencyPipe, DecimalPipe, PercentPipe} from '@angular/common'; import {CurrencyPipe, DecimalPipe, PercentPipe} from '@angular/common';
import {isNumeric} from '@angular/common/src/pipes/number_pipe';
import {beforeEach, describe, expect, it} from '@angular/core/testing/testing_internal'; import {beforeEach, describe, expect, it} from '@angular/core/testing/testing_internal';
import {browserDetection} from '@angular/platform-browser/testing/browser_util'; import {browserDetection} from '@angular/platform-browser/testing/browser_util';
@ -80,6 +81,26 @@ export function main() {
() => { expect(() => pipe.transform(new Object())).toThrowError(); }); () => { expect(() => pipe.transform(new Object())).toThrowError(); });
}); });
}); });
describe('isNumeric', () => {
it('should return true when passing correct numeric string',
() => { expect(isNumeric('2')).toBe(true); });
it('should return true when passing correct double string',
() => { expect(isNumeric('1.123')).toBe(true); });
it('should return true when passing correct negative string',
() => { expect(isNumeric('-2')).toBe(true); });
it('should return true when passing correct scientific notation string',
() => { expect(isNumeric('1e5')).toBe(true); });
it('should return false when passing incorrect numeric',
() => { expect(isNumeric('a')).toBe(false); });
it('should return false when passing parseable but non numeric',
() => { expect(isNumeric('2a')).toBe(false); });
});
}); });
} }

View File

@ -1 +0,0 @@
../../facade/src

View File

@ -8,10 +8,9 @@
import {isDevMode} from '@angular/core'; import {isDevMode} from '@angular/core';
import {isBlank, isPresent} from '../src/facade/lang';
export function assertArrayOfStrings(identifier: string, value: any) { export function assertArrayOfStrings(identifier: string, value: any) {
if (!isDevMode() || isBlank(value)) { if (!isDevMode() || value == null) {
return; return;
} }
if (!Array.isArray(value)) { if (!Array.isArray(value)) {
@ -33,9 +32,9 @@ const INTERPOLATION_BLACKLIST_REGEXPS = [
]; ];
export function assertInterpolationSymbols(identifier: string, value: any): void { export function assertInterpolationSymbols(identifier: string, value: any): void {
if (isPresent(value) && !(Array.isArray(value) && value.length == 2)) { if (value != null && !(Array.isArray(value) && value.length == 2)) {
throw new Error(`Expected '${identifier}' to be an array, [start, end].`); throw new Error(`Expected '${identifier}' to be an array, [start, end].`);
} else if (isDevMode() && !isBlank(value)) { } else if (isDevMode() && value != null) {
const start = value[0] as string; const start = value[0] as string;
const end = value[1] as string; const end = value[1] as string;
// black list checking // black list checking

View File

@ -6,9 +6,8 @@
* found in the LICENSE file at https://angular.io/license * found in the LICENSE file at https://angular.io/license
*/ */
import {ChangeDetectionStrategy, ComponentFactory, RendererTypeV2, SchemaMetadata, Type, ViewEncapsulation, ɵLifecycleHooks, ɵreflector} from '@angular/core'; import {ChangeDetectionStrategy, ComponentFactory, RendererTypeV2, SchemaMetadata, Type, ViewEncapsulation, ɵLifecycleHooks, ɵreflector, ɵstringify as stringify} from '@angular/core';
import {StaticSymbol} from './aot/static_symbol'; import {StaticSymbol} from './aot/static_symbol';
import {isPresent, stringify} from './facade/lang';
import {CssSelector} from './selector'; import {CssSelector} from './selector';
import {splitAtColon} from './util'; import {splitAtColon} from './util';
@ -179,12 +178,11 @@ export interface CompileFactoryMetadata extends CompileIdentifierMetadata {
} }
export function tokenName(token: CompileTokenMetadata) { export function tokenName(token: CompileTokenMetadata) {
return isPresent(token.value) ? _sanitizeIdentifier(token.value) : return token.value != null ? _sanitizeIdentifier(token.value) : identifierName(token.identifier);
identifierName(token.identifier);
} }
export function tokenReference(token: CompileTokenMetadata) { export function tokenReference(token: CompileTokenMetadata) {
if (isPresent(token.identifier)) { if (token.identifier != null) {
return token.identifier.reference; return token.identifier.reference;
} else { } else {
return token.value; return token.value;
@ -346,21 +344,21 @@ export class CompileDirectiveMetadata {
const hostListeners: {[key: string]: string} = {}; const hostListeners: {[key: string]: string} = {};
const hostProperties: {[key: string]: string} = {}; const hostProperties: {[key: string]: string} = {};
const hostAttributes: {[key: string]: string} = {}; const hostAttributes: {[key: string]: string} = {};
if (isPresent(host)) { if (host != null) {
Object.keys(host).forEach(key => { Object.keys(host).forEach(key => {
const value = host[key]; const value = host[key];
const matches = key.match(HOST_REG_EXP); const matches = key.match(HOST_REG_EXP);
if (matches === null) { if (matches === null) {
hostAttributes[key] = value; hostAttributes[key] = value;
} else if (isPresent(matches[1])) { } else if (matches[1] != null) {
hostProperties[matches[1]] = value; hostProperties[matches[1]] = value;
} else if (isPresent(matches[2])) { } else if (matches[2] != null) {
hostListeners[matches[2]] = value; hostListeners[matches[2]] = value;
} }
}); });
} }
const inputsMap: {[key: string]: string} = {}; const inputsMap: {[key: string]: string} = {};
if (isPresent(inputs)) { if (inputs != null) {
inputs.forEach((bindConfig: string) => { inputs.forEach((bindConfig: string) => {
// canonical syntax: `dirProp: elProp` // canonical syntax: `dirProp: elProp`
// if there is no `:`, use dirProp = elProp // if there is no `:`, use dirProp = elProp
@ -369,7 +367,7 @@ export class CompileDirectiveMetadata {
}); });
} }
const outputsMap: {[key: string]: string} = {}; const outputsMap: {[key: string]: string} = {};
if (isPresent(outputs)) { if (outputs != null) {
outputs.forEach((bindConfig: string) => { outputs.forEach((bindConfig: string) => {
// canonical syntax: `dirProp: elProp` // canonical syntax: `dirProp: elProp`
// if there is no `:`, use dirProp = elProp // if there is no `:`, use dirProp = elProp

View File

@ -8,7 +8,6 @@
import * as cdAst from '../expression_parser/ast'; import * as cdAst from '../expression_parser/ast';
import {isBlank} from '../facade/lang';
import {Identifiers, createIdentifier} from '../identifiers'; import {Identifiers, createIdentifier} from '../identifiers';
import * as o from '../output/output_ast'; import * as o from '../output/output_ast';
@ -338,7 +337,7 @@ class _AstToIrVisitor implements cdAst.AstVisitor {
result = varExpr.callFn(args); result = varExpr.callFn(args);
} }
} }
if (isBlank(result)) { if (result == null) {
result = receiver.callMethod(ast.name, args); result = receiver.callMethod(ast.name, args);
} }
return convertToStatementIfNeeded(mode, result); return convertToStatementIfNeeded(mode, result);
@ -359,7 +358,7 @@ class _AstToIrVisitor implements cdAst.AstVisitor {
if (receiver === this._implicitReceiver) { if (receiver === this._implicitReceiver) {
result = this._getLocal(ast.name); result = this._getLocal(ast.name);
} }
if (isBlank(result)) { if (result == null) {
result = receiver.prop(ast.name); result = receiver.prop(ast.name);
} }
return convertToStatementIfNeeded(mode, result); return convertToStatementIfNeeded(mode, result);

View File

@ -8,7 +8,6 @@
import * as chars from '../chars'; import * as chars from '../chars';
import {isPresent} from '../facade/lang';
export enum CssTokenType { export enum CssTokenType {
EOF, EOF,
@ -200,9 +199,9 @@ export class CssScanner {
let next: CssToken; let next: CssToken;
const output = this.scan(); const output = this.scan();
if (isPresent(output)) { if (output != null) {
// just incase the inner scan method returned an error // just incase the inner scan method returned an error
if (isPresent(output.error)) { if (output.error != null) {
this.setMode(mode); this.setMode(mode);
return output; return output;
} }
@ -210,7 +209,7 @@ export class CssScanner {
next = output.token; next = output.token;
} }
if (!isPresent(next)) { if (next == null) {
next = new CssToken(this.index, this.column, this.line, CssTokenType.EOF, 'end of file'); next = new CssToken(this.index, this.column, this.line, CssTokenType.EOF, 'end of file');
} }
@ -227,11 +226,11 @@ export class CssScanner {
this.setMode(mode); this.setMode(mode);
let error: Error = null; let error: Error = null;
if (!isMatchingType || (isPresent(value) && value != next.strValue)) { if (!isMatchingType || (value != null && value != next.strValue)) {
let errorMessage = let errorMessage =
CssTokenType[next.type] + ' does not match expected ' + CssTokenType[type] + ' value'; CssTokenType[next.type] + ' does not match expected ' + CssTokenType[type] + ' value';
if (isPresent(value)) { if (value != null) {
errorMessage += ' ("' + next.strValue + '" should match "' + value + '")'; errorMessage += ' ("' + next.strValue + '" should match "' + value + '")';
} }

View File

@ -7,7 +7,6 @@
*/ */
import * as chars from '../chars'; import * as chars from '../chars';
import {isPresent} from '../facade/lang';
import {ParseError, ParseLocation, ParseSourceFile, ParseSourceSpan} from '../parse_util'; import {ParseError, ParseLocation, ParseSourceFile, ParseSourceSpan} from '../parse_util';
import {BlockType, CssAst, CssAtRulePredicateAst, CssBlockAst, CssBlockDefinitionRuleAst, CssBlockRuleAst, CssDefinitionAst, CssInlineRuleAst, CssKeyframeDefinitionAst, CssKeyframeRuleAst, CssMediaQueryRuleAst, CssPseudoSelectorAst, CssRuleAst, CssSelectorAst, CssSelectorRuleAst, CssSimpleSelectorAst, CssStyleSheetAst, CssStyleValueAst, CssStylesBlockAst, CssUnknownRuleAst, CssUnknownTokenListAst, mergeTokens} from './css_ast'; import {BlockType, CssAst, CssAtRulePredicateAst, CssBlockAst, CssBlockDefinitionRuleAst, CssBlockRuleAst, CssDefinitionAst, CssInlineRuleAst, CssKeyframeDefinitionAst, CssKeyframeRuleAst, CssMediaQueryRuleAst, CssPseudoSelectorAst, CssRuleAst, CssSelectorAst, CssSelectorRuleAst, CssSimpleSelectorAst, CssStyleSheetAst, CssStyleValueAst, CssStylesBlockAst, CssUnknownRuleAst, CssUnknownTokenListAst, mergeTokens} from './css_ast';
@ -127,7 +126,7 @@ export class CssParser {
} }
/** @internal */ /** @internal */
_getSourceContent(): string { return isPresent(this._scanner) ? this._scanner.input : ''; } _getSourceContent(): string { return this._scanner != null ? this._scanner.input : ''; }
/** @internal */ /** @internal */
_extractSourceContent(start: number, end: number): string { _extractSourceContent(start: number, end: number): string {
@ -141,7 +140,7 @@ export class CssParser {
startLoc = start.location.start; startLoc = start.location.start;
} else { } else {
let token = start; let token = start;
if (!isPresent(token)) { if (token == null) {
// the data here is invalid, however, if and when this does // the data here is invalid, however, if and when this does
// occur, any other errors associated with this will be collected // occur, any other errors associated with this will be collected
token = this._lastToken; token = this._lastToken;
@ -149,7 +148,7 @@ export class CssParser {
startLoc = new ParseLocation(this._file, token.index, token.line, token.column); startLoc = new ParseLocation(this._file, token.index, token.line, token.column);
} }
if (!isPresent(end)) { if (end == null) {
end = this._lastToken; end = this._lastToken;
} }
@ -329,7 +328,7 @@ export class CssParser {
let ruleAst: CssRuleAst; let ruleAst: CssRuleAst;
let span: ParseSourceSpan; let span: ParseSourceSpan;
const startSelector = selectors[0]; const startSelector = selectors[0];
if (isPresent(block)) { if (block != null) {
span = this._generateSourceSpan(startSelector, block); span = this._generateSourceSpan(startSelector, block);
ruleAst = new CssSelectorRuleAst(span, selectors, block); ruleAst = new CssSelectorRuleAst(span, selectors, block);
} else { } else {
@ -377,7 +376,7 @@ export class CssParser {
const output = this._scanner.scan(); const output = this._scanner.scan();
const token = output.token; const token = output.token;
const error = output.error; const error = output.error;
if (isPresent(error)) { if (error != null) {
this._error(getRawMessage(error), token); this._error(getRawMessage(error), token);
} }
this._lastToken = token; this._lastToken = token;
@ -392,7 +391,7 @@ export class CssParser {
const output = this._scanner.consume(type, value); const output = this._scanner.consume(type, value);
const token = output.token; const token = output.token;
const error = output.error; const error = output.error;
if (isPresent(error)) { if (error != null) {
this._error(getRawMessage(error), token); this._error(getRawMessage(error), token);
} }
this._lastToken = token; this._lastToken = token;
@ -601,7 +600,7 @@ export class CssParser {
let index = lastOperatorToken.index; let index = lastOperatorToken.index;
let line = lastOperatorToken.line; let line = lastOperatorToken.line;
let column = lastOperatorToken.column; let column = lastOperatorToken.column;
if (isPresent(deepToken) && deepToken.strValue.toLowerCase() == 'deep' && if (deepToken != null && deepToken.strValue.toLowerCase() == 'deep' &&
deepSlash.strValue == SLASH_CHARACTER) { deepSlash.strValue == SLASH_CHARACTER) {
token = new CssToken( token = new CssToken(
lastOperatorToken.index, lastOperatorToken.column, lastOperatorToken.line, lastOperatorToken.index, lastOperatorToken.column, lastOperatorToken.line,
@ -636,7 +635,7 @@ export class CssParser {
// so long as there is an operator then we can have an // so long as there is an operator then we can have an
// ending value that is beyond the selector value ... // ending value that is beyond the selector value ...
// otherwise it's just a bunch of trailing whitespace // otherwise it's just a bunch of trailing whitespace
if (isPresent(operator)) { if (operator != null) {
end = operator.index; end = operator.index;
} }
} }
@ -664,7 +663,7 @@ export class CssParser {
startTokenOrAst = startTokenOrAst || pseudoSelectors[0]; startTokenOrAst = startTokenOrAst || pseudoSelectors[0];
endTokenOrAst = pseudoSelectors[pseudoSelectors.length - 1]; endTokenOrAst = pseudoSelectors[pseudoSelectors.length - 1];
} }
if (isPresent(operator)) { if (operator != null) {
startTokenOrAst = startTokenOrAst || operator; startTokenOrAst = startTokenOrAst || operator;
endTokenOrAst = operator; endTokenOrAst = operator;
} }
@ -702,7 +701,7 @@ export class CssParser {
let previous: CssToken; let previous: CssToken;
while (!characterContainsDelimiter(this._scanner.peek, delimiters)) { while (!characterContainsDelimiter(this._scanner.peek, delimiters)) {
let token: CssToken; let token: CssToken;
if (isPresent(previous) && previous.type == CssTokenType.Identifier && if (previous != null && previous.type == CssTokenType.Identifier &&
this._scanner.peek == chars.$LPAREN) { this._scanner.peek == chars.$LPAREN) {
token = this._consume(CssTokenType.Character, '('); token = this._consume(CssTokenType.Character, '(');
tokens.push(token); tokens.push(token);
@ -753,7 +752,7 @@ export class CssParser {
_collectUntilDelim(delimiters: number, assertType: CssTokenType = null): CssToken[] { _collectUntilDelim(delimiters: number, assertType: CssTokenType = null): CssToken[] {
const tokens: CssToken[] = []; const tokens: CssToken[] = [];
while (!characterContainsDelimiter(this._scanner.peek, delimiters)) { while (!characterContainsDelimiter(this._scanner.peek, delimiters)) {
const val = isPresent(assertType) ? this._consume(assertType) : this._scan(); const val = assertType != null ? this._consume(assertType) : this._scan();
tokens.push(val); tokens.push(val);
} }
return tokens; return tokens;

View File

@ -6,11 +6,9 @@
* found in the LICENSE file at https://angular.io/license * found in the LICENSE file at https://angular.io/license
*/ */
import {ViewEncapsulation} from '@angular/core'; import {ViewEncapsulation, ɵstringify as stringify} from '@angular/core';
import {CompileAnimationEntryMetadata, CompileDirectiveMetadata, CompileStylesheetMetadata, CompileTemplateMetadata} from './compile_metadata'; import {CompileAnimationEntryMetadata, CompileDirectiveMetadata, CompileStylesheetMetadata, CompileTemplateMetadata} from './compile_metadata';
import {CompilerConfig} from './config'; import {CompilerConfig} from './config';
import {stringify} from './facade/lang';
import {CompilerInjectable} from './injectable'; import {CompilerInjectable} from './injectable';
import * as html from './ml_parser/ast'; import * as html from './ml_parser/ast';
import {HtmlParser} from './ml_parser/html_parser'; import {HtmlParser} from './ml_parser/html_parser';

View File

@ -6,9 +6,7 @@
* found in the LICENSE file at https://angular.io/license * found in the LICENSE file at https://angular.io/license
*/ */
import {Component, Directive, HostBinding, HostListener, Input, Output, Query, Type, resolveForwardRef, ɵReflectorReader, ɵmerge as merge, ɵreflector} from '@angular/core'; import {Component, Directive, HostBinding, HostListener, Input, Output, Query, Type, resolveForwardRef, ɵReflectorReader, ɵmerge as merge, ɵreflector, ɵstringify as stringify} from '@angular/core';
import {stringify} from './facade/lang';
import {CompilerInjectable} from './injectable'; import {CompilerInjectable} from './injectable';
import {splitAtColon} from './util'; import {splitAtColon} from './util';

View File

@ -7,7 +7,6 @@
*/ */
import {isBlank} from '../facade/lang';
export class ParserError { export class ParserError {
public message: string; public message: string;
@ -196,7 +195,7 @@ export class ASTWithSource extends AST {
constructor( constructor(
public ast: AST, public source: string, public location: string, public ast: AST, public source: string, public location: string,
public errors: ParserError[]) { public errors: ParserError[]) {
super(new ParseSpan(0, isBlank(source) ? 0 : source.length)); super(new ParseSpan(0, source == null ? 0 : source.length));
} }
visit(visitor: AstVisitor, context: any = null): any { return this.ast.visit(visitor, context); } visit(visitor: AstVisitor, context: any = null): any { return this.ast.visit(visitor, context); }
toString(): string { return `${this.source} in ${this.location}`; } toString(): string { return `${this.source} in ${this.location}`; }

View File

@ -7,7 +7,6 @@
*/ */
import * as chars from '../chars'; import * as chars from '../chars';
import {NumberWrapper} from '../facade/lang';
import {CompilerInjectable} from '../injectable'; import {CompilerInjectable} from '../injectable';
export enum TokenType { export enum TokenType {
@ -276,7 +275,7 @@ class _Scanner {
this.advance(); this.advance();
} }
const str: string = this.input.substring(start, this.index); const str: string = this.input.substring(start, this.index);
const value: number = simple ? NumberWrapper.parseIntAutoRadix(str) : parseFloat(str); const value: number = simple ? parseIntAutoRadix(str) : parseFloat(str);
return newNumberToken(start, value); return newNumberToken(start, value);
} }
@ -383,3 +382,11 @@ function unescape(code: number): number {
return code; return code;
} }
} }
function parseIntAutoRadix(text: string): number {
const result: number = parseInt(text);
if (isNaN(result)) {
throw new Error('Invalid integer literal when parsing ' + text);
}
return result;
}

View File

@ -7,10 +7,9 @@
*/ */
import * as chars from '../chars'; import * as chars from '../chars';
import {escapeRegExp, isBlank, isPresent} from '../facade/lang';
import {CompilerInjectable} from '../injectable'; import {CompilerInjectable} from '../injectable';
import {DEFAULT_INTERPOLATION_CONFIG, InterpolationConfig} from '../ml_parser/interpolation_config'; import {DEFAULT_INTERPOLATION_CONFIG, InterpolationConfig} from '../ml_parser/interpolation_config';
import {escapeRegExp} from '../util';
import {AST, ASTWithSource, AstVisitor, Binary, BindingPipe, Chain, Conditional, EmptyExpr, FunctionCall, ImplicitReceiver, Interpolation, KeyedRead, KeyedWrite, LiteralArray, LiteralMap, LiteralPrimitive, MethodCall, ParseSpan, ParserError, PrefixNot, PropertyRead, PropertyWrite, Quote, SafeMethodCall, SafePropertyRead, TemplateBinding} from './ast'; import {AST, ASTWithSource, AstVisitor, Binary, BindingPipe, Chain, Conditional, EmptyExpr, FunctionCall, ImplicitReceiver, Interpolation, KeyedRead, KeyedWrite, LiteralArray, LiteralMap, LiteralPrimitive, MethodCall, ParseSpan, ParserError, PrefixNot, PropertyRead, PropertyWrite, Quote, SafeMethodCall, SafePropertyRead, TemplateBinding} from './ast';
import {EOF, Lexer, Token, TokenType, isIdentifier, isQuote} from './lexer'; import {EOF, Lexer, Token, TokenType, isIdentifier, isQuote} from './lexer';
@ -78,7 +77,7 @@ export class Parser {
// our lexer or parser for that, so we check for that ahead of time. // our lexer or parser for that, so we check for that ahead of time.
const quote = this._parseQuote(input, location); const quote = this._parseQuote(input, location);
if (isPresent(quote)) { if (quote != null) {
return quote; return quote;
} }
@ -92,7 +91,7 @@ export class Parser {
} }
private _parseQuote(input: string, location: any): AST { private _parseQuote(input: string, location: any): AST {
if (isBlank(input)) return null; if (input == null) return null;
const prefixSeparatorIndex = input.indexOf(':'); const prefixSeparatorIndex = input.indexOf(':');
if (prefixSeparatorIndex == -1) return null; if (prefixSeparatorIndex == -1) return null;
const prefix = input.substring(0, prefixSeparatorIndex).trim(); const prefix = input.substring(0, prefixSeparatorIndex).trim();
@ -137,7 +136,7 @@ export class Parser {
return new ASTWithSource( return new ASTWithSource(
new Interpolation( new Interpolation(
new ParseSpan(0, isBlank(input) ? 0 : input.length), split.strings, expressions), new ParseSpan(0, input == null ? 0 : input.length), split.strings, expressions),
input, location, this.errors); input, location, this.errors);
} }
@ -178,13 +177,13 @@ export class Parser {
wrapLiteralPrimitive(input: string, location: any): ASTWithSource { wrapLiteralPrimitive(input: string, location: any): ASTWithSource {
return new ASTWithSource( return new ASTWithSource(
new LiteralPrimitive(new ParseSpan(0, isBlank(input) ? 0 : input.length), input), input, new LiteralPrimitive(new ParseSpan(0, input == null ? 0 : input.length), input), input,
location, this.errors); location, this.errors);
} }
private _stripComments(input: string): string { private _stripComments(input: string): string {
const i = this._commentStart(input); const i = this._commentStart(input);
return isPresent(i) ? input.substring(0, i).trim() : input; return i != null ? input.substring(0, i).trim() : input;
} }
private _commentStart(input: string): number { private _commentStart(input: string): number {
@ -193,11 +192,11 @@ export class Parser {
const char = input.charCodeAt(i); const char = input.charCodeAt(i);
const nextChar = input.charCodeAt(i + 1); const nextChar = input.charCodeAt(i + 1);
if (char === chars.$SLASH && nextChar == chars.$SLASH && isBlank(outerQuote)) return i; if (char === chars.$SLASH && nextChar == chars.$SLASH && outerQuote == null) return i;
if (outerQuote === char) { if (outerQuote === char) {
outerQuote = null; outerQuote = null;
} else if (isBlank(outerQuote) && isQuote(char)) { } else if (outerQuote == null && isQuote(char)) {
outerQuote = char; outerQuote = char;
} }
} }
@ -728,7 +727,7 @@ export class _ParseAST {
} }
private locationText(index: number = null) { private locationText(index: number = null) {
if (isBlank(index)) index = this.index; if (index == null) index = this.index;
return (index < this.tokens.length) ? `at column ${this.tokens[index].index + 1} in` : return (index < this.tokens.length) ? `at column ${this.tokens[index].index + 1} in` :
`at the end of the expression`; `at the end of the expression`;
} }

View File

@ -1 +0,0 @@
../../facade/src

View File

@ -6,11 +6,10 @@
* found in the LICENSE file at https://angular.io/license * found in the LICENSE file at https://angular.io/license
*/ */
import {Compiler, ComponentFactory, Inject, Injector, ModuleWithComponentFactories, NgModuleFactory, Type, ɵgetComponentViewDefinitionFactory as getComponentViewDefinitionFactory} from '@angular/core'; import {Compiler, ComponentFactory, Inject, Injector, ModuleWithComponentFactories, NgModuleFactory, Type, ɵgetComponentViewDefinitionFactory as getComponentViewDefinitionFactory, ɵstringify as stringify} from '@angular/core';
import {CompileDirectiveMetadata, CompileIdentifierMetadata, CompileNgModuleMetadata, ProviderMeta, ProxyClass, createHostComponentMeta, identifierName} from '../compile_metadata'; import {CompileDirectiveMetadata, CompileIdentifierMetadata, CompileNgModuleMetadata, ProviderMeta, ProxyClass, createHostComponentMeta, identifierName} from '../compile_metadata';
import {CompilerConfig} from '../config'; import {CompilerConfig} from '../config';
import {stringify} from '../facade/lang';
import {CompilerInjectable} from '../injectable'; import {CompilerInjectable} from '../injectable';
import {CompileMetadataResolver} from '../metadata_resolver'; import {CompileMetadataResolver} from '../metadata_resolver';
import {NgModuleCompiler} from '../ng_module_compiler'; import {NgModuleCompiler} from '../ng_module_compiler';

View File

@ -6,8 +6,7 @@
* found in the LICENSE file at https://angular.io/license * found in the LICENSE file at https://angular.io/license
*/ */
import {Attribute, ChangeDetectionStrategy, Component, ComponentFactory, Directive, Host, Inject, Injectable, InjectionToken, ModuleWithProviders, Optional, Provider, Query, RendererTypeV2, SchemaMetadata, Self, SkipSelf, Type, resolveForwardRef, ɵERROR_COMPONENT_TYPE, ɵLIFECYCLE_HOOKS_VALUES, ɵReflectorReader, ɵccf as createComponentFactory, ɵreflector} from '@angular/core'; import {Attribute, ChangeDetectionStrategy, Component, ComponentFactory, Directive, Host, Inject, Injectable, InjectionToken, ModuleWithProviders, Optional, Provider, Query, RendererTypeV2, SchemaMetadata, Self, SkipSelf, Type, resolveForwardRef, ɵERROR_COMPONENT_TYPE, ɵLIFECYCLE_HOOKS_VALUES, ɵReflectorReader, ɵccf as createComponentFactory, ɵreflector, ɵstringify as stringify} from '@angular/core';
import {StaticSymbol, StaticSymbolCache} from './aot/static_symbol'; import {StaticSymbol, StaticSymbolCache} from './aot/static_symbol';
import {ngfactoryFilePath} from './aot/util'; import {ngfactoryFilePath} from './aot/util';
import {assertArrayOfStrings, assertInterpolationSymbols} from './assertions'; import {assertArrayOfStrings, assertInterpolationSymbols} from './assertions';
@ -15,7 +14,6 @@ import * as cpl from './compile_metadata';
import {CompilerConfig} from './config'; import {CompilerConfig} from './config';
import {DirectiveNormalizer} from './directive_normalizer'; import {DirectiveNormalizer} from './directive_normalizer';
import {DirectiveResolver} from './directive_resolver'; import {DirectiveResolver} from './directive_resolver';
import {stringify} from './facade/lang';
import {Identifiers, resolveIdentifier} from './identifiers'; import {Identifiers, resolveIdentifier} from './identifiers';
import {CompilerInjectable} from './injectable'; import {CompilerInjectable} from './injectable';
import {hasLifecycleHook} from './lifecycle_reflector'; import {hasLifecycleHook} from './lifecycle_reflector';

View File

@ -6,7 +6,6 @@
* found in the LICENSE file at https://angular.io/license * found in the LICENSE file at https://angular.io/license
*/ */
import {isBlank, isPresent} from '../facade/lang';
import {ParseError, ParseSourceSpan} from '../parse_util'; import {ParseError, ParseSourceSpan} from '../parse_util';
import * as html from './ast'; import * as html from './ast';
@ -109,7 +108,7 @@ class _TreeBuilder {
private _consumeComment(token: lex.Token) { private _consumeComment(token: lex.Token) {
const text = this._advanceIf(lex.TokenType.RAW_TEXT); const text = this._advanceIf(lex.TokenType.RAW_TEXT);
this._advanceIf(lex.TokenType.COMMENT_END); this._advanceIf(lex.TokenType.COMMENT_END);
const value = isPresent(text) ? text.parts[0].trim() : null; const value = text != null ? text.parts[0].trim() : null;
this._addToParent(new html.Comment(value, token.sourceSpan)); this._addToParent(new html.Comment(value, token.sourceSpan));
} }
@ -217,7 +216,7 @@ class _TreeBuilder {
let text = token.parts[0]; let text = token.parts[0];
if (text.length > 0 && text[0] == '\n') { if (text.length > 0 && text[0] == '\n') {
const parent = this._getParentElement(); const parent = this._getParentElement();
if (isPresent(parent) && parent.children.length == 0 && if (parent != null && parent.children.length == 0 &&
this.getTagDefinition(parent.name).ignoreFirstLf) { this.getTagDefinition(parent.name).ignoreFirstLf) {
text = text.substring(1); text = text.substring(1);
} }
@ -365,7 +364,7 @@ class _TreeBuilder {
private _addToParent(node: html.Node) { private _addToParent(node: html.Node) {
const parent = this._getParentElement(); const parent = this._getParentElement();
if (isPresent(parent)) { if (parent != null) {
parent.children.push(node); parent.children.push(node);
} else { } else {
this._rootNodes.push(node); this._rootNodes.push(node);
@ -399,9 +398,9 @@ class _TreeBuilder {
private _getElementFullName(prefix: string, localName: string, parentElement: html.Element): private _getElementFullName(prefix: string, localName: string, parentElement: html.Element):
string { string {
if (isBlank(prefix)) { if (prefix == null) {
prefix = this.getTagDefinition(localName).implicitNamespacePrefix; prefix = this.getTagDefinition(localName).implicitNamespacePrefix;
if (isBlank(prefix) && isPresent(parentElement)) { if (prefix == null && parentElement != null) {
prefix = getNsPrefix(parentElement.name); prefix = getNsPrefix(parentElement.name);
} }
} }

View File

@ -9,7 +9,6 @@
import {ɵLifecycleHooks} from '@angular/core'; import {ɵLifecycleHooks} from '@angular/core';
import {CompileDiDependencyMetadata, CompileIdentifierMetadata, CompileNgModuleMetadata, CompileProviderMetadata, CompileTokenMetadata, identifierModuleUrl, identifierName, tokenName, tokenReference} from './compile_metadata'; import {CompileDiDependencyMetadata, CompileIdentifierMetadata, CompileNgModuleMetadata, CompileProviderMetadata, CompileTokenMetadata, identifierModuleUrl, identifierName, tokenName, tokenReference} from './compile_metadata';
import {isPresent} from './facade/lang';
import {Identifiers, createIdentifier, resolveIdentifier} from './identifiers'; import {Identifiers, createIdentifier, resolveIdentifier} from './identifiers';
import {CompilerInjectable} from './injectable'; import {CompilerInjectable} from './injectable';
import {ClassBuilder, createClassStmt} from './output/class_builder'; import {ClassBuilder, createClassStmt} from './output/class_builder';
@ -39,7 +38,7 @@ export class NgModuleCompiler {
compile(ngModuleMeta: CompileNgModuleMetadata, extraProviders: CompileProviderMetadata[]): compile(ngModuleMeta: CompileNgModuleMetadata, extraProviders: CompileProviderMetadata[]):
NgModuleCompileResult { NgModuleCompileResult {
const moduleUrl = identifierModuleUrl(ngModuleMeta.type); const moduleUrl = identifierModuleUrl(ngModuleMeta.type);
const sourceFileName = isPresent(moduleUrl) ? const sourceFileName = moduleUrl != null ?
`in NgModule ${identifierName(ngModuleMeta.type)} in ${moduleUrl}` : `in NgModule ${identifierName(ngModuleMeta.type)} in ${moduleUrl}` :
`in NgModule ${identifierName(ngModuleMeta.type)}`; `in NgModule ${identifierName(ngModuleMeta.type)}`;
const sourceFile = new ParseSourceFile('', sourceFileName); const sourceFile = new ParseSourceFile('', sourceFileName);
@ -161,13 +160,13 @@ class _InjectorBuilder implements ClassBuilder {
private _getProviderValue(provider: CompileProviderMetadata): o.Expression { private _getProviderValue(provider: CompileProviderMetadata): o.Expression {
let result: o.Expression; let result: o.Expression;
if (isPresent(provider.useExisting)) { if (provider.useExisting != null) {
result = this._getDependency({token: provider.useExisting}); result = this._getDependency({token: provider.useExisting});
} else if (isPresent(provider.useFactory)) { } else if (provider.useFactory != null) {
const deps = provider.deps || provider.useFactory.diDeps; const deps = provider.deps || provider.useFactory.diDeps;
const depsExpr = deps.map((dep) => this._getDependency(dep)); const depsExpr = deps.map((dep) => this._getDependency(dep));
result = o.importExpr(provider.useFactory).callFn(depsExpr); result = o.importExpr(provider.useFactory).callFn(depsExpr);
} else if (isPresent(provider.useClass)) { } else if (provider.useClass != null) {
const deps = provider.deps || provider.useClass.diDeps; const deps = provider.deps || provider.useClass.diDeps;
const depsExpr = deps.map((dep) => this._getDependency(dep)); const depsExpr = deps.map((dep) => this._getDependency(dep));
result = result =
@ -239,7 +238,7 @@ class _InjectorBuilder implements ClassBuilder {
} }
function createDiTokenExpression(token: CompileTokenMetadata): o.Expression { function createDiTokenExpression(token: CompileTokenMetadata): o.Expression {
if (isPresent(token.value)) { if (token.value != null) {
return o.literal(token.value); return o.literal(token.value);
} else { } else {
return o.importExpr(token.identifier); return o.importExpr(token.identifier);

View File

@ -6,9 +6,8 @@
* found in the LICENSE file at https://angular.io/license * found in the LICENSE file at https://angular.io/license
*/ */
import {NgModule, Type, ɵReflectorReader, ɵreflector} from '@angular/core'; import {NgModule, Type, ɵReflectorReader, ɵreflector, ɵstringify as stringify} from '@angular/core';
import {findLast} from './directive_resolver'; import {findLast} from './directive_resolver';
import {stringify} from './facade/lang';
import {CompilerInjectable} from './injectable'; import {CompilerInjectable} from './injectable';
function _isNgModuleMetadata(obj: any): obj is NgModule { function _isNgModuleMetadata(obj: any): obj is NgModule {

View File

@ -6,7 +6,6 @@
* found in the LICENSE file at https://angular.io/license * found in the LICENSE file at https://angular.io/license
*/ */
import {isBlank, isPresent} from '../facade/lang';
import {ParseSourceSpan} from '../parse_util'; import {ParseSourceSpan} from '../parse_util';
import * as o from './output_ast'; import * as o from './output_ast';
@ -164,7 +163,7 @@ export abstract class AbstractEmitterVisitor implements o.StatementVisitor, o.Ex
ctx.print(stmt, `if (`); ctx.print(stmt, `if (`);
stmt.condition.visitExpression(this, ctx); stmt.condition.visitExpression(this, ctx);
ctx.print(stmt, `) {`); ctx.print(stmt, `) {`);
const hasElseCase = isPresent(stmt.falseCase) && stmt.falseCase.length > 0; const hasElseCase = stmt.falseCase != null && stmt.falseCase.length > 0;
if (stmt.trueCase.length <= 1 && !hasElseCase) { if (stmt.trueCase.length <= 1 && !hasElseCase) {
ctx.print(stmt, ` `); ctx.print(stmt, ` `);
this.visitAllStatements(stmt.trueCase, ctx); this.visitAllStatements(stmt.trueCase, ctx);
@ -244,9 +243,9 @@ export abstract class AbstractEmitterVisitor implements o.StatementVisitor, o.Ex
visitInvokeMethodExpr(expr: o.InvokeMethodExpr, ctx: EmitterVisitorContext): any { visitInvokeMethodExpr(expr: o.InvokeMethodExpr, ctx: EmitterVisitorContext): any {
expr.receiver.visitExpression(this, ctx); expr.receiver.visitExpression(this, ctx);
let name = expr.name; let name = expr.name;
if (isPresent(expr.builtin)) { if (expr.builtin != null) {
name = this.getBuiltinMethodName(expr.builtin); name = this.getBuiltinMethodName(expr.builtin);
if (isBlank(name)) { if (name == null) {
// some builtins just mean to skip the call. // some builtins just mean to skip the call.
return null; return null;
} }
@ -268,7 +267,7 @@ export abstract class AbstractEmitterVisitor implements o.StatementVisitor, o.Ex
} }
visitReadVarExpr(ast: o.ReadVarExpr, ctx: EmitterVisitorContext): any { visitReadVarExpr(ast: o.ReadVarExpr, ctx: EmitterVisitorContext): any {
let varName = ast.name; let varName = ast.name;
if (isPresent(ast.builtin)) { if (ast.builtin != null) {
switch (ast.builtin) { switch (ast.builtin) {
case o.BuiltinVar.Super: case o.BuiltinVar.Super:
varName = 'super'; varName = 'super';
@ -450,7 +449,7 @@ export abstract class AbstractEmitterVisitor implements o.StatementVisitor, o.Ex
export function escapeIdentifier( export function escapeIdentifier(
input: string, escapeDollar: boolean, alwaysQuote: boolean = true): any { input: string, escapeDollar: boolean, alwaysQuote: boolean = true): any {
if (isBlank(input)) { if (input == null) {
return null; return null;
} }
const body = input.replace(_SINGLE_QUOTE_ESCAPE_STRING_RE, (...match: string[]) => { const body = input.replace(_SINGLE_QUOTE_ESCAPE_STRING_RE, (...match: string[]) => {

View File

@ -6,7 +6,6 @@
* found in the LICENSE file at https://angular.io/license * found in the LICENSE file at https://angular.io/license
*/ */
import {isPresent} from '../facade/lang';
import {AbstractEmitterVisitor, CATCH_ERROR_VAR, CATCH_STACK_VAR, EmitterVisitorContext} from './abstract_emitter'; import {AbstractEmitterVisitor, CATCH_ERROR_VAR, CATCH_STACK_VAR, EmitterVisitorContext} from './abstract_emitter';
import * as o from './output_ast'; import * as o from './output_ast';
@ -17,7 +16,7 @@ export abstract class AbstractJsEmitterVisitor extends AbstractEmitterVisitor {
ctx.pushClass(stmt); ctx.pushClass(stmt);
this._visitClassConstructor(stmt, ctx); this._visitClassConstructor(stmt, ctx);
if (isPresent(stmt.parent)) { if (stmt.parent != null) {
ctx.print(stmt, `${stmt.name}.prototype = Object.create(`); ctx.print(stmt, `${stmt.name}.prototype = Object.create(`);
stmt.parent.visitExpression(this, ctx); stmt.parent.visitExpression(this, ctx);
ctx.println(stmt, `.prototype);`); ctx.println(stmt, `.prototype);`);
@ -30,12 +29,12 @@ export abstract class AbstractJsEmitterVisitor extends AbstractEmitterVisitor {
private _visitClassConstructor(stmt: o.ClassStmt, ctx: EmitterVisitorContext) { private _visitClassConstructor(stmt: o.ClassStmt, ctx: EmitterVisitorContext) {
ctx.print(stmt, `function ${stmt.name}(`); ctx.print(stmt, `function ${stmt.name}(`);
if (isPresent(stmt.constructorMethod)) { if (stmt.constructorMethod != null) {
this._visitParams(stmt.constructorMethod.params, ctx); this._visitParams(stmt.constructorMethod.params, ctx);
} }
ctx.println(stmt, `) {`); ctx.println(stmt, `) {`);
ctx.incIndent(); ctx.incIndent();
if (isPresent(stmt.constructorMethod)) { if (stmt.constructorMethod != null) {
if (stmt.constructorMethod.body.length > 0) { if (stmt.constructorMethod.body.length > 0) {
ctx.println(stmt, `var self = this;`); ctx.println(stmt, `var self = this;`);
this.visitAllStatements(stmt.constructorMethod.body, ctx); this.visitAllStatements(stmt.constructorMethod.body, ctx);

View File

@ -9,7 +9,6 @@
import {StaticSymbol} from '../aot/static_symbol'; import {StaticSymbol} from '../aot/static_symbol';
import {CompileIdentifierMetadata} from '../compile_metadata'; import {CompileIdentifierMetadata} from '../compile_metadata';
import {isBlank} from '../facade/lang';
import {EmitterVisitorContext, OutputEmitter} from './abstract_emitter'; import {EmitterVisitorContext, OutputEmitter} from './abstract_emitter';
import {AbstractJsEmitterVisitor} from './abstract_js_emitter'; import {AbstractJsEmitterVisitor} from './abstract_js_emitter';
@ -61,7 +60,7 @@ class JsEmitterVisitor extends AbstractJsEmitterVisitor {
const {name, filePath} = this._resolveStaticSymbol(ast.value); const {name, filePath} = this._resolveStaticSymbol(ast.value);
if (filePath != this._genFilePath) { if (filePath != this._genFilePath) {
let prefix = this.importsWithPrefixes.get(filePath); let prefix = this.importsWithPrefixes.get(filePath);
if (isBlank(prefix)) { if (prefix == null) {
prefix = `import${this.importsWithPrefixes.size}`; prefix = `import${this.importsWithPrefixes.size}`;
this.importsWithPrefixes.set(filePath, prefix); this.importsWithPrefixes.set(filePath, prefix);
} }

View File

@ -8,7 +8,6 @@
import {CompileIdentifierMetadata} from '../compile_metadata'; import {CompileIdentifierMetadata} from '../compile_metadata';
import {isPresent} from '../facade/lang';
import {ParseSourceSpan} from '../parse_util'; import {ParseSourceSpan} from '../parse_util';
//// Types //// Types
@ -954,12 +953,12 @@ export function importExpr(
export function importType( export function importType(
id: CompileIdentifierMetadata, typeParams: Type[] = null, id: CompileIdentifierMetadata, typeParams: Type[] = null,
typeModifiers: TypeModifier[] = null): ExpressionType { typeModifiers: TypeModifier[] = null): ExpressionType {
return isPresent(id) ? expressionType(importExpr(id, typeParams), typeModifiers) : null; return id != null ? expressionType(importExpr(id, typeParams), typeModifiers) : null;
} }
export function expressionType( export function expressionType(
expr: Expression, typeModifiers: TypeModifier[] = null): ExpressionType { expr: Expression, typeModifiers: TypeModifier[] = null): ExpressionType {
return isPresent(expr) ? new ExpressionType(expr, typeModifiers) : null; return expr != null ? new ExpressionType(expr, typeModifiers) : null;
} }
export function literalArr( export function literalArr(

View File

@ -7,7 +7,6 @@
*/ */
import {isPresent} from '../facade/lang';
import * as o from './output_ast'; import * as o from './output_ast';
import {debugOutputAstAsTypeScript} from './ts_emitter'; import {debugOutputAstAsTypeScript} from './ts_emitter';
@ -18,7 +17,7 @@ export function interpretStatements(statements: o.Statement[], resultVars: strin
const ctx = new _ExecutionContext(null, null, null, new Map<string, any>()); const ctx = new _ExecutionContext(null, null, null, new Map<string, any>());
const visitor = new StatementInterpreter(); const visitor = new StatementInterpreter();
const result = visitor.visitAllStatements(stmtsWithReturn, ctx); const result = visitor.visitAllStatements(stmtsWithReturn, ctx);
return isPresent(result) ? result.value : null; return result != null ? result.value : null;
} }
function _executeFunctionStatements( function _executeFunctionStatements(
@ -107,7 +106,7 @@ class StatementInterpreter implements o.StatementVisitor, o.ExpressionVisitor {
} }
visitReadVarExpr(ast: o.ReadVarExpr, ctx: _ExecutionContext): any { visitReadVarExpr(ast: o.ReadVarExpr, ctx: _ExecutionContext): any {
let varName = ast.name; let varName = ast.name;
if (isPresent(ast.builtin)) { if (ast.builtin != null) {
switch (ast.builtin) { switch (ast.builtin) {
case o.BuiltinVar.Super: case o.BuiltinVar.Super:
return ctx.instance.__proto__; return ctx.instance.__proto__;
@ -150,7 +149,7 @@ class StatementInterpreter implements o.StatementVisitor, o.ExpressionVisitor {
const receiver = expr.receiver.visitExpression(this, ctx); const receiver = expr.receiver.visitExpression(this, ctx);
const args = this.visitAllExpressions(expr.args, ctx); const args = this.visitAllExpressions(expr.args, ctx);
let result: any; let result: any;
if (isPresent(expr.builtin)) { if (expr.builtin != null) {
switch (expr.builtin) { switch (expr.builtin) {
case o.BuiltinMethod.ConcatArray: case o.BuiltinMethod.ConcatArray:
result = receiver.concat(...args); result = receiver.concat(...args);
@ -195,7 +194,7 @@ class StatementInterpreter implements o.StatementVisitor, o.ExpressionVisitor {
const condition = stmt.condition.visitExpression(this, ctx); const condition = stmt.condition.visitExpression(this, ctx);
if (condition) { if (condition) {
return this.visitAllStatements(stmt.trueCase, ctx); return this.visitAllStatements(stmt.trueCase, ctx);
} else if (isPresent(stmt.falseCase)) { } else if (stmt.falseCase != null) {
return this.visitAllStatements(stmt.falseCase, ctx); return this.visitAllStatements(stmt.falseCase, ctx);
} }
return null; return null;
@ -226,7 +225,7 @@ class StatementInterpreter implements o.StatementVisitor, o.ExpressionVisitor {
visitConditionalExpr(ast: o.ConditionalExpr, ctx: _ExecutionContext): any { visitConditionalExpr(ast: o.ConditionalExpr, ctx: _ExecutionContext): any {
if (ast.condition.visitExpression(this, ctx)) { if (ast.condition.visitExpression(this, ctx)) {
return ast.trueCase.visitExpression(this, ctx); return ast.trueCase.visitExpression(this, ctx);
} else if (isPresent(ast.falseCase)) { } else if (ast.falseCase != null) {
return ast.falseCase.visitExpression(this, ctx); return ast.falseCase.visitExpression(this, ctx);
} }
return null; return null;

View File

@ -9,7 +9,6 @@
import {StaticSymbol} from '../aot/static_symbol'; import {StaticSymbol} from '../aot/static_symbol';
import {CompileIdentifierMetadata} from '../compile_metadata'; import {CompileIdentifierMetadata} from '../compile_metadata';
import {isBlank, isPresent} from '../facade/lang';
import {AbstractEmitterVisitor, CATCH_ERROR_VAR, CATCH_STACK_VAR, EmitterVisitorContext, OutputEmitter} from './abstract_emitter'; import {AbstractEmitterVisitor, CATCH_ERROR_VAR, CATCH_STACK_VAR, EmitterVisitorContext, OutputEmitter} from './abstract_emitter';
import * as o from './output_ast'; import * as o from './output_ast';
@ -91,7 +90,7 @@ class _TsEmitterVisitor extends AbstractEmitterVisitor implements o.TypeVisitor
reexports = new Map<string, {name: string, as: string}[]>(); reexports = new Map<string, {name: string, as: string}[]>();
visitType(t: o.Type, ctx: EmitterVisitorContext, defaultType: string = 'any') { visitType(t: o.Type, ctx: EmitterVisitorContext, defaultType: string = 'any') {
if (isPresent(t)) { if (t != null) {
this.typeExpression++; this.typeExpression++;
t.visitType(this, ctx); t.visitType(this, ctx);
this.typeExpression--; this.typeExpression--;
@ -102,7 +101,7 @@ class _TsEmitterVisitor extends AbstractEmitterVisitor implements o.TypeVisitor
visitLiteralExpr(ast: o.LiteralExpr, ctx: EmitterVisitorContext): any { visitLiteralExpr(ast: o.LiteralExpr, ctx: EmitterVisitorContext): any {
const value = ast.value; const value = ast.value;
if (isBlank(value) && ast.type != o.INFERRED_TYPE) { if (value == null && ast.type != o.INFERRED_TYPE) {
ctx.print(ast, `(${value} as any)`); ctx.print(ast, `(${value} as any)`);
return null; return null;
} }
@ -186,7 +185,7 @@ class _TsEmitterVisitor extends AbstractEmitterVisitor implements o.TypeVisitor
ctx.print(stmt, `export `); ctx.print(stmt, `export `);
} }
ctx.print(stmt, `class ${stmt.name}`); ctx.print(stmt, `class ${stmt.name}`);
if (isPresent(stmt.parent)) { if (stmt.parent != null) {
ctx.print(stmt, ` extends `); ctx.print(stmt, ` extends `);
this.typeExpression++; this.typeExpression++;
stmt.parent.visitExpression(this, ctx); stmt.parent.visitExpression(this, ctx);
@ -195,7 +194,7 @@ class _TsEmitterVisitor extends AbstractEmitterVisitor implements o.TypeVisitor
ctx.println(stmt, ` {`); ctx.println(stmt, ` {`);
ctx.incIndent(); ctx.incIndent();
stmt.fields.forEach((field) => this._visitClassField(field, ctx)); stmt.fields.forEach((field) => this._visitClassField(field, ctx));
if (isPresent(stmt.constructorMethod)) { if (stmt.constructorMethod != null) {
this._visitClassConstructor(stmt, ctx); this._visitClassConstructor(stmt, ctx);
} }
stmt.getters.forEach((getter) => this._visitClassGetter(getter, ctx)); stmt.getters.forEach((getter) => this._visitClassGetter(getter, ctx));
@ -391,7 +390,7 @@ class _TsEmitterVisitor extends AbstractEmitterVisitor implements o.TypeVisitor
const {name, filePath, members, arity} = this._resolveStaticSymbol(value); const {name, filePath, members, arity} = this._resolveStaticSymbol(value);
if (filePath != this._genFilePath) { if (filePath != this._genFilePath) {
let prefix = this.importsWithPrefixes.get(filePath); let prefix = this.importsWithPrefixes.get(filePath);
if (isBlank(prefix)) { if (prefix == null) {
prefix = `import${this.importsWithPrefixes.size}`; prefix = `import${this.importsWithPrefixes.size}`;
this.importsWithPrefixes.set(filePath, prefix); this.importsWithPrefixes.set(filePath, prefix);
} }

View File

@ -6,7 +6,6 @@
* found in the LICENSE file at https://angular.io/license * found in the LICENSE file at https://angular.io/license
*/ */
import * as chars from './chars'; import * as chars from './chars';
import {isPresent} from './facade/lang';
export class ParseLocation { export class ParseLocation {
constructor( constructor(
@ -14,7 +13,7 @@ export class ParseLocation {
public col: number) {} public col: number) {}
toString(): string { toString(): string {
return isPresent(this.offset) ? `${this.file.url}@${this.line}:${this.col}` : this.file.url; return this.offset != null ? `${this.file.url}@${this.line}:${this.col}` : this.file.url;
} }
moveBy(delta: number): ParseLocation { moveBy(delta: number): ParseLocation {
@ -55,7 +54,7 @@ export class ParseLocation {
const content = this.file.content; const content = this.file.content;
let startOffset = this.offset; let startOffset = this.offset;
if (isPresent(startOffset)) { if (startOffset != null) {
if (startOffset > content.length - 1) { if (startOffset > content.length - 1) {
startOffset = content.length - 1; startOffset = content.length - 1;
} }

View File

@ -6,9 +6,8 @@
* found in the LICENSE file at https://angular.io/license * found in the LICENSE file at https://angular.io/license
*/ */
import {Pipe, Type, resolveForwardRef, ɵReflectorReader, ɵreflector} from '@angular/core'; import {Pipe, Type, resolveForwardRef, ɵReflectorReader, ɵreflector, ɵstringify as stringify} from '@angular/core';
import {findLast} from './directive_resolver'; import {findLast} from './directive_resolver';
import {stringify} from './facade/lang';
import {CompilerInjectable} from './injectable'; import {CompilerInjectable} from './injectable';
function _isPipeMetadata(type: any): boolean { function _isPipeMetadata(type: any): boolean {

View File

@ -8,7 +8,6 @@
import {CompileDiDependencyMetadata, CompileDirectiveMetadata, CompileDirectiveSummary, CompileNgModuleMetadata, CompileProviderMetadata, CompileQueryMetadata, CompileTokenMetadata, CompileTypeMetadata, tokenName, tokenReference} from './compile_metadata'; import {CompileDiDependencyMetadata, CompileDirectiveMetadata, CompileDirectiveSummary, CompileNgModuleMetadata, CompileProviderMetadata, CompileQueryMetadata, CompileTokenMetadata, CompileTypeMetadata, tokenName, tokenReference} from './compile_metadata';
import {isBlank, isPresent} from './facade/lang';
import {Identifiers, createIdentifierToken, resolveIdentifier} from './identifiers'; import {Identifiers, createIdentifierToken, resolveIdentifier} from './identifiers';
import {ParseError, ParseSourceSpan} from './parse_util'; import {ParseError, ParseSourceSpan} from './parse_util';
import {AttrAst, DirectiveAst, ProviderAst, ProviderAstType, QueryMatch, ReferenceAst} from './template_parser/template_ast'; import {AttrAst, DirectiveAst, ProviderAst, ProviderAstType, QueryMatch, ReferenceAst} from './template_parser/template_ast';
@ -37,7 +36,7 @@ export class ProviderViewContext {
this.viewQueries = _getViewQueries(component); this.viewQueries = _getViewQueries(component);
this.viewProviders = new Map<any, boolean>(); this.viewProviders = new Map<any, boolean>();
component.viewProviders.forEach((provider) => { component.viewProviders.forEach((provider) => {
if (isBlank(this.viewProviders.get(tokenReference(provider.token)))) { if (this.viewProviders.get(tokenReference(provider.token)) == null) {
this.viewProviders.set(tokenReference(provider.token), true); this.viewProviders.set(tokenReference(provider.token), true);
} }
}); });
@ -171,7 +170,7 @@ export class ProviderElementContext {
if (transformedProviderAst) { if (transformedProviderAst) {
return transformedProviderAst; return transformedProviderAst;
} }
if (isPresent(this._seenProviders.get(tokenReference(token)))) { if (this._seenProviders.get(tokenReference(token)) != null) {
this.viewContext.errors.push(new ProviderError( this.viewContext.errors.push(new ProviderError(
`Cannot instantiate cyclic dependency! ${tokenName(token)}`, this._sourceSpan)); `Cannot instantiate cyclic dependency! ${tokenName(token)}`, this._sourceSpan));
return null; return null;
@ -181,10 +180,10 @@ export class ProviderElementContext {
let transformedUseValue = provider.useValue; let transformedUseValue = provider.useValue;
let transformedUseExisting = provider.useExisting; let transformedUseExisting = provider.useExisting;
let transformedDeps: CompileDiDependencyMetadata[]; let transformedDeps: CompileDiDependencyMetadata[];
if (isPresent(provider.useExisting)) { if (provider.useExisting != null) {
const existingDiDep = this._getDependency( const existingDiDep = this._getDependency(
resolvedProvider.providerType, {token: provider.useExisting}, eager); resolvedProvider.providerType, {token: provider.useExisting}, eager);
if (isPresent(existingDiDep.token)) { if (existingDiDep.token != null) {
transformedUseExisting = existingDiDep.token; transformedUseExisting = existingDiDep.token;
} else { } else {
transformedUseExisting = null; transformedUseExisting = null;
@ -219,7 +218,7 @@ export class ProviderElementContext {
return {isValue: true, value: attrValue == null ? null : attrValue}; return {isValue: true, value: attrValue == null ? null : attrValue};
} }
if (isPresent(dep.token)) { if (dep.token != null) {
// access builtints // access builtints
if ((requestingProviderType === ProviderAstType.Directive || if ((requestingProviderType === ProviderAstType.Directive ||
requestingProviderType === ProviderAstType.Component)) { requestingProviderType === ProviderAstType.Component)) {
@ -238,7 +237,7 @@ export class ProviderElementContext {
return dep; return dep;
} }
// access providers // access providers
if (isPresent(this._getOrCreateLocalProvider(requestingProviderType, dep.token, eager))) { if (this._getOrCreateLocalProvider(requestingProviderType, dep.token, eager) != null) {
return dep; return dep;
} }
} }
@ -272,7 +271,7 @@ export class ProviderElementContext {
if (!result) { if (!result) {
if (!dep.isHost || this.viewContext.component.isHost || if (!dep.isHost || this.viewContext.component.isHost ||
this.viewContext.component.type.reference === tokenReference(dep.token) || this.viewContext.component.type.reference === tokenReference(dep.token) ||
isPresent(this.viewContext.viewProviders.get(tokenReference(dep.token)))) { this.viewContext.viewProviders.get(tokenReference(dep.token)) != null) {
result = dep; result = dep;
} else { } else {
result = dep.isOptional ? result = {isValue: true, value: null} : null; result = dep.isOptional ? result = {isValue: true, value: null} : null;
@ -329,7 +328,7 @@ export class NgModuleProviderAnalyzer {
if (transformedProviderAst) { if (transformedProviderAst) {
return transformedProviderAst; return transformedProviderAst;
} }
if (isPresent(this._seenProviders.get(tokenReference(token)))) { if (this._seenProviders.get(tokenReference(token)) != null) {
this._errors.push(new ProviderError( this._errors.push(new ProviderError(
`Cannot instantiate cyclic dependency! ${tokenName(token)}`, `Cannot instantiate cyclic dependency! ${tokenName(token)}`,
resolvedProvider.sourceSpan)); resolvedProvider.sourceSpan));
@ -340,10 +339,10 @@ export class NgModuleProviderAnalyzer {
let transformedUseValue = provider.useValue; let transformedUseValue = provider.useValue;
let transformedUseExisting = provider.useExisting; let transformedUseExisting = provider.useExisting;
let transformedDeps: CompileDiDependencyMetadata[]; let transformedDeps: CompileDiDependencyMetadata[];
if (isPresent(provider.useExisting)) { if (provider.useExisting != null) {
const existingDiDep = const existingDiDep =
this._getDependency({token: provider.useExisting}, eager, resolvedProvider.sourceSpan); this._getDependency({token: provider.useExisting}, eager, resolvedProvider.sourceSpan);
if (isPresent(existingDiDep.token)) { if (existingDiDep.token != null) {
transformedUseExisting = existingDiDep.token; transformedUseExisting = existingDiDep.token;
} else { } else {
transformedUseExisting = null; transformedUseExisting = null;
@ -374,13 +373,13 @@ export class NgModuleProviderAnalyzer {
dep: CompileDiDependencyMetadata, eager: boolean = null, dep: CompileDiDependencyMetadata, eager: boolean = null,
requestorSourceSpan: ParseSourceSpan): CompileDiDependencyMetadata { requestorSourceSpan: ParseSourceSpan): CompileDiDependencyMetadata {
let foundLocal = false; let foundLocal = false;
if (!dep.isSkipSelf && isPresent(dep.token)) { if (!dep.isSkipSelf && dep.token != null) {
// access the injector // access the injector
if (tokenReference(dep.token) === resolveIdentifier(Identifiers.Injector) || if (tokenReference(dep.token) === resolveIdentifier(Identifiers.Injector) ||
tokenReference(dep.token) === resolveIdentifier(Identifiers.ComponentFactoryResolver)) { tokenReference(dep.token) === resolveIdentifier(Identifiers.ComponentFactoryResolver)) {
foundLocal = true; foundLocal = true;
// access providers // access providers
} else if (isPresent(this._getOrCreateLocalProvider(dep.token, eager))) { } else if (this._getOrCreateLocalProvider(dep.token, eager) != null) {
foundLocal = true; foundLocal = true;
} }
} }
@ -453,7 +452,7 @@ function _resolveProviders(
targetProvidersByToken: Map<any, ProviderAst>) { targetProvidersByToken: Map<any, ProviderAst>) {
providers.forEach((provider) => { providers.forEach((provider) => {
let resolvedProvider = targetProvidersByToken.get(tokenReference(provider.token)); let resolvedProvider = targetProvidersByToken.get(tokenReference(provider.token));
if (isPresent(resolvedProvider) && !!resolvedProvider.multiProvider !== !!provider.multi) { if (resolvedProvider != null && !!resolvedProvider.multiProvider !== !!provider.multi) {
targetErrors.push(new ProviderError( targetErrors.push(new ProviderError(
`Mixing multi and non multi provider is not possible for token ${tokenName(resolvedProvider.token)}`, `Mixing multi and non multi provider is not possible for token ${tokenName(resolvedProvider.token)}`,
sourceSpan)); sourceSpan));

View File

@ -11,7 +11,6 @@ import {CompileDirectiveMetadata, CompileDirectiveSummary, CompilePipeSummary, C
import {CompilerConfig} from '../config'; import {CompilerConfig} from '../config';
import {AST, ASTWithSource, EmptyExpr} from '../expression_parser/ast'; import {AST, ASTWithSource, EmptyExpr} from '../expression_parser/ast';
import {Parser} from '../expression_parser/parser'; import {Parser} from '../expression_parser/parser';
import {isPresent} from '../facade/lang';
import {I18NHtmlParser} from '../i18n/i18n_html_parser'; import {I18NHtmlParser} from '../i18n/i18n_html_parser';
import {Identifiers, createIdentifierToken, identifierToken} from '../identifiers'; import {Identifiers, createIdentifierToken, identifierToken} from '../identifiers';
import {CompilerInjectable} from '../injectable'; import {CompilerInjectable} from '../injectable';
@ -295,7 +294,7 @@ class TemplateParseVisitor implements html.Visitor {
prefixToken = normalizedName.substring(TEMPLATE_ATTR_PREFIX.length) + ':'; prefixToken = normalizedName.substring(TEMPLATE_ATTR_PREFIX.length) + ':';
} }
const hasTemplateBinding = isPresent(templateBindingsSource); const hasTemplateBinding = templateBindingsSource != null;
if (hasTemplateBinding) { if (hasTemplateBinding) {
if (hasInlineTemplates) { if (hasInlineTemplates) {
this._reportError( this._reportError(
@ -338,7 +337,7 @@ class TemplateParseVisitor implements html.Visitor {
isTemplateElement ? parent.providerContext : providerContext)); isTemplateElement ? parent.providerContext : providerContext));
providerContext.afterElement(); providerContext.afterElement();
// Override the actual selector when the `ngProjectAs` attribute is provided // Override the actual selector when the `ngProjectAs` attribute is provided
const projectionSelector = isPresent(preparsedElement.projectAs) ? const projectionSelector = preparsedElement.projectAs != null ?
CssSelector.parse(preparsedElement.projectAs)[0] : CssSelector.parse(preparsedElement.projectAs)[0] :
elementCssSelector; elementCssSelector;
const ngContentIndex = parent.findNgContentIndex(projectionSelector); const ngContentIndex = parent.findNgContentIndex(projectionSelector);
@ -415,7 +414,7 @@ class TemplateParseVisitor implements html.Visitor {
if (bindParts !== null) { if (bindParts !== null) {
hasBinding = true; hasBinding = true;
if (isPresent(bindParts[KW_BIND_IDX])) { if (bindParts[KW_BIND_IDX] != null) {
this._bindingParser.parsePropertyBinding( this._bindingParser.parsePropertyBinding(
bindParts[IDENT_KW_IDX], value, false, srcSpan, targetMatchableAttrs, targetProps); bindParts[IDENT_KW_IDX], value, false, srcSpan, targetMatchableAttrs, targetProps);
@ -698,7 +697,7 @@ class TemplateParseVisitor implements html.Visitor {
}); });
events.forEach(event => { events.forEach(event => {
if (isPresent(event.target) || !allDirectiveEvents.has(event.name)) { if (event.target != null || !allDirectiveEvents.has(event.name)) {
this._reportError( this._reportError(
`Event binding ${event.fullName} not emitted by any directive on an embedded template. Make sure that the event name is spelled correctly and all directives are listed in the "@NgModule.declarations".`, `Event binding ${event.fullName} not emitted by any directive on an embedded template. Make sure that the event name is spelled correctly and all directives are listed in the "@NgModule.declarations".`,
event.sourceSpan); event.sourceSpan);
@ -811,7 +810,7 @@ class ElementContext {
this._ngContentIndexMatcher.match( this._ngContentIndexMatcher.match(
selector, (selector, ngContentIndex) => { ngContentIndices.push(ngContentIndex); }); selector, (selector, ngContentIndex) => { ngContentIndices.push(ngContentIndex); });
ngContentIndices.sort(); ngContentIndices.sort();
if (isPresent(this._wildcardNgContentIndex)) { if (this._wildcardNgContentIndex != null) {
ngContentIndices.push(this._wildcardNgContentIndex); ngContentIndices.push(this._wildcardNgContentIndex);
} }
return ngContentIndices.length > 0 ? ngContentIndices[0] : null; return ngContentIndices.length > 0 ? ngContentIndices[0] : null;

View File

@ -8,7 +8,6 @@
import {Inject, InjectionToken, PACKAGE_ROOT_URL} from '@angular/core'; import {Inject, InjectionToken, PACKAGE_ROOT_URL} from '@angular/core';
import {isBlank, isPresent} from './facade/lang';
import {CompilerInjectable} from './injectable'; import {CompilerInjectable} from './injectable';
@ -62,12 +61,12 @@ export class UrlResolver {
*/ */
resolve(baseUrl: string, url: string): string { resolve(baseUrl: string, url: string): string {
let resolvedUrl = url; let resolvedUrl = url;
if (isPresent(baseUrl) && baseUrl.length > 0) { if (baseUrl != null && baseUrl.length > 0) {
resolvedUrl = _resolveUrl(baseUrl, resolvedUrl); resolvedUrl = _resolveUrl(baseUrl, resolvedUrl);
} }
const resolvedParts = _split(resolvedUrl); const resolvedParts = _split(resolvedUrl);
let prefix = this._packagePrefix; let prefix = this._packagePrefix;
if (isPresent(prefix) && isPresent(resolvedParts) && if (prefix != null && resolvedParts != null &&
resolvedParts[_ComponentIndex.Scheme] == 'package') { resolvedParts[_ComponentIndex.Scheme] == 'package') {
let path = resolvedParts[_ComponentIndex.Path]; let path = resolvedParts[_ComponentIndex.Path];
prefix = prefix.replace(/\/+$/, ''); prefix = prefix.replace(/\/+$/, '');
@ -111,33 +110,33 @@ function _buildFromEncodedParts(
opt_path?: string, opt_queryData?: string, opt_fragment?: string): string { opt_path?: string, opt_queryData?: string, opt_fragment?: string): string {
const out: string[] = []; const out: string[] = [];
if (isPresent(opt_scheme)) { if (opt_scheme != null) {
out.push(opt_scheme + ':'); out.push(opt_scheme + ':');
} }
if (isPresent(opt_domain)) { if (opt_domain != null) {
out.push('//'); out.push('//');
if (isPresent(opt_userInfo)) { if (opt_userInfo != null) {
out.push(opt_userInfo + '@'); out.push(opt_userInfo + '@');
} }
out.push(opt_domain); out.push(opt_domain);
if (isPresent(opt_port)) { if (opt_port != null) {
out.push(':' + opt_port); out.push(':' + opt_port);
} }
} }
if (isPresent(opt_path)) { if (opt_path != null) {
out.push(opt_path); out.push(opt_path);
} }
if (isPresent(opt_queryData)) { if (opt_queryData != null) {
out.push('?' + opt_queryData); out.push('?' + opt_queryData);
} }
if (isPresent(opt_fragment)) { if (opt_fragment != null) {
out.push('#' + opt_fragment); out.push('#' + opt_fragment);
} }
@ -309,7 +308,7 @@ function _removeDotSegments(path: string): string {
*/ */
function _joinAndCanonicalizePath(parts: any[]): string { function _joinAndCanonicalizePath(parts: any[]): string {
let path = parts[_ComponentIndex.Path]; let path = parts[_ComponentIndex.Path];
path = isBlank(path) ? '' : _removeDotSegments(path); path = path == null ? '' : _removeDotSegments(path);
parts[_ComponentIndex.Path] = path; parts[_ComponentIndex.Path] = path;
return _buildFromEncodedParts( return _buildFromEncodedParts(
@ -327,14 +326,14 @@ function _resolveUrl(base: string, url: string): string {
const parts = _split(encodeURI(url)); const parts = _split(encodeURI(url));
const baseParts = _split(base); const baseParts = _split(base);
if (isPresent(parts[_ComponentIndex.Scheme])) { if (parts[_ComponentIndex.Scheme] != null) {
return _joinAndCanonicalizePath(parts); return _joinAndCanonicalizePath(parts);
} else { } else {
parts[_ComponentIndex.Scheme] = baseParts[_ComponentIndex.Scheme]; parts[_ComponentIndex.Scheme] = baseParts[_ComponentIndex.Scheme];
} }
for (let i = _ComponentIndex.Scheme; i <= _ComponentIndex.Port; i++) { for (let i = _ComponentIndex.Scheme; i <= _ComponentIndex.Port; i++) {
if (isBlank(parts[i])) { if (parts[i] == null) {
parts[i] = baseParts[i]; parts[i] = baseParts[i];
} }
} }
@ -344,7 +343,7 @@ function _resolveUrl(base: string, url: string): string {
} }
let path = baseParts[_ComponentIndex.Path]; let path = baseParts[_ComponentIndex.Path];
if (isBlank(path)) path = '/'; if (path == null) path = '/';
const index = path.lastIndexOf('/'); const index = path.lastIndexOf('/');
path = path.substring(0, index + 1) + parts[_ComponentIndex.Path]; path = path.substring(0, index + 1) + parts[_ComponentIndex.Path];
parts[_ComponentIndex.Path] = path; parts[_ComponentIndex.Path] = path;

View File

@ -6,7 +6,6 @@
* found in the LICENSE file at https://angular.io/license * found in the LICENSE file at https://angular.io/license
*/ */
import {isPrimitive, isStrictStringMap} from './facade/lang';
export const MODULE_SUFFIX = ''; export const MODULE_SUFFIX = '';
const CAMEL_CASE_REGEXP = /([A-Z])/g; const CAMEL_CASE_REGEXP = /([A-Z])/g;
@ -43,7 +42,8 @@ export function visitValue(value: any, visitor: ValueVisitor, context: any): any
return visitor.visitStringMap(<{[key: string]: any}>value, context); return visitor.visitStringMap(<{[key: string]: any}>value, context);
} }
if (value == null || isPrimitive(value)) { if (value == null || typeof value == 'string' || typeof value == 'number' ||
typeof value == 'boolean') {
return visitor.visitPrimitive(value, context); return visitor.visitPrimitive(value, context);
} }
@ -89,3 +89,12 @@ const ERROR_SYNTAX_ERROR = 'ngSyntaxError';
export function isSyntaxError(error: Error): boolean { export function isSyntaxError(error: Error): boolean {
return (error as any)[ERROR_SYNTAX_ERROR]; return (error as any)[ERROR_SYNTAX_ERROR];
} }
export function escapeRegExp(s: string): string {
return s.replace(/([.*+?^=!:${}()|[\]\/\\])/g, '\\$1');
}
const STRING_MAP_PROTO = Object.getPrototypeOf({});
function isStrictStringMap(obj: any): boolean {
return typeof obj === 'object' && obj !== null && Object.getPrototypeOf(obj) === STRING_MAP_PROTO;
}

View File

@ -8,7 +8,6 @@
import {describe, expect, it} from '../../../core/testing/testing_internal'; import {describe, expect, it} from '../../../core/testing/testing_internal';
import {CssLexer, CssLexerMode, CssToken, CssTokenType, cssScannerError, getRawMessage, getToken} from '../../src/css_parser/css_lexer'; import {CssLexer, CssLexerMode, CssToken, CssTokenType, cssScannerError, getRawMessage, getToken} from '../../src/css_parser/css_lexer';
import {isPresent} from '../../src/facade/lang';
export function main() { export function main() {
function tokenize( function tokenize(
@ -21,7 +20,7 @@ export function main() {
let output = scanner.scan(); let output = scanner.scan();
while (output != null) { while (output != null) {
const error = output.error; const error = output.error;
if (isPresent(error)) { if (error != null) {
throw cssScannerError(getToken(error), getRawMessage(error)); throw cssScannerError(getToken(error), getRawMessage(error));
} }
tokens.push(output.token); tokens.push(output.token);

View File

@ -10,7 +10,6 @@
import {beforeEach, describe, expect, it} from '../../../core/testing/testing_internal'; import {beforeEach, describe, expect, it} from '../../../core/testing/testing_internal';
import {CssAst, CssAstVisitor, CssAtRulePredicateAst, CssBlockAst, CssDefinitionAst, CssInlineRuleAst, CssKeyframeDefinitionAst, CssKeyframeRuleAst, CssMediaQueryRuleAst, CssPseudoSelectorAst, CssRuleAst, CssSelectorAst, CssSelectorRuleAst, CssSimpleSelectorAst, CssStyleSheetAst, CssStyleValueAst, CssStylesBlockAst, CssUnknownRuleAst, CssUnknownTokenListAst} from '../../src/css_parser/css_ast'; import {CssAst, CssAstVisitor, CssAtRulePredicateAst, CssBlockAst, CssDefinitionAst, CssInlineRuleAst, CssKeyframeDefinitionAst, CssKeyframeRuleAst, CssMediaQueryRuleAst, CssPseudoSelectorAst, CssRuleAst, CssSelectorAst, CssSelectorRuleAst, CssSimpleSelectorAst, CssStyleSheetAst, CssStyleValueAst, CssStylesBlockAst, CssUnknownRuleAst, CssUnknownTokenListAst} from '../../src/css_parser/css_ast';
import {BlockType, CssParseError, CssParser, CssToken} from '../../src/css_parser/css_parser'; import {BlockType, CssParseError, CssParser, CssToken} from '../../src/css_parser/css_parser';
import {isPresent} from '../../src/facade/lang';
function _assertTokens(tokens: CssToken[], valuesArr: string[]): void { function _assertTokens(tokens: CssToken[], valuesArr: string[]): void {
expect(tokens.length).toEqual(valuesArr.length); expect(tokens.length).toEqual(valuesArr.length);

View File

@ -11,7 +11,6 @@ import {Lexer} from '@angular/compiler/src/expression_parser/lexer';
import {Parser, SplitInterpolation, TemplateBindingParseResult} from '@angular/compiler/src/expression_parser/parser'; import {Parser, SplitInterpolation, TemplateBindingParseResult} from '@angular/compiler/src/expression_parser/parser';
import {expect} from '@angular/platform-browser/testing/matchers'; import {expect} from '@angular/platform-browser/testing/matchers';
import {isBlank, isPresent} from '../../src/facade/lang';
import {unparse} from './unparser'; import {unparse} from './unparser';
import {validate} from './validator'; import {validate} from './validator';
@ -50,21 +49,21 @@ export function main() {
function checkInterpolation(exp: string, expected?: string) { function checkInterpolation(exp: string, expected?: string) {
const ast = parseInterpolation(exp); const ast = parseInterpolation(exp);
if (isBlank(expected)) expected = exp; if (expected == null) expected = exp;
expect(unparse(ast)).toEqual(expected); expect(unparse(ast)).toEqual(expected);
validate(ast); validate(ast);
} }
function checkBinding(exp: string, expected?: string) { function checkBinding(exp: string, expected?: string) {
const ast = parseBinding(exp); const ast = parseBinding(exp);
if (isBlank(expected)) expected = exp; if (expected == null) expected = exp;
expect(unparse(ast)).toEqual(expected); expect(unparse(ast)).toEqual(expected);
validate(ast); validate(ast);
} }
function checkAction(exp: string, expected?: string) { function checkAction(exp: string, expected?: string) {
const ast = parseAction(exp); const ast = parseAction(exp);
if (isBlank(expected)) expected = exp; if (expected == null) expected = exp;
expect(unparse(ast)).toEqual(expected); expect(unparse(ast)).toEqual(expected);
validate(ast); validate(ast);
} }
@ -321,9 +320,9 @@ export function main() {
function keyValues(templateBindings: any[]) { function keyValues(templateBindings: any[]) {
return templateBindings.map(binding => { return templateBindings.map(binding => {
if (binding.keyIsVar) { if (binding.keyIsVar) {
return 'let ' + binding.key + (isBlank(binding.name) ? '=null' : '=' + binding.name); return 'let ' + binding.key + (binding.name == null ? '=null' : '=' + binding.name);
} else { } else {
return binding.key + (isBlank(binding.expression) ? '' : `=${binding.expression}`); return binding.key + (binding.expression == null ? '' : `=${binding.expression}`);
} }
}); });
} }
@ -335,7 +334,7 @@ export function main() {
function exprSources(templateBindings: any[]) { function exprSources(templateBindings: any[]) {
return templateBindings.map( return templateBindings.map(
binding => isPresent(binding.expression) ? binding.expression.source : null); binding => binding.expression != null ? binding.expression.source : null);
} }
it('should parse an empty string', () => { expect(parseTemplateBindings('')).toEqual([]); }); it('should parse an empty string', () => { expect(parseTemplateBindings('')).toEqual([]); });

View File

@ -6,7 +6,7 @@
* found in the LICENSE file at https://angular.io/license * found in the LICENSE file at https://angular.io/license
*/ */
import {escapeRegExp} from '@angular/core/src/facade/lang'; import {escapeRegExp} from '@angular/compiler/src/util';
import {serializeNodes} from '../../../src/i18n/digest'; import {serializeNodes} from '../../../src/i18n/digest';
import {MessageBundle} from '../../../src/i18n/message_bundle'; import {MessageBundle} from '../../../src/i18n/message_bundle';

View File

@ -6,8 +6,7 @@
* found in the LICENSE file at https://angular.io/license * found in the LICENSE file at https://angular.io/license
*/ */
import {escapeRegExp} from '@angular/core/src/facade/lang'; import {escapeRegExp} from '@angular/compiler/src/util';
import {serializeNodes} from '../../../src/i18n/digest'; import {serializeNodes} from '../../../src/i18n/digest';
import * as i18n from '../../../src/i18n/i18n_ast'; import * as i18n from '../../../src/i18n/i18n_ast';
import {Xtb} from '../../../src/i18n/serializers/xtb'; import {Xtb} from '../../../src/i18n/serializers/xtb';

View File

@ -7,12 +7,10 @@
*/ */
import {TEST_COMPILER_PROVIDERS} from '@angular/compiler/testing/test_bindings'; import {TEST_COMPILER_PROVIDERS} from '@angular/compiler/testing/test_bindings';
import {AfterContentChecked, AfterContentInit, AfterViewChecked, AfterViewInit, ChangeDetectionStrategy, Component, Directive, DoCheck, Injectable, NgModule, OnChanges, OnDestroy, OnInit, Pipe, SimpleChanges, ViewEncapsulation} from '@angular/core'; import {AfterContentChecked, AfterContentInit, AfterViewChecked, AfterViewInit, ChangeDetectionStrategy, Component, Directive, DoCheck, Injectable, NgModule, OnChanges, OnDestroy, OnInit, Pipe, SimpleChanges, ViewEncapsulation, ɵstringify as stringify} from '@angular/core';
import {LIFECYCLE_HOOKS_VALUES} from '@angular/core/src/metadata/lifecycle_hooks'; import {LIFECYCLE_HOOKS_VALUES} from '@angular/core/src/metadata/lifecycle_hooks';
import {TestBed, async, inject} from '@angular/core/testing'; import {TestBed, async, inject} from '@angular/core/testing';
import {identifierName} from '../src/compile_metadata'; import {identifierName} from '../src/compile_metadata';
import {stringify} from '../src/facade/lang';
import {CompileMetadataResolver} from '../src/metadata_resolver'; import {CompileMetadataResolver} from '../src/metadata_resolver';
import {ResourceLoader} from '../src/resource_loader'; import {ResourceLoader} from '../src/resource_loader';
import {MockResourceLoader} from '../testing/resource_loader_mock'; import {MockResourceLoader} from '../testing/resource_loader_mock';

View File

@ -7,8 +7,8 @@
*/ */
import {NgModuleResolver} from '@angular/compiler/src/ng_module_resolver'; import {NgModuleResolver} from '@angular/compiler/src/ng_module_resolver';
import {ɵstringify as stringify} from '@angular/core';
import {NgModule} from '@angular/core/src/metadata'; import {NgModule} from '@angular/core/src/metadata';
import {stringify} from '../src/facade/lang';
class SomeClass1 {} class SomeClass1 {}
class SomeClass2 {} class SomeClass2 {}

View File

@ -7,8 +7,8 @@
*/ */
import {PipeResolver} from '@angular/compiler/src/pipe_resolver'; import {PipeResolver} from '@angular/compiler/src/pipe_resolver';
import {ɵstringify as stringify} from '@angular/core';
import {Pipe} from '@angular/core/src/metadata'; import {Pipe} from '@angular/core/src/metadata';
import {stringify} from '../src/facade/lang';
@Pipe({name: 'somePipe', pure: true}) @Pipe({name: 'somePipe', pure: true})
class SomePipe { class SomePipe {

View File

@ -8,7 +8,6 @@
import {MockResourceLoader} from '@angular/compiler/testing/resource_loader_mock'; import {MockResourceLoader} from '@angular/compiler/testing/resource_loader_mock';
import {AsyncTestCompleter, beforeEach, describe, expect, inject, it} from '@angular/core/testing/testing_internal'; import {AsyncTestCompleter, beforeEach, describe, expect, inject, it} from '@angular/core/testing/testing_internal';
import {isPresent} from '../src/facade/lang';
export function main() { export function main() {
describe('MockResourceLoader', () => { describe('MockResourceLoader', () => {
@ -23,7 +22,7 @@ export function main() {
throw `Unexpected response ${url} -> ${text}`; throw `Unexpected response ${url} -> ${text}`;
} else { } else {
expect(text).toEqual(response); expect(text).toEqual(response);
if (isPresent(done)) done(); if (done != null) done();
} }
return text; return text;
} }
@ -33,7 +32,7 @@ export function main() {
throw `Unexpected error ${url}`; throw `Unexpected error ${url}`;
} else { } else {
expect(error).toEqual(`Failed to load ${url}`); expect(error).toEqual(`Failed to load ${url}`);
if (isPresent(done)) done(); if (done != null) done();
} }
return error; return error;
} }

View File

@ -7,11 +7,9 @@
*/ */
import {DirectiveResolver, ResourceLoader} from '@angular/compiler'; import {DirectiveResolver, ResourceLoader} from '@angular/compiler';
import {Compiler, Component, Injector, NgModule, NgModuleFactory, ɵViewMetadata as ViewMetadata} from '@angular/core'; import {Compiler, Component, Injector, NgModule, NgModuleFactory, ɵViewMetadata as ViewMetadata, ɵstringify as stringify} from '@angular/core';
import {TestBed, async, fakeAsync, inject, tick} from '@angular/core/testing'; import {TestBed, async, fakeAsync, inject, tick} from '@angular/core/testing';
import {expect} from '@angular/platform-browser/testing/matchers'; import {expect} from '@angular/platform-browser/testing/matchers';
import {stringify} from '../src/facade/lang';
import {MockDirectiveResolver} from '../testing/index'; import {MockDirectiveResolver} from '../testing/index';
import {SpyResourceLoader} from './spies'; import {SpyResourceLoader} from './spies';

View File

@ -9,7 +9,7 @@
import {fakeAsync} from '@angular/core/testing/fake_async'; import {fakeAsync} from '@angular/core/testing/fake_async';
import {describe, expect, it} from '@angular/core/testing/testing_internal'; import {describe, expect, it} from '@angular/core/testing/testing_internal';
import {SyncAsyncResult, splitAtColon} from '../src/util'; import {SyncAsyncResult, escapeRegExp, splitAtColon} from '../src/util';
export function main() { export function main() {
describe('util', () => { describe('util', () => {
@ -36,5 +36,14 @@ export function main() {
expect(splitAtColon('ab', ['c', 'd'])).toEqual(['c', 'd']); expect(splitAtColon('ab', ['c', 'd'])).toEqual(['c', 'd']);
}); });
}); });
describe('RegExp', () => {
it('should escape regexp', () => {
expect(new RegExp(escapeRegExp('b')).exec('abc')).toBeTruthy();
expect(new RegExp(escapeRegExp('b')).exec('adc')).toBeFalsy();
expect(new RegExp(escapeRegExp('a.b')).exec('a.b')).toBeTruthy();
expect(new RegExp(escapeRegExp('a.b')).exec('axb')).toBeFalsy();
});
});
}); });
} }

View File

@ -7,7 +7,6 @@
*/ */
import {DirectiveResolver} from '@angular/compiler'; import {DirectiveResolver} from '@angular/compiler';
import {Compiler, Component, Directive, Injectable, Injector, Provider, Type, resolveForwardRef, ɵViewMetadata as ViewMetadata} from '@angular/core'; import {Compiler, Component, Directive, Injectable, Injector, Provider, Type, resolveForwardRef, ɵViewMetadata as ViewMetadata} from '@angular/core';
import {isPresent} from './facade/lang';
@ -42,14 +41,14 @@ export class MockDirectiveResolver extends DirectiveResolver {
const viewProviderOverrides = this._viewProviderOverrides.get(type); const viewProviderOverrides = this._viewProviderOverrides.get(type);
let providers = metadata.providers; let providers = metadata.providers;
if (isPresent(providerOverrides)) { if (providerOverrides != null) {
const originalViewProviders: Provider[] = metadata.providers || []; const originalViewProviders: Provider[] = metadata.providers || [];
providers = originalViewProviders.concat(providerOverrides); providers = originalViewProviders.concat(providerOverrides);
} }
if (metadata instanceof Component) { if (metadata instanceof Component) {
let viewProviders = metadata.viewProviders; let viewProviders = metadata.viewProviders;
if (isPresent(viewProviderOverrides)) { if (viewProviderOverrides != null) {
const originalViewProviders: Provider[] = metadata.viewProviders || []; const originalViewProviders: Provider[] = metadata.viewProviders || [];
viewProviders = originalViewProviders.concat(viewProviderOverrides); viewProviders = originalViewProviders.concat(viewProviderOverrides);
} }
@ -63,7 +62,7 @@ export class MockDirectiveResolver extends DirectiveResolver {
let templateUrl = view.templateUrl; let templateUrl = view.templateUrl;
let inlineTemplate = this._inlineTemplates.get(type); let inlineTemplate = this._inlineTemplates.get(type);
if (isPresent(inlineTemplate)) { if (inlineTemplate != null) {
templateUrl = null; templateUrl = null;
} else { } else {
inlineTemplate = view.template; inlineTemplate = view.template;
@ -137,7 +136,7 @@ export class MockDirectiveResolver extends DirectiveResolver {
} }
function flattenArray(tree: any[], out: Array<Type<any>|any[]>): void { function flattenArray(tree: any[], out: Array<Type<any>|any[]>): void {
if (!isPresent(tree)) return; if (tree == null) return;
for (let i = 0; i < tree.length; i++) { for (let i = 0; i < tree.length; i++) {
const item = resolveForwardRef(tree[i]); const item = resolveForwardRef(tree[i]);
if (Array.isArray(item)) { if (Array.isArray(item)) {

View File

@ -1 +0,0 @@
../../facade/src

View File

@ -6,8 +6,8 @@
* found in the LICENSE file at https://angular.io/license * found in the LICENSE file at https://angular.io/license
*/ */
import {ɵstringify as stringify} from '@angular/core';
import {MetadataOverride} from '@angular/core/testing'; import {MetadataOverride} from '@angular/core/testing';
import {stringify} from './facade/lang';
type StringMap = { type StringMap = {
[key: string]: any [key: string]: any

View File

@ -7,7 +7,6 @@
*/ */
import {ResourceLoader} from '@angular/compiler'; import {ResourceLoader} from '@angular/compiler';
import {isBlank} from './facade/lang';
/** /**
* A mock implementation of {@link ResourceLoader} that allows outgoing requests to be mocked * A mock implementation of {@link ResourceLoader} that allows outgoing requests to be mocked
@ -110,7 +109,7 @@ class _PendingRequest {
} }
complete(response: string) { complete(response: string) {
if (isBlank(response)) { if (response == null) {
this.reject(`Failed to load ${this.url}`); this.reject(`Failed to load ${this.url}`);
} else { } else {
this.resolve(response); this.resolve(response);

View File

@ -12,12 +12,9 @@ import {Subject} from 'rxjs/Subject';
import {Subscription} from 'rxjs/Subscription'; import {Subscription} from 'rxjs/Subscription';
import {merge} from 'rxjs/observable/merge'; import {merge} from 'rxjs/observable/merge';
import {share} from 'rxjs/operator/share'; import {share} from 'rxjs/operator/share';
import {ErrorHandler} from '../src/error_handler'; import {ErrorHandler} from '../src/error_handler';
import {stringify} from '../src/facade/lang'; import {scheduleMicroTask, stringify} from '../src/util';
import {scheduleMicroTask} from '../src/util';
import {isPromise} from '../src/util/lang'; import {isPromise} from '../src/util/lang';
import {ApplicationInitStatus} from './application_init'; import {ApplicationInitStatus} from './application_init';
import {APP_BOOTSTRAP_LISTENER, PLATFORM_INITIALIZER} from './application_tokens'; import {APP_BOOTSTRAP_LISTENER, PLATFORM_INITIALIZER} from './application_tokens';
import {Console} from './console'; import {Console} from './console';

View File

@ -12,7 +12,7 @@ import {IterableDifferFactory, IterableDiffers} from './differs/iterable_differs
import {KeyValueDifferFactory, KeyValueDiffers} from './differs/keyvalue_differs'; import {KeyValueDifferFactory, KeyValueDiffers} from './differs/keyvalue_differs';
export {SimpleChanges} from '../metadata/lifecycle_hooks'; export {SimpleChanges} from '../metadata/lifecycle_hooks';
export {SimpleChange, ValueUnwrapper, WrappedValue, devModeEqual, looseIdentical} from './change_detection_util'; export {SimpleChange, ValueUnwrapper, WrappedValue, devModeEqual} from './change_detection_util';
export {ChangeDetectorRef} from './change_detector_ref'; export {ChangeDetectorRef} from './change_detector_ref';
export {ChangeDetectionStrategy, ChangeDetectorStatus, isDefaultChangeDetectionStrategy} from './constants'; export {ChangeDetectionStrategy, ChangeDetectorStatus, isDefaultChangeDetectionStrategy} from './constants';
export {DefaultIterableDifferFactory} from './differs/default_iterable_differ'; export {DefaultIterableDifferFactory} from './differs/default_iterable_differ';

View File

@ -6,23 +6,23 @@
* found in the LICENSE file at https://angular.io/license * found in the LICENSE file at https://angular.io/license
*/ */
import {isJsObject, isPrimitive, looseIdentical} from '../facade/lang'; import {getSymbolIterator, looseIdentical} from '../util';
import {getSymbolIterator} from '../util';
export {looseIdentical} from '../facade/lang';
export function devModeEqual(a: any, b: any): boolean { export function devModeEqual(a: any, b: any): boolean {
if (isListLikeIterable(a) && isListLikeIterable(b)) { const isListLikeIterableA = isListLikeIterable(a);
const isListLikeIterableB = isListLikeIterable(b);
if (isListLikeIterableA && isListLikeIterableB) {
return areIterablesEqual(a, b, devModeEqual); return areIterablesEqual(a, b, devModeEqual);
} else {
} else if ( const isAObject = a && (typeof a === 'object' || typeof a === 'function');
!isListLikeIterable(a) && !isPrimitive(a) && !isListLikeIterable(b) && !isPrimitive(b)) { const isBObject = b && (typeof b === 'object' || typeof b === 'function');
if (!isListLikeIterableA && isAObject && !isListLikeIterableB && isBObject) {
return true; return true;
} else { } else {
return looseIdentical(a, b); return looseIdentical(a, b);
} }
} }
}
/** /**
* Indicates that the result of a {@link Pipe} transformation has changed even though the * Indicates that the result of a {@link Pipe} transformation has changed even though the
@ -113,3 +113,7 @@ export function iterateListLike(obj: any, fn: (p: any) => any) {
} }
} }
} }
export function isJsObject(o: any): boolean {
return o !== null && (typeof o === 'function' || typeof o === 'object');
}

View File

@ -6,7 +6,6 @@
* found in the LICENSE file at https://angular.io/license * found in the LICENSE file at https://angular.io/license
*/ */
import {isBlank} from '../facade/lang';
/** /**
* Describes within the change detector which strategy will be used the next time change * Describes within the change detector which strategy will be used the next time change
@ -68,6 +67,6 @@ export enum ChangeDetectorStatus {
export function isDefaultChangeDetectionStrategy(changeDetectionStrategy: ChangeDetectionStrategy): export function isDefaultChangeDetectionStrategy(changeDetectionStrategy: ChangeDetectionStrategy):
boolean { boolean {
return isBlank(changeDetectionStrategy) || return changeDetectionStrategy == null ||
changeDetectionStrategy === ChangeDetectionStrategy.Default; changeDetectionStrategy === ChangeDetectionStrategy.Default;
} }

View File

@ -6,7 +6,7 @@
* found in the LICENSE file at https://angular.io/license * found in the LICENSE file at https://angular.io/license
*/ */
import {isBlank, looseIdentical, stringify} from '../../facade/lang'; import {looseIdentical, stringify} from '../../util';
import {isListLikeIterable, iterateListLike} from '../change_detection_util'; import {isListLikeIterable, iterateListLike} from '../change_detection_util';
import {ChangeDetectorRef} from '../change_detector_ref'; import {ChangeDetectorRef} from '../change_detector_ref';
@ -155,7 +155,7 @@ export class DefaultIterableDiffer<V> implements IterableDiffer<V>, IterableChan
} }
diff(collection: NgIterable<V>): DefaultIterableDiffer<V> { diff(collection: NgIterable<V>): DefaultIterableDiffer<V> {
if (isBlank(collection)) collection = []; if (collection == null) collection = [];
if (!isListLikeIterable(collection)) { if (!isListLikeIterable(collection)) {
throw new Error(`Error trying to diff '${collection}'`); throw new Error(`Error trying to diff '${collection}'`);
} }

View File

@ -6,7 +6,8 @@
* found in the LICENSE file at https://angular.io/license * found in the LICENSE file at https://angular.io/license
*/ */
import {isJsObject, looseIdentical, stringify} from '../../facade/lang'; import {looseIdentical, stringify} from '../../util';
import {isJsObject} from '../change_detection_util';
import {ChangeDetectorRef} from '../change_detector_ref'; import {ChangeDetectorRef} from '../change_detector_ref';
import {KeyValueChangeRecord, KeyValueChanges, KeyValueDiffer, KeyValueDifferFactory} from './keyvalue_differs'; import {KeyValueChangeRecord, KeyValueChanges, KeyValueDiffer, KeyValueDifferFactory} from './keyvalue_differs';

View File

@ -7,7 +7,6 @@
*/ */
import {Optional, Provider, SkipSelf} from '../../di'; import {Optional, Provider, SkipSelf} from '../../di';
import {getTypeNameForDebugging, isPresent} from '../../facade/lang';
import {ChangeDetectorRef} from '../change_detector_ref'; import {ChangeDetectorRef} from '../change_detector_ref';
/** /**
@ -158,7 +157,7 @@ export class IterableDiffers {
constructor(factories: IterableDifferFactory[]) { this.factories = factories; } constructor(factories: IterableDifferFactory[]) { this.factories = factories; }
static create(factories: IterableDifferFactory[], parent?: IterableDiffers): IterableDiffers { static create(factories: IterableDifferFactory[], parent?: IterableDiffers): IterableDiffers {
if (isPresent(parent)) { if (parent != null) {
const copied = parent.factories.slice(); const copied = parent.factories.slice();
factories = factories.concat(copied); factories = factories.concat(copied);
return new IterableDiffers(factories); return new IterableDiffers(factories);
@ -205,7 +204,7 @@ export class IterableDiffers {
find(iterable: any): IterableDifferFactory { find(iterable: any): IterableDifferFactory {
const factory = this.factories.find(f => f.supports(iterable)); const factory = this.factories.find(f => f.supports(iterable));
if (isPresent(factory)) { if (factory != null) {
return factory; return factory;
} else { } else {
throw new Error( throw new Error(
@ -213,3 +212,7 @@ export class IterableDiffers {
} }
} }
} }
export function getTypeNameForDebugging(type: any): string {
return type['name'] || typeof type;
}

View File

@ -7,11 +7,16 @@
*/ */
import {Injectable} from './di'; import {Injectable} from './di';
import {print, warn} from './facade/lang';
@Injectable() @Injectable()
export class Console { export class Console {
log(message: string): void { print(message); } log(message: string): void {
// Note: for reporting errors use `DOM.logError()` as it is platform specific // tslint:disable-next-line:no-console
warn(message: string): void { warn(message); } console.log(message);
}
// Note: for reporting errors use `DOM.logError()` as it is platform specific
warn(message: string): void {
// tslint:disable-next-line:no-console
console.warn(message);
}
} }

View File

@ -23,6 +23,6 @@ export {ReflectionCapabilities as ɵReflectionCapabilities} from './reflection/r
export {ReflectorReader as ɵReflectorReader} from './reflection/reflector_reader'; export {ReflectorReader as ɵReflectorReader} from './reflection/reflector_reader';
export {GetterFn as ɵGetterFn, MethodFn as ɵMethodFn, SetterFn as ɵSetterFn} from './reflection/types'; export {GetterFn as ɵGetterFn, MethodFn as ɵMethodFn, SetterFn as ɵSetterFn} from './reflection/types';
export {DirectRenderer as ɵDirectRenderer, RenderDebugInfo as ɵRenderDebugInfo} from './render/api'; export {DirectRenderer as ɵDirectRenderer, RenderDebugInfo as ɵRenderDebugInfo} from './render/api';
export {global as ɵglobal} from './util'; export {global as ɵglobal, looseIdentical as ɵlooseIdentical, stringify as ɵstringify} from './util';
export {makeDecorator as ɵmakeDecorator} from './util/decorators'; export {makeDecorator as ɵmakeDecorator} from './util/decorators';
export {isObservable as ɵisObservable, isPromise as ɵisPromise, merge as ɵmerge} from './util/lang'; export {isObservable as ɵisObservable, isPromise as ɵisPromise, merge as ɵmerge} from './util/lang';

View File

@ -6,8 +6,9 @@
* found in the LICENSE file at https://angular.io/license * found in the LICENSE file at https://angular.io/license
*/ */
import {stringify} from '../facade/lang';
import {Type} from '../type'; import {Type} from '../type';
import {stringify} from '../util';
/** /**

View File

@ -6,8 +6,8 @@
* found in the LICENSE file at https://angular.io/license * found in the LICENSE file at https://angular.io/license
*/ */
import {stringify} from '../facade/lang';
import {Type} from '../type'; import {Type} from '../type';
import {stringify} from '../util';
import {InjectionToken} from './injection_token'; import {InjectionToken} from './injection_token';

View File

@ -8,8 +8,8 @@
import {wrappedError} from '../error_handler'; import {wrappedError} from '../error_handler';
import {ERROR_ORIGINAL_ERROR, getOriginalError} from '../errors'; import {ERROR_ORIGINAL_ERROR, getOriginalError} from '../errors';
import {stringify} from '../facade/lang';
import {Type} from '../type'; import {Type} from '../type';
import {stringify} from '../util';
import {ReflectiveInjector} from './reflective_injector'; import {ReflectiveInjector} from './reflective_injector';
import {ReflectiveKey} from './reflective_key'; import {ReflectiveKey} from './reflective_key';

View File

@ -6,8 +6,7 @@
* found in the LICENSE file at https://angular.io/license * found in the LICENSE file at https://angular.io/license
*/ */
import {stringify} from '../facade/lang'; import {stringify} from '../util';
import {resolveForwardRef} from './forward_ref'; import {resolveForwardRef} from './forward_ref';

View File

@ -1 +0,0 @@
../../facade/src

View File

@ -6,8 +6,8 @@
* found in the LICENSE file at https://angular.io/license * found in the LICENSE file at https://angular.io/license
*/ */
import {stringify} from '../facade/lang';
import {Type} from '../type'; import {Type} from '../type';
import {stringify} from '../util';
import {ComponentFactory} from './component_factory'; import {ComponentFactory} from './component_factory';

View File

@ -7,8 +7,9 @@
*/ */
import {Injector, THROW_IF_NOT_FOUND} from '../di/injector'; import {Injector, THROW_IF_NOT_FOUND} from '../di/injector';
import {stringify} from '../facade/lang';
import {Type} from '../type'; import {Type} from '../type';
import {stringify} from '../util';
import {ComponentFactory} from './component_factory'; import {ComponentFactory} from './component_factory';
import {CodegenComponentFactoryResolver, ComponentFactoryResolver} from './component_factory_resolver'; import {CodegenComponentFactoryResolver, ComponentFactoryResolver} from './component_factory_resolver';

View File

@ -6,9 +6,8 @@
* found in the LICENSE file at https://angular.io/license * found in the LICENSE file at https://angular.io/license
*/ */
import {isPresent, stringify} from '../facade/lang';
import {Type, isType} from '../type'; import {Type, isType} from '../type';
import {global} from '../util'; import {global, stringify} from '../util';
import {PlatformReflectionCapabilities} from './platform_reflection_capabilities'; import {PlatformReflectionCapabilities} from './platform_reflection_capabilities';
import {GetterFn, MethodFn, SetterFn} from './types'; import {GetterFn, MethodFn, SetterFn} from './types';
@ -48,7 +47,7 @@ export class ReflectionCapabilities implements PlatformReflectionCapabilities {
} else { } else {
result[i] = []; result[i] = [];
} }
if (paramAnnotations && isPresent(paramAnnotations[i])) { if (paramAnnotations && paramAnnotations[i] != null) {
result[i] = result[i].concat(paramAnnotations[i]); result[i] = result[i].concat(paramAnnotations[i]);
} }
} }
@ -87,7 +86,7 @@ export class ReflectionCapabilities implements PlatformReflectionCapabilities {
} }
// API for metadata created by invoking the decorators. // API for metadata created by invoking the decorators.
if (isPresent(this._reflect) && isPresent(this._reflect.getOwnMetadata)) { if (this._reflect != null && this._reflect.getOwnMetadata != null) {
const paramAnnotations = this._reflect.getOwnMetadata('parameters', type); const paramAnnotations = this._reflect.getOwnMetadata('parameters', type);
const paramTypes = this._reflect.getOwnMetadata('design:paramtypes', type); const paramTypes = this._reflect.getOwnMetadata('design:paramtypes', type);
if (paramTypes || paramAnnotations) { if (paramTypes || paramAnnotations) {

View File

@ -24,7 +24,7 @@ declare const Symbol: any;
let _symbolIterator: any = null; let _symbolIterator: any = null;
export function getSymbolIterator(): string|symbol { export function getSymbolIterator(): string|symbol {
if (!_symbolIterator) { if (!_symbolIterator) {
var Symbol = _global['Symbol']; const Symbol = _global['Symbol'];
if (Symbol && Symbol.iterator) { if (Symbol && Symbol.iterator) {
_symbolIterator = Symbol.iterator; _symbolIterator = Symbol.iterator;
} else { } else {
@ -45,3 +45,30 @@ export function getSymbolIterator(): string|symbol {
export function scheduleMicroTask(fn: Function) { export function scheduleMicroTask(fn: Function) {
Zone.current.scheduleMicroTask('scheduleMicrotask', fn); Zone.current.scheduleMicroTask('scheduleMicrotask', fn);
} }
// JS has NaN !== NaN
export function looseIdentical(a: any, b: any): boolean {
return a === b || typeof a === 'number' && typeof b === 'number' && isNaN(a) && isNaN(b);
}
export function stringify(token: any): string {
if (typeof token === 'string') {
return token;
}
if (token == null) {
return '' + token;
}
if (token.overriddenName) {
return `${token.overriddenName}`;
}
if (token.name) {
return `${token.name}`;
}
const res = token.toString();
const newLineIndex = res.indexOf('\n');
return newLineIndex === -1 ? res : res.substring(0, newLineIndex);
}

View File

@ -6,9 +6,8 @@
* found in the LICENSE file at https://angular.io/license * found in the LICENSE file at https://angular.io/license
*/ */
import {stringify} from '../facade/lang';
import {Type} from '../type'; import {Type} from '../type';
import {global} from '../util'; import {global, stringify} from '../util';
let _nextClassId = 0; let _nextClassId = 0;
const Reflect = global['Reflect']; const Reflect = global['Reflect'];

View File

@ -7,7 +7,7 @@
*/ */
import {isDevMode} from '../application_ref'; import {isDevMode} from '../application_ref';
import {looseIdentical} from '../facade/lang'; import {looseIdentical} from '../util';
import {BindingDef, BindingType, DebugContext, NodeData, NodeDef, NodeFlags, RootData, Services, TextData, ViewData, ViewFlags, asElementData, asTextData} from './types'; import {BindingDef, BindingType, DebugContext, NodeData, NodeDef, NodeFlags, RootData, Services, TextData, ViewData, ViewFlags, asElementData, asTextData} from './types';
import {checkAndUpdateBinding, getParentRenderElement, sliceErrorStack} from './util'; import {checkAndUpdateBinding, getParentRenderElement, sliceErrorStack} from './util';

View File

@ -10,12 +10,12 @@ import {isDevMode} from '../application_ref';
import {WrappedValue, devModeEqual} from '../change_detection/change_detection'; import {WrappedValue, devModeEqual} from '../change_detection/change_detection';
import {SimpleChange} from '../change_detection/change_detection_util'; import {SimpleChange} from '../change_detection/change_detection_util';
import {Injector} from '../di'; import {Injector} from '../di';
import {looseIdentical, stringify} from '../facade/lang';
import {TemplateRef} from '../linker/template_ref'; import {TemplateRef} from '../linker/template_ref';
import {ViewContainerRef} from '../linker/view_container_ref'; import {ViewContainerRef} from '../linker/view_container_ref';
import {ViewRef} from '../linker/view_ref'; import {ViewRef} from '../linker/view_ref';
import {ViewEncapsulation} from '../metadata/view'; import {ViewEncapsulation} from '../metadata/view';
import {Renderer, RendererTypeV2} from '../render/api'; import {Renderer, RendererTypeV2} from '../render/api';
import {looseIdentical, stringify} from '../util';
import {expressionChangedAfterItHasBeenCheckedError, isViewDebugError, viewDestroyedError, viewWrappedDebugError} from './errors'; import {expressionChangedAfterItHasBeenCheckedError, isViewDebugError, viewDestroyedError, viewWrappedDebugError} from './errors';
import {DebugContext, ElementData, NodeData, NodeDef, NodeFlags, QueryValueType, Services, ViewData, ViewDefinition, ViewDefinitionFactory, ViewFlags, ViewState, asElementData, asProviderData, asTextData} from './types'; import {DebugContext, ElementData, NodeData, NodeDef, NodeFlags, QueryValueType, Services, ViewData, ViewDefinition, ViewDefinitionFactory, ViewFlags, ViewState, asElementData, asProviderData, asTextData} from './types';

View File

@ -11,8 +11,7 @@ import {ReflectiveInjector_} from '@angular/core/src/di/reflective_injector';
import {ResolvedReflectiveProvider_} from '@angular/core/src/di/reflective_provider'; import {ResolvedReflectiveProvider_} from '@angular/core/src/di/reflective_provider';
import {getOriginalError} from '@angular/core/src/errors'; import {getOriginalError} from '@angular/core/src/errors';
import {expect} from '@angular/platform-browser/testing/matchers'; import {expect} from '@angular/platform-browser/testing/matchers';
import {stringify} from '../../src/util';
import {isPresent, stringify} from '../../src/facade/lang';
class Engine {} class Engine {}
@ -82,7 +81,7 @@ export function main() {
function createInjector( function createInjector(
providers: Provider[], parent: ReflectiveInjector = null): ReflectiveInjector_ { providers: Provider[], parent: ReflectiveInjector = null): ReflectiveInjector_ {
const resolvedProviders = ReflectiveInjector.resolve(providers.concat(dynamicProviders)); const resolvedProviders = ReflectiveInjector.resolve(providers.concat(dynamicProviders));
if (isPresent(parent)) { if (parent != null) {
return <ReflectiveInjector_>parent.createChildFromResolved(resolvedProviders); return <ReflectiveInjector_>parent.createChildFromResolved(resolvedProviders);
} else { } else {
return <ReflectiveInjector_>ReflectiveInjector.fromResolvedProviders(resolvedProviders); return <ReflectiveInjector_>ReflectiveInjector.fromResolvedProviders(resolvedProviders);

View File

@ -1,63 +0,0 @@
/**
* @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 {AsyncTestCompleter, describe, expect, inject, it} from '@angular/core/testing/testing_internal';
import {Observable} from 'rxjs/Observable';
export function main() {
describe('Observable', () => {
describe('#core', () => {
it('should call next with values',
inject([AsyncTestCompleter], (async: AsyncTestCompleter) => {
const o = new Observable((sink: any /** TODO #9100 */) => { sink.next(1); });
o.subscribe(v => {
expect(v).toEqual(1);
async.done();
});
}));
it('should call next and then complete',
inject([AsyncTestCompleter], (async: AsyncTestCompleter) => {
const o = new Observable((sink: any /** TODO #9100 */) => {
sink.next(1);
sink.complete();
});
let nexted = false;
o.subscribe(
v => { nexted = true; }, null,
() => {
expect(nexted).toBe(true);
async.done();
});
}));
it('should call error with errors',
inject([AsyncTestCompleter], (async: AsyncTestCompleter) => {
const o = new Observable((sink: any /** TODO #9100 */) => { sink.error('oh noes!'); });
o.subscribe(
v => {
},
(err) => {
expect(err).toEqual('oh noes!');
async.done();
});
}));
});
});
}

View File

@ -22,8 +22,7 @@ import {getDOM} from '@angular/platform-browser/src/dom/dom_adapter';
import {DOCUMENT} from '@angular/platform-browser/src/dom/dom_tokens'; import {DOCUMENT} from '@angular/platform-browser/src/dom/dom_tokens';
import {dispatchEvent, el} from '@angular/platform-browser/testing/browser_util'; import {dispatchEvent, el} from '@angular/platform-browser/testing/browser_util';
import {expect} from '@angular/platform-browser/testing/matchers'; import {expect} from '@angular/platform-browser/testing/matchers';
import {stringify} from '../../src/util';
import {stringify} from '../../src/facade/lang';
const ANCHOR_ELEMENT = new InjectionToken('AnchorElement'); const ANCHOR_ELEMENT = new InjectionToken('AnchorElement');

View File

@ -11,9 +11,9 @@ import {Console} from '@angular/core/src/console';
import {ComponentFixture, TestBed, inject} from '@angular/core/testing'; import {ComponentFixture, TestBed, inject} from '@angular/core/testing';
import {expect} from '@angular/platform-browser/testing/matchers'; import {expect} from '@angular/platform-browser/testing/matchers';
import {stringify} from '../../src/facade/lang';
import {NgModuleInjector} from '../../src/linker/ng_module_factory'; import {NgModuleInjector} from '../../src/linker/ng_module_factory';
import {clearModulesForTest} from '../../src/linker/ng_module_factory_loader'; import {clearModulesForTest} from '../../src/linker/ng_module_factory_loader';
import {stringify} from '../../src/util';
class Engine {} class Engine {}

View File

@ -10,7 +10,7 @@ import {AfterContentChecked, AfterContentInit, AfterViewChecked, AfterViewInit,
import {ComponentFixture, TestBed, async} from '@angular/core/testing'; import {ComponentFixture, TestBed, async} from '@angular/core/testing';
import {expect} from '@angular/platform-browser/testing/matchers'; import {expect} from '@angular/platform-browser/testing/matchers';
import {stringify} from '../../src/facade/lang'; import {stringify} from '../../src/util';
export function main() { export function main() {
describe('Query API', () => { describe('Query API', () => {

View File

@ -10,7 +10,6 @@ import {NgZone} from '@angular/core/src/zone/ng_zone';
import {async, fakeAsync, flushMicrotasks} from '@angular/core/testing'; import {async, fakeAsync, flushMicrotasks} from '@angular/core/testing';
import {AsyncTestCompleter, Log, beforeEach, describe, expect, inject, it, xit} from '@angular/core/testing/testing_internal'; import {AsyncTestCompleter, Log, beforeEach, describe, expect, inject, it, xit} from '@angular/core/testing/testing_internal';
import {browserDetection} from '@angular/platform-browser/testing/browser_util'; import {browserDetection} from '@angular/platform-browser/testing/browser_util';
import {isPresent} from '../../src/facade/lang';
import {scheduleMicroTask} from '../../src/util'; import {scheduleMicroTask} from '../../src/util';
const needsLongerTimers = browserDetection.isSlow || browserDetection.isEdge; const needsLongerTimers = browserDetection.isSlow || browserDetection.isEdge;
@ -159,7 +158,7 @@ export function main() {
promise.then((_) => { promise.then((_) => {
expect(_traces.length).toBe(1); expect(_traces.length).toBe(1);
if (isPresent(_traces[0])) { if (_traces[0] != null) {
// some browsers don't have stack traces. // some browsers don't have stack traces.
expect(_traces[0].indexOf('---')).toEqual(-1); expect(_traces[0].indexOf('---')).toEqual(-1);
} }

View File

@ -1 +0,0 @@
../../facade/src

View File

@ -6,10 +6,9 @@
* found in the LICENSE file at https://angular.io/license * found in the LICENSE file at https://angular.io/license
*/ */
import {CompilerOptions, Component, Directive, InjectionToken, Injector, ModuleWithComponentFactories, NgModule, NgModuleRef, NgZone, Pipe, PlatformRef, Provider, ReflectiveInjector, SchemaMetadata, Type, ɵERROR_COMPONENT_TYPE} from '@angular/core'; import {CompilerOptions, Component, Directive, InjectionToken, Injector, ModuleWithComponentFactories, NgModule, NgModuleRef, NgZone, Pipe, PlatformRef, Provider, ReflectiveInjector, SchemaMetadata, Type, ɵERROR_COMPONENT_TYPE, ɵstringify as stringify} from '@angular/core';
import {AsyncTestCompleter} from './async_test_completer'; import {AsyncTestCompleter} from './async_test_completer';
import {ComponentFixture} from './component_fixture'; import {ComponentFixture} from './component_fixture';
import {stringify} from './facade/lang';
import {MetadataOverride} from './metadata_override'; import {MetadataOverride} from './metadata_override';
import {TestingCompiler, TestingCompilerFactory} from './test_compiler'; import {TestingCompiler, TestingCompilerFactory} from './test_compiler';

View File

@ -1,19 +0,0 @@
/**
* @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
*/
/* tslint:disable:no-console */
// #docregion Observable
import {Observable} from 'rxjs/Observable';
import {Subscriber} from 'rxjs/Subscriber';
const obs = new Observable<number>((obs: Subscriber<number>) => {
let i = 0;
setInterval(() => { obs.next(++i); }, 1000);
});
obs.subscribe(i => console.log(`${i} seconds elapsed`));
// #enddocregion

View File

@ -1,21 +0,0 @@
/**
* @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
*/
/* tslint:disable:no-console */
// #docregion Observable
import 'rxjs/add/operator/map';
import {Observable} from 'rxjs/Observable';
import {Subscriber} from 'rxjs/Subscriber';
const obs = new Observable<number>((obs: Subscriber<any>) => {
let i = 0;
setInterval(() => obs.next(++i), 1000);
});
obs.map((i: number) => `${i} seconds elapsed`).subscribe(msg => console.log(msg));
// #enddocregion

View File

@ -1,20 +0,0 @@
/**
* @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
*/
/* tslint:disable:no-console */
// #docregion Observable
import {Observable} from 'rxjs/Observable';
import {Subscriber} from 'rxjs/Subscriber';
import {map} from 'rxjs/operator/map';
const obs = new Observable<number>((sub: Subscriber<number>) => {
let i = 0;
setInterval(() => sub.next(++i), 1000);
});
map.call(obs, (i: number) => `${i} seconds elapsed`).subscribe((msg: string) => console.log(msg));
// #enddocregion

View File

@ -1,102 +0,0 @@
/**
* @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
*/
export function getTypeNameForDebugging(type: any): string {
return type['name'] || typeof type;
}
export function isPresent(obj: any): boolean {
return obj != null;
}
export function isBlank(obj: any): boolean {
return obj == null;
}
const STRING_MAP_PROTO = Object.getPrototypeOf({});
export function isStrictStringMap(obj: any): boolean {
return typeof obj === 'object' && obj !== null && Object.getPrototypeOf(obj) === STRING_MAP_PROTO;
}
export function stringify(token: any): string {
if (typeof token === 'string') {
return token;
}
if (token == null) {
return '' + token;
}
if (token.overriddenName) {
return `${token.overriddenName}`;
}
if (token.name) {
return `${token.name}`;
}
const res = token.toString();
const newLineIndex = res.indexOf('\n');
return newLineIndex === -1 ? res : res.substring(0, newLineIndex);
}
export class NumberWrapper {
static parseIntAutoRadix(text: string): number {
const result: number = parseInt(text);
if (isNaN(result)) {
throw new Error('Invalid integer literal when parsing ' + text);
}
return result;
}
static isNumeric(value: any): boolean { return !isNaN(value - parseFloat(value)); }
}
// JS has NaN !== NaN
export function looseIdentical(a: any, b: any): boolean {
return a === b || typeof a === 'number' && typeof b === 'number' && isNaN(a) && isNaN(b);
}
export function isJsObject(o: any): boolean {
return o !== null && (typeof o === 'function' || typeof o === 'object');
}
export function print(obj: Error | Object) {
// tslint:disable-next-line:no-console
console.log(obj);
}
export function warn(obj: Error | Object) {
console.warn(obj);
}
export function setValueOnPath(global: any, path: string, value: any) {
const parts = path.split('.');
let obj: any = global;
while (parts.length > 1) {
const name = parts.shift();
if (obj.hasOwnProperty(name) && obj[name] != null) {
obj = obj[name];
} else {
obj = obj[name] = {};
}
}
if (obj === undefined || obj === null) {
obj = {};
}
obj[parts.shift()] = value;
}
export function isPrimitive(obj: any): boolean {
return !isJsObject(obj);
}
export function escapeRegExp(s: string): string {
return s.replace(/([.*+?^=!:${}()|[\]\/\\])/g, '\\$1');
}

View File

@ -1,43 +0,0 @@
/**
* @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 {NumberWrapper, escapeRegExp} from '../src/lang';
export function main() {
describe('RegExp', () => {
it('should escape regexp', () => {
expect(new RegExp(escapeRegExp('b')).exec('abc')).toBeTruthy();
expect(new RegExp(escapeRegExp('b')).exec('adc')).toBeFalsy();
expect(new RegExp(escapeRegExp('a.b')).exec('a.b')).toBeTruthy();
expect(new RegExp(escapeRegExp('a.b')).exec('axb')).toBeFalsy();
});
});
describe('Number', () => {
describe('isNumeric', () => {
it('should return true when passing correct numeric string',
() => { expect(NumberWrapper.isNumeric('2')).toBe(true); });
it('should return true when passing correct double string',
() => { expect(NumberWrapper.isNumeric('1.123')).toBe(true); });
it('should return true when passing correct negative string',
() => { expect(NumberWrapper.isNumeric('-2')).toBe(true); });
it('should return true when passing correct scientific notation string',
() => { expect(NumberWrapper.isNumeric('1e5')).toBe(true); });
it('should return false when passing incorrect numeric',
() => { expect(NumberWrapper.isNumeric('a')).toBe(false); });
it('should return false when passing parseable but non numeric',
() => { expect(NumberWrapper.isNumeric('2a')).toBe(false); });
});
});
}

Some files were not shown because too many files have changed in this diff Show More