@angular/cli 7.2.0-beta.1 → 7.2.1

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.
Files changed (49) hide show
  1. package/README.md +3 -2
  2. package/commands/add.d.ts +2 -2
  3. package/commands/add.js +3 -3
  4. package/commands/build.d.ts +6 -2
  5. package/commands/build.js +3 -3
  6. package/commands/build.json +10 -1
  7. package/commands/config.d.ts +2 -2
  8. package/commands/config.js +3 -3
  9. package/commands/deprecated.d.ts +2 -2
  10. package/commands/deprecated.js +3 -3
  11. package/commands/doc.d.ts +2 -2
  12. package/commands/doc.js +3 -3
  13. package/commands/e2e.d.ts +2 -2
  14. package/commands/e2e.js +3 -3
  15. package/commands/easter-egg.d.ts +2 -2
  16. package/commands/easter-egg.js +3 -3
  17. package/commands/eject.d.ts +2 -2
  18. package/commands/eject.js +3 -3
  19. package/commands/generate.d.ts +2 -2
  20. package/commands/generate.js +3 -3
  21. package/commands/help.d.ts +2 -2
  22. package/commands/help.js +3 -3
  23. package/commands/lint.d.ts +2 -2
  24. package/commands/lint.js +3 -3
  25. package/commands/new.d.ts +2 -2
  26. package/commands/new.js +3 -3
  27. package/commands/run.d.ts +2 -2
  28. package/commands/run.js +3 -3
  29. package/commands/serve.d.ts +6 -2
  30. package/commands/serve.js +3 -3
  31. package/commands/serve.json +10 -1
  32. package/commands/test.d.ts +2 -2
  33. package/commands/test.js +3 -3
  34. package/commands/update.d.ts +2 -2
  35. package/commands/update.js +3 -3
  36. package/commands/version.d.ts +2 -2
  37. package/commands/version.js +3 -3
  38. package/commands/xi18n.d.ts +2 -2
  39. package/commands/xi18n.js +3 -3
  40. package/lib/config/schema.d.ts +23 -7
  41. package/lib/config/schema.js +2 -2
  42. package/lib/config/schema.json +53 -33
  43. package/models/architect-command.d.ts +3 -2
  44. package/models/architect-command.js +37 -7
  45. package/models/parser.js +2 -2
  46. package/package.json +7 -7
  47. package/utilities/bep.d.ts +18 -0
  48. package/utilities/bep.js +55 -0
  49. package/utilities/json-schema.js +3 -1
package/commands/xi18n.js CHANGED
@@ -4,7 +4,7 @@
4
4
  Object.defineProperty(exports, "__esModule", { value: true });
5
5
  var HelpEnum;
6
6
  (function (HelpEnum) {
7
- HelpEnum["HelpJSON"] = "JSON";
8
- HelpEnum["JSON"] = "json";
7
+ HelpEnum["HelpJson"] = "JSON";
8
+ HelpEnum["Json"] = "json";
9
9
  })(HelpEnum = exports.HelpEnum || (exports.HelpEnum = {}));
