"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); const of_1 = require("rxjs/observable/of"); const operators_1 = require("rxjs/operators"); const filtered_1 = require("../tree/filtered"); const interface_1 = require("../tree/interface"); const static_1 = require("../tree/static"); const virtual_1 = require("../tree/virtual"); const call_1 = require("./call"); /** * A Source that returns an tree as its single value. */ function source(tree) { return () => tree; } exports.source = source; /** * A source that returns an empty tree. */ function empty() { return () => static_1.empty(); } exports.empty = empty; /** * Chain multiple rules into a single rule. */ function chain(rules) { return (tree, context) => { return rules.reduce((acc, curr) => { return call_1.callRule(curr, acc, context); }, of_1.of(tree)); }; } exports.chain = chain; /** * Apply multiple rules to a source, and returns the source transformed. */ function apply(source, rules) { return (context) => { return call_1.callRule(chain(rules), call_1.callSource(source, context), context); }; } exports.apply = apply; /** * Merge an input tree with the source passed in. */ function mergeWith(source, strategy = interface_1.MergeStrategy.Default) { return (tree, context) => { const result = call_1.callSource(source, context); return result.pipe(operators_1.map(other => virtual_1.VirtualTree.merge(tree, other, strategy || context.strategy))); }; } exports.mergeWith = mergeWith; function noop() { return (tree, _context) => tree; } exports.noop = noop; function filter(predicate) { return (tree) => new filtered_1.FilteredTree(tree, predicate); } exports.filter = filter; function asSource(rule) { return apply(empty(), [rule]); } exports.asSource = asSource; function branchAndMerge(rule, strategy = interface_1.MergeStrategy.Default) { return (tree, context) => { const branchedTree = static_1.branch(tree); return call_1.callRule(rule, of_1.of(branchedTree), context) .pipe(operators_1.map(t => static_1.merge(tree, t, strategy))); }; } exports.branchAndMerge = branchAndMerge; function when(predicate, operator) { return (entry) => { if (predicate(entry.path, entry)) { return operator(entry); } else { return entry; } }; } exports.when = when; function partitionApplyMerge(predicate, ruleYes, ruleNo) { return (tree, context) => { const [yes, no] = static_1.partition(tree, predicate); if (!ruleNo) { // Shortcut. return call_1.callRule(ruleYes, of_1.of(static_1.partition(tree, predicate)[0]), context) .pipe(operators_1.map(yesTree => static_1.merge(yesTree, no, context.strategy))); } return call_1.callRule(ruleYes, of_1.of(yes), context) .pipe(operators_1.concatMap(yesTree => { return call_1.callRule(ruleNo, of_1.of(no), context) .pipe(operators_1.map(noTree => static_1.merge(yesTree, noTree, context.strategy))); })); }; } exports.partitionApplyMerge = partitionApplyMerge; function forEach(operator) { return (tree) => { tree.visit((path, entry) => { if (!entry) { return; } const newEntry = operator(entry); if (newEntry === entry) { return; } if (newEntry === null) { tree.delete(path); return; } if (newEntry.path != path) { tree.rename(path, newEntry.path); } if (!newEntry.content.equals(entry.content)) { tree.overwrite(newEntry.path, newEntry.content); } }); return tree; }; } exports.forEach = forEach; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base.js","sourceRoot":"/Users/hansl/Sources/hansl/devkit/","sources":["packages/angular_devkit/schematics/src/rules/base.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 { Observable } from 'rxjs/Observable';\nimport { of as observableOf } from 'rxjs/observable/of';\nimport { concatMap, map } from 'rxjs/operators';\nimport { FileOperator, Rule, SchematicContext, Source } from '../engine/interface';\nimport { FilteredTree } from '../tree/filtered';\nimport { FileEntry, FilePredicate, MergeStrategy, Tree } from '../tree/interface';\nimport {\n  branch,\n  empty as staticEmpty,\n  merge as staticMerge,\n  partition as staticPartition,\n} from '../tree/static';\nimport { VirtualTree } from '../tree/virtual';\nimport { callRule, callSource } from './call';\n\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/**\n * A source that returns an empty tree.\n */\nexport function empty(): Source {\n  return () => staticEmpty();\n}\n\n\n/**\n * Chain multiple rules into a single rule.\n */\nexport function chain(rules: Rule[]): Rule {\n  return (tree: Tree, context: SchematicContext) => {\n    return rules.reduce((acc: Observable<Tree>, curr: Rule) => {\n      return callRule(curr, acc, context);\n    }, observableOf(tree));\n  };\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: SchematicContext) => {\n    return callRule(chain(rules), callSource(source, context), context);\n  };\n}\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: Tree, context: SchematicContext) => {\n    const result = callSource(source, context);\n\n    return result.pipe(map(other => VirtualTree.merge(tree, other, strategy || context.strategy)));\n  };\n}\n\n\nexport function noop(): Rule {\n  return (tree: Tree, _context: SchematicContext) => tree;\n}\n\n\nexport function filter(predicate: FilePredicate<boolean>): Rule {\n  return (tree: Tree) => new FilteredTree(tree, predicate);\n}\n\n\nexport function asSource(rule: Rule): Source {\n  return apply(empty(), [rule]);\n}\n\n\nexport function branchAndMerge(rule: Rule, strategy = MergeStrategy.Default): Rule {\n  return (tree: Tree, context: SchematicContext) => {\n    const branchedTree = branch(tree);\n\n    return callRule(rule, observableOf(branchedTree), context)\n      .pipe(map(t => staticMerge(tree, t, strategy)));\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\n\nexport function partitionApplyMerge(\n  predicate: FilePredicate<boolean>,\n  ruleYes: Rule,\n  ruleNo?: Rule,\n): Rule {\n  return (tree: Tree, context: SchematicContext) => {\n    const [yes, no] = staticPartition(tree, predicate);\n\n    if (!ruleNo) {\n      // Shortcut.\n      return callRule(ruleYes, observableOf(staticPartition(tree, predicate)[0]), context)\n        .pipe(map(yesTree => staticMerge(yesTree, no, context.strategy)));\n    }\n\n    return callRule(ruleYes, observableOf(yes), context)\n      .pipe(concatMap(yesTree => {\n        return callRule(ruleNo, observableOf(no), context)\n          .pipe(map(noTree => staticMerge(yesTree, noTree, context.strategy)));\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    return tree;\n  };\n}\n"]}