UNPKG

18 kBJavaScriptView Raw
1"use strict";
2/**
3 * @license
4 * Copyright Google LLC All Rights Reserved.
5 *
6 * Use of this source code is governed by an MIT-style license that can be
7 * found in the LICENSE file at https://angular.io/license
8 */
9Object.defineProperty(exports, "__esModule", { value: true });
10exports.applyToSubtree = exports.composeFileOperators = exports.forEach = exports.partitionApplyMerge = exports.when = exports.branchAndMerge = exports.asSource = exports.filter = exports.noop = exports.mergeWith = exports.apply = exports.chain = exports.empty = exports.source = void 0;
11const rxjs_1 = require("rxjs");
12const operators_1 = require("rxjs/operators");
13const exception_1 = require("../exception/exception");
14const host_tree_1 = require("../tree/host-tree");
15const interface_1 = require("../tree/interface");
16const scoped_1 = require("../tree/scoped");
17const static_1 = require("../tree/static");
18const call_1 = require("./call");
19/**
20 * A Source that returns an tree as its single value.
21 */
22function source(tree) {
23 return () => tree;
24}
25exports.source = source;
26/**
27 * A source that returns an empty tree.
28 */
29function empty() {
30 return () => (0, static_1.empty)();
31}
32exports.empty = empty;
33/**
34 * Chain multiple rules into a single rule.
35 */
36function chain(rules) {
37 return async (initialTree, context) => {
38 let intermediateTree;
39 for await (const rule of rules) {
40 intermediateTree = (0, call_1.callRule)(rule, intermediateTree !== null && intermediateTree !== void 0 ? intermediateTree : initialTree, context);
41 }
42 return () => intermediateTree;
43 };
44}
45exports.chain = chain;
46/**
47 * Apply multiple rules to a source, and returns the source transformed.
48 */
49function apply(source, rules) {
50 return (context) => (0, call_1.callRule)(chain(rules), (0, call_1.callSource)(source, context), context);
51}
52exports.apply = apply;
53/**
54 * Merge an input tree with the source passed in.
55 */
56function mergeWith(source, strategy = interface_1.MergeStrategy.Default) {
57 return (tree, context) => {
58 return (0, call_1.callSource)(source, context).pipe((0, operators_1.map)((sourceTree) => tree.merge(sourceTree, strategy || context.strategy)), (0, operators_1.mapTo)(tree));
59 };
60}
61exports.mergeWith = mergeWith;
62function noop() {
63 return () => { };
64}
65exports.noop = noop;
66function filter(predicate) {
67 return (tree) => {
68 if (host_tree_1.HostTree.isHostTree(tree)) {
69 return new host_tree_1.FilterHostTree(tree, predicate);
70 }
71 else {
72 throw new exception_1.SchematicsException('Tree type is not supported.');
73 }
74 };
75}
76exports.filter = filter;
77function asSource(rule) {
78 return (context) => (0, call_1.callRule)(rule, (0, static_1.empty)(), context);
79}
80exports.asSource = asSource;
81function branchAndMerge(rule, strategy = interface_1.MergeStrategy.Default) {
82 return (tree, context) => {
83 return (0, call_1.callRule)(rule, tree.branch(), context).pipe((0, operators_1.map)((branch) => tree.merge(branch, strategy || context.strategy)), (0, operators_1.mapTo)(tree));
84 };
85}
86exports.branchAndMerge = branchAndMerge;
87function when(predicate, operator) {
88 return (entry) => {
89 if (predicate(entry.path, entry)) {
90 return operator(entry);
91 }
92 else {
93 return entry;
94 }
95 };
96}
97exports.when = when;
98function partitionApplyMerge(predicate, ruleYes, ruleNo) {
99 return (tree, context) => {
100 const [yes, no] = (0, static_1.partition)(tree, predicate);
101 return (0, rxjs_1.concat)((0, call_1.callRule)(ruleYes, yes, context), (0, call_1.callRule)(ruleNo || noop(), no, context)).pipe((0, operators_1.toArray)(), (0, operators_1.map)(([yesTree, noTree]) => {
102 yesTree.merge(noTree, context.strategy);
103 return yesTree;
104 }));
105 };
106}
107exports.partitionApplyMerge = partitionApplyMerge;
108function forEach(operator) {
109 return (tree) => {
110 tree.visit((path, entry) => {
111 if (!entry) {
112 return;
113 }
114 const newEntry = operator(entry);
115 if (newEntry === entry) {
116 return;
117 }
118 if (newEntry === null) {
119 tree.delete(path);
120 return;
121 }
122 if (newEntry.path != path) {
123 tree.rename(path, newEntry.path);
124 }
125 if (!newEntry.content.equals(entry.content)) {
126 tree.overwrite(newEntry.path, newEntry.content);
127 }
128 });
129 };
130}
131exports.forEach = forEach;
132function composeFileOperators(operators) {
133 return (entry) => {
134 let current = entry;
135 for (const op of operators) {
136 current = op(current);
137 if (current === null) {
138 // Deleted, just return.
139 return null;
140 }
141 }
142 return current;
143 };
144}
145exports.composeFileOperators = composeFileOperators;
146function applyToSubtree(path, rules) {
147 return (tree, context) => {
148 const scoped = new scoped_1.ScopedTree(tree, path);
149 return (0, call_1.callRule)(chain(rules), scoped, context).pipe((0, operators_1.map)((result) => {
150 if (result === scoped) {
151 return tree;
152 }
153 else {
154 throw new exception_1.SchematicsException('Original tree must be returned from all rules when using "applyToSubtree".');
155 }
156 }));
157 };
158}
159exports.applyToSubtree = applyToSubtree;
160//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base.js","sourceRoot":"","sources":["../../../../../../../../packages/angular_devkit/schematics/src/rules/base.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC 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 */\n\nimport { Observable, concat } from 'rxjs';\nimport { map, mapTo, toArray } from 'rxjs/operators';\nimport { FileOperator, Rule, Source } from '../engine/interface';\nimport { SchematicsException } from '../exception/exception';\nimport { FilterHostTree, HostTree } from '../tree/host-tree';\nimport { FileEntry, FilePredicate, MergeStrategy, Tree } from '../tree/interface';\nimport { ScopedTree } from '../tree/scoped';\nimport { partition, empty as staticEmpty } from '../tree/static';\nimport { callRule, callSource } from './call';\n\n/**\n * A Source that returns an tree as its single value.\n */\nexport function source(tree: Tree): Source {\n  return () => tree;\n}\n\n/**\n * A source that returns an empty tree.\n */\nexport function empty(): Source {\n  return () => staticEmpty();\n}\n\n/**\n * Chain multiple rules into a single rule.\n */\nexport function chain(rules: Iterable<Rule> | AsyncIterable<Rule>): Rule {\n  return async (initialTree, context) => {\n    let intermediateTree: Observable<Tree> | undefined;\n    for await (const rule of rules) {\n      intermediateTree = callRule(rule, intermediateTree ?? initialTree, context);\n    }\n\n    return () => intermediateTree;\n  };\n}\n\n/**\n * Apply multiple rules to a source, and returns the source transformed.\n */\nexport function apply(source: Source, rules: Rule[]): Source {\n  return (context) => callRule(chain(rules), callSource(source, context), context);\n}\n\n/**\n * Merge an input tree with the source passed in.\n */\nexport function mergeWith(source: Source, strategy: MergeStrategy = MergeStrategy.Default): Rule {\n  return (tree, context) => {\n    return callSource(source, context).pipe(\n      map((sourceTree) => tree.merge(sourceTree, strategy || context.strategy)),\n      mapTo(tree),\n    );\n  };\n}\n\nexport function noop(): Rule {\n  return () => {};\n}\n\nexport function filter(predicate: FilePredicate<boolean>): Rule {\n  return (tree: Tree) => {\n    if (HostTree.isHostTree(tree)) {\n      return new FilterHostTree(tree, predicate);\n    } else {\n      throw new SchematicsException('Tree type is not supported.');\n    }\n  };\n}\n\nexport function asSource(rule: Rule): Source {\n  return (context) => callRule(rule, staticEmpty(), context);\n}\n\nexport function branchAndMerge(rule: Rule, strategy = MergeStrategy.Default): Rule {\n  return (tree, context) => {\n    return callRule(rule, tree.branch(), context).pipe(\n      map((branch) => tree.merge(branch, strategy || context.strategy)),\n      mapTo(tree),\n    );\n  };\n}\n\nexport function when(predicate: FilePredicate<boolean>, operator: FileOperator): FileOperator {\n  return (entry: FileEntry) => {\n    if (predicate(entry.path, entry)) {\n      return operator(entry);\n    } else {\n      return entry;\n    }\n  };\n}\n\nexport function partitionApplyMerge(\n  predicate: FilePredicate<boolean>,\n  ruleYes: Rule,\n  ruleNo?: Rule,\n): Rule {\n  return (tree, context) => {\n    const [yes, no] = partition(tree, predicate);\n\n    return concat(callRule(ruleYes, yes, context), callRule(ruleNo || noop(), no, context)).pipe(\n      toArray(),\n      map(([yesTree, noTree]) => {\n        yesTree.merge(noTree, context.strategy);\n\n        return yesTree;\n      }),\n    );\n  };\n}\n\nexport function forEach(operator: FileOperator): Rule {\n  return (tree: Tree) => {\n    tree.visit((path, entry) => {\n      if (!entry) {\n        return;\n      }\n      const newEntry = operator(entry);\n      if (newEntry === entry) {\n        return;\n      }\n      if (newEntry === null) {\n        tree.delete(path);\n\n        return;\n      }\n      if (newEntry.path != path) {\n        tree.rename(path, newEntry.path);\n      }\n      if (!newEntry.content.equals(entry.content)) {\n        tree.overwrite(newEntry.path, newEntry.content);\n      }\n    });\n  };\n}\n\nexport function composeFileOperators(operators: FileOperator[]): FileOperator {\n  return (entry: FileEntry) => {\n    let current: FileEntry | null = entry;\n    for (const op of operators) {\n      current = op(current);\n\n      if (current === null) {\n        // Deleted, just return.\n        return null;\n      }\n    }\n\n    return current;\n  };\n}\n\nexport function applyToSubtree(path: string, rules: Rule[]): Rule {\n  return (tree, context) => {\n    const scoped = new ScopedTree(tree, path);\n\n    return callRule(chain(rules), scoped, context).pipe(\n      map((result) => {\n        if (result === scoped) {\n          return tree;\n        } else {\n          throw new SchematicsException(\n            'Original tree must be returned from all rules when using \"applyToSubtree\".',\n          );\n        }\n      }),\n    );\n  };\n}\n"]}
\No newline at end of file