@angular-devkit/schematics 0.0.24 → 0.0.25
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bin/schematics.js +62 -17
- package/collection-schema.json +40 -0
- package/package.json +2 -2
- package/src/engine/engine.d.ts +6 -2
- package/src/engine/engine.js +22 -3
- package/src/engine/interface.d.ts +8 -4
- package/src/engine/interface.js +1 -1
- package/src/engine/schematic.d.ts +3 -3
- package/src/engine/schematic.js +8 -10
- package/src/rules/call.d.ts +1 -1
- package/src/rules/call.js +6 -3
- package/src/rules/schematic.js +3 -3
- package/src/rules/template.js +2 -3
- package/src/rules/url.js +2 -2
- package/tools/description.d.ts +3 -1
- package/tools/description.js +1 -1
- package/tools/fallback-engine-host.d.ts +34 -0
- package/tools/fallback-engine-host.js +52 -0
- package/tools/file-system-engine-host-base.d.ts +3 -0
- package/tools/file-system-engine-host-base.js +31 -9
- package/tools/file-system-utility.d.ts +1 -1
- package/tools/file-system-utility.js +3 -3
- package/tools/index.d.ts +2 -1
- package/tools/index.js +5 -3
- package/tools/node-module-engine-host.d.ts +3 -7
- package/tools/node-module-engine-host.js +48 -8
- package/tools/node-modules-test-engine-host.d.ts +17 -0
- package/tools/node-modules-test-engine-host.js +32 -0
- package/src/rules/template/template.d.ts +0 -16
- package/src/rules/template/template.js +0 -110
- package/test/index.d.ts +0 -8
- package/test/index.js +0 -14
- package/test/schematic-test-runner.d.ts +0 -21
- package/test/schematic-test-runner.js +0 -50
- package/tools/registry-engine-host.d.ts +0 -32
- package/tools/registry-engine-host.js +0 -95
package/bin/schematics.js
CHANGED
|
@@ -2,9 +2,9 @@
|
|
|
2
2
|
"use strict";
|
|
3
3
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
4
|
const core_1 = require("@angular-devkit/core");
|
|
5
|
+
const node_1 = require("@angular-devkit/core/node");
|
|
5
6
|
const schematics_1 = require("@angular-devkit/schematics");
|
|
6
7
|
const tools_1 = require("@angular-devkit/schematics/tools");
|
|
7
|
-
const json_schema_1 = require("@ngtools/json-schema");
|
|
8
8
|
const minimist = require("minimist");
|
|
9
9
|
const Observable_1 = require("rxjs/Observable");
|
|
10
10
|
require("rxjs/add/operator/ignoreElements");
|
|
@@ -12,21 +12,25 @@ require("rxjs/add/operator/ignoreElements");
|
|
|
12
12
|
* Show usage of the CLI tool, and exit the process.
|
|
13
13
|
*/
|
|
14
14
|
function usage(exitCode = 0) {
|
|
15
|
-
logger.info(`
|
|
15
|
+
logger.info(core_1.tags.stripIndent `
|
|
16
16
|
schematics [CollectionName:]SchematicName [options, ...]
|
|
17
17
|
|
|
18
18
|
By default, if the collection name is not specified, use the internal collection provided
|
|
19
19
|
by the Schematics CLI.
|
|
20
20
|
|
|
21
21
|
Options:
|
|
22
|
+
--debug Debug mode. This is true by default if the collection is a relative
|
|
23
|
+
path (in that case, turn off with --debug=false).
|
|
22
24
|
--dry-run Do not output anything, but instead just show what actions would be
|
|
23
|
-
performed.
|
|
25
|
+
performed. Default to true if debug is also true.
|
|
24
26
|
--force Force overwriting files that would otherwise be an error.
|
|
25
27
|
--list-schematics List all schematics from the collection, by name.
|
|
28
|
+
--verbose Show more information.
|
|
29
|
+
|
|
26
30
|
--help Show this message.
|
|
27
31
|
|
|
28
32
|
Any additional option is passed to the Schematics depending on
|
|
29
|
-
|
|
33
|
+
`);
|
|
30
34
|
process.exit(exitCode);
|
|
31
35
|
throw 0; // The node typing sometimes don't have a never type for process.exit().
|
|
32
36
|
}
|
|
@@ -59,28 +63,39 @@ function parseSchematicName(str) {
|
|
|
59
63
|
return { collection, schematic };
|
|
60
64
|
}
|
|
61
65
|
/** Parse the command line. */
|
|
66
|
+
const booleanArgs = ['debug', 'dry-run', 'force', 'help', 'list-schematics', 'verbose'];
|
|
62
67
|
const argv = minimist(process.argv.slice(2), {
|
|
63
|
-
boolean:
|
|
68
|
+
boolean: booleanArgs,
|
|
69
|
+
default: {
|
|
70
|
+
'debug': null,
|
|
71
|
+
'dry-run': null,
|
|
72
|
+
},
|
|
73
|
+
'--': true,
|
|
64
74
|
});
|
|
65
75
|
/** Create the DevKit Logger used through the CLI. */
|
|
66
|
-
const logger =
|
|
76
|
+
const logger = node_1.createConsoleLogger(argv['verbose']);
|
|
67
77
|
if (argv.help) {
|
|
68
78
|
usage();
|
|
69
79
|
}
|
|
70
80
|
/** Get the collection an schematic name from the first argument. */
|
|
71
81
|
const { collection: collectionName, schematic: schematicName, } = parseSchematicName(argv._.shift() || null);
|
|
82
|
+
const isLocalCollection = collectionName.startsWith('.') || collectionName.startsWith('/');
|
|
72
83
|
/**
|
|
73
84
|
* Create the SchematicEngine, which is used by the Schematic library as callbacks to load a
|
|
74
85
|
* Collection or a Schematic.
|
|
75
86
|
*/
|
|
76
87
|
const engineHost = new tools_1.NodeModulesEngineHost();
|
|
77
88
|
const engine = new schematics_1.SchematicEngine(engineHost);
|
|
89
|
+
const schemaRegistry = new core_1.schema.JsonSchemaRegistry();
|
|
78
90
|
// Add support for schemaJson.
|
|
79
91
|
engineHost.registerOptionsTransform((schematic, options) => {
|
|
80
92
|
if (schematic.schema && schematic.schemaJson) {
|
|
81
|
-
const
|
|
82
|
-
const
|
|
83
|
-
|
|
93
|
+
const schemaJson = schematic.schemaJson;
|
|
94
|
+
const ref = schemaJson.$id || ('/' + schematic.collection.name + '/' + schematic.name);
|
|
95
|
+
schemaRegistry.addSchema(ref, schemaJson);
|
|
96
|
+
const serializer = new core_1.schema.serializers.JavascriptSerializer();
|
|
97
|
+
const fn = serializer.serialize(ref, schemaRegistry);
|
|
98
|
+
return fn(options);
|
|
84
99
|
}
|
|
85
100
|
return options;
|
|
86
101
|
});
|
|
@@ -103,8 +118,9 @@ if (argv['list-schematics']) {
|
|
|
103
118
|
/** Create the schematic from the collection. */
|
|
104
119
|
const schematic = collection.createSchematic(schematicName);
|
|
105
120
|
/** Gather the arguments for later use. */
|
|
121
|
+
const debug = argv.debug === null ? isLocalCollection : argv.debug;
|
|
122
|
+
const dryRun = argv['dry-run'] === null ? debug : argv['dry-run'];
|
|
106
123
|
const force = argv['force'];
|
|
107
|
-
const dryRun = argv['dry-run'];
|
|
108
124
|
/** This host is the original Tree created from the current directory. */
|
|
109
125
|
const host = Observable_1.Observable.of(new schematics_1.FileSystemTree(new tools_1.FileSystemHost(process.cwd())));
|
|
110
126
|
// We need two sinks if we want to output what will happen, and actually do the work.
|
|
@@ -125,19 +141,39 @@ dryRunSink.reporter.subscribe((event) => {
|
|
|
125
141
|
error = true;
|
|
126
142
|
break;
|
|
127
143
|
case 'update':
|
|
128
|
-
loggingQueue.push(
|
|
144
|
+
loggingQueue.push(core_1.tags.oneLine `
|
|
145
|
+
${core_1.terminal.white('UPDATE')} ${event.path} (${event.content.length} bytes)
|
|
146
|
+
`);
|
|
129
147
|
break;
|
|
130
148
|
case 'create':
|
|
131
|
-
loggingQueue.push(
|
|
149
|
+
loggingQueue.push(core_1.tags.oneLine `
|
|
150
|
+
${core_1.terminal.green('CREATE')} ${event.path} (${event.content.length} bytes)
|
|
151
|
+
`);
|
|
132
152
|
break;
|
|
133
153
|
case 'delete':
|
|
134
|
-
loggingQueue.push(
|
|
154
|
+
loggingQueue.push(`${core_1.terminal.yellow('DELETE')} ${event.path}`);
|
|
135
155
|
break;
|
|
136
156
|
case 'rename':
|
|
137
|
-
loggingQueue.push(
|
|
157
|
+
loggingQueue.push(`${core_1.terminal.blue('RENAME')} ${event.path} => ${event.to}`);
|
|
138
158
|
break;
|
|
139
159
|
}
|
|
140
160
|
});
|
|
161
|
+
/**
|
|
162
|
+
* Remove every options from argv that we support in schematics itself.
|
|
163
|
+
*/
|
|
164
|
+
const args = Object.assign({}, argv);
|
|
165
|
+
delete args['--'];
|
|
166
|
+
for (const key of booleanArgs) {
|
|
167
|
+
delete args[key];
|
|
168
|
+
}
|
|
169
|
+
/**
|
|
170
|
+
* Add options from `--` to args.
|
|
171
|
+
*/
|
|
172
|
+
const argv2 = minimist(argv['--']);
|
|
173
|
+
for (const key of Object.keys(argv2)) {
|
|
174
|
+
args[key] = argv2[key];
|
|
175
|
+
}
|
|
176
|
+
delete args._;
|
|
141
177
|
/**
|
|
142
178
|
* The main path. Call the schematic with the host. This creates a new Context for the schematic
|
|
143
179
|
* to run in, then call the schematic rule using the input Tree. This returns a new Tree as if
|
|
@@ -150,7 +186,7 @@ dryRunSink.reporter.subscribe((event) => {
|
|
|
150
186
|
* Then we proceed to run the dryRun commit. We run this before we then commit to the filesystem
|
|
151
187
|
* (if --dry-run was not passed or an error was detected by dryRun).
|
|
152
188
|
*/
|
|
153
|
-
schematic.call(
|
|
189
|
+
schematic.call(args, host, { debug, logger: logger.asApi() })
|
|
154
190
|
.map((tree) => schematics_1.Tree.optimize(tree))
|
|
155
191
|
.concatMap((tree) => {
|
|
156
192
|
return dryRunSink.commit(tree).ignoreElements().concat(Observable_1.Observable.of(tree));
|
|
@@ -167,8 +203,17 @@ schematic.call(argv, host)
|
|
|
167
203
|
})
|
|
168
204
|
.subscribe({
|
|
169
205
|
error(err) {
|
|
170
|
-
|
|
206
|
+
// Add extra processing to output better error messages.
|
|
207
|
+
if (err instanceof core_1.schema.javascript.RequiredValueMissingException) {
|
|
208
|
+
logger.fatal('Missing argument on the command line: ' + err.path.split('/').pop());
|
|
209
|
+
}
|
|
210
|
+
else if (err instanceof core_1.schema.javascript.InvalidPropertyNameException) {
|
|
211
|
+
logger.fatal('A non-supported argument was passed: ' + err.path.split('/').pop());
|
|
212
|
+
}
|
|
213
|
+
else {
|
|
214
|
+
logger.fatal(err.message);
|
|
215
|
+
}
|
|
171
216
|
process.exit(1);
|
|
172
217
|
},
|
|
173
218
|
});
|
|
174
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"schematics.js","sourceRoot":"/Users/hansl/Sources/devkit/","sources":["packages/angular_devkit/schematics/bin/schematics.ts"],"names":[],"mappings":"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","sourcesContent":["#!/usr/bin/env node\n/**\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 { createLogger } from '@angular-devkit/core';\nimport {\n  DryRunEvent,\n  DryRunSink,\n  FileSystemSink,\n  FileSystemTree,\n  SchematicEngine,\n  Tree,\n} from '@angular-devkit/schematics';\nimport {\n  FileSystemHost,\n  FileSystemSchematicDesc,\n  NodeModulesEngineHost,\n} from '@angular-devkit/schematics/tools';\nimport { SchemaClassFactory } from '@ngtools/json-schema';\nimport * as minimist from 'minimist';\nimport { Observable } from 'rxjs/Observable';\nimport 'rxjs/add/operator/ignoreElements';\n\n\n/**\n * Show usage of the CLI tool, and exit the process.\n */\nfunction usage(exitCode = 0): never {\n  logger.info(`\n    schematics [CollectionName:]SchematicName [options, ...]\n\n    By default, if the collection name is not specified, use the internal collection provided\n    by the Schematics CLI.\n\n    Options:\n        --dry-run           Do not output anything, but instead just show what actions would be\n                            performed.\n        --force             Force overwriting files that would otherwise be an error.\n        --list-schematics   List all schematics from the collection, by name.\n        --help              Show this message.\n\n    Any additional option is passed to the Schematics depending on\n  `.replace(/^\\s\\s\\s\\s/g, ''));  // To remove the indentation.\n\n  process.exit(exitCode);\n  throw 0;  // The node typing sometimes don't have a never type for process.exit().\n}\n\n\n/**\n * Parse the name of schematic passed in argument, and return a {collection, schematic} named\n * tuple. The user can pass in `collection-name:schematic-name`, and this function will either\n * return `{collection: 'collection-name', schematic: 'schematic-name'}`, or it will error out\n * and show usage.\n *\n * In the case where a collection name isn't part of the argument, the default is to use this\n * package (@schematics/angular) as the collection.\n *\n * This logic is entirely up to the tooling.\n *\n * @param str The argument to parse.\n * @return {{collection: string, schematic: (string)}}\n */\nfunction parseSchematicName(str: string | null): { collection: string, schematic: string } {\n  let collection = '@schematics/angular';\n\n  if (!str || str === null) {\n    usage(1);\n  }\n\n  let schematic: string = str as string;\n  if (schematic.indexOf(':') != -1) {\n    [collection, schematic] = schematic.split(':', 2);\n\n    if (!schematic) {\n      usage(2);\n    }\n  }\n\n  return { collection, schematic };\n}\n\n\n/** Parse the command line. */\nconst argv = minimist(process.argv.slice(2), {\n  boolean: [ 'dry-run', 'force', 'help', 'list-schematics', 'verbose' ],\n});\n/** Create the DevKit Logger used through the CLI. */\nconst logger = createLogger(argv['verbose']);\n\nif (argv.help) {\n  usage();\n}\n\n/** Get the collection an schematic name from the first argument. */\nconst {\n  collection: collectionName,\n  schematic: schematicName,\n} = parseSchematicName(argv._.shift() || null);\n\n\n/**\n * Create the SchematicEngine, which is used by the Schematic library as callbacks to load a\n * Collection or a Schematic.\n */\nconst engineHost = new NodeModulesEngineHost();\nconst engine = new SchematicEngine(engineHost);\n\n// Add support for schemaJson.\nengineHost.registerOptionsTransform((schematic: FileSystemSchematicDesc, options: {}) => {\n  if (schematic.schema && schematic.schemaJson) {\n    const SchemaMetaClass = SchemaClassFactory<{}>(schematic.schemaJson);\n    const schemaClass = new SchemaMetaClass(options);\n\n    return schemaClass.$$root();\n  }\n\n  return options;\n});\n\n\n/**\n * The collection to be used.\n * @type {Collection|any}\n */\nconst collection = engine.createCollection(collectionName);\nif (collection === null) {\n  logger.fatal(`Invalid collection name: \"${collectionName}\".`);\n  process.exit(3);\n  throw 3;  // TypeScript doesn't know that process.exit() never returns.\n}\n\n\n/** If the user wants to list schematics, we simply show all the schematic names. */\nif (argv['list-schematics']) {\n  logger.info(engineHost.listSchematics(collection).join('\\n'));\n  process.exit(0);\n  throw 0;  // TypeScript doesn't know that process.exit() never returns.\n}\n\n\n/** Create the schematic from the collection. */\nconst schematic = collection.createSchematic(schematicName);\n\n/** Gather the arguments for later use. */\nconst force = argv['force'];\nconst dryRun = argv['dry-run'];\n\n/** This host is the original Tree created from the current directory. */\nconst host = Observable.of(new FileSystemTree(new FileSystemHost(process.cwd())));\n\n// We need two sinks if we want to output what will happen, and actually do the work.\n// Note that fsSink is technically not used if `--dry-run` is passed, but creating the Sink\n// does not have any side effect.\nconst dryRunSink = new DryRunSink(process.cwd(), force);\nconst fsSink = new FileSystemSink(process.cwd(), force);\n\n\n// We keep a boolean to tell us whether an error would occur if we were to commit to an\n// actual filesystem. In this case we simply show the dry-run, but skip the fsSink commit.\nlet error = false;\n\n\nconst loggingQueue: string[] = [];\n\n// Logs out dry run events.\ndryRunSink.reporter.subscribe((event: DryRunEvent) => {\n  switch (event.kind) {\n    case 'error':\n      const desc = event.description == 'alreadyExist' ? 'already exists' : 'does not exist.';\n      logger.warn(`ERROR! ${event.path} ${desc}.`);\n      error = true;\n      break;\n    case 'update':\n      loggingQueue.push(`UPDATE ${event.path} (${event.content.length} bytes)`);\n      break;\n    case 'create':\n      loggingQueue.push(`CREATE ${event.path} (${event.content.length} bytes)`);\n      break;\n    case 'delete':\n      loggingQueue.push(`DELETE ${event.path}`);\n      break;\n    case 'rename':\n      loggingQueue.push(`RENAME ${event.path} => ${event.to}`);\n      break;\n  }\n});\n\n\n/**\n * The main path. Call the schematic with the host. This creates a new Context for the schematic\n * to run in, then call the schematic rule using the input Tree. This returns a new Tree as if\n * the schematic was applied to it.\n *\n * We then optimize this tree. This removes any duplicated actions or actions that would result\n * in a noop (for example, creating then deleting a file). This is not necessary but will greatly\n * improve performance as hitting the file system is costly.\n *\n * Then we proceed to run the dryRun commit. We run this before we then commit to the filesystem\n * (if --dry-run was not passed or an error was detected by dryRun).\n */\nschematic.call(argv, host)\n  .map((tree: Tree) => Tree.optimize(tree))\n  .concatMap((tree: Tree) => {\n    return dryRunSink.commit(tree).ignoreElements().concat(Observable.of(tree));\n  })\n  .concatMap((tree: Tree) => {\n    if (!error) {\n      // Output the logging queue.\n      loggingQueue.forEach(log => logger.info(log));\n    }\n\n    if (dryRun || error) {\n      return Observable.of(tree);\n    }\n\n    return fsSink.commit(tree).ignoreElements().concat(Observable.of(tree));\n  })\n  .subscribe({\n    error(err: Error) {\n      logger.fatal(err.toString());\n      process.exit(1);\n    },\n  });\n"]}
|
|
219
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"schematics.js","sourceRoot":"/Users/hansl/Sources/devkit/","sources":["packages/angular_devkit/schematics/bin/schematics.ts"],"names":[],"mappings":";;;AAQA,+CAA8D;AAC9D,oDAAgE;AAChE,2DAOoC;AACpC,4DAI0C;AAC1C,qCAAqC;AACrC,gDAA6C;AAC7C,4CAA0C;AAG1C;;GAEG;AACH,eAAe,QAAQ,GAAG,CAAC;IACzB,MAAM,CAAC,IAAI,CAAC,WAAI,CAAC,WAAW,CAAA;;;;;;;;;;;;;;;;;;GAkB3B,CAAC,CAAC;IAEH,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACvB,MAAM,CAAC,CAAC,CAAE,wEAAwE;AACpF,CAAC;AAGD;;;;;;;;;;;;;GAaG;AACH,4BAA4B,GAAkB;IAC5C,IAAI,UAAU,GAAG,qBAAqB,CAAC;IAEvC,EAAE,CAAC,CAAC,CAAC,GAAG,IAAI,GAAG,KAAK,IAAI,CAAC,CAAC,CAAC;QACzB,KAAK,CAAC,CAAC,CAAC,CAAC;IACX,CAAC;IAED,IAAI,SAAS,GAAW,GAAa,CAAC;IACtC,EAAE,CAAC,CAAC,SAAS,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QACjC,CAAC,UAAU,EAAE,SAAS,CAAC,GAAG,SAAS,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;QAElD,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;YACf,KAAK,CAAC,CAAC,CAAC,CAAC;QACX,CAAC;IACH,CAAC;IAED,MAAM,CAAC,EAAE,UAAU,EAAE,SAAS,EAAE,CAAC;AACnC,CAAC;AAGD,8BAA8B;AAC9B,MAAM,WAAW,GAAG,CAAE,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,EAAE,iBAAiB,EAAE,SAAS,CAAE,CAAC;AAC1F,MAAM,IAAI,GAAG,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE;IAC3C,OAAO,EAAE,WAAW;IACpB,OAAO,EAAE;QACP,OAAO,EAAE,IAAI;QACb,SAAS,EAAE,IAAI;KAChB;IACD,IAAI,EAAE,IAAI;CACX,CAAC,CAAC;AAEH,qDAAqD;AACrD,MAAM,MAAM,GAAG,0BAAmB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;AAEpD,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IACd,KAAK,EAAE,CAAC;AACV,CAAC;AAED,oEAAoE;AACpE,MAAM,EACJ,UAAU,EAAE,cAAc,EAC1B,SAAS,EAAE,aAAa,GACzB,GAAG,kBAAkB,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,EAAE,IAAI,IAAI,CAAC,CAAC;AAC/C,MAAM,iBAAiB,GAAG,cAAc,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,cAAc,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;AAG3F;;;GAGG;AACH,MAAM,UAAU,GAAG,IAAI,6BAAqB,EAAE,CAAC;AAC/C,MAAM,MAAM,GAAG,IAAI,4BAAe,CAAC,UAAU,CAAC,CAAC;AAE/C,MAAM,cAAc,GAAG,IAAI,aAAM,CAAC,kBAAkB,EAAE,CAAC;AAEvD,8BAA8B;AAC9B,UAAU,CAAC,wBAAwB,CAAC,CAAC,SAAkC,EAAE,OAAW;IAClF,EAAE,CAAC,CAAC,SAAS,CAAC,MAAM,IAAI,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC;QAC7C,MAAM,UAAU,GAAG,SAAS,CAAC,UAAqC,CAAC;QACnE,MAAM,GAAG,GAAG,UAAU,CAAC,GAAG,IAAI,CAAC,GAAG,GAAG,SAAS,CAAC,UAAU,CAAC,IAAI,GAAG,GAAG,GAAG,SAAS,CAAC,IAAI,CAAC,CAAC;QACvF,cAAc,CAAC,SAAS,CAAC,GAAG,EAAE,UAAU,CAAC,CAAC;QAC1C,MAAM,UAAU,GAAG,IAAI,aAAM,CAAC,WAAW,CAAC,oBAAoB,EAAE,CAAC;QACjE,MAAM,EAAE,GAAG,UAAU,CAAC,SAAS,CAAC,GAAG,EAAE,cAAc,CAAC,CAAC;QAErD,MAAM,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC;IACrB,CAAC;IAED,MAAM,CAAC,OAAO,CAAC;AACjB,CAAC,CAAC,CAAC;AAGH;;;GAGG;AACH,MAAM,UAAU,GAAG,MAAM,CAAC,gBAAgB,CAAC,cAAc,CAAC,CAAC;AAC3D,EAAE,CAAC,CAAC,UAAU,KAAK,IAAI,CAAC,CAAC,CAAC;IACxB,MAAM,CAAC,KAAK,CAAC,6BAA6B,cAAc,IAAI,CAAC,CAAC;IAC9D,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAChB,MAAM,CAAC,CAAC,CAAE,6DAA6D;AACzE,CAAC;AAGD,oFAAoF;AACpF,EAAE,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC;IAC5B,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IAC9D,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAChB,MAAM,CAAC,CAAC,CAAE,6DAA6D;AACzE,CAAC;AAGD,gDAAgD;AAChD,MAAM,SAAS,GAAG,UAAU,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC;AAE5D,0CAA0C;AAC1C,MAAM,KAAK,GAAY,IAAI,CAAC,KAAK,KAAK,IAAI,GAAG,iBAAiB,GAAG,IAAI,CAAC,KAAK,CAAC;AAC5E,MAAM,MAAM,GAAY,IAAI,CAAC,SAAS,CAAC,KAAK,IAAI,GAAG,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC;AAC3E,MAAM,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC;AAE5B,yEAAyE;AACzE,MAAM,IAAI,GAAG,uBAAU,CAAC,EAAE,CAAC,IAAI,2BAAc,CAAC,IAAI,sBAAc,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC;AAElF,qFAAqF;AACrF,2FAA2F;AAC3F,iCAAiC;AACjC,MAAM,UAAU,GAAG,IAAI,uBAAU,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,KAAK,CAAC,CAAC;AACxD,MAAM,MAAM,GAAG,IAAI,2BAAc,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,KAAK,CAAC,CAAC;AAGxD,uFAAuF;AACvF,0FAA0F;AAC1F,IAAI,KAAK,GAAG,KAAK,CAAC;AAGlB,MAAM,YAAY,GAAa,EAAE,CAAC;AAElC,2BAA2B;AAC3B,UAAU,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,KAAkB;IAC/C,MAAM,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC;QACnB,KAAK,OAAO;YACV,MAAM,IAAI,GAAG,KAAK,CAAC,WAAW,IAAI,cAAc,GAAG,gBAAgB,GAAG,iBAAiB,CAAC;YACxF,MAAM,CAAC,IAAI,CAAC,UAAU,KAAK,CAAC,IAAI,IAAI,IAAI,GAAG,CAAC,CAAC;YAC7C,KAAK,GAAG,IAAI,CAAC;YACb,KAAK,CAAC;QACR,KAAK,QAAQ;YACX,YAAY,CAAC,IAAI,CAAC,WAAI,CAAC,OAAO,CAAA;UAC1B,eAAQ,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,KAAK,CAAC,IAAI,KAAK,KAAK,CAAC,OAAO,CAAC,MAAM;OAClE,CAAC,CAAC;YACH,KAAK,CAAC;QACR,KAAK,QAAQ;YACX,YAAY,CAAC,IAAI,CAAC,WAAI,CAAC,OAAO,CAAA;UAC1B,eAAQ,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,KAAK,CAAC,IAAI,KAAK,KAAK,CAAC,OAAO,CAAC,MAAM;OAClE,CAAC,CAAC;YACH,KAAK,CAAC;QACR,KAAK,QAAQ;YACX,YAAY,CAAC,IAAI,CAAC,GAAG,eAAQ,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC;YAChE,KAAK,CAAC;QACR,KAAK,QAAQ;YACX,YAAY,CAAC,IAAI,CAAC,GAAG,eAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,KAAK,CAAC,IAAI,OAAO,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC;YAC7E,KAAK,CAAC;IACV,CAAC;AACH,CAAC,CAAC,CAAC;AAGH;;GAEG;AACH,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;AACrC,OAAO,IAAI,CAAC,IAAI,CAAC,CAAC;AAClB,GAAG,CAAC,CAAC,MAAM,GAAG,IAAI,WAAW,CAAC,CAAC,CAAC;IAC9B,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC;AACnB,CAAC;AAED;;GAEG;AACH,MAAM,KAAK,GAAG,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;AACnC,GAAG,CAAC,CAAC,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IACrC,IAAI,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC;AACzB,CAAC;AACD,OAAO,IAAI,CAAC,CAAC,CAAC;AAGd;;;;;;;;;;;GAWG;AACH,SAAS,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,CAAC,KAAK,EAAE,EAAE,CAAC;KAC1D,GAAG,CAAC,CAAC,IAAU,KAAK,iBAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;KACxC,SAAS,CAAC,CAAC,IAAU;IACpB,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,cAAc,EAAE,CAAC,MAAM,CAAC,uBAAU,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;AAC9E,CAAC,CAAC;KACD,SAAS,CAAC,CAAC,IAAU;IACpB,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;QACX,4BAA4B;QAC5B,YAAY,CAAC,OAAO,CAAC,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;IAChD,CAAC;IAED,EAAE,CAAC,CAAC,MAAM,IAAI,KAAK,CAAC,CAAC,CAAC;QACpB,MAAM,CAAC,uBAAU,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC;IAC7B,CAAC;IAED,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,cAAc,EAAE,CAAC,MAAM,CAAC,uBAAU,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;AAC1E,CAAC,CAAC;KACD,SAAS,CAAC;IACT,KAAK,CAAC,GAAU;QACd,wDAAwD;QACxD,EAAE,CAAC,CAAC,GAAG,YAAY,aAAM,CAAC,UAAU,CAAC,6BAA6B,CAAC,CAAC,CAAC;YACnE,MAAM,CAAC,KAAK,CAAC,wCAAwC,GAAG,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC;QACrF,CAAC;QAAC,IAAI,CAAC,EAAE,CAAC,CAAC,GAAG,YAAY,aAAM,CAAC,UAAU,CAAC,4BAA4B,CAAC,CAAC,CAAC;YACzE,MAAM,CAAC,KAAK,CAAC,uCAAuC,GAAG,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC;QACpF,CAAC;QAAC,IAAI,CAAC,CAAC;YACN,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;QAC5B,CAAC;QACD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;CACF,CAAC,CAAC","sourcesContent":["#!/usr/bin/env node\n/**\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 { schema, tags, terminal } from '@angular-devkit/core';\nimport { createConsoleLogger } from '@angular-devkit/core/node';\nimport {\n  DryRunEvent,\n  DryRunSink,\n  FileSystemSink,\n  FileSystemTree,\n  SchematicEngine,\n  Tree,\n} from '@angular-devkit/schematics';\nimport {\n  FileSystemHost,\n  FileSystemSchematicDesc,\n  NodeModulesEngineHost,\n} from '@angular-devkit/schematics/tools';\nimport * as minimist from 'minimist';\nimport { Observable } from 'rxjs/Observable';\nimport 'rxjs/add/operator/ignoreElements';\n\n\n/**\n * Show usage of the CLI tool, and exit the process.\n */\nfunction usage(exitCode = 0): never {\n  logger.info(tags.stripIndent`\n    schematics [CollectionName:]SchematicName [options, ...]\n\n    By default, if the collection name is not specified, use the internal collection provided\n    by the Schematics CLI.\n\n    Options:\n        --debug             Debug mode. This is true by default if the collection is a relative\n                            path (in that case, turn off with --debug=false).\n        --dry-run           Do not output anything, but instead just show what actions would be\n                            performed. Default to true if debug is also true.\n        --force             Force overwriting files that would otherwise be an error.\n        --list-schematics   List all schematics from the collection, by name.\n        --verbose           Show more information.\n\n        --help              Show this message.\n\n    Any additional option is passed to the Schematics depending on\n  `);\n\n  process.exit(exitCode);\n  throw 0;  // The node typing sometimes don't have a never type for process.exit().\n}\n\n\n/**\n * Parse the name of schematic passed in argument, and return a {collection, schematic} named\n * tuple. The user can pass in `collection-name:schematic-name`, and this function will either\n * return `{collection: 'collection-name', schematic: 'schematic-name'}`, or it will error out\n * and show usage.\n *\n * In the case where a collection name isn't part of the argument, the default is to use this\n * package (@schematics/angular) as the collection.\n *\n * This logic is entirely up to the tooling.\n *\n * @param str The argument to parse.\n * @return {{collection: string, schematic: (string)}}\n */\nfunction parseSchematicName(str: string | null): { collection: string, schematic: string } {\n  let collection = '@schematics/angular';\n\n  if (!str || str === null) {\n    usage(1);\n  }\n\n  let schematic: string = str as string;\n  if (schematic.indexOf(':') != -1) {\n    [collection, schematic] = schematic.split(':', 2);\n\n    if (!schematic) {\n      usage(2);\n    }\n  }\n\n  return { collection, schematic };\n}\n\n\n/** Parse the command line. */\nconst booleanArgs = [ 'debug', 'dry-run', 'force', 'help', 'list-schematics', 'verbose' ];\nconst argv = minimist(process.argv.slice(2), {\n  boolean: booleanArgs,\n  default: {\n    'debug': null,\n    'dry-run': null,\n  },\n  '--': true,\n});\n\n/** Create the DevKit Logger used through the CLI. */\nconst logger = createConsoleLogger(argv['verbose']);\n\nif (argv.help) {\n  usage();\n}\n\n/** Get the collection an schematic name from the first argument. */\nconst {\n  collection: collectionName,\n  schematic: schematicName,\n} = parseSchematicName(argv._.shift() || null);\nconst isLocalCollection = collectionName.startsWith('.') || collectionName.startsWith('/');\n\n\n/**\n * Create the SchematicEngine, which is used by the Schematic library as callbacks to load a\n * Collection or a Schematic.\n */\nconst engineHost = new NodeModulesEngineHost();\nconst engine = new SchematicEngine(engineHost);\n\nconst schemaRegistry = new schema.JsonSchemaRegistry();\n\n// Add support for schemaJson.\nengineHost.registerOptionsTransform((schematic: FileSystemSchematicDesc, options: {}) => {\n  if (schematic.schema && schematic.schemaJson) {\n    const schemaJson = schematic.schemaJson as schema.JsonSchemaObject;\n    const ref = schemaJson.$id || ('/' + schematic.collection.name + '/' + schematic.name);\n    schemaRegistry.addSchema(ref, schemaJson);\n    const serializer = new schema.serializers.JavascriptSerializer();\n    const fn = serializer.serialize(ref, schemaRegistry);\n\n    return fn(options);\n  }\n\n  return options;\n});\n\n\n/**\n * The collection to be used.\n * @type {Collection|any}\n */\nconst collection = engine.createCollection(collectionName);\nif (collection === null) {\n  logger.fatal(`Invalid collection name: \"${collectionName}\".`);\n  process.exit(3);\n  throw 3;  // TypeScript doesn't know that process.exit() never returns.\n}\n\n\n/** If the user wants to list schematics, we simply show all the schematic names. */\nif (argv['list-schematics']) {\n  logger.info(engineHost.listSchematics(collection).join('\\n'));\n  process.exit(0);\n  throw 0;  // TypeScript doesn't know that process.exit() never returns.\n}\n\n\n/** Create the schematic from the collection. */\nconst schematic = collection.createSchematic(schematicName);\n\n/** Gather the arguments for later use. */\nconst debug: boolean = argv.debug === null ? isLocalCollection : argv.debug;\nconst dryRun: boolean = argv['dry-run'] === null ? debug : argv['dry-run'];\nconst force = argv['force'];\n\n/** This host is the original Tree created from the current directory. */\nconst host = Observable.of(new FileSystemTree(new FileSystemHost(process.cwd())));\n\n// We need two sinks if we want to output what will happen, and actually do the work.\n// Note that fsSink is technically not used if `--dry-run` is passed, but creating the Sink\n// does not have any side effect.\nconst dryRunSink = new DryRunSink(process.cwd(), force);\nconst fsSink = new FileSystemSink(process.cwd(), force);\n\n\n// We keep a boolean to tell us whether an error would occur if we were to commit to an\n// actual filesystem. In this case we simply show the dry-run, but skip the fsSink commit.\nlet error = false;\n\n\nconst loggingQueue: string[] = [];\n\n// Logs out dry run events.\ndryRunSink.reporter.subscribe((event: DryRunEvent) => {\n  switch (event.kind) {\n    case 'error':\n      const desc = event.description == 'alreadyExist' ? 'already exists' : 'does not exist.';\n      logger.warn(`ERROR! ${event.path} ${desc}.`);\n      error = true;\n      break;\n    case 'update':\n      loggingQueue.push(tags.oneLine`\n        ${terminal.white('UPDATE')} ${event.path} (${event.content.length} bytes)\n      `);\n      break;\n    case 'create':\n      loggingQueue.push(tags.oneLine`\n        ${terminal.green('CREATE')} ${event.path} (${event.content.length} bytes)\n      `);\n      break;\n    case 'delete':\n      loggingQueue.push(`${terminal.yellow('DELETE')} ${event.path}`);\n      break;\n    case 'rename':\n      loggingQueue.push(`${terminal.blue('RENAME')} ${event.path} => ${event.to}`);\n      break;\n  }\n});\n\n\n/**\n * Remove every options from argv that we support in schematics itself.\n */\nconst args = Object.assign({}, argv);\ndelete args['--'];\nfor (const key of booleanArgs) {\n  delete args[key];\n}\n\n/**\n * Add options from `--` to args.\n */\nconst argv2 = minimist(argv['--']);\nfor (const key of Object.keys(argv2)) {\n  args[key] = argv2[key];\n}\ndelete args._;\n\n\n/**\n * The main path. Call the schematic with the host. This creates a new Context for the schematic\n * to run in, then call the schematic rule using the input Tree. This returns a new Tree as if\n * the schematic was applied to it.\n *\n * We then optimize this tree. This removes any duplicated actions or actions that would result\n * in a noop (for example, creating then deleting a file). This is not necessary but will greatly\n * improve performance as hitting the file system is costly.\n *\n * Then we proceed to run the dryRun commit. We run this before we then commit to the filesystem\n * (if --dry-run was not passed or an error was detected by dryRun).\n */\nschematic.call(args, host, { debug, logger: logger.asApi() })\n  .map((tree: Tree) => Tree.optimize(tree))\n  .concatMap((tree: Tree) => {\n    return dryRunSink.commit(tree).ignoreElements().concat(Observable.of(tree));\n  })\n  .concatMap((tree: Tree) => {\n    if (!error) {\n      // Output the logging queue.\n      loggingQueue.forEach(log => logger.info(log));\n    }\n\n    if (dryRun || error) {\n      return Observable.of(tree);\n    }\n\n    return fsSink.commit(tree).ignoreElements().concat(Observable.of(tree));\n  })\n  .subscribe({\n    error(err: Error) {\n      // Add extra processing to output better error messages.\n      if (err instanceof schema.javascript.RequiredValueMissingException) {\n        logger.fatal('Missing argument on the command line: ' + err.path.split('/').pop());\n      } else if (err instanceof schema.javascript.InvalidPropertyNameException) {\n        logger.fatal('A non-supported argument was passed: ' + err.path.split('/').pop());\n      } else {\n        logger.fatal(err.message);\n      }\n      process.exit(1);\n    },\n  });\n"]}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/schema",
|
|
3
|
+
"id": "SchematicsCollectionSchema",
|
|
4
|
+
"title": "Collection Schema for validating a 'collection.json'.",
|
|
5
|
+
"type": "object",
|
|
6
|
+
"properties": {
|
|
7
|
+
"schematics": {
|
|
8
|
+
"type": "object",
|
|
9
|
+
"properties": {
|
|
10
|
+
"additionalProperty": {
|
|
11
|
+
"type": "object",
|
|
12
|
+
"properties": {
|
|
13
|
+
"factory": {
|
|
14
|
+
"type": "string"
|
|
15
|
+
},
|
|
16
|
+
"description": {
|
|
17
|
+
"type": "string"
|
|
18
|
+
},
|
|
19
|
+
"extends": {
|
|
20
|
+
"type": "string"
|
|
21
|
+
},
|
|
22
|
+
"schema": {
|
|
23
|
+
"type": "string"
|
|
24
|
+
}
|
|
25
|
+
},
|
|
26
|
+
"required": [
|
|
27
|
+
"factory",
|
|
28
|
+
"description"
|
|
29
|
+
]
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
},
|
|
33
|
+
"version": {
|
|
34
|
+
"type": "string"
|
|
35
|
+
}
|
|
36
|
+
},
|
|
37
|
+
"required": [
|
|
38
|
+
"schematics"
|
|
39
|
+
]
|
|
40
|
+
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@angular-devkit/schematics",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.25",
|
|
4
4
|
"description": "Angular Schematics - Library",
|
|
5
5
|
"bin": {
|
|
6
6
|
"schematics": "./bin/schematics.js"
|
|
@@ -20,7 +20,7 @@
|
|
|
20
20
|
"schematics"
|
|
21
21
|
],
|
|
22
22
|
"dependencies": {
|
|
23
|
-
"@angular-devkit/core": "0.0.
|
|
23
|
+
"@angular-devkit/core": "0.0.15",
|
|
24
24
|
"@ngtools/json-schema": "^1.1.0",
|
|
25
25
|
"minimist": "^1.2.0",
|
|
26
26
|
"rxjs": "^5.4.2"
|
package/src/engine/engine.d.ts
CHANGED
|
@@ -7,7 +7,7 @@
|
|
|
7
7
|
* found in the LICENSE file at https://angular.io/license
|
|
8
8
|
*/
|
|
9
9
|
import { BaseException } from '@angular-devkit/core';
|
|
10
|
-
import { CollectionDescription } from '@angular-devkit/schematics';
|
|
10
|
+
import { CollectionDescription, TypedSchematicContext } from '@angular-devkit/schematics';
|
|
11
11
|
import 'rxjs/add/operator/map';
|
|
12
12
|
import { Url } from 'url';
|
|
13
13
|
import { MergeStrategy } from '../tree/interface';
|
|
@@ -21,6 +21,9 @@ export declare class UnknownCollectionException extends BaseException {
|
|
|
21
21
|
export declare class UnknownSchematicException extends BaseException {
|
|
22
22
|
constructor(name: string, collection: CollectionDescription<{}>);
|
|
23
23
|
}
|
|
24
|
+
export declare class SchematicEngineConflictingException extends BaseException {
|
|
25
|
+
constructor();
|
|
26
|
+
}
|
|
24
27
|
export declare class SchematicEngine<CollectionT extends object, SchematicT extends object> implements Engine<CollectionT, SchematicT> {
|
|
25
28
|
private _host;
|
|
26
29
|
private _collectionCache;
|
|
@@ -28,7 +31,8 @@ export declare class SchematicEngine<CollectionT extends object, SchematicT exte
|
|
|
28
31
|
constructor(_host: EngineHost<CollectionT, SchematicT>);
|
|
29
32
|
readonly defaultMergeStrategy: MergeStrategy;
|
|
30
33
|
createCollection(name: string): Collection<CollectionT, SchematicT>;
|
|
34
|
+
createContext(schematic: Schematic<CollectionT, SchematicT>, parent?: Partial<TypedSchematicContext<CollectionT, SchematicT>>): TypedSchematicContext<CollectionT, SchematicT>;
|
|
31
35
|
createSchematic(name: string, collection: Collection<CollectionT, SchematicT>): Schematic<CollectionT, SchematicT>;
|
|
32
36
|
transformOptions<OptionT extends object, ResultT extends object>(schematic: Schematic<CollectionT, SchematicT>, options: OptionT): ResultT;
|
|
33
|
-
createSourceFromUrl(url: Url): Source;
|
|
37
|
+
createSourceFromUrl(url: Url, context: TypedSchematicContext<CollectionT, SchematicT>): Source;
|
|
34
38
|
}
|
package/src/engine/engine.js
CHANGED
|
@@ -28,6 +28,10 @@ class UnknownSchematicException extends core_1.BaseException {
|
|
|
28
28
|
}
|
|
29
29
|
}
|
|
30
30
|
exports.UnknownSchematicException = UnknownSchematicException;
|
|
31
|
+
class SchematicEngineConflictingException extends core_1.BaseException {
|
|
32
|
+
constructor() { super(`A schematic was called from a different engine as its parent.`); }
|
|
33
|
+
}
|
|
34
|
+
exports.SchematicEngineConflictingException = SchematicEngineConflictingException;
|
|
31
35
|
class SchematicEngine {
|
|
32
36
|
constructor(_host) {
|
|
33
37
|
this._host = _host;
|
|
@@ -49,6 +53,21 @@ class SchematicEngine {
|
|
|
49
53
|
this._schematicCache.set(name, new Map());
|
|
50
54
|
return collection;
|
|
51
55
|
}
|
|
56
|
+
createContext(schematic, parent) {
|
|
57
|
+
// Check for inconsistencies.
|
|
58
|
+
if (parent && parent.engine && parent.engine !== this) {
|
|
59
|
+
throw new SchematicEngineConflictingException();
|
|
60
|
+
}
|
|
61
|
+
return {
|
|
62
|
+
debug: parent && parent.debug || false,
|
|
63
|
+
engine: this,
|
|
64
|
+
logger: (parent && parent.logger && parent.logger.createChild(schematic.description.name))
|
|
65
|
+
|| new core_1.NullLogger(),
|
|
66
|
+
schematic,
|
|
67
|
+
strategy: (parent && parent.strategy !== undefined)
|
|
68
|
+
? parent.strategy : this.defaultMergeStrategy,
|
|
69
|
+
};
|
|
70
|
+
}
|
|
52
71
|
createSchematic(name, collection) {
|
|
53
72
|
const collectionImpl = this._collectionCache.get(collection.description.name);
|
|
54
73
|
const schematicMap = this._schematicCache.get(collection.description.name);
|
|
@@ -72,12 +91,12 @@ class SchematicEngine {
|
|
|
72
91
|
transformOptions(schematic, options) {
|
|
73
92
|
return this._host.transformOptions(schematic.description, options);
|
|
74
93
|
}
|
|
75
|
-
createSourceFromUrl(url) {
|
|
94
|
+
createSourceFromUrl(url, context) {
|
|
76
95
|
switch (url.protocol) {
|
|
77
96
|
case 'null:': return () => new null_1.NullTree();
|
|
78
97
|
case 'empty:': return () => static_1.empty();
|
|
79
98
|
default:
|
|
80
|
-
const hostSource = this._host.createSourceFromUrl(url);
|
|
99
|
+
const hostSource = this._host.createSourceFromUrl(url, context);
|
|
81
100
|
if (!hostSource) {
|
|
82
101
|
throw new UnknownUrlSourceProtocol(url.toString());
|
|
83
102
|
}
|
|
@@ -86,4 +105,4 @@ class SchematicEngine {
|
|
|
86
105
|
}
|
|
87
106
|
}
|
|
88
107
|
exports.SchematicEngine = SchematicEngine;
|
|
89
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"engine.js","sourceRoot":"/Users/hansl/Sources/devkit/","sources":["packages/angular_devkit/schematics/src/engine/engine.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 } from '@angular-devkit/core';\nimport { CollectionDescription } from '@angular-devkit/schematics';\nimport 'rxjs/add/operator/map';\nimport { Url } from 'url';\nimport { MergeStrategy } from '../tree/interface';\nimport { NullTree } from '../tree/null';\nimport { empty } from '../tree/static';\nimport { CollectionImpl } from './collection';\nimport {\n  Collection,\n  Engine,\n  EngineHost,\n  Schematic,\n  Source,\n} from './interface';\nimport { SchematicImpl } from './schematic';\n\n\nexport class UnknownUrlSourceProtocol extends BaseException {\n  constructor(url: string) { super(`Unknown Protocol on url \"${url}\".`); }\n}\n\nexport class UnknownCollectionException extends BaseException {\n  constructor(name: string) { super(`Unknown collection \"${name}\".`); }\n}\nexport class UnknownSchematicException extends BaseException {\n  constructor(name: string, collection: CollectionDescription<{}>) {\n    super(`Schematic \"${name}\" not found in collection \"${collection.name}\".`);\n  }\n}\n\n\nexport class SchematicEngine<CollectionT extends object, SchematicT extends object>\n    implements Engine<CollectionT, SchematicT> {\n\n  private _collectionCache = new Map<string, CollectionImpl<CollectionT, SchematicT>>();\n  private _schematicCache\n    = new Map<string, Map<string, SchematicImpl<CollectionT, SchematicT>>>();\n\n  constructor(private _host: EngineHost<CollectionT, SchematicT>) {\n  }\n\n  get defaultMergeStrategy() { return this._host.defaultMergeStrategy || MergeStrategy.Default; }\n\n  createCollection(name: string): Collection<CollectionT, SchematicT> {\n    let collection = this._collectionCache.get(name);\n    if (collection) {\n      return collection;\n    }\n\n    const description = this._host.createCollectionDescription(name);\n    if (!description) {\n      throw new UnknownCollectionException(name);\n    }\n\n    collection = new CollectionImpl<CollectionT, SchematicT>(description, this);\n    this._collectionCache.set(name, collection);\n    this._schematicCache.set(name, new Map());\n\n    return collection;\n  }\n\n  createSchematic(\n      name: string,\n      collection: Collection<CollectionT, SchematicT>): Schematic<CollectionT, SchematicT> {\n    const collectionImpl = this._collectionCache.get(collection.description.name);\n    const schematicMap = this._schematicCache.get(collection.description.name);\n    if (!collectionImpl || !schematicMap || collectionImpl !== collection) {\n      // This is weird, maybe the collection was created by another engine?\n      throw new UnknownCollectionException(collection.description.name);\n    }\n\n    let schematic = schematicMap.get(name);\n    if (schematic) {\n      return schematic;\n    }\n\n    const description = this._host.createSchematicDescription(name, collection.description);\n    if (!description) {\n      throw new UnknownSchematicException(name, collection.description);\n    }\n\n    const factory = this._host.getSchematicRuleFactory(description, collection.description);\n    schematic = new SchematicImpl<CollectionT, SchematicT>(description, factory, collection, this);\n\n    schematicMap.set(name, schematic);\n\n    return schematic;\n  }\n\n  transformOptions<OptionT extends object, ResultT extends object>(\n      schematic: Schematic<CollectionT, SchematicT>, options: OptionT): ResultT {\n    return this._host.transformOptions<OptionT, ResultT>(\n      schematic.description,\n      options,\n    );\n  }\n\n  createSourceFromUrl(url: Url): Source {\n    switch (url.protocol) {\n      case 'null:': return () => new NullTree();\n      case 'empty:': return () => empty();\n      default:\n        const hostSource = this._host.createSourceFromUrl(url);\n        if (!hostSource) {\n          throw new UnknownUrlSourceProtocol(url.toString());\n        }\n\n        return hostSource;\n    }\n  }\n}\n"]}
|
|
108
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"engine.js","sourceRoot":"/Users/hansl/Sources/devkit/","sources":["packages/angular_devkit/schematics/src/engine/engine.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, NullLogger } from '@angular-devkit/core';\nimport { CollectionDescription, TypedSchematicContext } from '@angular-devkit/schematics';\nimport 'rxjs/add/operator/map';\nimport { Url } from 'url';\nimport { MergeStrategy } from '../tree/interface';\nimport { NullTree } from '../tree/null';\nimport { empty } from '../tree/static';\nimport { CollectionImpl } from './collection';\nimport {\n  Collection,\n  Engine,\n  EngineHost,\n  Schematic,\n  Source,\n} from './interface';\nimport { SchematicImpl } from './schematic';\n\n\nexport class UnknownUrlSourceProtocol extends BaseException {\n  constructor(url: string) { super(`Unknown Protocol on url \"${url}\".`); }\n}\n\nexport class UnknownCollectionException extends BaseException {\n  constructor(name: string) { super(`Unknown collection \"${name}\".`); }\n}\nexport class UnknownSchematicException extends BaseException {\n  constructor(name: string, collection: CollectionDescription<{}>) {\n    super(`Schematic \"${name}\" not found in collection \"${collection.name}\".`);\n  }\n}\n\nexport class SchematicEngineConflictingException extends BaseException {\n  constructor() { super(`A schematic was called from a different engine as its parent.`); }\n}\n\n\nexport class SchematicEngine<CollectionT extends object, SchematicT extends object>\n    implements Engine<CollectionT, SchematicT> {\n\n  private _collectionCache = new Map<string, CollectionImpl<CollectionT, SchematicT>>();\n  private _schematicCache\n    = new Map<string, Map<string, SchematicImpl<CollectionT, SchematicT>>>();\n\n  constructor(private _host: EngineHost<CollectionT, SchematicT>) {\n  }\n\n  get defaultMergeStrategy() { return this._host.defaultMergeStrategy || MergeStrategy.Default; }\n\n  createCollection(name: string): Collection<CollectionT, SchematicT> {\n    let collection = this._collectionCache.get(name);\n    if (collection) {\n      return collection;\n    }\n\n    const description = this._host.createCollectionDescription(name);\n    if (!description) {\n      throw new UnknownCollectionException(name);\n    }\n\n    collection = new CollectionImpl<CollectionT, SchematicT>(description, this);\n    this._collectionCache.set(name, collection);\n    this._schematicCache.set(name, new Map());\n\n    return collection;\n  }\n\n  createContext(\n    schematic: Schematic<CollectionT, SchematicT>,\n    parent?: Partial<TypedSchematicContext<CollectionT, SchematicT>>,\n  ): TypedSchematicContext<CollectionT, SchematicT> {\n    // Check for inconsistencies.\n    if (parent && parent.engine && parent.engine !== this) {\n      throw new SchematicEngineConflictingException();\n    }\n\n    return {\n      debug: parent && parent.debug || false,\n      engine: this,\n      logger: (parent && parent.logger && parent.logger.createChild(schematic.description.name))\n              || new NullLogger(),\n      schematic,\n      strategy: (parent && parent.strategy !== undefined)\n        ? parent.strategy : this.defaultMergeStrategy,\n    };\n  }\n\n  createSchematic(\n      name: string,\n      collection: Collection<CollectionT, SchematicT>): Schematic<CollectionT, SchematicT> {\n    const collectionImpl = this._collectionCache.get(collection.description.name);\n    const schematicMap = this._schematicCache.get(collection.description.name);\n    if (!collectionImpl || !schematicMap || collectionImpl !== collection) {\n      // This is weird, maybe the collection was created by another engine?\n      throw new UnknownCollectionException(collection.description.name);\n    }\n\n    let schematic = schematicMap.get(name);\n    if (schematic) {\n      return schematic;\n    }\n\n    const description = this._host.createSchematicDescription(name, collection.description);\n    if (!description) {\n      throw new UnknownSchematicException(name, collection.description);\n    }\n\n    const factory = this._host.getSchematicRuleFactory(description, collection.description);\n    schematic = new SchematicImpl<CollectionT, SchematicT>(description, factory, collection, this);\n\n    schematicMap.set(name, schematic);\n\n    return schematic;\n  }\n\n  transformOptions<OptionT extends object, ResultT extends object>(\n      schematic: Schematic<CollectionT, SchematicT>, options: OptionT): ResultT {\n    return this._host.transformOptions<OptionT, ResultT>(\n      schematic.description,\n      options,\n    );\n  }\n\n  createSourceFromUrl(url: Url, context: TypedSchematicContext<CollectionT, SchematicT>): Source {\n    switch (url.protocol) {\n      case 'null:': return () => new NullTree();\n      case 'empty:': return () => empty();\n      default:\n        const hostSource = this._host.createSourceFromUrl(url, context);\n        if (!hostSource) {\n          throw new UnknownUrlSourceProtocol(url.toString());\n        }\n\n        return hostSource;\n    }\n  }\n}\n"]}
|
|
@@ -6,6 +6,7 @@
|
|
|
6
6
|
* Use of this source code is governed by an MIT-style license that can be
|
|
7
7
|
* found in the LICENSE file at https://angular.io/license
|
|
8
8
|
*/
|
|
9
|
+
import { LoggerApi } from '@angular-devkit/core';
|
|
9
10
|
import { Observable } from 'rxjs/Observable';
|
|
10
11
|
import { Url } from 'url';
|
|
11
12
|
import { FileEntry, MergeStrategy, Tree } from '../tree/interface';
|
|
@@ -35,7 +36,7 @@ export interface EngineHost<CollectionMetadataT extends object, SchematicMetadat
|
|
|
35
36
|
createCollectionDescription(name: string): CollectionDescription<CollectionMetadataT>;
|
|
36
37
|
createSchematicDescription(name: string, collection: CollectionDescription<CollectionMetadataT>): SchematicDescription<CollectionMetadataT, SchematicMetadataT>;
|
|
37
38
|
getSchematicRuleFactory<OptionT extends object>(schematic: SchematicDescription<CollectionMetadataT, SchematicMetadataT>, collection: CollectionDescription<CollectionMetadataT>): RuleFactory<OptionT>;
|
|
38
|
-
createSourceFromUrl(url: Url): Source | null;
|
|
39
|
+
createSourceFromUrl(url: Url, context: TypedSchematicContext<CollectionMetadataT, SchematicMetadataT>): Source | null;
|
|
39
40
|
transformOptions<OptionT extends object, ResultT extends object>(schematic: SchematicDescription<CollectionMetadataT, SchematicMetadataT>, options: OptionT): ResultT;
|
|
40
41
|
readonly defaultMergeStrategy?: MergeStrategy;
|
|
41
42
|
}
|
|
@@ -51,8 +52,9 @@ export interface EngineHost<CollectionMetadataT extends object, SchematicMetadat
|
|
|
51
52
|
*/
|
|
52
53
|
export interface Engine<CollectionMetadataT extends object, SchematicMetadataT extends object> {
|
|
53
54
|
createCollection(name: string): Collection<CollectionMetadataT, SchematicMetadataT>;
|
|
55
|
+
createContext(schematic: Schematic<CollectionMetadataT, SchematicMetadataT>, parent?: Partial<TypedSchematicContext<CollectionMetadataT, SchematicMetadataT>>): TypedSchematicContext<CollectionMetadataT, SchematicMetadataT>;
|
|
54
56
|
createSchematic(name: string, collection: Collection<CollectionMetadataT, SchematicMetadataT>): Schematic<CollectionMetadataT, SchematicMetadataT>;
|
|
55
|
-
createSourceFromUrl(url: Url): Source;
|
|
57
|
+
createSourceFromUrl(url: Url, context: TypedSchematicContext<CollectionMetadataT, SchematicMetadataT>): Source;
|
|
56
58
|
transformOptions<OptionT extends object, ResultT extends object>(schematic: Schematic<CollectionMetadataT, SchematicMetadataT>, options: OptionT): ResultT;
|
|
57
59
|
readonly defaultMergeStrategy: MergeStrategy;
|
|
58
60
|
}
|
|
@@ -71,14 +73,16 @@ export interface Collection<CollectionMetadataT extends object, SchematicMetadat
|
|
|
71
73
|
export interface Schematic<CollectionMetadataT extends object, SchematicMetadataT extends object> {
|
|
72
74
|
readonly description: SchematicDescription<CollectionMetadataT, SchematicMetadataT>;
|
|
73
75
|
readonly collection: Collection<CollectionMetadataT, SchematicMetadataT>;
|
|
74
|
-
call<OptionT extends object>(options: OptionT, host: Observable<Tree
|
|
76
|
+
call<OptionT extends object>(options: OptionT, host: Observable<Tree>, parentContext?: Partial<TypedSchematicContext<CollectionMetadataT, SchematicMetadataT>>): Observable<Tree>;
|
|
75
77
|
}
|
|
76
78
|
/**
|
|
77
79
|
* A SchematicContext. Contains information necessary for Schematics to execute some rules, for
|
|
78
80
|
* example when using another schematics, as we need the engine and collection.
|
|
79
81
|
*/
|
|
80
82
|
export interface TypedSchematicContext<CollectionMetadataT extends object, SchematicMetadataT extends object> {
|
|
83
|
+
readonly debug: boolean;
|
|
81
84
|
readonly engine: Engine<CollectionMetadataT, SchematicMetadataT>;
|
|
85
|
+
readonly logger: LoggerApi;
|
|
82
86
|
readonly schematic: Schematic<CollectionMetadataT, SchematicMetadataT>;
|
|
83
87
|
readonly strategy: MergeStrategy;
|
|
84
88
|
}
|
|
@@ -108,4 +112,4 @@ export declare type AsyncFileOperator = (tree: FileEntry) => Observable<FileEntr
|
|
|
108
112
|
* know which types is the schematic or collection metadata, as they are both tooling specific.
|
|
109
113
|
*/
|
|
110
114
|
export declare type Source = (context: SchematicContext) => Tree | Observable<Tree>;
|
|
111
|
-
export declare type Rule = (tree: Tree, context: SchematicContext) => Tree | Observable<Tree
|
|
115
|
+
export declare type Rule = (tree: Tree, context: SchematicContext) => Tree | Observable<Tree> | void;
|
package/src/engine/interface.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"interface.js","sourceRoot":"/Users/hansl/Sources/devkit/","sources":["packages/angular_devkit/schematics/src/engine/interface.ts"],"names":[],"mappings":"","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 { LoggerApi } from '@angular-devkit/core';\nimport { Observable } from 'rxjs/Observable';\nimport { Url } from 'url';\nimport { FileEntry, MergeStrategy, Tree } from '../tree/interface';\n\n\n/**\n * The description (metadata) of a collection. This type contains every information the engine\n * needs to run. The CollectionMetadataT type parameter contains additional metadata that you\n * want to store while remaining type-safe.\n */\nexport type CollectionDescription<CollectionMetadataT extends object> = CollectionMetadataT & {\n  readonly name: string;\n};\n\n/**\n * The description (metadata) of a schematic. This type contains every information the engine\n * needs to run. The SchematicMetadataT and CollectionMetadataT type parameters contain additional\n * metadata that you want to store while remaining type-safe.\n */\nexport type SchematicDescription<CollectionMetadataT extends object,\n                                 SchematicMetadataT extends object> = SchematicMetadataT & {\n  readonly collection: CollectionDescription<CollectionMetadataT>;\n  readonly name: string;\n};\n\n\n/**\n * The Host for the Engine. Specifically, the piece of the tooling responsible for resolving\n * collections and schematics descriptions. The SchematicMetadataT and CollectionMetadataT type\n * parameters contain additional metadata that you want to store while remaining type-safe.\n */\nexport interface EngineHost<CollectionMetadataT extends object, SchematicMetadataT extends object> {\n  createCollectionDescription(name: string): CollectionDescription<CollectionMetadataT>;\n  createSchematicDescription(\n      name: string,\n      collection: CollectionDescription<CollectionMetadataT>):\n        SchematicDescription<CollectionMetadataT, SchematicMetadataT>;\n  getSchematicRuleFactory<OptionT extends object>(\n      schematic: SchematicDescription<CollectionMetadataT, SchematicMetadataT>,\n      collection: CollectionDescription<CollectionMetadataT>): RuleFactory<OptionT>;\n  createSourceFromUrl(\n    url: Url,\n    context: TypedSchematicContext<CollectionMetadataT, SchematicMetadataT>,\n  ): Source | null;\n  transformOptions<OptionT extends object, ResultT extends object>(\n    schematic: SchematicDescription<CollectionMetadataT, SchematicMetadataT>,\n    options: OptionT,\n  ): ResultT;\n\n\n  readonly defaultMergeStrategy?: MergeStrategy;\n}\n\n\n/**\n * The root Engine for creating and running schematics and collections. Everything related to\n * a schematic execution starts from this interface.\n *\n * CollectionMetadataT is, by default, a generic Collection metadata type. This is used throughout\n * the engine typings so that you can use a type that's merged into descriptions, while being\n * type-safe.\n *\n * SchematicMetadataT is a type that contains additional typing for the Schematic Description.\n */\nexport interface Engine<CollectionMetadataT extends object, SchematicMetadataT extends object> {\n  createCollection(name: string): Collection<CollectionMetadataT, SchematicMetadataT>;\n  createContext(\n    schematic: Schematic<CollectionMetadataT, SchematicMetadataT>,\n    parent?: Partial<TypedSchematicContext<CollectionMetadataT, SchematicMetadataT>>,\n  ): TypedSchematicContext<CollectionMetadataT, SchematicMetadataT>;\n  createSchematic(\n      name: string,\n      collection: Collection<CollectionMetadataT, SchematicMetadataT>,\n  ): Schematic<CollectionMetadataT, SchematicMetadataT>;\n  createSourceFromUrl(\n    url: Url,\n    context: TypedSchematicContext<CollectionMetadataT, SchematicMetadataT>,\n  ): Source;\n  transformOptions<OptionT extends object, ResultT extends object>(\n      schematic: Schematic<CollectionMetadataT, SchematicMetadataT>,\n      options: OptionT,\n  ): ResultT;\n\n  readonly defaultMergeStrategy: MergeStrategy;\n}\n\n\n/**\n * A Collection as created by the Engine. This should be used by the tool to create schematics,\n * or by rules to create other schematics as well.\n */\nexport interface Collection<CollectionMetadataT extends object, SchematicMetadataT extends object> {\n  readonly description: CollectionDescription<CollectionMetadataT>;\n\n  createSchematic(name: string): Schematic<CollectionMetadataT, SchematicMetadataT>;\n}\n\n\n/**\n * A Schematic as created by the Engine. This should be used by the tool to execute the main\n * schematics, or by rules to execute other schematics as well.\n */\nexport interface Schematic<CollectionMetadataT extends object, SchematicMetadataT extends object> {\n  readonly description: SchematicDescription<CollectionMetadataT, SchematicMetadataT>;\n  readonly collection: Collection<CollectionMetadataT, SchematicMetadataT>;\n\n  call<OptionT extends object>(\n    options: OptionT,\n    host: Observable<Tree>,\n    parentContext?: Partial<TypedSchematicContext<CollectionMetadataT, SchematicMetadataT>>,\n  ): Observable<Tree>;\n}\n\n\n/**\n * A SchematicContext. Contains information necessary for Schematics to execute some rules, for\n * example when using another schematics, as we need the engine and collection.\n */\nexport interface TypedSchematicContext<CollectionMetadataT extends object,\n                                       SchematicMetadataT extends object> {\n  readonly debug: boolean;\n  readonly engine: Engine<CollectionMetadataT, SchematicMetadataT>;\n  readonly logger: LoggerApi;\n  readonly schematic: Schematic<CollectionMetadataT, SchematicMetadataT>;\n  readonly strategy: MergeStrategy;\n}\n\n\n/**\n * This is used by the Schematics implementations in order to avoid needing to have typing from\n * the tooling. Schematics are not specific to a tool.\n */\nexport type SchematicContext = TypedSchematicContext<{}, {}>;\n\n\n/**\n * A rule factory, which is normally the way schematics are implemented. Returned by the tooling\n * after loading a schematic description.\n */\nexport type RuleFactory<T extends object> = (options: T) => Rule;\n\n\n/**\n * A FileOperator applies changes synchronously to a FileEntry. An async operator returns\n * asynchronously. We separate them so that the type system can catch early errors.\n */\nexport type FileOperator = (entry: FileEntry) => FileEntry | null;\nexport type AsyncFileOperator = (tree: FileEntry) => Observable<FileEntry | null>;\n\n\n/**\n * A source is a function that generates a Tree from a specific context. A rule transforms a tree\n * into another tree from a specific context. In both cases, an Observable can be returned if\n * the source or the rule are asynchronous. Only the last Tree generated in the observable will\n * be used though.\n *\n * We obfuscate the context of Source and Rule because the schematic implementation should not\n * know which types is the schematic or collection metadata, as they are both tooling specific.\n */\nexport type Source = (context: SchematicContext) => Tree | Observable<Tree>;\nexport type Rule = (tree: Tree, context: SchematicContext) => Tree | Observable<Tree> | void;\n"]}
|
|
@@ -10,7 +10,7 @@ import { Observable } from 'rxjs/Observable';
|
|
|
10
10
|
import 'rxjs/add/observable/of';
|
|
11
11
|
import 'rxjs/add/operator/concatMap';
|
|
12
12
|
import { Tree } from '../tree/interface';
|
|
13
|
-
import { Collection, Engine, RuleFactory, Schematic, SchematicDescription } from './interface';
|
|
13
|
+
import { Collection, Engine, RuleFactory, Schematic, SchematicDescription, TypedSchematicContext } from './interface';
|
|
14
14
|
export declare class InvalidSchematicsNameException extends BaseException {
|
|
15
15
|
constructor(name: string);
|
|
16
16
|
}
|
|
@@ -19,8 +19,8 @@ export declare class SchematicImpl<CollectionT extends object, SchematicT extend
|
|
|
19
19
|
private _factory;
|
|
20
20
|
private _collection;
|
|
21
21
|
private _engine;
|
|
22
|
-
constructor(_description: SchematicDescription<CollectionT, SchematicT>, _factory: RuleFactory<
|
|
22
|
+
constructor(_description: SchematicDescription<CollectionT, SchematicT>, _factory: RuleFactory<{}>, _collection: Collection<CollectionT, SchematicT>, _engine: Engine<CollectionT, SchematicT>);
|
|
23
23
|
readonly description: SchematicDescription<CollectionT, SchematicT>;
|
|
24
24
|
readonly collection: Collection<CollectionT, SchematicT>;
|
|
25
|
-
call<OptionT extends object>(options: OptionT, host: Observable<Tree
|
|
25
|
+
call<OptionT extends object>(options: OptionT, host: Observable<Tree>, parentContext?: Partial<TypedSchematicContext<CollectionT, SchematicT>>): Observable<Tree>;
|
|
26
26
|
}
|
package/src/engine/schematic.js
CHANGED
|
@@ -18,8 +18,7 @@ class InvalidSchematicsNameException extends core_1.BaseException {
|
|
|
18
18
|
}
|
|
19
19
|
exports.InvalidSchematicsNameException = InvalidSchematicsNameException;
|
|
20
20
|
class SchematicImpl {
|
|
21
|
-
constructor(_description, _factory,
|
|
22
|
-
_collection, _engine) {
|
|
21
|
+
constructor(_description, _factory, _collection, _engine) {
|
|
23
22
|
this._description = _description;
|
|
24
23
|
this._factory = _factory;
|
|
25
24
|
this._collection = _collection;
|
|
@@ -30,18 +29,17 @@ class SchematicImpl {
|
|
|
30
29
|
}
|
|
31
30
|
get description() { return this._description; }
|
|
32
31
|
get collection() { return this._collection; }
|
|
33
|
-
call(options, host) {
|
|
34
|
-
const context =
|
|
35
|
-
engine: this._engine,
|
|
36
|
-
schematic: this,
|
|
37
|
-
strategy: this._engine.defaultMergeStrategy,
|
|
38
|
-
};
|
|
39
|
-
const transformedOptions = this._engine.transformOptions(this, options);
|
|
32
|
+
call(options, host, parentContext) {
|
|
33
|
+
const context = this._engine.createContext(this, parentContext);
|
|
40
34
|
return host.concatMap(tree => {
|
|
35
|
+
const transformedOptions = this._engine.transformOptions(this, options);
|
|
41
36
|
const result = this._factory(transformedOptions)(tree, context);
|
|
42
37
|
if (result instanceof Observable_1.Observable) {
|
|
43
38
|
return result;
|
|
44
39
|
}
|
|
40
|
+
else if (result === undefined) {
|
|
41
|
+
return Observable_1.Observable.of(tree);
|
|
42
|
+
}
|
|
45
43
|
else {
|
|
46
44
|
return Observable_1.Observable.of(result);
|
|
47
45
|
}
|
|
@@ -49,4 +47,4 @@ class SchematicImpl {
|
|
|
49
47
|
}
|
|
50
48
|
}
|
|
51
49
|
exports.SchematicImpl = SchematicImpl;
|
|
52
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NoZW1hdGljLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9oYW5zbC9Tb3VyY2VzL2RldmtpdC8iLCJzb3VyY2VzIjpbInBhY2thZ2VzL2FuZ3VsYXJfZGV2a2l0L3NjaGVtYXRpY3Mvc3JjL2VuZ2luZS9zY2hlbWF0aWMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQTs7Ozs7O0dBTUc7QUFDSCwrQ0FBcUQ7QUFDckQsZ0RBQTZDO0FBQzdDLGtDQUFnQztBQUNoQyx1Q0FBcUM7QUFZckMsb0NBQTRDLFNBQVEsb0JBQWE7SUFDL0QsWUFBWSxJQUFZO1FBQ3RCLEtBQUssQ0FBQyxpQ0FBaUMsSUFBSSxJQUFJLENBQUMsQ0FBQztJQUNuRCxDQUFDO0NBQ0Y7QUFKRCx3RUFJQztBQUdEO0lBR0UsWUFBb0IsWUFBMkQsRUFDM0QsUUFBeUIsRUFDekIsV0FBZ0QsRUFDaEQsT0FBd0M7UUFIeEMsaUJBQVksR0FBWixZQUFZLENBQStDO1FBQzNELGFBQVEsR0FBUixRQUFRLENBQWlCO1FBQ3pCLGdCQUFXLEdBQVgsV0FBVyxDQUFxQztRQUNoRCxZQUFPLEdBQVAsT0FBTyxDQUFpQztRQUMxRCxFQUFFLENBQUMsQ0FBQyxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLG1CQUFtQixDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ2xELE1BQU0sSUFBSSw4QkFBOEIsQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDOUQsQ0FBQztJQUNILENBQUM7SUFFRCxJQUFJLFdBQVcsS0FBSyxNQUFNLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUM7SUFDL0MsSUFBSSxVQUFVLEtBQUssTUFBTSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDO0lBRTdDLElBQUksQ0FDRixPQUFnQixFQUNoQixJQUFzQixFQUN0QixhQUF1RTtRQUV2RSxNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxJQUFJLEVBQUUsYUFBYSxDQUFDLENBQUM7UUFFaEUsTUFBTSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSTtZQUN4QixNQUFNLGtCQUFrQixHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxFQUFFLE9BQU8sQ0FBQyxDQUFDO1lBRXhFLE1BQU0sTUFBTSxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsa0JBQWtCLENBQUMsQ0FBQyxJQUFJLEVBQUUsT0FBTyxDQUFDLENBQUM7WUFDaEUsRUFBRSxDQUFDLENBQUMsTUFBTSxZQUFZLHVCQUFVLENBQUMsQ0FBQyxDQUFDO2dCQUNqQyxNQUFNLENBQUMsTUFBTSxDQUFDO1lBQ2hCLENBQUM7WUFBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUMsTUFBTSxLQUFLLFNBQVMsQ0FBQyxDQUFDLENBQUM7Z0JBQ2hDLE1BQU0sQ0FBQyx1QkFBVSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUM3QixDQUFDO1lBQUMsSUFBSSxDQUFDLENBQUM7Z0JBQ04sTUFBTSxDQUFDLHVCQUFVLENBQUMsRUFBRSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1lBQy9CLENBQUM7UUFDSCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7Q0FDRjtBQW5DRCxzQ0FtQ0MiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5pbXBvcnQgeyBCYXNlRXhjZXB0aW9uIH0gZnJvbSAnQGFuZ3VsYXItZGV2a2l0L2NvcmUnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMvT2JzZXJ2YWJsZSc7XG5pbXBvcnQgJ3J4anMvYWRkL29ic2VydmFibGUvb2YnO1xuaW1wb3J0ICdyeGpzL2FkZC9vcGVyYXRvci9jb25jYXRNYXAnO1xuaW1wb3J0IHsgVHJlZSB9IGZyb20gJy4uL3RyZWUvaW50ZXJmYWNlJztcbmltcG9ydCB7XG4gIENvbGxlY3Rpb24sXG4gIEVuZ2luZSxcbiAgUnVsZUZhY3RvcnksXG4gIFNjaGVtYXRpYyxcbiAgU2NoZW1hdGljRGVzY3JpcHRpb24sXG4gIFR5cGVkU2NoZW1hdGljQ29udGV4dCxcbn0gZnJvbSAnLi9pbnRlcmZhY2UnO1xuXG5cbmV4cG9ydCBjbGFzcyBJbnZhbGlkU2NoZW1hdGljc05hbWVFeGNlcHRpb24gZXh0ZW5kcyBCYXNlRXhjZXB0aW9uIHtcbiAgY29uc3RydWN0b3IobmFtZTogc3RyaW5nKSB7XG4gICAgc3VwZXIoYFNjaGVtYXRpY3MgaGFzIGludmFsaWQgbmFtZTogXCIke25hbWV9XCIuYCk7XG4gIH1cbn1cblxuXG5leHBvcnQgY2xhc3MgU2NoZW1hdGljSW1wbDxDb2xsZWN0aW9uVCBleHRlbmRzIG9iamVjdCwgU2NoZW1hdGljVCBleHRlbmRzIG9iamVjdD5cbiAgICBpbXBsZW1lbnRzIFNjaGVtYXRpYzxDb2xsZWN0aW9uVCwgU2NoZW1hdGljVD4ge1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgX2Rlc2NyaXB0aW9uOiBTY2hlbWF0aWNEZXNjcmlwdGlvbjxDb2xsZWN0aW9uVCwgU2NoZW1hdGljVD4sXG4gICAgICAgICAgICAgIHByaXZhdGUgX2ZhY3Rvcnk6IFJ1bGVGYWN0b3J5PHt9PixcbiAgICAgICAgICAgICAgcHJpdmF0ZSBfY29sbGVjdGlvbjogQ29sbGVjdGlvbjxDb2xsZWN0aW9uVCwgU2NoZW1hdGljVD4sXG4gICAgICAgICAgICAgIHByaXZhdGUgX2VuZ2luZTogRW5naW5lPENvbGxlY3Rpb25ULCBTY2hlbWF0aWNUPikge1xuICAgIGlmICghX2Rlc2NyaXB0aW9uLm5hbWUubWF0Y2goL15bLV8uYS16QS1aMC05XSskLykpIHtcbiAgICAgIHRocm93IG5ldyBJbnZhbGlkU2NoZW1hdGljc05hbWVFeGNlcHRpb24oX2Rlc2NyaXB0aW9uLm5hbWUpO1xuICAgIH1cbiAgfVxuXG4gIGdldCBkZXNjcmlwdGlvbigpIHsgcmV0dXJuIHRoaXMuX2Rlc2NyaXB0aW9uOyB9XG4gIGdldCBjb2xsZWN0aW9uKCkgeyByZXR1cm4gdGhpcy5fY29sbGVjdGlvbjsgfVxuXG4gIGNhbGw8T3B0aW9uVCBleHRlbmRzIG9iamVjdD4oXG4gICAgb3B0aW9uczogT3B0aW9uVCxcbiAgICBob3N0OiBPYnNlcnZhYmxlPFRyZWU+LFxuICAgIHBhcmVudENvbnRleHQ/OiBQYXJ0aWFsPFR5cGVkU2NoZW1hdGljQ29udGV4dDxDb2xsZWN0aW9uVCwgU2NoZW1hdGljVD4+LFxuICApOiBPYnNlcnZhYmxlPFRyZWU+IHtcbiAgICBjb25zdCBjb250ZXh0ID0gdGhpcy5fZW5naW5lLmNyZWF0ZUNvbnRleHQodGhpcywgcGFyZW50Q29udGV4dCk7XG5cbiAgICByZXR1cm4gaG9zdC5jb25jYXRNYXAodHJlZSA9PiB7XG4gICAgICBjb25zdCB0cmFuc2Zvcm1lZE9wdGlvbnMgPSB0aGlzLl9lbmdpbmUudHJhbnNmb3JtT3B0aW9ucyh0aGlzLCBvcHRpb25zKTtcblxuICAgICAgY29uc3QgcmVzdWx0ID0gdGhpcy5fZmFjdG9yeSh0cmFuc2Zvcm1lZE9wdGlvbnMpKHRyZWUsIGNvbnRleHQpO1xuICAgICAgaWYgKHJlc3VsdCBpbnN0YW5jZW9mIE9ic2VydmFibGUpIHtcbiAgICAgICAgcmV0dXJuIHJlc3VsdDtcbiAgICAgIH0gZWxzZSBpZiAocmVzdWx0ID09PSB1bmRlZmluZWQpIHtcbiAgICAgICAgcmV0dXJuIE9ic2VydmFibGUub2YodHJlZSk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICByZXR1cm4gT2JzZXJ2YWJsZS5vZihyZXN1bHQpO1xuICAgICAgfVxuICAgIH0pO1xuICB9XG59XG4iXX0=
|
package/src/rules/call.d.ts
CHANGED
|
@@ -13,7 +13,7 @@ import { Tree } from '../tree/interface';
|
|
|
13
13
|
* When a rule or source returns an invalid value.
|
|
14
14
|
*/
|
|
15
15
|
export declare class InvalidRuleResultException extends BaseException {
|
|
16
|
-
constructor(value
|
|
16
|
+
constructor(value?: {});
|
|
17
17
|
}
|
|
18
18
|
export declare function callSource(source: Source, context: SchematicContext): Observable<Tree>;
|
|
19
19
|
export declare function callRule(rule: Rule, input: Observable<Tree>, context: SchematicContext): Observable<Tree>;
|