10
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoieGkxOG4uanMiLCJzb3VyY2VSb290IjoiLi8iLCJzb3VyY2VzIjpbImRpc3Qtc2NoZW1hL3BhY2thZ2VzL2FuZ3VsYXIvY2xpL2NvbW1hbmRzL3hpMThuLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFDQSxtRkFBbUY7QUFDbkYsb0ZBQW9GOztBQW1DcEYsSUFBWSxRQUdYO0FBSEQsV0FBWSxRQUFRO0lBQ2hCLDZCQUFpQixDQUFBO0lBQ2pCLHlCQUFhLENBQUE7QUFDakIsQ0FBQyxFQUhXLFFBQVEsR0FBUixnQkFBUSxLQUFSLGdCQUFRLFFBR25CIiwic291cmNlc0NvbnRlbnQiOlsiXG4vLyBUSElTIEZJTEUgSVMgQVVUT01BVElDQUxMWSBHRU5FUkFURUQuIFRPIFVQREFURSBUSElTIEZJTEUgWU9VIE5FRUQgVE8gQ0hBTkdFIFRIRVxuLy8gQ09SUkVTUE9ORElORyBKU09OIFNDSEVNQSBGSUxFLCBUSEVOIFJVTiBkZXZraXQtYWRtaW4gYnVpbGQgKG9yIGJhemVsIGJ1aWxkIC4uLikuXG5cbi8vIHRzbGludDpkaXNhYmxlOm5vLWdsb2JhbC10c2xpbnQtZGlzYWJsZVxuLy8gdHNsaW50OmRpc2FibGVcblxuLyoqXG4gKiBFeHRyYWN0cyBpMThuIG1lc3NhZ2VzIGZyb20gc291cmNlIGNvZGUuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgU2NoZW1hIHtcbiAgICAvKipcbiAgICAgKiBBIG5hbWVkIGJ1aWxkIHRhcmdldCwgYXMgc3BlY2lmaWVkIGluIHRoZSBcImNvbmZpZ3VyYXRpb25zXCIgc2VjdGlvbiBvZiBhbmd1bGFyLmpzb24uXG4gICAgICogRWFjaCBuYW1lZCB0YXJnZXQgaXMgYWNjb21wYW5pZWQgYnkgYSBjb25maWd1cmF0aW9uIG9mIG9wdGlvbiBkZWZhdWx0cyBmb3IgdGhhdCB0YXJnZXQuXG4gICAgICovXG4gICAgY29uZmlndXJhdGlvbj86IHN0cmluZztcbiAgICAvKipcbiAgICAgKiBTaG93cyBhIGhlbHAgbWVzc2FnZSBmb3IgdGhpcyBjb21tYW5kIGluIHRoZSBjb25zb2xlLlxuICAgICAqL1xuICAgIGhlbHA/OiBIZWxwVW5pb247XG4gICAgLyoqXG4gICAgICogV2hlbiB0cnVlLCBzZXRzIHRoZSBidWlsZCBjb25maWd1cmF0aW9uIHRvIHRoZSBwcm9kdWN0aW9uIHRhcmdldC5cbiAgICAgKiBBbGwgYnVpbGRzIG1ha2UgdXNlIG9mIGJ1bmRsaW5nIGFuZCBsaW1pdGVkIHRyZWUtc2hha2luZy4gQSBwcm9kdWN0aW9uIGJ1aWxkIGFsc28gcnVuc1xuICAgICAqIGxpbWl0ZWQgZGVhZCBjb2RlIGVsaW1pbmF0aW9uLlxuICAgICAqL1xuICAgIHByb2Q/OiBib29sZWFuO1xuICAgIC8qKlxuICAgICAqIFRoZSBuYW1lIG9mIHRoZSBwcm9qZWN0IHRvIGJ1aWxkLiBDYW4gYmUgYW4gYXBwIG9yIGEgbGlicmFyeS5cbiAgICAgKi9cbiAgICBwcm9qZWN0Pzogc3RyaW5nO1xufVxuXG4vKipcbiAqIFNob3dzIGEgaGVscCBtZXNzYWdlIGZvciB0aGlzIGNvbW1hbmQgaW4gdGhlIGNvbnNvbGUuXG4gKi9cbmV4cG9ydCB0eXBlIEhlbHBVbmlvbiA9IGJvb2xlYW4gfCBIZWxwRW51bTtcblxuZXhwb3J0IGVudW0gSGVscEVudW0ge1xuICAgIEhlbHBKU09OID0gXCJKU09OXCIsXG4gICAgSlNPTiA9IFwianNvblwiLFxufVxuIl19
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoieGkxOG4uanMiLCJzb3VyY2VSb290IjoiLi8iLCJzb3VyY2VzIjpbImRpc3Qtc2NoZW1hL3BhY2thZ2VzL2FuZ3VsYXIvY2xpL2NvbW1hbmRzL3hpMThuLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFDQSxtRkFBbUY7QUFDbkYsb0ZBQW9GOztBQW1DcEYsSUFBWSxRQUdYO0FBSEQsV0FBWSxRQUFRO0lBQ2hCLDZCQUFpQixDQUFBO0lBQ2pCLHlCQUFhLENBQUE7QUFDakIsQ0FBQyxFQUhXLFFBQVEsR0FBUixnQkFBUSxLQUFSLGdCQUFRLFFBR25CIiwic291cmNlc0NvbnRlbnQiOlsiXG4vLyBUSElTIEZJTEUgSVMgQVVUT01BVElDQUxMWSBHRU5FUkFURUQuIFRPIFVQREFURSBUSElTIEZJTEUgWU9VIE5FRUQgVE8gQ0hBTkdFIFRIRVxuLy8gQ09SUkVTUE9ORElORyBKU09OIFNDSEVNQSBGSUxFLCBUSEVOIFJVTiBkZXZraXQtYWRtaW4gYnVpbGQgKG9yIGJhemVsIGJ1aWxkIC4uLikuXG5cbi8vIHRzbGludDpkaXNhYmxlOm5vLWdsb2JhbC10c2xpbnQtZGlzYWJsZVxuLy8gdHNsaW50OmRpc2FibGVcblxuLyoqXG4gKiBFeHRyYWN0cyBpMThuIG1lc3NhZ2VzIGZyb20gc291cmNlIGNvZGUuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgU2NoZW1hIHtcbiAgICAvKipcbiAgICAgKiBBIG5hbWVkIGJ1aWxkIHRhcmdldCwgYXMgc3BlY2lmaWVkIGluIHRoZSBcImNvbmZpZ3VyYXRpb25zXCIgc2VjdGlvbiBvZiBhbmd1bGFyLmpzb24uXG4gICAgICogRWFjaCBuYW1lZCB0YXJnZXQgaXMgYWNjb21wYW5pZWQgYnkgYSBjb25maWd1cmF0aW9uIG9mIG9wdGlvbiBkZWZhdWx0cyBmb3IgdGhhdCB0YXJnZXQuXG4gICAgICovXG4gICAgY29uZmlndXJhdGlvbj86IHN0cmluZztcbiAgICAvKipcbiAgICAgKiBTaG93cyBhIGhlbHAgbWVzc2FnZSBmb3IgdGhpcyBjb21tYW5kIGluIHRoZSBjb25zb2xlLlxuICAgICAqL1xuICAgIGhlbHA/OiBIZWxwVW5pb247XG4gICAgLyoqXG4gICAgICogV2hlbiB0cnVlLCBzZXRzIHRoZSBidWlsZCBjb25maWd1cmF0aW9uIHRvIHRoZSBwcm9kdWN0aW9uIHRhcmdldC5cbiAgICAgKiBBbGwgYnVpbGRzIG1ha2UgdXNlIG9mIGJ1bmRsaW5nIGFuZCBsaW1pdGVkIHRyZWUtc2hha2luZy4gQSBwcm9kdWN0aW9uIGJ1aWxkIGFsc28gcnVuc1xuICAgICAqIGxpbWl0ZWQgZGVhZCBjb2RlIGVsaW1pbmF0aW9uLlxuICAgICAqL1xuICAgIHByb2Q/OiBib29sZWFuO1xuICAgIC8qKlxuICAgICAqIFRoZSBuYW1lIG9mIHRoZSBwcm9qZWN0IHRvIGJ1aWxkLiBDYW4gYmUgYW4gYXBwIG9yIGEgbGlicmFyeS5cbiAgICAgKi9cbiAgICBwcm9qZWN0Pzogc3RyaW5nO1xufVxuXG4vKipcbiAqIFNob3dzIGEgaGVscCBtZXNzYWdlIGZvciB0aGlzIGNvbW1hbmQgaW4gdGhlIGNvbnNvbGUuXG4gKi9cbmV4cG9ydCB0eXBlIEhlbHBVbmlvbiA9IGJvb2xlYW4gfCBIZWxwRW51bTtcblxuZXhwb3J0IGVudW0gSGVscEVudW0ge1xuICAgIEhlbHBKc29uID0gXCJKU09OXCIsXG4gICAgSnNvbiA9IFwianNvblwiLFxufVxuIl19
@@ -1,6 +1,6 @@
1
1
  export interface Schema {
2
2
  $schema?: string;
3
- cli?: CLIOptions;
3
+ cli?: CliOptions;
4
4
  /**
5
5
  * Default project name used in commands.
6
6
  */
@@ -13,7 +13,7 @@ export interface Schema {
13
13
  schematics?: SchematicOptions;
14
14
  version: number;
15
15
  }
16
- export interface CLIOptions {
16
+ export interface CliOptions {
17
17
  /**
18
18
  * The default schematics collection to use.
19
19
  */
@@ -59,6 +59,10 @@ export interface SchematicOptions {
59
59
  "@schematics/angular:service"?: SchematicsAngularService;
60
60
  }
61
61
  export interface SchematicsAngularClass {
62
+ /**
63
+ * When true, does not create test files.
64
+ */
65
+ skipTests?: boolean;
62
66
  /**
63
67
  * Specifies if a spec file is generated.
64
68
  */
@@ -109,6 +113,10 @@ export interface SchematicsAngularComponent {
109
113
  * Specifies if a spec file is generated.
110
114
  */
111
115
  spec?: boolean;
116
+ /**
117
+ * The file extension to use for style files.
118
+ */
119
+ style?: string;
112
120
  /**
113
121
  * The file extension to be used for style files.
114
122
  */
@@ -132,7 +140,7 @@ export declare enum ViewEncapsulation {
132
140
  Emulated = "Emulated",
133
141
  Native = "Native",
134
142
  None = "None",
135
- ShadowDOM = "ShadowDom"
143
+ ShadowDom = "ShadowDom"
136
144
  }
137
145
  export interface SchematicsAngularDirective {
138
146
  /**
@@ -159,6 +167,10 @@ export interface SchematicsAngularDirective {
159
167
  * Flag to skip the module import.
160
168
  */
161
169
  skipImport?: boolean;
170
+ /**
171
+ * When true, does not create test files.
172
+ */
173
+ skipTests?: boolean;
162
174
  /**
163
175
  * Specifies if a spec file is generated.
164
176
  */
@@ -185,10 +197,6 @@ export interface SchematicsAngularModule {
185
197
  * The scope for the generated routing.
186
198
  */
187
199
  routingScope?: RoutingScope;
188
- /**
189
- * Specifies if a spec file is generated.
190
- */
191
- spec?: boolean;
192
200
  }
193
201
  /**
194
202
  * The scope for the generated routing.
@@ -214,6 +222,10 @@ export interface SchematicsAngularPipe {
214
222
  * Allows for skipping the module import.
215
223
  */
216
224
  skipImport?: boolean;
225
+ /**
226
+ * When true, does not create test files.
227
+ */
228
+ skipTests?: boolean;
217
229
  /**
218
230
  * Specifies if a spec file is generated.
219
231
  */
@@ -224,6 +236,10 @@ export interface SchematicsAngularService {
224
236
  * Flag to indicate if a directory is created.
225
237
  */
226
238
  flat?: boolean;
239
+ /**
240
+ * When true, does not create test files.
241
+ */
242
+ skipTests?: boolean;
227
243
  /**
228
244
  * Specifies if a spec file is generated.
229
245
  */
@@ -27,7 +27,7 @@ var ViewEncapsulation;
27
27
  ViewEncapsulation["Emulated"] = "Emulated";
28
28
  ViewEncapsulation["Native"] = "Native";
29
29
  ViewEncapsulation["None"] = "None";
30
- ViewEncapsulation["ShadowDOM"] = "ShadowDom";
30
+ ViewEncapsulation["ShadowDom"] = "ShadowDom";
31
31
  })(ViewEncapsulation = exports.ViewEncapsulation || (exports.ViewEncapsulation = {}));
32
32
  /**
33
33
  * The scope for the generated routing.
@@ -37,4 +37,4 @@ var RoutingScope;
37
37
  RoutingScope["Child"] = "Child";
38
38
  RoutingScope["Root"] = "Root";
39
39
  })(RoutingScope = exports.RoutingScope || (exports.RoutingScope = {}));
40
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"schema.js","sourceRoot":"./","sources":["dist-schema/packages/angular/cli/lib/config/schema.ts"],"names":[],"mappings":";AACA,mFAAmF;AACnF,oFAAoF;;AAoCpF;;GAEG;AACH,IAAY,cAIX;AAJD,WAAY,cAAc;IACtB,+BAAa,CAAA;IACb,6BAAW,CAAA;IACX,+BAAa,CAAA;AACjB,CAAC,EAJW,cAAc,GAAd,sBAAc,KAAd,sBAAc,QAIzB;AA0FD;;GAEG;AACH,IAAY,eAGX;AAHD,WAAY,eAAe;IACvB,sCAAmB,CAAA;IACnB,oCAAiB,CAAA;AACrB,CAAC,EAHW,eAAe,GAAf,uBAAe,KAAf,uBAAe,QAG1B;AAED;;GAEG;AACH,IAAY,iBAKX;AALD,WAAY,iBAAiB;IACzB,0CAAqB,CAAA;IACrB,sCAAiB,CAAA;IACjB,kCAAa,CAAA;IACb,4CAAuB,CAAA;AAC3B,CAAC,EALW,iBAAiB,GAAjB,yBAAiB,KAAjB,yBAAiB,QAK5B;AA4DD;;GAEG;AACH,IAAY,YAGX;AAHD,WAAY,YAAY;IACpB,+BAAe,CAAA;IACf,6BAAa,CAAA;AACjB,CAAC,EAHW,YAAY,GAAZ,oBAAY,KAAZ,oBAAY,QAGvB","sourcesContent":["\n// THIS FILE IS AUTOMATICALLY GENERATED. TO UPDATE THIS FILE YOU NEED TO CHANGE THE\n// CORRESPONDING JSON SCHEMA FILE, THEN RUN devkit-admin build (or bazel build ...).\n\n// tslint:disable:no-global-tslint-disable\n// tslint:disable\n\nexport interface Schema {\n    $schema?: string;\n    cli?:     CLIOptions;\n    /**\n     * Default project name used in commands.\n     */\n    defaultProject?: string;\n    /**\n     * Path where new projects will be created.\n     */\n    newProjectRoot?: string;\n    projects?:       Projects;\n    schematics?:     SchematicOptions;\n    version:         number;\n}\n\nexport interface CLIOptions {\n    /**\n     * The default schematics collection to use.\n     */\n    defaultCollection?: string;\n    /**\n     * Specify which package manager tool to use.\n     */\n    packageManager?: PackageManager;\n    /**\n     * Control CLI specific console warnings\n     */\n    warnings?: Warnings;\n}\n\n/**\n * Specify which package manager tool to use.\n */\nexport enum PackageManager {\n    Cnpm = \"cnpm\",\n    Npm = \"npm\",\n    Yarn = \"yarn\",\n}\n\n/**\n * Control CLI specific console warnings\n */\nexport interface Warnings {\n    /**\n     * Show a warning when the TypeScript version is incompatible.\n     */\n    typescriptMismatch?: boolean;\n    /**\n     * Show a warning when the global version is newer than the local one.\n     */\n    versionMismatch?: boolean;\n}\n\nexport interface Projects {\n}\n\nexport interface SchematicOptions {\n    \"@schematics/angular:class\"?:     SchematicsAngularClass;\n    \"@schematics/angular:component\"?: SchematicsAngularComponent;\n    \"@schematics/angular:directive\"?: SchematicsAngularDirective;\n    \"@schematics/angular:module\"?:    SchematicsAngularModule;\n    \"@schematics/angular:pipe\"?:      SchematicsAngularPipe;\n    \"@schematics/angular:service\"?:   SchematicsAngularService;\n}\n\nexport interface SchematicsAngularClass {\n    /**\n     * Specifies if a spec file is generated.\n     */\n    spec?: boolean;\n}\n\nexport interface SchematicsAngularComponent {\n    /**\n     * Specifies the change detection strategy.\n     */\n    changeDetection?: ChangeDetection;\n    /**\n     * Specifies if the component is an entry component of declaring module.\n     */\n    entryComponent?: boolean;\n    /**\n     * Specifies if declaring module exports the component.\n     */\n    export?: boolean;\n    /**\n     * Flag to indicate if a directory is created.\n     */\n    flat?: boolean;\n    /**\n     * Specifies if the style will be in the ts file.\n     */\n    inlineStyle?: boolean;\n    /**\n     * Specifies if the template will be in the ts file.\n     */\n    inlineTemplate?: boolean;\n    /**\n     * Allows specification of the declaring module.\n     */\n    module?: string;\n    /**\n     * The prefix to apply to generated selectors.\n     */\n    prefix?: string;\n    /**\n     * The selector to use for the component.\n     */\n    selector?: string;\n    /**\n     * Flag to skip the module import.\n     */\n    skipImport?: boolean;\n    /**\n     * Specifies if a spec file is generated.\n     */\n    spec?: boolean;\n    /**\n     * The file extension to be used for style files.\n     */\n    styleext?: string;\n    /**\n     * Specifies the view encapsulation strategy.\n     */\n    viewEncapsulation?: ViewEncapsulation;\n}\n\n/**\n * Specifies the change detection strategy.\n */\nexport enum ChangeDetection {\n    Default = \"Default\",\n    OnPush = \"OnPush\",\n}\n\n/**\n * Specifies the view encapsulation strategy.\n */\nexport enum ViewEncapsulation {\n    Emulated = \"Emulated\",\n    Native = \"Native\",\n    None = \"None\",\n    ShadowDOM = \"ShadowDom\",\n}\n\nexport interface SchematicsAngularDirective {\n    /**\n     * Specifies if declaring module exports the directive.\n     */\n    export?: boolean;\n    /**\n     * Flag to indicate if a directory is created.\n     */\n    flat?: boolean;\n    /**\n     * Allows specification of the declaring module.\n     */\n    module?: string;\n    /**\n     * The prefix to apply to generated selectors.\n     */\n    prefix?: string;\n    /**\n     * The selector to use for the directive.\n     */\n    selector?: string;\n    /**\n     * Flag to skip the module import.\n     */\n    skipImport?: boolean;\n    /**\n     * Specifies if a spec file is generated.\n     */\n    spec?: boolean;\n}\n\nexport interface SchematicsAngularModule {\n    /**\n     * Flag to control whether the CommonModule is imported.\n     */\n    commonModule?: boolean;\n    /**\n     * Flag to indicate if a directory is created.\n     */\n    flat?: boolean;\n    /**\n     * Allows specification of the declaring module.\n     */\n    module?: string;\n    /**\n     * Generates a routing module.\n     */\n    routing?: boolean;\n    /**\n     * The scope for the generated routing.\n     */\n    routingScope?: RoutingScope;\n    /**\n     * Specifies if a spec file is generated.\n     */\n    spec?: boolean;\n}\n\n/**\n * The scope for the generated routing.\n */\nexport enum RoutingScope {\n    Child = \"Child\",\n    Root = \"Root\",\n}\n\nexport interface SchematicsAngularPipe {\n    /**\n     * Specifies if declaring module exports the pipe.\n     */\n    export?: boolean;\n    /**\n     * Flag to indicate if a directory is created.\n     */\n    flat?: boolean;\n    /**\n     * Allows specification of the declaring module.\n     */\n    module?: string;\n    /**\n     * Allows for skipping the module import.\n     */\n    skipImport?: boolean;\n    /**\n     * Specifies if a spec file is generated.\n     */\n    spec?: boolean;\n}\n\nexport interface SchematicsAngularService {\n    /**\n     * Flag to indicate if a directory is created.\n     */\n    flat?: boolean;\n    /**\n     * Specifies if a spec file is generated.\n     */\n    spec?: boolean;\n}\n"]}
40
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"schema.js","sourceRoot":"./","sources":["dist-schema/packages/angular/cli/lib/config/schema.ts"],"names":[],"mappings":";AACA,mFAAmF;AACnF,oFAAoF;;AAoCpF;;GAEG;AACH,IAAY,cAIX;AAJD,WAAY,cAAc;IACtB,+BAAa,CAAA;IACb,6BAAW,CAAA;IACX,+BAAa,CAAA;AACjB,CAAC,EAJW,cAAc,GAAd,sBAAc,KAAd,sBAAc,QAIzB;AAkGD;;GAEG;AACH,IAAY,eAGX;AAHD,WAAY,eAAe;IACvB,sCAAmB,CAAA;IACnB,oCAAiB,CAAA;AACrB,CAAC,EAHW,eAAe,GAAf,uBAAe,KAAf,uBAAe,QAG1B;AAED;;GAEG;AACH,IAAY,iBAKX;AALD,WAAY,iBAAiB;IACzB,0CAAqB,CAAA;IACrB,sCAAiB,CAAA;IACjB,kCAAa,CAAA;IACb,4CAAuB,CAAA;AAC3B,CAAC,EALW,iBAAiB,GAAjB,yBAAiB,KAAjB,yBAAiB,QAK5B;AA4DD;;GAEG;AACH,IAAY,YAGX;AAHD,WAAY,YAAY;IACpB,+BAAe,CAAA;IACf,6BAAa,CAAA;AACjB,CAAC,EAHW,YAAY,GAAZ,oBAAY,KAAZ,oBAAY,QAGvB","sourcesContent":["\n// THIS FILE IS AUTOMATICALLY GENERATED. TO UPDATE THIS FILE YOU NEED TO CHANGE THE\n// CORRESPONDING JSON SCHEMA FILE, THEN RUN devkit-admin build (or bazel build ...).\n\n// tslint:disable:no-global-tslint-disable\n// tslint:disable\n\nexport interface Schema {\n    $schema?: string;\n    cli?:     CliOptions;\n    /**\n     * Default project name used in commands.\n     */\n    defaultProject?: string;\n    /**\n     * Path where new projects will be created.\n     */\n    newProjectRoot?: string;\n    projects?:       Projects;\n    schematics?:     SchematicOptions;\n    version:         number;\n}\n\nexport interface CliOptions {\n    /**\n     * The default schematics collection to use.\n     */\n    defaultCollection?: string;\n    /**\n     * Specify which package manager tool to use.\n     */\n    packageManager?: PackageManager;\n    /**\n     * Control CLI specific console warnings\n     */\n    warnings?: Warnings;\n}\n\n/**\n * Specify which package manager tool to use.\n */\nexport enum PackageManager {\n    Cnpm = \"cnpm\",\n    Npm = \"npm\",\n    Yarn = \"yarn\",\n}\n\n/**\n * Control CLI specific console warnings\n */\nexport interface Warnings {\n    /**\n     * Show a warning when the TypeScript version is incompatible.\n     */\n    typescriptMismatch?: boolean;\n    /**\n     * Show a warning when the global version is newer than the local one.\n     */\n    versionMismatch?: boolean;\n}\n\nexport interface Projects {\n}\n\nexport interface SchematicOptions {\n    \"@schematics/angular:class\"?:     SchematicsAngularClass;\n    \"@schematics/angular:component\"?: SchematicsAngularComponent;\n    \"@schematics/angular:directive\"?: SchematicsAngularDirective;\n    \"@schematics/angular:module\"?:    SchematicsAngularModule;\n    \"@schematics/angular:pipe\"?:      SchematicsAngularPipe;\n    \"@schematics/angular:service\"?:   SchematicsAngularService;\n}\n\nexport interface SchematicsAngularClass {\n    /**\n     * When true, does not create test files.\n     */\n    skipTests?: boolean;\n    /**\n     * Specifies if a spec file is generated.\n     */\n    spec?: boolean;\n}\n\nexport interface SchematicsAngularComponent {\n    /**\n     * Specifies the change detection strategy.\n     */\n    changeDetection?: ChangeDetection;\n    /**\n     * Specifies if the component is an entry component of declaring module.\n     */\n    entryComponent?: boolean;\n    /**\n     * Specifies if declaring module exports the component.\n     */\n    export?: boolean;\n    /**\n     * Flag to indicate if a directory is created.\n     */\n    flat?: boolean;\n    /**\n     * Specifies if the style will be in the ts file.\n     */\n    inlineStyle?: boolean;\n    /**\n     * Specifies if the template will be in the ts file.\n     */\n    inlineTemplate?: boolean;\n    /**\n     * Allows specification of the declaring module.\n     */\n    module?: string;\n    /**\n     * The prefix to apply to generated selectors.\n     */\n    prefix?: string;\n    /**\n     * The selector to use for the component.\n     */\n    selector?: string;\n    /**\n     * Flag to skip the module import.\n     */\n    skipImport?: boolean;\n    /**\n     * Specifies if a spec file is generated.\n     */\n    spec?: boolean;\n    /**\n     * The file extension to use for style files.\n     */\n    style?: string;\n    /**\n     * The file extension to be used for style files.\n     */\n    styleext?: string;\n    /**\n     * Specifies the view encapsulation strategy.\n     */\n    viewEncapsulation?: ViewEncapsulation;\n}\n\n/**\n * Specifies the change detection strategy.\n */\nexport enum ChangeDetection {\n    Default = \"Default\",\n    OnPush = \"OnPush\",\n}\n\n/**\n * Specifies the view encapsulation strategy.\n */\nexport enum ViewEncapsulation {\n    Emulated = \"Emulated\",\n    Native = \"Native\",\n    None = \"None\",\n    ShadowDom = \"ShadowDom\",\n}\n\nexport interface SchematicsAngularDirective {\n    /**\n     * Specifies if declaring module exports the directive.\n     */\n    export?: boolean;\n    /**\n     * Flag to indicate if a directory is created.\n     */\n    flat?: boolean;\n    /**\n     * Allows specification of the declaring module.\n     */\n    module?: string;\n    /**\n     * The prefix to apply to generated selectors.\n     */\n    prefix?: string;\n    /**\n     * The selector to use for the directive.\n     */\n    selector?: string;\n    /**\n     * Flag to skip the module import.\n     */\n    skipImport?: boolean;\n    /**\n     * When true, does not create test files.\n     */\n    skipTests?: boolean;\n    /**\n     * Specifies if a spec file is generated.\n     */\n    spec?: boolean;\n}\n\nexport interface SchematicsAngularModule {\n    /**\n     * Flag to control whether the CommonModule is imported.\n     */\n    commonModule?: boolean;\n    /**\n     * Flag to indicate if a directory is created.\n     */\n    flat?: boolean;\n    /**\n     * Allows specification of the declaring module.\n     */\n    module?: string;\n    /**\n     * Generates a routing module.\n     */\n    routing?: boolean;\n    /**\n     * The scope for the generated routing.\n     */\n    routingScope?: RoutingScope;\n}\n\n/**\n * The scope for the generated routing.\n */\nexport enum RoutingScope {\n    Child = \"Child\",\n    Root = \"Root\",\n}\n\nexport interface SchematicsAngularPipe {\n    /**\n     * Specifies if declaring module exports the pipe.\n     */\n    export?: boolean;\n    /**\n     * Flag to indicate if a directory is created.\n     */\n    flat?: boolean;\n    /**\n     * Allows specification of the declaring module.\n     */\n    module?: string;\n    /**\n     * Allows for skipping the module import.\n     */\n    skipImport?: boolean;\n    /**\n     * When true, does not create test files.\n     */\n    skipTests?: boolean;\n    /**\n     * Specifies if a spec file is generated.\n     */\n    spec?: boolean;\n}\n\nexport interface SchematicsAngularService {\n    /**\n     * Flag to indicate if a directory is created.\n     */\n    flat?: boolean;\n    /**\n     * When true, does not create test files.\n     */\n    skipTests?: boolean;\n    /**\n     * Specifies if a spec file is generated.\n     */\n    spec?: boolean;\n}\n"]}
@@ -139,6 +139,11 @@
139
139
  "type": "string",
140
140
  "default": "css"
141
141
  },
142
+ "style": {
143
+ "description": "The file extension to use for style files.",
144
+ "type": "string",
145
+ "default": "css"
146
+ },
142
147
  "viewEncapsulation": {
143
148
  "description": "Specifies the view encapsulation strategy.",
144
149
  "enum": ["Emulated", "Native", "None", "ShadowDom"],
@@ -186,6 +191,11 @@
186
191
  "type": "boolean",
187
192
  "description": "Specifies if a spec file is generated.",
188
193
  "default": true
194
+ },
195
+ "skipTests": {
196
+ "type": "boolean",
197
+ "description": "When true, does not create test files.",
198
+ "default": false
189
199
  }
190
200
  }
