refactor: add override keyword to members implementing abstract declarations (#42512)
In combination with the TS `noImplicitOverride` compatibility changes, we also want to follow the best-practice of adding `override` to members which are implemented as part of abstract classes. This commit fixes all instances which will be flagged as part of the custom `no-implicit-override-abstract` TSLint rule. PR Close #42512
This commit is contained in:
parent
04642e7985
commit
b5ab7aff43
|
@ -13,10 +13,10 @@ const exampleData = 'this is example data' as const;
|
||||||
|
|
||||||
/** A simple usage of the BaseModule to illustrate the workings built into the abstract class. */
|
/** A simple usage of the BaseModule to illustrate the workings built into the abstract class. */
|
||||||
class ConcreteBaseModule extends BaseModule<typeof exampleData> {
|
class ConcreteBaseModule extends BaseModule<typeof exampleData> {
|
||||||
async retrieveData() {
|
override async retrieveData() {
|
||||||
return exampleData;
|
return exampleData;
|
||||||
}
|
}
|
||||||
async printToTerminal() {}
|
override async printToTerminal() {}
|
||||||
}
|
}
|
||||||
|
|
||||||
describe('BaseModule', () => {
|
describe('BaseModule', () => {
|
||||||
|
|
|
@ -25,7 +25,7 @@ type CiData = {
|
||||||
}[];
|
}[];
|
||||||
|
|
||||||
export class CiModule extends BaseModule<CiData> {
|
export class CiModule extends BaseModule<CiData> {
|
||||||
async retrieveData() {
|
override async retrieveData() {
|
||||||
const gitRepoWithApi = {api: this.git.github, ...this.git.remoteConfig};
|
const gitRepoWithApi = {api: this.git.github, ...this.git.remoteConfig};
|
||||||
const releaseTrains = await fetchActiveReleaseTrains(gitRepoWithApi);
|
const releaseTrains = await fetchActiveReleaseTrains(gitRepoWithApi);
|
||||||
|
|
||||||
|
@ -52,7 +52,7 @@ export class CiModule extends BaseModule<CiData> {
|
||||||
return await Promise.all(ciResultPromises);
|
return await Promise.all(ciResultPromises);
|
||||||
}
|
}
|
||||||
|
|
||||||
async printToTerminal() {
|
override async printToTerminal() {
|
||||||
const data = await this.data;
|
const data = await this.data;
|
||||||
const minLabelLength = Math.max(...data.map(result => result.label.length));
|
const minLabelLength = Math.max(...data.map(result => result.label.length));
|
||||||
info.group(bold(`CI`));
|
info.group(bold(`CI`));
|
||||||
|
|
|
@ -23,7 +23,7 @@ export interface G3StatsData {
|
||||||
}
|
}
|
||||||
|
|
||||||
export class G3Module extends BaseModule<G3StatsData|void> {
|
export class G3Module extends BaseModule<G3StatsData|void> {
|
||||||
async retrieveData() {
|
override async retrieveData() {
|
||||||
const toCopyToG3 = this.getG3FileIncludeAndExcludeLists();
|
const toCopyToG3 = this.getG3FileIncludeAndExcludeLists();
|
||||||
const latestSha = this.getLatestShas();
|
const latestSha = this.getLatestShas();
|
||||||
|
|
||||||
|
@ -35,7 +35,7 @@ export class G3Module extends BaseModule<G3StatsData|void> {
|
||||||
latestSha.g3, latestSha.master, toCopyToG3.include, toCopyToG3.exclude);
|
latestSha.g3, latestSha.master, toCopyToG3.include, toCopyToG3.exclude);
|
||||||
}
|
}
|
||||||
|
|
||||||
async printToTerminal() {
|
override async printToTerminal() {
|
||||||
const stats = await this.data;
|
const stats = await this.data;
|
||||||
if (!stats) {
|
if (!stats) {
|
||||||
return;
|
return;
|
||||||
|
|
|
@ -45,7 +45,7 @@ type GithubQueryResult = {
|
||||||
const MAX_RETURNED_ISSUES = 20;
|
const MAX_RETURNED_ISSUES = 20;
|
||||||
|
|
||||||
export class GithubQueriesModule extends BaseModule<GithubQueryResults|void> {
|
export class GithubQueriesModule extends BaseModule<GithubQueryResults|void> {
|
||||||
async retrieveData() {
|
override async retrieveData() {
|
||||||
// Non-null assertion is used here as the check for undefined immediately follows to confirm the
|
// Non-null assertion is used here as the check for undefined immediately follows to confirm the
|
||||||
// assertion. Typescript's type filtering does not seem to work as needed to understand
|
// assertion. Typescript's type filtering does not seem to work as needed to understand
|
||||||
// whether githubQueries is undefined or not.
|
// whether githubQueries is undefined or not.
|
||||||
|
@ -95,7 +95,7 @@ export class GithubQueriesModule extends BaseModule<GithubQueryResults|void> {
|
||||||
return graphqlQuery;
|
return graphqlQuery;
|
||||||
}
|
}
|
||||||
|
|
||||||
async printToTerminal() {
|
override async printToTerminal() {
|
||||||
const queryResults = await this.data;
|
const queryResults = await this.data;
|
||||||
if (!queryResults) {
|
if (!queryResults) {
|
||||||
return;
|
return;
|
||||||
|
|
|
@ -45,11 +45,11 @@ export const services: ServiceConfig[] = [
|
||||||
];
|
];
|
||||||
|
|
||||||
export class ServicesModule extends BaseModule<StatusCheckResult[]> {
|
export class ServicesModule extends BaseModule<StatusCheckResult[]> {
|
||||||
async retrieveData() {
|
override async retrieveData() {
|
||||||
return Promise.all(services.map(service => this.getStatusFromStandardApi(service)));
|
return Promise.all(services.map(service => this.getStatusFromStandardApi(service)));
|
||||||
}
|
}
|
||||||
|
|
||||||
async printToTerminal() {
|
override async printToTerminal() {
|
||||||
const statuses = await this.data;
|
const statuses = await this.data;
|
||||||
const serviceNameMinLength = Math.max(...statuses.map(service => service.name.length));
|
const serviceNameMinLength = Math.max(...statuses.map(service => service.name.length));
|
||||||
info.group(bold('Service Statuses'));
|
info.group(bold('Service Statuses'));
|
||||||
|
|
|
@ -16,13 +16,13 @@ import {Formatter} from './base-formatter';
|
||||||
* Formatter for running buildifier against bazel related files.
|
* Formatter for running buildifier against bazel related files.
|
||||||
*/
|
*/
|
||||||
export class Buildifier extends Formatter {
|
export class Buildifier extends Formatter {
|
||||||
name = 'buildifier';
|
override name = 'buildifier';
|
||||||
|
|
||||||
binaryFilePath = join(this.git.baseDir, 'node_modules/.bin/buildifier');
|
override binaryFilePath = join(this.git.baseDir, 'node_modules/.bin/buildifier');
|
||||||
|
|
||||||
defaultFileMatcher = ['**/*.bzl', '**/BUILD.bazel', '**/WORKSPACE', '**/BUILD'];
|
override defaultFileMatcher = ['**/*.bzl', '**/BUILD.bazel', '**/WORKSPACE', '**/BUILD'];
|
||||||
|
|
||||||
actions = {
|
override actions = {
|
||||||
check: {
|
check: {
|
||||||
commandFlags: `${BAZEL_WARNING_FLAG} --lint=warn --mode=check --format=json`,
|
commandFlags: `${BAZEL_WARNING_FLAG} --lint=warn --mode=check --format=json`,
|
||||||
callback:
|
callback:
|
||||||
|
|
|
@ -16,13 +16,13 @@ import {Formatter} from './base-formatter';
|
||||||
* Formatter for running clang-format against Typescript and Javascript files
|
* Formatter for running clang-format against Typescript and Javascript files
|
||||||
*/
|
*/
|
||||||
export class ClangFormat extends Formatter {
|
export class ClangFormat extends Formatter {
|
||||||
name = 'clang-format';
|
override name = 'clang-format';
|
||||||
|
|
||||||
binaryFilePath = join(this.git.baseDir, 'node_modules/.bin/clang-format');
|
override binaryFilePath = join(this.git.baseDir, 'node_modules/.bin/clang-format');
|
||||||
|
|
||||||
defaultFileMatcher = ['**/*.{t,j}s'];
|
override defaultFileMatcher = ['**/*.{t,j}s'];
|
||||||
|
|
||||||
actions = {
|
override actions = {
|
||||||
check: {
|
check: {
|
||||||
commandFlags: `--Werror -n -style=file`,
|
commandFlags: `--Werror -n -style=file`,
|
||||||
callback:
|
callback:
|
||||||
|
|
|
@ -17,11 +17,11 @@ import {Formatter} from './base-formatter';
|
||||||
* Formatter for running prettier against Typescript and Javascript files.
|
* Formatter for running prettier against Typescript and Javascript files.
|
||||||
*/
|
*/
|
||||||
export class Prettier extends Formatter {
|
export class Prettier extends Formatter {
|
||||||
name = 'prettier';
|
override name = 'prettier';
|
||||||
|
|
||||||
binaryFilePath = join(this.git.baseDir, 'node_modules/.bin/prettier');
|
override binaryFilePath = join(this.git.baseDir, 'node_modules/.bin/prettier');
|
||||||
|
|
||||||
defaultFileMatcher = ['**/*.{t,j}s'];
|
override defaultFileMatcher = ['**/*.{t,j}s'];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The configuration path of the prettier config, obtained during construction to prevent needing
|
* The configuration path of the prettier config, obtained during construction to prevent needing
|
||||||
|
@ -30,7 +30,7 @@ export class Prettier extends Formatter {
|
||||||
private configPath =
|
private configPath =
|
||||||
this.config['prettier'] ? exec(`${this.binaryFilePath} --find-config-path .`).trim() : '';
|
this.config['prettier'] ? exec(`${this.binaryFilePath} --find-config-path .`).trim() : '';
|
||||||
|
|
||||||
actions = {
|
override actions = {
|
||||||
check: {
|
check: {
|
||||||
commandFlags: `--config ${this.configPath} --check`,
|
commandFlags: `--config ${this.configPath} --check`,
|
||||||
callback:
|
callback:
|
||||||
|
|
|
@ -44,7 +44,7 @@ export class GithubApiMergeStrategy extends MergeStrategy {
|
||||||
super(git);
|
super(git);
|
||||||
}
|
}
|
||||||
|
|
||||||
async merge(pullRequest: PullRequest): Promise<PullRequestFailure|null> {
|
override async merge(pullRequest: PullRequest): Promise<PullRequestFailure|null> {
|
||||||
const {githubTargetBranch, prNumber, targetBranches, requiredBaseSha, needsCommitMessageFixup} =
|
const {githubTargetBranch, prNumber, targetBranches, requiredBaseSha, needsCommitMessageFixup} =
|
||||||
pullRequest;
|
pullRequest;
|
||||||
// If the pull request does not have its base branch set to any determined target
|
// If the pull request does not have its base branch set to any determined target
|
||||||
|
|
|
@ -31,7 +31,7 @@ export class AutosquashMergeStrategy extends MergeStrategy {
|
||||||
* specific to the pull request merge.
|
* specific to the pull request merge.
|
||||||
* @returns A pull request failure or null in case of success.
|
* @returns A pull request failure or null in case of success.
|
||||||
*/
|
*/
|
||||||
async merge(pullRequest: PullRequest): Promise<PullRequestFailure|null> {
|
override async merge(pullRequest: PullRequest): Promise<PullRequestFailure|null> {
|
||||||
const {prNumber, targetBranches, requiredBaseSha, needsCommitMessageFixup, githubTargetBranch} =
|
const {prNumber, targetBranches, requiredBaseSha, needsCommitMessageFixup, githubTargetBranch} =
|
||||||
pullRequest;
|
pullRequest;
|
||||||
// In case a required base is specified for this pull request, check if the pull
|
// In case a required base is specified for this pull request, check if the pull
|
||||||
|
|
|
@ -21,13 +21,13 @@ import {packageJsonPath} from '../constants';
|
||||||
export class ConfigureNextAsMajorAction extends ReleaseAction {
|
export class ConfigureNextAsMajorAction extends ReleaseAction {
|
||||||
private _newVersion = semver.parse(`${this.active.next.version.major + 1}.0.0-next.0`)!;
|
private _newVersion = semver.parse(`${this.active.next.version.major + 1}.0.0-next.0`)!;
|
||||||
|
|
||||||
async getDescription() {
|
override async getDescription() {
|
||||||
const {branchName} = this.active.next;
|
const {branchName} = this.active.next;
|
||||||
const newVersion = this._newVersion;
|
const newVersion = this._newVersion;
|
||||||
return `Configure the "${branchName}" branch to be released as major (v${newVersion}).`;
|
return `Configure the "${branchName}" branch to be released as major (v${newVersion}).`;
|
||||||
}
|
}
|
||||||
|
|
||||||
async perform() {
|
override async perform() {
|
||||||
const {branchName} = this.active.next;
|
const {branchName} = this.active.next;
|
||||||
const newVersion = this._newVersion;
|
const newVersion = this._newVersion;
|
||||||
|
|
||||||
|
|
|
@ -22,12 +22,12 @@ export class CutLongTermSupportPatchAction extends ReleaseAction {
|
||||||
/** Promise resolving an object describing long-term support branches. */
|
/** Promise resolving an object describing long-term support branches. */
|
||||||
ltsBranches = fetchLongTermSupportBranchesFromNpm(this.config);
|
ltsBranches = fetchLongTermSupportBranchesFromNpm(this.config);
|
||||||
|
|
||||||
async getDescription() {
|
override async getDescription() {
|
||||||
const {active} = await this.ltsBranches;
|
const {active} = await this.ltsBranches;
|
||||||
return `Cut a new release for an active LTS branch (${active.length} active).`;
|
return `Cut a new release for an active LTS branch (${active.length} active).`;
|
||||||
}
|
}
|
||||||
|
|
||||||
async perform() {
|
override async perform() {
|
||||||
const ltsBranch = await this._promptForTargetLtsBranch();
|
const ltsBranch = await this._promptForTargetLtsBranch();
|
||||||
const newVersion = semverInc(ltsBranch.version, 'patch');
|
const newVersion = semverInc(ltsBranch.version, 'patch');
|
||||||
const {pullRequest: {id}, releaseNotes} =
|
const {pullRequest: {id}, releaseNotes} =
|
||||||
|
|
|
@ -18,13 +18,13 @@ import {ReleaseAction} from '../actions';
|
||||||
export class CutNewPatchAction extends ReleaseAction {
|
export class CutNewPatchAction extends ReleaseAction {
|
||||||
private _newVersion = semverInc(this.active.latest.version, 'patch');
|
private _newVersion = semverInc(this.active.latest.version, 'patch');
|
||||||
|
|
||||||
async getDescription() {
|
override async getDescription() {
|
||||||
const {branchName} = this.active.latest;
|
const {branchName} = this.active.latest;
|
||||||
const newVersion = this._newVersion;
|
const newVersion = this._newVersion;
|
||||||
return `Cut a new patch release for the "${branchName}" branch (v${newVersion}).`;
|
return `Cut a new patch release for the "${branchName}" branch (v${newVersion}).`;
|
||||||
}
|
}
|
||||||
|
|
||||||
async perform() {
|
override async perform() {
|
||||||
const {branchName} = this.active.latest;
|
const {branchName} = this.active.latest;
|
||||||
const newVersion = this._newVersion;
|
const newVersion = this._newVersion;
|
||||||
|
|
||||||
|
|
|
@ -21,13 +21,13 @@ export class CutNextPrereleaseAction extends ReleaseAction {
|
||||||
/** Promise resolving with the new version if a NPM next pre-release is cut. */
|
/** Promise resolving with the new version if a NPM next pre-release is cut. */
|
||||||
private _newVersion: Promise<semver.SemVer> = this._computeNewVersion();
|
private _newVersion: Promise<semver.SemVer> = this._computeNewVersion();
|
||||||
|
|
||||||
async getDescription() {
|
override async getDescription() {
|
||||||
const {branchName} = this._getActivePrereleaseTrain();
|
const {branchName} = this._getActivePrereleaseTrain();
|
||||||
const newVersion = await this._newVersion;
|
const newVersion = await this._newVersion;
|
||||||
return `Cut a new next pre-release for the "${branchName}" branch (v${newVersion}).`;
|
return `Cut a new next pre-release for the "${branchName}" branch (v${newVersion}).`;
|
||||||
}
|
}
|
||||||
|
|
||||||
async perform() {
|
override async perform() {
|
||||||
const releaseTrain = this._getActivePrereleaseTrain();
|
const releaseTrain = this._getActivePrereleaseTrain();
|
||||||
const {branchName} = releaseTrain;
|
const {branchName} = releaseTrain;
|
||||||
const newVersion = await this._newVersion;
|
const newVersion = await this._newVersion;
|
||||||
|
|
|
@ -17,12 +17,12 @@ import {ReleaseAction} from '../actions';
|
||||||
export class CutReleaseCandidateAction extends ReleaseAction {
|
export class CutReleaseCandidateAction extends ReleaseAction {
|
||||||
private _newVersion = semverInc(this.active.releaseCandidate!.version, 'prerelease', 'rc');
|
private _newVersion = semverInc(this.active.releaseCandidate!.version, 'prerelease', 'rc');
|
||||||
|
|
||||||
async getDescription() {
|
override async getDescription() {
|
||||||
const newVersion = this._newVersion;
|
const newVersion = this._newVersion;
|
||||||
return `Cut a first release-candidate for the feature-freeze branch (v${newVersion}).`;
|
return `Cut a first release-candidate for the feature-freeze branch (v${newVersion}).`;
|
||||||
}
|
}
|
||||||
|
|
||||||
async perform() {
|
override async perform() {
|
||||||
const {branchName} = this.active.releaseCandidate!;
|
const {branchName} = this.active.releaseCandidate!;
|
||||||
const newVersion = this._newVersion;
|
const newVersion = this._newVersion;
|
||||||
|
|
||||||
|
|
|
@ -20,12 +20,12 @@ import {invokeSetNpmDistCommand, invokeYarnInstallCommand} from '../external-com
|
||||||
export class CutStableAction extends ReleaseAction {
|
export class CutStableAction extends ReleaseAction {
|
||||||
private _newVersion = this._computeNewVersion();
|
private _newVersion = this._computeNewVersion();
|
||||||
|
|
||||||
async getDescription() {
|
override async getDescription() {
|
||||||
const newVersion = this._newVersion;
|
const newVersion = this._newVersion;
|
||||||
return `Cut a stable release for the release-candidate branch (v${newVersion}).`;
|
return `Cut a stable release for the release-candidate branch (v${newVersion}).`;
|
||||||
}
|
}
|
||||||
|
|
||||||
async perform() {
|
override async perform() {
|
||||||
const {branchName} = this.active.releaseCandidate!;
|
const {branchName} = this.active.releaseCandidate!;
|
||||||
const newVersion = this._newVersion;
|
const newVersion = this._newVersion;
|
||||||
const isNewMajor = this.active.releaseCandidate?.isMajor;
|
const isNewMajor = this.active.releaseCandidate?.isMajor;
|
||||||
|
|
|
@ -24,13 +24,13 @@ import {changelogPath, packageJsonPath} from '../constants';
|
||||||
export class MoveNextIntoFeatureFreezeAction extends ReleaseAction {
|
export class MoveNextIntoFeatureFreezeAction extends ReleaseAction {
|
||||||
private _newVersion = computeNewPrereleaseVersionForNext(this.active, this.config);
|
private _newVersion = computeNewPrereleaseVersionForNext(this.active, this.config);
|
||||||
|
|
||||||
async getDescription() {
|
override async getDescription() {
|
||||||
const {branchName} = this.active.next;
|
const {branchName} = this.active.next;
|
||||||
const newVersion = await this._newVersion;
|
const newVersion = await this._newVersion;
|
||||||
return `Move the "${branchName}" branch into feature-freeze phase (v${newVersion}).`;
|
return `Move the "${branchName}" branch into feature-freeze phase (v${newVersion}).`;
|
||||||
}
|
}
|
||||||
|
|
||||||
async perform() {
|
override async perform() {
|
||||||
const newVersion = await this._newVersion;
|
const newVersion = await this._newVersion;
|
||||||
const newBranch = `${newVersion.major}.${newVersion.minor}.x`;
|
const newBranch = `${newVersion.major}.${newVersion.minor}.x`;
|
||||||
|
|
||||||
|
|
|
@ -25,11 +25,11 @@ import {invokeSetNpmDistCommand, invokeYarnInstallCommand} from '../external-com
|
||||||
* @see {CutStableAction#perform} for more details.
|
* @see {CutStableAction#perform} for more details.
|
||||||
*/
|
*/
|
||||||
export class TagRecentMajorAsLatest extends ReleaseAction {
|
export class TagRecentMajorAsLatest extends ReleaseAction {
|
||||||
async getDescription() {
|
override async getDescription() {
|
||||||
return `Tag recently published major v${this.active.latest.version} as "next" in NPM.`;
|
return `Tag recently published major v${this.active.latest.version} as "next" in NPM.`;
|
||||||
}
|
}
|
||||||
|
|
||||||
async perform() {
|
override async perform() {
|
||||||
await this.checkoutUpstreamBranch(this.active.latest.branchName);
|
await this.checkoutUpstreamBranch(this.active.latest.branchName);
|
||||||
await invokeYarnInstallCommand(this.projectDir);
|
await invokeYarnInstallCommand(this.projectDir);
|
||||||
await invokeSetNpmDistCommand('latest', this.active.latest.version);
|
await invokeSetNpmDistCommand('latest', this.active.latest.version);
|
||||||
|
|
|
@ -143,11 +143,11 @@ describe('common release action logic', () => {
|
||||||
* release action class. This allows us to add unit tests.
|
* release action class. This allows us to add unit tests.
|
||||||
*/
|
*/
|
||||||
class TestAction extends ReleaseAction {
|
class TestAction extends ReleaseAction {
|
||||||
async getDescription() {
|
override async getDescription() {
|
||||||
return 'Test action';
|
return 'Test action';
|
||||||
}
|
}
|
||||||
|
|
||||||
async perform() {
|
override async perform() {
|
||||||
throw Error('Not implemented.');
|
throw Error('Not implemented.');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -10,11 +10,11 @@ import {dashCaseToCamelCase} from '../../util';
|
||||||
import {AnimationStyleNormalizer} from './animation_style_normalizer';
|
import {AnimationStyleNormalizer} from './animation_style_normalizer';
|
||||||
|
|
||||||
export class WebAnimationsStyleNormalizer extends AnimationStyleNormalizer {
|
export class WebAnimationsStyleNormalizer extends AnimationStyleNormalizer {
|
||||||
normalizePropertyName(propertyName: string, errors: string[]): string {
|
override normalizePropertyName(propertyName: string, errors: string[]): string {
|
||||||
return dashCaseToCamelCase(propertyName);
|
return dashCaseToCamelCase(propertyName);
|
||||||
}
|
}
|
||||||
|
|
||||||
normalizeStyleValue(
|
override normalizeStyleValue(
|
||||||
userProvidedProperty: string, normalizedProperty: string, value: string|number,
|
userProvidedProperty: string, normalizedProperty: string, value: string|number,
|
||||||
errors: string[]): string {
|
errors: string[]): string {
|
||||||
let unit: string = '';
|
let unit: string = '';
|
||||||
|
|
|
@ -110,11 +110,11 @@ class SuffixNormalizer extends AnimationStyleNormalizer {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
normalizePropertyName(propertyName: string, errors: string[]): string {
|
override normalizePropertyName(propertyName: string, errors: string[]): string {
|
||||||
return propertyName + this._suffix;
|
return propertyName + this._suffix;
|
||||||
}
|
}
|
||||||
|
|
||||||
normalizeStyleValue(
|
override normalizeStyleValue(
|
||||||
userProvidedProperty: string, normalizedProperty: string, value: string|number,
|
userProvidedProperty: string, normalizedProperty: string, value: string|number,
|
||||||
errors: string[]): string {
|
errors: string[]): string {
|
||||||
return value + this._suffix;
|
return value + this._suffix;
|
||||||
|
|
|
@ -693,11 +693,11 @@ class SuffixNormalizer extends AnimationStyleNormalizer {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
normalizePropertyName(propertyName: string, errors: string[]): string {
|
override normalizePropertyName(propertyName: string, errors: string[]): string {
|
||||||
return propertyName + this._suffix;
|
return propertyName + this._suffix;
|
||||||
}
|
}
|
||||||
|
|
||||||
normalizeStyleValue(
|
override normalizeStyleValue(
|
||||||
userProvidedProperty: string, normalizedProperty: string, value: string|number,
|
userProvidedProperty: string, normalizedProperty: string, value: string|number,
|
||||||
errors: string[]): string {
|
errors: string[]): string {
|
||||||
return value + this._suffix;
|
return value + this._suffix;
|
||||||
|
@ -709,14 +709,14 @@ class ExactCssValueNormalizer extends AnimationStyleNormalizer {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
normalizePropertyName(propertyName: string, errors: string[]): string {
|
override normalizePropertyName(propertyName: string, errors: string[]): string {
|
||||||
if (!this._allowedValues[propertyName]) {
|
if (!this._allowedValues[propertyName]) {
|
||||||
errors.push(`The CSS property \`${propertyName}\` is not allowed`);
|
errors.push(`The CSS property \`${propertyName}\` is not allowed`);
|
||||||
}
|
}
|
||||||
return propertyName;
|
return propertyName;
|
||||||
}
|
}
|
||||||
|
|
||||||
normalizeStyleValue(
|
override normalizeStyleValue(
|
||||||
userProvidedProperty: string, normalizedProperty: string, value: string|number,
|
userProvidedProperty: string, normalizedProperty: string, value: string|number,
|
||||||
errors: string[]): string {
|
errors: string[]): string {
|
||||||
const expectedValue = this._allowedValues[userProvidedProperty];
|
const expectedValue = this._allowedValues[userProvidedProperty];
|
||||||
|
|
|
@ -17,7 +17,7 @@ class SampleTokenExtractor extends HttpXsrfTokenExtractor {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
getToken(): string|null {
|
override getToken(): string|null {
|
||||||
return this.token;
|
return this.token;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -56,7 +56,7 @@ export class NgLocaleLocalization extends NgLocalization {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
getPluralCategory(value: any, locale?: string): string {
|
override getPluralCategory(value: any, locale?: string): string {
|
||||||
const plural = getLocalePluralCase(locale || this.locale)(value);
|
const plural = getLocalePluralCase(locale || this.locale)(value);
|
||||||
|
|
||||||
switch (plural) {
|
switch (plural) {
|
||||||
|
|
|
@ -52,16 +52,16 @@ export class HashLocationStrategy extends LocationStrategy implements OnDestroy
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
onPopState(fn: LocationChangeListener): void {
|
override onPopState(fn: LocationChangeListener): void {
|
||||||
this._removeListenerFns.push(
|
this._removeListenerFns.push(
|
||||||
this._platformLocation.onPopState(fn), this._platformLocation.onHashChange(fn));
|
this._platformLocation.onPopState(fn), this._platformLocation.onHashChange(fn));
|
||||||
}
|
}
|
||||||
|
|
||||||
getBaseHref(): string {
|
override getBaseHref(): string {
|
||||||
return this._baseHref;
|
return this._baseHref;
|
||||||
}
|
}
|
||||||
|
|
||||||
path(includeHash: boolean = false): string {
|
override path(includeHash: boolean = false): string {
|
||||||
// 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;
|
||||||
|
@ -70,12 +70,12 @@ export class HashLocationStrategy extends LocationStrategy implements OnDestroy
|
||||||
return path.length > 0 ? path.substring(1) : path;
|
return path.length > 0 ? path.substring(1) : path;
|
||||||
}
|
}
|
||||||
|
|
||||||
prepareExternalUrl(internal: string): string {
|
override prepareExternalUrl(internal: string): string {
|
||||||
const url = joinWithSlash(this._baseHref, internal);
|
const url = joinWithSlash(this._baseHref, internal);
|
||||||
return url.length > 0 ? ('#' + url) : url;
|
return url.length > 0 ? ('#' + url) : url;
|
||||||
}
|
}
|
||||||
|
|
||||||
pushState(state: any, title: string, path: string, queryParams: string) {
|
override pushState(state: any, title: string, path: string, queryParams: string) {
|
||||||
let url: string|null = this.prepareExternalUrl(path + normalizeQueryParams(queryParams));
|
let url: string|null = this.prepareExternalUrl(path + normalizeQueryParams(queryParams));
|
||||||
if (url.length == 0) {
|
if (url.length == 0) {
|
||||||
url = this._platformLocation.pathname;
|
url = this._platformLocation.pathname;
|
||||||
|
@ -83,7 +83,7 @@ export class HashLocationStrategy extends LocationStrategy implements OnDestroy
|
||||||
this._platformLocation.pushState(state, title, url);
|
this._platformLocation.pushState(state, title, url);
|
||||||
}
|
}
|
||||||
|
|
||||||
replaceState(state: any, title: string, path: string, queryParams: string) {
|
override replaceState(state: any, title: string, path: string, queryParams: string) {
|
||||||
let url = this.prepareExternalUrl(path + normalizeQueryParams(queryParams));
|
let url = this.prepareExternalUrl(path + normalizeQueryParams(queryParams));
|
||||||
if (url.length == 0) {
|
if (url.length == 0) {
|
||||||
url = this._platformLocation.pathname;
|
url = this._platformLocation.pathname;
|
||||||
|
@ -91,11 +91,11 @@ export class HashLocationStrategy extends LocationStrategy implements OnDestroy
|
||||||
this._platformLocation.replaceState(state, title, url);
|
this._platformLocation.replaceState(state, title, url);
|
||||||
}
|
}
|
||||||
|
|
||||||
forward(): void {
|
override forward(): void {
|
||||||
this._platformLocation.forward();
|
this._platformLocation.forward();
|
||||||
}
|
}
|
||||||
|
|
||||||
back(): void {
|
override back(): void {
|
||||||
this._platformLocation.back();
|
this._platformLocation.back();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -135,41 +135,41 @@ export class PathLocationStrategy extends LocationStrategy implements OnDestroy
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
onPopState(fn: LocationChangeListener): void {
|
override onPopState(fn: LocationChangeListener): void {
|
||||||
this._removeListenerFns.push(
|
this._removeListenerFns.push(
|
||||||
this._platformLocation.onPopState(fn), this._platformLocation.onHashChange(fn));
|
this._platformLocation.onPopState(fn), this._platformLocation.onHashChange(fn));
|
||||||
}
|
}
|
||||||
|
|
||||||
getBaseHref(): string {
|
override getBaseHref(): string {
|
||||||
return this._baseHref;
|
return this._baseHref;
|
||||||
}
|
}
|
||||||
|
|
||||||
prepareExternalUrl(internal: string): string {
|
override prepareExternalUrl(internal: string): string {
|
||||||
return joinWithSlash(this._baseHref, internal);
|
return joinWithSlash(this._baseHref, internal);
|
||||||
}
|
}
|
||||||
|
|
||||||
path(includeHash: boolean = false): string {
|
override path(includeHash: boolean = false): string {
|
||||||
const pathname =
|
const pathname =
|
||||||
this._platformLocation.pathname + normalizeQueryParams(this._platformLocation.search);
|
this._platformLocation.pathname + normalizeQueryParams(this._platformLocation.search);
|
||||||
const hash = this._platformLocation.hash;
|
const hash = this._platformLocation.hash;
|
||||||
return hash && includeHash ? `${pathname}${hash}` : pathname;
|
return hash && includeHash ? `${pathname}${hash}` : pathname;
|
||||||
}
|
}
|
||||||
|
|
||||||
pushState(state: any, title: string, url: string, queryParams: string) {
|
override pushState(state: any, title: string, url: string, queryParams: string) {
|
||||||
const externalUrl = this.prepareExternalUrl(url + normalizeQueryParams(queryParams));
|
const externalUrl = this.prepareExternalUrl(url + normalizeQueryParams(queryParams));
|
||||||
this._platformLocation.pushState(state, title, externalUrl);
|
this._platformLocation.pushState(state, title, externalUrl);
|
||||||
}
|
}
|
||||||
|
|
||||||
replaceState(state: any, title: string, url: string, queryParams: string) {
|
override replaceState(state: any, title: string, url: string, queryParams: string) {
|
||||||
const externalUrl = this.prepareExternalUrl(url + normalizeQueryParams(queryParams));
|
const externalUrl = this.prepareExternalUrl(url + normalizeQueryParams(queryParams));
|
||||||
this._platformLocation.replaceState(state, title, externalUrl);
|
this._platformLocation.replaceState(state, title, externalUrl);
|
||||||
}
|
}
|
||||||
|
|
||||||
forward(): void {
|
override forward(): void {
|
||||||
this._platformLocation.forward();
|
this._platformLocation.forward();
|
||||||
}
|
}
|
||||||
|
|
||||||
back(): void {
|
override back(): void {
|
||||||
this._platformLocation.back();
|
this._platformLocation.back();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -128,48 +128,48 @@ export class BrowserPlatformLocation extends PlatformLocation {
|
||||||
this._history = window.history;
|
this._history = window.history;
|
||||||
}
|
}
|
||||||
|
|
||||||
getBaseHrefFromDOM(): string {
|
override getBaseHrefFromDOM(): string {
|
||||||
return getDOM().getBaseHref(this._doc)!;
|
return getDOM().getBaseHref(this._doc)!;
|
||||||
}
|
}
|
||||||
|
|
||||||
onPopState(fn: LocationChangeListener): VoidFunction {
|
override onPopState(fn: LocationChangeListener): VoidFunction {
|
||||||
const window = getDOM().getGlobalEventTarget(this._doc, 'window');
|
const window = getDOM().getGlobalEventTarget(this._doc, 'window');
|
||||||
window.addEventListener('popstate', fn, false);
|
window.addEventListener('popstate', fn, false);
|
||||||
return () => window.removeEventListener('popstate', fn);
|
return () => window.removeEventListener('popstate', fn);
|
||||||
}
|
}
|
||||||
|
|
||||||
onHashChange(fn: LocationChangeListener): VoidFunction {
|
override onHashChange(fn: LocationChangeListener): VoidFunction {
|
||||||
const window = getDOM().getGlobalEventTarget(this._doc, 'window');
|
const window = getDOM().getGlobalEventTarget(this._doc, 'window');
|
||||||
window.addEventListener('hashchange', fn, false);
|
window.addEventListener('hashchange', fn, false);
|
||||||
return () => window.removeEventListener('hashchange', fn);
|
return () => window.removeEventListener('hashchange', fn);
|
||||||
}
|
}
|
||||||
|
|
||||||
get href(): string {
|
override get href(): string {
|
||||||
return this.location.href;
|
return this.location.href;
|
||||||
}
|
}
|
||||||
get protocol(): string {
|
override get protocol(): string {
|
||||||
return this.location.protocol;
|
return this.location.protocol;
|
||||||
}
|
}
|
||||||
get hostname(): string {
|
override get hostname(): string {
|
||||||
return this.location.hostname;
|
return this.location.hostname;
|
||||||
}
|
}
|
||||||
get port(): string {
|
override get port(): string {
|
||||||
return this.location.port;
|
return this.location.port;
|
||||||
}
|
}
|
||||||
get pathname(): string {
|
override get pathname(): string {
|
||||||
return this.location.pathname;
|
return this.location.pathname;
|
||||||
}
|
}
|
||||||
get search(): string {
|
override get search(): string {
|
||||||
return this.location.search;
|
return this.location.search;
|
||||||
}
|
}
|
||||||
get hash(): string {
|
override get hash(): string {
|
||||||
return this.location.hash;
|
return this.location.hash;
|
||||||
}
|
}
|
||||||
set pathname(newPath: string) {
|
override set pathname(newPath: string) {
|
||||||
this.location.pathname = newPath;
|
this.location.pathname = newPath;
|
||||||
}
|
}
|
||||||
|
|
||||||
pushState(state: any, title: string, url: string): void {
|
override pushState(state: any, title: string, url: string): void {
|
||||||
if (supportsState()) {
|
if (supportsState()) {
|
||||||
this._history.pushState(state, title, url);
|
this._history.pushState(state, title, url);
|
||||||
} else {
|
} else {
|
||||||
|
@ -177,7 +177,7 @@ export class BrowserPlatformLocation extends PlatformLocation {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
replaceState(state: any, title: string, url: string): void {
|
override replaceState(state: any, title: string, url: string): void {
|
||||||
if (supportsState()) {
|
if (supportsState()) {
|
||||||
this._history.replaceState(state, title, url);
|
this._history.replaceState(state, title, url);
|
||||||
} else {
|
} else {
|
||||||
|
@ -185,11 +185,11 @@ export class BrowserPlatformLocation extends PlatformLocation {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
forward(): void {
|
override forward(): void {
|
||||||
this._history.forward();
|
this._history.forward();
|
||||||
}
|
}
|
||||||
|
|
||||||
back(): void {
|
override back(): void {
|
||||||
this._history.back();
|
this._history.back();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -197,7 +197,7 @@ export class BrowserPlatformLocation extends PlatformLocation {
|
||||||
this._history.go(relativePosition);
|
this._history.go(relativePosition);
|
||||||
}
|
}
|
||||||
|
|
||||||
getState(): unknown {
|
override getState(): unknown {
|
||||||
return this._history.state;
|
return this._history.state;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,11 +16,11 @@ import {DependencyHostBase} from './dependency_host';
|
||||||
* Helper functions for computing dependencies.
|
* Helper functions for computing dependencies.
|
||||||
*/
|
*/
|
||||||
export class CommonJsDependencyHost extends DependencyHostBase {
|
export class CommonJsDependencyHost extends DependencyHostBase {
|
||||||
protected canSkipFile(fileContents: string): boolean {
|
protected override canSkipFile(fileContents: string): boolean {
|
||||||
return !hasRequireCalls(fileContents);
|
return !hasRequireCalls(fileContents);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected extractImports(file: AbsoluteFsPath, fileContents: string): Set<string> {
|
protected override extractImports(file: AbsoluteFsPath, fileContents: string): Set<string> {
|
||||||
// Parse the source into a TypeScript AST and then walk it looking for imports and re-exports.
|
// Parse the source into a TypeScript AST and then walk it looking for imports and re-exports.
|
||||||
const sf =
|
const sf =
|
||||||
ts.createSourceFile(file, fileContents, ts.ScriptTarget.ES2015, false, ts.ScriptKind.JS);
|
ts.createSourceFile(file, fileContents, ts.ScriptTarget.ES2015, false, ts.ScriptKind.JS);
|
||||||
|
|
|
@ -23,7 +23,7 @@ export class EsmDependencyHost extends DependencyHostBase {
|
||||||
// It has no relevance to capturing imports.
|
// It has no relevance to capturing imports.
|
||||||
private scanner = ts.createScanner(ts.ScriptTarget.Latest, /* skipTrivia */ true);
|
private scanner = ts.createScanner(ts.ScriptTarget.Latest, /* skipTrivia */ true);
|
||||||
|
|
||||||
protected canSkipFile(fileContents: string): boolean {
|
protected override canSkipFile(fileContents: string): boolean {
|
||||||
return !hasImportOrReexportStatements(fileContents);
|
return !hasImportOrReexportStatements(fileContents);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -43,7 +43,7 @@ export class EsmDependencyHost extends DependencyHostBase {
|
||||||
* Specifically, backticked strings are particularly challenging since it is possible
|
* Specifically, backticked strings are particularly challenging since it is possible
|
||||||
* to recursively nest backticks and TypeScript expressions within each other.
|
* to recursively nest backticks and TypeScript expressions within each other.
|
||||||
*/
|
*/
|
||||||
protected extractImports(file: AbsoluteFsPath, fileContents: string): Set<string> {
|
protected override extractImports(file: AbsoluteFsPath, fileContents: string): Set<string> {
|
||||||
const imports = new Set<string>();
|
const imports = new Set<string>();
|
||||||
const templateStack: ts.SyntaxKind[] = [];
|
const templateStack: ts.SyntaxKind[] = [];
|
||||||
let lastToken: ts.SyntaxKind = ts.SyntaxKind.Unknown;
|
let lastToken: ts.SyntaxKind = ts.SyntaxKind.Unknown;
|
||||||
|
|
|
@ -17,11 +17,11 @@ import {DependencyHostBase} from './dependency_host';
|
||||||
* Helper functions for computing dependencies.
|
* Helper functions for computing dependencies.
|
||||||
*/
|
*/
|
||||||
export class UmdDependencyHost extends DependencyHostBase {
|
export class UmdDependencyHost extends DependencyHostBase {
|
||||||
protected canSkipFile(fileContents: string): boolean {
|
protected override canSkipFile(fileContents: string): boolean {
|
||||||
return !hasRequireCalls(fileContents);
|
return !hasRequireCalls(fileContents);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected extractImports(file: AbsoluteFsPath, fileContents: string): Set<string> {
|
protected override extractImports(file: AbsoluteFsPath, fileContents: string): Set<string> {
|
||||||
// Parse the source into a TypeScript AST and then walk it looking for imports and re-exports.
|
// Parse the source into a TypeScript AST and then walk it looking for imports and re-exports.
|
||||||
const sf =
|
const sf =
|
||||||
ts.createSourceFile(file, fileContents, ts.ScriptTarget.ES2015, false, ts.ScriptKind.JS);
|
ts.createSourceFile(file, fileContents, ts.ScriptTarget.ES2015, false, ts.ScriptKind.JS);
|
||||||
|
|
|
@ -45,7 +45,7 @@ export class ProgramBasedEntryPointFinder extends TracingEntryPointFinder {
|
||||||
* Return an array containing the external import paths that were extracted from the source-files
|
* Return an array containing the external import paths that were extracted from the source-files
|
||||||
* of the program defined by the tsconfig.json.
|
* of the program defined by the tsconfig.json.
|
||||||
*/
|
*/
|
||||||
protected getInitialEntryPointPaths(): AbsoluteFsPath[] {
|
protected override getInitialEntryPointPaths(): AbsoluteFsPath[] {
|
||||||
const moduleResolver = new ModuleResolver(this.fs, this.pathMappings, ['', '.ts', '/index.ts']);
|
const moduleResolver = new ModuleResolver(this.fs, this.pathMappings, ['', '.ts', '/index.ts']);
|
||||||
const host = new EsmDependencyHost(this.fs, moduleResolver);
|
const host = new EsmDependencyHost(this.fs, moduleResolver);
|
||||||
const dependencies = createDependencyInfo();
|
const dependencies = createDependencyInfo();
|
||||||
|
@ -71,7 +71,8 @@ export class ProgramBasedEntryPointFinder extends TracingEntryPointFinder {
|
||||||
* @returns the entry-point and its dependencies or `null` if the entry-point is not compiled by
|
* @returns the entry-point and its dependencies or `null` if the entry-point is not compiled by
|
||||||
* Angular or cannot be determined.
|
* Angular or cannot be determined.
|
||||||
*/
|
*/
|
||||||
protected getEntryPointWithDeps(entryPointPath: AbsoluteFsPath): EntryPointWithDependencies|null {
|
protected override getEntryPointWithDeps(entryPointPath: AbsoluteFsPath):
|
||||||
|
EntryPointWithDependencies|null {
|
||||||
const entryPoints = this.findOrLoadEntryPoints();
|
const entryPoints = this.findOrLoadEntryPoints();
|
||||||
if (!entryPoints.has(entryPointPath)) {
|
if (!entryPoints.has(entryPointPath)) {
|
||||||
return null;
|
return null;
|
||||||
|
|
|
@ -83,7 +83,7 @@ export class TargetedEntryPointFinder extends TracingEntryPointFinder {
|
||||||
/**
|
/**
|
||||||
* Return an array containing the `targetPath` from which to start the trace.
|
* Return an array containing the `targetPath` from which to start the trace.
|
||||||
*/
|
*/
|
||||||
protected getInitialEntryPointPaths(): AbsoluteFsPath[] {
|
protected override getInitialEntryPointPaths(): AbsoluteFsPath[] {
|
||||||
return [this.targetPath];
|
return [this.targetPath];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -97,7 +97,8 @@ export class TargetedEntryPointFinder extends TracingEntryPointFinder {
|
||||||
* @returns the entry-point and its dependencies or `null` if the entry-point is not compiled by
|
* @returns the entry-point and its dependencies or `null` if the entry-point is not compiled by
|
||||||
* Angular or cannot be determined.
|
* Angular or cannot be determined.
|
||||||
*/
|
*/
|
||||||
protected getEntryPointWithDeps(entryPointPath: AbsoluteFsPath): EntryPointWithDependencies|null {
|
protected override getEntryPointWithDeps(entryPointPath: AbsoluteFsPath):
|
||||||
|
EntryPointWithDependencies|null {
|
||||||
const packagePath = this.computePackagePath(entryPointPath);
|
const packagePath = this.computePackagePath(entryPointPath);
|
||||||
const entryPoint =
|
const entryPoint =
|
||||||
getEntryPointInfo(this.fs, this.config, this.logger, packagePath, entryPointPath);
|
getEntryPointInfo(this.fs, this.config, this.logger, packagePath, entryPointPath);
|
||||||
|
|
|
@ -27,7 +27,7 @@ export class ParallelTaskQueue extends BaseTaskQueue {
|
||||||
this.blockedTasks = getBlockedTasks(dependencies);
|
this.blockedTasks = getBlockedTasks(dependencies);
|
||||||
}
|
}
|
||||||
|
|
||||||
computeNextTask(): Task|null {
|
override computeNextTask(): Task|null {
|
||||||
// Look for the first available (i.e. not blocked) task.
|
// Look for the first available (i.e. not blocked) task.
|
||||||
// (NOTE: Since tasks are sorted by priority, the first available one is the best choice.)
|
// (NOTE: Since tasks are sorted by priority, the first available one is the best choice.)
|
||||||
const nextTaskIdx = this.tasks.findIndex(task => !this.blockedTasks.has(task));
|
const nextTaskIdx = this.tasks.findIndex(task => !this.blockedTasks.has(task));
|
||||||
|
|
|
@ -17,7 +17,7 @@ import {BaseTaskQueue} from './base_task_queue';
|
||||||
* before requesting the next one.
|
* before requesting the next one.
|
||||||
*/
|
*/
|
||||||
export class SerialTaskQueue extends BaseTaskQueue {
|
export class SerialTaskQueue extends BaseTaskQueue {
|
||||||
computeNextTask(): Task|null {
|
override computeNextTask(): Task|null {
|
||||||
const nextTask = this.tasks.shift() || null;
|
const nextTask = this.tasks.shift() || null;
|
||||||
|
|
||||||
if (nextTask) {
|
if (nextTask) {
|
||||||
|
|
|
@ -64,7 +64,7 @@ export class DirectiveSymbol extends SemanticSymbol {
|
||||||
super(decl);
|
super(decl);
|
||||||
}
|
}
|
||||||
|
|
||||||
isPublicApiAffected(previousSymbol: SemanticSymbol): boolean {
|
override isPublicApiAffected(previousSymbol: SemanticSymbol): boolean {
|
||||||
// Note: since components and directives have exactly the same items contributing to their
|
// Note: since components and directives have exactly the same items contributing to their
|
||||||
// public API, it is okay for a directive to change into a component and vice versa without
|
// public API, it is okay for a directive to change into a component and vice versa without
|
||||||
// the API being affected.
|
// the API being affected.
|
||||||
|
@ -83,7 +83,7 @@ export class DirectiveSymbol extends SemanticSymbol {
|
||||||
!isArrayEqual(this.exportAs, previousSymbol.exportAs);
|
!isArrayEqual(this.exportAs, previousSymbol.exportAs);
|
||||||
}
|
}
|
||||||
|
|
||||||
isTypeCheckApiAffected(previousSymbol: SemanticSymbol): boolean {
|
override isTypeCheckApiAffected(previousSymbol: SemanticSymbol): boolean {
|
||||||
// If the public API of the directive has changed, then so has its type-check API.
|
// If the public API of the directive has changed, then so has its type-check API.
|
||||||
if (this.isPublicApiAffected(previousSymbol)) {
|
if (this.isPublicApiAffected(previousSymbol)) {
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -58,7 +58,7 @@ export class NgModuleSymbol extends SemanticSymbol {
|
||||||
usedPipes: SemanticReference[]
|
usedPipes: SemanticReference[]
|
||||||
}[] = [];
|
}[] = [];
|
||||||
|
|
||||||
isPublicApiAffected(previousSymbol: SemanticSymbol): boolean {
|
override isPublicApiAffected(previousSymbol: SemanticSymbol): boolean {
|
||||||
if (!(previousSymbol instanceof NgModuleSymbol)) {
|
if (!(previousSymbol instanceof NgModuleSymbol)) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -104,7 +104,7 @@ export class NgModuleSymbol extends SemanticSymbol {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
isTypeCheckApiAffected(previousSymbol: SemanticSymbol): boolean {
|
override isTypeCheckApiAffected(previousSymbol: SemanticSymbol): boolean {
|
||||||
if (!(previousSymbol instanceof NgModuleSymbol)) {
|
if (!(previousSymbol instanceof NgModuleSymbol)) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -38,7 +38,7 @@ export class PipeSymbol extends SemanticSymbol {
|
||||||
super(decl);
|
super(decl);
|
||||||
}
|
}
|
||||||
|
|
||||||
isPublicApiAffected(previousSymbol: SemanticSymbol): boolean {
|
override isPublicApiAffected(previousSymbol: SemanticSymbol): boolean {
|
||||||
if (!(previousSymbol instanceof PipeSymbol)) {
|
if (!(previousSymbol instanceof PipeSymbol)) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -46,7 +46,7 @@ export class PipeSymbol extends SemanticSymbol {
|
||||||
return this.name !== previousSymbol.name;
|
return this.name !== previousSymbol.name;
|
||||||
}
|
}
|
||||||
|
|
||||||
isTypeCheckApiAffected(previousSymbol: SemanticSymbol): boolean {
|
override isTypeCheckApiAffected(previousSymbol: SemanticSymbol): boolean {
|
||||||
return this.isPublicApiAffected(previousSymbol);
|
return this.isPublicApiAffected(previousSymbol);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,20 +21,20 @@ export class MockFileSystemNative extends MockFileSystem {
|
||||||
|
|
||||||
// Delegate to the real NodeJSFileSystem for these path related methods
|
// Delegate to the real NodeJSFileSystem for these path related methods
|
||||||
|
|
||||||
resolve(...paths: string[]): AbsoluteFsPath {
|
override resolve(...paths: string[]): AbsoluteFsPath {
|
||||||
return NodeJSFileSystem.prototype.resolve.call(this, this.pwd(), ...paths);
|
return NodeJSFileSystem.prototype.resolve.call(this, this.pwd(), ...paths);
|
||||||
}
|
}
|
||||||
dirname<T extends string>(file: T): T {
|
override dirname<T extends string>(file: T): T {
|
||||||
return NodeJSFileSystem.prototype.dirname.call(this, file) as T;
|
return NodeJSFileSystem.prototype.dirname.call(this, file) as T;
|
||||||
}
|
}
|
||||||
join<T extends string>(basePath: T, ...paths: string[]): T {
|
override join<T extends string>(basePath: T, ...paths: string[]): T {
|
||||||
return NodeJSFileSystem.prototype.join.call(this, basePath, ...paths) as T;
|
return NodeJSFileSystem.prototype.join.call(this, basePath, ...paths) as T;
|
||||||
}
|
}
|
||||||
relative<T extends PathString>(from: T, to: T): PathSegment|AbsoluteFsPath {
|
override relative<T extends PathString>(from: T, to: T): PathSegment|AbsoluteFsPath {
|
||||||
return NodeJSFileSystem.prototype.relative.call(this, from, to);
|
return NodeJSFileSystem.prototype.relative.call(this, from, to);
|
||||||
}
|
}
|
||||||
|
|
||||||
basename(filePath: string, extension?: string): PathSegment {
|
override basename(filePath: string, extension?: string): PathSegment {
|
||||||
return NodeJSFileSystem.prototype.basename.call(this, filePath, extension);
|
return NodeJSFileSystem.prototype.basename.call(this, filePath, extension);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -42,7 +42,7 @@ export class MockFileSystemNative extends MockFileSystem {
|
||||||
return NodeJSFileSystem.prototype.isCaseSensitive.call(this);
|
return NodeJSFileSystem.prototype.isCaseSensitive.call(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
isRooted(path: string): boolean {
|
override isRooted(path: string): boolean {
|
||||||
return NodeJSFileSystem.prototype.isRooted.call(this, path);
|
return NodeJSFileSystem.prototype.isRooted.call(this, path);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -50,7 +50,7 @@ export class MockFileSystemNative extends MockFileSystem {
|
||||||
return NodeJSFileSystem.prototype.isRoot.call(this, path);
|
return NodeJSFileSystem.prototype.isRoot.call(this, path);
|
||||||
}
|
}
|
||||||
|
|
||||||
normalize<T extends PathString>(path: T): T {
|
override normalize<T extends PathString>(path: T): T {
|
||||||
// When running in Windows, absolute paths are normalized to always include a drive letter. This
|
// When running in Windows, absolute paths are normalized to always include a drive letter. This
|
||||||
// ensures that rooted posix paths used in tests will be normalized to real Windows paths, i.e.
|
// ensures that rooted posix paths used in tests will be normalized to real Windows paths, i.e.
|
||||||
// including a drive letter. Note that the same normalization is done in emulated Windows mode
|
// including a drive letter. Note that the same normalization is done in emulated Windows mode
|
||||||
|
@ -63,7 +63,7 @@ export class MockFileSystemNative extends MockFileSystem {
|
||||||
return NodeJSFileSystem.prototype.normalize.call(this, path) as T;
|
return NodeJSFileSystem.prototype.normalize.call(this, path) as T;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected splitPath<T>(path: string): string[] {
|
protected override splitPath<T>(path: string): string[] {
|
||||||
return path.split(/[\\\/]/);
|
return path.split(/[\\\/]/);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,36 +12,36 @@ import {AbsoluteFsPath, PathSegment, PathString} from '../../src/types';
|
||||||
import {MockFileSystem} from './mock_file_system';
|
import {MockFileSystem} from './mock_file_system';
|
||||||
|
|
||||||
export class MockFileSystemPosix extends MockFileSystem {
|
export class MockFileSystemPosix extends MockFileSystem {
|
||||||
resolve(...paths: string[]): AbsoluteFsPath {
|
override resolve(...paths: string[]): AbsoluteFsPath {
|
||||||
const resolved = p.posix.resolve(this.pwd(), ...paths);
|
const resolved = p.posix.resolve(this.pwd(), ...paths);
|
||||||
return this.normalize(resolved) as AbsoluteFsPath;
|
return this.normalize(resolved) as AbsoluteFsPath;
|
||||||
}
|
}
|
||||||
|
|
||||||
dirname<T extends string>(file: T): T {
|
override dirname<T extends string>(file: T): T {
|
||||||
return this.normalize(p.posix.dirname(file)) as T;
|
return this.normalize(p.posix.dirname(file)) as T;
|
||||||
}
|
}
|
||||||
|
|
||||||
join<T extends string>(basePath: T, ...paths: string[]): T {
|
override join<T extends string>(basePath: T, ...paths: string[]): T {
|
||||||
return this.normalize(p.posix.join(basePath, ...paths)) as T;
|
return this.normalize(p.posix.join(basePath, ...paths)) as T;
|
||||||
}
|
}
|
||||||
|
|
||||||
relative<T extends PathString>(from: T, to: T): PathSegment|AbsoluteFsPath {
|
override relative<T extends PathString>(from: T, to: T): PathSegment|AbsoluteFsPath {
|
||||||
return this.normalize(p.posix.relative(from, to)) as PathSegment | AbsoluteFsPath;
|
return this.normalize(p.posix.relative(from, to)) as PathSegment | AbsoluteFsPath;
|
||||||
}
|
}
|
||||||
|
|
||||||
basename(filePath: string, extension?: string): PathSegment {
|
override basename(filePath: string, extension?: string): PathSegment {
|
||||||
return p.posix.basename(filePath, extension) as PathSegment;
|
return p.posix.basename(filePath, extension) as PathSegment;
|
||||||
}
|
}
|
||||||
|
|
||||||
isRooted(path: string): boolean {
|
override isRooted(path: string): boolean {
|
||||||
return path.startsWith('/');
|
return path.startsWith('/');
|
||||||
}
|
}
|
||||||
|
|
||||||
protected splitPath<T extends PathString>(path: T): string[] {
|
protected override splitPath<T extends PathString>(path: T): string[] {
|
||||||
return path.split('/');
|
return path.split('/');
|
||||||
}
|
}
|
||||||
|
|
||||||
normalize<T extends PathString>(path: T): T {
|
override normalize<T extends PathString>(path: T): T {
|
||||||
return path.replace(/^[a-z]:\//i, '/').replace(/\\/g, '/') as T;
|
return path.replace(/^[a-z]:\//i, '/').replace(/\\/g, '/') as T;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,36 +12,36 @@ import {AbsoluteFsPath, PathSegment, PathString} from '../../src/types';
|
||||||
import {MockFileSystem} from './mock_file_system';
|
import {MockFileSystem} from './mock_file_system';
|
||||||
|
|
||||||
export class MockFileSystemWindows extends MockFileSystem {
|
export class MockFileSystemWindows extends MockFileSystem {
|
||||||
resolve(...paths: string[]): AbsoluteFsPath {
|
override resolve(...paths: string[]): AbsoluteFsPath {
|
||||||
const resolved = p.win32.resolve(this.pwd(), ...paths);
|
const resolved = p.win32.resolve(this.pwd(), ...paths);
|
||||||
return this.normalize(resolved as AbsoluteFsPath);
|
return this.normalize(resolved as AbsoluteFsPath);
|
||||||
}
|
}
|
||||||
|
|
||||||
dirname<T extends string>(path: T): T {
|
override dirname<T extends string>(path: T): T {
|
||||||
return this.normalize(p.win32.dirname(path) as T);
|
return this.normalize(p.win32.dirname(path) as T);
|
||||||
}
|
}
|
||||||
|
|
||||||
join<T extends string>(basePath: T, ...paths: string[]): T {
|
override join<T extends string>(basePath: T, ...paths: string[]): T {
|
||||||
return this.normalize(p.win32.join(basePath, ...paths)) as T;
|
return this.normalize(p.win32.join(basePath, ...paths)) as T;
|
||||||
}
|
}
|
||||||
|
|
||||||
relative<T extends PathString>(from: T, to: T): PathSegment|AbsoluteFsPath {
|
override relative<T extends PathString>(from: T, to: T): PathSegment|AbsoluteFsPath {
|
||||||
return this.normalize(p.win32.relative(from, to)) as PathSegment | AbsoluteFsPath;
|
return this.normalize(p.win32.relative(from, to)) as PathSegment | AbsoluteFsPath;
|
||||||
}
|
}
|
||||||
|
|
||||||
basename(filePath: string, extension?: string): PathSegment {
|
override basename(filePath: string, extension?: string): PathSegment {
|
||||||
return p.win32.basename(filePath, extension) as PathSegment;
|
return p.win32.basename(filePath, extension) as PathSegment;
|
||||||
}
|
}
|
||||||
|
|
||||||
isRooted(path: string): boolean {
|
override isRooted(path: string): boolean {
|
||||||
return /^([A-Z]:)?([\\\/]|$)/i.test(path);
|
return /^([A-Z]:)?([\\\/]|$)/i.test(path);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected splitPath<T extends PathString>(path: T): string[] {
|
protected override splitPath<T extends PathString>(path: T): string[] {
|
||||||
return path.split(/[\\\/]/);
|
return path.split(/[\\\/]/);
|
||||||
}
|
}
|
||||||
|
|
||||||
normalize<T extends PathString>(path: T): T {
|
override normalize<T extends PathString>(path: T): T {
|
||||||
return path.replace(/^[\/\\]/i, 'C:/').replace(/\\/g, '/') as T;
|
return path.replace(/^[\/\\]/i, 'C:/').replace(/\\/g, '/') as T;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -35,11 +35,11 @@ export interface SemanticDependencyResult {
|
||||||
* compilation.
|
* compilation.
|
||||||
*/
|
*/
|
||||||
class OpaqueSymbol extends SemanticSymbol {
|
class OpaqueSymbol extends SemanticSymbol {
|
||||||
isPublicApiAffected(): false {
|
override isPublicApiAffected(): false {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
isTypeCheckApiAffected(): false {
|
override isTypeCheckApiAffected(): false {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,7 +16,7 @@ export class ArraySliceBuiltinFn extends KnownFn {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
evaluate(node: ts.CallExpression, args: ResolvedValueArray): ResolvedValue {
|
override evaluate(node: ts.CallExpression, args: ResolvedValueArray): ResolvedValue {
|
||||||
if (args.length === 0) {
|
if (args.length === 0) {
|
||||||
return this.lhs;
|
return this.lhs;
|
||||||
} else {
|
} else {
|
||||||
|
@ -30,7 +30,7 @@ export class ArrayConcatBuiltinFn extends KnownFn {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
evaluate(node: ts.CallExpression, args: ResolvedValueArray): ResolvedValue {
|
override evaluate(node: ts.CallExpression, args: ResolvedValueArray): ResolvedValue {
|
||||||
const result: ResolvedValueArray = [...this.lhs];
|
const result: ResolvedValueArray = [...this.lhs];
|
||||||
for (const arg of args) {
|
for (const arg of args) {
|
||||||
if (arg instanceof DynamicValue) {
|
if (arg instanceof DynamicValue) {
|
||||||
|
@ -46,7 +46,7 @@ export class ArrayConcatBuiltinFn extends KnownFn {
|
||||||
}
|
}
|
||||||
|
|
||||||
export class ObjectAssignBuiltinFn extends KnownFn {
|
export class ObjectAssignBuiltinFn extends KnownFn {
|
||||||
evaluate(node: ts.CallExpression, args: ResolvedValueArray): ResolvedValue {
|
override evaluate(node: ts.CallExpression, args: ResolvedValueArray): ResolvedValue {
|
||||||
if (args.length === 0) {
|
if (args.length === 0) {
|
||||||
return DynamicValue.fromUnsupportedSyntax(node);
|
return DynamicValue.fromUnsupportedSyntax(node);
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,7 +19,7 @@ export class AssignHelperFn extends ObjectAssignBuiltinFn {}
|
||||||
|
|
||||||
// Used for both `__spread()` and `__spreadArrays()` TypeScript helper functions.
|
// Used for both `__spread()` and `__spreadArrays()` TypeScript helper functions.
|
||||||
export class SpreadHelperFn extends KnownFn {
|
export class SpreadHelperFn extends KnownFn {
|
||||||
evaluate(node: ts.Node, args: ResolvedValueArray): ResolvedValueArray {
|
override evaluate(node: ts.Node, args: ResolvedValueArray): ResolvedValueArray {
|
||||||
const result: ResolvedValueArray = [];
|
const result: ResolvedValueArray = [];
|
||||||
|
|
||||||
for (const arg of args) {
|
for (const arg of args) {
|
||||||
|
@ -38,7 +38,7 @@ export class SpreadHelperFn extends KnownFn {
|
||||||
|
|
||||||
// Used for `__spreadArray` TypeScript helper function.
|
// Used for `__spreadArray` TypeScript helper function.
|
||||||
export class SpreadArrayHelperFn extends KnownFn {
|
export class SpreadArrayHelperFn extends KnownFn {
|
||||||
evaluate(node: ts.Node, args: ResolvedValueArray): ResolvedValue {
|
override evaluate(node: ts.Node, args: ResolvedValueArray): ResolvedValue {
|
||||||
if (args.length !== 2) {
|
if (args.length !== 2) {
|
||||||
return DynamicValue.fromUnknown(node);
|
return DynamicValue.fromUnknown(node);
|
||||||
}
|
}
|
||||||
|
@ -62,7 +62,7 @@ export class SpreadArrayHelperFn extends KnownFn {
|
||||||
|
|
||||||
// Used for `__read` TypeScript helper function.
|
// Used for `__read` TypeScript helper function.
|
||||||
export class ReadHelperFn extends KnownFn {
|
export class ReadHelperFn extends KnownFn {
|
||||||
evaluate(node: ts.Node, args: ResolvedValueArray): ResolvedValue {
|
override evaluate(node: ts.Node, args: ResolvedValueArray): ResolvedValue {
|
||||||
if (args.length !== 1) {
|
if (args.length !== 1) {
|
||||||
// The `__read` helper accepts a second argument `n` but that case is not supported.
|
// The `__read` helper accepts a second argument `n` but that case is not supported.
|
||||||
return DynamicValue.fromUnknown(node);
|
return DynamicValue.fromUnknown(node);
|
||||||
|
|
|
@ -61,7 +61,7 @@ class IvyCompilationVisitor extends Visitor {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
visitClassDeclaration(node: ts.ClassDeclaration):
|
override visitClassDeclaration(node: ts.ClassDeclaration):
|
||||||
VisitListEntryResult<ts.Statement, ts.ClassDeclaration> {
|
VisitListEntryResult<ts.Statement, ts.ClassDeclaration> {
|
||||||
// Determine if this class has an Ivy field that needs to be added, and compile the field
|
// Determine if this class has an Ivy field that needs to be added, and compile the field
|
||||||
// to an expression if so.
|
// to an expression if so.
|
||||||
|
@ -87,7 +87,7 @@ class IvyTransformationVisitor extends Visitor {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
visitClassDeclaration(node: ts.ClassDeclaration):
|
override visitClassDeclaration(node: ts.ClassDeclaration):
|
||||||
VisitListEntryResult<ts.Statement, ts.ClassDeclaration> {
|
VisitListEntryResult<ts.Statement, ts.ClassDeclaration> {
|
||||||
// If this class is not registered in the map, it means that it doesn't have Angular decorators,
|
// If this class is not registered in the map, it means that it doesn't have Angular decorators,
|
||||||
// thus no further processing is required.
|
// thus no further processing is required.
|
||||||
|
|
|
@ -192,14 +192,14 @@ class TcbElementOp extends TcbOp {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
get optional() {
|
override get optional() {
|
||||||
// The statement generated by this operation is only used for type-inference of the DOM
|
// The statement generated by this operation is only used for type-inference of the DOM
|
||||||
// element's type and won't report diagnostics by itself, so the operation is marked as optional
|
// element's type and won't report diagnostics by itself, so the operation is marked as optional
|
||||||
// to avoid generating statements for DOM elements that are never referenced.
|
// to avoid generating statements for DOM elements that are never referenced.
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
execute(): ts.Identifier {
|
override execute(): ts.Identifier {
|
||||||
const id = this.tcb.allocateId();
|
const id = this.tcb.allocateId();
|
||||||
// Add the declaration of the element using document.createElement.
|
// Add the declaration of the element using document.createElement.
|
||||||
const initializer = tsCreateElement(this.element.name);
|
const initializer = tsCreateElement(this.element.name);
|
||||||
|
@ -222,11 +222,11 @@ class TcbVariableOp extends TcbOp {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
get optional() {
|
override get optional() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
execute(): ts.Identifier {
|
override execute(): ts.Identifier {
|
||||||
// Look for a context variable for the template.
|
// Look for a context variable for the template.
|
||||||
const ctx = this.scope.resolve(this.template);
|
const ctx = this.scope.resolve(this.template);
|
||||||
|
|
||||||
|
@ -263,9 +263,9 @@ class TcbTemplateContextOp extends TcbOp {
|
||||||
}
|
}
|
||||||
|
|
||||||
// The declaration of the context variable is only needed when the context is actually referenced.
|
// The declaration of the context variable is only needed when the context is actually referenced.
|
||||||
readonly optional = true;
|
override readonly optional = true;
|
||||||
|
|
||||||
execute(): ts.Identifier {
|
override execute(): ts.Identifier {
|
||||||
// Allocate a template ctx variable and declare it with an 'any' type. The type of this variable
|
// Allocate a template ctx variable and declare it with an 'any' type. The type of this variable
|
||||||
// may be narrowed as a result of template guard conditions.
|
// may be narrowed as a result of template guard conditions.
|
||||||
const ctx = this.tcb.allocateId();
|
const ctx = this.tcb.allocateId();
|
||||||
|
@ -287,11 +287,11 @@ class TcbTemplateBodyOp extends TcbOp {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
get optional() {
|
override get optional() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
execute(): null {
|
override execute(): null {
|
||||||
// An `if` will be constructed, within which the template's children will be type checked. The
|
// An `if` will be constructed, within which the template's children will be type checked. The
|
||||||
// `if` is used for two reasons: it creates a new syntactic scope, isolating variables declared
|
// `if` is used for two reasons: it creates a new syntactic scope, isolating variables declared
|
||||||
// in the template's TCB from the outer context, and it allows any directives on the templates
|
// in the template's TCB from the outer context, and it allows any directives on the templates
|
||||||
|
@ -414,11 +414,11 @@ class TcbTextInterpolationOp extends TcbOp {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
get optional() {
|
override get optional() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
execute(): null {
|
override execute(): null {
|
||||||
const expr = tcbExpression(this.binding.value, this.tcb, this.scope);
|
const expr = tcbExpression(this.binding.value, this.tcb, this.scope);
|
||||||
this.scope.addStatement(ts.createExpressionStatement(expr));
|
this.scope.addStatement(ts.createExpressionStatement(expr));
|
||||||
return null;
|
return null;
|
||||||
|
@ -436,14 +436,14 @@ abstract class TcbDirectiveTypeOpBase extends TcbOp {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
get optional() {
|
override get optional() {
|
||||||
// The statement generated by this operation is only used to declare the directive's type and
|
// The statement generated by this operation is only used to declare the directive's type and
|
||||||
// won't report diagnostics by itself, so the operation is marked as optional to avoid
|
// won't report diagnostics by itself, so the operation is marked as optional to avoid
|
||||||
// generating declarations for directives that don't have any inputs/outputs.
|
// generating declarations for directives that don't have any inputs/outputs.
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
execute(): ts.Identifier {
|
override execute(): ts.Identifier {
|
||||||
const dirRef = this.dir.ref as Reference<ClassDeclaration<ts.ClassDeclaration>>;
|
const dirRef = this.dir.ref as Reference<ClassDeclaration<ts.ClassDeclaration>>;
|
||||||
|
|
||||||
const rawType = this.tcb.env.referenceType(this.dir.ref);
|
const rawType = this.tcb.env.referenceType(this.dir.ref);
|
||||||
|
@ -543,9 +543,9 @@ class TcbReferenceOp extends TcbOp {
|
||||||
|
|
||||||
// The statement generated by this operation is only used to for the Type Checker
|
// The statement generated by this operation is only used to for the Type Checker
|
||||||
// so it can map a reference variable in the template directly to a node in the TCB.
|
// so it can map a reference variable in the template directly to a node in the TCB.
|
||||||
readonly optional = true;
|
override readonly optional = true;
|
||||||
|
|
||||||
execute(): ts.Identifier {
|
override execute(): ts.Identifier {
|
||||||
const id = this.tcb.allocateId();
|
const id = this.tcb.allocateId();
|
||||||
let initializer =
|
let initializer =
|
||||||
this.target instanceof TmplAstTemplate || this.target instanceof TmplAstElement ?
|
this.target instanceof TmplAstTemplate || this.target instanceof TmplAstElement ?
|
||||||
|
@ -591,9 +591,9 @@ class TcbInvalidReferenceOp extends TcbOp {
|
||||||
}
|
}
|
||||||
|
|
||||||
// The declaration of a missing reference is only needed when the reference is resolved.
|
// The declaration of a missing reference is only needed when the reference is resolved.
|
||||||
readonly optional = true;
|
override readonly optional = true;
|
||||||
|
|
||||||
execute(): ts.Identifier {
|
override execute(): ts.Identifier {
|
||||||
const id = this.tcb.allocateId();
|
const id = this.tcb.allocateId();
|
||||||
this.scope.addStatement(tsCreateVariable(id, NULL_AS_ANY));
|
this.scope.addStatement(tsCreateVariable(id, NULL_AS_ANY));
|
||||||
return id;
|
return id;
|
||||||
|
@ -619,13 +619,13 @@ class TcbDirectiveCtorOp extends TcbOp {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
get optional() {
|
override get optional() {
|
||||||
// The statement generated by this operation is only used to infer the directive's type and
|
// The statement generated by this operation is only used to infer the directive's type and
|
||||||
// won't report diagnostics by itself, so the operation is marked as optional.
|
// won't report diagnostics by itself, so the operation is marked as optional.
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
execute(): ts.Identifier {
|
override execute(): ts.Identifier {
|
||||||
const id = this.tcb.allocateId();
|
const id = this.tcb.allocateId();
|
||||||
addExpressionIdentifier(id, ExpressionIdentifier.DIRECTIVE);
|
addExpressionIdentifier(id, ExpressionIdentifier.DIRECTIVE);
|
||||||
addParseSpanInfo(id, this.node.startSourceSpan || this.node.sourceSpan);
|
addParseSpanInfo(id, this.node.startSourceSpan || this.node.sourceSpan);
|
||||||
|
@ -689,11 +689,11 @@ class TcbDirectiveInputsOp extends TcbOp {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
get optional() {
|
override get optional() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
execute(): null {
|
override execute(): null {
|
||||||
let dirId: ts.Expression|null = null;
|
let dirId: ts.Expression|null = null;
|
||||||
|
|
||||||
// TODO(joost): report duplicate properties
|
// TODO(joost): report duplicate properties
|
||||||
|
@ -815,11 +815,11 @@ class TcbDirectiveCtorCircularFallbackOp extends TcbOp {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
get optional() {
|
override get optional() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
execute(): ts.Identifier {
|
override execute(): ts.Identifier {
|
||||||
const id = this.tcb.allocateId();
|
const id = this.tcb.allocateId();
|
||||||
const typeCtor = this.tcb.env.typeCtorFor(this.dir);
|
const typeCtor = this.tcb.env.typeCtorFor(this.dir);
|
||||||
const circularPlaceholder = ts.createCall(
|
const circularPlaceholder = ts.createCall(
|
||||||
|
@ -846,11 +846,11 @@ class TcbDomSchemaCheckerOp extends TcbOp {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
get optional() {
|
override get optional() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
execute(): ts.Expression|null {
|
override execute(): ts.Expression|null {
|
||||||
if (this.checkElement) {
|
if (this.checkElement) {
|
||||||
this.tcb.domSchemaChecker.checkElement(this.tcb.id, this.element, this.tcb.schemas);
|
this.tcb.domSchemaChecker.checkElement(this.tcb.id, this.element, this.tcb.schemas);
|
||||||
}
|
}
|
||||||
|
@ -906,11 +906,11 @@ class TcbUnclaimedInputsOp extends TcbOp {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
get optional() {
|
override get optional() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
execute(): null {
|
override execute(): null {
|
||||||
// `this.inputs` contains only those bindings not matched by any directive. These bindings go to
|
// `this.inputs` contains only those bindings not matched by any directive. These bindings go to
|
||||||
// the element itself.
|
// the element itself.
|
||||||
let elId: ts.Expression|null = null;
|
let elId: ts.Expression|null = null;
|
||||||
|
@ -972,11 +972,11 @@ export class TcbDirectiveOutputsOp extends TcbOp {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
get optional() {
|
override get optional() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
execute(): null {
|
override execute(): null {
|
||||||
let dirId: ts.Expression|null = null;
|
let dirId: ts.Expression|null = null;
|
||||||
const outputs = this.dir.outputs;
|
const outputs = this.dir.outputs;
|
||||||
|
|
||||||
|
@ -1035,11 +1035,11 @@ class TcbUnclaimedOutputsOp extends TcbOp {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
get optional() {
|
override get optional() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
execute(): null {
|
override execute(): null {
|
||||||
let elId: ts.Expression|null = null;
|
let elId: ts.Expression|null = null;
|
||||||
|
|
||||||
// TODO(alxhub): this could be more efficient.
|
// TODO(alxhub): this could be more efficient.
|
||||||
|
@ -1103,9 +1103,9 @@ class TcbComponentContextCompletionOp extends TcbOp {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
readonly optional = false;
|
override readonly optional = false;
|
||||||
|
|
||||||
execute(): null {
|
override execute(): null {
|
||||||
const ctx = ts.createIdentifier('ctx');
|
const ctx = ts.createIdentifier('ctx');
|
||||||
const ctxDot = ts.createPropertyAccess(ctx, '');
|
const ctxDot = ts.createPropertyAccess(ctx, '');
|
||||||
markIgnoreDiagnostics(ctxDot);
|
markIgnoreDiagnostics(ctxDot);
|
||||||
|
|
|
@ -13,7 +13,7 @@ import {makeProgram} from '../../testing';
|
||||||
import {visit, VisitListEntryResult, Visitor} from '../src/visitor';
|
import {visit, VisitListEntryResult, Visitor} from '../src/visitor';
|
||||||
|
|
||||||
class TestAstVisitor extends Visitor {
|
class TestAstVisitor extends Visitor {
|
||||||
visitClassDeclaration(node: ts.ClassDeclaration):
|
override visitClassDeclaration(node: ts.ClassDeclaration):
|
||||||
VisitListEntryResult<ts.Statement, ts.ClassDeclaration> {
|
VisitListEntryResult<ts.Statement, ts.ClassDeclaration> {
|
||||||
const name = node.name!.text;
|
const name = node.name!.text;
|
||||||
const statics = node.members.filter(
|
const statics = node.members.filter(
|
||||||
|
|
|
@ -1056,7 +1056,7 @@ class PopulatedScope extends BindingScope {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
resolve(name: string): any {
|
override resolve(name: string): any {
|
||||||
return this.bindings.has(name) ? this.bindings.get(name) : BindingScope.missing;
|
return this.bindings.has(name) ? this.bindings.get(name) : BindingScope.missing;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -62,7 +62,7 @@ class FixupExpression extends o.Expression {
|
||||||
this.original = resolved;
|
this.original = resolved;
|
||||||
}
|
}
|
||||||
|
|
||||||
visitExpression(visitor: o.ExpressionVisitor, context: any): any {
|
override visitExpression(visitor: o.ExpressionVisitor, context: any): any {
|
||||||
if (context === KEY_CONTEXT) {
|
if (context === KEY_CONTEXT) {
|
||||||
// When producing a key we want to traverse the constant not the
|
// When producing a key we want to traverse the constant not the
|
||||||
// variable used to refer to it.
|
// variable used to refer to it.
|
||||||
|
@ -72,11 +72,11 @@ class FixupExpression extends o.Expression {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
isEquivalent(e: o.Expression): boolean {
|
override isEquivalent(e: o.Expression): boolean {
|
||||||
return e instanceof FixupExpression && this.resolved.isEquivalent(e.resolved);
|
return e instanceof FixupExpression && this.resolved.isEquivalent(e.resolved);
|
||||||
}
|
}
|
||||||
|
|
||||||
isConstant() {
|
override isConstant() {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -65,7 +65,7 @@ export class Quote extends AST {
|
||||||
public uninterpretedExpression: string, public location: any) {
|
public uninterpretedExpression: string, public location: any) {
|
||||||
super(span, sourceSpan);
|
super(span, sourceSpan);
|
||||||
}
|
}
|
||||||
visit(visitor: AstVisitor, context: any = null): any {
|
override visit(visitor: AstVisitor, context: any = null): any {
|
||||||
return visitor.visitQuote(this, context);
|
return visitor.visitQuote(this, context);
|
||||||
}
|
}
|
||||||
override toString(): string {
|
override toString(): string {
|
||||||
|
@ -74,13 +74,13 @@ export class Quote extends AST {
|
||||||
}
|
}
|
||||||
|
|
||||||
export class EmptyExpr extends AST {
|
export class EmptyExpr extends AST {
|
||||||
visit(visitor: AstVisitor, context: any = null) {
|
override visit(visitor: AstVisitor, context: any = null) {
|
||||||
// do nothing
|
// do nothing
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export class ImplicitReceiver extends AST {
|
export class ImplicitReceiver extends AST {
|
||||||
visit(visitor: AstVisitor, context: any = null): any {
|
override visit(visitor: AstVisitor, context: any = null): any {
|
||||||
return visitor.visitImplicitReceiver(this, context);
|
return visitor.visitImplicitReceiver(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -106,7 +106,7 @@ export class Chain extends AST {
|
||||||
constructor(span: ParseSpan, sourceSpan: AbsoluteSourceSpan, public expressions: any[]) {
|
constructor(span: ParseSpan, sourceSpan: AbsoluteSourceSpan, public expressions: any[]) {
|
||||||
super(span, sourceSpan);
|
super(span, sourceSpan);
|
||||||
}
|
}
|
||||||
visit(visitor: AstVisitor, context: any = null): any {
|
override visit(visitor: AstVisitor, context: any = null): any {
|
||||||
return visitor.visitChain(this, context);
|
return visitor.visitChain(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -117,7 +117,7 @@ export class Conditional extends AST {
|
||||||
public falseExp: AST) {
|
public falseExp: AST) {
|
||||||
super(span, sourceSpan);
|
super(span, sourceSpan);
|
||||||
}
|
}
|
||||||
visit(visitor: AstVisitor, context: any = null): any {
|
override visit(visitor: AstVisitor, context: any = null): any {
|
||||||
return visitor.visitConditional(this, context);
|
return visitor.visitConditional(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -128,7 +128,7 @@ export class PropertyRead extends ASTWithName {
|
||||||
public receiver: AST, public name: string) {
|
public receiver: AST, public name: string) {
|
||||||
super(span, sourceSpan, nameSpan);
|
super(span, sourceSpan, nameSpan);
|
||||||
}
|
}
|
||||||
visit(visitor: AstVisitor, context: any = null): any {
|
override visit(visitor: AstVisitor, context: any = null): any {
|
||||||
return visitor.visitPropertyRead(this, context);
|
return visitor.visitPropertyRead(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -139,7 +139,7 @@ export class PropertyWrite extends ASTWithName {
|
||||||
public receiver: AST, public name: string, public value: AST) {
|
public receiver: AST, public name: string, public value: AST) {
|
||||||
super(span, sourceSpan, nameSpan);
|
super(span, sourceSpan, nameSpan);
|
||||||
}
|
}
|
||||||
visit(visitor: AstVisitor, context: any = null): any {
|
override visit(visitor: AstVisitor, context: any = null): any {
|
||||||
return visitor.visitPropertyWrite(this, context);
|
return visitor.visitPropertyWrite(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -150,7 +150,7 @@ export class SafePropertyRead extends ASTWithName {
|
||||||
public receiver: AST, public name: string) {
|
public receiver: AST, public name: string) {
|
||||||
super(span, sourceSpan, nameSpan);
|
super(span, sourceSpan, nameSpan);
|
||||||
}
|
}
|
||||||
visit(visitor: AstVisitor, context: any = null): any {
|
override visit(visitor: AstVisitor, context: any = null): any {
|
||||||
return visitor.visitSafePropertyRead(this, context);
|
return visitor.visitSafePropertyRead(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -160,7 +160,7 @@ export class KeyedRead extends AST {
|
||||||
span: ParseSpan, sourceSpan: AbsoluteSourceSpan, public receiver: AST, public key: AST) {
|
span: ParseSpan, sourceSpan: AbsoluteSourceSpan, public receiver: AST, public key: AST) {
|
||||||
super(span, sourceSpan);
|
super(span, sourceSpan);
|
||||||
}
|
}
|
||||||
visit(visitor: AstVisitor, context: any = null): any {
|
override visit(visitor: AstVisitor, context: any = null): any {
|
||||||
return visitor.visitKeyedRead(this, context);
|
return visitor.visitKeyedRead(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -170,7 +170,7 @@ export class SafeKeyedRead extends AST {
|
||||||
span: ParseSpan, sourceSpan: AbsoluteSourceSpan, public receiver: AST, public key: AST) {
|
span: ParseSpan, sourceSpan: AbsoluteSourceSpan, public receiver: AST, public key: AST) {
|
||||||
super(span, sourceSpan);
|
super(span, sourceSpan);
|
||||||
}
|
}
|
||||||
visit(visitor: AstVisitor, context: any = null): any {
|
override visit(visitor: AstVisitor, context: any = null): any {
|
||||||
return visitor.visitSafeKeyedRead(this, context);
|
return visitor.visitSafeKeyedRead(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -181,7 +181,7 @@ export class KeyedWrite extends AST {
|
||||||
public value: AST) {
|
public value: AST) {
|
||||||
super(span, sourceSpan);
|
super(span, sourceSpan);
|
||||||
}
|
}
|
||||||
visit(visitor: AstVisitor, context: any = null): any {
|
override visit(visitor: AstVisitor, context: any = null): any {
|
||||||
return visitor.visitKeyedWrite(this, context);
|
return visitor.visitKeyedWrite(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -192,7 +192,7 @@ export class BindingPipe extends ASTWithName {
|
||||||
public args: any[], nameSpan: AbsoluteSourceSpan) {
|
public args: any[], nameSpan: AbsoluteSourceSpan) {
|
||||||
super(span, sourceSpan, nameSpan);
|
super(span, sourceSpan, nameSpan);
|
||||||
}
|
}
|
||||||
visit(visitor: AstVisitor, context: any = null): any {
|
override visit(visitor: AstVisitor, context: any = null): any {
|
||||||
return visitor.visitPipe(this, context);
|
return visitor.visitPipe(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -201,7 +201,7 @@ export class LiteralPrimitive extends AST {
|
||||||
constructor(span: ParseSpan, sourceSpan: AbsoluteSourceSpan, public value: any) {
|
constructor(span: ParseSpan, sourceSpan: AbsoluteSourceSpan, public value: any) {
|
||||||
super(span, sourceSpan);
|
super(span, sourceSpan);
|
||||||
}
|
}
|
||||||
visit(visitor: AstVisitor, context: any = null): any {
|
override visit(visitor: AstVisitor, context: any = null): any {
|
||||||
return visitor.visitLiteralPrimitive(this, context);
|
return visitor.visitLiteralPrimitive(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -210,7 +210,7 @@ export class LiteralArray extends AST {
|
||||||
constructor(span: ParseSpan, sourceSpan: AbsoluteSourceSpan, public expressions: any[]) {
|
constructor(span: ParseSpan, sourceSpan: AbsoluteSourceSpan, public expressions: any[]) {
|
||||||
super(span, sourceSpan);
|
super(span, sourceSpan);
|
||||||
}
|
}
|
||||||
visit(visitor: AstVisitor, context: any = null): any {
|
override visit(visitor: AstVisitor, context: any = null): any {
|
||||||
return visitor.visitLiteralArray(this, context);
|
return visitor.visitLiteralArray(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -225,7 +225,7 @@ export class LiteralMap extends AST {
|
||||||
public values: any[]) {
|
public values: any[]) {
|
||||||
super(span, sourceSpan);
|
super(span, sourceSpan);
|
||||||
}
|
}
|
||||||
visit(visitor: AstVisitor, context: any = null): any {
|
override visit(visitor: AstVisitor, context: any = null): any {
|
||||||
return visitor.visitLiteralMap(this, context);
|
return visitor.visitLiteralMap(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -236,7 +236,7 @@ export class Interpolation extends AST {
|
||||||
public expressions: any[]) {
|
public expressions: any[]) {
|
||||||
super(span, sourceSpan);
|
super(span, sourceSpan);
|
||||||
}
|
}
|
||||||
visit(visitor: AstVisitor, context: any = null): any {
|
override visit(visitor: AstVisitor, context: any = null): any {
|
||||||
return visitor.visitInterpolation(this, context);
|
return visitor.visitInterpolation(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -247,7 +247,7 @@ export class Binary extends AST {
|
||||||
public right: AST) {
|
public right: AST) {
|
||||||
super(span, sourceSpan);
|
super(span, sourceSpan);
|
||||||
}
|
}
|
||||||
visit(visitor: AstVisitor, context: any = null): any {
|
override visit(visitor: AstVisitor, context: any = null): any {
|
||||||
return visitor.visitBinary(this, context);
|
return visitor.visitBinary(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -302,7 +302,7 @@ export class PrefixNot extends AST {
|
||||||
constructor(span: ParseSpan, sourceSpan: AbsoluteSourceSpan, public expression: AST) {
|
constructor(span: ParseSpan, sourceSpan: AbsoluteSourceSpan, public expression: AST) {
|
||||||
super(span, sourceSpan);
|
super(span, sourceSpan);
|
||||||
}
|
}
|
||||||
visit(visitor: AstVisitor, context: any = null): any {
|
override visit(visitor: AstVisitor, context: any = null): any {
|
||||||
return visitor.visitPrefixNot(this, context);
|
return visitor.visitPrefixNot(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -311,7 +311,7 @@ export class NonNullAssert extends AST {
|
||||||
constructor(span: ParseSpan, sourceSpan: AbsoluteSourceSpan, public expression: AST) {
|
constructor(span: ParseSpan, sourceSpan: AbsoluteSourceSpan, public expression: AST) {
|
||||||
super(span, sourceSpan);
|
super(span, sourceSpan);
|
||||||
}
|
}
|
||||||
visit(visitor: AstVisitor, context: any = null): any {
|
override visit(visitor: AstVisitor, context: any = null): any {
|
||||||
return visitor.visitNonNullAssert(this, context);
|
return visitor.visitNonNullAssert(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -323,7 +323,7 @@ export class MethodCall extends ASTWithName {
|
||||||
public argumentSpan: AbsoluteSourceSpan) {
|
public argumentSpan: AbsoluteSourceSpan) {
|
||||||
super(span, sourceSpan, nameSpan);
|
super(span, sourceSpan, nameSpan);
|
||||||
}
|
}
|
||||||
visit(visitor: AstVisitor, context: any = null): any {
|
override visit(visitor: AstVisitor, context: any = null): any {
|
||||||
return visitor.visitMethodCall(this, context);
|
return visitor.visitMethodCall(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -335,7 +335,7 @@ export class SafeMethodCall extends ASTWithName {
|
||||||
public argumentSpan: AbsoluteSourceSpan) {
|
public argumentSpan: AbsoluteSourceSpan) {
|
||||||
super(span, sourceSpan, nameSpan);
|
super(span, sourceSpan, nameSpan);
|
||||||
}
|
}
|
||||||
visit(visitor: AstVisitor, context: any = null): any {
|
override visit(visitor: AstVisitor, context: any = null): any {
|
||||||
return visitor.visitSafeMethodCall(this, context);
|
return visitor.visitSafeMethodCall(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -346,7 +346,7 @@ export class FunctionCall extends AST {
|
||||||
public args: any[]) {
|
public args: any[]) {
|
||||||
super(span, sourceSpan);
|
super(span, sourceSpan);
|
||||||
}
|
}
|
||||||
visit(visitor: AstVisitor, context: any = null): any {
|
override visit(visitor: AstVisitor, context: any = null): any {
|
||||||
return visitor.visitFunctionCall(this, context);
|
return visitor.visitFunctionCall(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -368,7 +368,7 @@ export class ASTWithSource extends AST {
|
||||||
new AbsoluteSourceSpan(
|
new AbsoluteSourceSpan(
|
||||||
absoluteOffset, source === null ? absoluteOffset : absoluteOffset + source.length));
|
absoluteOffset, source === null ? absoluteOffset : absoluteOffset + source.length));
|
||||||
}
|
}
|
||||||
visit(visitor: AstVisitor, context: any = null): any {
|
override visit(visitor: AstVisitor, context: any = null): any {
|
||||||
if (visitor.visitASTWithSource) {
|
if (visitor.visitASTWithSource) {
|
||||||
return visitor.visitASTWithSource(this, context);
|
return visitor.visitASTWithSource(this, context);
|
||||||
}
|
}
|
||||||
|
|
|
@ -34,7 +34,7 @@ const _CONTEXT_TAG = 'context';
|
||||||
// https://docs.oasis-open.org/xliff/v1.2/os/xliff-core.html
|
// https://docs.oasis-open.org/xliff/v1.2/os/xliff-core.html
|
||||||
// https://docs.oasis-open.org/xliff/v1.2/xliff-profile-html/xliff-profile-html-1.2.html
|
// https://docs.oasis-open.org/xliff/v1.2/xliff-profile-html/xliff-profile-html-1.2.html
|
||||||
export class Xliff extends Serializer {
|
export class Xliff extends Serializer {
|
||||||
write(messages: i18n.Message[], locale: string|null): string {
|
override write(messages: i18n.Message[], locale: string|null): string {
|
||||||
const visitor = new _WriteVisitor();
|
const visitor = new _WriteVisitor();
|
||||||
const transUnits: xml.Node[] = [];
|
const transUnits: xml.Node[] = [];
|
||||||
|
|
||||||
|
@ -92,7 +92,7 @@ export class Xliff extends Serializer {
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
load(content: string, url: string):
|
override load(content: string, url: string):
|
||||||
{locale: string, i18nNodesByMsgId: {[msgId: string]: i18n.Node[]}} {
|
{locale: string, i18nNodesByMsgId: {[msgId: string]: i18n.Node[]}} {
|
||||||
// xliff to xml nodes
|
// xliff to xml nodes
|
||||||
const xliffParser = new XliffParser();
|
const xliffParser = new XliffParser();
|
||||||
|
@ -115,7 +115,7 @@ export class Xliff extends Serializer {
|
||||||
return {locale: locale!, i18nNodesByMsgId};
|
return {locale: locale!, i18nNodesByMsgId};
|
||||||
}
|
}
|
||||||
|
|
||||||
digest(message: i18n.Message): string {
|
override digest(message: i18n.Message): string {
|
||||||
return digest(message);
|
return digest(message);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -30,7 +30,7 @@ const _UNIT_TAG = 'unit';
|
||||||
|
|
||||||
// https://docs.oasis-open.org/xliff/xliff-core/v2.0/os/xliff-core-v2.0-os.html
|
// https://docs.oasis-open.org/xliff/xliff-core/v2.0/os/xliff-core-v2.0-os.html
|
||||||
export class Xliff2 extends Serializer {
|
export class Xliff2 extends Serializer {
|
||||||
write(messages: i18n.Message[], locale: string|null): string {
|
override write(messages: i18n.Message[], locale: string|null): string {
|
||||||
const visitor = new _WriteVisitor();
|
const visitor = new _WriteVisitor();
|
||||||
const units: xml.Node[] = [];
|
const units: xml.Node[] = [];
|
||||||
|
|
||||||
|
@ -85,7 +85,7 @@ export class Xliff2 extends Serializer {
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
load(content: string, url: string):
|
override load(content: string, url: string):
|
||||||
{locale: string, i18nNodesByMsgId: {[msgId: string]: i18n.Node[]}} {
|
{locale: string, i18nNodesByMsgId: {[msgId: string]: i18n.Node[]}} {
|
||||||
// xliff to xml nodes
|
// xliff to xml nodes
|
||||||
const xliff2Parser = new Xliff2Parser();
|
const xliff2Parser = new Xliff2Parser();
|
||||||
|
@ -108,7 +108,7 @@ export class Xliff2 extends Serializer {
|
||||||
return {locale: locale!, i18nNodesByMsgId};
|
return {locale: locale!, i18nNodesByMsgId};
|
||||||
}
|
}
|
||||||
|
|
||||||
digest(message: i18n.Message): string {
|
override digest(message: i18n.Message): string {
|
||||||
return decimalDigest(message);
|
return decimalDigest(message);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -39,7 +39,7 @@ const _DOCTYPE = `<!ELEMENT messagebundle (msg)*>
|
||||||
<!ELEMENT ex (#PCDATA)>`;
|
<!ELEMENT ex (#PCDATA)>`;
|
||||||
|
|
||||||
export class Xmb extends Serializer {
|
export class Xmb extends Serializer {
|
||||||
write(messages: i18n.Message[], locale: string|null): string {
|
override write(messages: i18n.Message[], locale: string|null): string {
|
||||||
const exampleVisitor = new ExampleVisitor();
|
const exampleVisitor = new ExampleVisitor();
|
||||||
const visitor = new _Visitor();
|
const visitor = new _Visitor();
|
||||||
let rootNode = new xml.Tag(_MESSAGES_TAG);
|
let rootNode = new xml.Tag(_MESSAGES_TAG);
|
||||||
|
@ -80,12 +80,12 @@ export class Xmb extends Serializer {
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
load(content: string, url: string):
|
override load(content: string, url: string):
|
||||||
{locale: string, i18nNodesByMsgId: {[msgId: string]: i18n.Node[]}} {
|
{locale: string, i18nNodesByMsgId: {[msgId: string]: i18n.Node[]}} {
|
||||||
throw new Error('Unsupported');
|
throw new Error('Unsupported');
|
||||||
}
|
}
|
||||||
|
|
||||||
digest(message: i18n.Message): string {
|
override digest(message: i18n.Message): string {
|
||||||
return digest(message);
|
return digest(message);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -19,11 +19,11 @@ const _TRANSLATION_TAG = 'translation';
|
||||||
const _PLACEHOLDER_TAG = 'ph';
|
const _PLACEHOLDER_TAG = 'ph';
|
||||||
|
|
||||||
export class Xtb extends Serializer {
|
export class Xtb extends Serializer {
|
||||||
write(messages: i18n.Message[], locale: string|null): string {
|
override write(messages: i18n.Message[], locale: string|null): string {
|
||||||
throw new Error('Unsupported');
|
throw new Error('Unsupported');
|
||||||
}
|
}
|
||||||
|
|
||||||
load(content: string, url: string):
|
override load(content: string, url: string):
|
||||||
{locale: string, i18nNodesByMsgId: {[msgId: string]: i18n.Node[]}} {
|
{locale: string, i18nNodesByMsgId: {[msgId: string]: i18n.Node[]}} {
|
||||||
// xtb to xml nodes
|
// xtb to xml nodes
|
||||||
const xtbParser = new XtbParser();
|
const xtbParser = new XtbParser();
|
||||||
|
@ -54,7 +54,7 @@ export class Xtb extends Serializer {
|
||||||
return {locale: locale!, i18nNodesByMsgId};
|
return {locale: locale!, i18nNodesByMsgId};
|
||||||
}
|
}
|
||||||
|
|
||||||
digest(message: i18n.Message): string {
|
override digest(message: i18n.Message): string {
|
||||||
return digest(message);
|
return digest(message);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -26,7 +26,7 @@ export class Text extends NodeWithI18n {
|
||||||
constructor(public value: string, sourceSpan: ParseSourceSpan, i18n?: I18nMeta) {
|
constructor(public value: string, sourceSpan: ParseSourceSpan, i18n?: I18nMeta) {
|
||||||
super(sourceSpan, i18n);
|
super(sourceSpan, i18n);
|
||||||
}
|
}
|
||||||
visit(visitor: Visitor, context: any): any {
|
override visit(visitor: Visitor, context: any): any {
|
||||||
return visitor.visitText(this, context);
|
return visitor.visitText(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -37,7 +37,7 @@ export class Expansion extends NodeWithI18n {
|
||||||
sourceSpan: ParseSourceSpan, public switchValueSourceSpan: ParseSourceSpan, i18n?: I18nMeta) {
|
sourceSpan: ParseSourceSpan, public switchValueSourceSpan: ParseSourceSpan, i18n?: I18nMeta) {
|
||||||
super(sourceSpan, i18n);
|
super(sourceSpan, i18n);
|
||||||
}
|
}
|
||||||
visit(visitor: Visitor, context: any): any {
|
override visit(visitor: Visitor, context: any): any {
|
||||||
return visitor.visitExpansion(this, context);
|
return visitor.visitExpansion(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -59,7 +59,7 @@ export class Attribute extends NodeWithI18n {
|
||||||
i18n?: I18nMeta) {
|
i18n?: I18nMeta) {
|
||||||
super(sourceSpan, i18n);
|
super(sourceSpan, i18n);
|
||||||
}
|
}
|
||||||
visit(visitor: Visitor, context: any): any {
|
override visit(visitor: Visitor, context: any): any {
|
||||||
return visitor.visitAttribute(this, context);
|
return visitor.visitAttribute(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -71,7 +71,7 @@ export class Element extends NodeWithI18n {
|
||||||
public endSourceSpan: ParseSourceSpan|null = null, i18n?: I18nMeta) {
|
public endSourceSpan: ParseSourceSpan|null = null, i18n?: I18nMeta) {
|
||||||
super(sourceSpan, i18n);
|
super(sourceSpan, i18n);
|
||||||
}
|
}
|
||||||
visit(visitor: Visitor, context: any): any {
|
override visit(visitor: Visitor, context: any): any {
|
||||||
return visitor.visitElement(this, context);
|
return visitor.visitElement(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -29,7 +29,7 @@ export abstract class AbstractJsEmitterVisitor extends AbstractEmitterVisitor {
|
||||||
constructor() {
|
constructor() {
|
||||||
super(false);
|
super(false);
|
||||||
}
|
}
|
||||||
visitDeclareClassStmt(stmt: o.ClassStmt, ctx: EmitterVisitorContext): any {
|
override visitDeclareClassStmt(stmt: o.ClassStmt, ctx: EmitterVisitorContext): any {
|
||||||
ctx.pushClass(stmt);
|
ctx.pushClass(stmt);
|
||||||
this._visitClassConstructor(stmt, ctx);
|
this._visitClassConstructor(stmt, ctx);
|
||||||
|
|
||||||
|
@ -102,7 +102,7 @@ export abstract class AbstractJsEmitterVisitor extends AbstractEmitterVisitor {
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
visitDeclareVarStmt(stmt: o.DeclareVarStmt, ctx: EmitterVisitorContext): any {
|
override visitDeclareVarStmt(stmt: o.DeclareVarStmt, ctx: EmitterVisitorContext): any {
|
||||||
ctx.print(stmt, `var ${stmt.name}`);
|
ctx.print(stmt, `var ${stmt.name}`);
|
||||||
if (stmt.value) {
|
if (stmt.value) {
|
||||||
ctx.print(stmt, ' = ');
|
ctx.print(stmt, ' = ');
|
||||||
|
@ -111,7 +111,7 @@ export abstract class AbstractJsEmitterVisitor extends AbstractEmitterVisitor {
|
||||||
ctx.println(stmt, `;`);
|
ctx.println(stmt, `;`);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
visitCastExpr(ast: o.CastExpr, ctx: EmitterVisitorContext): any {
|
override visitCastExpr(ast: o.CastExpr, ctx: EmitterVisitorContext): any {
|
||||||
ast.value.visitExpression(this, ctx);
|
ast.value.visitExpression(this, ctx);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@ -152,7 +152,7 @@ export abstract class AbstractJsEmitterVisitor extends AbstractEmitterVisitor {
|
||||||
ctx.print(ast, ')');
|
ctx.print(ast, ')');
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
visitFunctionExpr(ast: o.FunctionExpr, ctx: EmitterVisitorContext): any {
|
override visitFunctionExpr(ast: o.FunctionExpr, ctx: EmitterVisitorContext): any {
|
||||||
ctx.print(ast, `function${ast.name ? ' ' + ast.name : ''}(`);
|
ctx.print(ast, `function${ast.name ? ' ' + ast.name : ''}(`);
|
||||||
this._visitParams(ast.params, ctx);
|
this._visitParams(ast.params, ctx);
|
||||||
ctx.println(ast, `) {`);
|
ctx.println(ast, `) {`);
|
||||||
|
@ -162,7 +162,7 @@ export abstract class AbstractJsEmitterVisitor extends AbstractEmitterVisitor {
|
||||||
ctx.print(ast, `}`);
|
ctx.print(ast, `}`);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
visitDeclareFunctionStmt(stmt: o.DeclareFunctionStmt, ctx: EmitterVisitorContext): any {
|
override visitDeclareFunctionStmt(stmt: o.DeclareFunctionStmt, ctx: EmitterVisitorContext): any {
|
||||||
ctx.print(stmt, `function ${stmt.name}(`);
|
ctx.print(stmt, `function ${stmt.name}(`);
|
||||||
this._visitParams(stmt.params, ctx);
|
this._visitParams(stmt.params, ctx);
|
||||||
ctx.println(stmt, `) {`);
|
ctx.println(stmt, `) {`);
|
||||||
|
@ -172,7 +172,7 @@ export abstract class AbstractJsEmitterVisitor extends AbstractEmitterVisitor {
|
||||||
ctx.println(stmt, `}`);
|
ctx.println(stmt, `}`);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
visitTryCatchStmt(stmt: o.TryCatchStmt, ctx: EmitterVisitorContext): any {
|
override visitTryCatchStmt(stmt: o.TryCatchStmt, ctx: EmitterVisitorContext): any {
|
||||||
ctx.println(stmt, `try {`);
|
ctx.println(stmt, `try {`);
|
||||||
ctx.incIndent();
|
ctx.incIndent();
|
||||||
this.visitAllStatements(stmt.bodyStmts, ctx);
|
this.visitAllStatements(stmt.bodyStmts, ctx);
|
||||||
|
@ -217,7 +217,7 @@ export abstract class AbstractJsEmitterVisitor extends AbstractEmitterVisitor {
|
||||||
this.visitAllObjects(param => ctx.print(null, param.name), params, ctx, ',');
|
this.visitAllObjects(param => ctx.print(null, param.name), params, ctx, ',');
|
||||||
}
|
}
|
||||||
|
|
||||||
getBuiltinMethodName(method: o.BuiltinMethod): string {
|
override getBuiltinMethodName(method: o.BuiltinMethod): string {
|
||||||
let name: string;
|
let name: string;
|
||||||
switch (method) {
|
switch (method) {
|
||||||
case o.BuiltinMethod.ConcatArray:
|
case o.BuiltinMethod.ConcatArray:
|
||||||
|
|
|
@ -41,7 +41,7 @@ export class JavaScriptEmitter implements OutputEmitter {
|
||||||
class JsEmitterVisitor extends AbstractJsEmitterVisitor {
|
class JsEmitterVisitor extends AbstractJsEmitterVisitor {
|
||||||
importsWithPrefixes = new Map<string, string>();
|
importsWithPrefixes = new Map<string, string>();
|
||||||
|
|
||||||
visitExternalExpr(ast: o.ExternalExpr, ctx: EmitterVisitorContext): any {
|
override visitExternalExpr(ast: o.ExternalExpr, ctx: EmitterVisitorContext): any {
|
||||||
const {name, moduleName} = ast.value;
|
const {name, moduleName} = ast.value;
|
||||||
if (moduleName) {
|
if (moduleName) {
|
||||||
let prefix = this.importsWithPrefixes.get(moduleName);
|
let prefix = this.importsWithPrefixes.get(moduleName);
|
||||||
|
|
|
@ -39,7 +39,7 @@ export class BuiltinType extends Type {
|
||||||
constructor(public name: BuiltinTypeName, modifiers?: TypeModifier[]) {
|
constructor(public name: BuiltinTypeName, modifiers?: TypeModifier[]) {
|
||||||
super(modifiers);
|
super(modifiers);
|
||||||
}
|
}
|
||||||
visitType(visitor: TypeVisitor, context: any): any {
|
override visitType(visitor: TypeVisitor, context: any): any {
|
||||||
return visitor.visitBuiltinType(this, context);
|
return visitor.visitBuiltinType(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -49,7 +49,7 @@ export class ExpressionType extends Type {
|
||||||
public value: Expression, modifiers?: TypeModifier[], public typeParams: Type[]|null = null) {
|
public value: Expression, modifiers?: TypeModifier[], public typeParams: Type[]|null = null) {
|
||||||
super(modifiers);
|
super(modifiers);
|
||||||
}
|
}
|
||||||
visitType(visitor: TypeVisitor, context: any): any {
|
override visitType(visitor: TypeVisitor, context: any): any {
|
||||||
return visitor.visitExpressionType(this, context);
|
return visitor.visitExpressionType(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -59,7 +59,7 @@ export class ArrayType extends Type {
|
||||||
constructor(public of: Type, modifiers?: TypeModifier[]) {
|
constructor(public of: Type, modifiers?: TypeModifier[]) {
|
||||||
super(modifiers);
|
super(modifiers);
|
||||||
}
|
}
|
||||||
visitType(visitor: TypeVisitor, context: any): any {
|
override visitType(visitor: TypeVisitor, context: any): any {
|
||||||
return visitor.visitArrayType(this, context);
|
return visitor.visitArrayType(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -71,7 +71,7 @@ export class MapType extends Type {
|
||||||
super(modifiers);
|
super(modifiers);
|
||||||
this.valueType = valueType || null;
|
this.valueType = valueType || null;
|
||||||
}
|
}
|
||||||
visitType(visitor: TypeVisitor, context: any): any {
|
override visitType(visitor: TypeVisitor, context: any): any {
|
||||||
return visitor.visitMapType(this, context);
|
return visitor.visitMapType(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -286,15 +286,15 @@ export class ReadVarExpr extends Expression {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
isEquivalent(e: Expression): boolean {
|
override isEquivalent(e: Expression): boolean {
|
||||||
return e instanceof ReadVarExpr && this.name === e.name && this.builtin === e.builtin;
|
return e instanceof ReadVarExpr && this.name === e.name && this.builtin === e.builtin;
|
||||||
}
|
}
|
||||||
|
|
||||||
isConstant() {
|
override isConstant() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
visitExpression(visitor: ExpressionVisitor, context: any): any {
|
override visitExpression(visitor: ExpressionVisitor, context: any): any {
|
||||||
return visitor.visitReadVarExpr(this, context);
|
return visitor.visitReadVarExpr(this, context);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -311,15 +311,15 @@ export class TypeofExpr extends Expression {
|
||||||
super(type, sourceSpan);
|
super(type, sourceSpan);
|
||||||
}
|
}
|
||||||
|
|
||||||
visitExpression(visitor: ExpressionVisitor, context: any) {
|
override visitExpression(visitor: ExpressionVisitor, context: any) {
|
||||||
return visitor.visitTypeofExpr(this, context);
|
return visitor.visitTypeofExpr(this, context);
|
||||||
}
|
}
|
||||||
|
|
||||||
isEquivalent(e: Expression): boolean {
|
override isEquivalent(e: Expression): boolean {
|
||||||
return e instanceof TypeofExpr && e.expr.isEquivalent(this.expr);
|
return e instanceof TypeofExpr && e.expr.isEquivalent(this.expr);
|
||||||
}
|
}
|
||||||
|
|
||||||
isConstant(): boolean {
|
override isConstant(): boolean {
|
||||||
return this.expr.isConstant();
|
return this.expr.isConstant();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -329,15 +329,15 @@ export class WrappedNodeExpr<T> extends Expression {
|
||||||
super(type, sourceSpan);
|
super(type, sourceSpan);
|
||||||
}
|
}
|
||||||
|
|
||||||
isEquivalent(e: Expression): boolean {
|
override isEquivalent(e: Expression): boolean {
|
||||||
return e instanceof WrappedNodeExpr && this.node === e.node;
|
return e instanceof WrappedNodeExpr && this.node === e.node;
|
||||||
}
|
}
|
||||||
|
|
||||||
isConstant() {
|
override isConstant() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
visitExpression(visitor: ExpressionVisitor, context: any): any {
|
override visitExpression(visitor: ExpressionVisitor, context: any): any {
|
||||||
return visitor.visitWrappedNodeExpr(this, context);
|
return visitor.visitWrappedNodeExpr(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -350,15 +350,15 @@ export class WriteVarExpr extends Expression {
|
||||||
this.value = value;
|
this.value = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
isEquivalent(e: Expression): boolean {
|
override isEquivalent(e: Expression): boolean {
|
||||||
return e instanceof WriteVarExpr && this.name === e.name && this.value.isEquivalent(e.value);
|
return e instanceof WriteVarExpr && this.name === e.name && this.value.isEquivalent(e.value);
|
||||||
}
|
}
|
||||||
|
|
||||||
isConstant() {
|
override isConstant() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
visitExpression(visitor: ExpressionVisitor, context: any): any {
|
override visitExpression(visitor: ExpressionVisitor, context: any): any {
|
||||||
return visitor.visitWriteVarExpr(this, context);
|
return visitor.visitWriteVarExpr(this, context);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -381,16 +381,16 @@ export class WriteKeyExpr extends Expression {
|
||||||
this.value = value;
|
this.value = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
isEquivalent(e: Expression): boolean {
|
override isEquivalent(e: Expression): boolean {
|
||||||
return e instanceof WriteKeyExpr && this.receiver.isEquivalent(e.receiver) &&
|
return e instanceof WriteKeyExpr && this.receiver.isEquivalent(e.receiver) &&
|
||||||
this.index.isEquivalent(e.index) && this.value.isEquivalent(e.value);
|
this.index.isEquivalent(e.index) && this.value.isEquivalent(e.value);
|
||||||
}
|
}
|
||||||
|
|
||||||
isConstant() {
|
override isConstant() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
visitExpression(visitor: ExpressionVisitor, context: any): any {
|
override visitExpression(visitor: ExpressionVisitor, context: any): any {
|
||||||
return visitor.visitWriteKeyExpr(this, context);
|
return visitor.visitWriteKeyExpr(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -405,16 +405,16 @@ export class WritePropExpr extends Expression {
|
||||||
this.value = value;
|
this.value = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
isEquivalent(e: Expression): boolean {
|
override isEquivalent(e: Expression): boolean {
|
||||||
return e instanceof WritePropExpr && this.receiver.isEquivalent(e.receiver) &&
|
return e instanceof WritePropExpr && this.receiver.isEquivalent(e.receiver) &&
|
||||||
this.name === e.name && this.value.isEquivalent(e.value);
|
this.name === e.name && this.value.isEquivalent(e.value);
|
||||||
}
|
}
|
||||||
|
|
||||||
isConstant() {
|
override isConstant() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
visitExpression(visitor: ExpressionVisitor, context: any): any {
|
override visitExpression(visitor: ExpressionVisitor, context: any): any {
|
||||||
return visitor.visitWritePropExpr(this, context);
|
return visitor.visitWritePropExpr(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -441,16 +441,16 @@ export class InvokeMethodExpr extends Expression {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
isEquivalent(e: Expression): boolean {
|
override isEquivalent(e: Expression): boolean {
|
||||||
return e instanceof InvokeMethodExpr && this.receiver.isEquivalent(e.receiver) &&
|
return e instanceof InvokeMethodExpr && this.receiver.isEquivalent(e.receiver) &&
|
||||||
this.name === e.name && this.builtin === e.builtin && areAllEquivalent(this.args, e.args);
|
this.name === e.name && this.builtin === e.builtin && areAllEquivalent(this.args, e.args);
|
||||||
}
|
}
|
||||||
|
|
||||||
isConstant() {
|
override isConstant() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
visitExpression(visitor: ExpressionVisitor, context: any): any {
|
override visitExpression(visitor: ExpressionVisitor, context: any): any {
|
||||||
return visitor.visitInvokeMethodExpr(this, context);
|
return visitor.visitInvokeMethodExpr(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -463,16 +463,16 @@ export class InvokeFunctionExpr extends Expression {
|
||||||
super(type, sourceSpan);
|
super(type, sourceSpan);
|
||||||
}
|
}
|
||||||
|
|
||||||
isEquivalent(e: Expression): boolean {
|
override isEquivalent(e: Expression): boolean {
|
||||||
return e instanceof InvokeFunctionExpr && this.fn.isEquivalent(e.fn) &&
|
return e instanceof InvokeFunctionExpr && this.fn.isEquivalent(e.fn) &&
|
||||||
areAllEquivalent(this.args, e.args) && this.pure === e.pure;
|
areAllEquivalent(this.args, e.args) && this.pure === e.pure;
|
||||||
}
|
}
|
||||||
|
|
||||||
isConstant() {
|
override isConstant() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
visitExpression(visitor: ExpressionVisitor, context: any): any {
|
override visitExpression(visitor: ExpressionVisitor, context: any): any {
|
||||||
return visitor.visitInvokeFunctionExpr(this, context);
|
return visitor.visitInvokeFunctionExpr(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -485,18 +485,18 @@ export class TaggedTemplateExpr extends Expression {
|
||||||
super(type, sourceSpan);
|
super(type, sourceSpan);
|
||||||
}
|
}
|
||||||
|
|
||||||
isEquivalent(e: Expression): boolean {
|
override isEquivalent(e: Expression): boolean {
|
||||||
return e instanceof TaggedTemplateExpr && this.tag.isEquivalent(e.tag) &&
|
return e instanceof TaggedTemplateExpr && this.tag.isEquivalent(e.tag) &&
|
||||||
areAllEquivalentPredicate(
|
areAllEquivalentPredicate(
|
||||||
this.template.elements, e.template.elements, (a, b) => a.text === b.text) &&
|
this.template.elements, e.template.elements, (a, b) => a.text === b.text) &&
|
||||||
areAllEquivalent(this.template.expressions, e.template.expressions);
|
areAllEquivalent(this.template.expressions, e.template.expressions);
|
||||||
}
|
}
|
||||||
|
|
||||||
isConstant() {
|
override isConstant() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
visitExpression(visitor: ExpressionVisitor, context: any): any {
|
override visitExpression(visitor: ExpressionVisitor, context: any): any {
|
||||||
return visitor.visitTaggedTemplateExpr(this, context);
|
return visitor.visitTaggedTemplateExpr(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -509,16 +509,16 @@ export class InstantiateExpr extends Expression {
|
||||||
super(type, sourceSpan);
|
super(type, sourceSpan);
|
||||||
}
|
}
|
||||||
|
|
||||||
isEquivalent(e: Expression): boolean {
|
override isEquivalent(e: Expression): boolean {
|
||||||
return e instanceof InstantiateExpr && this.classExpr.isEquivalent(e.classExpr) &&
|
return e instanceof InstantiateExpr && this.classExpr.isEquivalent(e.classExpr) &&
|
||||||
areAllEquivalent(this.args, e.args);
|
areAllEquivalent(this.args, e.args);
|
||||||
}
|
}
|
||||||
|
|
||||||
isConstant() {
|
override isConstant() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
visitExpression(visitor: ExpressionVisitor, context: any): any {
|
override visitExpression(visitor: ExpressionVisitor, context: any): any {
|
||||||
return visitor.visitInstantiateExpr(this, context);
|
return visitor.visitInstantiateExpr(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -531,15 +531,15 @@ export class LiteralExpr extends Expression {
|
||||||
super(type, sourceSpan);
|
super(type, sourceSpan);
|
||||||
}
|
}
|
||||||
|
|
||||||
isEquivalent(e: Expression): boolean {
|
override isEquivalent(e: Expression): boolean {
|
||||||
return e instanceof LiteralExpr && this.value === e.value;
|
return e instanceof LiteralExpr && this.value === e.value;
|
||||||
}
|
}
|
||||||
|
|
||||||
isConstant() {
|
override isConstant() {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
visitExpression(visitor: ExpressionVisitor, context: any): any {
|
override visitExpression(visitor: ExpressionVisitor, context: any): any {
|
||||||
return visitor.visitLiteralExpr(this, context);
|
return visitor.visitLiteralExpr(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -575,16 +575,16 @@ export class LocalizedString extends Expression {
|
||||||
super(STRING_TYPE, sourceSpan);
|
super(STRING_TYPE, sourceSpan);
|
||||||
}
|
}
|
||||||
|
|
||||||
isEquivalent(e: Expression): boolean {
|
override isEquivalent(e: Expression): boolean {
|
||||||
// return e instanceof LocalizedString && this.message === e.message;
|
// return e instanceof LocalizedString && this.message === e.message;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
isConstant() {
|
override isConstant() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
visitExpression(visitor: ExpressionVisitor, context: any): any {
|
override visitExpression(visitor: ExpressionVisitor, context: any): any {
|
||||||
return visitor.visitLocalizedString(this, context);
|
return visitor.visitLocalizedString(this, context);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -696,16 +696,16 @@ export class ExternalExpr extends Expression {
|
||||||
super(type, sourceSpan);
|
super(type, sourceSpan);
|
||||||
}
|
}
|
||||||
|
|
||||||
isEquivalent(e: Expression): boolean {
|
override isEquivalent(e: Expression): boolean {
|
||||||
return e instanceof ExternalExpr && this.value.name === e.value.name &&
|
return e instanceof ExternalExpr && this.value.name === e.value.name &&
|
||||||
this.value.moduleName === e.value.moduleName && this.value.runtime === e.value.runtime;
|
this.value.moduleName === e.value.moduleName && this.value.runtime === e.value.runtime;
|
||||||
}
|
}
|
||||||
|
|
||||||
isConstant() {
|
override isConstant() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
visitExpression(visitor: ExpressionVisitor, context: any): any {
|
override visitExpression(visitor: ExpressionVisitor, context: any): any {
|
||||||
return visitor.visitExternalExpr(this, context);
|
return visitor.visitExternalExpr(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -726,16 +726,16 @@ export class ConditionalExpr extends Expression {
|
||||||
this.trueCase = trueCase;
|
this.trueCase = trueCase;
|
||||||
}
|
}
|
||||||
|
|
||||||
isEquivalent(e: Expression): boolean {
|
override isEquivalent(e: Expression): boolean {
|
||||||
return e instanceof ConditionalExpr && this.condition.isEquivalent(e.condition) &&
|
return e instanceof ConditionalExpr && this.condition.isEquivalent(e.condition) &&
|
||||||
this.trueCase.isEquivalent(e.trueCase) && nullSafeIsEquivalent(this.falseCase, e.falseCase);
|
this.trueCase.isEquivalent(e.trueCase) && nullSafeIsEquivalent(this.falseCase, e.falseCase);
|
||||||
}
|
}
|
||||||
|
|
||||||
isConstant() {
|
override isConstant() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
visitExpression(visitor: ExpressionVisitor, context: any): any {
|
override visitExpression(visitor: ExpressionVisitor, context: any): any {
|
||||||
return visitor.visitConditionalExpr(this, context);
|
return visitor.visitConditionalExpr(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -746,15 +746,15 @@ export class NotExpr extends Expression {
|
||||||
super(BOOL_TYPE, sourceSpan);
|
super(BOOL_TYPE, sourceSpan);
|
||||||
}
|
}
|
||||||
|
|
||||||
isEquivalent(e: Expression): boolean {
|
override isEquivalent(e: Expression): boolean {
|
||||||
return e instanceof NotExpr && this.condition.isEquivalent(e.condition);
|
return e instanceof NotExpr && this.condition.isEquivalent(e.condition);
|
||||||
}
|
}
|
||||||
|
|
||||||
isConstant() {
|
override isConstant() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
visitExpression(visitor: ExpressionVisitor, context: any): any {
|
override visitExpression(visitor: ExpressionVisitor, context: any): any {
|
||||||
return visitor.visitNotExpr(this, context);
|
return visitor.visitNotExpr(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -764,15 +764,15 @@ export class AssertNotNull extends Expression {
|
||||||
super(condition.type, sourceSpan);
|
super(condition.type, sourceSpan);
|
||||||
}
|
}
|
||||||
|
|
||||||
isEquivalent(e: Expression): boolean {
|
override isEquivalent(e: Expression): boolean {
|
||||||
return e instanceof AssertNotNull && this.condition.isEquivalent(e.condition);
|
return e instanceof AssertNotNull && this.condition.isEquivalent(e.condition);
|
||||||
}
|
}
|
||||||
|
|
||||||
isConstant() {
|
override isConstant() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
visitExpression(visitor: ExpressionVisitor, context: any): any {
|
override visitExpression(visitor: ExpressionVisitor, context: any): any {
|
||||||
return visitor.visitAssertNotNullExpr(this, context);
|
return visitor.visitAssertNotNullExpr(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -782,15 +782,15 @@ export class CastExpr extends Expression {
|
||||||
super(type, sourceSpan);
|
super(type, sourceSpan);
|
||||||
}
|
}
|
||||||
|
|
||||||
isEquivalent(e: Expression): boolean {
|
override isEquivalent(e: Expression): boolean {
|
||||||
return e instanceof CastExpr && this.value.isEquivalent(e.value);
|
return e instanceof CastExpr && this.value.isEquivalent(e.value);
|
||||||
}
|
}
|
||||||
|
|
||||||
isConstant() {
|
override isConstant() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
visitExpression(visitor: ExpressionVisitor, context: any): any {
|
override visitExpression(visitor: ExpressionVisitor, context: any): any {
|
||||||
return visitor.visitCastExpr(this, context);
|
return visitor.visitCastExpr(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -812,16 +812,16 @@ export class FunctionExpr extends Expression {
|
||||||
super(type, sourceSpan);
|
super(type, sourceSpan);
|
||||||
}
|
}
|
||||||
|
|
||||||
isEquivalent(e: Expression): boolean {
|
override isEquivalent(e: Expression): boolean {
|
||||||
return e instanceof FunctionExpr && areAllEquivalent(this.params, e.params) &&
|
return e instanceof FunctionExpr && areAllEquivalent(this.params, e.params) &&
|
||||||
areAllEquivalent(this.statements, e.statements);
|
areAllEquivalent(this.statements, e.statements);
|
||||||
}
|
}
|
||||||
|
|
||||||
isConstant() {
|
override isConstant() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
visitExpression(visitor: ExpressionVisitor, context: any): any {
|
override visitExpression(visitor: ExpressionVisitor, context: any): any {
|
||||||
return visitor.visitFunctionExpr(this, context);
|
return visitor.visitFunctionExpr(this, context);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -839,16 +839,16 @@ export class UnaryOperatorExpr extends Expression {
|
||||||
super(type || NUMBER_TYPE, sourceSpan);
|
super(type || NUMBER_TYPE, sourceSpan);
|
||||||
}
|
}
|
||||||
|
|
||||||
isEquivalent(e: Expression): boolean {
|
override isEquivalent(e: Expression): boolean {
|
||||||
return e instanceof UnaryOperatorExpr && this.operator === e.operator &&
|
return e instanceof UnaryOperatorExpr && this.operator === e.operator &&
|
||||||
this.expr.isEquivalent(e.expr);
|
this.expr.isEquivalent(e.expr);
|
||||||
}
|
}
|
||||||
|
|
||||||
isConstant() {
|
override isConstant() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
visitExpression(visitor: ExpressionVisitor, context: any): any {
|
override visitExpression(visitor: ExpressionVisitor, context: any): any {
|
||||||
return visitor.visitUnaryOperatorExpr(this, context);
|
return visitor.visitUnaryOperatorExpr(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -863,16 +863,16 @@ export class BinaryOperatorExpr extends Expression {
|
||||||
this.lhs = lhs;
|
this.lhs = lhs;
|
||||||
}
|
}
|
||||||
|
|
||||||
isEquivalent(e: Expression): boolean {
|
override isEquivalent(e: Expression): boolean {
|
||||||
return e instanceof BinaryOperatorExpr && this.operator === e.operator &&
|
return e instanceof BinaryOperatorExpr && this.operator === e.operator &&
|
||||||
this.lhs.isEquivalent(e.lhs) && this.rhs.isEquivalent(e.rhs);
|
this.lhs.isEquivalent(e.lhs) && this.rhs.isEquivalent(e.rhs);
|
||||||
}
|
}
|
||||||
|
|
||||||
isConstant() {
|
override isConstant() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
visitExpression(visitor: ExpressionVisitor, context: any): any {
|
override visitExpression(visitor: ExpressionVisitor, context: any): any {
|
||||||
return visitor.visitBinaryOperatorExpr(this, context);
|
return visitor.visitBinaryOperatorExpr(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -885,16 +885,16 @@ export class ReadPropExpr extends Expression {
|
||||||
super(type, sourceSpan);
|
super(type, sourceSpan);
|
||||||
}
|
}
|
||||||
|
|
||||||
isEquivalent(e: Expression): boolean {
|
override isEquivalent(e: Expression): boolean {
|
||||||
return e instanceof ReadPropExpr && this.receiver.isEquivalent(e.receiver) &&
|
return e instanceof ReadPropExpr && this.receiver.isEquivalent(e.receiver) &&
|
||||||
this.name === e.name;
|
this.name === e.name;
|
||||||
}
|
}
|
||||||
|
|
||||||
isConstant() {
|
override isConstant() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
visitExpression(visitor: ExpressionVisitor, context: any): any {
|
override visitExpression(visitor: ExpressionVisitor, context: any): any {
|
||||||
return visitor.visitReadPropExpr(this, context);
|
return visitor.visitReadPropExpr(this, context);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -911,16 +911,16 @@ export class ReadKeyExpr extends Expression {
|
||||||
super(type, sourceSpan);
|
super(type, sourceSpan);
|
||||||
}
|
}
|
||||||
|
|
||||||
isEquivalent(e: Expression): boolean {
|
override isEquivalent(e: Expression): boolean {
|
||||||
return e instanceof ReadKeyExpr && this.receiver.isEquivalent(e.receiver) &&
|
return e instanceof ReadKeyExpr && this.receiver.isEquivalent(e.receiver) &&
|
||||||
this.index.isEquivalent(e.index);
|
this.index.isEquivalent(e.index);
|
||||||
}
|
}
|
||||||
|
|
||||||
isConstant() {
|
override isConstant() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
visitExpression(visitor: ExpressionVisitor, context: any): any {
|
override visitExpression(visitor: ExpressionVisitor, context: any): any {
|
||||||
return visitor.visitReadKeyExpr(this, context);
|
return visitor.visitReadKeyExpr(this, context);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -937,14 +937,14 @@ export class LiteralArrayExpr extends Expression {
|
||||||
this.entries = entries;
|
this.entries = entries;
|
||||||
}
|
}
|
||||||
|
|
||||||
isConstant() {
|
override isConstant() {
|
||||||
return this.entries.every(e => e.isConstant());
|
return this.entries.every(e => e.isConstant());
|
||||||
}
|
}
|
||||||
|
|
||||||
isEquivalent(e: Expression): boolean {
|
override isEquivalent(e: Expression): boolean {
|
||||||
return e instanceof LiteralArrayExpr && areAllEquivalent(this.entries, e.entries);
|
return e instanceof LiteralArrayExpr && areAllEquivalent(this.entries, e.entries);
|
||||||
}
|
}
|
||||||
visitExpression(visitor: ExpressionVisitor, context: any): any {
|
override visitExpression(visitor: ExpressionVisitor, context: any): any {
|
||||||
return visitor.visitLiteralArrayExpr(this, context);
|
return visitor.visitLiteralArrayExpr(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -966,15 +966,15 @@ export class LiteralMapExpr extends Expression {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
isEquivalent(e: Expression): boolean {
|
override isEquivalent(e: Expression): boolean {
|
||||||
return e instanceof LiteralMapExpr && areAllEquivalent(this.entries, e.entries);
|
return e instanceof LiteralMapExpr && areAllEquivalent(this.entries, e.entries);
|
||||||
}
|
}
|
||||||
|
|
||||||
isConstant() {
|
override isConstant() {
|
||||||
return this.entries.every(e => e.value.isConstant());
|
return this.entries.every(e => e.value.isConstant());
|
||||||
}
|
}
|
||||||
|
|
||||||
visitExpression(visitor: ExpressionVisitor, context: any): any {
|
override visitExpression(visitor: ExpressionVisitor, context: any): any {
|
||||||
return visitor.visitLiteralMapExpr(this, context);
|
return visitor.visitLiteralMapExpr(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -984,15 +984,15 @@ export class CommaExpr extends Expression {
|
||||||
super(parts[parts.length - 1].type, sourceSpan);
|
super(parts[parts.length - 1].type, sourceSpan);
|
||||||
}
|
}
|
||||||
|
|
||||||
isEquivalent(e: Expression): boolean {
|
override isEquivalent(e: Expression): boolean {
|
||||||
return e instanceof CommaExpr && areAllEquivalent(this.parts, e.parts);
|
return e instanceof CommaExpr && areAllEquivalent(this.parts, e.parts);
|
||||||
}
|
}
|
||||||
|
|
||||||
isConstant() {
|
override isConstant() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
visitExpression(visitor: ExpressionVisitor, context: any): any {
|
override visitExpression(visitor: ExpressionVisitor, context: any): any {
|
||||||
return visitor.visitCommaExpr(this, context);
|
return visitor.visitCommaExpr(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1086,11 +1086,11 @@ export class DeclareVarStmt extends Statement {
|
||||||
super(modifiers, sourceSpan, leadingComments);
|
super(modifiers, sourceSpan, leadingComments);
|
||||||
this.type = type || (value && value.type) || null;
|
this.type = type || (value && value.type) || null;
|
||||||
}
|
}
|
||||||
isEquivalent(stmt: Statement): boolean {
|
override isEquivalent(stmt: Statement): boolean {
|
||||||
return stmt instanceof DeclareVarStmt && this.name === stmt.name &&
|
return stmt instanceof DeclareVarStmt && this.name === stmt.name &&
|
||||||
(this.value ? !!stmt.value && this.value.isEquivalent(stmt.value) : !stmt.value);
|
(this.value ? !!stmt.value && this.value.isEquivalent(stmt.value) : !stmt.value);
|
||||||
}
|
}
|
||||||
visitStatement(visitor: StatementVisitor, context: any): any {
|
override visitStatement(visitor: StatementVisitor, context: any): any {
|
||||||
return visitor.visitDeclareVarStmt(this, context);
|
return visitor.visitDeclareVarStmt(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1104,11 +1104,11 @@ export class DeclareFunctionStmt extends Statement {
|
||||||
super(modifiers, sourceSpan, leadingComments);
|
super(modifiers, sourceSpan, leadingComments);
|
||||||
this.type = type || null;
|
this.type = type || null;
|
||||||
}
|
}
|
||||||
isEquivalent(stmt: Statement): boolean {
|
override isEquivalent(stmt: Statement): boolean {
|
||||||
return stmt instanceof DeclareFunctionStmt && areAllEquivalent(this.params, stmt.params) &&
|
return stmt instanceof DeclareFunctionStmt && areAllEquivalent(this.params, stmt.params) &&
|
||||||
areAllEquivalent(this.statements, stmt.statements);
|
areAllEquivalent(this.statements, stmt.statements);
|
||||||
}
|
}
|
||||||
visitStatement(visitor: StatementVisitor, context: any): any {
|
override visitStatement(visitor: StatementVisitor, context: any): any {
|
||||||
return visitor.visitDeclareFunctionStmt(this, context);
|
return visitor.visitDeclareFunctionStmt(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1119,10 +1119,10 @@ export class ExpressionStatement extends Statement {
|
||||||
leadingComments?: LeadingComment[]) {
|
leadingComments?: LeadingComment[]) {
|
||||||
super([], sourceSpan, leadingComments);
|
super([], sourceSpan, leadingComments);
|
||||||
}
|
}
|
||||||
isEquivalent(stmt: Statement): boolean {
|
override isEquivalent(stmt: Statement): boolean {
|
||||||
return stmt instanceof ExpressionStatement && this.expr.isEquivalent(stmt.expr);
|
return stmt instanceof ExpressionStatement && this.expr.isEquivalent(stmt.expr);
|
||||||
}
|
}
|
||||||
visitStatement(visitor: StatementVisitor, context: any): any {
|
override visitStatement(visitor: StatementVisitor, context: any): any {
|
||||||
return visitor.visitExpressionStmt(this, context);
|
return visitor.visitExpressionStmt(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1134,10 +1134,10 @@ export class ReturnStatement extends Statement {
|
||||||
leadingComments?: LeadingComment[]) {
|
leadingComments?: LeadingComment[]) {
|
||||||
super([], sourceSpan, leadingComments);
|
super([], sourceSpan, leadingComments);
|
||||||
}
|
}
|
||||||
isEquivalent(stmt: Statement): boolean {
|
override isEquivalent(stmt: Statement): boolean {
|
||||||
return stmt instanceof ReturnStatement && this.value.isEquivalent(stmt.value);
|
return stmt instanceof ReturnStatement && this.value.isEquivalent(stmt.value);
|
||||||
}
|
}
|
||||||
visitStatement(visitor: StatementVisitor, context: any): any {
|
override visitStatement(visitor: StatementVisitor, context: any): any {
|
||||||
return visitor.visitReturnStmt(this, context);
|
return visitor.visitReturnStmt(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1192,7 +1192,7 @@ export class ClassStmt extends Statement {
|
||||||
leadingComments?: LeadingComment[]) {
|
leadingComments?: LeadingComment[]) {
|
||||||
super(modifiers, sourceSpan, leadingComments);
|
super(modifiers, sourceSpan, leadingComments);
|
||||||
}
|
}
|
||||||
isEquivalent(stmt: Statement): boolean {
|
override isEquivalent(stmt: Statement): boolean {
|
||||||
return stmt instanceof ClassStmt && this.name === stmt.name &&
|
return stmt instanceof ClassStmt && this.name === stmt.name &&
|
||||||
nullSafeIsEquivalent(this.parent, stmt.parent) &&
|
nullSafeIsEquivalent(this.parent, stmt.parent) &&
|
||||||
areAllEquivalent(this.fields, stmt.fields) &&
|
areAllEquivalent(this.fields, stmt.fields) &&
|
||||||
|
@ -1200,7 +1200,7 @@ export class ClassStmt extends Statement {
|
||||||
this.constructorMethod.isEquivalent(stmt.constructorMethod) &&
|
this.constructorMethod.isEquivalent(stmt.constructorMethod) &&
|
||||||
areAllEquivalent(this.methods, stmt.methods);
|
areAllEquivalent(this.methods, stmt.methods);
|
||||||
}
|
}
|
||||||
visitStatement(visitor: StatementVisitor, context: any): any {
|
override visitStatement(visitor: StatementVisitor, context: any): any {
|
||||||
return visitor.visitDeclareClassStmt(this, context);
|
return visitor.visitDeclareClassStmt(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1213,12 +1213,12 @@ export class IfStmt extends Statement {
|
||||||
leadingComments?: LeadingComment[]) {
|
leadingComments?: LeadingComment[]) {
|
||||||
super([], sourceSpan, leadingComments);
|
super([], sourceSpan, leadingComments);
|
||||||
}
|
}
|
||||||
isEquivalent(stmt: Statement): boolean {
|
override isEquivalent(stmt: Statement): boolean {
|
||||||
return stmt instanceof IfStmt && this.condition.isEquivalent(stmt.condition) &&
|
return stmt instanceof IfStmt && this.condition.isEquivalent(stmt.condition) &&
|
||||||
areAllEquivalent(this.trueCase, stmt.trueCase) &&
|
areAllEquivalent(this.trueCase, stmt.trueCase) &&
|
||||||
areAllEquivalent(this.falseCase, stmt.falseCase);
|
areAllEquivalent(this.falseCase, stmt.falseCase);
|
||||||
}
|
}
|
||||||
visitStatement(visitor: StatementVisitor, context: any): any {
|
override visitStatement(visitor: StatementVisitor, context: any): any {
|
||||||
return visitor.visitIfStmt(this, context);
|
return visitor.visitIfStmt(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1229,11 +1229,11 @@ export class TryCatchStmt extends Statement {
|
||||||
sourceSpan: ParseSourceSpan|null = null, leadingComments?: LeadingComment[]) {
|
sourceSpan: ParseSourceSpan|null = null, leadingComments?: LeadingComment[]) {
|
||||||
super([], sourceSpan, leadingComments);
|
super([], sourceSpan, leadingComments);
|
||||||
}
|
}
|
||||||
isEquivalent(stmt: Statement): boolean {
|
override isEquivalent(stmt: Statement): boolean {
|
||||||
return stmt instanceof TryCatchStmt && areAllEquivalent(this.bodyStmts, stmt.bodyStmts) &&
|
return stmt instanceof TryCatchStmt && areAllEquivalent(this.bodyStmts, stmt.bodyStmts) &&
|
||||||
areAllEquivalent(this.catchStmts, stmt.catchStmts);
|
areAllEquivalent(this.catchStmts, stmt.catchStmts);
|
||||||
}
|
}
|
||||||
visitStatement(visitor: StatementVisitor, context: any): any {
|
override visitStatement(visitor: StatementVisitor, context: any): any {
|
||||||
return visitor.visitTryCatchStmt(this, context);
|
return visitor.visitTryCatchStmt(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1245,10 +1245,10 @@ export class ThrowStmt extends Statement {
|
||||||
leadingComments?: LeadingComment[]) {
|
leadingComments?: LeadingComment[]) {
|
||||||
super([], sourceSpan, leadingComments);
|
super([], sourceSpan, leadingComments);
|
||||||
}
|
}
|
||||||
isEquivalent(stmt: ThrowStmt): boolean {
|
override isEquivalent(stmt: ThrowStmt): boolean {
|
||||||
return stmt instanceof TryCatchStmt && this.error.isEquivalent(stmt.error);
|
return stmt instanceof TryCatchStmt && this.error.isEquivalent(stmt.error);
|
||||||
}
|
}
|
||||||
visitStatement(visitor: StatementVisitor, context: any): any {
|
override visitStatement(visitor: StatementVisitor, context: any): any {
|
||||||
return visitor.visitThrowStmt(this, context);
|
return visitor.visitThrowStmt(this, context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -119,7 +119,7 @@ export class JitEmitterVisitor extends AbstractJsEmitterVisitor {
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
visitExternalExpr(ast: o.ExternalExpr, ctx: EmitterVisitorContext): any {
|
override visitExternalExpr(ast: o.ExternalExpr, ctx: EmitterVisitorContext): any {
|
||||||
this._emitReferenceToExternal(ast, this.reflector.resolveExternalReference(ast.value), ctx);
|
this._emitReferenceToExternal(ast, this.reflector.resolveExternalReference(ast.value), ctx);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
|
@ -118,7 +118,7 @@ class _TsEmitterVisitor extends AbstractEmitterVisitor implements o.TypeVisitor
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
visitExternalExpr(ast: o.ExternalExpr, ctx: EmitterVisitorContext): any {
|
override visitExternalExpr(ast: o.ExternalExpr, ctx: EmitterVisitorContext): any {
|
||||||
this._visitIdentifier(ast.value, ast.typeParams, ctx);
|
this._visitIdentifier(ast.value, ast.typeParams, ctx);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@ -129,7 +129,7 @@ class _TsEmitterVisitor extends AbstractEmitterVisitor implements o.TypeVisitor
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
visitDeclareVarStmt(stmt: o.DeclareVarStmt, ctx: EmitterVisitorContext): any {
|
override visitDeclareVarStmt(stmt: o.DeclareVarStmt, ctx: EmitterVisitorContext): any {
|
||||||
if (stmt.hasModifier(o.StmtModifier.Exported) && stmt.value instanceof o.ExternalExpr &&
|
if (stmt.hasModifier(o.StmtModifier.Exported) && stmt.value instanceof o.ExternalExpr &&
|
||||||
!stmt.type) {
|
!stmt.type) {
|
||||||
// check for a reexport
|
// check for a reexport
|
||||||
|
@ -166,7 +166,7 @@ class _TsEmitterVisitor extends AbstractEmitterVisitor implements o.TypeVisitor
|
||||||
throw new Error('Cannot visit a WrappedNodeExpr when outputting Typescript.');
|
throw new Error('Cannot visit a WrappedNodeExpr when outputting Typescript.');
|
||||||
}
|
}
|
||||||
|
|
||||||
visitCastExpr(ast: o.CastExpr, ctx: EmitterVisitorContext): any {
|
override visitCastExpr(ast: o.CastExpr, ctx: EmitterVisitorContext): any {
|
||||||
ctx.print(ast, `(<`);
|
ctx.print(ast, `(<`);
|
||||||
ast.type!.visitType(this, ctx);
|
ast.type!.visitType(this, ctx);
|
||||||
ctx.print(ast, `>`);
|
ctx.print(ast, `>`);
|
||||||
|
@ -186,7 +186,7 @@ class _TsEmitterVisitor extends AbstractEmitterVisitor implements o.TypeVisitor
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
visitDeclareClassStmt(stmt: o.ClassStmt, ctx: EmitterVisitorContext): any {
|
override visitDeclareClassStmt(stmt: o.ClassStmt, ctx: EmitterVisitorContext): any {
|
||||||
ctx.pushClass(stmt);
|
ctx.pushClass(stmt);
|
||||||
if (stmt.hasModifier(o.StmtModifier.Exported)) {
|
if (stmt.hasModifier(o.StmtModifier.Exported)) {
|
||||||
ctx.print(stmt, `export `);
|
ctx.print(stmt, `export `);
|
||||||
|
@ -267,7 +267,7 @@ class _TsEmitterVisitor extends AbstractEmitterVisitor implements o.TypeVisitor
|
||||||
ctx.println(null, `}`);
|
ctx.println(null, `}`);
|
||||||
}
|
}
|
||||||
|
|
||||||
visitFunctionExpr(ast: o.FunctionExpr, ctx: EmitterVisitorContext): any {
|
override visitFunctionExpr(ast: o.FunctionExpr, ctx: EmitterVisitorContext): any {
|
||||||
if (ast.name) {
|
if (ast.name) {
|
||||||
ctx.print(ast, 'function ');
|
ctx.print(ast, 'function ');
|
||||||
ctx.print(ast, ast.name);
|
ctx.print(ast, ast.name);
|
||||||
|
@ -288,7 +288,7 @@ class _TsEmitterVisitor extends AbstractEmitterVisitor implements o.TypeVisitor
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
visitDeclareFunctionStmt(stmt: o.DeclareFunctionStmt, ctx: EmitterVisitorContext): any {
|
override visitDeclareFunctionStmt(stmt: o.DeclareFunctionStmt, ctx: EmitterVisitorContext): any {
|
||||||
if (stmt.hasModifier(o.StmtModifier.Exported)) {
|
if (stmt.hasModifier(o.StmtModifier.Exported)) {
|
||||||
ctx.print(stmt, `export `);
|
ctx.print(stmt, `export `);
|
||||||
}
|
}
|
||||||
|
@ -304,7 +304,7 @@ class _TsEmitterVisitor extends AbstractEmitterVisitor implements o.TypeVisitor
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
visitTryCatchStmt(stmt: o.TryCatchStmt, ctx: EmitterVisitorContext): any {
|
override visitTryCatchStmt(stmt: o.TryCatchStmt, ctx: EmitterVisitorContext): any {
|
||||||
ctx.println(stmt, `try {`);
|
ctx.println(stmt, `try {`);
|
||||||
ctx.incIndent();
|
ctx.incIndent();
|
||||||
this.visitAllStatements(stmt.bodyStmts, ctx);
|
this.visitAllStatements(stmt.bodyStmts, ctx);
|
||||||
|
@ -375,7 +375,7 @@ class _TsEmitterVisitor extends AbstractEmitterVisitor implements o.TypeVisitor
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
getBuiltinMethodName(method: o.BuiltinMethod): string {
|
override getBuiltinMethodName(method: o.BuiltinMethod): string {
|
||||||
let name: string;
|
let name: string;
|
||||||
switch (method) {
|
switch (method) {
|
||||||
case o.BuiltinMethod.ConcatArray:
|
case o.BuiltinMethod.ConcatArray:
|
||||||
|
|
|
@ -291,7 +291,7 @@ export class DomElementSchemaRegistry extends ElementSchemaRegistry {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
hasProperty(tagName: string, propName: string, schemaMetas: SchemaMetadata[]): boolean {
|
override hasProperty(tagName: string, propName: string, schemaMetas: SchemaMetadata[]): boolean {
|
||||||
if (schemaMetas.some((schema) => schema.name === NO_ERRORS_SCHEMA.name)) {
|
if (schemaMetas.some((schema) => schema.name === NO_ERRORS_SCHEMA.name)) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -312,7 +312,7 @@ export class DomElementSchemaRegistry extends ElementSchemaRegistry {
|
||||||
return !!elementProperties[propName];
|
return !!elementProperties[propName];
|
||||||
}
|
}
|
||||||
|
|
||||||
hasElement(tagName: string, schemaMetas: SchemaMetadata[]): boolean {
|
override hasElement(tagName: string, schemaMetas: SchemaMetadata[]): boolean {
|
||||||
if (schemaMetas.some((schema) => schema.name === NO_ERRORS_SCHEMA.name)) {
|
if (schemaMetas.some((schema) => schema.name === NO_ERRORS_SCHEMA.name)) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -341,7 +341,8 @@ export class DomElementSchemaRegistry extends ElementSchemaRegistry {
|
||||||
* above are assumed to have the 'NONE' security context, i.e. that they are safe inert
|
* above are assumed to have the 'NONE' security context, i.e. that they are safe inert
|
||||||
* string values. Only specific well known attack vectors are assigned their appropriate context.
|
* string values. Only specific well known attack vectors are assigned their appropriate context.
|
||||||
*/
|
*/
|
||||||
securityContext(tagName: string, propName: string, isAttribute: boolean): SecurityContext {
|
override securityContext(tagName: string, propName: string, isAttribute: boolean):
|
||||||
|
SecurityContext {
|
||||||
if (isAttribute) {
|
if (isAttribute) {
|
||||||
// NB: For security purposes, use the mapped property name, not the attribute name.
|
// NB: For security purposes, use the mapped property name, not the attribute name.
|
||||||
propName = this.getMappedPropName(propName);
|
propName = this.getMappedPropName(propName);
|
||||||
|
@ -359,15 +360,15 @@ export class DomElementSchemaRegistry extends ElementSchemaRegistry {
|
||||||
return ctx ? ctx : SecurityContext.NONE;
|
return ctx ? ctx : SecurityContext.NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
getMappedPropName(propName: string): string {
|
override getMappedPropName(propName: string): string {
|
||||||
return _ATTR_TO_PROP[propName] || propName;
|
return _ATTR_TO_PROP[propName] || propName;
|
||||||
}
|
}
|
||||||
|
|
||||||
getDefaultComponentElementName(): string {
|
override getDefaultComponentElementName(): string {
|
||||||
return 'ng-component';
|
return 'ng-component';
|
||||||
}
|
}
|
||||||
|
|
||||||
validateProperty(name: string): {error: boolean, msg?: string} {
|
override validateProperty(name: string): {error: boolean, msg?: string} {
|
||||||
if (name.toLowerCase().startsWith('on')) {
|
if (name.toLowerCase().startsWith('on')) {
|
||||||
const msg = `Binding to event property '${name}' is disallowed for security reasons, ` +
|
const msg = `Binding to event property '${name}' is disallowed for security reasons, ` +
|
||||||
`please use (${name.slice(2)})=...` +
|
`please use (${name.slice(2)})=...` +
|
||||||
|
@ -379,7 +380,7 @@ export class DomElementSchemaRegistry extends ElementSchemaRegistry {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
validateAttribute(name: string): {error: boolean, msg?: string} {
|
override validateAttribute(name: string): {error: boolean, msg?: string} {
|
||||||
if (name.toLowerCase().startsWith('on')) {
|
if (name.toLowerCase().startsWith('on')) {
|
||||||
const msg = `Binding to event attribute '${name}' is disallowed for security reasons, ` +
|
const msg = `Binding to event attribute '${name}' is disallowed for security reasons, ` +
|
||||||
`please use (${name.slice(2)})=...`;
|
`please use (${name.slice(2)})=...`;
|
||||||
|
@ -389,7 +390,7 @@ export class DomElementSchemaRegistry extends ElementSchemaRegistry {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
allKnownElementNames(): string[] {
|
override allKnownElementNames(): string[] {
|
||||||
return Object.keys(this._schema);
|
return Object.keys(this._schema);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -399,12 +400,13 @@ export class DomElementSchemaRegistry extends ElementSchemaRegistry {
|
||||||
return Object.keys(elementProperties).map(prop => _PROP_TO_ATTR[prop] ?? prop);
|
return Object.keys(elementProperties).map(prop => _PROP_TO_ATTR[prop] ?? prop);
|
||||||
}
|
}
|
||||||
|
|
||||||
normalizeAnimationStyleProperty(propName: string): string {
|
override normalizeAnimationStyleProperty(propName: string): string {
|
||||||
return dashCaseToCamelCase(propName);
|
return dashCaseToCamelCase(propName);
|
||||||
}
|
}
|
||||||
|
|
||||||
normalizeAnimationStyleValue(camelCaseProp: string, userProvidedProp: string, val: string|number):
|
override normalizeAnimationStyleValue(
|
||||||
{error: string, value: string} {
|
camelCaseProp: string, userProvidedProp: string,
|
||||||
|
val: string|number): {error: string, value: string} {
|
||||||
let unit: string = '';
|
let unit: string = '';
|
||||||
const strVal = val.toString().trim();
|
const strVal = val.toString().trim();
|
||||||
let errorMsg: string = null!;
|
let errorMsg: string = null!;
|
||||||
|
|
|
@ -44,17 +44,17 @@ import {DEFAULT_INTERPOLATION_CONFIG} from '../../src/ml_parser/interpolation_co
|
||||||
}
|
}
|
||||||
|
|
||||||
class _TestSerializer extends Serializer {
|
class _TestSerializer extends Serializer {
|
||||||
write(messages: i18n.Message[]): string {
|
override write(messages: i18n.Message[]): string {
|
||||||
return messages.map(msg => `${serializeNodes(msg.nodes)} (${msg.meaning}|${msg.description})`)
|
return messages.map(msg => `${serializeNodes(msg.nodes)} (${msg.meaning}|${msg.description})`)
|
||||||
.join('//');
|
.join('//');
|
||||||
}
|
}
|
||||||
|
|
||||||
load(content: string, url: string):
|
override load(content: string, url: string):
|
||||||
{locale: string|null, i18nNodesByMsgId: {[id: string]: i18n.Node[]}} {
|
{locale: string|null, i18nNodesByMsgId: {[id: string]: i18n.Node[]}} {
|
||||||
return {locale: null, i18nNodesByMsgId: {}};
|
return {locale: null, i18nNodesByMsgId: {}};
|
||||||
}
|
}
|
||||||
|
|
||||||
digest(msg: i18n.Message): string {
|
override digest(msg: i18n.Message): string {
|
||||||
return msg.id || `default`;
|
return msg.id || `default`;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,7 +17,7 @@ export class MockResourceLoader extends ResourceLoader {
|
||||||
private _definitions = new Map<string, string>();
|
private _definitions = new Map<string, string>();
|
||||||
private _requests: _PendingRequest[] = [];
|
private _requests: _PendingRequest[] = [];
|
||||||
|
|
||||||
get(url: string): Promise<string> {
|
override get(url: string): Promise<string> {
|
||||||
const request = new _PendingRequest(url);
|
const request = new _PendingRequest(url);
|
||||||
this._requests.push(request);
|
this._requests.push(request);
|
||||||
return request.getPromise();
|
return request.getPromise();
|
||||||
|
|
|
@ -12,7 +12,7 @@ import * as ts from 'typescript';
|
||||||
import {findFragmentAccesses, migrateActivatedRouteSnapshotFragment} from '../activated-route-snapshot-fragment/util';
|
import {findFragmentAccesses, migrateActivatedRouteSnapshotFragment} from '../activated-route-snapshot-fragment/util';
|
||||||
|
|
||||||
export class Rule extends Rules.TypedRule {
|
export class Rule extends Rules.TypedRule {
|
||||||
applyWithProgram(sourceFile: ts.SourceFile, program: ts.Program): RuleFailure[] {
|
override applyWithProgram(sourceFile: ts.SourceFile, program: ts.Program): RuleFailure[] {
|
||||||
if (sourceFile.isDeclarationFile || program.isSourceFileFromExternalLibrary(sourceFile)) {
|
if (sourceFile.isDeclarationFile || program.isSourceFileFromExternalLibrary(sourceFile)) {
|
||||||
return [];
|
return [];
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,7 +13,7 @@ import {findLiteralsToMigrate, migrateLiteral} from '../can-activate-with-redire
|
||||||
|
|
||||||
/** TSLint rule that removes canActivate from Route configs that also have redirectTo. */
|
/** TSLint rule that removes canActivate from Route configs that also have redirectTo. */
|
||||||
export class Rule extends Rules.TypedRule {
|
export class Rule extends Rules.TypedRule {
|
||||||
applyWithProgram(sourceFile: ts.SourceFile, program: ts.Program): RuleFailure[] {
|
override applyWithProgram(sourceFile: ts.SourceFile, program: ts.Program): RuleFailure[] {
|
||||||
const failures: RuleFailure[] = [];
|
const failures: RuleFailure[] = [];
|
||||||
const printer = ts.createPrinter();
|
const printer = ts.createPrinter();
|
||||||
const literalsToMigrate = findLiteralsToMigrate(sourceFile);
|
const literalsToMigrate = findLiteralsToMigrate(sourceFile);
|
||||||
|
|
|
@ -19,7 +19,7 @@ const FAILURE_MESSAGE =
|
||||||
* TSLint rule that removes the `static` flag from dynamic queries.
|
* TSLint rule that removes the `static` flag from dynamic queries.
|
||||||
*/
|
*/
|
||||||
export class Rule extends Rules.TypedRule {
|
export class Rule extends Rules.TypedRule {
|
||||||
applyWithProgram(sourceFile: ts.SourceFile, program: ts.Program): RuleFailure[] {
|
override applyWithProgram(sourceFile: ts.SourceFile, program: ts.Program): RuleFailure[] {
|
||||||
const printer = ts.createPrinter();
|
const printer = ts.createPrinter();
|
||||||
const failures: RuleFailure[] = [];
|
const failures: RuleFailure[] = [];
|
||||||
const result = identifyDynamicQueryNodes(program.getTypeChecker(), sourceFile);
|
const result = identifyDynamicQueryNodes(program.getTypeChecker(), sourceFile);
|
||||||
|
|
|
@ -24,7 +24,7 @@ const FAILURE_MESSAGE = 'Query does not explicitly specify its timing. Read more
|
||||||
* be applied in order to automatically migrate to the explicit query timing API.
|
* be applied in order to automatically migrate to the explicit query timing API.
|
||||||
*/
|
*/
|
||||||
export class Rule extends Rules.TypedRule {
|
export class Rule extends Rules.TypedRule {
|
||||||
applyWithProgram(sourceFile: ts.SourceFile, program: ts.Program): RuleFailure[] {
|
override applyWithProgram(sourceFile: ts.SourceFile, program: ts.Program): RuleFailure[] {
|
||||||
const typeChecker = program.getTypeChecker();
|
const typeChecker = program.getTypeChecker();
|
||||||
const queryVisitor = new NgQueryResolveVisitor(program.getTypeChecker());
|
const queryVisitor = new NgQueryResolveVisitor(program.getTypeChecker());
|
||||||
const templateVisitor = new NgComponentTemplateVisitor(typeChecker);
|
const templateVisitor = new NgComponentTemplateVisitor(typeChecker);
|
||||||
|
|
|
@ -19,7 +19,7 @@ import {InitialNavigationTransform} from '../initial-navigation/transform';
|
||||||
* TSLint rule that updates RouterModule `forRoot` options to be in line with v10 updates.
|
* TSLint rule that updates RouterModule `forRoot` options to be in line with v10 updates.
|
||||||
*/
|
*/
|
||||||
export class Rule extends Rules.TypedRule {
|
export class Rule extends Rules.TypedRule {
|
||||||
applyWithProgram(sourceFile: ts.SourceFile, program: ts.Program): RuleFailure[] {
|
override applyWithProgram(sourceFile: ts.SourceFile, program: ts.Program): RuleFailure[] {
|
||||||
const ruleName = this.ruleName;
|
const ruleName = this.ruleName;
|
||||||
const typeChecker = program.getTypeChecker();
|
const typeChecker = program.getTypeChecker();
|
||||||
const sourceFiles = program.getSourceFiles().filter(
|
const sourceFiles = program.getSourceFiles().filter(
|
||||||
|
|
|
@ -13,7 +13,7 @@ import {findLiteralsToMigrate, migrateLiteral} from '../../migrations/navigation
|
||||||
|
|
||||||
/** TSLint rule that migrates `navigateByUrl` and `createUrlTree` calls to an updated signature. */
|
/** TSLint rule that migrates `navigateByUrl` and `createUrlTree` calls to an updated signature. */
|
||||||
export class Rule extends Rules.TypedRule {
|
export class Rule extends Rules.TypedRule {
|
||||||
applyWithProgram(sourceFile: ts.SourceFile, program: ts.Program): RuleFailure[] {
|
override applyWithProgram(sourceFile: ts.SourceFile, program: ts.Program): RuleFailure[] {
|
||||||
const failures: RuleFailure[] = [];
|
const failures: RuleFailure[] = [];
|
||||||
const typeChecker = program.getTypeChecker();
|
const typeChecker = program.getTypeChecker();
|
||||||
const printer = ts.createPrinter();
|
const printer = ts.createPrinter();
|
||||||
|
|
|
@ -21,7 +21,7 @@ import {MissingInjectableTransform} from '../missing-injectable/transform';
|
||||||
* Angular decorator (e.g. "@Injectable").
|
* Angular decorator (e.g. "@Injectable").
|
||||||
*/
|
*/
|
||||||
export class Rule extends Rules.TypedRule {
|
export class Rule extends Rules.TypedRule {
|
||||||
applyWithProgram(sourceFile: ts.SourceFile, program: ts.Program): RuleFailure[] {
|
override applyWithProgram(sourceFile: ts.SourceFile, program: ts.Program): RuleFailure[] {
|
||||||
const ruleName = this.ruleName;
|
const ruleName = this.ruleName;
|
||||||
const typeChecker = program.getTypeChecker();
|
const typeChecker = program.getTypeChecker();
|
||||||
const sourceFiles = program.getSourceFiles().filter(
|
const sourceFiles = program.getSourceFiles().filter(
|
||||||
|
|
|
@ -20,7 +20,7 @@ const FAILURE_MESSAGE = 'Found assignment to template variable. This does not wo
|
||||||
* Rule that reports if an Angular template contains property assignments to template variables.
|
* Rule that reports if an Angular template contains property assignments to template variables.
|
||||||
*/
|
*/
|
||||||
export class Rule extends Rules.TypedRule {
|
export class Rule extends Rules.TypedRule {
|
||||||
applyWithProgram(sourceFile: ts.SourceFile, program: ts.Program): RuleFailure[] {
|
override applyWithProgram(sourceFile: ts.SourceFile, program: ts.Program): RuleFailure[] {
|
||||||
const typeChecker = program.getTypeChecker();
|
const typeChecker = program.getTypeChecker();
|
||||||
const templateVisitor = new NgComponentTemplateVisitor(typeChecker);
|
const templateVisitor = new NgComponentTemplateVisitor(typeChecker);
|
||||||
const failures: RuleFailure[] = [];
|
const failures: RuleFailure[] = [];
|
||||||
|
|
|
@ -14,7 +14,7 @@ import {TslintUpdateRecorder} from '../relative-link-resolution/google3/tslint_u
|
||||||
import {RelativeLinkResolutionTransform} from '../relative-link-resolution/transform';
|
import {RelativeLinkResolutionTransform} from '../relative-link-resolution/transform';
|
||||||
|
|
||||||
export class Rule extends Rules.TypedRule {
|
export class Rule extends Rules.TypedRule {
|
||||||
applyWithProgram(sourceFile: ts.SourceFile, program: ts.Program): RuleFailure[] {
|
override applyWithProgram(sourceFile: ts.SourceFile, program: ts.Program): RuleFailure[] {
|
||||||
const typeChecker = program.getTypeChecker();
|
const typeChecker = program.getTypeChecker();
|
||||||
const ruleName = this.ruleName;
|
const ruleName = this.ruleName;
|
||||||
const sourceFiles = program.getSourceFiles().filter(
|
const sourceFiles = program.getSourceFiles().filter(
|
||||||
|
|
|
@ -20,7 +20,7 @@ import {findRendererReferences} from '../renderer-to-renderer2/util';
|
||||||
* https://hackmd.angular.io/UTzUZTnPRA-cSa_4mHyfYw
|
* https://hackmd.angular.io/UTzUZTnPRA-cSa_4mHyfYw
|
||||||
*/
|
*/
|
||||||
export class Rule extends Rules.TypedRule {
|
export class Rule extends Rules.TypedRule {
|
||||||
applyWithProgram(sourceFile: ts.SourceFile, program: ts.Program): RuleFailure[] {
|
override applyWithProgram(sourceFile: ts.SourceFile, program: ts.Program): RuleFailure[] {
|
||||||
const typeChecker = program.getTypeChecker();
|
const typeChecker = program.getTypeChecker();
|
||||||
const printer = ts.createPrinter();
|
const printer = ts.createPrinter();
|
||||||
const failures: RuleFailure[] = [];
|
const failures: RuleFailure[] = [];
|
||||||
|
|
|
@ -16,7 +16,7 @@ import {UndecoratedClassesWithDecoratedFieldsTransform} from '../undecorated-cla
|
||||||
* https://hackmd.io/vuQfavzfRG6KUCtU7oK_EA
|
* https://hackmd.io/vuQfavzfRG6KUCtU7oK_EA
|
||||||
*/
|
*/
|
||||||
export class Rule extends Rules.TypedRule {
|
export class Rule extends Rules.TypedRule {
|
||||||
applyWithProgram(sourceFile: ts.SourceFile, program: ts.Program): RuleFailure[] {
|
override applyWithProgram(sourceFile: ts.SourceFile, program: ts.Program): RuleFailure[] {
|
||||||
const typeChecker = program.getTypeChecker();
|
const typeChecker = program.getTypeChecker();
|
||||||
const ruleName = this.ruleName;
|
const ruleName = this.ruleName;
|
||||||
const sourceFiles = program.getSourceFiles().filter(
|
const sourceFiles = program.getSourceFiles().filter(
|
||||||
|
|
|
@ -21,7 +21,7 @@ const newFunction = 'waitForAsync';
|
||||||
|
|
||||||
/** TSLint rule that migrates from `async` to `waitForAsync`. */
|
/** TSLint rule that migrates from `async` to `waitForAsync`. */
|
||||||
export class Rule extends Rules.TypedRule {
|
export class Rule extends Rules.TypedRule {
|
||||||
applyWithProgram(sourceFile: ts.SourceFile, program: ts.Program): RuleFailure[] {
|
override applyWithProgram(sourceFile: ts.SourceFile, program: ts.Program): RuleFailure[] {
|
||||||
const failures: RuleFailure[] = [];
|
const failures: RuleFailure[] = [];
|
||||||
const asyncImportSpecifier =
|
const asyncImportSpecifier =
|
||||||
getImportSpecifier(sourceFile, '@angular/core/testing', deprecatedFunction);
|
getImportSpecifier(sourceFile, '@angular/core/testing', deprecatedFunction);
|
||||||
|
|
|
@ -79,11 +79,11 @@ export class CodegenComponentFactoryResolver implements ComponentFactoryResolver
|
||||||
}
|
}
|
||||||
|
|
||||||
export class ComponentFactoryBoundToModule<C> extends ComponentFactory<C> {
|
export class ComponentFactoryBoundToModule<C> extends ComponentFactory<C> {
|
||||||
readonly selector: string;
|
override readonly selector: string;
|
||||||
readonly componentType: Type<any>;
|
override readonly componentType: Type<any>;
|
||||||
readonly ngContentSelectors: string[];
|
override readonly ngContentSelectors: string[];
|
||||||
readonly inputs: {propName: string, templateName: string}[];
|
override readonly inputs: {propName: string, templateName: string}[];
|
||||||
readonly outputs: {propName: string, templateName: string}[];
|
override readonly outputs: {propName: string, templateName: string}[];
|
||||||
|
|
||||||
constructor(private factory: ComponentFactory<C>, private ngModule: NgModuleRef<any>) {
|
constructor(private factory: ComponentFactory<C>, private ngModule: NgModuleRef<any>) {
|
||||||
super();
|
super();
|
||||||
|
@ -94,7 +94,7 @@ export class ComponentFactoryBoundToModule<C> extends ComponentFactory<C> {
|
||||||
this.outputs = factory.outputs;
|
this.outputs = factory.outputs;
|
||||||
}
|
}
|
||||||
|
|
||||||
create(
|
override create(
|
||||||
injector: Injector, projectableNodes?: any[][], rootSelectorOrNode?: string|any,
|
injector: Injector, projectableNodes?: any[][], rootSelectorOrNode?: string|any,
|
||||||
ngModule?: NgModuleRef<any>): ComponentRef<C> {
|
ngModule?: NgModuleRef<any>): ComponentRef<C> {
|
||||||
return this.factory.create(
|
return this.factory.create(
|
||||||
|
|
|
@ -81,7 +81,7 @@ const R3TemplateRef = class TemplateRef<T> extends ViewEngineTemplateRef<T> {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
createEmbeddedView(context: T): EmbeddedViewRef<T> {
|
override createEmbeddedView(context: T): EmbeddedViewRef<T> {
|
||||||
const embeddedTView = this._declarationTContainer.tViews as TView;
|
const embeddedTView = this._declarationTContainer.tViews as TView;
|
||||||
const embeddedLView = createLView(
|
const embeddedLView = createLView(
|
||||||
this._declarationLView, embeddedTView, context, LViewFlags.CheckAlways, null,
|
this._declarationLView, embeddedTView, context, LViewFlags.CheckAlways, null,
|
||||||
|
|
|
@ -194,16 +194,16 @@ const R3ViewContainerRef = class ViewContainerRef extends VE_ViewContainerRef {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
get element(): ElementRef {
|
override get element(): ElementRef {
|
||||||
return createElementRef(this._hostTNode, this._hostLView);
|
return createElementRef(this._hostTNode, this._hostLView);
|
||||||
}
|
}
|
||||||
|
|
||||||
get injector(): Injector {
|
override get injector(): Injector {
|
||||||
return new NodeInjector(this._hostTNode, this._hostLView);
|
return new NodeInjector(this._hostTNode, this._hostLView);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** @deprecated No replacement */
|
/** @deprecated No replacement */
|
||||||
get parentInjector(): Injector {
|
override get parentInjector(): Injector {
|
||||||
const parentLocation = getParentInjectorLocation(this._hostTNode, this._hostLView);
|
const parentLocation = getParentInjectorLocation(this._hostTNode, this._hostLView);
|
||||||
if (hasParentInjector(parentLocation)) {
|
if (hasParentInjector(parentLocation)) {
|
||||||
const parentView = getParentInjectorView(parentLocation, this._hostLView);
|
const parentView = getParentInjectorView(parentLocation, this._hostLView);
|
||||||
|
@ -217,29 +217,29 @@ const R3ViewContainerRef = class ViewContainerRef extends VE_ViewContainerRef {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
clear(): void {
|
override clear(): void {
|
||||||
while (this.length > 0) {
|
while (this.length > 0) {
|
||||||
this.remove(this.length - 1);
|
this.remove(this.length - 1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
get(index: number): ViewRef|null {
|
override get(index: number): ViewRef|null {
|
||||||
const viewRefs = getViewRefs(this._lContainer);
|
const viewRefs = getViewRefs(this._lContainer);
|
||||||
return viewRefs !== null && viewRefs[index] || null;
|
return viewRefs !== null && viewRefs[index] || null;
|
||||||
}
|
}
|
||||||
|
|
||||||
get length(): number {
|
override get length(): number {
|
||||||
return this._lContainer.length - CONTAINER_HEADER_OFFSET;
|
return this._lContainer.length - CONTAINER_HEADER_OFFSET;
|
||||||
}
|
}
|
||||||
|
|
||||||
createEmbeddedView<C>(templateRef: TemplateRef<C>, context?: C, index?: number):
|
override createEmbeddedView<C>(templateRef: TemplateRef<C>, context?: C, index?: number):
|
||||||
EmbeddedViewRef<C> {
|
EmbeddedViewRef<C> {
|
||||||
const viewRef = templateRef.createEmbeddedView(context || <any>{});
|
const viewRef = templateRef.createEmbeddedView(context || <any>{});
|
||||||
this.insert(viewRef, index);
|
this.insert(viewRef, index);
|
||||||
return viewRef;
|
return viewRef;
|
||||||
}
|
}
|
||||||
|
|
||||||
createComponent<C>(
|
override createComponent<C>(
|
||||||
componentFactory: ComponentFactory<C>, index?: number|undefined,
|
componentFactory: ComponentFactory<C>, index?: number|undefined,
|
||||||
injector?: Injector|undefined, projectableNodes?: any[][]|undefined,
|
injector?: Injector|undefined, projectableNodes?: any[][]|undefined,
|
||||||
ngModuleRef?: NgModuleRef<any>|undefined): ComponentRef<C> {
|
ngModuleRef?: NgModuleRef<any>|undefined): ComponentRef<C> {
|
||||||
|
@ -260,7 +260,7 @@ const R3ViewContainerRef = class ViewContainerRef extends VE_ViewContainerRef {
|
||||||
return componentRef;
|
return componentRef;
|
||||||
}
|
}
|
||||||
|
|
||||||
insert(viewRef: ViewRef, index?: number): ViewRef {
|
override insert(viewRef: ViewRef, index?: number): ViewRef {
|
||||||
const lView = (viewRef as R3ViewRef<any>)._lView!;
|
const lView = (viewRef as R3ViewRef<any>)._lView!;
|
||||||
const tView = lView[TVIEW];
|
const tView = lView[TVIEW];
|
||||||
|
|
||||||
|
@ -315,19 +315,19 @@ const R3ViewContainerRef = class ViewContainerRef extends VE_ViewContainerRef {
|
||||||
return viewRef;
|
return viewRef;
|
||||||
}
|
}
|
||||||
|
|
||||||
move(viewRef: ViewRef, newIndex: number): ViewRef {
|
override move(viewRef: ViewRef, newIndex: number): ViewRef {
|
||||||
if (ngDevMode && viewRef.destroyed) {
|
if (ngDevMode && viewRef.destroyed) {
|
||||||
throw new Error('Cannot move a destroyed View in a ViewContainer!');
|
throw new Error('Cannot move a destroyed View in a ViewContainer!');
|
||||||
}
|
}
|
||||||
return this.insert(viewRef, newIndex);
|
return this.insert(viewRef, newIndex);
|
||||||
}
|
}
|
||||||
|
|
||||||
indexOf(viewRef: ViewRef): number {
|
override indexOf(viewRef: ViewRef): number {
|
||||||
const viewRefsArr = getViewRefs(this._lContainer);
|
const viewRefsArr = getViewRefs(this._lContainer);
|
||||||
return viewRefsArr !== null ? viewRefsArr.indexOf(viewRef) : -1;
|
return viewRefsArr !== null ? viewRefsArr.indexOf(viewRef) : -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
remove(index?: number): void {
|
override remove(index?: number): void {
|
||||||
const adjustedIdx = this._adjustIndex(index, -1);
|
const adjustedIdx = this._adjustIndex(index, -1);
|
||||||
const detachedView = detachView(this._lContainer, adjustedIdx);
|
const detachedView = detachView(this._lContainer, adjustedIdx);
|
||||||
|
|
||||||
|
@ -343,7 +343,7 @@ const R3ViewContainerRef = class ViewContainerRef extends VE_ViewContainerRef {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
detach(index?: number): ViewRef|null {
|
override detach(index?: number): ViewRef|null {
|
||||||
const adjustedIdx = this._adjustIndex(index, -1);
|
const adjustedIdx = this._adjustIndex(index, -1);
|
||||||
const view = detachView(this._lContainer, adjustedIdx);
|
const view = detachView(this._lContainer, adjustedIdx);
|
||||||
|
|
||||||
|
|
|
@ -47,7 +47,7 @@ export class ComponentFactoryResolver extends viewEngine_ComponentFactoryResolve
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
resolveComponentFactory<T>(component: Type<T>): viewEngine_ComponentFactory<T> {
|
override resolveComponentFactory<T>(component: Type<T>): viewEngine_ComponentFactory<T> {
|
||||||
ngDevMode && assertComponentType(component);
|
ngDevMode && assertComponentType(component);
|
||||||
const componentDef = getComponentDef(component)!;
|
const componentDef = getComponentDef(component)!;
|
||||||
return new ComponentFactory(componentDef, this.ngModule);
|
return new ComponentFactory(componentDef, this.ngModule);
|
||||||
|
@ -103,16 +103,16 @@ function createChainedInjector(rootViewInjector: Injector, moduleInjector: Injec
|
||||||
* Render3 implementation of {@link viewEngine_ComponentFactory}.
|
* Render3 implementation of {@link viewEngine_ComponentFactory}.
|
||||||
*/
|
*/
|
||||||
export class ComponentFactory<T> extends viewEngine_ComponentFactory<T> {
|
export class ComponentFactory<T> extends viewEngine_ComponentFactory<T> {
|
||||||
selector: string;
|
override selector: string;
|
||||||
componentType: Type<any>;
|
override componentType: Type<any>;
|
||||||
ngContentSelectors: string[];
|
override ngContentSelectors: string[];
|
||||||
isBoundToModule: boolean;
|
isBoundToModule: boolean;
|
||||||
|
|
||||||
get inputs(): {propName: string; templateName: string;}[] {
|
override get inputs(): {propName: string; templateName: string;}[] {
|
||||||
return toRefArray(this.componentDef.inputs);
|
return toRefArray(this.componentDef.inputs);
|
||||||
}
|
}
|
||||||
|
|
||||||
get outputs(): {propName: string; templateName: string;}[] {
|
override get outputs(): {propName: string; templateName: string;}[] {
|
||||||
return toRefArray(this.componentDef.outputs);
|
return toRefArray(this.componentDef.outputs);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -130,7 +130,7 @@ export class ComponentFactory<T> extends viewEngine_ComponentFactory<T> {
|
||||||
this.isBoundToModule = !!ngModule;
|
this.isBoundToModule = !!ngModule;
|
||||||
}
|
}
|
||||||
|
|
||||||
create(
|
override create(
|
||||||
injector: Injector, projectableNodes?: any[][]|undefined, rootSelectorOrNode?: any,
|
injector: Injector, projectableNodes?: any[][]|undefined, rootSelectorOrNode?: any,
|
||||||
ngModule?: viewEngine_NgModuleRef<any>|undefined): viewEngine_ComponentRef<T> {
|
ngModule?: viewEngine_NgModuleRef<any>|undefined): viewEngine_ComponentRef<T> {
|
||||||
ngModule = ngModule || this.ngModule;
|
ngModule = ngModule || this.ngModule;
|
||||||
|
@ -247,10 +247,10 @@ export function injectComponentFactoryResolver(): viewEngine_ComponentFactoryRes
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
export class ComponentRef<T> extends viewEngine_ComponentRef<T> {
|
export class ComponentRef<T> extends viewEngine_ComponentRef<T> {
|
||||||
instance: T;
|
override instance: T;
|
||||||
hostView: ViewRef<T>;
|
override hostView: ViewRef<T>;
|
||||||
changeDetectorRef: ViewEngine_ChangeDetectorRef;
|
override changeDetectorRef: ViewEngine_ChangeDetectorRef;
|
||||||
componentType: Type<T>;
|
override componentType: Type<T>;
|
||||||
|
|
||||||
constructor(
|
constructor(
|
||||||
componentType: Type<T>, instance: T, public location: viewEngine_ElementRef,
|
componentType: Type<T>, instance: T, public location: viewEngine_ElementRef,
|
||||||
|
@ -262,15 +262,15 @@ export class ComponentRef<T> extends viewEngine_ComponentRef<T> {
|
||||||
this.componentType = componentType;
|
this.componentType = componentType;
|
||||||
}
|
}
|
||||||
|
|
||||||
get injector(): Injector {
|
override get injector(): Injector {
|
||||||
return new NodeInjector(this._tNode, this._rootLView);
|
return new NodeInjector(this._tNode, this._rootLView);
|
||||||
}
|
}
|
||||||
|
|
||||||
destroy(): void {
|
override destroy(): void {
|
||||||
this.hostView.destroy();
|
this.hostView.destroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
onDestroy(callback: () => void): void {
|
override onDestroy(callback: () => void): void {
|
||||||
this.hostView.onDestroy(callback);
|
this.hostView.onDestroy(callback);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -28,8 +28,8 @@ export class NgModuleRef<T> extends viewEngine_NgModuleRef<T> implements Interna
|
||||||
_bootstrapComponents: Type<any>[] = [];
|
_bootstrapComponents: Type<any>[] = [];
|
||||||
// tslint:disable-next-line:require-internal-with-underscore
|
// tslint:disable-next-line:require-internal-with-underscore
|
||||||
_r3Injector: R3Injector;
|
_r3Injector: R3Injector;
|
||||||
injector: Injector = this;
|
override injector: Injector = this;
|
||||||
instance: T;
|
override instance: T;
|
||||||
destroyCbs: (() => void)[]|null = [];
|
destroyCbs: (() => void)[]|null = [];
|
||||||
|
|
||||||
// When bootstrapping a module we have a dependency graph that looks like this:
|
// When bootstrapping a module we have a dependency graph that looks like this:
|
||||||
|
@ -38,7 +38,8 @@ export class NgModuleRef<T> extends viewEngine_NgModuleRef<T> implements Interna
|
||||||
// circular dependency which will result in a runtime error, because the injector doesn't
|
// circular dependency which will result in a runtime error, because the injector doesn't
|
||||||
// exist yet. We work around the issue by creating the ComponentFactoryResolver ourselves
|
// exist yet. We work around the issue by creating the ComponentFactoryResolver ourselves
|
||||||
// and providing it, rather than letting the injector resolve it.
|
// and providing it, rather than letting the injector resolve it.
|
||||||
readonly componentFactoryResolver: ComponentFactoryResolver = new ComponentFactoryResolver(this);
|
override readonly componentFactoryResolver: ComponentFactoryResolver =
|
||||||
|
new ComponentFactoryResolver(this);
|
||||||
|
|
||||||
constructor(ngModuleType: Type<T>, public _parent: Injector|null) {
|
constructor(ngModuleType: Type<T>, public _parent: Injector|null) {
|
||||||
super();
|
super();
|
||||||
|
@ -76,14 +77,14 @@ export class NgModuleRef<T> extends viewEngine_NgModuleRef<T> implements Interna
|
||||||
return this._r3Injector.get(token, notFoundValue, injectFlags);
|
return this._r3Injector.get(token, notFoundValue, injectFlags);
|
||||||
}
|
}
|
||||||
|
|
||||||
destroy(): void {
|
override destroy(): void {
|
||||||
ngDevMode && assertDefined(this.destroyCbs, 'NgModule already destroyed');
|
ngDevMode && assertDefined(this.destroyCbs, 'NgModule already destroyed');
|
||||||
const injector = this._r3Injector;
|
const injector = this._r3Injector;
|
||||||
!injector.destroyed && injector.destroy();
|
!injector.destroyed && injector.destroy();
|
||||||
this.destroyCbs!.forEach(fn => fn());
|
this.destroyCbs!.forEach(fn => fn());
|
||||||
this.destroyCbs = null;
|
this.destroyCbs = null;
|
||||||
}
|
}
|
||||||
onDestroy(callback: () => void): void {
|
override onDestroy(callback: () => void): void {
|
||||||
ngDevMode && assertDefined(this.destroyCbs, 'NgModule already destroyed');
|
ngDevMode && assertDefined(this.destroyCbs, 'NgModule already destroyed');
|
||||||
this.destroyCbs!.push(callback);
|
this.destroyCbs!.push(callback);
|
||||||
}
|
}
|
||||||
|
@ -122,7 +123,7 @@ export class NgModuleFactory<T> extends viewEngine_NgModuleFactory<T> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
create(parentInjector: Injector|null): viewEngine_NgModuleRef<T> {
|
override create(parentInjector: Injector|null): viewEngine_NgModuleRef<T> {
|
||||||
return new NgModuleRef(this.moduleType, parentInjector);
|
return new NgModuleRef(this.moduleType, parentInjector);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -70,27 +70,27 @@ abstract class SafeValueImpl implements SafeValue {
|
||||||
}
|
}
|
||||||
|
|
||||||
class SafeHtmlImpl extends SafeValueImpl implements SafeHtml {
|
class SafeHtmlImpl extends SafeValueImpl implements SafeHtml {
|
||||||
getTypeName() {
|
override getTypeName() {
|
||||||
return BypassType.Html;
|
return BypassType.Html;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
class SafeStyleImpl extends SafeValueImpl implements SafeStyle {
|
class SafeStyleImpl extends SafeValueImpl implements SafeStyle {
|
||||||
getTypeName() {
|
override getTypeName() {
|
||||||
return BypassType.Style;
|
return BypassType.Style;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
class SafeScriptImpl extends SafeValueImpl implements SafeScript {
|
class SafeScriptImpl extends SafeValueImpl implements SafeScript {
|
||||||
getTypeName() {
|
override getTypeName() {
|
||||||
return BypassType.Script;
|
return BypassType.Script;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
class SafeUrlImpl extends SafeValueImpl implements SafeUrl {
|
class SafeUrlImpl extends SafeValueImpl implements SafeUrl {
|
||||||
getTypeName() {
|
override getTypeName() {
|
||||||
return BypassType.Url;
|
return BypassType.Url;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
class SafeResourceUrlImpl extends SafeValueImpl implements SafeResourceUrl {
|
class SafeResourceUrlImpl extends SafeValueImpl implements SafeResourceUrl {
|
||||||
getTypeName() {
|
override getTypeName() {
|
||||||
return BypassType.ResourceUrl;
|
return BypassType.ResourceUrl;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -64,7 +64,7 @@ class NgModuleFactory_ extends NgModuleFactory<any> {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
create(parentInjector: Injector|null): NgModuleRef<any> {
|
override create(parentInjector: Injector|null): NgModuleRef<any> {
|
||||||
initServicesIfNeeded();
|
initServicesIfNeeded();
|
||||||
// Clone the NgModuleDefinition so that any tree shakeable provider definition
|
// Clone the NgModuleDefinition so that any tree shakeable provider definition
|
||||||
// added to this instance of the NgModuleRef doesn't affect the cached copy.
|
// added to this instance of the NgModuleRef doesn't affect the cached copy.
|
||||||
|
|
|
@ -58,7 +58,7 @@ class ComponentFactory_ extends ComponentFactory<any> {
|
||||||
this.viewDefFactory = viewDefFactory;
|
this.viewDefFactory = viewDefFactory;
|
||||||
}
|
}
|
||||||
|
|
||||||
get inputs() {
|
override get inputs() {
|
||||||
const inputsArr: {propName: string, templateName: string}[] = [];
|
const inputsArr: {propName: string, templateName: string}[] = [];
|
||||||
const inputs = this._inputs!;
|
const inputs = this._inputs!;
|
||||||
for (let propName in inputs) {
|
for (let propName in inputs) {
|
||||||
|
@ -68,7 +68,7 @@ class ComponentFactory_ extends ComponentFactory<any> {
|
||||||
return inputsArr;
|
return inputsArr;
|
||||||
}
|
}
|
||||||
|
|
||||||
get outputs() {
|
override get outputs() {
|
||||||
const outputsArr: {propName: string, templateName: string}[] = [];
|
const outputsArr: {propName: string, templateName: string}[] = [];
|
||||||
for (let propName in this._outputs) {
|
for (let propName in this._outputs) {
|
||||||
const templateName = this._outputs[propName];
|
const templateName = this._outputs[propName];
|
||||||
|
@ -80,7 +80,7 @@ class ComponentFactory_ extends ComponentFactory<any> {
|
||||||
/**
|
/**
|
||||||
* Creates a new component.
|
* Creates a new component.
|
||||||
*/
|
*/
|
||||||
create(
|
override create(
|
||||||
injector: Injector, projectableNodes?: any[][], rootSelectorOrNode?: string|any,
|
injector: Injector, projectableNodes?: any[][], rootSelectorOrNode?: string|any,
|
||||||
ngModule?: NgModuleRef<any>): ComponentRef<any> {
|
ngModule?: NgModuleRef<any>): ComponentRef<any> {
|
||||||
if (!ngModule) {
|
if (!ngModule) {
|
||||||
|
@ -100,9 +100,9 @@ class ComponentFactory_ extends ComponentFactory<any> {
|
||||||
}
|
}
|
||||||
|
|
||||||
class ComponentRef_ extends ComponentRef<any> {
|
class ComponentRef_ extends ComponentRef<any> {
|
||||||
public readonly hostView: ViewRef;
|
public override readonly hostView: ViewRef;
|
||||||
public readonly instance: any;
|
public override readonly instance: any;
|
||||||
public readonly changeDetectorRef: ChangeDetectorRef;
|
public override readonly changeDetectorRef: ChangeDetectorRef;
|
||||||
private _elDef: NodeDef;
|
private _elDef: NodeDef;
|
||||||
constructor(private _view: ViewData, private _viewRef: ViewRef, private _component: any) {
|
constructor(private _view: ViewData, private _viewRef: ViewRef, private _component: any) {
|
||||||
super();
|
super();
|
||||||
|
@ -111,20 +111,20 @@ class ComponentRef_ extends ComponentRef<any> {
|
||||||
this.changeDetectorRef = _viewRef;
|
this.changeDetectorRef = _viewRef;
|
||||||
this.instance = _component;
|
this.instance = _component;
|
||||||
}
|
}
|
||||||
get location(): ElementRef {
|
override get location(): ElementRef {
|
||||||
return new ElementRef(asElementData(this._view, this._elDef.nodeIndex).renderElement);
|
return new ElementRef(asElementData(this._view, this._elDef.nodeIndex).renderElement);
|
||||||
}
|
}
|
||||||
get injector(): Injector {
|
override get injector(): Injector {
|
||||||
return new Injector_(this._view, this._elDef);
|
return new Injector_(this._view, this._elDef);
|
||||||
}
|
}
|
||||||
get componentType(): Type<any> {
|
override get componentType(): Type<any> {
|
||||||
return <any>this._component.constructor;
|
return <any>this._component.constructor;
|
||||||
}
|
}
|
||||||
|
|
||||||
destroy(): void {
|
override destroy(): void {
|
||||||
this._viewRef.destroy();
|
this._viewRef.destroy();
|
||||||
}
|
}
|
||||||
onDestroy(callback: Function): void {
|
override onDestroy(callback: Function): void {
|
||||||
this._viewRef.onDestroy(callback);
|
this._viewRef.onDestroy(callback);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -350,12 +350,12 @@ class TemplateRef_ extends TemplateRef<any> implements TemplateData {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
createEmbeddedView(context: any): EmbeddedViewRef<any> {
|
override createEmbeddedView(context: any): EmbeddedViewRef<any> {
|
||||||
return new ViewRef_(Services.createEmbeddedView(
|
return new ViewRef_(Services.createEmbeddedView(
|
||||||
this._parentView, this._def, this._def.element!.template !, context));
|
this._parentView, this._def, this._def.element!.template !, context));
|
||||||
}
|
}
|
||||||
|
|
||||||
get elementRef(): ElementRef {
|
override get elementRef(): ElementRef {
|
||||||
return new ElementRef(asElementData(this._parentView, this._def.nodeIndex).renderElement);
|
return new ElementRef(asElementData(this._parentView, this._def.nodeIndex).renderElement);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -329,7 +329,7 @@ describe('inheritance', () => {
|
||||||
|
|
||||||
@Component({selector: 'my-comp', template: ''})
|
@Component({selector: 'my-comp', template: ''})
|
||||||
class MyComp extends UndecoratedBase {
|
class MyComp extends UndecoratedBase {
|
||||||
@Input() input: any;
|
@Input() override input: any;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Component({template: '<my-comp [input]="value"></my-comp>'})
|
@Component({template: '<my-comp [input]="value"></my-comp>'})
|
||||||
|
|
|
@ -21,11 +21,11 @@ export class SimpleDomEventsPlugin extends EventManagerPlugin {
|
||||||
super(doc);
|
super(doc);
|
||||||
}
|
}
|
||||||
|
|
||||||
supports(eventName: string): boolean {
|
override supports(eventName: string): boolean {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
addEventListener(element: HTMLElement, eventName: string, handler: Function): Function {
|
override addEventListener(element: HTMLElement, eventName: string, handler: Function): Function {
|
||||||
let callback: EventListener = handler as EventListener;
|
let callback: EventListener = handler as EventListener;
|
||||||
element.addEventListener(eventName, callback, false);
|
element.addEventListener(eventName, callback, false);
|
||||||
return () => this.removeEventListener(element, eventName, callback);
|
return () => this.removeEventListener(element, eventName, callback);
|
||||||
|
|
|
@ -86,25 +86,25 @@ abstract class OverrideResolver<T> implements Resolver<T> {
|
||||||
|
|
||||||
|
|
||||||
export class DirectiveResolver extends OverrideResolver<Directive> {
|
export class DirectiveResolver extends OverrideResolver<Directive> {
|
||||||
get type() {
|
override get type() {
|
||||||
return Directive;
|
return Directive;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export class ComponentResolver extends OverrideResolver<Component> {
|
export class ComponentResolver extends OverrideResolver<Component> {
|
||||||
get type() {
|
override get type() {
|
||||||
return Component;
|
return Component;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export class PipeResolver extends OverrideResolver<Pipe> {
|
export class PipeResolver extends OverrideResolver<Pipe> {
|
||||||
get type() {
|
override get type() {
|
||||||
return Pipe;
|
return Pipe;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export class NgModuleResolver extends OverrideResolver<NgModule> {
|
export class NgModuleResolver extends OverrideResolver<NgModule> {
|
||||||
get type() {
|
override get type() {
|
||||||
return NgModule;
|
return NgModule;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -139,7 +139,7 @@ export function createCustomElement<P>(
|
||||||
// field externs. So using quoted access to explicitly prevent renaming.
|
// field externs. So using quoted access to explicitly prevent renaming.
|
||||||
static readonly['observedAttributes'] = Object.keys(attributeToPropertyInputs);
|
static readonly['observedAttributes'] = Object.keys(attributeToPropertyInputs);
|
||||||
|
|
||||||
protected get ngElementStrategy(): NgElementStrategy {
|
protected override get ngElementStrategy(): NgElementStrategy {
|
||||||
// NOTE:
|
// NOTE:
|
||||||
// Some polyfills (e.g. `document-register-element`) do not call the constructor, therefore
|
// Some polyfills (e.g. `document-register-element`) do not call the constructor, therefore
|
||||||
// it is not safe to set `ngElementStrategy` in the constructor and assume it will be
|
// it is not safe to set `ngElementStrategy` in the constructor and assume it will be
|
||||||
|
@ -175,13 +175,13 @@ export function createCustomElement<P>(
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
attributeChangedCallback(
|
override attributeChangedCallback(
|
||||||
attrName: string, oldValue: string|null, newValue: string, namespace?: string): void {
|
attrName: string, oldValue: string|null, newValue: string, namespace?: string): void {
|
||||||
const propName = attributeToPropertyInputs[attrName]!;
|
const propName = attributeToPropertyInputs[attrName]!;
|
||||||
this.ngElementStrategy.setInputValue(propName, newValue);
|
this.ngElementStrategy.setInputValue(propName, newValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
connectedCallback(): void {
|
override connectedCallback(): void {
|
||||||
// For historical reasons, some strategies may not have initialized the `events` property
|
// For historical reasons, some strategies may not have initialized the `events` property
|
||||||
// until after `connect()` is run. Subscribe to `events` if it is available before running
|
// until after `connect()` is run. Subscribe to `events` if it is available before running
|
||||||
// `connect()` (in order to capture events emitted suring inittialization), otherwise
|
// `connect()` (in order to capture events emitted suring inittialization), otherwise
|
||||||
|
@ -208,7 +208,7 @@ export function createCustomElement<P>(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
disconnectedCallback(): void {
|
override disconnectedCallback(): void {
|
||||||
// Not using `this.ngElementStrategy` to avoid unnecessarily creating the `NgElementStrategy`.
|
// Not using `this.ngElementStrategy` to avoid unnecessarily creating the `NgElementStrategy`.
|
||||||
if (this._ngElementStrategy) {
|
if (this._ngElementStrategy) {
|
||||||
this._ngElementStrategy.disconnect();
|
this._ngElementStrategy.disconnect();
|
||||||
|
|
|
@ -451,16 +451,16 @@ export class FakeComponentFactory<T extends Type<any>> extends ComponentFactory<
|
||||||
instance: new this.ComponentClass(),
|
instance: new this.ComponentClass(),
|
||||||
});
|
});
|
||||||
|
|
||||||
get selector(): string {
|
override get selector(): string {
|
||||||
return 'fake-component';
|
return 'fake-component';
|
||||||
}
|
}
|
||||||
get componentType(): Type<any> {
|
override get componentType(): Type<any> {
|
||||||
return this.ComponentClass;
|
return this.ComponentClass;
|
||||||
}
|
}
|
||||||
get ngContentSelectors(): string[] {
|
override get ngContentSelectors(): string[] {
|
||||||
return ['content-1', 'content-2'];
|
return ['content-1', 'content-2'];
|
||||||
}
|
}
|
||||||
get inputs(): {propName: string; templateName: string}[] {
|
override get inputs(): {propName: string; templateName: string}[] {
|
||||||
return [
|
return [
|
||||||
{propName: 'fooFoo', templateName: 'fooFoo'},
|
{propName: 'fooFoo', templateName: 'fooFoo'},
|
||||||
{propName: 'barBar', templateName: 'my-bar-bar'},
|
{propName: 'barBar', templateName: 'my-bar-bar'},
|
||||||
|
@ -471,7 +471,7 @@ export class FakeComponentFactory<T extends Type<any>> extends ComponentFactory<
|
||||||
{propName: 'falsyZero', templateName: 'falsyZero'},
|
{propName: 'falsyZero', templateName: 'falsyZero'},
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
get outputs(): {propName: string; templateName: string}[] {
|
override get outputs(): {propName: string; templateName: string}[] {
|
||||||
return [
|
return [
|
||||||
{propName: 'output1', templateName: 'templateOutput1'},
|
{propName: 'output1', templateName: 'templateOutput1'},
|
||||||
{propName: 'output2', templateName: 'templateOutput2'},
|
{propName: 'output2', templateName: 'templateOutput2'},
|
||||||
|
@ -482,7 +482,7 @@ export class FakeComponentFactory<T extends Type<any>> extends ComponentFactory<
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
create(
|
override create(
|
||||||
injector: Injector, projectableNodes?: any[][], rootSelectorOrNode?: string|any,
|
injector: Injector, projectableNodes?: any[][], rootSelectorOrNode?: string|any,
|
||||||
ngModule?: NgModuleRef<any>): ComponentRef<any> {
|
ngModule?: NgModuleRef<any>): ComponentRef<any> {
|
||||||
return this.componentRef;
|
return this.componentRef;
|
||||||
|
|
|
@ -52,7 +52,7 @@ export class AbstractFormGroupDirective extends ControlContainer implements OnIn
|
||||||
* @description
|
* @description
|
||||||
* The `FormGroup` bound to this directive.
|
* The `FormGroup` bound to this directive.
|
||||||
*/
|
*/
|
||||||
get control(): FormGroup {
|
override get control(): FormGroup {
|
||||||
return this.formDirective!.getFormGroup(this);
|
return this.formDirective!.getFormGroup(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -156,7 +156,7 @@ export class NgForm extends ControlContainer implements Form, AfterViewInit {
|
||||||
* @description
|
* @description
|
||||||
* The internal `FormGroup` instance.
|
* The internal `FormGroup` instance.
|
||||||
*/
|
*/
|
||||||
get control(): FormGroup {
|
override get control(): FormGroup {
|
||||||
return this.form;
|
return this.form;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -136,7 +136,7 @@ const resolvedPromise = (() => Promise.resolve(null))();
|
||||||
exportAs: 'ngModel'
|
exportAs: 'ngModel'
|
||||||
})
|
})
|
||||||
export class NgModel extends NgControl implements OnChanges, OnDestroy {
|
export class NgModel extends NgControl implements OnChanges, OnDestroy {
|
||||||
public readonly control: FormControl = new FormControl();
|
public override readonly control: FormControl = new FormControl();
|
||||||
|
|
||||||
// At runtime we coerce arbitrary values assigned to the "disabled" input to a "boolean".
|
// At runtime we coerce arbitrary values assigned to the "disabled" input to a "boolean".
|
||||||
// This is not reflected in the type of the property because outside of templates, consumers
|
// This is not reflected in the type of the property because outside of templates, consumers
|
||||||
|
@ -258,7 +258,7 @@ export class NgModel extends NgControl implements OnChanges, OnDestroy {
|
||||||
*
|
*
|
||||||
* @param newValue The new value emitted by `ngModelChange`.
|
* @param newValue The new value emitted by `ngModelChange`.
|
||||||
*/
|
*/
|
||||||
viewToModelUpdate(newValue: any): void {
|
override viewToModelUpdate(newValue: any): void {
|
||||||
this.viewModel = newValue;
|
this.viewModel = newValue;
|
||||||
this.update.emit(newValue);
|
this.update.emit(newValue);
|
||||||
}
|
}
|
||||||
|
|
|
@ -157,7 +157,7 @@ export class FormControlDirective extends NgControl implements OnChanges, OnDest
|
||||||
* @description
|
* @description
|
||||||
* The `FormControl` bound to this directive.
|
* The `FormControl` bound to this directive.
|
||||||
*/
|
*/
|
||||||
get control(): FormControl {
|
override get control(): FormControl {
|
||||||
return this.form;
|
return this.form;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -167,7 +167,7 @@ export class FormControlDirective extends NgControl implements OnChanges, OnDest
|
||||||
*
|
*
|
||||||
* @param newValue The new value for the view model.
|
* @param newValue The new value for the view model.
|
||||||
*/
|
*/
|
||||||
viewToModelUpdate(newValue: any): void {
|
override viewToModelUpdate(newValue: any): void {
|
||||||
this.viewModel = newValue;
|
this.viewModel = newValue;
|
||||||
this.update.emit(newValue);
|
this.update.emit(newValue);
|
||||||
}
|
}
|
||||||
|
|
|
@ -75,7 +75,7 @@ export class FormControlName extends NgControl implements OnChanges, OnDestroy {
|
||||||
* Tracks the `FormControl` instance bound to the directive.
|
* Tracks the `FormControl` instance bound to the directive.
|
||||||
*/
|
*/
|
||||||
// TODO(issue/24571): remove '!'.
|
// TODO(issue/24571): remove '!'.
|
||||||
readonly control!: FormControl;
|
override readonly control!: FormControl;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @description
|
* @description
|
||||||
|
@ -166,7 +166,7 @@ export class FormControlName extends NgControl implements OnChanges, OnDestroy {
|
||||||
*
|
*
|
||||||
* @param newValue The new value for the view model.
|
* @param newValue The new value for the view model.
|
||||||
*/
|
*/
|
||||||
viewToModelUpdate(newValue: any): void {
|
override viewToModelUpdate(newValue: any): void {
|
||||||
this.viewModel = newValue;
|
this.viewModel = newValue;
|
||||||
this.update.emit(newValue);
|
this.update.emit(newValue);
|
||||||
}
|
}
|
||||||
|
|
|
@ -140,7 +140,7 @@ export class FormGroupDirective extends ControlContainer implements Form, OnChan
|
||||||
* @description
|
* @description
|
||||||
* Returns the `FormGroup` bound to this directive.
|
* Returns the `FormGroup` bound to this directive.
|
||||||
*/
|
*/
|
||||||
get control(): FormGroup {
|
override get control(): FormGroup {
|
||||||
return this.form;
|
return this.form;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -184,7 +184,7 @@ export class FormArrayName extends ControlContainer implements OnInit, OnDestroy
|
||||||
* @description
|
* @description
|
||||||
* The `FormArray` bound to this directive.
|
* The `FormArray` bound to this directive.
|
||||||
*/
|
*/
|
||||||
get control(): FormArray {
|
override get control(): FormArray {
|
||||||
return this.formDirective!.getFormArray(this);
|
return this.formDirective!.getFormArray(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -176,11 +176,11 @@ export class MaxValidator extends AbstractValidatorDirective implements OnChange
|
||||||
*/
|
*/
|
||||||
@Input() max!: string|number;
|
@Input() max!: string|number;
|
||||||
/** @internal */
|
/** @internal */
|
||||||
inputName = 'max';
|
override inputName = 'max';
|
||||||
/** @internal */
|
/** @internal */
|
||||||
normalizeInput = (input: string): number => parseFloat(input);
|
override normalizeInput = (input: string): number => parseFloat(input);
|
||||||
/** @internal */
|
/** @internal */
|
||||||
createValidator = (max: number): ValidatorFn => maxValidator(max);
|
override createValidator = (max: number): ValidatorFn => maxValidator(max);
|
||||||
/**
|
/**
|
||||||
* Declare `ngOnChanges` lifecycle hook at the main directive level (vs keeping it in base class)
|
* Declare `ngOnChanges` lifecycle hook at the main directive level (vs keeping it in base class)
|
||||||
* to avoid differences in handling inheritance of lifecycle hooks between Ivy and ViewEngine in
|
* to avoid differences in handling inheritance of lifecycle hooks between Ivy and ViewEngine in
|
||||||
|
@ -236,11 +236,11 @@ export class MinValidator extends AbstractValidatorDirective implements OnChange
|
||||||
*/
|
*/
|
||||||
@Input() min!: string|number;
|
@Input() min!: string|number;
|
||||||
/** @internal */
|
/** @internal */
|
||||||
inputName = 'min';
|
override inputName = 'min';
|
||||||
/** @internal */
|
/** @internal */
|
||||||
normalizeInput = (input: string): number => parseFloat(input);
|
override normalizeInput = (input: string): number => parseFloat(input);
|
||||||
/** @internal */
|
/** @internal */
|
||||||
createValidator = (min: number): ValidatorFn => minValidator(min);
|
override createValidator = (min: number): ValidatorFn => minValidator(min);
|
||||||
/**
|
/**
|
||||||
* Declare `ngOnChanges` lifecycle hook at the main directive level (vs keeping it in base class)
|
* Declare `ngOnChanges` lifecycle hook at the main directive level (vs keeping it in base class)
|
||||||
* to avoid differences in handling inheritance of lifecycle hooks between Ivy and ViewEngine in
|
* to avoid differences in handling inheritance of lifecycle hooks between Ivy and ViewEngine in
|
||||||
|
|
|
@ -1194,7 +1194,7 @@ export class FormControl extends AbstractControl {
|
||||||
* event to update the model.
|
* event to update the model.
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
setValue(value: any, options: {
|
override setValue(value: any, options: {
|
||||||
onlySelf?: boolean,
|
onlySelf?: boolean,
|
||||||
emitEvent?: boolean,
|
emitEvent?: boolean,
|
||||||
emitModelToViewChange?: boolean,
|
emitModelToViewChange?: boolean,
|
||||||
|
@ -1217,7 +1217,7 @@ export class FormControl extends AbstractControl {
|
||||||
*
|
*
|
||||||
* @see `setValue` for options
|
* @see `setValue` for options
|
||||||
*/
|
*/
|
||||||
patchValue(value: any, options: {
|
override patchValue(value: any, options: {
|
||||||
onlySelf?: boolean,
|
onlySelf?: boolean,
|
||||||
emitEvent?: boolean,
|
emitEvent?: boolean,
|
||||||
emitModelToViewChange?: boolean,
|
emitModelToViewChange?: boolean,
|
||||||
|
@ -1244,7 +1244,8 @@ export class FormControl extends AbstractControl {
|
||||||
* When false, no events are emitted.
|
* When false, no events are emitted.
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
reset(formState: any = null, options: {onlySelf?: boolean, emitEvent?: boolean} = {}): void {
|
override reset(formState: any = null, options: {onlySelf?: boolean, emitEvent?: boolean} = {}):
|
||||||
|
void {
|
||||||
this._applyFormState(formState);
|
this._applyFormState(formState);
|
||||||
this.markAsPristine(options);
|
this.markAsPristine(options);
|
||||||
this.markAsUntouched(options);
|
this.markAsUntouched(options);
|
||||||
|
@ -1255,19 +1256,19 @@ export class FormControl extends AbstractControl {
|
||||||
/**
|
/**
|
||||||
* @internal
|
* @internal
|
||||||
*/
|
*/
|
||||||
_updateValue() {}
|
override _updateValue() {}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @internal
|
* @internal
|
||||||
*/
|
*/
|
||||||
_anyControls(condition: Function): boolean {
|
override _anyControls(condition: Function): boolean {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @internal
|
* @internal
|
||||||
*/
|
*/
|
||||||
_allControlsDisabled(): boolean {
|
override _allControlsDisabled(): boolean {
|
||||||
return this.disabled;
|
return this.disabled;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1308,10 +1309,10 @@ export class FormControl extends AbstractControl {
|
||||||
/**
|
/**
|
||||||
* @internal
|
* @internal
|
||||||
*/
|
*/
|
||||||
_forEachChild(cb: Function): void {}
|
override _forEachChild(cb: Function): void {}
|
||||||
|
|
||||||
/** @internal */
|
/** @internal */
|
||||||
_syncPendingControls(): boolean {
|
override _syncPendingControls(): boolean {
|
||||||
if (this.updateOn === 'submit') {
|
if (this.updateOn === 'submit') {
|
||||||
if (this._pendingDirty) this.markAsDirty();
|
if (this._pendingDirty) this.markAsDirty();
|
||||||
if (this._pendingTouched) this.markAsTouched();
|
if (this._pendingTouched) this.markAsTouched();
|
||||||
|
@ -1564,8 +1565,8 @@ export class FormGroup extends AbstractControl {
|
||||||
* observables emit events with the latest status and value when the control value is updated.
|
* observables emit events with the latest status and value when the control value is updated.
|
||||||
* When false, no events are emitted.
|
* When false, no events are emitted.
|
||||||
*/
|
*/
|
||||||
setValue(value: {[key: string]: any}, options: {onlySelf?: boolean, emitEvent?: boolean} = {}):
|
override setValue(
|
||||||
void {
|
value: {[key: string]: any}, options: {onlySelf?: boolean, emitEvent?: boolean} = {}): void {
|
||||||
this._checkAllValuesPresent(value);
|
this._checkAllValuesPresent(value);
|
||||||
Object.keys(value).forEach(name => {
|
Object.keys(value).forEach(name => {
|
||||||
this._throwIfControlMissing(name);
|
this._throwIfControlMissing(name);
|
||||||
|
@ -1605,8 +1606,8 @@ export class FormGroup extends AbstractControl {
|
||||||
* is updated. When false, no events are emitted. The configuration options are passed to
|
* is updated. When false, no events are emitted. The configuration options are passed to
|
||||||
* the {@link AbstractControl#updateValueAndValidity updateValueAndValidity} method.
|
* the {@link AbstractControl#updateValueAndValidity updateValueAndValidity} method.
|
||||||
*/
|
*/
|
||||||
patchValue(value: {[key: string]: any}, options: {onlySelf?: boolean, emitEvent?: boolean} = {}):
|
override patchValue(
|
||||||
void {
|
value: {[key: string]: any}, options: {onlySelf?: boolean, emitEvent?: boolean} = {}): void {
|
||||||
// Even though the `value` argument type doesn't allow `null` and `undefined` values, the
|
// Even though the `value` argument type doesn't allow `null` and `undefined` values, the
|
||||||
// `patchValue` can be called recursively and inner data structures might have these values, so
|
// `patchValue` can be called recursively and inner data structures might have these values, so
|
||||||
// we just ignore such cases when a field containing FormGroup instance receives `null` or
|
// we just ignore such cases when a field containing FormGroup instance receives `null` or
|
||||||
|
@ -1678,7 +1679,7 @@ export class FormGroup extends AbstractControl {
|
||||||
* console.log(form.get('first').status); // 'DISABLED'
|
* console.log(form.get('first').status); // 'DISABLED'
|
||||||
* ```
|
* ```
|
||||||
*/
|
*/
|
||||||
reset(value: any = {}, options: {onlySelf?: boolean, emitEvent?: boolean} = {}): void {
|
override reset(value: any = {}, options: {onlySelf?: boolean, emitEvent?: boolean} = {}): void {
|
||||||
this._forEachChild((control: AbstractControl, name: string) => {
|
this._forEachChild((control: AbstractControl, name: string) => {
|
||||||
control.reset(value[name], {onlySelf: true, emitEvent: options.emitEvent});
|
control.reset(value[name], {onlySelf: true, emitEvent: options.emitEvent});
|
||||||
});
|
});
|
||||||
|
@ -1703,7 +1704,7 @@ export class FormGroup extends AbstractControl {
|
||||||
}
|
}
|
||||||
|
|
||||||
/** @internal */
|
/** @internal */
|
||||||
_syncPendingControls(): boolean {
|
override _syncPendingControls(): boolean {
|
||||||
let subtreeUpdated = this._reduceChildren(false, (updated: boolean, child: AbstractControl) => {
|
let subtreeUpdated = this._reduceChildren(false, (updated: boolean, child: AbstractControl) => {
|
||||||
return child._syncPendingControls() ? true : updated;
|
return child._syncPendingControls() ? true : updated;
|
||||||
});
|
});
|
||||||
|
@ -1725,7 +1726,7 @@ export class FormGroup extends AbstractControl {
|
||||||
}
|
}
|
||||||
|
|
||||||
/** @internal */
|
/** @internal */
|
||||||
_forEachChild(cb: (v: any, k: string) => void): void {
|
override _forEachChild(cb: (v: any, k: string) => void): void {
|
||||||
Object.keys(this.controls).forEach(key => {
|
Object.keys(this.controls).forEach(key => {
|
||||||
// The list of controls can change (for ex. controls might be removed) while the loop
|
// The list of controls can change (for ex. controls might be removed) while the loop
|
||||||
// is running (as a result of invoking Forms API in `valueChanges` subscription), so we
|
// is running (as a result of invoking Forms API in `valueChanges` subscription), so we
|
||||||
|
@ -1744,12 +1745,12 @@ export class FormGroup extends AbstractControl {
|
||||||
}
|
}
|
||||||
|
|
||||||
/** @internal */
|
/** @internal */
|
||||||
_updateValue(): void {
|
override _updateValue(): void {
|
||||||
(this as {value: any}).value = this._reduceValue();
|
(this as {value: any}).value = this._reduceValue();
|
||||||
}
|
}
|
||||||
|
|
||||||
/** @internal */
|
/** @internal */
|
||||||
_anyControls(condition: Function): boolean {
|
override _anyControls(condition: Function): boolean {
|
||||||
for (const controlName of Object.keys(this.controls)) {
|
for (const controlName of Object.keys(this.controls)) {
|
||||||
const control = this.controls[controlName];
|
const control = this.controls[controlName];
|
||||||
if (this.contains(controlName) && condition(control)) {
|
if (this.contains(controlName) && condition(control)) {
|
||||||
|
@ -1780,7 +1781,7 @@ export class FormGroup extends AbstractControl {
|
||||||
}
|
}
|
||||||
|
|
||||||
/** @internal */
|
/** @internal */
|
||||||
_allControlsDisabled(): boolean {
|
override _allControlsDisabled(): boolean {
|
||||||
for (const controlName of Object.keys(this.controls)) {
|
for (const controlName of Object.keys(this.controls)) {
|
||||||
if (this.controls[controlName].enabled) {
|
if (this.controls[controlName].enabled) {
|
||||||
return false;
|
return false;
|
||||||
|
@ -2021,7 +2022,7 @@ export class FormArray extends AbstractControl {
|
||||||
* The configuration options are passed to the {@link AbstractControl#updateValueAndValidity
|
* The configuration options are passed to the {@link AbstractControl#updateValueAndValidity
|
||||||
* updateValueAndValidity} method.
|
* updateValueAndValidity} method.
|
||||||
*/
|
*/
|
||||||
setValue(value: any[], options: {onlySelf?: boolean, emitEvent?: boolean} = {}): void {
|
override setValue(value: any[], options: {onlySelf?: boolean, emitEvent?: boolean} = {}): void {
|
||||||
this._checkAllValuesPresent(value);
|
this._checkAllValuesPresent(value);
|
||||||
value.forEach((newValue: any, index: number) => {
|
value.forEach((newValue: any, index: number) => {
|
||||||
this._throwIfControlMissing(index);
|
this._throwIfControlMissing(index);
|
||||||
|
@ -2062,7 +2063,7 @@ export class FormArray extends AbstractControl {
|
||||||
* is updated. When false, no events are emitted. The configuration options are passed to
|
* is updated. When false, no events are emitted. The configuration options are passed to
|
||||||
* the {@link AbstractControl#updateValueAndValidity updateValueAndValidity} method.
|
* the {@link AbstractControl#updateValueAndValidity updateValueAndValidity} method.
|
||||||
*/
|
*/
|
||||||
patchValue(value: any[], options: {onlySelf?: boolean, emitEvent?: boolean} = {}): void {
|
override patchValue(value: any[], options: {onlySelf?: boolean, emitEvent?: boolean} = {}): void {
|
||||||
// Even though the `value` argument type doesn't allow `null` and `undefined` values, the
|
// Even though the `value` argument type doesn't allow `null` and `undefined` values, the
|
||||||
// `patchValue` can be called recursively and inner data structures might have these values, so
|
// `patchValue` can be called recursively and inner data structures might have these values, so
|
||||||
// we just ignore such cases when a field containing FormArray instance receives `null` or
|
// we just ignore such cases when a field containing FormArray instance receives `null` or
|
||||||
|
@ -2123,7 +2124,7 @@ export class FormArray extends AbstractControl {
|
||||||
* The configuration options are passed to the {@link AbstractControl#updateValueAndValidity
|
* The configuration options are passed to the {@link AbstractControl#updateValueAndValidity
|
||||||
* updateValueAndValidity} method.
|
* updateValueAndValidity} method.
|
||||||
*/
|
*/
|
||||||
reset(value: any = [], options: {onlySelf?: boolean, emitEvent?: boolean} = {}): void {
|
override reset(value: any = [], options: {onlySelf?: boolean, emitEvent?: boolean} = {}): void {
|
||||||
this._forEachChild((control: AbstractControl, index: number) => {
|
this._forEachChild((control: AbstractControl, index: number) => {
|
||||||
control.reset(value[index], {onlySelf: true, emitEvent: options.emitEvent});
|
control.reset(value[index], {onlySelf: true, emitEvent: options.emitEvent});
|
||||||
});
|
});
|
||||||
|
@ -2188,7 +2189,7 @@ export class FormArray extends AbstractControl {
|
||||||
}
|
}
|
||||||
|
|
||||||
/** @internal */
|
/** @internal */
|
||||||
_syncPendingControls(): boolean {
|
override _syncPendingControls(): boolean {
|
||||||
let subtreeUpdated = this.controls.reduce((updated: boolean, child: AbstractControl) => {
|
let subtreeUpdated = this.controls.reduce((updated: boolean, child: AbstractControl) => {
|
||||||
return child._syncPendingControls() ? true : updated;
|
return child._syncPendingControls() ? true : updated;
|
||||||
}, false);
|
}, false);
|
||||||
|
@ -2210,21 +2211,21 @@ export class FormArray extends AbstractControl {
|
||||||
}
|
}
|
||||||
|
|
||||||
/** @internal */
|
/** @internal */
|
||||||
_forEachChild(cb: Function): void {
|
override _forEachChild(cb: Function): void {
|
||||||
this.controls.forEach((control: AbstractControl, index: number) => {
|
this.controls.forEach((control: AbstractControl, index: number) => {
|
||||||
cb(control, index);
|
cb(control, index);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
/** @internal */
|
/** @internal */
|
||||||
_updateValue(): void {
|
override _updateValue(): void {
|
||||||
(this as {value: any}).value =
|
(this as {value: any}).value =
|
||||||
this.controls.filter((control) => control.enabled || this.disabled)
|
this.controls.filter((control) => control.enabled || this.disabled)
|
||||||
.map((control) => control.value);
|
.map((control) => control.value);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** @internal */
|
/** @internal */
|
||||||
_anyControls(condition: Function): boolean {
|
override _anyControls(condition: Function): boolean {
|
||||||
return this.controls.some((control: AbstractControl) => control.enabled && condition(control));
|
return this.controls.some((control: AbstractControl) => control.enabled && condition(control));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2243,7 +2244,7 @@ export class FormArray extends AbstractControl {
|
||||||
}
|
}
|
||||||
|
|
||||||
/** @internal */
|
/** @internal */
|
||||||
_allControlsDisabled(): boolean {
|
override _allControlsDisabled(): boolean {
|
||||||
for (const control of this.controls) {
|
for (const control of this.controls) {
|
||||||
if (control.enabled) return false;
|
if (control.enabled) return false;
|
||||||
}
|
}
|
||||||
|
|
|
@ -147,7 +147,7 @@ export interface TwoWayBindingContext {
|
||||||
* the key or value span of a node with key/value spans.
|
* the key or value span of a node with key/value spans.
|
||||||
*/
|
*/
|
||||||
class OutsideKeyValueMarkerAst extends e.AST {
|
class OutsideKeyValueMarkerAst extends e.AST {
|
||||||
visit(): null {
|
override visit(): null {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -87,9 +87,9 @@ abstract class BaseTemplate implements ng.TemplateSource {
|
||||||
* `template` attribute in the decorator.
|
* `template` attribute in the decorator.
|
||||||
*/
|
*/
|
||||||
export class InlineTemplate extends BaseTemplate {
|
export class InlineTemplate extends BaseTemplate {
|
||||||
public readonly fileName: string;
|
public override readonly fileName: string;
|
||||||
public readonly source: string;
|
public override readonly source: string;
|
||||||
public readonly span: ng.Span;
|
public override readonly span: ng.Span;
|
||||||
|
|
||||||
constructor(
|
constructor(
|
||||||
templateNode: ts.StringLiteralLike, classDeclNode: ts.ClassDeclaration,
|
templateNode: ts.StringLiteralLike, classDeclNode: ts.ClassDeclaration,
|
||||||
|
@ -119,7 +119,7 @@ export class InlineTemplate extends BaseTemplate {
|
||||||
* a TS file.
|
* a TS file.
|
||||||
*/
|
*/
|
||||||
export class ExternalTemplate extends BaseTemplate {
|
export class ExternalTemplate extends BaseTemplate {
|
||||||
public readonly span: ng.Span;
|
public override readonly span: ng.Span;
|
||||||
|
|
||||||
constructor(
|
constructor(
|
||||||
public readonly source: string, public readonly fileName: string,
|
public readonly source: string, public readonly fileName: string,
|
||||||
|
|
|
@ -32,7 +32,7 @@ export class DummyHtmlParser extends HtmlParser {
|
||||||
* Avoid loading resources in the language servcie by using a dummy loader.
|
* Avoid loading resources in the language servcie by using a dummy loader.
|
||||||
*/
|
*/
|
||||||
export class DummyResourceLoader extends ResourceLoader {
|
export class DummyResourceLoader extends ResourceLoader {
|
||||||
get(_url: string): Promise<string> {
|
override get(_url: string): Promise<string> {
|
||||||
return Promise.resolve('');
|
return Promise.resolve('');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -174,7 +174,7 @@ export class DiagnosticContext {
|
||||||
const pipeResolver = new PipeResolver(this.reflector);
|
const pipeResolver = new PipeResolver(this.reflector);
|
||||||
const elementSchemaRegistry = new DomElementSchemaRegistry();
|
const elementSchemaRegistry = new DomElementSchemaRegistry();
|
||||||
const resourceLoader = new class extends ResourceLoader {
|
const resourceLoader = new class extends ResourceLoader {
|
||||||
get(url: string): Promise<string> {
|
override get(url: string): Promise<string> {
|
||||||
return Promise.resolve('');
|
return Promise.resolve('');
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue