@angular-devkit/core 15.2.0-rc.0 → 16.0.0-next.0

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.
@@ -13,21 +13,15 @@ const utils_1 = require("../../json/utils");
13
13
  const definitions_1 = require("../definitions");
14
14
  const metadata_1 = require("./metadata");
15
15
  const utilities_1 = require("./utilities");
16
- const ANGULAR_WORKSPACE_EXTENSIONS = Object.freeze([
17
- 'cli',
18
- 'defaultProject',
19
- 'newProjectRoot',
20
- 'schematics',
21
- ]);
16
+ const ANGULAR_WORKSPACE_EXTENSIONS = Object.freeze(['cli', 'newProjectRoot', 'schematics']);
22
17
  const ANGULAR_PROJECT_EXTENSIONS = Object.freeze(['cli', 'schematics', 'projectType', 'i18n']);
23
18
  async function readJsonWorkspace(path, host, options = {}) {
24
- var _a, _b;
25
19
  const raw = await host.readFile(path);
26
20
  if (raw === undefined) {
27
21
  throw new Error('Unable to read workspace file.');
28
22
  }
29
23
  const ast = (0, jsonc_parser_1.parseTree)(raw, undefined, { allowTrailingComma: true, disallowComments: false });
30
- if ((ast === null || ast === void 0 ? void 0 : ast.type) !== 'object' || !ast.children) {
24
+ if (ast?.type !== 'object' || !ast.children) {
31
25
  throw new Error('Invalid workspace file - expected JSON object.');
32
26
  }
33
27
  // Version check
@@ -45,11 +39,11 @@ async function readJsonWorkspace(path, host, options = {}) {
45
39
  trackChanges: true,
46
40
  unprefixedWorkspaceExtensions: new Set([
47
41
  ...ANGULAR_WORKSPACE_EXTENSIONS,
48
- ...((_a = options.allowedWorkspaceExtensions) !== null && _a !== void 0 ? _a : []),
42
+ ...(options.allowedWorkspaceExtensions ?? []),
49
43
  ]),
50
44
  unprefixedProjectExtensions: new Set([
51
45
  ...ANGULAR_PROJECT_EXTENSIONS,
52
- ...((_b = options.allowedProjectExtensions) !== null && _b !== void 0 ? _b : []),
46
+ ...(options.allowedProjectExtensions ?? []),
53
47
  ]),
54
48
  error(message, _node) {
55
49
  // TODO: Diagnostic reporting support
@@ -108,12 +102,13 @@ function parseWorkspace(workspaceNode, context) {
108
102
  projects: projectCollection,
109
103
  // If not tracking changes the `extensions` variable will contain the parsed
110
104
  // values. Otherwise the extensions are tracked via a virtual AST object.
111
- extensions: extensions !== null && extensions !== void 0 ? extensions : (0, utilities_1.createVirtualAstObject)(workspaceNodeValue, {
112
- exclude: ['$schema', 'version', 'projects'],
113
- listener(path, value) {
114
- jsonMetadata.addChange(path, value);
115
- },
116
- }),
105
+ extensions: extensions ??
106
+ (0, utilities_1.createVirtualAstObject)(workspaceNodeValue, {
107
+ exclude: ['$schema', 'version', 'projects'],
108
+ listener(path, value) {
109
+ jsonMetadata.addChange(path, value);
110
+ },
111
+ }),
117
112
  };
118
113
  }
119
114
  function parseProjectsObject(projectsNode, context) {
@@ -191,22 +186,24 @@ function parseProject(projectName, projectNode, context) {
191
186
  targets: new definitions_1.TargetDefinitionCollection(targets, collectionListener),
192
187
  // If not tracking changes the `extensions` variable will contain the parsed
193
188
  // values. Otherwise the extensions are tracked via a virtual AST object.
194
- extensions: extensions !== null && extensions !== void 0 ? extensions : (0, utilities_1.createVirtualAstObject)(projectNodeValue, {
195
- exclude: ['architect', 'prefix', 'root', 'sourceRoot', 'targets'],
196
- listener(path, value) {
197
- jsonMetadata.addChange(['projects', projectName, ...path], value);
198
- },
199
- }),
189
+ extensions: extensions ??
190
+ (0, utilities_1.createVirtualAstObject)(projectNodeValue, {
191
+ exclude: ['architect', 'prefix', 'root', 'sourceRoot', 'targets'],
192
+ listener(path, value) {
193
+ jsonMetadata.addChange(['projects', projectName, ...path], value);
194
+ },
195
+ }),
200
196
  };
201
197
  const baseKeys = new Set(Object.keys(base));
202
- const project = properties !== null && properties !== void 0 ? properties : (0, utilities_1.createVirtualAstObject)(projectNodeValue, {
203
- include: ['prefix', 'root', 'sourceRoot', ...baseKeys],
204
- listener(path, value) {
205
- if (!baseKeys.has(path[0])) {
206
- jsonMetadata.addChange(['projects', projectName, ...path], value);
207
- }
208
- },
209
- });
198
+ const project = properties ??
199
+ (0, utilities_1.createVirtualAstObject)(projectNodeValue, {
200
+ include: ['prefix', 'root', 'sourceRoot', ...baseKeys],
201
+ listener(path, value) {
202
+ if (!baseKeys.has(path[0])) {
203
+ jsonMetadata.addChange(['projects', projectName, ...path], value);
204
+ }
205
+ },
206
+ });
210
207
  return Object.assign(project, base);
211
208
  }
212
209
  function parseTargetsObject(projectName, targetsNode, context) {
@@ -231,4 +228,4 @@ function parseTargetsObject(projectName, targetsNode, context) {
231
228
  }
232
229
  return targets;
233
230
  }
234
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"reader.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/core/src/workspace/json/reader.ts"],"names":[],"mappings":";AAAA;;;;;;GAMG;;;AAEH,+CAAiF;AACjF,4CAA2D;AAC3D,gDAOwB;AAExB,yCAAwE;AACxE,2CAAqD;AAErD,MAAM,4BAA4B,GAAG,MAAM,CAAC,MAAM,CAAC;IACjD,KAAK;IACL,gBAAgB;IAChB,gBAAgB;IAChB,YAAY;CACb,CAAC,CAAC;AACH,MAAM,0BAA0B,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,CAAC,CAAC,CAAC;AAiBxF,KAAK,UAAU,iBAAiB,CACrC,IAAY,EACZ,IAAmB,EACnB,UAAgC,EAAE;;IAElC,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;IACtC,IAAI,GAAG,KAAK,SAAS,EAAE;QACrB,MAAM,IAAI,KAAK,CAAC,gCAAgC,CAAC,CAAC;KACnD;IAED,MAAM,GAAG,GAAG,IAAA,wBAAS,EAAC,GAAG,EAAE,SAAS,EAAE,EAAE,kBAAkB,EAAE,IAAI,EAAE,gBAAgB,EAAE,KAAK,EAAE,CAAC,CAAC;IAC7F,IAAI,CAAA,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,IAAI,MAAK,QAAQ,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE;QAC3C,MAAM,IAAI,KAAK,CAAC,gDAAgD,CAAC,CAAC;KACnE;IAED,gBAAgB;IAChB,MAAM,WAAW,GAAG,IAAA,iCAAkB,EAAC,GAAG,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC;IACzD,IAAI,CAAC,WAAW,EAAE;QAChB,MAAM,IAAI,KAAK,CAAC,+CAA+C,CAAC,CAAC;KAClE;IACD,MAAM,OAAO,GAAG,WAAW,CAAC,KAAK,CAAC;IAClC,IAAI,OAAO,KAAK,CAAC,EAAE;QACjB,MAAM,IAAI,KAAK,CAAC,6DAA6D,OAAO,IAAI,CAAC,CAAC;KAC3F;IAED,MAAM,OAAO,GAAkB;QAC7B,IAAI;QACJ,QAAQ,EAAE,IAAI,gCAAqB,CAAC,IAAI,EAAE,GAAG,EAAE,GAAG,CAAC;QACnD,YAAY,EAAE,IAAI;QAClB,6BAA6B,EAAE,IAAI,GAAG,CAAC;YACrC,GAAG,4BAA4B;YAC/B,GAAG,CAAC,MAAA,OAAO,CAAC,0BAA0B,mCAAI,EAAE,CAAC;SAC9C,CAAC;QACF,2BAA2B,EAAE,IAAI,GAAG,CAAC;YACnC,GAAG,0BAA0B;YAC7B,GAAG,CAAC,MAAA,OAAO,CAAC,wBAAwB,mCAAI,EAAE,CAAC;SAC5C,CAAC;QACF,KAAK,CAAC,OAAO,EAAE,KAAK;YAClB,qCAAqC;YACrC,MAAM,IAAI,KAAK,CAAC,OAAO,CAAC,CAAC;QAC3B,CAAC;QACD,IAAI,CAAC,OAAO,EAAE,KAAK;YACjB,qCAAqC;YACrC,sCAAsC;YACtC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACxB,CAAC;KACF,CAAC;IAEF,MAAM,SAAS,GAAG,cAAc,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;IAE/C,OAAO,SAAS,CAAC;AACnB,CAAC;AAnDD,8CAmDC;AAED,SAAS,cAAc,CAAC,aAAmB,EAAE,OAAsB;IACjE,MAAM,YAAY,GAAG,OAAO,CAAC,QAAQ,CAAC;IACtC,IAAI,QAAQ,CAAC;IACb,IAAI,UAAiD,CAAC;IACtD,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE;QACzB,UAAU,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;KAClC;IAED,yIAAyI;IACzI,4DAA4D;IAC5D,MAAM,kBAAkB,GAAG,IAAA,2BAAY,EAAC,aAAa,CAAC,CAAC;IACvD,KAAK,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAY,kBAAkB,CAAC,EAAE;QACzE,IAAI,IAAI,KAAK,SAAS,IAAI,IAAI,KAAK,SAAS,EAAE;YAC5C,OAAO;SACR;aAAM,IAAI,IAAI,KAAK,UAAU,EAAE;YAC9B,MAAM,KAAK,GAAG,IAAA,iCAAkB,EAAC,aAAa,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC;YAC9D,IAAI,CAAC,IAAA,oBAAY,EAAC,KAAK,CAAC,IAAI,CAAC,KAAK,EAAE;gBAClC,OAAO,CAAC,KAAK,CAAC,qDAAqD,EAAE,KAAK,CAAC,CAAC;gBAC5E,SAAS;aACV;YAED,QAAQ,GAAG,mBAAmB,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;SAChD;aAAM;YACL,IAAI,CAAC,OAAO,CAAC,6BAA6B,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;gBACpF,OAAO,CAAC,IAAI,CAAC,0CAA0C,IAAI,UAAU,EAAE,IAAI,CAAC,CAAC;aAC9E;YACD,IAAI,UAAU,EAAE;gBACd,UAAU,CAAC,IAAI,CAAC,GAAG,KAAK,CAAC;aAC1B;SACF;KACF;IAED,IAAI,kBAA+E,CAAC;IACpF,IAAI,OAAO,CAAC,YAAY,EAAE;QACxB,kBAAkB,GAAG,CAAC,IAAI,EAAE,QAAQ,EAAE,EAAE;YACtC,YAAY,CAAC,SAAS,CAAC,CAAC,UAAU,EAAE,IAAI,CAAC,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC;QAClE,CAAC,CAAC;KACH;IAED,MAAM,iBAAiB,GAAG,IAAI,yCAA2B,CAAC,QAAQ,EAAE,kBAAkB,CAAC,CAAC;IAExF,OAAO;QACL,CAAC,8BAAmB,CAAC,EAAE,YAAY;QACnC,QAAQ,EAAE,iBAAiB;QAC3B,4EAA4E;QAC5E,0EAA0E;QAC1E,UAAU,EACR,UAAU,aAAV,UAAU,cAAV,UAAU,GACV,IAAA,kCAAsB,EAAC,kBAAkB,EAAE;YACzC,OAAO,EAAE,CAAC,SAAS,EAAE,SAAS,EAAE,UAAU,CAAC;YAC3C,QAAQ,CAAC,IAAI,EAAE,KAAK;gBAClB,YAAY,CAAC,SAAS,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;YACtC,CAAC;SACF,CAAC;KACkB,CAAC;AAC3B,CAAC;AAED,SAAS,mBAAmB,CAC1B,YAAkB,EAClB,OAAsB;IAEtB,MAAM,QAAQ,GAAsC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAExE,KAAK,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAY,IAAA,2BAAY,EAAC,YAAY,CAAC,CAAC,EAAE;QACjF,MAAM,KAAK,GAAG,IAAA,iCAAkB,EAAC,YAAY,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;QACvD,IAAI,CAAC,IAAA,oBAAY,EAAC,KAAK,CAAC,IAAI,CAAC,KAAK,EAAE;YAClC,OAAO,CAAC,IAAI,CAAC,qDAAqD,EAAE,KAAK,CAAC,CAAC;YAC3E,SAAS;SACV;QAED,QAAQ,CAAC,IAAI,CAAC,GAAG,YAAY,CAAC,IAAI,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC;KACrD;IAED,OAAO,QAAQ,CAAC;AAClB,CAAC;AAED,SAAS,YAAY,CACnB,WAAmB,EACnB,WAAiB,EACjB,OAAsB;IAEtB,MAAM,YAAY,GAAG,OAAO,CAAC,QAAQ,CAAC;IACtC,IAAI,OAAO,CAAC;IACZ,IAAI,UAAU,GAAG,KAAK,CAAC;IACvB,IAAI,UAAiD,CAAC;IACtD,IAAI,UAAwE,CAAC;IAC7E,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE;QACzB,yFAAyF;QACzF,UAAU,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACjC,UAAU,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;KAClC;IAED,MAAM,gBAAgB,GAAG,IAAA,2BAAY,EAAC,WAAW,CAAC,CAAC;IACnD,IAAI,CAAC,CAAC,MAAM,IAAI,gBAAgB,CAAC,EAAE;QACjC,MAAM,IAAI,KAAK,CAAC,YAAY,WAAW,0CAA0C,CAAC,CAAC;KACpF;IAED,KAAK,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAY,gBAAgB,CAAC,EAAE;QACvE,QAAQ,IAAI,EAAE;YACZ,KAAK,SAAS,CAAC;YACf,KAAK,WAAW;gBACd,MAAM,KAAK,GAAG,IAAA,iCAAkB,EAAC,WAAW,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;gBACtD,IAAI,CAAC,IAAA,oBAAY,EAAC,KAAK,CAAC,IAAI,CAAC,KAAK,EAAE;oBAClC,OAAO,CAAC,KAAK,CAAC,YAAY,IAAI,oCAAoC,EAAE,KAAK,CAAC,CAAC;oBAC3E,MAAM;iBACP;gBACD,UAAU,GAAG,IAAI,CAAC;gBAClB,OAAO,GAAG,kBAAkB,CAAC,WAAW,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC;gBAC1D,YAAY,CAAC,oBAAoB,GAAG,IAAI,KAAK,WAAW,CAAC;gBACzD,MAAM;YACR,KAAK,QAAQ,CAAC;YACd,KAAK,MAAM,CAAC;YACZ,KAAK,YAAY;gBACf,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;oBAC7B,OAAO,CAAC,IAAI,CAAC,qBAAqB,IAAI,uBAAuB,EAAE,KAAK,CAAC,CAAC;iBACvE;gBACD,IAAI,UAAU,EAAE;oBACd,UAAU,CAAC,IAAI,CAAC,GAAG,KAAe,CAAC;iBACpC;gBACD,MAAM;YACR;gBACE,IAAI,CAAC,OAAO,CAAC,2BAA2B,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;oBAClF,OAAO,CAAC,IAAI,CACV,YAAY,WAAW,2CAA2C,IAAI,IAAI,EAC1E,IAAI,CACL,CAAC;iBACH;gBACD,IAAI,UAAU,EAAE;oBACd,UAAU,CAAC,IAAI,CAAC,GAAG,KAAK,CAAC;iBAC1B;gBACD,MAAM;SACT;KACF;IAED,IAAI,kBAA8E,CAAC;IACnF,IAAI,OAAO,CAAC,YAAY,EAAE;QACxB,kBAAkB,GAAG,CAAC,IAAI,EAAE,QAAQ,EAAE,UAAU,EAAE,EAAE;YAClD,IAAI,UAAU,EAAE;gBACd,YAAY,CAAC,SAAS,CAAC,CAAC,UAAU,EAAE,WAAW,EAAE,SAAS,EAAE,IAAI,CAAC,EAAE,QAAQ,EAAE,QAAQ,CAAC,CAAC;aACxF;iBAAM;gBACL,YAAY,CAAC,SAAS,CACpB,CAAC,UAAU,EAAE,WAAW,EAAE,SAAS,CAAC,EACpC,UAAU,EACV,kBAAkB,CACnB,CAAC;aACH;QACH,CAAC,CAAC;KACH;IAED,MAAM,IAAI,GAAG;QACX,OAAO,EAAE,IAAI,wCAA0B,CAAC,OAAO,EAAE,kBAAkB,CAAC;QACpE,4EAA4E;QAC5E,0EAA0E;QAC1E,UAAU,EACR,UAAU,aAAV,UAAU,cAAV,UAAU,GACV,IAAA,kCAAsB,EAAC,gBAAgB,EAAE;YACvC,OAAO,EAAE,CAAC,WAAW,EAAE,QAAQ,EAAE,MAAM,EAAE,YAAY,EAAE,SAAS,CAAC;YACjE,QAAQ,CAAC,IAAI,EAAE,KAAK;gBAClB,YAAY,CAAC,SAAS,CAAC,CAAC,UAAU,EAAE,WAAW,EAAE,GAAG,IAAI,CAAC,EAAE,KAAK,CAAC,CAAC;YACpE,CAAC;SACF,CAAC;KACL,CAAC;IAEF,MAAM,QAAQ,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IAC5C,MAAM,OAAO,GACX,UAAU,aAAV,UAAU,cAAV,UAAU,GACV,IAAA,kCAAsB,EAAoB,gBAAgB,EAAE;QAC1D,OAAO,EAAE,CAAC,QAAQ,EAAE,MAAM,EAAE,YAAY,EAAE,GAAG,QAAQ,CAAC;QACtD,QAAQ,CAAC,IAAI,EAAE,KAAK;YAClB,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE;gBAC1B,YAAY,CAAC,SAAS,CAAC,CAAC,UAAU,EAAE,WAAW,EAAE,GAAG,IAAI,CAAC,EAAE,KAAK,CAAC,CAAC;aACnE;QACH,CAAC;KACF,CAAC,CAAC;IAEL,OAAO,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,CAAsB,CAAC;AAC3D,CAAC;AAED,SAAS,kBAAkB,CACzB,WAAmB,EACnB,WAAiB,EACjB,OAAsB;IAEtB,MAAM,YAAY,GAAG,OAAO,CAAC,QAAQ,CAAC;IACtC,MAAM,OAAO,GAAqC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAEtE,KAAK,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAY,IAAA,2BAAY,EAAC,WAAW,CAAC,CAAC,EAAE;QAChF,IAAI,CAAC,IAAA,oBAAY,EAAC,KAAK,CAAC,EAAE;YACxB,OAAO,CAAC,IAAI,CAAC,oDAAoD,EAAE,KAAK,CAAC,CAAC;YAC1E,SAAS;SACV;QAED,IAAI,OAAO,CAAC,YAAY,EAAE;YACxB,OAAO,CAAC,IAAI,CAAC,GAAG,IAAA,kCAAsB,EAAmB,KAAK,EAAE;gBAC9D,OAAO,EAAE,CAAC,SAAS,EAAE,SAAS,EAAE,gBAAgB,EAAE,sBAAsB,CAAC;gBACzE,QAAQ,CAAC,IAAI,EAAE,KAAK;oBAClB,YAAY,CAAC,SAAS,CAAC,CAAC,UAAU,EAAE,WAAW,EAAE,SAAS,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,EAAE,KAAK,CAAC,CAAC;gBACrF,CAAC;aACF,CAAC,CAAC;SACJ;aAAM;YACL,OAAO,CAAC,IAAI,CAAC,GAAG,KAAoC,CAAC;SACtD;KACF;IAED,OAAO,OAAO,CAAC;AACjB,CAAC","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport { Node, findNodeAtLocation, getNodeValue, parseTree } from 'jsonc-parser';\nimport { JsonValue, isJsonObject } from '../../json/utils';\nimport {\n  DefinitionCollectionListener,\n  ProjectDefinition,\n  ProjectDefinitionCollection,\n  TargetDefinition,\n  TargetDefinitionCollection,\n  WorkspaceDefinition,\n} from '../definitions';\nimport { WorkspaceHost } from '../host';\nimport { JsonWorkspaceMetadata, JsonWorkspaceSymbol } from './metadata';\nimport { createVirtualAstObject } from './utilities';\n\nconst ANGULAR_WORKSPACE_EXTENSIONS = Object.freeze([\n  'cli',\n  'defaultProject',\n  'newProjectRoot',\n  'schematics',\n]);\nconst ANGULAR_PROJECT_EXTENSIONS = Object.freeze(['cli', 'schematics', 'projectType', 'i18n']);\n\ninterface ParserContext {\n  readonly host: WorkspaceHost;\n  readonly metadata: JsonWorkspaceMetadata;\n  readonly trackChanges: boolean;\n  readonly unprefixedWorkspaceExtensions: ReadonlySet<string>;\n  readonly unprefixedProjectExtensions: ReadonlySet<string>;\n  error(message: string, node: JsonValue): void;\n  warn(message: string, node: JsonValue): void;\n}\n\nexport interface JsonWorkspaceOptions {\n  allowedProjectExtensions?: string[];\n  allowedWorkspaceExtensions?: string[];\n}\n\nexport async function readJsonWorkspace(\n  path: string,\n  host: WorkspaceHost,\n  options: JsonWorkspaceOptions = {},\n): Promise<WorkspaceDefinition> {\n  const raw = await host.readFile(path);\n  if (raw === undefined) {\n    throw new Error('Unable to read workspace file.');\n  }\n\n  const ast = parseTree(raw, undefined, { allowTrailingComma: true, disallowComments: false });\n  if (ast?.type !== 'object' || !ast.children) {\n    throw new Error('Invalid workspace file - expected JSON object.');\n  }\n\n  // Version check\n  const versionNode = findNodeAtLocation(ast, ['version']);\n  if (!versionNode) {\n    throw new Error('Unknown format - version specifier not found.');\n  }\n  const version = versionNode.value;\n  if (version !== 1) {\n    throw new Error(`Invalid format version detected - Expected:[ 1 ] Found: [ ${version} ]`);\n  }\n\n  const context: ParserContext = {\n    host,\n    metadata: new JsonWorkspaceMetadata(path, ast, raw),\n    trackChanges: true,\n    unprefixedWorkspaceExtensions: new Set([\n      ...ANGULAR_WORKSPACE_EXTENSIONS,\n      ...(options.allowedWorkspaceExtensions ?? []),\n    ]),\n    unprefixedProjectExtensions: new Set([\n      ...ANGULAR_PROJECT_EXTENSIONS,\n      ...(options.allowedProjectExtensions ?? []),\n    ]),\n    error(message, _node) {\n      // TODO: Diagnostic reporting support\n      throw new Error(message);\n    },\n    warn(message, _node) {\n      // TODO: Diagnostic reporting support\n      // eslint-disable-next-line no-console\n      console.warn(message);\n    },\n  };\n\n  const workspace = parseWorkspace(ast, context);\n\n  return workspace;\n}\n\nfunction parseWorkspace(workspaceNode: Node, context: ParserContext): WorkspaceDefinition {\n  const jsonMetadata = context.metadata;\n  let projects;\n  let extensions: Record<string, JsonValue> | undefined;\n  if (!context.trackChanges) {\n    extensions = Object.create(null);\n  }\n\n  // TODO: `getNodeValue` - looks potentially expensive since it walks the whole tree and instantiates the full object structure each time.\n  // Might be something to look at moving forward to optimize.\n  const workspaceNodeValue = getNodeValue(workspaceNode);\n  for (const [name, value] of Object.entries<JsonValue>(workspaceNodeValue)) {\n    if (name === '$schema' || name === 'version') {\n      // skip\n    } else if (name === 'projects') {\n      const nodes = findNodeAtLocation(workspaceNode, ['projects']);\n      if (!isJsonObject(value) || !nodes) {\n        context.error('Invalid \"projects\" field found; expected an object.', value);\n        continue;\n      }\n\n      projects = parseProjectsObject(nodes, context);\n    } else {\n      if (!context.unprefixedWorkspaceExtensions.has(name) && !/^[a-z]{1,3}-.*/.test(name)) {\n        context.warn(`Workspace extension with invalid name (${name}) found.`, name);\n      }\n      if (extensions) {\n        extensions[name] = value;\n      }\n    }\n  }\n\n  let collectionListener: DefinitionCollectionListener<ProjectDefinition> | undefined;\n  if (context.trackChanges) {\n    collectionListener = (name, newValue) => {\n      jsonMetadata.addChange(['projects', name], newValue, 'project');\n    };\n  }\n\n  const projectCollection = new ProjectDefinitionCollection(projects, collectionListener);\n\n  return {\n    [JsonWorkspaceSymbol]: jsonMetadata,\n    projects: projectCollection,\n    // If not tracking changes the `extensions` variable will contain the parsed\n    // values.  Otherwise the extensions are tracked via a virtual AST object.\n    extensions:\n      extensions ??\n      createVirtualAstObject(workspaceNodeValue, {\n        exclude: ['$schema', 'version', 'projects'],\n        listener(path, value) {\n          jsonMetadata.addChange(path, value);\n        },\n      }),\n  } as WorkspaceDefinition;\n}\n\nfunction parseProjectsObject(\n  projectsNode: Node,\n  context: ParserContext,\n): Record<string, ProjectDefinition> {\n  const projects: Record<string, ProjectDefinition> = Object.create(null);\n\n  for (const [name, value] of Object.entries<JsonValue>(getNodeValue(projectsNode))) {\n    const nodes = findNodeAtLocation(projectsNode, [name]);\n    if (!isJsonObject(value) || !nodes) {\n      context.warn('Skipping invalid project value; expected an object.', value);\n      continue;\n    }\n\n    projects[name] = parseProject(name, nodes, context);\n  }\n\n  return projects;\n}\n\nfunction parseProject(\n  projectName: string,\n  projectNode: Node,\n  context: ParserContext,\n): ProjectDefinition {\n  const jsonMetadata = context.metadata;\n  let targets;\n  let hasTargets = false;\n  let extensions: Record<string, JsonValue> | undefined;\n  let properties: Record<'root' | 'sourceRoot' | 'prefix', string> | undefined;\n  if (!context.trackChanges) {\n    // If not tracking changes, the parser will store the values directly in standard objects\n    extensions = Object.create(null);\n    properties = Object.create(null);\n  }\n\n  const projectNodeValue = getNodeValue(projectNode);\n  if (!('root' in projectNodeValue)) {\n    throw new Error(`Project \"${projectName}\" is missing a required property \"root\".`);\n  }\n\n  for (const [name, value] of Object.entries<JsonValue>(projectNodeValue)) {\n    switch (name) {\n      case 'targets':\n      case 'architect':\n        const nodes = findNodeAtLocation(projectNode, [name]);\n        if (!isJsonObject(value) || !nodes) {\n          context.error(`Invalid \"${name}\" field found; expected an object.`, value);\n          break;\n        }\n        hasTargets = true;\n        targets = parseTargetsObject(projectName, nodes, context);\n        jsonMetadata.hasLegacyTargetsName = name === 'architect';\n        break;\n      case 'prefix':\n      case 'root':\n      case 'sourceRoot':\n        if (typeof value !== 'string') {\n          context.warn(`Project property \"${name}\" should be a string.`, value);\n        }\n        if (properties) {\n          properties[name] = value as string;\n        }\n        break;\n      default:\n        if (!context.unprefixedProjectExtensions.has(name) && !/^[a-z]{1,3}-.*/.test(name)) {\n          context.warn(\n            `Project '${projectName}' contains extension with invalid name (${name}).`,\n            name,\n          );\n        }\n        if (extensions) {\n          extensions[name] = value;\n        }\n        break;\n    }\n  }\n\n  let collectionListener: DefinitionCollectionListener<TargetDefinition> | undefined;\n  if (context.trackChanges) {\n    collectionListener = (name, newValue, collection) => {\n      if (hasTargets) {\n        jsonMetadata.addChange(['projects', projectName, 'targets', name], newValue, 'target');\n      } else {\n        jsonMetadata.addChange(\n          ['projects', projectName, 'targets'],\n          collection,\n          'targetcollection',\n        );\n      }\n    };\n  }\n\n  const base = {\n    targets: new TargetDefinitionCollection(targets, collectionListener),\n    // If not tracking changes the `extensions` variable will contain the parsed\n    // values.  Otherwise the extensions are tracked via a virtual AST object.\n    extensions:\n      extensions ??\n      createVirtualAstObject(projectNodeValue, {\n        exclude: ['architect', 'prefix', 'root', 'sourceRoot', 'targets'],\n        listener(path, value) {\n          jsonMetadata.addChange(['projects', projectName, ...path], value);\n        },\n      }),\n  };\n\n  const baseKeys = new Set(Object.keys(base));\n  const project =\n    properties ??\n    createVirtualAstObject<ProjectDefinition>(projectNodeValue, {\n      include: ['prefix', 'root', 'sourceRoot', ...baseKeys],\n      listener(path, value) {\n        if (!baseKeys.has(path[0])) {\n          jsonMetadata.addChange(['projects', projectName, ...path], value);\n        }\n      },\n    });\n\n  return Object.assign(project, base) as ProjectDefinition;\n}\n\nfunction parseTargetsObject(\n  projectName: string,\n  targetsNode: Node,\n  context: ParserContext,\n): Record<string, TargetDefinition> {\n  const jsonMetadata = context.metadata;\n  const targets: Record<string, TargetDefinition> = Object.create(null);\n\n  for (const [name, value] of Object.entries<JsonValue>(getNodeValue(targetsNode))) {\n    if (!isJsonObject(value)) {\n      context.warn('Skipping invalid target value; expected an object.', value);\n      continue;\n    }\n\n    if (context.trackChanges) {\n      targets[name] = createVirtualAstObject<TargetDefinition>(value, {\n        include: ['builder', 'options', 'configurations', 'defaultConfiguration'],\n        listener(path, value) {\n          jsonMetadata.addChange(['projects', projectName, 'targets', name, ...path], value);\n        },\n      });\n    } else {\n      targets[name] = value as unknown as TargetDefinition;\n    }\n  }\n\n  return targets;\n}\n"]}
231
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"reader.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/core/src/workspace/json/reader.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport { Node, findNodeAtLocation, getNodeValue, parseTree } from 'jsonc-parser';\nimport { JsonValue, isJsonObject } from '../../json/utils';\nimport {\n  DefinitionCollectionListener,\n  ProjectDefinition,\n  ProjectDefinitionCollection,\n  TargetDefinition,\n  TargetDefinitionCollection,\n  WorkspaceDefinition,\n} from '../definitions';\nimport { WorkspaceHost } from '../host';\nimport { JsonWorkspaceMetadata, JsonWorkspaceSymbol } from './metadata';\nimport { createVirtualAstObject } from './utilities';\n\nconst ANGULAR_WORKSPACE_EXTENSIONS = Object.freeze(['cli', 'newProjectRoot', 'schematics']);\nconst ANGULAR_PROJECT_EXTENSIONS = Object.freeze(['cli', 'schematics', 'projectType', 'i18n']);\n\ninterface ParserContext {\n  readonly host: WorkspaceHost;\n  readonly metadata: JsonWorkspaceMetadata;\n  readonly trackChanges: boolean;\n  readonly unprefixedWorkspaceExtensions: ReadonlySet<string>;\n  readonly unprefixedProjectExtensions: ReadonlySet<string>;\n  error(message: string, node: JsonValue): void;\n  warn(message: string, node: JsonValue): void;\n}\n\nexport interface JsonWorkspaceOptions {\n  allowedProjectExtensions?: string[];\n  allowedWorkspaceExtensions?: string[];\n}\n\nexport async function readJsonWorkspace(\n  path: string,\n  host: WorkspaceHost,\n  options: JsonWorkspaceOptions = {},\n): Promise<WorkspaceDefinition> {\n  const raw = await host.readFile(path);\n  if (raw === undefined) {\n    throw new Error('Unable to read workspace file.');\n  }\n\n  const ast = parseTree(raw, undefined, { allowTrailingComma: true, disallowComments: false });\n  if (ast?.type !== 'object' || !ast.children) {\n    throw new Error('Invalid workspace file - expected JSON object.');\n  }\n\n  // Version check\n  const versionNode = findNodeAtLocation(ast, ['version']);\n  if (!versionNode) {\n    throw new Error('Unknown format - version specifier not found.');\n  }\n  const version = versionNode.value;\n  if (version !== 1) {\n    throw new Error(`Invalid format version detected - Expected:[ 1 ] Found: [ ${version} ]`);\n  }\n\n  const context: ParserContext = {\n    host,\n    metadata: new JsonWorkspaceMetadata(path, ast, raw),\n    trackChanges: true,\n    unprefixedWorkspaceExtensions: new Set([\n      ...ANGULAR_WORKSPACE_EXTENSIONS,\n      ...(options.allowedWorkspaceExtensions ?? []),\n    ]),\n    unprefixedProjectExtensions: new Set([\n      ...ANGULAR_PROJECT_EXTENSIONS,\n      ...(options.allowedProjectExtensions ?? []),\n    ]),\n    error(message, _node) {\n      // TODO: Diagnostic reporting support\n      throw new Error(message);\n    },\n    warn(message, _node) {\n      // TODO: Diagnostic reporting support\n      // eslint-disable-next-line no-console\n      console.warn(message);\n    },\n  };\n\n  const workspace = parseWorkspace(ast, context);\n\n  return workspace;\n}\n\nfunction parseWorkspace(workspaceNode: Node, context: ParserContext): WorkspaceDefinition {\n  const jsonMetadata = context.metadata;\n  let projects;\n  let extensions: Record<string, JsonValue> | undefined;\n  if (!context.trackChanges) {\n    extensions = Object.create(null);\n  }\n\n  // TODO: `getNodeValue` - looks potentially expensive since it walks the whole tree and instantiates the full object structure each time.\n  // Might be something to look at moving forward to optimize.\n  const workspaceNodeValue = getNodeValue(workspaceNode);\n  for (const [name, value] of Object.entries<JsonValue>(workspaceNodeValue)) {\n    if (name === '$schema' || name === 'version') {\n      // skip\n    } else if (name === 'projects') {\n      const nodes = findNodeAtLocation(workspaceNode, ['projects']);\n      if (!isJsonObject(value) || !nodes) {\n        context.error('Invalid \"projects\" field found; expected an object.', value);\n        continue;\n      }\n\n      projects = parseProjectsObject(nodes, context);\n    } else {\n      if (!context.unprefixedWorkspaceExtensions.has(name) && !/^[a-z]{1,3}-.*/.test(name)) {\n        context.warn(`Workspace extension with invalid name (${name}) found.`, name);\n      }\n      if (extensions) {\n        extensions[name] = value;\n      }\n    }\n  }\n\n  let collectionListener: DefinitionCollectionListener<ProjectDefinition> | undefined;\n  if (context.trackChanges) {\n    collectionListener = (name, newValue) => {\n      jsonMetadata.addChange(['projects', name], newValue, 'project');\n    };\n  }\n\n  const projectCollection = new ProjectDefinitionCollection(projects, collectionListener);\n\n  return {\n    [JsonWorkspaceSymbol]: jsonMetadata,\n    projects: projectCollection,\n    // If not tracking changes the `extensions` variable will contain the parsed\n    // values.  Otherwise the extensions are tracked via a virtual AST object.\n    extensions:\n      extensions ??\n      createVirtualAstObject(workspaceNodeValue, {\n        exclude: ['$schema', 'version', 'projects'],\n        listener(path, value) {\n          jsonMetadata.addChange(path, value);\n        },\n      }),\n  } as WorkspaceDefinition;\n}\n\nfunction parseProjectsObject(\n  projectsNode: Node,\n  context: ParserContext,\n): Record<string, ProjectDefinition> {\n  const projects: Record<string, ProjectDefinition> = Object.create(null);\n\n  for (const [name, value] of Object.entries<JsonValue>(getNodeValue(projectsNode))) {\n    const nodes = findNodeAtLocation(projectsNode, [name]);\n    if (!isJsonObject(value) || !nodes) {\n      context.warn('Skipping invalid project value; expected an object.', value);\n      continue;\n    }\n\n    projects[name] = parseProject(name, nodes, context);\n  }\n\n  return projects;\n}\n\nfunction parseProject(\n  projectName: string,\n  projectNode: Node,\n  context: ParserContext,\n): ProjectDefinition {\n  const jsonMetadata = context.metadata;\n  let targets;\n  let hasTargets = false;\n  let extensions: Record<string, JsonValue> | undefined;\n  let properties: Record<'root' | 'sourceRoot' | 'prefix', string> | undefined;\n  if (!context.trackChanges) {\n    // If not tracking changes, the parser will store the values directly in standard objects\n    extensions = Object.create(null);\n    properties = Object.create(null);\n  }\n\n  const projectNodeValue = getNodeValue(projectNode);\n  if (!('root' in projectNodeValue)) {\n    throw new Error(`Project \"${projectName}\" is missing a required property \"root\".`);\n  }\n\n  for (const [name, value] of Object.entries<JsonValue>(projectNodeValue)) {\n    switch (name) {\n      case 'targets':\n      case 'architect':\n        const nodes = findNodeAtLocation(projectNode, [name]);\n        if (!isJsonObject(value) || !nodes) {\n          context.error(`Invalid \"${name}\" field found; expected an object.`, value);\n          break;\n        }\n        hasTargets = true;\n        targets = parseTargetsObject(projectName, nodes, context);\n        jsonMetadata.hasLegacyTargetsName = name === 'architect';\n        break;\n      case 'prefix':\n      case 'root':\n      case 'sourceRoot':\n        if (typeof value !== 'string') {\n          context.warn(`Project property \"${name}\" should be a string.`, value);\n        }\n        if (properties) {\n          properties[name] = value as string;\n        }\n        break;\n      default:\n        if (!context.unprefixedProjectExtensions.has(name) && !/^[a-z]{1,3}-.*/.test(name)) {\n          context.warn(\n            `Project '${projectName}' contains extension with invalid name (${name}).`,\n            name,\n          );\n        }\n        if (extensions) {\n          extensions[name] = value;\n        }\n        break;\n    }\n  }\n\n  let collectionListener: DefinitionCollectionListener<TargetDefinition> | undefined;\n  if (context.trackChanges) {\n    collectionListener = (name, newValue, collection) => {\n      if (hasTargets) {\n        jsonMetadata.addChange(['projects', projectName, 'targets', name], newValue, 'target');\n      } else {\n        jsonMetadata.addChange(\n          ['projects', projectName, 'targets'],\n          collection,\n          'targetcollection',\n        );\n      }\n    };\n  }\n\n  const base = {\n    targets: new TargetDefinitionCollection(targets, collectionListener),\n    // If not tracking changes the `extensions` variable will contain the parsed\n    // values.  Otherwise the extensions are tracked via a virtual AST object.\n    extensions:\n      extensions ??\n      createVirtualAstObject(projectNodeValue, {\n        exclude: ['architect', 'prefix', 'root', 'sourceRoot', 'targets'],\n        listener(path, value) {\n          jsonMetadata.addChange(['projects', projectName, ...path], value);\n        },\n      }),\n  };\n\n  const baseKeys = new Set(Object.keys(base));\n  const project =\n    properties ??\n    createVirtualAstObject<ProjectDefinition>(projectNodeValue, {\n      include: ['prefix', 'root', 'sourceRoot', ...baseKeys],\n      listener(path, value) {\n        if (!baseKeys.has(path[0])) {\n          jsonMetadata.addChange(['projects', projectName, ...path], value);\n        }\n      },\n    });\n\n  return Object.assign(project, base) as ProjectDefinition;\n}\n\nfunction parseTargetsObject(\n  projectName: string,\n  targetsNode: Node,\n  context: ParserContext,\n): Record<string, TargetDefinition> {\n  const jsonMetadata = context.metadata;\n  const targets: Record<string, TargetDefinition> = Object.create(null);\n\n  for (const [name, value] of Object.entries<JsonValue>(getNodeValue(targetsNode))) {\n    if (!isJsonObject(value)) {\n      context.warn('Skipping invalid target value; expected an object.', value);\n      continue;\n    }\n\n    if (context.trackChanges) {\n      targets[name] = createVirtualAstObject<TargetDefinition>(value, {\n        include: ['builder', 'options', 'configurations', 'defaultConfiguration'],\n        listener(path, value) {\n          jsonMetadata.addChange(['projects', projectName, 'targets', name, ...path], value);\n        },\n      });\n    } else {\n      targets[name] = value as unknown as TargetDefinition;\n    }\n  }\n\n  return targets;\n}\n"]}
@@ -10,7 +10,6 @@ Object.defineProperty(exports, "__esModule", { value: true });
10
10
  exports.createVirtualAstObject = void 0;