191
201
  },
@@ -203,11 +213,6 @@
203
213
  "description": "The scope for the generated routing.",
204
214
  "default": "Child"
205
215
  },
206
- "spec": {
207
- "type": "boolean",
208
- "description": "Specifies if a spec file is generated.",
209
- "default": true
210
- },
211
216
  "flat": {
212
217
  "type": "boolean",
213
218
  "description": "Flag to indicate if a directory is created.",
@@ -236,8 +241,13 @@
236
241
  },
237
242
  "spec": {
238
243
  "type": "boolean",
239
- "default": true,
240
- "description": "Specifies if a spec file is generated."
244
+ "description": "Specifies if a spec file is generated.",
245
+ "default": true
246
+ },
247
+ "skipTests": {
248
+ "type": "boolean",
249
+ "description": "When true, does not create test files.",
250
+ "default": false
241
251
  }
242
252
  }
243
253
  },
@@ -251,8 +261,13 @@
251
261
  },
252
262
  "spec": {
253
263
  "type": "boolean",
254
- "default": true,
255
- "description": "Specifies if a spec file is generated."
264
+ "description": "Specifies if a spec file is generated.",
265
+ "default": true
266
+ },
267
+ "skipTests": {
268
+ "type": "boolean",
269
+ "description": "When true, does not create test files.",
270
+ "default": false
256
271
  },
