| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556 |
- "use strict";
- var __extends = (this && this.__extends) || (function () {
- var extendStatics = function (d, b) {
- extendStatics = Object.setPrototypeOf ||
- ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
- function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
- return extendStatics(d, b);
- };
- return function (d, b) {
- extendStatics(d, b);
- function __() { this.constructor = d; }
- d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
- };
- })();
- Object.defineProperty(exports, "__esModule", { value: true });
- var lib_1 = require("tslint/lib");
- var typescript_1 = require("typescript/lib/typescript");
- var ngWalker_1 = require("./angular/ngWalker");
- var Rule = (function (_super) {
- __extends(Rule, _super);
- function Rule() {
- return _super !== null && _super.apply(this, arguments) || this;
- }
- Rule.prototype.apply = function (sourceFile) {
- var walker = new Walker(sourceFile, this.getOptions());
- return this.applyWithWalker(walker);
- };
- Rule.metadata = {
- description: 'Prefer to declare `@Output` as readonly since they are not supposed to be reassigned.',
- options: null,
- optionsDescription: 'Not configurable.',
- ruleName: 'prefer-output-readonly',
- type: 'maintainability',
- typescriptOnly: true
- };
- Rule.FAILURE_STRING = 'Prefer to declare `@Output` as readonly since they are not supposed to be reassigned';
- return Rule;
- }(lib_1.Rules.AbstractRule));
- exports.Rule = Rule;
- var Walker = (function (_super) {
- __extends(Walker, _super);
- function Walker() {
- return _super !== null && _super.apply(this, arguments) || this;
- }
- Walker.prototype.visitNgOutput = function (property, output, args) {
- this.validateOutput(property);
- _super.prototype.visitNgOutput.call(this, property, output, args);
- };
- Walker.prototype.validateOutput = function (property) {
- if (property.modifiers && property.modifiers.some(function (m) { return m.kind === typescript_1.SyntaxKind.ReadonlyKeyword; })) {
- return;
- }
- this.addFailureAtNode(property.name, Rule.FAILURE_STRING);
- };
- return Walker;
- }(ngWalker_1.NgWalker));
|