New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More →

@angular-devkit/schematics

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@angular-devkit/schematics - npm Package Compare versions

Comparing version

to
0.8.0-beta.0

{
"name": "@angular-devkit/schematics",
"version": "0.7.2",
"version": "0.8.0-beta.0",
"description": "Angular Schematics - Library",

@@ -21,3 +21,3 @@ "main": "src/index.js",

"dependencies": {
"@angular-devkit/core": "0.7.2",
"@angular-devkit/core": "0.8.0-beta.0",
"rxjs": "^6.0.0"

@@ -24,0 +24,0 @@ },

@@ -11,2 +11,3 @@ "use strict";

const core_1 = require("@angular-devkit/core");
const base_1 = require("./base");
function move(from, to) {

@@ -19,2 +20,5 @@ if (to === undefined) {

const toPath = core_1.normalize('/' + to);
if (fromPath === toPath) {
return base_1.noop;
}
return tree => tree.visit(path => {

@@ -27,2 +31,2 @@ if (path.startsWith(fromPath)) {

exports.move = move;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW92ZS5qcyIsInNvdXJjZVJvb3QiOiIuLyIsInNvdXJjZXMiOlsicGFja2FnZXMvYW5ndWxhcl9kZXZraXQvc2NoZW1hdGljcy9zcmMvcnVsZXMvbW92ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBOzs7Ozs7R0FNRztBQUNILCtDQUFpRDtBQUlqRCxjQUFxQixJQUFZLEVBQUUsRUFBVztJQUM1QyxFQUFFLENBQUMsQ0FBQyxFQUFFLEtBQUssU0FBUyxDQUFDLENBQUMsQ0FBQztRQUNyQixFQUFFLEdBQUcsSUFBSSxDQUFDO1FBQ1YsSUFBSSxHQUFHLEdBQUcsQ0FBQztJQUNiLENBQUM7SUFFRCxNQUFNLFFBQVEsR0FBRyxnQkFBUyxDQUFDLEdBQUcsR0FBRyxJQUFJLENBQUMsQ0FBQztJQUN2QyxNQUFNLE1BQU0sR0FBRyxnQkFBUyxDQUFDLEdBQUcsR0FBRyxFQUFFLENBQUMsQ0FBQztJQUVuQyxNQUFNLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxFQUFFO1FBQy9CLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQzlCLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxFQUFFLE1BQU0sR0FBRyxHQUFHLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQztRQUNqRSxDQUFDO0lBQ0gsQ0FBQyxDQUFDLENBQUM7QUFDTCxDQUFDO0FBZEQsb0JBY0MiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5pbXBvcnQgeyBub3JtYWxpemUgfSBmcm9tICdAYW5ndWxhci1kZXZraXQvY29yZSc7XG5pbXBvcnQgeyBSdWxlIH0gZnJvbSAnLi4vZW5naW5lL2ludGVyZmFjZSc7XG5cblxuZXhwb3J0IGZ1bmN0aW9uIG1vdmUoZnJvbTogc3RyaW5nLCB0bz86IHN0cmluZyk6IFJ1bGUge1xuICBpZiAodG8gPT09IHVuZGVmaW5lZCkge1xuICAgIHRvID0gZnJvbTtcbiAgICBmcm9tID0gJy8nO1xuICB9XG5cbiAgY29uc3QgZnJvbVBhdGggPSBub3JtYWxpemUoJy8nICsgZnJvbSk7XG4gIGNvbnN0IHRvUGF0aCA9IG5vcm1hbGl6ZSgnLycgKyB0byk7XG5cbiAgcmV0dXJuIHRyZWUgPT4gdHJlZS52aXNpdChwYXRoID0+IHtcbiAgICBpZiAocGF0aC5zdGFydHNXaXRoKGZyb21QYXRoKSkge1xuICAgICAgdHJlZS5yZW5hbWUocGF0aCwgdG9QYXRoICsgJy8nICsgcGF0aC5zdWJzdHIoZnJvbVBhdGgubGVuZ3RoKSk7XG4gICAgfVxuICB9KTtcbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW92ZS5qcyIsInNvdXJjZVJvb3QiOiIuLyIsInNvdXJjZXMiOlsicGFja2FnZXMvYW5ndWxhcl9kZXZraXQvc2NoZW1hdGljcy9zcmMvcnVsZXMvbW92ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBOzs7Ozs7R0FNRztBQUNILCtDQUFpRDtBQUVqRCxpQ0FBOEI7QUFHOUIsY0FBcUIsSUFBWSxFQUFFLEVBQVc7SUFDNUMsRUFBRSxDQUFDLENBQUMsRUFBRSxLQUFLLFNBQVMsQ0FBQyxDQUFDLENBQUM7UUFDckIsRUFBRSxHQUFHLElBQUksQ0FBQztRQUNWLElBQUksR0FBRyxHQUFHLENBQUM7SUFDYixDQUFDO0lBRUQsTUFBTSxRQUFRLEdBQUcsZ0JBQVMsQ0FBQyxHQUFHLEdBQUcsSUFBSSxDQUFDLENBQUM7SUFDdkMsTUFBTSxNQUFNLEdBQUcsZ0JBQVMsQ0FBQyxHQUFHLEdBQUcsRUFBRSxDQUFDLENBQUM7SUFFbkMsRUFBRSxDQUFDLENBQUMsUUFBUSxLQUFLLE1BQU0sQ0FBQyxDQUFDLENBQUM7UUFDeEIsTUFBTSxDQUFDLFdBQUksQ0FBQztJQUNkLENBQUM7SUFFRCxNQUFNLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxFQUFFO1FBQy9CLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQzlCLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxFQUFFLE1BQU0sR0FBRyxHQUFHLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQztRQUNqRSxDQUFDO0lBQ0gsQ0FBQyxDQUFDLENBQUM7QUFDTCxDQUFDO0FBbEJELG9CQWtCQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgSW5jLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cbmltcG9ydCB7IG5vcm1hbGl6ZSB9IGZyb20gJ0Bhbmd1bGFyLWRldmtpdC9jb3JlJztcbmltcG9ydCB7IFJ1bGUgfSBmcm9tICcuLi9lbmdpbmUvaW50ZXJmYWNlJztcbmltcG9ydCB7IG5vb3AgfSBmcm9tICcuL2Jhc2UnO1xuXG5cbmV4cG9ydCBmdW5jdGlvbiBtb3ZlKGZyb206IHN0cmluZywgdG8/OiBzdHJpbmcpOiBSdWxlIHtcbiAgaWYgKHRvID09PSB1bmRlZmluZWQpIHtcbiAgICB0byA9IGZyb207XG4gICAgZnJvbSA9ICcvJztcbiAgfVxuXG4gIGNvbnN0IGZyb21QYXRoID0gbm9ybWFsaXplKCcvJyArIGZyb20pO1xuICBjb25zdCB0b1BhdGggPSBub3JtYWxpemUoJy8nICsgdG8pO1xuXG4gIGlmIChmcm9tUGF0aCA9PT0gdG9QYXRoKSB7XG4gICAgcmV0dXJuIG5vb3A7XG4gIH1cblxuICByZXR1cm4gdHJlZSA9PiB0cmVlLnZpc2l0KHBhdGggPT4ge1xuICAgIGlmIChwYXRoLnN0YXJ0c1dpdGgoZnJvbVBhdGgpKSB7XG4gICAgICB0cmVlLnJlbmFtZShwYXRoLCB0b1BhdGggKyAnLycgKyBwYXRoLnN1YnN0cihmcm9tUGF0aC5sZW5ndGgpKTtcbiAgICB9XG4gIH0pO1xufVxuIl19

@@ -19,13 +19,16 @@ /**

}
export declare const kPathTemplateComponentRE: RegExp;
export declare const kPathTemplatePipeRE: RegExp;
export declare type TemplateValue = boolean | string | number | undefined;
export declare type TemplatePipeFunction = (x: string) => TemplateValue;
export declare type TemplateOptions = {
[key: string]: TemplateValue | TemplateOptions | TemplatePipeFunction;
export declare type PathTemplateValue = boolean | string | number | undefined;
export declare type PathTemplatePipeFunction = (x: string) => PathTemplateValue;
export declare type PathTemplateData = {
[key: string]: PathTemplateValue | PathTemplateData | PathTemplatePipeFunction;
};
export declare function applyContentTemplate<T extends TemplateOptions>(options: T): FileOperator;
export declare function contentTemplate<T extends TemplateOptions>(options: T): Rule;
export declare function applyPathTemplate<T extends TemplateOptions>(options: T): FileOperator;
export declare function pathTemplate<T extends TemplateOptions>(options: T): Rule;
export declare function template<T extends TemplateOptions>(options: T): Rule;
export interface PathTemplateOptions {
interpolationStart: string;
interpolationEnd: string;
pipeSeparator?: string;
}
export declare function applyContentTemplate<T>(options: T): FileOperator;
export declare function contentTemplate<T>(options: T): Rule;
export declare function applyPathTemplate<T extends PathTemplateData>(data: T, options?: PathTemplateOptions): FileOperator;
export declare function pathTemplate<T extends PathTemplateData>(options: T): Rule;
export declare function template<T>(options: T): Rule;

@@ -25,4 +25,2 @@ "use strict";

exports.InvalidPipeException = InvalidPipeException;
exports.kPathTemplateComponentRE = /__(.+?)__/g;
exports.kPathTemplatePipeRE = /@([^@]+)/;
function applyContentTemplate(options) {

@@ -45,3 +43,11 @@ return (entry) => {

exports.contentTemplate = contentTemplate;
function applyPathTemplate(options) {
function applyPathTemplate(data, options = {
interpolationStart: '__',
interpolationEnd: '__',
pipeSeparator: '@',
}) {
const is = options.interpolationStart;
const ie = options.interpolationEnd;
const isL = is.length;
const ieL = ie.length;
return (entry) => {

@@ -51,26 +57,45 @@ let path = entry.path;

const original = path;
// Path template.
path = core_1.normalize(path.replace(exports.kPathTemplateComponentRE, (_, match) => {
const [name, ...pipes] = match.split(exports.kPathTemplatePipeRE);
const value = typeof options[name] == 'function'
? options[name].call(options, original)
: options[name];
if (value === undefined) {
throw new OptionIsNotDefinedException(name);
let start = path.indexOf(is);
// + 1 to have at least a length 1 name. `____` is not valid.
let end = path.indexOf(ie, start + isL + 1);
while (start != -1 && end != -1) {
const match = path.substring(start + isL, end);
let replacement = data[match];
if (!options.pipeSeparator) {
if (typeof replacement == 'function') {
replacement = replacement.call(data, original);
}
if (replacement === undefined) {
throw new OptionIsNotDefinedException(match);
}
}
return pipes.reduce((acc, pipe) => {
if (!pipe) {
return acc;
else {
const [name, ...pipes] = match.split(options.pipeSeparator);
replacement = data[name];
if (typeof replacement == 'function') {
replacement = replacement.call(data, original);
}
if (!(pipe in options)) {
throw new UnknownPipeException(pipe);
if (replacement === undefined) {
throw new OptionIsNotDefinedException(name);
}
if (typeof options[pipe] != 'function') {
throw new InvalidPipeException(pipe);
}
// Coerce to string.
return '' + options[pipe](acc);
}, '' + value);
}));
return { path, content };
replacement = pipes.reduce((acc, pipe) => {
if (!pipe) {
return acc;
}
if (!(pipe in data)) {
throw new UnknownPipeException(pipe);
}
if (typeof data[pipe] != 'function') {
throw new InvalidPipeException(pipe);
}
// Coerce to string.
return '' + data[pipe](acc);
}, '' + replacement);
}
path = path.substring(0, start) + replacement + path.substring(end + ieL);
start = path.indexOf(options.interpolationStart);
// See above.
end = path.indexOf(options.interpolationEnd, start + isL + 1);
}
return { path: core_1.normalize(path), content };
};

@@ -86,2 +111,5 @@ }

contentTemplate(options),
// Force cast to PathTemplateData. We need the type for the actual pathTemplate() call,
// but in this case we cannot do anything as contentTemplate are more permissive.
// Since values are coerced to strings in PathTemplates it will be fine in the end.
pathTemplate(options),

@@ -91,2 +119,2 @@ ]);

exports.template = template;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVtcGxhdGUuanMiLCJzb3VyY2VSb290IjoiLi8iLCJzb3VyY2VzIjpbInBhY2thZ2VzL2FuZ3VsYXJfZGV2a2l0L3NjaGVtYXRpY3Mvc3JjL3J1bGVzL3RlbXBsYXRlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUE7Ozs7OztHQU1HO0FBQ0gsK0NBQTBGO0FBRzFGLGlDQUF3QztBQUN4QyxpREFBNkM7QUFHN0MsaUNBQXlDLFNBQVEsb0JBQWE7SUFDNUQsWUFBWSxJQUFZLElBQUksS0FBSyxDQUFDLFdBQVcsSUFBSSxtQkFBbUIsQ0FBQyxDQUFDLENBQUMsQ0FBQztDQUN6RTtBQUZELGtFQUVDO0FBR0QsMEJBQWtDLFNBQVEsb0JBQWE7SUFDckQsWUFBWSxJQUFZLElBQUksS0FBSyxDQUFDLFNBQVMsSUFBSSxtQkFBbUIsQ0FBQyxDQUFDLENBQUMsQ0FBQztDQUN2RTtBQUZELG9EQUVDO0FBR0QsMEJBQWtDLFNBQVEsb0JBQWE7SUFDckQsWUFBWSxJQUFZLElBQUksS0FBSyxDQUFDLFNBQVMsSUFBSSxlQUFlLENBQUMsQ0FBQyxDQUFDLENBQUM7Q0FDbkU7QUFGRCxvREFFQztBQUdZLFFBQUEsd0JBQXdCLEdBQUcsWUFBWSxDQUFDO0FBQ3hDLFFBQUEsbUJBQW1CLEdBQUcsVUFBVSxDQUFDO0FBVTlDLDhCQUFnRSxPQUFVO0lBQ3hFLE1BQU0sQ0FBQyxDQUFDLEtBQWdCLEVBQUUsRUFBRTtRQUMxQixNQUFNLEVBQUMsSUFBSSxFQUFFLE9BQU8sRUFBQyxHQUFHLEtBQUssQ0FBQztRQUM5QixFQUFFLENBQUMsQ0FBQyxvQkFBUSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUN0QixNQUFNLENBQUMsS0FBSyxDQUFDO1FBQ2YsQ0FBQztRQUVELE1BQU0sQ0FBQztZQUNMLElBQUksRUFBRSxJQUFJO1lBQ1YsT0FBTyxFQUFFLE1BQU0sQ0FBQyxJQUFJLENBQUMsZUFBWSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUM7U0FDM0UsQ0FBQztJQUNKLENBQUMsQ0FBQztBQUNKLENBQUM7QUFaRCxvREFZQztBQUdELHlCQUEyRCxPQUFVO0lBQ25FLE1BQU0sQ0FBQyxjQUFPLENBQUMsb0JBQW9CLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQztBQUNoRCxDQUFDO0FBRkQsMENBRUM7QUFHRCwyQkFBNkQsT0FBVTtJQUNyRSxNQUFNLENBQUMsQ0FBQyxLQUFnQixFQUFFLEVBQUU7UUFDMUIsSUFBSSxJQUFJLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQztRQUN0QixNQUFNLE9BQU8sR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDO1FBQzlCLE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQztRQUV0QixpQkFBaUI7UUFDakIsSUFBSSxHQUFHLGdCQUFTLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxnQ0FBd0IsRUFBRSxDQUFDLENBQUMsRUFBRSxLQUFLLEVBQUUsRUFBRTtZQUNuRSxNQUFNLENBQUMsSUFBSSxFQUFFLEdBQUcsS0FBSyxDQUFDLEdBQUcsS0FBSyxDQUFDLEtBQUssQ0FBQywyQkFBbUIsQ0FBQyxDQUFDO1lBQzFELE1BQU0sS0FBSyxHQUFHLE9BQU8sT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLFVBQVU7Z0JBQzlDLENBQUMsQ0FBRSxPQUFPLENBQUMsSUFBSSxDQUEwQixDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsUUFBUSxDQUFDO2dCQUNqRSxDQUFDLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO1lBRWxCLEVBQUUsQ0FBQyxDQUFDLEtBQUssS0FBSyxTQUFTLENBQUMsQ0FBQyxDQUFDO2dCQUN4QixNQUFNLElBQUksMkJBQTJCLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDOUMsQ0FBQztZQUVELE1BQU0sQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUMsR0FBVyxFQUFFLElBQVksRUFBRSxFQUFFO2dCQUNoRCxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7b0JBQ1YsTUFBTSxDQUFDLEdBQUcsQ0FBQztnQkFDYixDQUFDO2dCQUNELEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLElBQUksT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDO29CQUN2QixNQUFNLElBQUksb0JBQW9CLENBQUMsSUFBSSxDQUFDLENBQUM7Z0JBQ3ZDLENBQUM7Z0JBQ0QsRUFBRSxDQUFDLENBQUMsT0FBTyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksVUFBVSxDQUFDLENBQUMsQ0FBQztvQkFDdkMsTUFBTSxJQUFJLG9CQUFvQixDQUFDLElBQUksQ0FBQyxDQUFDO2dCQUN2QyxDQUFDO2dCQUVELG9CQUFvQjtnQkFDcEIsTUFBTSxDQUFDLEVBQUUsR0FBSSxPQUFPLENBQUMsSUFBSSxDQUEwQixDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQzNELENBQUMsRUFBRSxFQUFFLEdBQUcsS0FBSyxDQUFDLENBQUM7UUFDakIsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUVKLE1BQU0sQ0FBQyxFQUFFLElBQUksRUFBRSxPQUFPLEVBQUUsQ0FBQztJQUMzQixDQUFDLENBQUM7QUFDSixDQUFDO0FBbkNELDhDQW1DQztBQUdELHNCQUF3RCxPQUFVO0lBQ2hFLE1BQU0sQ0FBQyxjQUFPLENBQUMsaUJBQWlCLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQztBQUM3QyxDQUFDO0FBRkQsb0NBRUM7QUFHRCxrQkFBb0QsT0FBVTtJQUM1RCxNQUFNLENBQUMsWUFBSyxDQUFDO1FBQ1gsZUFBZSxDQUFDLE9BQU8sQ0FBQztRQUN4QixZQUFZLENBQUMsT0FBTyxDQUFDO0tBQ3RCLENBQUMsQ0FBQztBQUNMLENBQUM7QUFMRCw0QkFLQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgSW5jLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cbmltcG9ydCB7IEJhc2VFeGNlcHRpb24sIG5vcm1hbGl6ZSwgdGVtcGxhdGUgYXMgdGVtcGxhdGVJbXBsIH0gZnJvbSAnQGFuZ3VsYXItZGV2a2l0L2NvcmUnO1xuaW1wb3J0IHsgRmlsZU9wZXJhdG9yLCBSdWxlIH0gZnJvbSAnLi4vZW5naW5lL2ludGVyZmFjZSc7XG5pbXBvcnQgeyBGaWxlRW50cnkgfSBmcm9tICcuLi90cmVlL2ludGVyZmFjZSc7XG5pbXBvcnQgeyBjaGFpbiwgZm9yRWFjaCB9IGZyb20gJy4vYmFzZSc7XG5pbXBvcnQgeyBpc0JpbmFyeSB9IGZyb20gJy4vdXRpbHMvaXMtYmluYXJ5JztcblxuXG5leHBvcnQgY2xhc3MgT3B0aW9uSXNOb3REZWZpbmVkRXhjZXB0aW9uIGV4dGVuZHMgQmFzZUV4Y2VwdGlvbiB7XG4gIGNvbnN0cnVjdG9yKG5hbWU6IHN0cmluZykgeyBzdXBlcihgT3B0aW9uIFwiJHtuYW1lfVwiIGlzIG5vdCBkZWZpbmVkLmApOyB9XG59XG5cblxuZXhwb3J0IGNsYXNzIFVua25vd25QaXBlRXhjZXB0aW9uIGV4dGVuZHMgQmFzZUV4Y2VwdGlvbiB7XG4gIGNvbnN0cnVjdG9yKG5hbWU6IHN0cmluZykgeyBzdXBlcihgUGlwZSBcIiR7bmFtZX1cIiBpcyBub3QgZGVmaW5lZC5gKTsgfVxufVxuXG5cbmV4cG9ydCBjbGFzcyBJbnZhbGlkUGlwZUV4Y2VwdGlvbiBleHRlbmRzIEJhc2VFeGNlcHRpb24ge1xuICBjb25zdHJ1Y3RvcihuYW1lOiBzdHJpbmcpIHsgc3VwZXIoYFBpcGUgXCIke25hbWV9XCIgaXMgaW52YWxpZC5gKTsgfVxufVxuXG5cbmV4cG9ydCBjb25zdCBrUGF0aFRlbXBsYXRlQ29tcG9uZW50UkUgPSAvX18oLis/KV9fL2c7XG5leHBvcnQgY29uc3Qga1BhdGhUZW1wbGF0ZVBpcGVSRSA9IC9AKFteQF0rKS87XG5cblxuZXhwb3J0IHR5cGUgVGVtcGxhdGVWYWx1ZSA9IGJvb2xlYW4gfCBzdHJpbmcgfCBudW1iZXIgfCB1bmRlZmluZWQ7XG5leHBvcnQgdHlwZSBUZW1wbGF0ZVBpcGVGdW5jdGlvbiA9ICh4OiBzdHJpbmcpID0+IFRlbXBsYXRlVmFsdWU7XG5leHBvcnQgdHlwZSBUZW1wbGF0ZU9wdGlvbnMgPSB7XG4gIFtrZXk6IHN0cmluZ106IFRlbXBsYXRlVmFsdWUgfCBUZW1wbGF0ZU9wdGlvbnMgfCBUZW1wbGF0ZVBpcGVGdW5jdGlvbixcbn07XG5cblxuZXhwb3J0IGZ1bmN0aW9uIGFwcGx5Q29udGVudFRlbXBsYXRlPFQgZXh0ZW5kcyBUZW1wbGF0ZU9wdGlvbnM+KG9wdGlvbnM6IFQpOiBGaWxlT3BlcmF0b3Ige1xuICByZXR1cm4gKGVudHJ5OiBGaWxlRW50cnkpID0+IHtcbiAgICBjb25zdCB7cGF0aCwgY29udGVudH0gPSBlbnRyeTtcbiAgICBpZiAoaXNCaW5hcnkoY29udGVudCkpIHtcbiAgICAgIHJldHVybiBlbnRyeTtcbiAgICB9XG5cbiAgICByZXR1cm4ge1xuICAgICAgcGF0aDogcGF0aCxcbiAgICAgIGNvbnRlbnQ6IEJ1ZmZlci5mcm9tKHRlbXBsYXRlSW1wbChjb250ZW50LnRvU3RyaW5nKCd1dGYtOCcpLCB7fSkob3B0aW9ucykpLFxuICAgIH07XG4gIH07XG59XG5cblxuZXhwb3J0IGZ1bmN0aW9uIGNvbnRlbnRUZW1wbGF0ZTxUIGV4dGVuZHMgVGVtcGxhdGVPcHRpb25zPihvcHRpb25zOiBUKTogUnVsZSB7XG4gIHJldHVybiBmb3JFYWNoKGFwcGx5Q29udGVudFRlbXBsYXRlKG9wdGlvbnMpKTtcbn1cblxuXG5leHBvcnQgZnVuY3Rpb24gYXBwbHlQYXRoVGVtcGxhdGU8VCBleHRlbmRzIFRlbXBsYXRlT3B0aW9ucz4ob3B0aW9uczogVCk6IEZpbGVPcGVyYXRvciB7XG4gIHJldHVybiAoZW50cnk6IEZpbGVFbnRyeSkgPT4ge1xuICAgIGxldCBwYXRoID0gZW50cnkucGF0aDtcbiAgICBjb25zdCBjb250ZW50ID0gZW50cnkuY29udGVudDtcbiAgICBjb25zdCBvcmlnaW5hbCA9IHBhdGg7XG5cbiAgICAvLyBQYXRoIHRlbXBsYXRlLlxuICAgIHBhdGggPSBub3JtYWxpemUocGF0aC5yZXBsYWNlKGtQYXRoVGVtcGxhdGVDb21wb25lbnRSRSwgKF8sIG1hdGNoKSA9PiB7XG4gICAgICBjb25zdCBbbmFtZSwgLi4ucGlwZXNdID0gbWF0Y2guc3BsaXQoa1BhdGhUZW1wbGF0ZVBpcGVSRSk7XG4gICAgICBjb25zdCB2YWx1ZSA9IHR5cGVvZiBvcHRpb25zW25hbWVdID09ICdmdW5jdGlvbidcbiAgICAgICAgPyAob3B0aW9uc1tuYW1lXSBhcyBUZW1wbGF0ZVBpcGVGdW5jdGlvbikuY2FsbChvcHRpb25zLCBvcmlnaW5hbClcbiAgICAgICAgOiBvcHRpb25zW25hbWVdO1xuXG4gICAgICBpZiAodmFsdWUgPT09IHVuZGVmaW5lZCkge1xuICAgICAgICB0aHJvdyBuZXcgT3B0aW9uSXNOb3REZWZpbmVkRXhjZXB0aW9uKG5hbWUpO1xuICAgICAgfVxuXG4gICAgICByZXR1cm4gcGlwZXMucmVkdWNlKChhY2M6IHN0cmluZywgcGlwZTogc3RyaW5nKSA9PiB7XG4gICAgICAgIGlmICghcGlwZSkge1xuICAgICAgICAgIHJldHVybiBhY2M7XG4gICAgICAgIH1cbiAgICAgICAgaWYgKCEocGlwZSBpbiBvcHRpb25zKSkge1xuICAgICAgICAgIHRocm93IG5ldyBVbmtub3duUGlwZUV4Y2VwdGlvbihwaXBlKTtcbiAgICAgICAgfVxuICAgICAgICBpZiAodHlwZW9mIG9wdGlvbnNbcGlwZV0gIT0gJ2Z1bmN0aW9uJykge1xuICAgICAgICAgIHRocm93IG5ldyBJbnZhbGlkUGlwZUV4Y2VwdGlvbihwaXBlKTtcbiAgICAgICAgfVxuXG4gICAgICAgIC8vIENvZXJjZSB0byBzdHJpbmcuXG4gICAgICAgIHJldHVybiAnJyArIChvcHRpb25zW3BpcGVdIGFzIFRlbXBsYXRlUGlwZUZ1bmN0aW9uKShhY2MpO1xuICAgICAgfSwgJycgKyB2YWx1ZSk7XG4gICAgfSkpO1xuXG4gICAgcmV0dXJuIHsgcGF0aCwgY29udGVudCB9O1xuICB9O1xufVxuXG5cbmV4cG9ydCBmdW5jdGlvbiBwYXRoVGVtcGxhdGU8VCBleHRlbmRzIFRlbXBsYXRlT3B0aW9ucz4ob3B0aW9uczogVCk6IFJ1bGUge1xuICByZXR1cm4gZm9yRWFjaChhcHBseVBhdGhUZW1wbGF0ZShvcHRpb25zKSk7XG59XG5cblxuZXhwb3J0IGZ1bmN0aW9uIHRlbXBsYXRlPFQgZXh0ZW5kcyBUZW1wbGF0ZU9wdGlvbnM+KG9wdGlvbnM6IFQpOiBSdWxlIHtcbiAgcmV0dXJuIGNoYWluKFtcbiAgICBjb250ZW50VGVtcGxhdGUob3B0aW9ucyksXG4gICAgcGF0aFRlbXBsYXRlKG9wdGlvbnMpLFxuICBdKTtcbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"template.js","sourceRoot":"./","sources":["packages/angular_devkit/schematics/src/rules/template.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport { BaseException, normalize, template as templateImpl } from '@angular-devkit/core';\nimport { FileOperator, Rule } from '../engine/interface';\nimport { FileEntry } from '../tree/interface';\nimport { chain, forEach } from './base';\nimport { isBinary } from './utils/is-binary';\n\n\nexport class OptionIsNotDefinedException extends BaseException {\n  constructor(name: string) { super(`Option \"${name}\" is not defined.`); }\n}\n\n\nexport class UnknownPipeException extends BaseException {\n  constructor(name: string) { super(`Pipe \"${name}\" is not defined.`); }\n}\n\n\nexport class InvalidPipeException extends BaseException {\n  constructor(name: string) { super(`Pipe \"${name}\" is invalid.`); }\n}\n\n\nexport type PathTemplateValue = boolean | string | number | undefined;\nexport type PathTemplatePipeFunction = (x: string) => PathTemplateValue;\nexport type PathTemplateData = {\n  [key: string]: PathTemplateValue | PathTemplateData | PathTemplatePipeFunction,\n};\n\n\nexport interface PathTemplateOptions {\n  // Interpolation start and end strings.\n  interpolationStart: string;\n  // Interpolation start and end strings.\n  interpolationEnd: string;\n\n  // Separator for pipes. Do not specify to remove pipe support.\n  pipeSeparator?: string;\n}\n\n\nexport function applyContentTemplate<T>(options: T): FileOperator {\n  return (entry: FileEntry) => {\n    const {path, content} = entry;\n    if (isBinary(content)) {\n      return entry;\n    }\n\n    return {\n      path: path,\n      content: Buffer.from(templateImpl(content.toString('utf-8'), {})(options)),\n    };\n  };\n}\n\n\nexport function contentTemplate<T>(options: T): Rule {\n  return forEach(applyContentTemplate(options));\n}\n\n\nexport function applyPathTemplate<T extends PathTemplateData>(\n  data: T,\n  options: PathTemplateOptions = {\n    interpolationStart: '__',\n    interpolationEnd: '__',\n    pipeSeparator: '@',\n  },\n): FileOperator {\n  const is = options.interpolationStart;\n  const ie = options.interpolationEnd;\n  const isL = is.length;\n  const ieL = ie.length;\n\n  return (entry: FileEntry) => {\n    let path = entry.path as string;\n    const content = entry.content;\n    const original = path;\n\n    let start = path.indexOf(is);\n    // + 1 to have at least a length 1 name. `____` is not valid.\n    let end = path.indexOf(ie, start + isL + 1);\n\n    while (start != -1 && end != -1) {\n      const match = path.substring(start + isL, end);\n      let replacement = data[match];\n\n      if (!options.pipeSeparator) {\n        if (typeof replacement == 'function') {\n          replacement = replacement.call(data, original);\n        }\n\n        if (replacement === undefined) {\n          throw new OptionIsNotDefinedException(match);\n        }\n      } else {\n        const [name, ...pipes] = match.split(options.pipeSeparator);\n        replacement = data[name];\n\n        if (typeof replacement == 'function') {\n          replacement = replacement.call(data, original);\n        }\n\n        if (replacement === undefined) {\n          throw new OptionIsNotDefinedException(name);\n        }\n\n        replacement = pipes.reduce((acc: string, pipe: string) => {\n          if (!pipe) {\n            return acc;\n          }\n          if (!(pipe in data)) {\n            throw new UnknownPipeException(pipe);\n          }\n          if (typeof data[pipe] != 'function') {\n            throw new InvalidPipeException(pipe);\n          }\n\n          // Coerce to string.\n          return '' + (data[pipe] as PathTemplatePipeFunction)(acc);\n        }, '' + replacement);\n      }\n\n      path = path.substring(0, start) + replacement + path.substring(end + ieL);\n\n      start = path.indexOf(options.interpolationStart);\n      // See above.\n      end = path.indexOf(options.interpolationEnd, start + isL + 1);\n    }\n\n    return { path: normalize(path), content };\n  };\n}\n\n\nexport function pathTemplate<T extends PathTemplateData>(options: T): Rule {\n  return forEach(applyPathTemplate(options));\n}\n\n\nexport function template<T>(options: T): Rule {\n  return chain([\n    contentTemplate(options),\n    // Force cast to PathTemplateData. We need the type for the actual pathTemplate() call,\n    // but in this case we cannot do anything as contentTemplate are more permissive.\n    // Since values are coerced to strings in PathTemplates it will be fine in the end.\n    pathTemplate(options as {} as PathTemplateData),\n  ]);\n}\n"]}

@@ -19,5 +19,7 @@ "use strict";

else if (options.tslintPath) {
const tslintPath = path.join(root, options.tslintPath);
return Configuration.findConfiguration(tslintPath, file && path.join(root, file)).results;
return Configuration.findConfiguration(path.join(root, options.tslintPath)).results;
}
else if (file) {
return Configuration.findConfiguration(null, file).results;
}
else {

@@ -76,7 +78,10 @@ throw new Error('Executor must specify a tslint configuration.');

: (options.includes ? [options.includes] : []));
const files = (Array.isArray(options.files)
? options.files
: (options.files ? [options.files] : []));
const Linter = tslint.Linter;
const Configuration = tslint.Configuration;
let program = undefined;
let filesToLint = [];
if (options.tsConfigPath) {
let filesToLint = files;
if (options.tsConfigPath && files.length == 0) {
const tsConfigPath = path.join(process.cwd(), options.tsConfigPath);

@@ -113,4 +118,11 @@ if (!fs.existsSync(tsConfigPath)) {

const linter = new Linter(lintOptions, program);
const config = _loadConfiguration(Configuration, options, root);
// If directory doesn't change, we
let lastDirectory = null;
let config;
for (const file of filesToLint) {
const dir = path.dirname(file);
if (lastDirectory !== dir) {
lastDirectory = dir;
config = _loadConfiguration(Configuration, options, root, file);
}
const content = _getFileContent(file, options, program);

@@ -146,2 +158,2 @@ if (!content) {

exports.default = default_1;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"executor.js","sourceRoot":"./","sources":["packages/angular_devkit/schematics/tasks/tslint-fix/executor.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport { resolve } from '@angular-devkit/core/node';\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport { Observable } from 'rxjs';\nimport {\n  Configuration as ConfigurationNS,\n  Linter as LinterNS,\n} from 'tslint';  // tslint:disable-line:no-implicit-dependencies\nimport * as ts from 'typescript';  // tslint:disable-line:no-implicit-dependencies\nimport { SchematicContext, TaskExecutor } from '../../src';\nimport { TslintFixTaskOptions } from './options';\n\n\ntype ConfigurationT = typeof ConfigurationNS;\ntype LinterT = typeof LinterNS;\n\n\nfunction _loadConfiguration(\n  Configuration: ConfigurationT,\n  options: TslintFixTaskOptions,\n  root: string,\n  file?: string,\n) {\n  if (options.tslintConfig) {\n    return Configuration.parseConfigFile(options.tslintConfig, root);\n  } else if (options.tslintPath) {\n    const tslintPath = path.join(root, options.tslintPath);\n\n    return Configuration.findConfiguration(tslintPath, file && path.join(root, file)).results;\n  } else {\n    throw new Error('Executor must specify a tslint configuration.');\n  }\n}\n\n\nfunction _getFileContent(\n  file: string,\n  options: TslintFixTaskOptions,\n  program?: ts.Program,\n): string | undefined {\n  // The linter retrieves the SourceFile TS node directly if a program is used\n  if (program) {\n    const source = program.getSourceFile(file);\n    if (!source) {\n      const message\n        = `File '${file}' is not part of the TypeScript project '${options.tsConfigPath}'.`;\n      throw new Error(message);\n    }\n\n    return source.getFullText(source);\n  }\n\n  // NOTE: The tslint CLI checks for and excludes MPEG transport streams; this does not.\n  try {\n    // Strip BOM from file data.\n    // https://stackoverflow.com/questions/24356713\n    return fs.readFileSync(file, 'utf-8').replace(/^\\uFEFF/, '');\n  } catch {\n    throw new Error(`Could not read file '${file}'.`);\n  }\n}\n\n\nfunction _listAllFiles(root: string): string[] {\n  const result: string[] = [];\n\n  function _recurse(location: string) {\n    const dir = fs.readdirSync(path.join(root, location));\n\n    dir.forEach(name => {\n      const loc = path.join(location, name);\n      if (fs.statSync(path.join(root, loc)).isDirectory()) {\n        _recurse(loc);\n      } else {\n        result.push(loc);\n      }\n    });\n  }\n  _recurse('');\n\n  return result;\n}\n\n\nexport default function(): TaskExecutor<TslintFixTaskOptions> {\n  return (options: TslintFixTaskOptions, context: SchematicContext) => {\n    return new Observable(obs => {\n      const root = process.cwd();\n      const tslint = require(resolve('tslint', {\n        basedir: root,\n        checkGlobal: true,\n        checkLocal: true,\n      }));\n      const includes = (\n        Array.isArray(options.includes)\n          ? options.includes\n          : (options.includes ? [options.includes] : [])\n      );\n\n      const Linter = tslint.Linter as LinterT;\n      const Configuration = tslint.Configuration as ConfigurationT;\n      let program: ts.Program | undefined = undefined;\n      let filesToLint: string[] = [];\n\n      if (options.tsConfigPath) {\n        const tsConfigPath = path.join(process.cwd(), options.tsConfigPath);\n\n        if (!fs.existsSync(tsConfigPath)) {\n          obs.error(new Error('Could not find tsconfig.'));\n\n          return;\n        }\n        program = Linter.createProgram(tsConfigPath);\n        filesToLint = Linter.getFileNames(program);\n      }\n\n      if (includes.length > 0) {\n        const allFilesRel = _listAllFiles(root);\n        const pattern = '^('\n          + (includes as string[])\n            .map(ex => '('\n              + ex.split(/[\\/\\\\]/g).map(f => f\n                .replace(/[\\-\\[\\]{}()+?.^$|]/g, '\\\\$&')\n                .replace(/^\\*\\*/g, '(.+?)?')\n                .replace(/\\*/g, '[^/\\\\\\\\]*'))\n                .join('[\\/\\\\\\\\]')\n              + ')')\n            .join('|')\n          + ')($|/|\\\\\\\\)';\n        const re = new RegExp(pattern);\n\n        filesToLint.push(...allFilesRel\n          .filter(x => re.test(x))\n          .map(x => path.join(root, x)),\n        );\n      }\n\n      const lintOptions = {\n        fix: true,\n        formatter: options.format || 'prose',\n      };\n\n      const linter = new Linter(lintOptions, program);\n      const config = _loadConfiguration(Configuration, options, root);\n\n      for (const file of filesToLint) {\n        const content = _getFileContent(file, options, program);\n\n        if (!content) {\n          continue;\n        }\n\n        linter.lint(file, content, config);\n      }\n\n      const result = linter.getResult();\n\n      // Format and show the results.\n      if (!options.silent) {\n        const Formatter = tslint.findFormatter(options.format || 'prose');\n        if (!Formatter) {\n          throw new Error(`Invalid lint format \"${options.format}\".`);\n        }\n        const formatter = new Formatter();\n\n        const output = formatter.format(result.failures, result.fixes);\n        if (output) {\n          context.logger.info(output);\n        }\n      }\n\n      if (!options.ignoreErrors && result.errorCount > 0) {\n        obs.error(new Error('Lint errors were found.'));\n      } else {\n        obs.next();\n        obs.complete();\n      }\n    });\n  };\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"executor.js","sourceRoot":"./","sources":["packages/angular_devkit/schematics/tasks/tslint-fix/executor.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport { resolve } from '@angular-devkit/core/node';\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport { Observable } from 'rxjs';\nimport {\n  Configuration as ConfigurationNS,\n  Linter as LinterNS,\n} from 'tslint';  // tslint:disable-line:no-implicit-dependencies\nimport * as ts from 'typescript';  // tslint:disable-line:no-implicit-dependencies\nimport { SchematicContext, TaskExecutor } from '../../src';\nimport { TslintFixTaskOptions } from './options';\n\n\ntype ConfigurationT = typeof ConfigurationNS;\ntype LinterT = typeof LinterNS;\n\n\nfunction _loadConfiguration(\n  Configuration: ConfigurationT,\n  options: TslintFixTaskOptions,\n  root: string,\n  file?: string,\n) {\n  if (options.tslintConfig) {\n    return Configuration.parseConfigFile(options.tslintConfig, root);\n  } else if (options.tslintPath) {\n    return Configuration.findConfiguration(path.join(root, options.tslintPath)).results;\n  } else if (file) {\n    return Configuration.findConfiguration(null, file).results;\n  } else {\n    throw new Error('Executor must specify a tslint configuration.');\n  }\n}\n\n\nfunction _getFileContent(\n  file: string,\n  options: TslintFixTaskOptions,\n  program?: ts.Program,\n): string | undefined {\n  // The linter retrieves the SourceFile TS node directly if a program is used\n  if (program) {\n    const source = program.getSourceFile(file);\n    if (!source) {\n      const message\n        = `File '${file}' is not part of the TypeScript project '${options.tsConfigPath}'.`;\n      throw new Error(message);\n    }\n\n    return source.getFullText(source);\n  }\n\n  // NOTE: The tslint CLI checks for and excludes MPEG transport streams; this does not.\n  try {\n    // Strip BOM from file data.\n    // https://stackoverflow.com/questions/24356713\n    return fs.readFileSync(file, 'utf-8').replace(/^\\uFEFF/, '');\n  } catch {\n    throw new Error(`Could not read file '${file}'.`);\n  }\n}\n\n\nfunction _listAllFiles(root: string): string[] {\n  const result: string[] = [];\n\n  function _recurse(location: string) {\n    const dir = fs.readdirSync(path.join(root, location));\n\n    dir.forEach(name => {\n      const loc = path.join(location, name);\n      if (fs.statSync(path.join(root, loc)).isDirectory()) {\n        _recurse(loc);\n      } else {\n        result.push(loc);\n      }\n    });\n  }\n  _recurse('');\n\n  return result;\n}\n\n\nexport default function(): TaskExecutor<TslintFixTaskOptions> {\n  return (options: TslintFixTaskOptions, context: SchematicContext) => {\n    return new Observable(obs => {\n      const root = process.cwd();\n      const tslint = require(resolve('tslint', {\n        basedir: root,\n        checkGlobal: true,\n        checkLocal: true,\n      }));\n      const includes = (\n        Array.isArray(options.includes)\n          ? options.includes\n          : (options.includes ? [options.includes] : [])\n      );\n      const files = (\n        Array.isArray(options.files)\n          ? options.files\n          : (options.files ? [options.files] : [])\n      );\n\n      const Linter = tslint.Linter as LinterT;\n      const Configuration = tslint.Configuration as ConfigurationT;\n      let program: ts.Program | undefined = undefined;\n      let filesToLint: string[] = files;\n\n      if (options.tsConfigPath && files.length == 0) {\n        const tsConfigPath = path.join(process.cwd(), options.tsConfigPath);\n\n        if (!fs.existsSync(tsConfigPath)) {\n          obs.error(new Error('Could not find tsconfig.'));\n\n          return;\n        }\n        program = Linter.createProgram(tsConfigPath);\n        filesToLint = Linter.getFileNames(program);\n      }\n\n      if (includes.length > 0) {\n        const allFilesRel = _listAllFiles(root);\n        const pattern = '^('\n          + (includes as string[])\n            .map(ex => '('\n              + ex.split(/[\\/\\\\]/g).map(f => f\n                .replace(/[\\-\\[\\]{}()+?.^$|]/g, '\\\\$&')\n                .replace(/^\\*\\*/g, '(.+?)?')\n                .replace(/\\*/g, '[^/\\\\\\\\]*'))\n                .join('[\\/\\\\\\\\]')\n              + ')')\n            .join('|')\n          + ')($|/|\\\\\\\\)';\n        const re = new RegExp(pattern);\n\n        filesToLint.push(...allFilesRel\n          .filter(x => re.test(x))\n          .map(x => path.join(root, x)),\n        );\n      }\n\n      const lintOptions = {\n        fix: true,\n        formatter: options.format || 'prose',\n      };\n\n      const linter = new Linter(lintOptions, program);\n      // If directory doesn't change, we\n      let lastDirectory: string | null = null;\n      let config;\n\n      for (const file of filesToLint) {\n        const dir = path.dirname(file);\n        if (lastDirectory !== dir) {\n          lastDirectory = dir;\n          config = _loadConfiguration(Configuration, options, root, file);\n        }\n        const content = _getFileContent(file, options, program);\n\n        if (!content) {\n          continue;\n        }\n\n        linter.lint(file, content, config);\n      }\n\n      const result = linter.getResult();\n\n      // Format and show the results.\n      if (!options.silent) {\n        const Formatter = tslint.findFormatter(options.format || 'prose');\n        if (!Formatter) {\n          throw new Error(`Invalid lint format \"${options.format}\".`);\n        }\n        const formatter = new Formatter();\n\n        const output = formatter.format(result.failures, result.fixes);\n        if (output) {\n          context.logger.info(output);\n        }\n      }\n\n      if (!options.ignoreErrors && result.errorCount > 0) {\n        obs.error(new Error('Lint errors were found.'));\n      } else {\n        obs.next();\n        obs.complete();\n      }\n    });\n  };\n}\n"]}

@@ -16,11 +16,6 @@ /**

includes?: string | string[];
files?: string | string[];
tslintPath?: string;
tslintConfig?: JsonObject;
}
export interface TslintFixTaskOptionsPath extends TslintFixTaskOptionsBase {
tslintPath: string;
tslintConfig?: never;
}
export interface TslintFixTaskOptionsConfig extends TslintFixTaskOptionsBase {
tslintPath?: never;
tslintConfig: JsonObject;
}
export declare type TslintFixTaskOptions = TslintFixTaskOptionsPath | TslintFixTaskOptionsConfig;
export declare type TslintFixTaskOptions = TslintFixTaskOptionsBase;
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.TslintFixName = 'tslint-fix';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3B0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIuLyIsInNvdXJjZXMiOlsicGFja2FnZXMvYW5ndWxhcl9kZXZraXQvc2NoZW1hdGljcy90YXNrcy90c2xpbnQtZml4L29wdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFTYSxRQUFBLGFBQWEsR0FBRyxZQUFZLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5pbXBvcnQgeyBKc29uT2JqZWN0IH0gZnJvbSAnQGFuZ3VsYXItZGV2a2l0L2NvcmUnO1xuXG5leHBvcnQgY29uc3QgVHNsaW50Rml4TmFtZSA9ICd0c2xpbnQtZml4JztcblxuZXhwb3J0IGludGVyZmFjZSBUc2xpbnRGaXhUYXNrT3B0aW9uc0Jhc2Uge1xuICBzaWxlbnQ/OiBib29sZWFuO1xuICBmb3JtYXQ/OiBzdHJpbmc7XG4gIHRzQ29uZmlnUGF0aD86IHN0cmluZztcblxuICBpZ25vcmVFcnJvcnM/OiBib29sZWFuO1xuXG4gIGluY2x1ZGVzPzogc3RyaW5nIHwgc3RyaW5nW107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVHNsaW50Rml4VGFza09wdGlvbnNQYXRoIGV4dGVuZHMgVHNsaW50Rml4VGFza09wdGlvbnNCYXNlIHtcbiAgdHNsaW50UGF0aDogc3RyaW5nO1xuICB0c2xpbnRDb25maWc/OiBuZXZlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBUc2xpbnRGaXhUYXNrT3B0aW9uc0NvbmZpZyBleHRlbmRzIFRzbGludEZpeFRhc2tPcHRpb25zQmFzZSB7XG4gIHRzbGludFBhdGg/OiBuZXZlcjtcbiAgdHNsaW50Q29uZmlnOiBKc29uT2JqZWN0O1xufVxuXG5leHBvcnQgdHlwZSBUc2xpbnRGaXhUYXNrT3B0aW9ucyA9IFRzbGludEZpeFRhc2tPcHRpb25zUGF0aCB8IFRzbGludEZpeFRhc2tPcHRpb25zQ29uZmlnO1xuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3B0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIuLyIsInNvdXJjZXMiOlsicGFja2FnZXMvYW5ndWxhcl9kZXZraXQvc2NoZW1hdGljcy90YXNrcy90c2xpbnQtZml4L29wdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFTYSxRQUFBLGFBQWEsR0FBRyxZQUFZLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5pbXBvcnQgeyBKc29uT2JqZWN0IH0gZnJvbSAnQGFuZ3VsYXItZGV2a2l0L2NvcmUnO1xuXG5leHBvcnQgY29uc3QgVHNsaW50Rml4TmFtZSA9ICd0c2xpbnQtZml4JztcblxuZXhwb3J0IGludGVyZmFjZSBUc2xpbnRGaXhUYXNrT3B0aW9uc0Jhc2Uge1xuICBzaWxlbnQ/OiBib29sZWFuO1xuICBmb3JtYXQ/OiBzdHJpbmc7XG4gIHRzQ29uZmlnUGF0aD86IHN0cmluZztcblxuICBpZ25vcmVFcnJvcnM/OiBib29sZWFuO1xuXG4gIGluY2x1ZGVzPzogc3RyaW5nIHwgc3RyaW5nW107XG4gIGZpbGVzPzogc3RyaW5nIHwgc3RyaW5nW107XG5cbiAgdHNsaW50UGF0aD86IHN0cmluZztcbiAgdHNsaW50Q29uZmlnPzogSnNvbk9iamVjdDtcbn1cblxuZXhwb3J0IHR5cGUgVHNsaW50Rml4VGFza09wdGlvbnMgPSBUc2xpbnRGaXhUYXNrT3B0aW9uc0Jhc2U7XG4iXX0=

@@ -12,7 +12,8 @@ /**

export declare class TslintFixTask implements TaskConfigurationGenerator<TslintFixTaskOptions> {
protected _configOrPath: string | JsonObject;
protected _configOrPath: null | string | JsonObject;
protected _options: TslintFixTaskOptionsBase;
constructor(config: JsonObject, options: TslintFixTaskOptionsBase);
constructor(options: TslintFixTaskOptionsBase);
constructor(path: string, options: TslintFixTaskOptionsBase);
toConfiguration(): TaskConfiguration<TslintFixTaskOptions>;
}

@@ -5,10 +5,18 @@ "use strict";

class TslintFixTask {
constructor(_configOrPath, _options) {
this._configOrPath = _configOrPath;
this._options = _options;
constructor(configOrPath, options) {
if (options) {
this._configOrPath = configOrPath;
this._options = options;
}
else {
this._options = configOrPath;
this._configOrPath = null;
}
}
toConfiguration() {
const options = Object.assign({}, this._options, ((typeof this._configOrPath == 'string'
? { tslintPath: this._configOrPath }
: { tslintConfig: this._configOrPath })));
const path = typeof this._configOrPath == 'string' ? { tslintPath: this._configOrPath } : {};
const config = typeof this._configOrPath == 'object' && this._configOrPath !== null
? { tslintConfig: this._configOrPath }
: {};
const options = Object.assign({}, this._options, path, config);
return { name: options_1.TslintFixName, options };

@@ -18,2 +26,2 @@ }

exports.TslintFixTask = TslintFixTask;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFzay5qcyIsInNvdXJjZVJvb3QiOiIuLyIsInNvdXJjZXMiOlsicGFja2FnZXMvYW5ndWxhcl9kZXZraXQvc2NoZW1hdGljcy90YXNrcy90c2xpbnQtZml4L3Rhc2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFTQSx1Q0FBMEY7QUFHMUY7SUFHRSxZQUNZLGFBQWtDLEVBQ2xDLFFBQWtDO1FBRGxDLGtCQUFhLEdBQWIsYUFBYSxDQUFxQjtRQUNsQyxhQUFRLEdBQVIsUUFBUSxDQUEwQjtJQUMzQyxDQUFDO0lBRUosZUFBZTtRQUNiLE1BQU0sT0FBTyxxQkFDUixJQUFJLENBQUMsUUFBUSxFQUNiLENBQUMsQ0FBQyxPQUFPLElBQUksQ0FBQyxhQUFhLElBQUksUUFBUTtZQUN4QyxDQUFDLENBQUMsRUFBRSxVQUFVLEVBQUUsSUFBSSxDQUFDLGFBQWEsRUFBRTtZQUNwQyxDQUFDLENBQUMsRUFBRSxZQUFZLEVBQUUsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDLENBQUMsQ0FDM0MsQ0FBQztRQUVGLE1BQU0sQ0FBQyxFQUFFLElBQUksRUFBRSx1QkFBYSxFQUFFLE9BQU8sRUFBRSxDQUFDO0lBQzFDLENBQUM7Q0FDRjtBQWxCRCxzQ0FrQkMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5pbXBvcnQgeyBKc29uT2JqZWN0IH0gZnJvbSAnQGFuZ3VsYXItZGV2a2l0L2NvcmUnO1xuaW1wb3J0IHsgVGFza0NvbmZpZ3VyYXRpb24sIFRhc2tDb25maWd1cmF0aW9uR2VuZXJhdG9yIH0gZnJvbSAnLi4vLi4vc3JjJztcbmltcG9ydCB7IFRzbGludEZpeE5hbWUsIFRzbGludEZpeFRhc2tPcHRpb25zLCBUc2xpbnRGaXhUYXNrT3B0aW9uc0Jhc2UgfSBmcm9tICcuL29wdGlvbnMnO1xuXG5cbmV4cG9ydCBjbGFzcyBUc2xpbnRGaXhUYXNrIGltcGxlbWVudHMgVGFza0NvbmZpZ3VyYXRpb25HZW5lcmF0b3I8VHNsaW50Rml4VGFza09wdGlvbnM+IHtcbiAgY29uc3RydWN0b3IoY29uZmlnOiBKc29uT2JqZWN0LCBvcHRpb25zOiBUc2xpbnRGaXhUYXNrT3B0aW9uc0Jhc2UpO1xuICBjb25zdHJ1Y3RvcihwYXRoOiBzdHJpbmcsIG9wdGlvbnM6IFRzbGludEZpeFRhc2tPcHRpb25zQmFzZSk7XG4gIGNvbnN0cnVjdG9yKFxuICAgIHByb3RlY3RlZCBfY29uZmlnT3JQYXRoOiBzdHJpbmcgfCBKc29uT2JqZWN0LFxuICAgIHByb3RlY3RlZCBfb3B0aW9uczogVHNsaW50Rml4VGFza09wdGlvbnNCYXNlLFxuICApIHt9XG5cbiAgdG9Db25maWd1cmF0aW9uKCk6IFRhc2tDb25maWd1cmF0aW9uPFRzbGludEZpeFRhc2tPcHRpb25zPiB7XG4gICAgY29uc3Qgb3B0aW9ucyA9IHtcbiAgICAgIC4uLnRoaXMuX29wdGlvbnMsXG4gICAgICAuLi4oKHR5cGVvZiB0aGlzLl9jb25maWdPclBhdGggPT0gJ3N0cmluZydcbiAgICAgICAgPyB7IHRzbGludFBhdGg6IHRoaXMuX2NvbmZpZ09yUGF0aCB9XG4gICAgICAgIDogeyB0c2xpbnRDb25maWc6IHRoaXMuX2NvbmZpZ09yUGF0aCB9KSksXG4gICAgfTtcblxuICAgIHJldHVybiB7IG5hbWU6IFRzbGludEZpeE5hbWUsIG9wdGlvbnMgfTtcbiAgfVxufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFzay5qcyIsInNvdXJjZVJvb3QiOiIuLyIsInNvdXJjZXMiOlsicGFja2FnZXMvYW5ndWxhcl9kZXZraXQvc2NoZW1hdGljcy90YXNrcy90c2xpbnQtZml4L3Rhc2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFTQSx1Q0FBMEY7QUFHMUY7SUFPRSxZQUNFLFlBQTRELEVBQzVELE9BQWtDO1FBRWxDLEVBQUUsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUM7WUFDWixJQUFJLENBQUMsYUFBYSxHQUFHLFlBQW1DLENBQUM7WUFDekQsSUFBSSxDQUFDLFFBQVEsR0FBRyxPQUFPLENBQUM7UUFDMUIsQ0FBQztRQUFDLElBQUksQ0FBQyxDQUFDO1lBQ04sSUFBSSxDQUFDLFFBQVEsR0FBRyxZQUF3QyxDQUFDO1lBQ3pELElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDO1FBQzVCLENBQUM7SUFDSCxDQUFDO0lBRUQsZUFBZTtRQUNiLE1BQU0sSUFBSSxHQUFHLE9BQU8sSUFBSSxDQUFDLGFBQWEsSUFBSSxRQUFRLENBQUMsQ0FBQyxDQUFDLEVBQUUsVUFBVSxFQUFFLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO1FBQzdGLE1BQU0sTUFBTSxHQUFHLE9BQU8sSUFBSSxDQUFDLGFBQWEsSUFBSSxRQUFRLElBQUksSUFBSSxDQUFDLGFBQWEsS0FBSyxJQUFJO1lBQ3RFLENBQUMsQ0FBQyxFQUFFLFlBQVksRUFBRSxJQUFJLENBQUMsYUFBYSxFQUFFO1lBQ3RDLENBQUMsQ0FBQyxFQUFFLENBQUM7UUFDbEIsTUFBTSxPQUFPLHFCQUNSLElBQUksQ0FBQyxRQUFRLEVBQ2IsSUFBSSxFQUNKLE1BQU0sQ0FDVixDQUFDO1FBRUYsTUFBTSxDQUFDLEVBQUUsSUFBSSxFQUFFLHVCQUFhLEVBQUUsT0FBTyxFQUFFLENBQUM7SUFDMUMsQ0FBQztDQUNGO0FBakNELHNDQWlDQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgSW5jLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cbmltcG9ydCB7IEpzb25PYmplY3QgfSBmcm9tICdAYW5ndWxhci1kZXZraXQvY29yZSc7XG5pbXBvcnQgeyBUYXNrQ29uZmlndXJhdGlvbiwgVGFza0NvbmZpZ3VyYXRpb25HZW5lcmF0b3IgfSBmcm9tICcuLi8uLi9zcmMnO1xuaW1wb3J0IHsgVHNsaW50Rml4TmFtZSwgVHNsaW50Rml4VGFza09wdGlvbnMsIFRzbGludEZpeFRhc2tPcHRpb25zQmFzZSB9IGZyb20gJy4vb3B0aW9ucyc7XG5cblxuZXhwb3J0IGNsYXNzIFRzbGludEZpeFRhc2sgaW1wbGVtZW50cyBUYXNrQ29uZmlndXJhdGlvbkdlbmVyYXRvcjxUc2xpbnRGaXhUYXNrT3B0aW9ucz4ge1xuICBwcm90ZWN0ZWQgX2NvbmZpZ09yUGF0aDogbnVsbCB8IHN0cmluZyB8IEpzb25PYmplY3Q7XG4gIHByb3RlY3RlZCBfb3B0aW9uczogVHNsaW50Rml4VGFza09wdGlvbnNCYXNlO1xuXG4gIGNvbnN0cnVjdG9yKGNvbmZpZzogSnNvbk9iamVjdCwgb3B0aW9uczogVHNsaW50Rml4VGFza09wdGlvbnNCYXNlKTtcbiAgY29uc3RydWN0b3Iob3B0aW9uczogVHNsaW50Rml4VGFza09wdGlvbnNCYXNlKTtcbiAgY29uc3RydWN0b3IocGF0aDogc3RyaW5nLCBvcHRpb25zOiBUc2xpbnRGaXhUYXNrT3B0aW9uc0Jhc2UpO1xuICBjb25zdHJ1Y3RvcihcbiAgICBjb25maWdPclBhdGg6IHN0cmluZyB8IEpzb25PYmplY3QgfCBUc2xpbnRGaXhUYXNrT3B0aW9uc0Jhc2UsXG4gICAgb3B0aW9ucz86IFRzbGludEZpeFRhc2tPcHRpb25zQmFzZSxcbiAgKSB7XG4gICAgaWYgKG9wdGlvbnMpIHtcbiAgICAgIHRoaXMuX2NvbmZpZ09yUGF0aCA9IGNvbmZpZ09yUGF0aCBhcyBzdHJpbmcgfCBKc29uT2JqZWN0O1xuICAgICAgdGhpcy5fb3B0aW9ucyA9IG9wdGlvbnM7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMuX29wdGlvbnMgPSBjb25maWdPclBhdGggYXMgVHNsaW50Rml4VGFza09wdGlvbnNCYXNlO1xuICAgICAgdGhpcy5fY29uZmlnT3JQYXRoID0gbnVsbDtcbiAgICB9XG4gIH1cblxuICB0b0NvbmZpZ3VyYXRpb24oKTogVGFza0NvbmZpZ3VyYXRpb248VHNsaW50Rml4VGFza09wdGlvbnM+IHtcbiAgICBjb25zdCBwYXRoID0gdHlwZW9mIHRoaXMuX2NvbmZpZ09yUGF0aCA9PSAnc3RyaW5nJyA/IHsgdHNsaW50UGF0aDogdGhpcy5fY29uZmlnT3JQYXRoIH0gOiB7fTtcbiAgICBjb25zdCBjb25maWcgPSB0eXBlb2YgdGhpcy5fY29uZmlnT3JQYXRoID09ICdvYmplY3QnICYmIHRoaXMuX2NvbmZpZ09yUGF0aCAhPT0gbnVsbFxuICAgICAgICAgICAgICAgICA/IHsgdHNsaW50Q29uZmlnOiB0aGlzLl9jb25maWdPclBhdGggfVxuICAgICAgICAgICAgICAgICA6IHt9O1xuICAgIGNvbnN0IG9wdGlvbnMgPSB7XG4gICAgICAuLi50aGlzLl9vcHRpb25zLFxuICAgICAgLi4ucGF0aCxcbiAgICAgIC4uLmNvbmZpZyxcbiAgICB9O1xuXG4gICAgcmV0dXJuIHsgbmFtZTogVHNsaW50Rml4TmFtZSwgb3B0aW9ucyB9O1xuICB9XG59XG4iXX0=