257
272
  "skipImport": {
258
273
  "type": "boolean",
@@ -277,8 +292,13 @@
277
292
  "properties": {
278
293
  "spec": {
279
294
  "type": "boolean",
280
- "default": true,
281
- "description": "Specifies if a spec file is generated."
295
+ "description": "Specifies if a spec file is generated.",
296
+ "default": true
297
+ },
298
+ "skipTests": {
299
+ "type": "boolean",
300
+ "description": "When true, does not create test files.",
301
+ "default": false
282
302
  }
283
303
  }
284
304
  }
@@ -1043,18 +1063,18 @@
1043
1063
  },
1044
1064
  "open": {
1045
1065
  "type": "boolean",
1046
- "description": "Opens the url in default browser.",
1066
+ "description": "When true, open the live-reload URL in default browser.",
1047
1067
  "default": false,
1048
1068
  "alias": "o"
1049
1069
  },
1050
1070
  "liveReload": {
1051
1071
  "type": "boolean",
1052
- "description": "Whether to reload the page on change, using live-reload.",
1072
+ "description": "When true, reload the page on change using live-reload.",
1053
1073
  "default": true
1054
1074
  },
1055
1075
  "publicHost": {
1056
1076
  "type": "string",
1057
- "description": "Specify the URL that the browser client will use."
1077
+ "description": "The URL that the browser client (or live-reload client, if enabled) should use to connect to the development server. Use for a complex dev server setup, such as one with reverse proxies."
1058
1078
  },
1059
1079
  "servePath": {
1060
1080
  "type": "string",
@@ -1062,43 +1082,43 @@
1062
1082
  },
1063
1083
  "disableHostCheck": {
1064
1084
  "type": "boolean",
1065
- "description": "Don't verify connected clients are part of allowed hosts.",
1085
+ "description": "When true, don't verify that connected clients are part of allowed hosts.",
1066
1086
  "default": false
1067
1087
  },
1068
1088
  "hmr": {
1069
1089
  "type": "boolean",
1070
- "description": "Enable hot module replacement.",
1090
+ "description": "When true, enable hot module replacement.",
1071
1091
  "default": false
1072
1092
  },
1073
1093
  "watch": {
1074
1094
  "type": "boolean",
1075
- "description": "Rebuild on change.",
1095
+ "description": "When true, rebuild on change.",
1076
1096
  "default": true
1077
1097
  },
1078
1098
  "hmrWarning": {
1079
1099
  "type": "boolean",
1080
- "description": "Show a warning when the --hmr option is enabled.",
1100
+ "description": "When true, show a warning when the --hmr option is enabled.",
1081
1101
  "default": true
1082
1102
  },
1083
1103
  "servePathDefaultWarning": {
1084
1104
  "type": "boolean",
1085
- "description": "Show a warning when deploy-url/base-href use unsupported serve path values.",
1105
+ "description": "When true, show a warning when deploy-url/base-href use unsupported serve path values.",
1086
1106
  "default": true
1087
1107
  },