11
11
  const json_1 = require("../../json");
12
12
  function createVirtualAstObject(root, options = {}) {
13
- var _a;
14
13
  const reporter = (path, target, oldValue, newValue) => {
15
14
  if (!options.listener) {
16
15
  return;
@@ -28,7 +27,7 @@ function createVirtualAstObject(root, options = {}) {
28
27
  options.listener(path, newValue);
29
28
  }
30
29
  };
31
- return create(Array.isArray(root) ? [...root] : { ...root }, [], reporter, new Set(options.exclude), ((_a = options.include) === null || _a === void 0 ? void 0 : _a.length) ? new Set(options.include) : undefined);
30
+ return create(Array.isArray(root) ? [...root] : { ...root }, [], reporter, new Set(options.exclude), options.include?.length ? new Set(options.include) : undefined);
32
31
  }
33
32
  exports.createVirtualAstObject = createVirtualAstObject;
34
33
  function create(obj, path, reporter, excluded = new Set(), included) {
@@ -61,13 +60,12 @@ function create(obj, path, reporter, excluded = new Set(), included) {
61
60
  }
62
61
  },
63
62
  set(target, p, value) {
64
- var _a, _b;
65
63
  if (excluded.has(p) || (included && !included.has(p))) {
66
64
  return false;
67
65
  }
68
66
  if (value === undefined) {
69
67
  // setting to undefined is equivalent to a delete.
70
- return (_b = (_a = this.deleteProperty) === null || _a === void 0 ? void 0 : _a.call(this, target, p)) !== null && _b !== void 0 ? _b : false;
68
+ return this.deleteProperty?.(target, p) ?? false;
71
69
  }
72
70
  if (typeof p === 'symbol') {
73
71
  return Reflect.set(target, p, value);
@@ -113,4 +111,4 @@ function getCurrentValue(target, property) {
113
111
  }
114
112
  return undefined;
115
113
  }
116
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utilities.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/core/src/workspace/json/utilities.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport { JsonArray, JsonObject, JsonValue, isJsonObject } from '../../json';\n\nexport type ChangeListener = (path: string[], newValue: JsonValue | undefined) => void;\n\ntype ChangeReporter = (\n  path: string[],\n  target: JsonObject | JsonArray,\n  oldValue: JsonValue | undefined,\n  newValue: JsonValue | undefined,\n) => void;\n\n// lib.es5 PropertyKey is string | number | symbol which doesn't overlap ProxyHandler PropertyKey which is string | symbol.\n// See https://github.com/microsoft/TypeScript/issues/42894\ntype ProxyPropertyKey = string | symbol;\n\nexport function createVirtualAstObject<T extends object = JsonObject>(\n  root: JsonObject | JsonArray,\n  options: {\n    exclude?: string[];\n    include?: string[];\n    listener?: ChangeListener;\n  } = {},\n): T {\n  const reporter: ChangeReporter = (path, target, oldValue, newValue) => {\n    if (!options.listener) {\n      return;\n    }\n\n    if (oldValue === newValue || JSON.stringify(oldValue) === JSON.stringify(newValue)) {\n      // same value\n      return;\n    }\n\n    if (Array.isArray(target)) {\n      // For arrays we remove the index and update the entire value as keeping\n      // track of changes by indices can be rather complex.\n      options.listener(path.slice(0, -1), target);\n    } else {\n      options.listener(path, newValue);\n    }\n  };\n\n  return create(\n    Array.isArray(root) ? [...root] : { ...root },\n    [],\n    reporter,\n    new Set(options.exclude),\n    options.include?.length ? new Set(options.include) : undefined,\n  ) as T;\n}\n\nfunction create(\n  obj: JsonObject | JsonArray,\n  path: string[],\n  reporter: ChangeReporter,\n  excluded = new Set<ProxyPropertyKey>(),\n  included?: Set<ProxyPropertyKey>,\n) {\n  return new Proxy(obj, {\n    getOwnPropertyDescriptor(target: {}, p: ProxyPropertyKey): PropertyDescriptor | undefined {\n      if (excluded.has(p) || (included && !included.has(p))) {\n        return undefined;\n      }\n\n      return Reflect.getOwnPropertyDescriptor(target, p);\n    },\n    has(target: {}, p: ProxyPropertyKey): boolean {\n      if (typeof p === 'symbol' || excluded.has(p)) {\n        return false;\n      }\n\n      return Reflect.has(target, p);\n    },\n    get(target: {}, p: ProxyPropertyKey): unknown {\n      if (excluded.has(p) || (included && !included.has(p))) {\n        return undefined;\n      }\n\n      const value = Reflect.get(target, p);\n      if (typeof p === 'symbol') {\n        return value;\n      }\n\n      if ((isJsonObject(value) && !(value instanceof Map)) || Array.isArray(value)) {\n        return create(value, [...path, p], reporter);\n      } else {\n        return value;\n      }\n    },\n    set(target: {}, p: ProxyPropertyKey, value: unknown): boolean {\n      if (excluded.has(p) || (included && !included.has(p))) {\n        return false;\n      }\n\n      if (value === undefined) {\n        // setting to undefined is equivalent to a delete.\n        return this.deleteProperty?.(target, p) ?? false;\n      }\n\n      if (typeof p === 'symbol') {\n        return Reflect.set(target, p, value);\n      }\n\n      const existingValue = getCurrentValue(target, p);\n      if (Reflect.set(target, p, value)) {\n        reporter([...path, p], target, existingValue, value as JsonValue);\n\n        return true;\n      }\n\n      return false;\n    },\n    deleteProperty(target: {}, p: ProxyPropertyKey): boolean {\n      if (excluded.has(p)) {\n        return false;\n      }\n\n      if (typeof p === 'symbol') {\n        return Reflect.deleteProperty(target, p);\n      }\n\n      const existingValue = getCurrentValue(target, p);\n      if (Reflect.deleteProperty(target, p)) {\n        reporter([...path, p], target, existingValue, undefined);\n\n        return true;\n      }\n\n      return true;\n    },\n    defineProperty(target: {}, p: ProxyPropertyKey, attributes: PropertyDescriptor): boolean {\n      if (typeof p === 'symbol') {\n        return Reflect.defineProperty(target, p, attributes);\n      }\n\n      return false;\n    },\n    ownKeys(target: {}): ProxyPropertyKey[] {\n      return Reflect.ownKeys(target).filter(\n        (p) => !excluded.has(p) && (!included || included.has(p)),\n      );\n    },\n  });\n}\n\nfunction getCurrentValue(target: object, property: string): JsonValue | undefined {\n  if (Array.isArray(target) && isFinite(+property)) {\n    return target[+property];\n  }\n\n  if (target && property in target) {\n    return (target as JsonObject)[property];\n  }\n\n  return undefined;\n}\n"]}
114
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utilities.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/core/src/workspace/json/utilities.ts"],"names":[],"mappings":";AAAA;;;;;;GAMG;;;AAEH,qCAA4E;AAe5E,SAAgB,sBAAsB,CACpC,IAA4B,EAC5B,UAII,EAAE;IAEN,MAAM,QAAQ,GAAmB,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,EAAE;QACpE,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE;YACrB,OAAO;SACR;QAED,IAAI,QAAQ,KAAK,QAAQ,IAAI,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE;YAClF,aAAa;YACb,OAAO;SACR;QAED,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;YACzB,wEAAwE;YACxE,qDAAqD;YACrD,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC;SAC7C;aAAM;YACL,OAAO,CAAC,QAAQ,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;SAClC;IACH,CAAC,CAAC;IAEF,OAAO,MAAM,CACX,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,IAAI,EAAE,EAC7C,EAAE,EACF,QAAQ,EACR,IAAI,GAAG,CAAC,OAAO,CAAC,OAAO,CAAC,EACxB,OAAO,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,SAAS,CAC1D,CAAC;AACT,CAAC;AAlCD,wDAkCC;AAED,SAAS,MAAM,CACb,GAA2B,EAC3B,IAAc,EACd,QAAwB,EACxB,WAAW,IAAI,GAAG,EAAoB,EACtC,QAAgC;IAEhC,OAAO,IAAI,KAAK,CAAC,GAAG,EAAE;QACpB,wBAAwB,CAAC,MAAU,EAAE,CAAmB;YACtD,IAAI,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE;gBACrD,OAAO,SAAS,CAAC;aAClB;YAED,OAAO,OAAO,CAAC,wBAAwB,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;QACrD,CAAC;QACD,GAAG,CAAC,MAAU,EAAE,CAAmB;YACjC,IAAI,OAAO,CAAC,KAAK,QAAQ,IAAI,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;gBAC5C,OAAO,KAAK,CAAC;aACd;YAED,OAAO,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;QAChC,CAAC;QACD,GAAG,CAAC,MAAU,EAAE,CAAmB;YACjC,IAAI,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE;gBACrD,OAAO,SAAS,CAAC;aAClB;YAED,MAAM,KAAK,GAAG,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;YACrC,IAAI,OAAO,CAAC,KAAK,QAAQ,EAAE;gBACzB,OAAO,KAAK,CAAC;aACd;YAED,IAAI,CAAC,IAAA,mBAAY,EAAC,KAAK,CAAC,IAAI,CAAC,CAAC,KAAK,YAAY,GAAG,CAAC,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;gBAC5E,OAAO,MAAM,CAAC,KAAK,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC;aAC9C;iBAAM;gBACL,OAAO,KAAK,CAAC;aACd;QACH,CAAC;QACD,GAAG,CAAC,MAAU,EAAE,CAAmB,EAAE,KAAc;YACjD,IAAI,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE;gBACrD,OAAO,KAAK,CAAC;aACd;YAED,IAAI,KAAK,KAAK,SAAS,EAAE;gBACvB,kDAAkD;gBAClD,OAAO,IAAI,CAAC,cAAc,EAAE,CAAC,MAAM,EAAE,CAAC,CAAC,IAAI,KAAK,CAAC;aAClD;YAED,IAAI,OAAO,CAAC,KAAK,QAAQ,EAAE;gBACzB,OAAO,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,EAAE,KAAK,CAAC,CAAC;aACtC;YAED,MAAM,aAAa,GAAG,eAAe,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;YACjD,IAAI,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,EAAE,KAAK,CAAC,EAAE;gBACjC,QAAQ,CAAC,CAAC,GAAG,IAAI,EAAE,CAAC,CAAC,EAAE,MAAM,EAAE,aAAa,EAAE,KAAkB,CAAC,CAAC;gBAElE,OAAO,IAAI,CAAC;aACb;YAED,OAAO,KAAK,CAAC;QACf,CAAC;QACD,cAAc,CAAC,MAAU,EAAE,CAAmB;YAC5C,IAAI,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;gBACnB,OAAO,KAAK,CAAC;aACd;YAED,IAAI,OAAO,CAAC,KAAK,QAAQ,EAAE;gBACzB,OAAO,OAAO,CAAC,cAAc,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;aAC1C;YAED,MAAM,aAAa,GAAG,eAAe,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;YACjD,IAAI,OAAO,CAAC,cAAc,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE;gBACrC,QAAQ,CAAC,CAAC,GAAG,IAAI,EAAE,CAAC,CAAC,EAAE,MAAM,EAAE,aAAa,EAAE,SAAS,CAAC,CAAC;gBAEzD,OAAO,IAAI,CAAC;aACb;YAED,OAAO,IAAI,CAAC;QACd,CAAC;QACD,cAAc,CAAC,MAAU,EAAE,CAAmB,EAAE,UAA8B;YAC5E,IAAI,OAAO,CAAC,KAAK,QAAQ,EAAE;gBACzB,OAAO,OAAO,CAAC,cAAc,CAAC,MAAM,EAAE,CAAC,EAAE,UAAU,CAAC,CAAC;aACtD;YAED,OAAO,KAAK,CAAC;QACf,CAAC;QACD,OAAO,CAAC,MAAU;YAChB,OAAO,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CACnC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,QAAQ,IAAI,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAC1D,CAAC;QACJ,CAAC;KACF,CAAC,CAAC;AACL,CAAC;AAED,SAAS,eAAe,CAAC,MAAc,EAAE,QAAgB;IACvD,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,QAAQ,CAAC,CAAC,QAAQ,CAAC,EAAE;QAChD,OAAO,MAAM,CAAC,CAAC,QAAQ,CAAC,CAAC;KAC1B;IAED,IAAI,MAAM,IAAI,QAAQ,IAAI,MAAM,EAAE;QAChC,OAAQ,MAAqB,CAAC,QAAQ,CAAC,CAAC;KACzC;IAED,OAAO,SAAS,CAAC;AACnB,CAAC","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport { JsonArray, JsonObject, JsonValue, isJsonObject } from '../../json';\n\nexport type ChangeListener = (path: string[], newValue: JsonValue | undefined) => void;\n\ntype ChangeReporter = (\n  path: string[],\n  target: JsonObject | JsonArray,\n  oldValue: JsonValue | undefined,\n  newValue: JsonValue | undefined,\n) => void;\n\n// lib.es5 PropertyKey is string | number | symbol which doesn't overlap ProxyHandler PropertyKey which is string | symbol.\n// See https://github.com/microsoft/TypeScript/issues/42894\ntype ProxyPropertyKey = string | symbol;\n\nexport function createVirtualAstObject<T extends object = JsonObject>(\n  root: JsonObject | JsonArray,\n  options: {\n    exclude?: string[];\n    include?: string[];\n    listener?: ChangeListener;\n  } = {},\n): T {\n  const reporter: ChangeReporter = (path, target, oldValue, newValue) => {\n    if (!options.listener) {\n      return;\n    }\n\n    if (oldValue === newValue || JSON.stringify(oldValue) === JSON.stringify(newValue)) {\n      // same value\n      return;\n    }\n\n    if (Array.isArray(target)) {\n      // For arrays we remove the index and update the entire value as keeping\n      // track of changes by indices can be rather complex.\n      options.listener(path.slice(0, -1), target);\n    } else {\n      options.listener(path, newValue);\n    }\n  };\n\n  return create(\n    Array.isArray(root) ? [...root] : { ...root },\n    [],\n    reporter,\n    new Set(options.exclude),\n    options.include?.length ? new Set(options.include) : undefined,\n  ) as T;\n}\n\nfunction create(\n  obj: JsonObject | JsonArray,\n  path: string[],\n  reporter: ChangeReporter,\n  excluded = new Set<ProxyPropertyKey>(),\n  included?: Set<ProxyPropertyKey>,\n) {\n  return new Proxy(obj, {\n    getOwnPropertyDescriptor(target: {}, p: ProxyPropertyKey): PropertyDescriptor | undefined {\n      if (excluded.has(p) || (included && !included.has(p))) {\n        return undefined;\n      }\n\n      return Reflect.getOwnPropertyDescriptor(target, p);\n    },\n    has(target: {}, p: ProxyPropertyKey): boolean {\n      if (typeof p === 'symbol' || excluded.has(p)) {\n        return false;\n      }\n\n      return Reflect.has(target, p);\n    },\n    get(target: {}, p: ProxyPropertyKey): unknown {\n      if (excluded.has(p) || (included && !included.has(p))) {\n        return undefined;\n      }\n\n      const value = Reflect.get(target, p);\n      if (typeof p === 'symbol') {\n        return value;\n      }\n\n      if ((isJsonObject(value) && !(value instanceof Map)) || Array.isArray(value)) {\n        return create(value, [...path, p], reporter);\n      } else {\n        return value;\n      }\n    },\n    set(target: {}, p: ProxyPropertyKey, value: unknown): boolean {\n      if (excluded.has(p) || (included && !included.has(p))) {\n        return false;\n      }\n\n      if (value === undefined) {\n        // setting to undefined is equivalent to a delete.\n        return this.deleteProperty?.(target, p) ?? false;\n      }\n\n      if (typeof p === 'symbol') {\n        return Reflect.set(target, p, value);\n      }\n\n      const existingValue = getCurrentValue(target, p);\n      if (Reflect.set(target, p, value)) {\n        reporter([...path, p], target, existingValue, value as JsonValue);\n\n        return true;\n      }\n\n      return false;\n    },\n    deleteProperty(target: {}, p: ProxyPropertyKey): boolean {\n      if (excluded.has(p)) {\n        return false;\n      }\n\n      if (typeof p === 'symbol') {\n        return Reflect.deleteProperty(target, p);\n      }\n\n      const existingValue = getCurrentValue(target, p);\n      if (Reflect.deleteProperty(target, p)) {\n        reporter([...path, p], target, existingValue, undefined);\n\n        return true;\n      }\n\n      return true;\n    },\n    defineProperty(target: {}, p: ProxyPropertyKey, attributes: PropertyDescriptor): boolean {\n      if (typeof p === 'symbol') {\n        return Reflect.defineProperty(target, p, attributes);\n      }\n\n      return false;\n    },\n    ownKeys(target: {}): ProxyPropertyKey[] {\n      return Reflect.ownKeys(target).filter(\n        (p) => !excluded.has(p) && (!included || included.has(p)),\n      );\n    },\n  });\n}\n\nfunction getCurrentValue(target: object, property: string): JsonValue | undefined {\n  if (Array.isArray(target) && isFinite(+property)) {\n    return target[+property];\n  }\n\n  if (target && property in target) {\n    return (target as JsonObject)[property];\n  }\n\n  return undefined;\n}\n"]}
@@ -18,7 +18,7 @@ async function writeJsonWorkspace(workspace, host, path, options = {}) {
18
18
  }
19
19
  // update existing JSON workspace
20
20
  const data = updateJsonWorkspace(metadata);
21
- return host.writeFile(path !== null && path !== void 0 ? path : metadata.filePath, data);
21
+ return host.writeFile(path ?? metadata.filePath, data);
22
22
  }
23
23
  else {
24
24
  // serialize directly
@@ -128,4 +128,4 @@ function updateJsonWorkspace(metadata) {
128
128
  }
129
129
  return content;
130
130
  }
131
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"writer.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/core/src/workspace/json/writer.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport { applyEdits, modify } from 'jsonc-parser';\nimport { JsonObject, JsonValue } from '../../json';\nimport { ProjectDefinition, TargetDefinition, WorkspaceDefinition } from '../definitions';\nimport { WorkspaceHost } from '../host';\nimport {\n  JsonChange,\n  JsonWorkspaceDefinition,\n  JsonWorkspaceMetadata,\n  JsonWorkspaceSymbol,\n} from './metadata';\n\nexport async function writeJsonWorkspace(\n  workspace: WorkspaceDefinition,\n  host: WorkspaceHost,\n  path?: string,\n  options: {\n    schema?: string;\n  } = {},\n): Promise<void> {\n  const metadata = (workspace as JsonWorkspaceDefinition)[JsonWorkspaceSymbol];\n\n  if (metadata) {\n    if (!metadata.hasChanges) {\n      return;\n    }\n    // update existing JSON workspace\n    const data = updateJsonWorkspace(metadata);\n\n    return host.writeFile(path ?? metadata.filePath, data);\n  } else {\n    // serialize directly\n    if (!path) {\n      throw new Error('path option is required');\n    }\n\n    const obj = convertJsonWorkspace(workspace, options.schema);\n    const data = JSON.stringify(obj, null, 2);\n\n    return host.writeFile(path, data);\n  }\n}\n\nfunction convertJsonWorkspace(workspace: WorkspaceDefinition, schema?: string): JsonObject {\n  const obj = {\n    $schema: schema || './node_modules/@angular/cli/lib/config/schema.json',\n    version: 1,\n    ...workspace.extensions,\n    ...(isEmpty(workspace.projects)\n      ? {}\n      : { projects: convertJsonProjectCollection(workspace.projects) }),\n  };\n\n  return obj;\n}\n\nfunction convertJsonProjectCollection(\n  collection: Iterable<[string, ProjectDefinition]>,\n): JsonObject {\n  const projects = Object.create(null) as JsonObject;\n\n  for (const [projectName, project] of collection) {\n    projects[projectName] = convertJsonProject(project);\n  }\n\n  return projects;\n}\n\nfunction convertJsonProject(project: ProjectDefinition): JsonObject {\n  let targets: JsonObject | undefined;\n  if (project.targets.size > 0) {\n    targets = Object.create(null) as JsonObject;\n    for (const [targetName, target] of project.targets) {\n      targets[targetName] = convertJsonTarget(target);\n    }\n  }\n\n  const obj = {\n    ...project.extensions,\n    root: project.root,\n    ...(project.sourceRoot === undefined ? {} : { sourceRoot: project.sourceRoot }),\n    ...(project.prefix === undefined ? {} : { prefix: project.prefix }),\n    ...(targets === undefined ? {} : { architect: targets }),\n  };\n\n  return obj;\n}\n\nfunction isEmpty(obj: object | undefined): boolean {\n  return obj === undefined || Object.keys(obj).length === 0;\n}\n\nfunction convertJsonTarget(target: TargetDefinition): JsonObject {\n  return {\n    builder: target.builder,\n    ...(isEmpty(target.options) ? {} : { options: target.options as JsonObject }),\n    ...(isEmpty(target.configurations)\n      ? {}\n      : { configurations: target.configurations as JsonObject }),\n    ...(target.defaultConfiguration === undefined\n      ? {}\n      : { defaultConfiguration: target.defaultConfiguration }),\n  };\n}\n\nfunction convertJsonTargetCollection(collection: Iterable<[string, TargetDefinition]>): JsonObject {\n  const targets = Object.create(null) as JsonObject;\n\n  for (const [projectName, target] of collection) {\n    targets[projectName] = convertJsonTarget(target);\n  }\n\n  return targets;\n}\n\nfunction normalizeValue(\n  value: JsonChange['value'] | undefined,\n  type: JsonChange['type'],\n): JsonValue | undefined {\n  if (value === undefined) {\n    return undefined;\n  }\n\n  switch (type) {\n    case 'project':\n      return convertJsonProject(value as ProjectDefinition);\n    case 'projectcollection':\n      const projects = convertJsonProjectCollection(value as Iterable<[string, ProjectDefinition]>);\n\n      return isEmpty(projects) ? undefined : projects;\n    case 'target':\n      return convertJsonTarget(value as TargetDefinition);\n    case 'targetcollection':\n      const targets = convertJsonTargetCollection(value as Iterable<[string, TargetDefinition]>);\n\n      return isEmpty(targets) ? undefined : targets;\n    default:\n      return value as JsonValue;\n  }\n}\n\nfunction updateJsonWorkspace(metadata: JsonWorkspaceMetadata): string {\n  let { raw: content } = metadata;\n  const { changes, hasLegacyTargetsName } = metadata;\n\n  for (const { jsonPath, value, type } of changes.values()) {\n    // Determine which key to use if (architect or targets)\n    if (hasLegacyTargetsName && jsonPath[2] === 'targets') {\n      jsonPath[2] = 'architect';\n    }\n\n    // TODO: `modify` re-parses the content every time.\n    // See: https://github.com/microsoft/node-jsonc-parser/blob/35d94cd71bd48f9784453b2439262c938e21d49b/src/impl/edit.ts#L18\n    // Ideally this should accept a string or an AST to avoid the potentially expensive repeat parsing operation.\n    const edits = modify(content, jsonPath, normalizeValue(value, type), {\n      formattingOptions: {\n        insertSpaces: true,\n        tabSize: 2,\n      },\n    });\n\n    content = applyEdits(content, edits);\n  }\n\n  return content;\n}\n"]}
131
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"writer.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/core/src/workspace/json/writer.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport { applyEdits, modify } from 'jsonc-parser';\nimport { JsonObject, JsonValue } from '../../json';\nimport { ProjectDefinition, TargetDefinition, WorkspaceDefinition } from '../definitions';\nimport { WorkspaceHost } from '../host';\nimport {\n  JsonChange,\n  JsonWorkspaceDefinition,\n  JsonWorkspaceMetadata,\n  JsonWorkspaceSymbol,\n} from './metadata';\n\nexport async function writeJsonWorkspace(\n  workspace: WorkspaceDefinition,\n  host: WorkspaceHost,\n  path?: string,\n  options: {\n    schema?: string;\n  } = {},\n): Promise<void> {\n  const metadata = (workspace as JsonWorkspaceDefinition)[JsonWorkspaceSymbol];\n\n  if (metadata) {\n    if (!metadata.hasChanges) {\n      return;\n    }\n    // update existing JSON workspace\n    const data = updateJsonWorkspace(metadata);\n\n    return host.writeFile(path ?? metadata.filePath, data);\n  } else {\n    // serialize directly\n    if (!path) {\n      throw new Error('path option is required');\n    }\n\n    const obj = convertJsonWorkspace(workspace, options.schema);\n    const data = JSON.stringify(obj, null, 2);\n\n    return host.writeFile(path, data);\n  }\n}\n\nfunction convertJsonWorkspace(workspace: WorkspaceDefinition, schema?: string): JsonObject {\n  const obj = {\n    $schema: schema || './node_modules/@angular/cli/lib/config/schema.json',\n    version: 1,\n    ...workspace.extensions,\n    ...(isEmpty(workspace.projects)\n      ? {}\n      : { projects: convertJsonProjectCollection(workspace.projects) }),\n  };\n\n  return obj;\n}\n\nfunction convertJsonProjectCollection(\n  collection: Iterable<[string, ProjectDefinition]>,\n): JsonObject {\n  const projects = Object.create(null) as JsonObject;\n\n  for (const [projectName, project] of collection) {\n    projects[projectName] = convertJsonProject(project);\n  }\n\n  return projects;\n}\n\nfunction convertJsonProject(project: ProjectDefinition): JsonObject {\n  let targets: JsonObject | undefined;\n  if (project.targets.size > 0) {\n    targets = Object.create(null) as JsonObject;\n    for (const [targetName, target] of project.targets) {\n      targets[targetName] = convertJsonTarget(target);\n    }\n  }\n\n  const obj = {\n    ...project.extensions,\n    root: project.root,\n    ...(project.sourceRoot === undefined ? {} : { sourceRoot: project.sourceRoot }),\n    ...(project.prefix === undefined ? {} : { prefix: project.prefix }),\n    ...(targets === undefined ? {} : { architect: targets }),\n  };\n\n  return obj;\n}\n\nfunction isEmpty(obj: object | undefined): boolean {\n  return obj === undefined || Object.keys(obj).length === 0;\n}\n\nfunction convertJsonTarget(target: TargetDefinition): JsonObject {\n  return {\n    builder: target.builder,\n    ...(isEmpty(target.options) ? {} : { options: target.options as JsonObject }),\n    ...(isEmpty(target.configurations)\n      ? {}\n      : { configurations: target.configurations as JsonObject }),\n    ...(target.defaultConfiguration === undefined\n      ? {}\n      : { defaultConfiguration: target.defaultConfiguration }),\n  };\n}\n\nfunction convertJsonTargetCollection(collection: Iterable<[string, TargetDefinition]>): JsonObject {\n  const targets = Object.create(null) as JsonObject;\n\n  for (const [projectName, target] of collection) {\n    targets[projectName] = convertJsonTarget(target);\n  }\n\n  return targets;\n}\n\nfunction normalizeValue(\n  value: JsonChange['value'] | undefined,\n  type: JsonChange['type'],\n): JsonValue | undefined {\n  if (value === undefined) {\n    return undefined;\n  }\n\n  switch (type) {\n    case 'project':\n      return convertJsonProject(value as ProjectDefinition);\n    case 'projectcollection':\n      const projects = convertJsonProjectCollection(value as Iterable<[string, ProjectDefinition]>);\n\n      return isEmpty(projects) ? undefined : projects;\n    case 'target':\n      return convertJsonTarget(value as TargetDefinition);\n    case 'targetcollection':\n      const targets = convertJsonTargetCollection(value as Iterable<[string, TargetDefinition]>);\n\n      return isEmpty(targets) ? undefined : targets;\n    default:\n      return value as JsonValue;\n  }\n}\n\nfunction updateJsonWorkspace(metadata: JsonWorkspaceMetadata): string {\n  let { raw: content } = metadata;\n  const { changes, hasLegacyTargetsName } = metadata;\n\n  for (const { jsonPath, value, type } of changes.values()) {\n    // Determine which key to use if (architect or targets)\n    if (hasLegacyTargetsName && jsonPath[2] === 'targets') {\n      jsonPath[2] = 'architect';\n    }\n\n    // TODO: `modify` re-parses the content every time.\n    // See: https://github.com/microsoft/node-jsonc-parser/blob/35d94cd71bd48f9784453b2439262c938e21d49b/src/impl/edit.ts#L18\n    // Ideally this should accept a string or an AST to avoid the potentially expensive repeat parsing operation.\n    const edits = modify(content, jsonPath, normalizeValue(value, type), {\n      formattingOptions: {\n        insertSpaces: true,\n        tabSize: 2,\n      },\n    });\n\n    content = applyEdits(content, edits);\n  }\n\n  return content;\n}\n"]}