1088
1108
  "optimization": {
1089
- "description": "Enables optimization of the build output.",
1109
+ "description": "Enable optimization of the build output.",
1090
1110
  "oneOf": [
1091
1111
  {
1092
1112
  "type": "object",
1093
1113
  "properties": {
1094
1114
  "scripts": {
1095
1115
  "type": "boolean",
1096
- "description": "Enables optimization of the scripts output.",
1116
+ "description": "When true, enable optimization of the scripts output.",
1097
1117
  "default": true
1098
1118
  },
1099
1119
  "styles": {
1100
1120
  "type": "boolean",
1101
- "description": "Enables optimization of the styles output.",
1121
+ "description": "When true, enable optimization of the styles output.",
1102
1122
  "default": true
1103
1123
  }
1104
1124
  },
@@ -1111,10 +1131,10 @@
1111
1131
  },
1112
1132
  "aot": {
1113
1133
  "type": "boolean",
1114
- "description": "Build using Ahead of Time compilation."
1134
+ "description": "Build using ahead-of-time compilation."
1115
1135
  },
1116
1136
  "sourceMap": {
1117
- "description": "Output sourcemaps.",
1137
+ "description": "When true, output sourcemaps.",
1118
1138
  "default": true,
1119
1139
  "oneOf": [
1120
1140
  {
@@ -1122,17 +1142,17 @@
1122
1142
  "properties": {
1123
1143
  "scripts": {
1124
1144
  "type": "boolean",
1125
- "description": "Output sourcemaps for all scripts.",
1145
+ "description": "When true, output sourcemaps for all scripts.",
1126
1146
  "default": true
1127
1147
  },
1128
1148
  "styles": {
1129
1149
  "type": "boolean",
1130
- "description": "Output sourcemaps for all styles.",
1150
+ "description": "When true, output sourcemaps for all styles.",
1131
1151
  "default": true
1132
1152
  },
1133
1153
  "vendor": {
1134
1154
  "type": "boolean",
1135
- "description": "Resolve vendor packages sourcemaps.",
1155
+ "description": "When true, resolve vendor packages sourcemaps.",
1136
1156
  "default": false
1137
1157
  }
1138
1158
  },
@@ -1145,20 +1165,20 @@
1145
1165
  },
1146
1166
  "vendorSourceMap": {
1147
1167
  "type": "boolean",
1148
- "description": "Resolve vendor packages sourcemaps.",
1168
+ "description": "When true, resolve vendor packages sourcemaps.",
1149
1169
  "default": false
1150
1170
  },
1151
1171
  "evalSourceMap": {
1152
1172
  "type": "boolean",
1153
- "description": "Output in-file eval sourcemaps."
1173
+ "description": "When true, output in-file eval sourcemaps."
1154
1174
  },
1155
1175
  "vendorChunk": {
1156
1176
  "type": "boolean",
1157
- "description": "Use a separate bundle containing only vendor libraries."
1177
+ "description": "When true, use a separate bundle containing only vendor libraries."
1158
1178
  },
1159
1179
  "commonChunk": {
1160
1180
  "type": "boolean",
1161
- "description": "Use a separate bundle containing code used across multiple bundles."
1181
+ "description": "When true, use a separate bundle containing code used across multiple bundles."
1162
1182
  },
1163
1183
  "baseHref": {
1164
1184
  "type": "string",
@@ -1170,11 +1190,11 @@
1170
1190
  },
1171
1191
  "verbose": {
1172
1192
  "type": "boolean",
1173
- "description": "Adds more details to output logging."
1193
+ "description": "When true, add more details to output logging."
1174
1194
  },
1175
1195
  "progress": {
1176
1196
  "type": "boolean",
1177
- "description": "Log progress to the console while building."
1197
+ "description": "When true, log progress to the console while building."
1178
1198
  }
1179
1199
  },
1180
1200
  "additionalProperties": false
@@ -5,7 +5,7 @@
5
5
  * Use of this source code is governed by an MIT-style license that can be
6
6
  * found in the LICENSE file at https://angular.io/license
7
7
  */
8
- import { Architect, TargetSpecifier } from '@angular-devkit/architect';
8
+ import { Architect, BuilderConfiguration, TargetSpecifier } from '@angular-devkit/architect';
9
9
  import { experimental, json } from '@angular-devkit/core';
10
10
  import { BaseCommandOptions, Command } from './command';
11
11
  import { Arguments } from './interface';
@@ -24,7 +24,8 @@ export declare abstract class ArchitectCommand<T extends ArchitectCommandOptions
24
24
  target: string | undefined;
25
25
  initialize(options: ArchitectCommandOptions & Arguments): Promise<void>;
26
26
  run(options: ArchitectCommandOptions & Arguments): Promise<number>;
27
- protected runSingleTarget(targetSpec: TargetSpecifier, options: string[]): Promise<1 | 0>;
27
+ protected runBepTarget<T>(command: string, configuration: BuilderConfiguration<T>, buildEventLog: string): Promise<number>;
28
+ protected runSingleTarget(targetSpec: TargetSpecifier, targetOptions: string[], commandOptions: ArchitectCommandOptions & Arguments): Promise<number>;
28
29
  protected runArchitectTarget(options: ArchitectCommandOptions & Arguments): Promise<number>;
29
30
  private getProjectNamesByTarget;
30
31
  private _loadWorkspaceAndArchitect;
@@ -10,6 +10,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
10
10
  const architect_1 = require("@angular-devkit/architect");
11
11
  const core_1 = require("@angular-devkit/core");
12
12
  const node_1 = require("@angular-devkit/core/node");
13
+ const bep_1 = require("../utilities/bep");
13
14
  const json_schema_1 = require("../utilities/json-schema");
14
15
  const command_1 = require("./command");
15
16
  const parser_1 = require("./parser");
@@ -132,14 +133,34 @@ class ArchitectCommand extends command_1.Command {
132
133
  async run(options) {
133
134
  return await this.runArchitectTarget(options);
134
135
  }
135
- async runSingleTarget(targetSpec, options) {
136
+ async runBepTarget(command, configuration, buildEventLog) {
137
+ const bep = new bep_1.BepJsonWriter(buildEventLog);
138
+ // Send start
139
+ bep.writeBuildStarted(command);
140
+ let last = 1;
141
+ let rebuild = false;
142
+ await this._architect.run(configuration, { logger: this.logger }).forEach(event => {
143
+ last = event.success ? 0 : 1;
144
+ if (rebuild) {
145
+ // NOTE: This will have an incorrect timestamp but this cannot be fixed
146
+ // until builders report additional status events
147
+ bep.writeBuildStarted(command);
148
+ }
149
+ else {
150
+ rebuild = true;
151
+ }
152
+ bep.writeBuildFinished(last);
153
+ });
154
+ return last;
155
+ }
156
+ async runSingleTarget(targetSpec, targetOptions, commandOptions) {
136
157
  // We need to build the builderSpec twice because architect does not understand
137
158
  // overrides separately (getting the configuration builds the whole project, including
138
159
  // overrides).
139
160
  const builderConf = this._architect.getBuilderConfiguration(targetSpec);
140
161
  const builderDesc = await this._architect.getBuilderDescription(builderConf).toPromise();
141
162
  const targetOptionArray = await json_schema_1.parseJsonSchemaToOptions(this._registry, builderDesc.schema);
142
- const overrides = parser_1.parseArguments(options, targetOptionArray, this.logger);
163
+ const overrides = parser_1.parseArguments(targetOptions, targetOptionArray, this.logger);
143
164
  if (overrides['--']) {
144
165
  (overrides['--'] || []).forEach(additional => {
145
166
  this.logger.fatal(`Unknown option: '${additional.split(/=/)[0]}'`);
@@ -151,8 +172,17 @@ class ArchitectCommand extends command_1.Command {
151
172
  logger: this.logger,
152
173
  targetSpecifier: targetSpec,
153
174
  };
154
- const result = await this._architect.run(realBuilderConf, builderContext).toPromise();
155
- return result.success ? 0 : 1;
175
+ if (commandOptions.buildEventLog && ['build', 'serve'].includes(this.description.name)) {
176
+ // The build/serve commands supports BEP messaging
177
+ this.logger.warn('BEP support is experimental and subject to change.');
178
+ return this.runBepTarget(this.description.name, realBuilderConf, commandOptions.buildEventLog);
179
+ }
180
+ else {
181
+ const result = await this._architect
182
+ .run(realBuilderConf, builderContext)
183
+ .toPromise();
184
+ return result.success ? 0 : 1;
185
+ }
156
186
  }
157
187
  async runArchitectTarget(options) {
158
188
  const extra = options['--'] || [];
@@ -163,12 +193,12 @@ class ArchitectCommand extends command_1.Command {
163
193
  // Running them in parallel would jumble the log messages.
164
194
  let result = 0;
165
195
  for (const project of this.getProjectNamesByTarget(this.target)) {
166
- result |= await this.runSingleTarget(Object.assign({}, targetSpec, { project }), extra);
196
+ result |= await this.runSingleTarget(Object.assign({}, targetSpec, { project }), extra, options);
167
197
  }
168
198
  return result;
169
199
  }
170
200
  else {
171
- return await this.runSingleTarget(targetSpec, extra);
201
+ return await this.runSingleTarget(targetSpec, extra, options);
172
202
  }
173
203
  }
174
204
  catch (e) {
@@ -250,4 +280,4 @@ class ArchitectCommand extends command_1.Command {
250
280
  }
251
281
  }
252
282
  exports.ArchitectCommand = ArchitectCommand;
253
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"architect-command.js","sourceRoot":"./","sources":["packages/angular/cli/models/architect-command.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 {\n  Architect,\n  BuilderContext,\n  TargetSpecifier,\n} from '@angular-devkit/architect';\nimport { experimental, json, schema, tags } from '@angular-devkit/core';\nimport { NodeJsSyncHost, createConsoleLogger } from '@angular-devkit/core/node';\nimport { parseJsonSchemaToOptions } from '../utilities/json-schema';\nimport { BaseCommandOptions, Command } from './command';\nimport { Arguments, Option } from './interface';\nimport { parseArguments } from './parser';\nimport { WorkspaceLoader } from './workspace-loader';\n\nexport interface ArchitectCommandOptions extends BaseCommandOptions {\n  project?: string;\n  configuration?: string;\n  prod?: boolean;\n  target?: string;\n}\n\nexport abstract class ArchitectCommand<\n  T extends ArchitectCommandOptions = ArchitectCommandOptions,\n> extends Command<ArchitectCommandOptions> {\n  private _host = new NodeJsSyncHost();\n  protected _architect: Architect;\n  protected _workspace: experimental.workspace.Workspace;\n  protected _registry: json.schema.SchemaRegistry;\n\n  // If this command supports running multiple targets.\n  protected multiTarget = false;\n\n  target: string | undefined;\n\n  public async initialize(options: ArchitectCommandOptions & Arguments): Promise<void> {\n    await super.initialize(options);\n\n    this._registry = new json.schema.CoreSchemaRegistry();\n    this._registry.addPostTransform(json.schema.transforms.addUndefinedDefaults);\n\n    await this._loadWorkspaceAndArchitect();\n\n    if (!this.target) {\n      if (options.help) {\n        // This is a special case where we just return.\n        return;\n      }\n\n      const specifier = this._makeTargetSpecifier(options);\n      if (!specifier.project || !specifier.target) {\n        throw new Error('Cannot determine project or target for command.');\n      }\n\n      return;\n    }\n\n    const commandLeftovers = options['--'];\n    let projectName = options.project;\n    const targetProjectNames: string[] = [];\n    for (const name of this._workspace.listProjectNames()) {\n      if (this._architect.listProjectTargets(name).includes(this.target)) {\n        targetProjectNames.push(name);\n      }\n    }\n\n    if (targetProjectNames.length === 0) {\n      throw new Error(`No projects support the '${this.target}' target.`);\n    }\n\n    if (projectName && !targetProjectNames.includes(projectName)) {\n      throw new Error(`Project '${projectName}' does not support the '${this.target}' target.`);\n    }\n\n    if (!projectName && commandLeftovers && commandLeftovers.length > 0) {\n      const builderNames = new Set<string>();\n      const leftoverMap = new Map<string, { optionDefs: Option[], parsedOptions: Arguments }>();\n      let potentialProjectNames = new Set<string>(targetProjectNames);\n      for (const name of targetProjectNames) {\n        const builderConfig = this._architect.getBuilderConfiguration({\n          project: name,\n          target: this.target,\n        });\n\n        if (this.multiTarget) {\n          builderNames.add(builderConfig.builder);\n        }\n\n        const builderDesc = await this._architect.getBuilderDescription(builderConfig).toPromise();\n        const optionDefs = await parseJsonSchemaToOptions(this._registry, builderDesc.schema);\n        const parsedOptions = parseArguments([...commandLeftovers], optionDefs);\n        const builderLeftovers = parsedOptions['--'] || [];\n        leftoverMap.set(name, { optionDefs, parsedOptions });\n\n        potentialProjectNames = new Set(builderLeftovers.filter(x => potentialProjectNames.has(x)));\n      }\n\n      if (potentialProjectNames.size === 1) {\n        projectName = [...potentialProjectNames][0];\n\n        // remove the project name from the leftovers\n        const optionInfo = leftoverMap.get(projectName);\n        if (optionInfo) {\n          const locations = [];\n          let i = 0;\n          while (i < commandLeftovers.length) {\n            i = commandLeftovers.indexOf(projectName, i + 1);\n            if (i === -1) {\n              break;\n            }\n            locations.push(i);\n          }\n          delete optionInfo.parsedOptions['--'];\n          for (const location of locations) {\n            const tempLeftovers = [...commandLeftovers];\n            tempLeftovers.splice(location, 1);\n            const tempArgs = parseArguments([...tempLeftovers], optionInfo.optionDefs);\n            delete tempArgs['--'];\n            if (JSON.stringify(optionInfo.parsedOptions) === JSON.stringify(tempArgs)) {\n              options['--'] = tempLeftovers;\n              break;\n            }\n          }\n        }\n      }\n\n      if (!projectName && this.multiTarget && builderNames.size > 1) {\n        throw new Error(tags.oneLine`\n          Architect commands with command line overrides cannot target different builders. The\n          '${this.target}' target would run on projects ${targetProjectNames.join()} which have the\n          following builders: ${'\\n  ' + [...builderNames].join('\\n  ')}\n        `);\n      }\n    }\n\n    if (!projectName && !this.multiTarget) {\n      const defaultProjectName = this._workspace.getDefaultProjectName();\n      if (targetProjectNames.length === 1) {\n        projectName = targetProjectNames[0];\n      } else if (defaultProjectName && targetProjectNames.includes(defaultProjectName)) {\n        projectName = defaultProjectName;\n      } else if (options.help) {\n        // This is a special case where we just return.\n        return;\n      } else {\n        throw new Error('Cannot determine project or target for command.');\n      }\n    }\n\n    options.project = projectName;\n\n    const builderConf = this._architect.getBuilderConfiguration({\n      project: projectName || (targetProjectNames.length > 0 ? targetProjectNames[0] : ''),\n      target: this.target,\n    });\n    const builderDesc = await this._architect.getBuilderDescription(builderConf).toPromise();\n\n    this.description.options.push(...(\n      await parseJsonSchemaToOptions(this._registry, builderDesc.schema)\n    ));\n  }\n\n  async run(options: ArchitectCommandOptions & Arguments) {\n    return await this.runArchitectTarget(options);\n  }\n\n  protected async runSingleTarget(targetSpec: TargetSpecifier, options: string[]) {\n    // We need to build the builderSpec twice because architect does not understand\n    // overrides separately (getting the configuration builds the whole project, including\n    // overrides).\n    const builderConf = this._architect.getBuilderConfiguration(targetSpec);\n    const builderDesc = await this._architect.getBuilderDescription(builderConf).toPromise();\n    const targetOptionArray = await parseJsonSchemaToOptions(this._registry, builderDesc.schema);\n    const overrides = parseArguments(options, targetOptionArray, this.logger);\n\n    if (overrides['--']) {\n      (overrides['--'] || []).forEach(additional => {\n        this.logger.fatal(`Unknown option: '${additional.split(/=/)[0]}'`);\n      });\n\n      return 1;\n    }\n    const realBuilderConf = this._architect.getBuilderConfiguration({ ...targetSpec, overrides });\n    const builderContext: Partial<BuilderContext> = {\n      logger: this.logger,\n      targetSpecifier: targetSpec,\n    };\n    const result = await this._architect.run(realBuilderConf, builderContext).toPromise();\n\n    return result.success ? 0 : 1;\n  }\n\n  protected async runArchitectTarget(\n    options: ArchitectCommandOptions & Arguments,\n  ): Promise<number> {\n    const extra = options['--'] || [];\n\n    try {\n      const targetSpec = this._makeTargetSpecifier(options);\n      if (!targetSpec.project && this.target) {\n        // This runs each target sequentially.\n        // Running them in parallel would jumble the log messages.\n        let result = 0;\n        for (const project of this.getProjectNamesByTarget(this.target)) {\n          result |= await this.runSingleTarget({ ...targetSpec, project }, extra);\n        }\n\n        return result;\n      } else {\n        return await this.runSingleTarget(targetSpec, extra);\n      }\n    } catch (e) {\n      if (e instanceof schema.SchemaValidationException) {\n        const newErrors: schema.SchemaValidatorError[] = [];\n        for (const schemaError of e.errors) {\n          if (schemaError.keyword === 'additionalProperties') {\n            const unknownProperty = schemaError.params.additionalProperty;\n            if (unknownProperty in options) {\n              const dashes = unknownProperty.length === 1 ? '-' : '--';\n              this.logger.fatal(`Unknown option: '${dashes}${unknownProperty}'`);\n              continue;\n            }\n          }\n          newErrors.push(schemaError);\n        }\n\n        if (newErrors.length > 0) {\n          this.logger.error(new schema.SchemaValidationException(newErrors).message);\n        }\n\n        return 1;\n      } else {\n        throw e;\n      }\n    }\n  }\n\n  private getProjectNamesByTarget(targetName: string): string[] {\n    const allProjectsForTargetName = this._workspace.listProjectNames().map(projectName =>\n      this._architect.listProjectTargets(projectName).includes(targetName) ? projectName : null,\n    ).filter(x => !!x) as string[];\n\n    if (this.multiTarget) {\n      // For multi target commands, we always list all projects that have the target.\n      return allProjectsForTargetName;\n    } else {\n      // For single target commands, we try the default project first,\n      // then the full list if it has a single project, then error out.\n      const maybeDefaultProject = this._workspace.getDefaultProjectName();\n      if (maybeDefaultProject && allProjectsForTargetName.includes(maybeDefaultProject)) {\n        return [maybeDefaultProject];\n      }\n\n      if (allProjectsForTargetName.length === 1) {\n        return allProjectsForTargetName;\n      }\n\n      throw new Error(`Could not determine a single project for the '${targetName}' target.`);\n    }\n  }\n\n  private async _loadWorkspaceAndArchitect() {\n    const workspaceLoader = new WorkspaceLoader(this._host);\n\n    const workspace = await workspaceLoader.loadWorkspace(this.workspace.root);\n\n    this._workspace = workspace;\n    this._architect = await new Architect(workspace).loadArchitect().toPromise();\n  }\n\n  private _makeTargetSpecifier(commandOptions: ArchitectCommandOptions): TargetSpecifier {\n    let project, target, configuration;\n\n    if (commandOptions.target) {\n      [project, target, configuration] = commandOptions.target.split(':');\n\n      if (commandOptions.configuration) {\n        configuration = commandOptions.configuration;\n      }\n    } else {\n      project = commandOptions.project;\n      target = this.target;\n      configuration = commandOptions.configuration;\n      if (!configuration && commandOptions.prod) {\n        configuration = 'production';\n      }\n    }\n\n    if (!project) {\n      project = '';\n    }\n    if (!target) {\n      target = '';\n    }\n\n    return {\n      project,\n      configuration,\n      target,\n    };\n  }\n}\n"]}
283
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"architect-command.js","sourceRoot":"./","sources":["packages/angular/cli/models/architect-command.ts"],"names":[],"mappings":";;AAAA;;;;;;GAMG;AACH,yDAKmC;AACnC,+CAAwE;AACxE,oDAA2D;AAC3D,0CAAiD;AACjD,0DAAoE;AACpE,uCAAwD;AAExD,qCAA0C;AAC1C,yDAAqD;AASrD,MAAsB,gBAEpB,SAAQ,iBAAgC;IAF1C;;QAGU,UAAK,GAAG,IAAI,qBAAc,EAAE,CAAC;QAKrC,qDAAqD;QAC3C,gBAAW,GAAG,KAAK,CAAC;IA4ThC,CAAC;IAxTQ,KAAK,CAAC,UAAU,CAAC,OAA4C;QAClE,MAAM,KAAK,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;QAEhC,IAAI,CAAC,SAAS,GAAG,IAAI,WAAI,CAAC,MAAM,CAAC,kBAAkB,EAAE,CAAC;QACtD,IAAI,CAAC,SAAS,CAAC,gBAAgB,CAAC,WAAI,CAAC,MAAM,CAAC,UAAU,CAAC,oBAAoB,CAAC,CAAC;QAE7E,MAAM,IAAI,CAAC,0BAA0B,EAAE,CAAC;QAExC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YAChB,IAAI,OAAO,CAAC,IAAI,EAAE;gBAChB,+CAA+C;gBAC/C,OAAO;aACR;YAED,MAAM,SAAS,GAAG,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,CAAC;YACrD,IAAI,CAAC,SAAS,CAAC,OAAO,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE;gBAC3C,MAAM,IAAI,KAAK,CAAC,iDAAiD,CAAC,CAAC;aACpE;YAED,OAAO;SACR;QAED,MAAM,gBAAgB,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;QACvC,IAAI,WAAW,GAAG,OAAO,CAAC,OAAO,CAAC;QAClC,MAAM,kBAAkB,GAAa,EAAE,CAAC;QACxC,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,UAAU,CAAC,gBAAgB,EAAE,EAAE;YACrD,IAAI,IAAI,CAAC,UAAU,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE;gBAClE,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;aAC/B;SACF;QAED,IAAI,kBAAkB,CAAC,MAAM,KAAK,CAAC,EAAE;YACnC,MAAM,IAAI,KAAK,CAAC,4BAA4B,IAAI,CAAC,MAAM,WAAW,CAAC,CAAC;SACrE;QAED,IAAI,WAAW,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,WAAW,CAAC,EAAE;YAC5D,MAAM,IAAI,KAAK,CAAC,YAAY,WAAW,2BAA2B,IAAI,CAAC,MAAM,WAAW,CAAC,CAAC;SAC3F;QAED,IAAI,CAAC,WAAW,IAAI,gBAAgB,IAAI,gBAAgB,CAAC,MAAM,GAAG,CAAC,EAAE;YACnE,MAAM,YAAY,GAAG,IAAI,GAAG,EAAU,CAAC;YACvC,MAAM,WAAW,GAAG,IAAI,GAAG,EAA8D,CAAC;YAC1F,IAAI,qBAAqB,GAAG,IAAI,GAAG,CAAS,kBAAkB,CAAC,CAAC;YAChE,KAAK,MAAM,IAAI,IAAI,kBAAkB,EAAE;gBACrC,MAAM,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,uBAAuB,CAAC;oBAC5D,OAAO,EAAE,IAAI;oBACb,MAAM,EAAE,IAAI,CAAC,MAAM;iBACpB,CAAC,CAAC;gBAEH,IAAI,IAAI,CAAC,WAAW,EAAE;oBACpB,YAAY,CAAC,GAAG,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;iBACzC;gBAED,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,qBAAqB,CAAC,aAAa,CAAC,CAAC,SAAS,EAAE,CAAC;gBAC3F,MAAM,UAAU,GAAG,MAAM,sCAAwB,CAAC,IAAI,CAAC,SAAS,EAAE,WAAW,CAAC,MAAM,CAAC,CAAC;gBACtF,MAAM,aAAa,GAAG,uBAAc,CAAC,CAAC,GAAG,gBAAgB,CAAC,EAAE,UAAU,CAAC,CAAC;gBACxE,MAAM,gBAAgB,GAAG,aAAa,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;gBACnD,WAAW,CAAC,GAAG,CAAC,IAAI,EAAE,EAAE,UAAU,EAAE,aAAa,EAAE,CAAC,CAAC;gBAErD,qBAAqB,GAAG,IAAI,GAAG,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,qBAAqB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;aAC7F;YAED,IAAI,qBAAqB,CAAC,IAAI,KAAK,CAAC,EAAE;gBACpC,WAAW,GAAG,CAAC,GAAG,qBAAqB,CAAC,CAAC,CAAC,CAAC,CAAC;gBAE5C,6CAA6C;gBAC7C,MAAM,UAAU,GAAG,WAAW,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;gBAChD,IAAI,UAAU,EAAE;oBACd,MAAM,SAAS,GAAG,EAAE,CAAC;oBACrB,IAAI,CAAC,GAAG,CAAC,CAAC;oBACV,OAAO,CAAC,GAAG,gBAAgB,CAAC,MAAM,EAAE;wBAClC,CAAC,GAAG,gBAAgB,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;wBACjD,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE;4BACZ,MAAM;yBACP;wBACD,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;qBACnB;oBACD,OAAO,UAAU,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;oBACtC,KAAK,MAAM,QAAQ,IAAI,SAAS,EAAE;wBAChC,MAAM,aAAa,GAAG,CAAC,GAAG,gBAAgB,CAAC,CAAC;wBAC5C,aAAa,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;wBAClC,MAAM,QAAQ,GAAG,uBAAc,CAAC,CAAC,GAAG,aAAa,CAAC,EAAE,UAAU,CAAC,UAAU,CAAC,CAAC;wBAC3E,OAAO,QAAQ,CAAC,IAAI,CAAC,CAAC;wBACtB,IAAI,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE;4BACzE,OAAO,CAAC,IAAI,CAAC,GAAG,aAAa,CAAC;4BAC9B,MAAM;yBACP;qBACF;iBACF;aACF;YAED,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,WAAW,IAAI,YAAY,CAAC,IAAI,GAAG,CAAC,EAAE;gBAC7D,MAAM,IAAI,KAAK,CAAC,WAAI,CAAC,OAAO,CAAA;;aAEvB,IAAI,CAAC,MAAM,kCAAkC,kBAAkB,CAAC,IAAI,EAAE;gCACnD,MAAM,GAAG,CAAC,GAAG,YAAY,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC;SAC9D,CAAC,CAAC;aACJ;SACF;QAED,IAAI,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;YACrC,MAAM,kBAAkB,GAAG,IAAI,CAAC,UAAU,CAAC,qBAAqB,EAAE,CAAC;YACnE,IAAI,kBAAkB,CAAC,MAAM,KAAK,CAAC,EAAE;gBACnC,WAAW,GAAG,kBAAkB,CAAC,CAAC,CAAC,CAAC;aACrC;iBAAM,IAAI,kBAAkB,IAAI,kBAAkB,CAAC,QAAQ,CAAC,kBAAkB,CAAC,EAAE;gBAChF,WAAW,GAAG,kBAAkB,CAAC;aAClC;iBAAM,IAAI,OAAO,CAAC,IAAI,EAAE;gBACvB,+CAA+C;gBAC/C,OAAO;aACR;iBAAM;gBACL,MAAM,IAAI,KAAK,CAAC,iDAAiD,CAAC,CAAC;aACpE;SACF;QAED,OAAO,CAAC,OAAO,GAAG,WAAW,CAAC;QAE9B,MAAM,WAAW,GAAG,IAAI,CAAC,UAAU,CAAC,uBAAuB,CAAC;YAC1D,OAAO,EAAE,WAAW,IAAI,CAAC,kBAAkB,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;YACpF,MAAM,EAAE,IAAI,CAAC,MAAM;SACpB,CAAC,CAAC;QACH,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,qBAAqB,CAAC,WAAW,CAAC,CAAC,SAAS,EAAE,CAAC;QAEzF,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAC/B,MAAM,sCAAwB,CAAC,IAAI,CAAC,SAAS,EAAE,WAAW,CAAC,MAAM,CAAC,CACnE,CAAC,CAAC;IACL,CAAC;IAED,KAAK,CAAC,GAAG,CAAC,OAA4C;QACpD,OAAO,MAAM,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC;IAChD,CAAC;IAES,KAAK,CAAC,YAAY,CAC1B,OAAe,EACf,aAAsC,EACtC,aAAqB;QAErB,MAAM,GAAG,GAAG,IAAI,mBAAa,CAAC,aAAa,CAAC,CAAC;QAE7C,aAAa;QACb,GAAG,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC;QAE/B,IAAI,IAAI,GAAG,CAAC,CAAC;QACb,IAAI,OAAO,GAAG,KAAK,CAAC;QACpB,MAAM,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,aAAa,EAAE,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;YAChF,IAAI,GAAG,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAE7B,IAAI,OAAO,EAAE;gBACX,uEAAuE;gBACvE,uDAAuD;gBACvD,GAAG,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC;aAChC;iBAAM;gBACL,OAAO,GAAG,IAAI,CAAC;aAChB;YAED,GAAG,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;QAC/B,CAAC,CAAC,CAAC;QAEH,OAAO,IAAI,CAAC;IACd,CAAC;IAES,KAAK,CAAC,eAAe,CAC7B,UAA2B,EAC3B,aAAuB,EACvB,cAAmD;QACnD,+EAA+E;QAC/E,sFAAsF;QACtF,cAAc;QACd,MAAM,WAAW,GAAG,IAAI,CAAC,UAAU,CAAC,uBAAuB,CAAC,UAAU,CAAC,CAAC;QACxE,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,qBAAqB,CAAC,WAAW,CAAC,CAAC,SAAS,EAAE,CAAC;QACzF,MAAM,iBAAiB,GAAG,MAAM,sCAAwB,CAAC,IAAI,CAAC,SAAS,EAAE,WAAW,CAAC,MAAM,CAAC,CAAC;QAC7F,MAAM,SAAS,GAAG,uBAAc,CAAC,aAAa,EAAE,iBAAiB,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;QAEhF,IAAI,SAAS,CAAC,IAAI,CAAC,EAAE;YACnB,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE;gBAC3C,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,oBAAoB,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;YACrE,CAAC,CAAC,CAAC;YAEH,OAAO,CAAC,CAAC;SACV;QACD,MAAM,eAAe,GAAG,IAAI,CAAC,UAAU,CAAC,uBAAuB,mBAAM,UAAU,IAAE,SAAS,IAAG,CAAC;QAC9F,MAAM,cAAc,GAA4B;YAC9C,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,eAAe,EAAE,UAAU;SAC5B,CAAC;QAEF,IAAI,cAAc,CAAC,aAAa,IAAI,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE;YACtF,kDAAkD;YAClD,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,oDAAoD,CAAC,CAAC;YAEvE,OAAO,IAAI,CAAC,YAAY,CACtB,IAAI,CAAC,WAAW,CAAC,IAAI,EACrB,eAAe,EACf,cAAc,CAAC,aAAuB,CACvC,CAAC;SACH;aAAM;YACL,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,UAAU;iBACjC,GAAG,CAAC,eAAe,EAAE,cAAc,CAAC;iBACpC,SAAS,EAAE,CAAC;YAEf,OAAO,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;SAC/B;IACH,CAAC;IAES,KAAK,CAAC,kBAAkB,CAChC,OAA4C;QAE5C,MAAM,KAAK,GAAG,OAAO,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;QAElC,IAAI;YACF,MAAM,UAAU,GAAG,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,CAAC;YACtD,IAAI,CAAC,UAAU,CAAC,OAAO,IAAI,IAAI,CAAC,MAAM,EAAE;gBACtC,sCAAsC;gBACtC,0DAA0D;gBAC1D,IAAI,MAAM,GAAG,CAAC,CAAC;gBACf,KAAK,MAAM,OAAO,IAAI,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE;oBAC/D,MAAM,IAAI,MAAM,IAAI,CAAC,eAAe,mBAAM,UAAU,IAAE,OAAO,KAAI,KAAK,EAAE,OAAO,CAAC,CAAC;iBAClF;gBAED,OAAO,MAAM,CAAC;aACf;iBAAM;gBACL,OAAO,MAAM,IAAI,CAAC,eAAe,CAAC,UAAU,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC;aAC/D;SACF;QAAC,OAAO,CAAC,EAAE;YACV,IAAI,CAAC,YAAY,aAAM,CAAC,yBAAyB,EAAE;gBACjD,MAAM,SAAS,GAAkC,EAAE,CAAC;gBACpD,KAAK,MAAM,WAAW,IAAI,CAAC,CAAC,MAAM,EAAE;oBAClC,IAAI,WAAW,CAAC,OAAO,KAAK,sBAAsB,EAAE;wBAClD,MAAM,eAAe,GAAG,WAAW,CAAC,MAAM,CAAC,kBAAkB,CAAC;wBAC9D,IAAI,eAAe,IAAI,OAAO,EAAE;4BAC9B,MAAM,MAAM,GAAG,eAAe,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC;4BACzD,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,oBAAoB,MAAM,GAAG,eAAe,GAAG,CAAC,CAAC;4BACnE,SAAS;yBACV;qBACF;oBACD,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;iBAC7B;gBAED,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE;oBACxB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,aAAM,CAAC,yBAAyB,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,CAAC;iBAC5E;gBAED,OAAO,CAAC,CAAC;aACV;iBAAM;gBACL,MAAM,CAAC,CAAC;aACT;SACF;IACH,CAAC;IAEO,uBAAuB,CAAC,UAAkB;QAChD,MAAM,wBAAwB,GAAG,IAAI,CAAC,UAAU,CAAC,gBAAgB,EAAE,CAAC,GAAG,CAAC,WAAW,CAAC,EAAE,CACpF,IAAI,CAAC,UAAU,CAAC,kBAAkB,CAAC,WAAW,CAAC,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAC1F,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAa,CAAC;QAE/B,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,+EAA+E;YAC/E,OAAO,wBAAwB,CAAC;SACjC;aAAM;YACL,gEAAgE;YAChE,iEAAiE;YACjE,MAAM,mBAAmB,GAAG,IAAI,CAAC,UAAU,CAAC,qBAAqB,EAAE,CAAC;YACpE,IAAI,mBAAmB,IAAI,wBAAwB,CAAC,QAAQ,CAAC,mBAAmB,CAAC,EAAE;gBACjF,OAAO,CAAC,mBAAmB,CAAC,CAAC;aAC9B;YAED,IAAI,wBAAwB,CAAC,MAAM,KAAK,CAAC,EAAE;gBACzC,OAAO,wBAAwB,CAAC;aACjC;YAED,MAAM,IAAI,KAAK,CAAC,iDAAiD,UAAU,WAAW,CAAC,CAAC;SACzF;IACH,CAAC;IAEO,KAAK,CAAC,0BAA0B;QACtC,MAAM,eAAe,GAAG,IAAI,kCAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAExD,MAAM,SAAS,GAAG,MAAM,eAAe,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAE3E,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;QAC5B,IAAI,CAAC,UAAU,GAAG,MAAM,IAAI,qBAAS,CAAC,SAAS,CAAC,CAAC,aAAa,EAAE,CAAC,SAAS,EAAE,CAAC;IAC/E,CAAC;IAEO,oBAAoB,CAAC,cAAuC;QAClE,IAAI,OAAO,EAAE,MAAM,EAAE,aAAa,CAAC;QAEnC,IAAI,cAAc,CAAC,MAAM,EAAE;YACzB,CAAC,OAAO,EAAE,MAAM,EAAE,aAAa,CAAC,GAAG,cAAc,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YAEpE,IAAI,cAAc,CAAC,aAAa,EAAE;gBAChC,aAAa,GAAG,cAAc,CAAC,aAAa,CAAC;aAC9C;SACF;aAAM;YACL,OAAO,GAAG,cAAc,CAAC,OAAO,CAAC;YACjC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;YACrB,aAAa,GAAG,cAAc,CAAC,aAAa,CAAC;YAC7C,IAAI,CAAC,aAAa,IAAI,cAAc,CAAC,IAAI,EAAE;gBACzC,aAAa,GAAG,YAAY,CAAC;aAC9B;SACF;QAED,IAAI,CAAC,OAAO,EAAE;YACZ,OAAO,GAAG,EAAE,CAAC;SACd;QACD,IAAI,CAAC,MAAM,EAAE;YACX,MAAM,GAAG,EAAE,CAAC;SACb;QAED,OAAO;YACL,OAAO;YACP,aAAa;YACb,MAAM;SACP,CAAC;IACJ,CAAC;CACF;AArUD,4CAqUC","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 {\n  Architect,\n  BuilderConfiguration,\n  BuilderContext,\n  TargetSpecifier,\n} from '@angular-devkit/architect';\nimport { experimental, json, schema, tags } from '@angular-devkit/core';\nimport { NodeJsSyncHost } from '@angular-devkit/core/node';\nimport { BepJsonWriter } from '../utilities/bep';\nimport { parseJsonSchemaToOptions } from '../utilities/json-schema';\nimport { BaseCommandOptions, Command } from './command';\nimport { Arguments, Option } from './interface';\nimport { parseArguments } from './parser';\nimport { WorkspaceLoader } from './workspace-loader';\n\nexport interface ArchitectCommandOptions extends BaseCommandOptions {\n  project?: string;\n  configuration?: string;\n  prod?: boolean;\n  target?: string;\n}\n\nexport abstract class ArchitectCommand<\n  T extends ArchitectCommandOptions = ArchitectCommandOptions,\n> extends Command<ArchitectCommandOptions> {\n  private _host = new NodeJsSyncHost();\n  protected _architect: Architect;\n  protected _workspace: experimental.workspace.Workspace;\n  protected _registry: json.schema.SchemaRegistry;\n\n  // If this command supports running multiple targets.\n  protected multiTarget = false;\n\n  target: string | undefined;\n\n  public async initialize(options: ArchitectCommandOptions & Arguments): Promise<void> {\n    await super.initialize(options);\n\n    this._registry = new json.schema.CoreSchemaRegistry();\n    this._registry.addPostTransform(json.schema.transforms.addUndefinedDefaults);\n\n    await this._loadWorkspaceAndArchitect();\n\n    if (!this.target) {\n      if (options.help) {\n        // This is a special case where we just return.\n        return;\n      }\n\n      const specifier = this._makeTargetSpecifier(options);\n      if (!specifier.project || !specifier.target) {\n        throw new Error('Cannot determine project or target for command.');\n      }\n\n      return;\n    }\n\n    const commandLeftovers = options['--'];\n    let projectName = options.project;\n    const targetProjectNames: string[] = [];\n    for (const name of this._workspace.listProjectNames()) {\n      if (this._architect.listProjectTargets(name).includes(this.target)) {\n        targetProjectNames.push(name);\n      }\n    }\n\n    if (targetProjectNames.length === 0) {\n      throw new Error(`No projects support the '${this.target}' target.`);\n    }\n\n    if (projectName && !targetProjectNames.includes(projectName)) {\n      throw new Error(`Project '${projectName}' does not support the '${this.target}' target.`);\n    }\n\n    if (!projectName && commandLeftovers && commandLeftovers.length > 0) {\n      const builderNames = new Set<string>();\n      const leftoverMap = new Map<string, { optionDefs: Option[], parsedOptions: Arguments }>();\n      let potentialProjectNames = new Set<string>(targetProjectNames);\n      for (const name of targetProjectNames) {\n        const builderConfig = this._architect.getBuilderConfiguration({\n          project: name,\n          target: this.target,\n        });\n\n        if (this.multiTarget) {\n          builderNames.add(builderConfig.builder);\n        }\n\n        const builderDesc = await this._architect.getBuilderDescription(builderConfig).toPromise();\n        const optionDefs = await parseJsonSchemaToOptions(this._registry, builderDesc.schema);\n        const parsedOptions = parseArguments([...commandLeftovers], optionDefs);\n        const builderLeftovers = parsedOptions['--'] || [];\n        leftoverMap.set(name, { optionDefs, parsedOptions });\n\n        potentialProjectNames = new Set(builderLeftovers.filter(x => potentialProjectNames.has(x)));\n      }\n\n      if (potentialProjectNames.size === 1) {\n        projectName = [...potentialProjectNames][0];\n\n        // remove the project name from the leftovers\n        const optionInfo = leftoverMap.get(projectName);\n        if (optionInfo) {\n          const locations = [];\n          let i = 0;\n          while (i < commandLeftovers.length) {\n            i = commandLeftovers.indexOf(projectName, i + 1);\n            if (i === -1) {\n              break;\n            }\n            locations.push(i);\n          }\n          delete optionInfo.parsedOptions['--'];\n          for (const location of locations) {\n            const tempLeftovers = [...commandLeftovers];\n            tempLeftovers.splice(location, 1);\n            const tempArgs = parseArguments([...tempLeftovers], optionInfo.optionDefs);\n            delete tempArgs['--'];\n            if (JSON.stringify(optionInfo.parsedOptions) === JSON.stringify(tempArgs)) {\n              options['--'] = tempLeftovers;\n              break;\n            }\n          }\n        }\n      }\n\n      if (!projectName && this.multiTarget && builderNames.size > 1) {\n        throw new Error(tags.oneLine`\n          Architect commands with command line overrides cannot target different builders. The\n          '${this.target}' target would run on projects ${targetProjectNames.join()} which have the\n          following builders: ${'\\n  ' + [...builderNames].join('\\n  ')}\n        `);\n      }\n    }\n\n    if (!projectName && !this.multiTarget) {\n      const defaultProjectName = this._workspace.getDefaultProjectName();\n      if (targetProjectNames.length === 1) {\n        projectName = targetProjectNames[0];\n      } else if (defaultProjectName && targetProjectNames.includes(defaultProjectName)) {\n        projectName = defaultProjectName;\n      } else if (options.help) {\n        // This is a special case where we just return.\n        return;\n      } else {\n        throw new Error('Cannot determine project or target for command.');\n      }\n    }\n\n    options.project = projectName;\n\n    const builderConf = this._architect.getBuilderConfiguration({\n      project: projectName || (targetProjectNames.length > 0 ? targetProjectNames[0] : ''),\n      target: this.target,\n    });\n    const builderDesc = await this._architect.getBuilderDescription(builderConf).toPromise();\n\n    this.description.options.push(...(\n      await parseJsonSchemaToOptions(this._registry, builderDesc.schema)\n    ));\n  }\n\n  async run(options: ArchitectCommandOptions & Arguments) {\n    return await this.runArchitectTarget(options);\n  }\n\n  protected async runBepTarget<T>(\n    command: string,\n    configuration: BuilderConfiguration<T>,\n    buildEventLog: string,\n  ): Promise<number> {\n    const bep = new BepJsonWriter(buildEventLog);\n\n    // Send start\n    bep.writeBuildStarted(command);\n\n    let last = 1;\n    let rebuild = false;\n    await this._architect.run(configuration, { logger: this.logger }).forEach(event => {\n      last = event.success ? 0 : 1;\n\n      if (rebuild) {\n        // NOTE: This will have an incorrect timestamp but this cannot be fixed\n        //       until builders report additional status events\n        bep.writeBuildStarted(command);\n      } else {\n        rebuild = true;\n      }\n\n      bep.writeBuildFinished(last);\n    });\n\n    return last;\n  }\n\n  protected async runSingleTarget(\n    targetSpec: TargetSpecifier,\n    targetOptions: string[],\n    commandOptions: ArchitectCommandOptions & Arguments) {\n    // We need to build the builderSpec twice because architect does not understand\n    // overrides separately (getting the configuration builds the whole project, including\n    // overrides).\n    const builderConf = this._architect.getBuilderConfiguration(targetSpec);\n    const builderDesc = await this._architect.getBuilderDescription(builderConf).toPromise();\n    const targetOptionArray = await parseJsonSchemaToOptions(this._registry, builderDesc.schema);\n    const overrides = parseArguments(targetOptions, targetOptionArray, this.logger);\n\n    if (overrides['--']) {\n      (overrides['--'] || []).forEach(additional => {\n        this.logger.fatal(`Unknown option: '${additional.split(/=/)[0]}'`);\n      });\n\n      return 1;\n    }\n    const realBuilderConf = this._architect.getBuilderConfiguration({ ...targetSpec, overrides });\n    const builderContext: Partial<BuilderContext> = {\n      logger: this.logger,\n      targetSpecifier: targetSpec,\n    };\n\n    if (commandOptions.buildEventLog && ['build', 'serve'].includes(this.description.name)) {\n      // The build/serve commands supports BEP messaging\n      this.logger.warn('BEP support is experimental and subject to change.');\n\n      return this.runBepTarget(\n        this.description.name,\n        realBuilderConf,\n        commandOptions.buildEventLog as string,\n      );\n    } else {\n      const result = await this._architect\n        .run(realBuilderConf, builderContext)\n        .toPromise();\n\n      return result.success ? 0 : 1;\n    }\n  }\n\n  protected async runArchitectTarget(\n    options: ArchitectCommandOptions & Arguments,\n  ): Promise<number> {\n    const extra = options['--'] || [];\n\n    try {\n      const targetSpec = this._makeTargetSpecifier(options);\n      if (!targetSpec.project && this.target) {\n        // This runs each target sequentially.\n        // Running them in parallel would jumble the log messages.\n        let result = 0;\n        for (const project of this.getProjectNamesByTarget(this.target)) {\n          result |= await this.runSingleTarget({ ...targetSpec, project }, extra, options);\n        }\n\n        return result;\n      } else {\n        return await this.runSingleTarget(targetSpec, extra, options);\n      }\n    } catch (e) {\n      if (e instanceof schema.SchemaValidationException) {\n        const newErrors: schema.SchemaValidatorError[] = [];\n        for (const schemaError of e.errors) {\n          if (schemaError.keyword === 'additionalProperties') {\n            const unknownProperty = schemaError.params.additionalProperty;\n            if (unknownProperty in options) {\n              const dashes = unknownProperty.length === 1 ? '-' : '--';\n              this.logger.fatal(`Unknown option: '${dashes}${unknownProperty}'`);\n              continue;\n            }\n          }\n          newErrors.push(schemaError);\n        }\n\n        if (newErrors.length > 0) {\n          this.logger.error(new schema.SchemaValidationException(newErrors).message);\n        }\n\n        return 1;\n      } else {\n        throw e;\n      }\n    }\n  }\n\n  private getProjectNamesByTarget(targetName: string): string[] {\n    const allProjectsForTargetName = this._workspace.listProjectNames().map(projectName =>\n      this._architect.listProjectTargets(projectName).includes(targetName) ? projectName : null,\n    ).filter(x => !!x) as string[];\n\n    if (this.multiTarget) {\n      // For multi target commands, we always list all projects that have the target.\n      return allProjectsForTargetName;\n    } else {\n      // For single target commands, we try the default project first,\n      // then the full list if it has a single project, then error out.\n      const maybeDefaultProject = this._workspace.getDefaultProjectName();\n      if (maybeDefaultProject && allProjectsForTargetName.includes(maybeDefaultProject)) {\n        return [maybeDefaultProject];\n      }\n\n      if (allProjectsForTargetName.length === 1) {\n        return allProjectsForTargetName;\n      }\n\n      throw new Error(`Could not determine a single project for the '${targetName}' target.`);\n    }\n  }\n\n  private async _loadWorkspaceAndArchitect() {\n    const workspaceLoader = new WorkspaceLoader(this._host);\n\n    const workspace = await workspaceLoader.loadWorkspace(this.workspace.root);\n\n    this._workspace = workspace;\n    this._architect = await new Architect(workspace).loadArchitect().toPromise();\n  }\n\n  private _makeTargetSpecifier(commandOptions: ArchitectCommandOptions): TargetSpecifier {\n    let project, target, configuration;\n\n    if (commandOptions.target) {\n      [project, target, configuration] = commandOptions.target.split(':');\n\n      if (commandOptions.configuration) {\n        configuration = commandOptions.configuration;\n      }\n    } else {\n      project = commandOptions.project;\n      target = this.target;\n      configuration = commandOptions.configuration;\n      if (!configuration && commandOptions.prod) {\n        configuration = 'production';\n      }\n    }\n\n    if (!project) {\n      project = '';\n    }\n    if (!target) {\n      target = '';\n    }\n\n    return {\n      project,\n      configuration,\n      target,\n    };\n  }\n}\n"]}