@angular/cli 15.2.0-next.0 → 15.2.0-next.2

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.
@@ -215,9 +215,7 @@
215
215
  "$ref": "#/definitions/SchematicsAngularWebWorkerSchema"
216
216
  }
217
217
  },
218
- "additionalProperties": {
219
- "type": "object"
220
- }
218
+ "additionalProperties": true
221
219
  },
222
220
  "fileVersion": {
223
221
  "type": "integer",
@@ -106,6 +106,7 @@ export interface SchematicOptions {
106
106
  "@schematics/angular:resolver"?: AngularResolverOptionsSchema;
107
107
  "@schematics/angular:service"?: AngularServiceOptionsSchema;
108
108
  "@schematics/angular:web-worker"?: AngularWebWorkerOptionsSchema;
109
+ [property: string]: any;
109
110
  }
110
111
  /**
111
112
  * Generates a new basic application definition in the "projects" subfolder of the workspace.
@@ -613,6 +614,7 @@ export interface CommitObject {
613
614
  email: string;
614
615
  message?: string;
615
616
  name: string;
617
+ [property: string]: any;
616
618
  }
617
619
  /**
618
620
  * Creates a new, generic pipe definition in the given project.
@@ -75,4 +75,4 @@ var Implement;
75
75
  Implement["CanLoad"] = "CanLoad";
76
76
  Implement["CanMatch"] = "CanMatch";
77
77
  })(Implement = exports.Implement || (exports.Implement = {}));
78
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workspace-schema.js","sourceRoot":"","sources":["../../../../../../../../packages/angular/cli/lib/config/workspace-schema.ts"],"names":[],"mappings":";AACA,mFAAmF;AACnF,oFAAoF;;;AAqEpF;;GAEG;AACH,IAAY,WAIX;AAJD,WAAY,WAAW;IACnB,0BAAW,CAAA;IACX,wBAAS,CAAA;IACT,8BAAe,CAAA;AACnB,CAAC,EAJW,WAAW,GAAX,mBAAW,KAAX,mBAAW,QAItB;AAED;;;;GAIG;AACH,IAAY,cAKX;AALD,WAAY,cAAc;IACtB,+BAAa,CAAA;IACb,6BAAW,CAAA;IACX,+BAAa,CAAA;IACb,+BAAa,CAAA;AACjB,CAAC,EALW,cAAc,GAAd,sBAAc,KAAd,sBAAc,QAKzB;AA8FD;;GAEG;AACH,IAAY,iCAKX;AALD,WAAY,iCAAiC;IACzC,gDAAW,CAAA;IACX,kDAAa,CAAA;IACb,kDAAa,CAAA;IACb,kDAAa,CAAA;AACjB,CAAC,EALW,iCAAiC,GAAjC,yCAAiC,KAAjC,yCAAiC,QAK5C;AAED;;;;;;GAMG;AACH,IAAY,iBAIX;AAJD,WAAY,iBAAiB;IACzB,0CAAqB,CAAA;IACrB,kCAAa,CAAA;IACb,4CAAuB,CAAA;AAC3B,CAAC,EAJW,iBAAiB,GAAjB,yBAAiB,KAAjB,yBAAiB,QAI5B;AAkHD;;GAEG;AACH,IAAY,eAGX;AAHD,WAAY,eAAe;IACvB,sCAAmB,CAAA;IACnB,oCAAiB,CAAA;AACrB,CAAC,EAHW,eAAe,GAAf,uBAAe,KAAf,uBAAe,QAG1B;AAED;;;GAGG;AACH,IAAY,+BAMX;AAND,WAAY,+BAA+B;IACvC,8CAAW,CAAA;IACX,gDAAa,CAAA;IACb,gDAAa,CAAA;IACb,gDAAa,CAAA;IACb,gDAAa,CAAA;AACjB,CAAC,EANW,+BAA+B,GAA/B,uCAA+B,KAA/B,uCAA+B,QAM1C;AA+GD,IAAY,SAMX;AAND,WAAY,SAAS;IACjB,wCAA2B,CAAA;IAC3B,kDAAqC,CAAA;IACrC,4CAA+B,CAAA;IAC/B,gCAAmB,CAAA;IACnB,kCAAqB,CAAA;AACzB,CAAC,EANW,SAAS,GAAT,iBAAS,KAAT,iBAAS,QAMpB","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\nexport interface Schema {\n    $schema?: string;\n    cli?:     CliOptions;\n    /**\n     * Default project name used in commands.\n     * @deprecated The project to use will be determined from the current working directory.\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     * Share pseudonymous usage data with the Angular Team at Google.\n     */\n    analytics?: Analytics;\n    /**\n     * Control disk cache.\n     */\n    cache?: Cache;\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     * The list of schematic collections to use.\n     */\n    schematicCollections?: string[];\n    /**\n     * Control CLI specific console warnings\n     */\n    warnings?: Warnings;\n}\n\n/**\n * Share pseudonymous usage data with the Angular Team at Google.\n */\nexport type Analytics = boolean | string;\n\n/**\n * Control disk cache.\n */\nexport interface Cache {\n    /**\n     * Configure whether disk caching is enabled.\n     */\n    enabled?: boolean;\n    /**\n     * Configure in which environment disk cache is enabled.\n     */\n    environment?: Environment;\n    /**\n     * Cache base path.\n     */\n    path?: string;\n}\n\n/**\n * Configure in which environment disk cache is enabled.\n */\nexport enum Environment {\n    All = \"all\",\n    Ci = \"ci\",\n    Local = \"local\",\n}\n\n/**\n * Specify which package manager tool to use.\n *\n * The package manager used to install dependencies.\n */\nexport enum PackageManager {\n    Cnpm = \"cnpm\",\n    Npm = \"npm\",\n    Pnpm = \"pnpm\",\n    Yarn = \"yarn\",\n}\n\n/**\n * Control CLI specific console warnings\n */\nexport interface Warnings {\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:application\"?: AngularApplicationOptionsSchema;\n    \"@schematics/angular:class\"?:       AngularClassOptionsSchema;\n    \"@schematics/angular:component\"?:   AngularComponentOptionsSchema;\n    \"@schematics/angular:directive\"?:   AngularDirectiveOptionsSchema;\n    \"@schematics/angular:enum\"?:        AngularEnumOptionsSchema;\n    \"@schematics/angular:guard\"?:       AngularGuardOptionsSchema;\n    \"@schematics/angular:interceptor\"?: AngularInterceptorOptionsSchema;\n    \"@schematics/angular:interface\"?:   AngularInterfaceOptionsSchema;\n    \"@schematics/angular:library\"?:     LibraryOptionsSchema;\n    \"@schematics/angular:ng-new\"?:      AngularNgNewOptionsSchema;\n    \"@schematics/angular:pipe\"?:        AngularPipeOptionsSchema;\n    \"@schematics/angular:resolver\"?:    AngularResolverOptionsSchema;\n    \"@schematics/angular:service\"?:     AngularServiceOptionsSchema;\n    \"@schematics/angular:web-worker\"?:  AngularWebWorkerOptionsSchema;\n}\n\n/**\n * Generates a new basic application definition in the \"projects\" subfolder of the workspace.\n */\nexport interface AngularApplicationOptionsSchema {\n    /**\n     * Include styles inline in the root component.ts file. Only CSS styles can be included\n     * inline. Default is false, meaning that an external styles file is created and referenced\n     * in the root component.ts file.\n     */\n    inlineStyle?: boolean;\n    /**\n     * Include template inline in the root component.ts file. Default is false, meaning that an\n     * external template file is created and referenced in the root component.ts file.\n     */\n    inlineTemplate?: boolean;\n    /**\n     * Create a bare-bones project without any testing frameworks. (Use for learning purposes\n     * only.)\n     */\n    minimal?: boolean;\n    /**\n     * The name of the new application.\n     */\n    name: string;\n    /**\n     * A prefix to apply to generated selectors.\n     */\n    prefix?: string;\n    /**\n     * The root directory of the new application.\n     */\n    projectRoot?: string;\n    /**\n     * Create a routing NgModule.\n     */\n    routing?: boolean;\n    /**\n     * Skip installing dependency packages.\n     */\n    skipInstall?: boolean;\n    /**\n     * Do not add dependencies to the \"package.json\" file.\n     */\n    skipPackageJson?: boolean;\n    /**\n     * Do not create \"spec.ts\" test files for the application.\n     */\n    skipTests?: boolean;\n    /**\n     * Creates an application with stricter bundle budgets settings.\n     */\n    strict?: boolean;\n    /**\n     * The file extension or preprocessor to use for style files.\n     */\n    style?: SchematicsAngularApplicationStyle;\n    /**\n     * The view encapsulation strategy to use in the new application.\n     */\n    viewEncapsulation?: ViewEncapsulation;\n}\n\n/**\n * The file extension or preprocessor to use for style files.\n */\nexport enum SchematicsAngularApplicationStyle {\n    Css = \"css\",\n    Less = \"less\",\n    Sass = \"sass\",\n    Scss = \"scss\",\n}\n\n/**\n * The view encapsulation strategy to use in the new application.\n *\n * The view encapsulation strategy to use in the new component.\n *\n * The view encapsulation strategy to use in the initial project.\n */\nexport enum ViewEncapsulation {\n    Emulated = \"Emulated\",\n    None = \"None\",\n    ShadowDom = \"ShadowDom\",\n}\n\n/**\n * Creates a new, generic class definition in the given project.\n */\nexport interface AngularClassOptionsSchema {\n    /**\n     * The name of the new class.\n     */\n    name: string;\n    /**\n     * The path at which to create the class, relative to the workspace root.\n     */\n    path?: string;\n    /**\n     * The name of the project.\n     */\n    project: string;\n    /**\n     * Do not create \"spec.ts\" test files for the new class.\n     */\n    skipTests?: boolean;\n    /**\n     * Adds a developer-defined type to the filename, in the format \"name.type.ts\".\n     */\n    type?: string;\n}\n\n/**\n * Creates a new, generic component definition in the given project.\n */\nexport interface AngularComponentOptionsSchema {\n    /**\n     * The change detection strategy to use in the new component.\n     */\n    changeDetection?: ChangeDetection;\n    /**\n     * Specifies if the style will contain `:host { display: block; }`.\n     */\n    displayBlock?: boolean;\n    /**\n     * The declaring NgModule exports this component.\n     */\n    export?: boolean;\n    /**\n     * Create the new files at the top level of the current project.\n     */\n    flat?: boolean;\n    /**\n     * Include styles inline in the component.ts file. Only CSS styles can be included inline.\n     * By default, an external styles file is created and referenced in the component.ts file.\n     */\n    inlineStyle?: boolean;\n    /**\n     * Include template inline in the component.ts file. By default, an external template file\n     * is created and referenced in the component.ts file.\n     */\n    inlineTemplate?: boolean;\n    /**\n     * The declaring NgModule.\n     */\n    module?: string;\n    /**\n     * The name of the component.\n     */\n    name: string;\n    /**\n     * The path at which to create the component file, relative to the current workspace.\n     * Default is a folder with the same name as the component in the project root.\n     */\n    path?: string;\n    /**\n     * The prefix to apply to the generated component selector.\n     */\n    prefix?: string;\n    /**\n     * The name of the project.\n     */\n    project: string;\n    /**\n     * The HTML selector to use for this component.\n     */\n    selector?: string;\n    /**\n     * Do not import this component into the owning NgModule.\n     */\n    skipImport?: boolean;\n    /**\n     * Specifies if the component should have a selector or not.\n     */\n    skipSelector?: boolean;\n    /**\n     * Do not create \"spec.ts\" test files for the new component.\n     */\n    skipTests?: boolean;\n    /**\n     * Whether the generated component is standalone.\n     */\n    standalone?: boolean;\n    /**\n     * The file extension or preprocessor to use for style files, or 'none' to skip generating\n     * the style file.\n     */\n    style?: SchematicsAngularComponentStyle;\n    /**\n     * Adds a developer-defined type to the filename, in the format \"name.type.ts\".\n     */\n    type?: string;\n    /**\n     * The view encapsulation strategy to use in the new component.\n     */\n    viewEncapsulation?: ViewEncapsulation;\n}\n\n/**\n * The change detection strategy to use in the new component.\n */\nexport enum ChangeDetection {\n    Default = \"Default\",\n    OnPush = \"OnPush\",\n}\n\n/**\n * The file extension or preprocessor to use for style files, or 'none' to skip generating\n * the style file.\n */\nexport enum SchematicsAngularComponentStyle {\n    Css = \"css\",\n    Less = \"less\",\n    None = \"none\",\n    Sass = \"sass\",\n    Scss = \"scss\",\n}\n\n/**\n * Creates a new, generic directive definition in the given project.\n */\nexport interface AngularDirectiveOptionsSchema {\n    /**\n     * The declaring NgModule exports this directive.\n     */\n    export?: boolean;\n    /**\n     * When true (the default), creates the new files at the top level of the current project.\n     */\n    flat?: boolean;\n    /**\n     * The declaring NgModule.\n     */\n    module?: string;\n    /**\n     * The name of the new directive.\n     */\n    name: string;\n    /**\n     * The path at which to create the interface that defines the directive, relative to the\n     * workspace root.\n     */\n    path?: string;\n    /**\n     * A prefix to apply to generated selectors.\n     */\n    prefix?: string;\n    /**\n     * The name of the project.\n     */\n    project: string;\n    /**\n     * The HTML selector to use for this directive.\n     */\n    selector?: string;\n    /**\n     * Do not import this directive into the owning NgModule.\n     */\n    skipImport?: boolean;\n    /**\n     * Do not create \"spec.ts\" test files for the new class.\n     */\n    skipTests?: boolean;\n    /**\n     * Whether the generated directive is standalone.\n     */\n    standalone?: boolean;\n}\n\n/**\n * Generates a new, generic enum definition in the given project.\n */\nexport interface AngularEnumOptionsSchema {\n    /**\n     * The name of the enum.\n     */\n    name: string;\n    /**\n     * The path at which to create the enum definition, relative to the current workspace.\n     */\n    path?: string;\n    /**\n     * The name of the project in which to create the enum. Default is the configured default\n     * project for the workspace.\n     */\n    project: string;\n    /**\n     * Adds a developer-defined type to the filename, in the format \"name.type.ts\".\n     */\n    type?: string;\n}\n\n/**\n * Generates a new, generic route guard definition in the given project.\n */\nexport interface AngularGuardOptionsSchema {\n    /**\n     * When true (the default), creates the new files at the top level of the current project.\n     */\n    flat?: boolean;\n    /**\n     * Specifies whether to generate a guard as a function.\n     */\n    functional?: boolean;\n    /**\n     * Specifies which type of guard to create.\n     */\n    implements?: Implement[];\n    /**\n     * The name of the new route guard.\n     */\n    name: string;\n    /**\n     * The path at which to create the interface that defines the guard, relative to the current\n     * workspace.\n     */\n    path?: string;\n    /**\n     * The name of the project.\n     */\n    project: string;\n    /**\n     * Do not create \"spec.ts\" test files for the new guard.\n     */\n    skipTests?: boolean;\n}\n\nexport enum Implement {\n    CanActivate = \"CanActivate\",\n    CanActivateChild = \"CanActivateChild\",\n    CanDeactivate = \"CanDeactivate\",\n    CanLoad = \"CanLoad\",\n    CanMatch = \"CanMatch\",\n}\n\n/**\n * Creates a new, generic interceptor definition in the given project.\n */\nexport interface AngularInterceptorOptionsSchema {\n    /**\n     * When true (the default), creates files at the top level of the project.\n     */\n    flat?: boolean;\n    /**\n     * Creates the interceptor as a `HttpInterceptorFn`.\n     */\n    functional?: boolean;\n    /**\n     * The name of the interceptor.\n     */\n    name: string;\n    /**\n     * The path at which to create the interceptor, relative to the workspace root.\n     */\n    path?: string;\n    /**\n     * The name of the project.\n     */\n    project: string;\n    /**\n     * Do not create \"spec.ts\" test files for the new interceptor.\n     */\n    skipTests?: boolean;\n}\n\n/**\n * Creates a new, generic interface definition in the given project.\n */\nexport interface AngularInterfaceOptionsSchema {\n    /**\n     * The name of the interface.\n     */\n    name: string;\n    /**\n     * The path at which to create the interface, relative to the workspace root.\n     */\n    path?: string;\n    /**\n     * A prefix to apply to generated selectors.\n     */\n    prefix?: string;\n    /**\n     * The name of the project.\n     */\n    project: string;\n    /**\n     * Adds a developer-defined type to the filename, in the format \"name.type.ts\".\n     */\n    type?: string;\n}\n\n/**\n * Creates a new, generic library project in the current workspace.\n */\nexport interface LibraryOptionsSchema {\n    /**\n     * The path at which to create the library's public API file, relative to the workspace root.\n     */\n    entryFile?: string;\n    /**\n     * The name of the library.\n     */\n    name: string;\n    /**\n     * A prefix to apply to generated selectors.\n     */\n    prefix?: string;\n    /**\n     * The root directory of the new library.\n     */\n    projectRoot?: string;\n    /**\n     * Do not install dependency packages.\n     */\n    skipInstall?: boolean;\n    /**\n     * Do not add dependencies to the \"package.json\" file.\n     */\n    skipPackageJson?: boolean;\n    /**\n     * Do not update \"tsconfig.json\" to add a path mapping for the new library. The path mapping\n     * is needed to use the library in an app, but can be disabled here to simplify development.\n     */\n    skipTsConfig?: boolean;\n}\n\n/**\n * Creates a new project by combining the workspace and application schematics.\n */\nexport interface AngularNgNewOptionsSchema {\n    /**\n     * Initial git repository commit information.\n     */\n    commit?: CommitUnion;\n    /**\n     * Create a new initial application project in the 'src' folder of the new workspace. When\n     * false, creates an empty workspace with no initial application. You can then use the\n     * generate application command so that all applications are created in the projects folder.\n     */\n    createApplication?: boolean;\n    /**\n     * The directory name to create the workspace in.\n     */\n    directory?: string;\n    /**\n     * Include styles inline in the component TS file. By default, an external styles file is\n     * created and referenced in the component TypeScript file.\n     */\n    inlineStyle?: boolean;\n    /**\n     * Include template inline in the component TS file. By default, an external template file\n     * is created and referenced in the component TypeScript file.\n     */\n    inlineTemplate?: boolean;\n    /**\n     * Link the CLI to the global version (internal development only).\n     */\n    linkCli?: boolean;\n    /**\n     * Create a workspace without any testing frameworks. (Use for learning purposes only.)\n     */\n    minimal?: boolean;\n    /**\n     * The name of the new workspace and initial project.\n     */\n    name: string;\n    /**\n     * The path where new projects will be created, relative to the new workspace root.\n     */\n    newProjectRoot?: string;\n    /**\n     * The package manager used to install dependencies.\n     */\n    packageManager?: PackageManager;\n    /**\n     * The prefix to apply to generated selectors for the initial project.\n     */\n    prefix?: string;\n    /**\n     * Generate a routing module for the initial project.\n     */\n    routing?: boolean;\n    /**\n     * Do not initialize a git repository.\n     */\n    skipGit?: boolean;\n    /**\n     * Do not install dependency packages.\n     */\n    skipInstall?: boolean;\n    /**\n     * Do not generate \"spec.ts\" test files for the new project.\n     */\n    skipTests?: boolean;\n    /**\n     * Creates a workspace with stricter type checking and stricter bundle budgets settings.\n     * This setting helps improve maintainability and catch bugs ahead of time. For more\n     * information, see https://angular.io/guide/strict-mode\n     */\n    strict?: boolean;\n    /**\n     * The file extension or preprocessor to use for style files.\n     */\n    style?: SchematicsAngularApplicationStyle;\n    /**\n     * The version of the Angular CLI to use.\n     */\n    version: string;\n    /**\n     * The view encapsulation strategy to use in the initial project.\n     */\n    viewEncapsulation?: ViewEncapsulation;\n}\n\n/**\n * Initial git repository commit information.\n */\nexport type CommitUnion = boolean | CommitObject;\n\nexport interface CommitObject {\n    email:    string;\n    message?: string;\n    name:     string;\n}\n\n/**\n * Creates a new, generic pipe definition in the given project.\n */\nexport interface AngularPipeOptionsSchema {\n    /**\n     * The declaring NgModule exports this pipe.\n     */\n    export?: boolean;\n    /**\n     * When true (the default) creates files at the top level of the project.\n     */\n    flat?: boolean;\n    /**\n     * The declaring NgModule.\n     */\n    module?: string;\n    /**\n     * The name of the pipe.\n     */\n    name: string;\n    /**\n     * The path at which to create the pipe, relative to the workspace root.\n     */\n    path?: string;\n    /**\n     * The name of the project.\n     */\n    project: string;\n    /**\n     * Do not import this pipe into the owning NgModule.\n     */\n    skipImport?: boolean;\n    /**\n     * Do not create \"spec.ts\" test files for the new pipe.\n     */\n    skipTests?: boolean;\n    /**\n     * Whether the generated pipe is standalone.\n     */\n    standalone?: boolean;\n}\n\n/**\n * Generates a new, generic resolver definition in the given project.\n */\nexport interface AngularResolverOptionsSchema {\n    /**\n     * When true (the default), creates the new files at the top level of the current project.\n     */\n    flat?: boolean;\n    /**\n     * Creates the resolver as a `ResolveFn`.\n     */\n    functional?: boolean;\n    /**\n     * The name of the new resolver.\n     */\n    name: string;\n    /**\n     * The path at which to create the interface that defines the resolver, relative to the\n     * current workspace.\n     */\n    path?: string;\n    /**\n     * The name of the project.\n     */\n    project: string;\n    /**\n     * Do not create \"spec.ts\" test files for the new resolver.\n     */\n    skipTests?: boolean;\n}\n\n/**\n * Creates a new, generic service definition in the given project.\n */\nexport interface AngularServiceOptionsSchema {\n    /**\n     * When true (the default), creates files at the top level of the project.\n     */\n    flat?: boolean;\n    /**\n     * The name of the service.\n     */\n    name: string;\n    /**\n     * The path at which to create the service, relative to the workspace root.\n     */\n    path?: string;\n    /**\n     * The name of the project.\n     */\n    project: string;\n    /**\n     * Do not create \"spec.ts\" test files for the new service.\n     */\n    skipTests?: boolean;\n}\n\n/**\n * Creates a new, generic web worker definition in the given project.\n */\nexport interface AngularWebWorkerOptionsSchema {\n    /**\n     * The name of the worker.\n     */\n    name: string;\n    /**\n     * The path at which to create the worker file, relative to the current workspace.\n     */\n    path?: string;\n    /**\n     * The name of the project.\n     */\n    project: string;\n    /**\n     * Add a worker creation snippet in a sibling file of the same name.\n     */\n    snippet?: boolean;\n}\n"]}
78
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workspace-schema.js","sourceRoot":"","sources":["../../../../../../../../packages/angular/cli/lib/config/workspace-schema.ts"],"names":[],"mappings":";AACA,mFAAmF;AACnF,oFAAoF;;;AAqEpF;;GAEG;AACH,IAAY,WAIX;AAJD,WAAY,WAAW;IACnB,0BAAW,CAAA;IACX,wBAAS,CAAA;IACT,8BAAe,CAAA;AACnB,CAAC,EAJW,WAAW,GAAX,mBAAW,KAAX,mBAAW,QAItB;AAED;;;;GAIG;AACH,IAAY,cAKX;AALD,WAAY,cAAc;IACtB,+BAAa,CAAA;IACb,6BAAW,CAAA;IACX,+BAAa,CAAA;IACb,+BAAa,CAAA;AACjB,CAAC,EALW,cAAc,GAAd,sBAAc,KAAd,sBAAc,QAKzB;AA+FD;;GAEG;AACH,IAAY,iCAKX;AALD,WAAY,iCAAiC;IACzC,gDAAW,CAAA;IACX,kDAAa,CAAA;IACb,kDAAa,CAAA;IACb,kDAAa,CAAA;AACjB,CAAC,EALW,iCAAiC,GAAjC,yCAAiC,KAAjC,yCAAiC,QAK5C;AAED;;;;;;GAMG;AACH,IAAY,iBAIX;AAJD,WAAY,iBAAiB;IACzB,0CAAqB,CAAA;IACrB,kCAAa,CAAA;IACb,4CAAuB,CAAA;AAC3B,CAAC,EAJW,iBAAiB,GAAjB,yBAAiB,KAAjB,yBAAiB,QAI5B;AAkHD;;GAEG;AACH,IAAY,eAGX;AAHD,WAAY,eAAe;IACvB,sCAAmB,CAAA;IACnB,oCAAiB,CAAA;AACrB,CAAC,EAHW,eAAe,GAAf,uBAAe,KAAf,uBAAe,QAG1B;AAED;;;GAGG;AACH,IAAY,+BAMX;AAND,WAAY,+BAA+B;IACvC,8CAAW,CAAA;IACX,gDAAa,CAAA;IACb,gDAAa,CAAA;IACb,gDAAa,CAAA;IACb,gDAAa,CAAA;AACjB,CAAC,EANW,+BAA+B,GAA/B,uCAA+B,KAA/B,uCAA+B,QAM1C;AA+GD,IAAY,SAMX;AAND,WAAY,SAAS;IACjB,wCAA2B,CAAA;IAC3B,kDAAqC,CAAA;IACrC,4CAA+B,CAAA;IAC/B,gCAAmB,CAAA;IACnB,kCAAqB,CAAA;AACzB,CAAC,EANW,SAAS,GAAT,iBAAS,KAAT,iBAAS,QAMpB","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\nexport interface Schema {\n    $schema?: string;\n    cli?:     CliOptions;\n    /**\n     * Default project name used in commands.\n     * @deprecated The project to use will be determined from the current working directory.\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     * Share pseudonymous usage data with the Angular Team at Google.\n     */\n    analytics?: Analytics;\n    /**\n     * Control disk cache.\n     */\n    cache?: Cache;\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     * The list of schematic collections to use.\n     */\n    schematicCollections?: string[];\n    /**\n     * Control CLI specific console warnings\n     */\n    warnings?: Warnings;\n}\n\n/**\n * Share pseudonymous usage data with the Angular Team at Google.\n */\nexport type Analytics = boolean | string;\n\n/**\n * Control disk cache.\n */\nexport interface Cache {\n    /**\n     * Configure whether disk caching is enabled.\n     */\n    enabled?: boolean;\n    /**\n     * Configure in which environment disk cache is enabled.\n     */\n    environment?: Environment;\n    /**\n     * Cache base path.\n     */\n    path?: string;\n}\n\n/**\n * Configure in which environment disk cache is enabled.\n */\nexport enum Environment {\n    All = \"all\",\n    Ci = \"ci\",\n    Local = \"local\",\n}\n\n/**\n * Specify which package manager tool to use.\n *\n * The package manager used to install dependencies.\n */\nexport enum PackageManager {\n    Cnpm = \"cnpm\",\n    Npm = \"npm\",\n    Pnpm = \"pnpm\",\n    Yarn = \"yarn\",\n}\n\n/**\n * Control CLI specific console warnings\n */\nexport interface Warnings {\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:application\"?: AngularApplicationOptionsSchema;\n    \"@schematics/angular:class\"?:       AngularClassOptionsSchema;\n    \"@schematics/angular:component\"?:   AngularComponentOptionsSchema;\n    \"@schematics/angular:directive\"?:   AngularDirectiveOptionsSchema;\n    \"@schematics/angular:enum\"?:        AngularEnumOptionsSchema;\n    \"@schematics/angular:guard\"?:       AngularGuardOptionsSchema;\n    \"@schematics/angular:interceptor\"?: AngularInterceptorOptionsSchema;\n    \"@schematics/angular:interface\"?:   AngularInterfaceOptionsSchema;\n    \"@schematics/angular:library\"?:     LibraryOptionsSchema;\n    \"@schematics/angular:ng-new\"?:      AngularNgNewOptionsSchema;\n    \"@schematics/angular:pipe\"?:        AngularPipeOptionsSchema;\n    \"@schematics/angular:resolver\"?:    AngularResolverOptionsSchema;\n    \"@schematics/angular:service\"?:     AngularServiceOptionsSchema;\n    \"@schematics/angular:web-worker\"?:  AngularWebWorkerOptionsSchema;\n    [property: string]: any;\n}\n\n/**\n * Generates a new basic application definition in the \"projects\" subfolder of the workspace.\n */\nexport interface AngularApplicationOptionsSchema {\n    /**\n     * Include styles inline in the root component.ts file. Only CSS styles can be included\n     * inline. Default is false, meaning that an external styles file is created and referenced\n     * in the root component.ts file.\n     */\n    inlineStyle?: boolean;\n    /**\n     * Include template inline in the root component.ts file. Default is false, meaning that an\n     * external template file is created and referenced in the root component.ts file.\n     */\n    inlineTemplate?: boolean;\n    /**\n     * Create a bare-bones project without any testing frameworks. (Use for learning purposes\n     * only.)\n     */\n    minimal?: boolean;\n    /**\n     * The name of the new application.\n     */\n    name: string;\n    /**\n     * A prefix to apply to generated selectors.\n     */\n    prefix?: string;\n    /**\n     * The root directory of the new application.\n     */\n    projectRoot?: string;\n    /**\n     * Create a routing NgModule.\n     */\n    routing?: boolean;\n    /**\n     * Skip installing dependency packages.\n     */\n    skipInstall?: boolean;\n    /**\n     * Do not add dependencies to the \"package.json\" file.\n     */\n    skipPackageJson?: boolean;\n    /**\n     * Do not create \"spec.ts\" test files for the application.\n     */\n    skipTests?: boolean;\n    /**\n     * Creates an application with stricter bundle budgets settings.\n     */\n    strict?: boolean;\n    /**\n     * The file extension or preprocessor to use for style files.\n     */\n    style?: SchematicsAngularApplicationStyle;\n    /**\n     * The view encapsulation strategy to use in the new application.\n     */\n    viewEncapsulation?: ViewEncapsulation;\n}\n\n/**\n * The file extension or preprocessor to use for style files.\n */\nexport enum SchematicsAngularApplicationStyle {\n    Css = \"css\",\n    Less = \"less\",\n    Sass = \"sass\",\n    Scss = \"scss\",\n}\n\n/**\n * The view encapsulation strategy to use in the new application.\n *\n * The view encapsulation strategy to use in the new component.\n *\n * The view encapsulation strategy to use in the initial project.\n */\nexport enum ViewEncapsulation {\n    Emulated = \"Emulated\",\n    None = \"None\",\n    ShadowDom = \"ShadowDom\",\n}\n\n/**\n * Creates a new, generic class definition in the given project.\n */\nexport interface AngularClassOptionsSchema {\n    /**\n     * The name of the new class.\n     */\n    name: string;\n    /**\n     * The path at which to create the class, relative to the workspace root.\n     */\n    path?: string;\n    /**\n     * The name of the project.\n     */\n    project: string;\n    /**\n     * Do not create \"spec.ts\" test files for the new class.\n     */\n    skipTests?: boolean;\n    /**\n     * Adds a developer-defined type to the filename, in the format \"name.type.ts\".\n     */\n    type?: string;\n}\n\n/**\n * Creates a new, generic component definition in the given project.\n */\nexport interface AngularComponentOptionsSchema {\n    /**\n     * The change detection strategy to use in the new component.\n     */\n    changeDetection?: ChangeDetection;\n    /**\n     * Specifies if the style will contain `:host { display: block; }`.\n     */\n    displayBlock?: boolean;\n    /**\n     * The declaring NgModule exports this component.\n     */\n    export?: boolean;\n    /**\n     * Create the new files at the top level of the current project.\n     */\n    flat?: boolean;\n    /**\n     * Include styles inline in the component.ts file. Only CSS styles can be included inline.\n     * By default, an external styles file is created and referenced in the component.ts file.\n     */\n    inlineStyle?: boolean;\n    /**\n     * Include template inline in the component.ts file. By default, an external template file\n     * is created and referenced in the component.ts file.\n     */\n    inlineTemplate?: boolean;\n    /**\n     * The declaring NgModule.\n     */\n    module?: string;\n    /**\n     * The name of the component.\n     */\n    name: string;\n    /**\n     * The path at which to create the component file, relative to the current workspace.\n     * Default is a folder with the same name as the component in the project root.\n     */\n    path?: string;\n    /**\n     * The prefix to apply to the generated component selector.\n     */\n    prefix?: string;\n    /**\n     * The name of the project.\n     */\n    project: string;\n    /**\n     * The HTML selector to use for this component.\n     */\n    selector?: string;\n    /**\n     * Do not import this component into the owning NgModule.\n     */\n    skipImport?: boolean;\n    /**\n     * Specifies if the component should have a selector or not.\n     */\n    skipSelector?: boolean;\n    /**\n     * Do not create \"spec.ts\" test files for the new component.\n     */\n    skipTests?: boolean;\n    /**\n     * Whether the generated component is standalone.\n     */\n    standalone?: boolean;\n    /**\n     * The file extension or preprocessor to use for style files, or 'none' to skip generating\n     * the style file.\n     */\n    style?: SchematicsAngularComponentStyle;\n    /**\n     * Adds a developer-defined type to the filename, in the format \"name.type.ts\".\n     */\n    type?: string;\n    /**\n     * The view encapsulation strategy to use in the new component.\n     */\n    viewEncapsulation?: ViewEncapsulation;\n}\n\n/**\n * The change detection strategy to use in the new component.\n */\nexport enum ChangeDetection {\n    Default = \"Default\",\n    OnPush = \"OnPush\",\n}\n\n/**\n * The file extension or preprocessor to use for style files, or 'none' to skip generating\n * the style file.\n */\nexport enum SchematicsAngularComponentStyle {\n    Css = \"css\",\n    Less = \"less\",\n    None = \"none\",\n    Sass = \"sass\",\n    Scss = \"scss\",\n}\n\n/**\n * Creates a new, generic directive definition in the given project.\n */\nexport interface AngularDirectiveOptionsSchema {\n    /**\n     * The declaring NgModule exports this directive.\n     */\n    export?: boolean;\n    /**\n     * When true (the default), creates the new files at the top level of the current project.\n     */\n    flat?: boolean;\n    /**\n     * The declaring NgModule.\n     */\n    module?: string;\n    /**\n     * The name of the new directive.\n     */\n    name: string;\n    /**\n     * The path at which to create the interface that defines the directive, relative to the\n     * workspace root.\n     */\n    path?: string;\n    /**\n     * A prefix to apply to generated selectors.\n     */\n    prefix?: string;\n    /**\n     * The name of the project.\n     */\n    project: string;\n    /**\n     * The HTML selector to use for this directive.\n     */\n    selector?: string;\n    /**\n     * Do not import this directive into the owning NgModule.\n     */\n    skipImport?: boolean;\n    /**\n     * Do not create \"spec.ts\" test files for the new class.\n     */\n    skipTests?: boolean;\n    /**\n     * Whether the generated directive is standalone.\n     */\n    standalone?: boolean;\n}\n\n/**\n * Generates a new, generic enum definition in the given project.\n */\nexport interface AngularEnumOptionsSchema {\n    /**\n     * The name of the enum.\n     */\n    name: string;\n    /**\n     * The path at which to create the enum definition, relative to the current workspace.\n     */\n    path?: string;\n    /**\n     * The name of the project in which to create the enum. Default is the configured default\n     * project for the workspace.\n     */\n    project: string;\n    /**\n     * Adds a developer-defined type to the filename, in the format \"name.type.ts\".\n     */\n    type?: string;\n}\n\n/**\n * Generates a new, generic route guard definition in the given project.\n */\nexport interface AngularGuardOptionsSchema {\n    /**\n     * When true (the default), creates the new files at the top level of the current project.\n     */\n    flat?: boolean;\n    /**\n     * Specifies whether to generate a guard as a function.\n     */\n    functional?: boolean;\n    /**\n     * Specifies which type of guard to create.\n     */\n    implements?: Implement[];\n    /**\n     * The name of the new route guard.\n     */\n    name: string;\n    /**\n     * The path at which to create the interface that defines the guard, relative to the current\n     * workspace.\n     */\n    path?: string;\n    /**\n     * The name of the project.\n     */\n    project: string;\n    /**\n     * Do not create \"spec.ts\" test files for the new guard.\n     */\n    skipTests?: boolean;\n}\n\nexport enum Implement {\n    CanActivate = \"CanActivate\",\n    CanActivateChild = \"CanActivateChild\",\n    CanDeactivate = \"CanDeactivate\",\n    CanLoad = \"CanLoad\",\n    CanMatch = \"CanMatch\",\n}\n\n/**\n * Creates a new, generic interceptor definition in the given project.\n */\nexport interface AngularInterceptorOptionsSchema {\n    /**\n     * When true (the default), creates files at the top level of the project.\n     */\n    flat?: boolean;\n    /**\n     * Creates the interceptor as a `HttpInterceptorFn`.\n     */\n    functional?: boolean;\n    /**\n     * The name of the interceptor.\n     */\n    name: string;\n    /**\n     * The path at which to create the interceptor, relative to the workspace root.\n     */\n    path?: string;\n    /**\n     * The name of the project.\n     */\n    project: string;\n    /**\n     * Do not create \"spec.ts\" test files for the new interceptor.\n     */\n    skipTests?: boolean;\n}\n\n/**\n * Creates a new, generic interface definition in the given project.\n */\nexport interface AngularInterfaceOptionsSchema {\n    /**\n     * The name of the interface.\n     */\n    name: string;\n    /**\n     * The path at which to create the interface, relative to the workspace root.\n     */\n    path?: string;\n    /**\n     * A prefix to apply to generated selectors.\n     */\n    prefix?: string;\n    /**\n     * The name of the project.\n     */\n    project: string;\n    /**\n     * Adds a developer-defined type to the filename, in the format \"name.type.ts\".\n     */\n    type?: string;\n}\n\n/**\n * Creates a new, generic library project in the current workspace.\n */\nexport interface LibraryOptionsSchema {\n    /**\n     * The path at which to create the library's public API file, relative to the workspace root.\n     */\n    entryFile?: string;\n    /**\n     * The name of the library.\n     */\n    name: string;\n    /**\n     * A prefix to apply to generated selectors.\n     */\n    prefix?: string;\n    /**\n     * The root directory of the new library.\n     */\n    projectRoot?: string;\n    /**\n     * Do not install dependency packages.\n     */\n    skipInstall?: boolean;\n    /**\n     * Do not add dependencies to the \"package.json\" file.\n     */\n    skipPackageJson?: boolean;\n    /**\n     * Do not update \"tsconfig.json\" to add a path mapping for the new library. The path mapping\n     * is needed to use the library in an app, but can be disabled here to simplify development.\n     */\n    skipTsConfig?: boolean;\n}\n\n/**\n * Creates a new project by combining the workspace and application schematics.\n */\nexport interface AngularNgNewOptionsSchema {\n    /**\n     * Initial git repository commit information.\n     */\n    commit?: CommitUnion;\n    /**\n     * Create a new initial application project in the 'src' folder of the new workspace. When\n     * false, creates an empty workspace with no initial application. You can then use the\n     * generate application command so that all applications are created in the projects folder.\n     */\n    createApplication?: boolean;\n    /**\n     * The directory name to create the workspace in.\n     */\n    directory?: string;\n    /**\n     * Include styles inline in the component TS file. By default, an external styles file is\n     * created and referenced in the component TypeScript file.\n     */\n    inlineStyle?: boolean;\n    /**\n     * Include template inline in the component TS file. By default, an external template file\n     * is created and referenced in the component TypeScript file.\n     */\n    inlineTemplate?: boolean;\n    /**\n     * Link the CLI to the global version (internal development only).\n     */\n    linkCli?: boolean;\n    /**\n     * Create a workspace without any testing frameworks. (Use for learning purposes only.)\n     */\n    minimal?: boolean;\n    /**\n     * The name of the new workspace and initial project.\n     */\n    name: string;\n    /**\n     * The path where new projects will be created, relative to the new workspace root.\n     */\n    newProjectRoot?: string;\n    /**\n     * The package manager used to install dependencies.\n     */\n    packageManager?: PackageManager;\n    /**\n     * The prefix to apply to generated selectors for the initial project.\n     */\n    prefix?: string;\n    /**\n     * Generate a routing module for the initial project.\n     */\n    routing?: boolean;\n    /**\n     * Do not initialize a git repository.\n     */\n    skipGit?: boolean;\n    /**\n     * Do not install dependency packages.\n     */\n    skipInstall?: boolean;\n    /**\n     * Do not generate \"spec.ts\" test files for the new project.\n     */\n    skipTests?: boolean;\n    /**\n     * Creates a workspace with stricter type checking and stricter bundle budgets settings.\n     * This setting helps improve maintainability and catch bugs ahead of time. For more\n     * information, see https://angular.io/guide/strict-mode\n     */\n    strict?: boolean;\n    /**\n     * The file extension or preprocessor to use for style files.\n     */\n    style?: SchematicsAngularApplicationStyle;\n    /**\n     * The version of the Angular CLI to use.\n     */\n    version: string;\n    /**\n     * The view encapsulation strategy to use in the initial project.\n     */\n    viewEncapsulation?: ViewEncapsulation;\n}\n\n/**\n * Initial git repository commit information.\n */\nexport type CommitUnion = boolean | CommitObject;\n\nexport interface CommitObject {\n    email:    string;\n    message?: string;\n    name:     string;\n    [property: string]: any;\n}\n\n/**\n * Creates a new, generic pipe definition in the given project.\n */\nexport interface AngularPipeOptionsSchema {\n    /**\n     * The declaring NgModule exports this pipe.\n     */\n    export?: boolean;\n    /**\n     * When true (the default) creates files at the top level of the project.\n     */\n    flat?: boolean;\n    /**\n     * The declaring NgModule.\n     */\n    module?: string;\n    /**\n     * The name of the pipe.\n     */\n    name: string;\n    /**\n     * The path at which to create the pipe, relative to the workspace root.\n     */\n    path?: string;\n    /**\n     * The name of the project.\n     */\n    project: string;\n    /**\n     * Do not import this pipe into the owning NgModule.\n     */\n    skipImport?: boolean;\n    /**\n     * Do not create \"spec.ts\" test files for the new pipe.\n     */\n    skipTests?: boolean;\n    /**\n     * Whether the generated pipe is standalone.\n     */\n    standalone?: boolean;\n}\n\n/**\n * Generates a new, generic resolver definition in the given project.\n */\nexport interface AngularResolverOptionsSchema {\n    /**\n     * When true (the default), creates the new files at the top level of the current project.\n     */\n    flat?: boolean;\n    /**\n     * Creates the resolver as a `ResolveFn`.\n     */\n    functional?: boolean;\n    /**\n     * The name of the new resolver.\n     */\n    name: string;\n    /**\n     * The path at which to create the interface that defines the resolver, relative to the\n     * current workspace.\n     */\n    path?: string;\n    /**\n     * The name of the project.\n     */\n    project: string;\n    /**\n     * Do not create \"spec.ts\" test files for the new resolver.\n     */\n    skipTests?: boolean;\n}\n\n/**\n * Creates a new, generic service definition in the given project.\n */\nexport interface AngularServiceOptionsSchema {\n    /**\n     * When true (the default), creates files at the top level of the project.\n     */\n    flat?: boolean;\n    /**\n     * The name of the service.\n     */\n    name: string;\n    /**\n     * The path at which to create the service, relative to the workspace root.\n     */\n    path?: string;\n    /**\n     * The name of the project.\n     */\n    project: string;\n    /**\n     * Do not create \"spec.ts\" test files for the new service.\n     */\n    skipTests?: boolean;\n}\n\n/**\n * Creates a new, generic web worker definition in the given project.\n */\nexport interface AngularWebWorkerOptionsSchema {\n    /**\n     * The name of the worker.\n     */\n    name: string;\n    /**\n     * The path at which to create the worker file, relative to the current workspace.\n     */\n    path?: string;\n    /**\n     * The name of the project.\n     */\n    project: string;\n    /**\n     * Add a worker creation snippet in a sibling file of the same name.\n     */\n    snippet?: boolean;\n}\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@angular/cli",
3
- "version": "15.2.0-next.0",
3
+ "version": "15.2.0-next.2",
4
4
  "description": "CLI tool for Angular",
5
5
  "main": "lib/cli/index.js",
6
6
  "bin": {
@@ -25,10 +25,10 @@
25
25
  },
26
26
  "homepage": "https://github.com/angular/angular-cli",
27
27
  "dependencies": {
28
- "@angular-devkit/architect": "0.1502.0-next.0",
29
- "@angular-devkit/core": "15.2.0-next.0",
30
- "@angular-devkit/schematics": "15.2.0-next.0",
31
- "@schematics/angular": "15.2.0-next.0",
28
+ "@angular-devkit/architect": "0.1502.0-next.2",
29
+ "@angular-devkit/core": "15.2.0-next.2",
30
+ "@angular-devkit/schematics": "15.2.0-next.2",
31
+ "@schematics/angular": "15.2.0-next.2",
32
32
  "@yarnpkg/lockfile": "1.1.0",
33
33
  "ansi-colors": "4.1.3",
34
34
  "ini": "3.0.1",
@@ -47,12 +47,12 @@
47
47
  "ng-update": {
48
48
  "migrations": "@schematics/angular/migrations/migration-collection.json",
49
49
  "packageGroup": {
50
- "@angular/cli": "15.2.0-next.0",
51
- "@angular-devkit/architect": "0.1502.0-next.0",
52
- "@angular-devkit/build-angular": "15.2.0-next.0",
53
- "@angular-devkit/build-webpack": "0.1502.0-next.0",
54
- "@angular-devkit/core": "15.2.0-next.0",
55
- "@angular-devkit/schematics": "15.2.0-next.0"
50
+ "@angular/cli": "15.2.0-next.2",
51
+ "@angular-devkit/architect": "0.1502.0-next.2",
52
+ "@angular-devkit/build-angular": "15.2.0-next.2",
53
+ "@angular-devkit/build-webpack": "0.1502.0-next.2",
54
+ "@angular-devkit/core": "15.2.0-next.2",
55
+ "@angular-devkit/schematics": "15.2.0-next.2"
56
56
  }
57
57
  },
58
58
  "engines": {
@@ -35,6 +35,7 @@ const crypto_1 = require("crypto");
35
35
  const https = __importStar(require("https"));
36
36
  const os = __importStar(require("os"));
37
37
  const querystring = __importStar(require("querystring"));
38
+ const semver = __importStar(require("semver"));
38
39
  const environment_options_1 = require("../utilities/environment-options");
39
40
  const error_1 = require("../utilities/error");
40
41
  const version_1 = require("../utilities/version");
@@ -60,8 +61,7 @@ class AnalyticsCollector {
60
61
  [analytics_parameters_1.RequestParameter.DebugView]: environment_options_1.ngDebug ? 1 : undefined,
61
62
  };
62
63
  this.requestParameterStringified = querystring.stringify(requestParameters);
63
- // Remove the `v` at the beginning.
64
- const nodeVersion = process.version.substring(1);
64
+ const parsedVersion = semver.parse(process.version);
65
65
  const packageManagerVersion = context.packageManager.version;
66
66
  this.userParameters = {
67
67
  // While architecture is being collect by GA as UserAgentArchitecture.
@@ -69,8 +69,10 @@ class AnalyticsCollector {
69
69
  [analytics_parameters_1.UserCustomDimension.OsArchitecture]: os.arch(),
70
70
  // While User ID is being collected by GA, this is not visible in reports/for filtering.
71
71
  [analytics_parameters_1.UserCustomDimension.UserId]: userId,
72
- [analytics_parameters_1.UserCustomDimension.NodeVersion]: nodeVersion,
73
- [analytics_parameters_1.UserCustomDimension.NodeMajorVersion]: +nodeVersion.split('.', 1)[0],
72
+ [analytics_parameters_1.UserCustomDimension.NodeVersion]: parsedVersion
73
+ ? `${parsedVersion.major}.${parsedVersion.minor}.${parsedVersion.patch}`
74
+ : 'other',
75
+ [analytics_parameters_1.UserCustomDimension.NodeMajorVersion]: parsedVersion === null || parsedVersion === void 0 ? void 0 : parsedVersion.major,
74
76
  [analytics_parameters_1.UserCustomDimension.PackageManager]: context.packageManager.name,
75
77
  [analytics_parameters_1.UserCustomDimension.PackageManagerVersion]: packageManagerVersion,
76
78
  [analytics_parameters_1.UserCustomDimension.PackageManagerMajorVersion]: packageManagerVersion
@@ -146,10 +148,6 @@ class AnalyticsCollector {
146
148
  }
147
149
  }
148
150
  async send(data) {
149
- // Temporarily disable sending analytics.
150
- if (true) {
151
- return Promise.resolve();
152
- }
153
151
  return new Promise((resolve, reject) => {
154
152
  const request = https.request({
155
153
  host: 'www.google-analytics.com',
@@ -171,4 +169,4 @@ class AnalyticsCollector {
171
169
  }
172
170
  }
173
171
  exports.AnalyticsCollector = AnalyticsCollector;
174
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"analytics-collector.js","sourceRoot":"","sources":["../../../../../../../../packages/angular/cli/src/analytics/analytics-collector.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 { randomUUID } from 'crypto';\nimport * as https from 'https';\nimport * as os from 'os';\nimport * as querystring from 'querystring';\nimport type { CommandContext } from '../command-builder/command-module';\nimport { ngDebug } from '../utilities/environment-options';\nimport { assertIsError } from '../utilities/error';\nimport { VERSION } from '../utilities/version';\nimport {\n  EventCustomDimension,\n  EventCustomMetric,\n  PrimitiveTypes,\n  RequestParameter,\n  UserCustomDimension,\n} from './analytics-parameters';\n\nconst TRACKING_ID_PROD = 'G-VETNJBW8L4';\nconst TRACKING_ID_STAGING = 'G-TBMPRL1BTM';\n\nexport class AnalyticsCollector {\n  private trackingEventsQueue: Record<string, PrimitiveTypes | undefined>[] | undefined;\n  private readonly requestParameterStringified: string;\n  private readonly userParameters: Record<UserCustomDimension, PrimitiveTypes | undefined>;\n\n  constructor(private context: CommandContext, userId: string) {\n    const requestParameters: Partial<Record<RequestParameter, PrimitiveTypes>> = {\n      [RequestParameter.ProtocolVersion]: 2,\n      [RequestParameter.ClientId]: userId,\n      [RequestParameter.UserId]: userId,\n      [RequestParameter.TrackingId]:\n        /^\\d+\\.\\d+\\.\\d+$/.test(VERSION.full) && VERSION.full !== '0.0.0'\n          ? TRACKING_ID_PROD\n          : TRACKING_ID_STAGING,\n\n      // Built-in user properties\n      [RequestParameter.SessionId]: randomUUID(),\n      [RequestParameter.UserAgentArchitecture]: os.arch(),\n      [RequestParameter.UserAgentPlatform]: os.platform(),\n      [RequestParameter.UserAgentPlatformVersion]: os.version(),\n\n      // Set undefined to disable debug view.\n      [RequestParameter.DebugView]: ngDebug ? 1 : undefined,\n    };\n\n    this.requestParameterStringified = querystring.stringify(requestParameters);\n\n    // Remove the `v` at the beginning.\n    const nodeVersion = process.version.substring(1);\n    const packageManagerVersion = context.packageManager.version;\n\n    this.userParameters = {\n      // While architecture is being collect by GA as UserAgentArchitecture.\n      // It doesn't look like there is a way to query this. Therefore we collect this as a custom user dimension too.\n      [UserCustomDimension.OsArchitecture]: os.arch(),\n      // While User ID is being collected by GA, this is not visible in reports/for filtering.\n      [UserCustomDimension.UserId]: userId,\n      [UserCustomDimension.NodeVersion]: nodeVersion,\n      [UserCustomDimension.NodeMajorVersion]: +nodeVersion.split('.', 1)[0],\n      [UserCustomDimension.PackageManager]: context.packageManager.name,\n      [UserCustomDimension.PackageManagerVersion]: packageManagerVersion,\n      [UserCustomDimension.PackageManagerMajorVersion]: packageManagerVersion\n        ? +packageManagerVersion.split('.', 1)[0]\n        : undefined,\n      [UserCustomDimension.AngularCLIVersion]: VERSION.full,\n      [UserCustomDimension.AngularCLIMajorVersion]: VERSION.major,\n    };\n  }\n\n  reportWorkspaceInfoEvent(\n    parameters: Partial<Record<EventCustomMetric, string | boolean | number | undefined>>,\n  ): void {\n    this.event('workspace_info', parameters);\n  }\n\n  reportRebuildRunEvent(\n    parameters: Partial<\n      Record<EventCustomMetric & EventCustomDimension, string | boolean | number | undefined>\n    >,\n  ): void {\n    this.event('run_rebuild', parameters);\n  }\n\n  reportBuildRunEvent(\n    parameters: Partial<\n      Record<EventCustomMetric & EventCustomDimension, string | boolean | number | undefined>\n    >,\n  ): void {\n    this.event('run_build', parameters);\n  }\n\n  reportArchitectRunEvent(parameters: Partial<Record<EventCustomDimension, PrimitiveTypes>>): void {\n    this.event('run_architect', parameters);\n  }\n\n  reportSchematicRunEvent(parameters: Partial<Record<EventCustomDimension, PrimitiveTypes>>): void {\n    this.event('run_schematic', parameters);\n  }\n\n  reportCommandRunEvent(command: string): void {\n    this.event('run_command', { [EventCustomDimension.Command]: command });\n  }\n\n  private event(eventName: string, parameters?: Record<string, PrimitiveTypes>): void {\n    this.trackingEventsQueue ??= [];\n    this.trackingEventsQueue.push({\n      ...this.userParameters,\n      ...parameters,\n      'en': eventName,\n    });\n  }\n\n  /**\n   * Flush on an interval (if the event loop is waiting).\n   *\n   * @returns a method that when called will terminate the periodic\n   * flush and call flush one last time.\n   */\n  periodFlush(): () => Promise<void> {\n    let analyticsFlushPromise = Promise.resolve();\n    const analyticsFlushInterval = setInterval(() => {\n      if (this.trackingEventsQueue?.length) {\n        analyticsFlushPromise = analyticsFlushPromise.then(() => this.flush());\n      }\n    }, 4000);\n\n    return () => {\n      clearInterval(analyticsFlushInterval);\n\n      // Flush one last time.\n      return analyticsFlushPromise.then(() => this.flush());\n    };\n  }\n\n  async flush(): Promise<void> {\n    const pendingTrackingEvents = this.trackingEventsQueue;\n    this.context.logger.debug(`Analytics flush size. ${pendingTrackingEvents?.length}.`);\n\n    if (!pendingTrackingEvents?.length) {\n      return;\n    }\n\n    // The below is needed so that if flush is called multiple times,\n    // we don't report the same event multiple times.\n    this.trackingEventsQueue = undefined;\n\n    try {\n      await this.send(pendingTrackingEvents);\n    } catch (error) {\n      // Failure to report analytics shouldn't crash the CLI.\n      assertIsError(error);\n      this.context.logger.debug(`Send analytics error. ${error.message}.`);\n    }\n  }\n\n  private async send(data: Record<string, PrimitiveTypes | undefined>[]): Promise<void> {\n    // Temporarily disable sending analytics.\n    if (true as boolean) {\n      return Promise.resolve();\n    }\n\n    return new Promise<void>((resolve, reject) => {\n      const request = https.request(\n        {\n          host: 'www.google-analytics.com',\n          method: 'POST',\n          path: '/g/collect?' + this.requestParameterStringified,\n        },\n        (response) => {\n          if (response.statusCode !== 200 && response.statusCode !== 204) {\n            reject(\n              new Error(`Analytics reporting failed with status code: ${response.statusCode}.`),\n            );\n          } else {\n            resolve();\n          }\n        },\n      );\n\n      request.on('error', reject);\n      const queryParameters = data.map((p) => querystring.stringify(p)).join('\\n');\n      request.write(queryParameters);\n      request.end();\n    });\n  }\n}\n"]}
172
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"analytics-collector.js","sourceRoot":"","sources":["../../../../../../../../packages/angular/cli/src/analytics/analytics-collector.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 { randomUUID } from 'crypto';\nimport * as https from 'https';\nimport * as os from 'os';\nimport * as querystring from 'querystring';\nimport * as semver from 'semver';\nimport type { CommandContext } from '../command-builder/command-module';\nimport { ngDebug } from '../utilities/environment-options';\nimport { assertIsError } from '../utilities/error';\nimport { VERSION } from '../utilities/version';\nimport {\n  EventCustomDimension,\n  EventCustomMetric,\n  PrimitiveTypes,\n  RequestParameter,\n  UserCustomDimension,\n} from './analytics-parameters';\n\nconst TRACKING_ID_PROD = 'G-VETNJBW8L4';\nconst TRACKING_ID_STAGING = 'G-TBMPRL1BTM';\n\nexport class AnalyticsCollector {\n  private trackingEventsQueue: Record<string, PrimitiveTypes | undefined>[] | undefined;\n  private readonly requestParameterStringified: string;\n  private readonly userParameters: Record<UserCustomDimension, PrimitiveTypes | undefined>;\n\n  constructor(private context: CommandContext, userId: string) {\n    const requestParameters: Partial<Record<RequestParameter, PrimitiveTypes>> = {\n      [RequestParameter.ProtocolVersion]: 2,\n      [RequestParameter.ClientId]: userId,\n      [RequestParameter.UserId]: userId,\n      [RequestParameter.TrackingId]:\n        /^\\d+\\.\\d+\\.\\d+$/.test(VERSION.full) && VERSION.full !== '0.0.0'\n          ? TRACKING_ID_PROD\n          : TRACKING_ID_STAGING,\n\n      // Built-in user properties\n      [RequestParameter.SessionId]: randomUUID(),\n      [RequestParameter.UserAgentArchitecture]: os.arch(),\n      [RequestParameter.UserAgentPlatform]: os.platform(),\n      [RequestParameter.UserAgentPlatformVersion]: os.version(),\n\n      // Set undefined to disable debug view.\n      [RequestParameter.DebugView]: ngDebug ? 1 : undefined,\n    };\n\n    this.requestParameterStringified = querystring.stringify(requestParameters);\n\n    const parsedVersion = semver.parse(process.version);\n    const packageManagerVersion = context.packageManager.version;\n\n    this.userParameters = {\n      // While architecture is being collect by GA as UserAgentArchitecture.\n      // It doesn't look like there is a way to query this. Therefore we collect this as a custom user dimension too.\n      [UserCustomDimension.OsArchitecture]: os.arch(),\n      // While User ID is being collected by GA, this is not visible in reports/for filtering.\n      [UserCustomDimension.UserId]: userId,\n      [UserCustomDimension.NodeVersion]: parsedVersion\n        ? `${parsedVersion.major}.${parsedVersion.minor}.${parsedVersion.patch}`\n        : 'other',\n      [UserCustomDimension.NodeMajorVersion]: parsedVersion?.major,\n      [UserCustomDimension.PackageManager]: context.packageManager.name,\n      [UserCustomDimension.PackageManagerVersion]: packageManagerVersion,\n      [UserCustomDimension.PackageManagerMajorVersion]: packageManagerVersion\n        ? +packageManagerVersion.split('.', 1)[0]\n        : undefined,\n      [UserCustomDimension.AngularCLIVersion]: VERSION.full,\n      [UserCustomDimension.AngularCLIMajorVersion]: VERSION.major,\n    };\n  }\n\n  reportWorkspaceInfoEvent(\n    parameters: Partial<Record<EventCustomMetric, string | boolean | number | undefined>>,\n  ): void {\n    this.event('workspace_info', parameters);\n  }\n\n  reportRebuildRunEvent(\n    parameters: Partial<\n      Record<EventCustomMetric & EventCustomDimension, string | boolean | number | undefined>\n    >,\n  ): void {\n    this.event('run_rebuild', parameters);\n  }\n\n  reportBuildRunEvent(\n    parameters: Partial<\n      Record<EventCustomMetric & EventCustomDimension, string | boolean | number | undefined>\n    >,\n  ): void {\n    this.event('run_build', parameters);\n  }\n\n  reportArchitectRunEvent(parameters: Partial<Record<EventCustomDimension, PrimitiveTypes>>): void {\n    this.event('run_architect', parameters);\n  }\n\n  reportSchematicRunEvent(parameters: Partial<Record<EventCustomDimension, PrimitiveTypes>>): void {\n    this.event('run_schematic', parameters);\n  }\n\n  reportCommandRunEvent(command: string): void {\n    this.event('run_command', { [EventCustomDimension.Command]: command });\n  }\n\n  private event(eventName: string, parameters?: Record<string, PrimitiveTypes>): void {\n    this.trackingEventsQueue ??= [];\n    this.trackingEventsQueue.push({\n      ...this.userParameters,\n      ...parameters,\n      'en': eventName,\n    });\n  }\n\n  /**\n   * Flush on an interval (if the event loop is waiting).\n   *\n   * @returns a method that when called will terminate the periodic\n   * flush and call flush one last time.\n   */\n  periodFlush(): () => Promise<void> {\n    let analyticsFlushPromise = Promise.resolve();\n    const analyticsFlushInterval = setInterval(() => {\n      if (this.trackingEventsQueue?.length) {\n        analyticsFlushPromise = analyticsFlushPromise.then(() => this.flush());\n      }\n    }, 4000);\n\n    return () => {\n      clearInterval(analyticsFlushInterval);\n\n      // Flush one last time.\n      return analyticsFlushPromise.then(() => this.flush());\n    };\n  }\n\n  async flush(): Promise<void> {\n    const pendingTrackingEvents = this.trackingEventsQueue;\n    this.context.logger.debug(`Analytics flush size. ${pendingTrackingEvents?.length}.`);\n\n    if (!pendingTrackingEvents?.length) {\n      return;\n    }\n\n    // The below is needed so that if flush is called multiple times,\n    // we don't report the same event multiple times.\n    this.trackingEventsQueue = undefined;\n\n    try {\n      await this.send(pendingTrackingEvents);\n    } catch (error) {\n      // Failure to report analytics shouldn't crash the CLI.\n      assertIsError(error);\n      this.context.logger.debug(`Send analytics error. ${error.message}.`);\n    }\n  }\n\n  private async send(data: Record<string, PrimitiveTypes | undefined>[]): Promise<void> {\n    return new Promise<void>((resolve, reject) => {\n      const request = https.request(\n        {\n          host: 'www.google-analytics.com',\n          method: 'POST',\n          path: '/g/collect?' + this.requestParameterStringified,\n        },\n        (response) => {\n          if (response.statusCode !== 200 && response.statusCode !== 204) {\n            reject(\n              new Error(`Analytics reporting failed with status code: ${response.statusCode}.`),\n            );\n          } else {\n            resolve();\n          }\n        },\n      );\n\n      request.on('error', reject);\n      const queryParameters = data.map((p) => querystring.stringify(p)).join('\\n');\n      request.write(queryParameters);\n      request.end();\n    });\n  }\n}\n"]}
@@ -19,6 +19,13 @@ export declare class GenerateCommandModule extends SchematicsCommandModule imple
19
19
  builder(argv: Argv): Promise<Argv<GenerateCommandArgs>>;
20
20
  run(options: Options<GenerateCommandArgs> & OtherOptions): Promise<number | void>;
21
21
  private getCollectionNames;
22
+ private shouldAddCollectionNameAsPartOfCommand;
23
+ /**
24
+ * Generate an aliases string array to be passed to the command builder.
25
+ *
26
+ * @example `[component]` or `[@schematics/angular:component]`.
27
+ */
28
+ private generateCommandAliasesStrings;
22
29
  /**
23
30
  * Generate a command string to be passed to the command builder.
24
31
  *
@@ -29,6 +36,7 @@ export declare class GenerateCommandModule extends SchematicsCommandModule imple
29
36
  * Get schematics that can to be registered as subcommands.
30
37
  */
31
38
  private getSchematics;
39
+ private listSchematicAliases;
32
40
  /**
33
41
  * Get schematics that should to be registered as subcommands.
34
42
  *
@@ -39,16 +39,21 @@ class GenerateCommandModule extends schematics_command_module_1.SchematicsComman
39
39
  if (!schemaJson) {
40
40
  continue;
41
41
  }
42
- const { 'x-deprecated': xDeprecated, description = schematicDescription, aliases = schematicAliases, hidden = schematicHidden, } = schemaJson;
42
+ const { 'x-deprecated': xDeprecated, description = schematicDescription, hidden = schematicHidden, } = schemaJson;
43
43
  const options = await this.getSchematicOptions(collection, schematicName, workflow);
44
44
  localYargs = localYargs.command({
45
45
  command: await this.generateCommandString(collectionName, schematicName, options),
46
46
  // When 'describe' is set to false, it results in a hidden command.
47
47
  describe: hidden === true ? false : typeof description === 'string' ? description : '',
48
48
  deprecated: xDeprecated === true || typeof xDeprecated === 'string' ? xDeprecated : false,
49
- aliases: Array.isArray(aliases) ? aliases : undefined,
49
+ aliases: Array.isArray(schematicAliases)
50
+ ? await this.generateCommandAliasesStrings(collectionName, schematicAliases)
51
+ : undefined,
50
52
  builder: (localYargs) => this.addSchemaOptionsToCommand(localYargs, options).strict(),
51
- handler: (options) => this.handler({ ...options, schematic: `${collectionName}:${schematicName}` }),
53
+ handler: (options) => this.handler({
54
+ ...options,
55
+ schematic: `${collectionName}:${schematicName}`,
56
+ }),
52
57
  });
53
58
  }
54
59
  return localYargs.demandCommand(1, command_1.demandCommandFailureMessage);
@@ -77,23 +82,42 @@ class GenerateCommandModule extends schematics_command_module_1.SchematicsComman
77
82
  this.context.args.positional[1]);
78
83
  return collectionName ? [collectionName] : [...(await this.getSchematicCollections())];
79
84
  }
85
+ async shouldAddCollectionNameAsPartOfCommand() {
86
+ const [collectionNameFromArgs] = this.parseSchematicInfo(
87
+ // positional = [generate, component] or [generate]
88
+ this.context.args.positional[1]);
89
+ const schematicCollectionsFromConfig = await this.getSchematicCollections();
90
+ const collectionNames = await this.getCollectionNames();
91
+ // Only add the collection name as part of the command when it's not a known
92
+ // schematics collection or when it has been provided via the CLI.
93
+ // Ex:`ng generate @schematics/angular:c`
94
+ return (!!collectionNameFromArgs ||
95
+ !collectionNames.some((c) => schematicCollectionsFromConfig.has(c)));
96
+ }
97
+ /**
98
+ * Generate an aliases string array to be passed to the command builder.
99
+ *
100
+ * @example `[component]` or `[@schematics/angular:component]`.
101
+ */
102
+ async generateCommandAliasesStrings(collectionName, schematicAliases) {
103
+ // Only add the collection name as part of the command when it's not a known
104
+ // schematics collection or when it has been provided via the CLI.
105
+ // Ex:`ng generate @schematics/angular:c`
106
+ return (await this.shouldAddCollectionNameAsPartOfCommand())
107
+ ? schematicAliases.map((alias) => `${collectionName}:${alias}`)
108
+ : schematicAliases;
109
+ }
80
110
  /**
81
111
  * Generate a command string to be passed to the command builder.
82
112
  *
83
113
  * @example `component [name]` or `@schematics/angular:component [name]`.
84
114
  */
85
115
  async generateCommandString(collectionName, schematicName, options) {
86
- const [collectionNameFromArgs] = this.parseSchematicInfo(
87
- // positional = [generate, component] or [generate]
88
- this.context.args.positional[1]);
89
116
  const dasherizedSchematicName = core_1.strings.dasherize(schematicName);
90
- const schematicCollectionsFromConfig = await this.getSchematicCollections();
91
- const collectionNames = await this.getCollectionNames();
92
117
  // Only add the collection name as part of the command when it's not a known
93
118
  // schematics collection or when it has been provided via the CLI.
94
119
  // Ex:`ng generate @schematics/angular:component`
95
- const commandName = !!collectionNameFromArgs ||
96
- !collectionNames.some((c) => schematicCollectionsFromConfig.has(c))
120
+ const commandName = (await this.shouldAddCollectionNameAsPartOfCommand())
97
121
  ? collectionName + ':' + dasherizedSchematicName
98
122
  : dasherizedSchematicName;
99
123
  const positionalArgs = options
@@ -117,10 +141,30 @@ class GenerateCommandModule extends schematics_command_module_1.SchematicsComman
117
141
  // If a schematic with this same name is already registered skip.
118
142
  if (!seenNames.has(schematicName)) {
119
143
  seenNames.add(schematicName);
120
- yield { schematicName, collectionName };
144
+ yield {
145
+ schematicName,
146
+ collectionName,
147
+ schematicAliases: this.listSchematicAliases(collection, schematicName),
148
+ };
149
+ }
150
+ }
151
+ }
152
+ }
153
+ listSchematicAliases(collection, schematicName) {
154
+ const description = collection.description.schematics[schematicName];
155
+ if (description) {
156
+ return description.aliases && new Set(description.aliases);
157
+ }
158
+ // Extended collections
159
+ if (collection.baseDescriptions) {
160
+ for (const base of collection.baseDescriptions) {
161
+ const description = base.schematics[schematicName];
162
+ if (description) {
163
+ return description.aliases && new Set(description.aliases);
121
164
  }
122
165
  }
123
166
  }
167
+ return undefined;
124
168
  }
125
169
  /**
126
170
  * Get schematics that should to be registered as subcommands.
@@ -132,8 +176,9 @@ class GenerateCommandModule extends schematics_command_module_1.SchematicsComman
132
176
  const [, schematicNameFromArgs] = this.parseSchematicInfo(
133
177
  // positional = [generate, component] or [generate]
134
178
  this.context.args.positional[1]);
135
- for await (const { schematicName, collectionName } of this.getSchematics()) {
136
- if (schematicName === schematicNameFromArgs) {
179
+ for await (const { schematicName, collectionName, schematicAliases } of this.getSchematics()) {
180
+ if (schematicNameFromArgs &&
181
+ (schematicName === schematicNameFromArgs || (schematicAliases === null || schematicAliases === void 0 ? void 0 : schematicAliases.has(schematicNameFromArgs)))) {
137
182
  return [[schematicName, collectionName]];
138
183
  }
139
184
  schematicsToRegister.push([schematicName, collectionName]);
@@ -143,4 +188,4 @@ class GenerateCommandModule extends schematics_command_module_1.SchematicsComman
143
188
  }
144
189
  }
145
190
  exports.GenerateCommandModule = GenerateCommandModule;
146
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cli.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular/cli/src/commands/generate/cli.ts"],"names":[],"mappings":";AAAA;;;;;;GAMG;;;AAEH,+CAA+C;AAE/C,yEAK8C;AAC9C,+FAGyD;AACzD,qEAAsF;AAOtF,MAAa,qBACX,SAAQ,mDAAuB;IADjC;;QAIE,YAAO,GAAG,UAAU,CAAC;QACrB,YAAO,GAAG,GAAG,CAAC;QACd,aAAQ,GAAG,uDAAuD,CAAC;IAkLrE,CAAC;IA/KU,KAAK,CAAC,OAAO,CAAC,IAAU;QAC/B,IAAI,UAAU,GAAG,CAAC,MAAM,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO,CAAsB;YACxE,OAAO,EAAE,gBAAgB;YACzB,QAAQ,EAAE,6BAA6B;YACvC,OAAO,EAAE,CAAC,UAAU,EAAE,EAAE,CACtB,UAAU;iBACP,UAAU,CAAC,WAAW,EAAE;gBACvB,QAAQ,EAAE,oCAAoC;gBAC9C,IAAI,EAAE,QAAQ;gBACd,YAAY,EAAE,IAAI;aACnB,CAAC;iBACD,MAAM,EAAE;YACb,OAAO,EAAE,CAAC,OAAO,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC;SAC5C,CAAC,CAAC;QAEH,KAAK,MAAM,CAAC,aAAa,EAAE,cAAc,CAAC,IAAI,MAAM,IAAI,CAAC,uBAAuB,EAAE,EAAE;YAClF,MAAM,QAAQ,GAAG,IAAI,CAAC,6BAA6B,CAAC,cAAc,CAAC,CAAC;YACpE,MAAM,UAAU,GAAG,QAAQ,CAAC,MAAM,CAAC,gBAAgB,CAAC,cAAc,CAAC,CAAC;YAEpE,MAAM,EACJ,WAAW,EAAE,EACX,UAAU,EACV,OAAO,EAAE,gBAAgB,EACzB,MAAM,EAAE,eAAe,EACvB,WAAW,EAAE,oBAAoB,GAClC,GACF,GAAG,UAAU,CAAC,eAAe,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC;YAEpD,IAAI,CAAC,UAAU,EAAE;gBACf,SAAS;aACV;YAED,MAAM,EACJ,cAAc,EAAE,WAAW,EAC3B,WAAW,GAAG,oBAAoB,EAClC,OAAO,GAAG,gBAAgB,EAC1B,MAAM,GAAG,eAAe,GACzB,GAAG,UAAU,CAAC;YACf,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,mBAAmB,CAAC,UAAU,EAAE,aAAa,EAAE,QAAQ,CAAC,CAAC;YAEpF,UAAU,GAAG,UAAU,CAAC,OAAO,CAAC;gBAC9B,OAAO,EAAE,MAAM,IAAI,CAAC,qBAAqB,CAAC,cAAc,EAAE,aAAa,EAAE,OAAO,CAAC;gBACjF,mEAAmE;gBACnE,QAAQ,EAAE,MAAM,KAAK,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,WAAW,KAAK,QAAQ,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE;gBACtF,UAAU,EAAE,WAAW,KAAK,IAAI,IAAI,OAAO,WAAW,KAAK,QAAQ,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,KAAK;gBACzF,OAAO,EAAE,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,CAAE,OAAoB,CAAC,CAAC,CAAC,SAAS;gBACnE,OAAO,EAAE,CAAC,UAAU,EAAE,EAAE,CAAC,IAAI,CAAC,yBAAyB,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC,MAAM,EAAE;gBACrF,OAAO,EAAE,CAAC,OAAO,EAAE,EAAE,CACnB,IAAI,CAAC,OAAO,CAAC,EAAE,GAAG,OAAO,EAAE,SAAS,EAAE,GAAG,cAAc,IAAI,aAAa,EAAE,EAAE,CAAC;aAChF,CAAC,CAAC;SACJ;QAED,OAAO,UAAU,CAAC,aAAa,CAAC,CAAC,EAAE,qCAA2B,CAAC,CAAC;IAClE,CAAC;IAED,KAAK,CAAC,GAAG,CAAC,OAAoD;QAC5D,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,QAAQ,EAAE,KAAK,EAAE,WAAW,EAAE,GAAG,gBAAgB,EAAE,GAAG,OAAO,CAAC;QAEzF,MAAM,CAAC,cAAc,EAAE,aAAa,CAAC,GAAG,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC;QAE3E,IAAI,CAAC,cAAc,IAAI,CAAC,aAAa,EAAE;YACrC,MAAM,IAAI,mCAAkB,CAAC,0DAA0D,CAAC,CAAC;SAC1F;QAED,OAAO,IAAI,CAAC,YAAY,CAAC;YACvB,cAAc;YACd,aAAa;YACb,gBAAgB;YAChB,gBAAgB,EAAE;gBAChB,MAAM;gBACN,QAAQ;gBACR,KAAK;gBACL,WAAW;aACZ;SACF,CAAC,CAAC;IACL,CAAC;IAEO,KAAK,CAAC,kBAAkB;QAC9B,MAAM,CAAC,cAAc,CAAC,GAAG,IAAI,CAAC,kBAAkB;QAC9C,mDAAmD;QACnD,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAChC,CAAC;QAEF,OAAO,cAAc,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,IAAI,CAAC,uBAAuB,EAAE,CAAC,CAAC,CAAC;IACzF,CAAC;IAED;;;;OAIG;IACK,KAAK,CAAC,qBAAqB,CACjC,cAAsB,EACtB,aAAqB,EACrB,OAAiB;QAEjB,MAAM,CAAC,sBAAsB,CAAC,GAAG,IAAI,CAAC,kBAAkB;QACtD,mDAAmD;QACnD,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAChC,CAAC;QAEF,MAAM,uBAAuB,GAAG,cAAO,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;QACjE,MAAM,8BAA8B,GAAG,MAAM,IAAI,CAAC,uBAAuB,EAAE,CAAC;QAC5E,MAAM,eAAe,GAAG,MAAM,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAExD,4EAA4E;QAC5E,kEAAkE;QAClE,iDAAiD;QACjD,MAAM,WAAW,GACf,CAAC,CAAC,sBAAsB;YACxB,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,8BAA8B,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YACjE,CAAC,CAAC,cAAc,GAAG,GAAG,GAAG,uBAAuB;YAChD,CAAC,CAAC,uBAAuB,CAAC;QAE9B,MAAM,cAAc,GAAG,OAAO;aAC3B,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,KAAK,SAAS,CAAC;aACzC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;YACT,MAAM,KAAK,GAAG,GAAG,cAAO,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC;YAE/E,OAAO,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,KAAK,GAAG,CAAC,CAAC,CAAC,IAAI,KAAK,GAAG,CAAC;QAClD,CAAC,CAAC;aACD,IAAI,CAAC,GAAG,CAAC,CAAC;QAEb,OAAO,GAAG,WAAW,GAAG,cAAc,CAAC,CAAC,CAAC,GAAG,GAAG,cAAc,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC;IACvE,CAAC;IAED;;OAEG;IACK,KAAK,CAAC,CAAC,aAAa;QAI1B,MAAM,SAAS,GAAG,IAAI,GAAG,EAAU,CAAC;QACpC,KAAK,MAAM,cAAc,IAAI,MAAM,IAAI,CAAC,kBAAkB,EAAE,EAAE;YAC5D,MAAM,QAAQ,GAAG,IAAI,CAAC,6BAA6B,CAAC,cAAc,CAAC,CAAC;YACpE,MAAM,UAAU,GAAG,QAAQ,CAAC,MAAM,CAAC,gBAAgB,CAAC,cAAc,CAAC,CAAC;YAEpE,KAAK,MAAM,aAAa,IAAI,UAAU,CAAC,kBAAkB,CAAC,IAAI,CAAC,oBAAoB,CAAC,EAAE;gBACpF,iEAAiE;gBACjE,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,aAAa,CAAC,EAAE;oBACjC,SAAS,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;oBAC7B,MAAM,EAAE,aAAa,EAAE,cAAc,EAAE,CAAC;iBACzC;aACF;SACF;IACH,CAAC;IAED;;;;OAIG;IACK,KAAK,CAAC,uBAAuB;QAGnC,MAAM,oBAAoB,GAAsD,EAAE,CAAC;QACnF,MAAM,CAAC,EAAE,qBAAqB,CAAC,GAAG,IAAI,CAAC,kBAAkB;QACvD,mDAAmD;QACnD,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAChC,CAAC;QAEF,IAAI,KAAK,EAAE,MAAM,EAAE,aAAa,EAAE,cAAc,EAAE,IAAI,IAAI,CAAC,aAAa,EAAE,EAAE;YAC1E,IAAI,aAAa,KAAK,qBAAqB,EAAE;gBAC3C,OAAO,CAAC,CAAC,aAAa,EAAE,cAAc,CAAC,CAAC,CAAC;aAC1C;YAED,oBAAoB,CAAC,IAAI,CAAC,CAAC,aAAa,EAAE,cAAc,CAAC,CAAC,CAAC;SAC5D;QAED,wFAAwF;QACxF,OAAO,oBAAoB,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,EAAE,CACpD,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE,SAAS,EAAE,EAAE,WAAW,EAAE,QAAQ,EAAE,CAAC,CACjE,CAAC;IACJ,CAAC;CACF;AAxLD,sDAwLC","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 { strings } from '@angular-devkit/core';\nimport { Argv } from 'yargs';\nimport {\n  CommandModuleError,\n  CommandModuleImplementation,\n  Options,\n  OtherOptions,\n} from '../../command-builder/command-module';\nimport {\n  SchematicsCommandArgs,\n  SchematicsCommandModule,\n} from '../../command-builder/schematics-command-module';\nimport { demandCommandFailureMessage } from '../../command-builder/utilities/command';\nimport { Option } from '../../command-builder/utilities/json-schema';\n\ninterface GenerateCommandArgs extends SchematicsCommandArgs {\n  schematic?: string;\n}\n\nexport class GenerateCommandModule\n  extends SchematicsCommandModule\n  implements CommandModuleImplementation<GenerateCommandArgs>\n{\n  command = 'generate';\n  aliases = 'g';\n  describe = 'Generates and/or modifies files based on a schematic.';\n  longDescriptionPath?: string | undefined;\n\n  override async builder(argv: Argv): Promise<Argv<GenerateCommandArgs>> {\n    let localYargs = (await super.builder(argv)).command<GenerateCommandArgs>({\n      command: '$0 <schematic>',\n      describe: 'Run the provided schematic.',\n      builder: (localYargs) =>\n        localYargs\n          .positional('schematic', {\n            describe: 'The [collection:schematic] to run.',\n            type: 'string',\n            demandOption: true,\n          })\n          .strict(),\n      handler: (options) => this.handler(options),\n    });\n\n    for (const [schematicName, collectionName] of await this.getSchematicsToRegister()) {\n      const workflow = this.getOrCreateWorkflowForBuilder(collectionName);\n      const collection = workflow.engine.createCollection(collectionName);\n\n      const {\n        description: {\n          schemaJson,\n          aliases: schematicAliases,\n          hidden: schematicHidden,\n          description: schematicDescription,\n        },\n      } = collection.createSchematic(schematicName, true);\n\n      if (!schemaJson) {\n        continue;\n      }\n\n      const {\n        'x-deprecated': xDeprecated,\n        description = schematicDescription,\n        aliases = schematicAliases,\n        hidden = schematicHidden,\n      } = schemaJson;\n      const options = await this.getSchematicOptions(collection, schematicName, workflow);\n\n      localYargs = localYargs.command({\n        command: await this.generateCommandString(collectionName, schematicName, options),\n        // When 'describe' is set to false, it results in a hidden command.\n        describe: hidden === true ? false : typeof description === 'string' ? description : '',\n        deprecated: xDeprecated === true || typeof xDeprecated === 'string' ? xDeprecated : false,\n        aliases: Array.isArray(aliases) ? (aliases as string[]) : undefined,\n        builder: (localYargs) => this.addSchemaOptionsToCommand(localYargs, options).strict(),\n        handler: (options) =>\n          this.handler({ ...options, schematic: `${collectionName}:${schematicName}` }),\n      });\n    }\n\n    return localYargs.demandCommand(1, demandCommandFailureMessage);\n  }\n\n  async run(options: Options<GenerateCommandArgs> & OtherOptions): Promise<number | void> {\n    const { dryRun, schematic, defaults, force, interactive, ...schematicOptions } = options;\n\n    const [collectionName, schematicName] = this.parseSchematicInfo(schematic);\n\n    if (!collectionName || !schematicName) {\n      throw new CommandModuleError('A collection and schematic is required during execution.');\n    }\n\n    return this.runSchematic({\n      collectionName,\n      schematicName,\n      schematicOptions,\n      executionOptions: {\n        dryRun,\n        defaults,\n        force,\n        interactive,\n      },\n    });\n  }\n\n  private async getCollectionNames(): Promise<string[]> {\n    const [collectionName] = this.parseSchematicInfo(\n      // positional = [generate, component] or [generate]\n      this.context.args.positional[1],\n    );\n\n    return collectionName ? [collectionName] : [...(await this.getSchematicCollections())];\n  }\n\n  /**\n   * Generate a command string to be passed to the command builder.\n   *\n   * @example `component [name]` or `@schematics/angular:component [name]`.\n   */\n  private async generateCommandString(\n    collectionName: string,\n    schematicName: string,\n    options: Option[],\n  ): Promise<string> {\n    const [collectionNameFromArgs] = this.parseSchematicInfo(\n      // positional = [generate, component] or [generate]\n      this.context.args.positional[1],\n    );\n\n    const dasherizedSchematicName = strings.dasherize(schematicName);\n    const schematicCollectionsFromConfig = await this.getSchematicCollections();\n    const collectionNames = await this.getCollectionNames();\n\n    // Only add the collection name as part of the command when it's not a known\n    // schematics collection or when it has been provided via the CLI.\n    // Ex:`ng generate @schematics/angular:component`\n    const commandName =\n      !!collectionNameFromArgs ||\n      !collectionNames.some((c) => schematicCollectionsFromConfig.has(c))\n        ? collectionName + ':' + dasherizedSchematicName\n        : dasherizedSchematicName;\n\n    const positionalArgs = options\n      .filter((o) => o.positional !== undefined)\n      .map((o) => {\n        const label = `${strings.dasherize(o.name)}${o.type === 'array' ? ' ..' : ''}`;\n\n        return o.required ? `<${label}>` : `[${label}]`;\n      })\n      .join(' ');\n\n    return `${commandName}${positionalArgs ? ' ' + positionalArgs : ''}`;\n  }\n\n  /**\n   * Get schematics that can to be registered as subcommands.\n   */\n  private async *getSchematics(): AsyncGenerator<{\n    schematicName: string;\n    collectionName: string;\n  }> {\n    const seenNames = new Set<string>();\n    for (const collectionName of await this.getCollectionNames()) {\n      const workflow = this.getOrCreateWorkflowForBuilder(collectionName);\n      const collection = workflow.engine.createCollection(collectionName);\n\n      for (const schematicName of collection.listSchematicNames(true /** includeHidden */)) {\n        // If a schematic with this same name is already registered skip.\n        if (!seenNames.has(schematicName)) {\n          seenNames.add(schematicName);\n          yield { schematicName, collectionName };\n        }\n      }\n    }\n  }\n\n  /**\n   * Get schematics that should to be registered as subcommands.\n   *\n   * @returns a sorted list of schematic that needs to be registered as subcommands.\n   */\n  private async getSchematicsToRegister(): Promise<\n    [schematicName: string, collectionName: string][]\n  > {\n    const schematicsToRegister: [schematicName: string, collectionName: string][] = [];\n    const [, schematicNameFromArgs] = this.parseSchematicInfo(\n      // positional = [generate, component] or [generate]\n      this.context.args.positional[1],\n    );\n\n    for await (const { schematicName, collectionName } of this.getSchematics()) {\n      if (schematicName === schematicNameFromArgs) {\n        return [[schematicName, collectionName]];\n      }\n\n      schematicsToRegister.push([schematicName, collectionName]);\n    }\n\n    // Didn't find the schematic or no schematic name was provided Ex: `ng generate --help`.\n    return schematicsToRegister.sort(([nameA], [nameB]) =>\n      nameA.localeCompare(nameB, undefined, { sensitivity: 'accent' }),\n    );\n  }\n}\n"]}
191
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cli.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular/cli/src/commands/generate/cli.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 { strings } from '@angular-devkit/core';\nimport { Collection } from '@angular-devkit/schematics';\nimport {\n  FileSystemCollectionDescription,\n  FileSystemSchematicDescription,\n} from '@angular-devkit/schematics/tools';\nimport { ArgumentsCamelCase, Argv } from 'yargs';\nimport {\n  CommandModuleError,\n  CommandModuleImplementation,\n  Options,\n  OtherOptions,\n} from '../../command-builder/command-module';\nimport {\n  SchematicsCommandArgs,\n  SchematicsCommandModule,\n} from '../../command-builder/schematics-command-module';\nimport { demandCommandFailureMessage } from '../../command-builder/utilities/command';\nimport { Option } from '../../command-builder/utilities/json-schema';\n\ninterface GenerateCommandArgs extends SchematicsCommandArgs {\n  schematic?: string;\n}\n\nexport class GenerateCommandModule\n  extends SchematicsCommandModule\n  implements CommandModuleImplementation<GenerateCommandArgs>\n{\n  command = 'generate';\n  aliases = 'g';\n  describe = 'Generates and/or modifies files based on a schematic.';\n  longDescriptionPath?: string | undefined;\n\n  override async builder(argv: Argv): Promise<Argv<GenerateCommandArgs>> {\n    let localYargs = (await super.builder(argv)).command({\n      command: '$0 <schematic>',\n      describe: 'Run the provided schematic.',\n      builder: (localYargs) =>\n        localYargs\n          .positional('schematic', {\n            describe: 'The [collection:schematic] to run.',\n            type: 'string',\n            demandOption: true,\n          })\n          .strict(),\n      handler: (options) => this.handler(options as ArgumentsCamelCase<GenerateCommandArgs>),\n    });\n\n    for (const [schematicName, collectionName] of await this.getSchematicsToRegister()) {\n      const workflow = this.getOrCreateWorkflowForBuilder(collectionName);\n      const collection = workflow.engine.createCollection(collectionName);\n\n      const {\n        description: {\n          schemaJson,\n          aliases: schematicAliases,\n          hidden: schematicHidden,\n          description: schematicDescription,\n        },\n      } = collection.createSchematic(schematicName, true);\n\n      if (!schemaJson) {\n        continue;\n      }\n\n      const {\n        'x-deprecated': xDeprecated,\n        description = schematicDescription,\n        hidden = schematicHidden,\n      } = schemaJson;\n      const options = await this.getSchematicOptions(collection, schematicName, workflow);\n\n      localYargs = localYargs.command({\n        command: await this.generateCommandString(collectionName, schematicName, options),\n        // When 'describe' is set to false, it results in a hidden command.\n        describe: hidden === true ? false : typeof description === 'string' ? description : '',\n        deprecated: xDeprecated === true || typeof xDeprecated === 'string' ? xDeprecated : false,\n        aliases: Array.isArray(schematicAliases)\n          ? await this.generateCommandAliasesStrings(collectionName, schematicAliases)\n          : undefined,\n        builder: (localYargs) => this.addSchemaOptionsToCommand(localYargs, options).strict(),\n        handler: (options) =>\n          this.handler({\n            ...options,\n            schematic: `${collectionName}:${schematicName}`,\n          } as ArgumentsCamelCase<\n            SchematicsCommandArgs & {\n              schematic: string;\n            }\n          >),\n      });\n    }\n\n    return localYargs.demandCommand(1, demandCommandFailureMessage);\n  }\n\n  async run(options: Options<GenerateCommandArgs> & OtherOptions): Promise<number | void> {\n    const { dryRun, schematic, defaults, force, interactive, ...schematicOptions } = options;\n\n    const [collectionName, schematicName] = this.parseSchematicInfo(schematic);\n\n    if (!collectionName || !schematicName) {\n      throw new CommandModuleError('A collection and schematic is required during execution.');\n    }\n\n    return this.runSchematic({\n      collectionName,\n      schematicName,\n      schematicOptions,\n      executionOptions: {\n        dryRun,\n        defaults,\n        force,\n        interactive,\n      },\n    });\n  }\n\n  private async getCollectionNames(): Promise<string[]> {\n    const [collectionName] = this.parseSchematicInfo(\n      // positional = [generate, component] or [generate]\n      this.context.args.positional[1],\n    );\n\n    return collectionName ? [collectionName] : [...(await this.getSchematicCollections())];\n  }\n\n  private async shouldAddCollectionNameAsPartOfCommand(): Promise<boolean> {\n    const [collectionNameFromArgs] = this.parseSchematicInfo(\n      // positional = [generate, component] or [generate]\n      this.context.args.positional[1],\n    );\n\n    const schematicCollectionsFromConfig = await this.getSchematicCollections();\n    const collectionNames = await this.getCollectionNames();\n\n    // Only add the collection name as part of the command when it's not a known\n    // schematics collection or when it has been provided via the CLI.\n    // Ex:`ng generate @schematics/angular:c`\n    return (\n      !!collectionNameFromArgs ||\n      !collectionNames.some((c) => schematicCollectionsFromConfig.has(c))\n    );\n  }\n\n  /**\n   * Generate an aliases string array to be passed to the command builder.\n   *\n   * @example `[component]` or `[@schematics/angular:component]`.\n   */\n  private async generateCommandAliasesStrings(\n    collectionName: string,\n    schematicAliases: string[],\n  ): Promise<string[]> {\n    // Only add the collection name as part of the command when it's not a known\n    // schematics collection or when it has been provided via the CLI.\n    // Ex:`ng generate @schematics/angular:c`\n    return (await this.shouldAddCollectionNameAsPartOfCommand())\n      ? schematicAliases.map((alias) => `${collectionName}:${alias}`)\n      : schematicAliases;\n  }\n\n  /**\n   * Generate a command string to be passed to the command builder.\n   *\n   * @example `component [name]` or `@schematics/angular:component [name]`.\n   */\n  private async generateCommandString(\n    collectionName: string,\n    schematicName: string,\n    options: Option[],\n  ): Promise<string> {\n    const dasherizedSchematicName = strings.dasherize(schematicName);\n\n    // Only add the collection name as part of the command when it's not a known\n    // schematics collection or when it has been provided via the CLI.\n    // Ex:`ng generate @schematics/angular:component`\n    const commandName = (await this.shouldAddCollectionNameAsPartOfCommand())\n      ? collectionName + ':' + dasherizedSchematicName\n      : dasherizedSchematicName;\n\n    const positionalArgs = options\n      .filter((o) => o.positional !== undefined)\n      .map((o) => {\n        const label = `${strings.dasherize(o.name)}${o.type === 'array' ? ' ..' : ''}`;\n\n        return o.required ? `<${label}>` : `[${label}]`;\n      })\n      .join(' ');\n\n    return `${commandName}${positionalArgs ? ' ' + positionalArgs : ''}`;\n  }\n\n  /**\n   * Get schematics that can to be registered as subcommands.\n   */\n  private async *getSchematics(): AsyncGenerator<{\n    schematicName: string;\n    schematicAliases?: Set<string>;\n    collectionName: string;\n  }> {\n    const seenNames = new Set<string>();\n    for (const collectionName of await this.getCollectionNames()) {\n      const workflow = this.getOrCreateWorkflowForBuilder(collectionName);\n      const collection = workflow.engine.createCollection(collectionName);\n\n      for (const schematicName of collection.listSchematicNames(true /** includeHidden */)) {\n        // If a schematic with this same name is already registered skip.\n        if (!seenNames.has(schematicName)) {\n          seenNames.add(schematicName);\n\n          yield {\n            schematicName,\n            collectionName,\n            schematicAliases: this.listSchematicAliases(collection, schematicName),\n          };\n        }\n      }\n    }\n  }\n\n  private listSchematicAliases(\n    collection: Collection<FileSystemCollectionDescription, FileSystemSchematicDescription>,\n    schematicName: string,\n  ): Set<string> | undefined {\n    const description = collection.description.schematics[schematicName];\n    if (description) {\n      return description.aliases && new Set(description.aliases);\n    }\n\n    // Extended collections\n    if (collection.baseDescriptions) {\n      for (const base of collection.baseDescriptions) {\n        const description = base.schematics[schematicName];\n        if (description) {\n          return description.aliases && new Set(description.aliases);\n        }\n      }\n    }\n\n    return undefined;\n  }\n\n  /**\n   * Get schematics that should to be registered as subcommands.\n   *\n   * @returns a sorted list of schematic that needs to be registered as subcommands.\n   */\n  private async getSchematicsToRegister(): Promise<\n    [schematicName: string, collectionName: string][]\n  > {\n    const schematicsToRegister: [schematicName: string, collectionName: string][] = [];\n    const [, schematicNameFromArgs] = this.parseSchematicInfo(\n      // positional = [generate, component] or [generate]\n      this.context.args.positional[1],\n    );\n\n    for await (const { schematicName, collectionName, schematicAliases } of this.getSchematics()) {\n      if (\n        schematicNameFromArgs &&\n        (schematicName === schematicNameFromArgs || schematicAliases?.has(schematicNameFromArgs))\n      ) {\n        return [[schematicName, collectionName]];\n      }\n\n      schematicsToRegister.push([schematicName, collectionName]);\n    }\n\n    // Didn't find the schematic or no schematic name was provided Ex: `ng generate --help`.\n    return schematicsToRegister.sort(([nameA], [nameB]) =>\n      nameA.localeCompare(nameB, undefined, { sensitivity: 'accent' }),\n    );\n  }\n}\n"]}
@@ -23,7 +23,7 @@ class RunCommandModule extends architect_base_command_module_1.ArchitectBaseComm
23
23
  const { jsonHelp, getYargsCompletions, help } = this.context.args.options;
24
24
  const localYargs = argv
25
25
  .positional('target', {
26
- describe: 'The Architect target to run.',
26
+ describe: 'The Architect target to run provided in the the following format `project:target[:configuration]`.',
27
27
  type: 'string',
28
28
  demandOption: true,
29
29
  // Show only in when using --help and auto completion because otherwise comma seperated configuration values will be invalid.
@@ -91,4 +91,4 @@ class RunCommandModule extends architect_base_command_module_1.ArchitectBaseComm
91
91
  }
92
92
  }
93
93
  exports.RunCommandModule = RunCommandModule;
94
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cli.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular/cli/src/commands/run/cli.ts"],"names":[],"mappings":";AAAA;;;;;;GAMG;;;AAGH,+BAA4B;AAE5B,uGAAiG;AACjG,yEAM8C;AAM9C,MAAa,gBACX,SAAQ,0DAA0C;IADpD;;QAIW,UAAK,GAAG,6BAAY,CAAC,EAAE,CAAC;QAEjC,YAAO,GAAG,cAAc,CAAC;QACzB,aAAQ,GACN,iGAAiG,CAAC;QACpG,wBAAmB,GAAG,IAAA,WAAI,EAAC,SAAS,EAAE,qBAAqB,CAAC,CAAC;IA2F/D,CAAC;IAzFC,KAAK,CAAC,OAAO,CAAC,IAAU;QACtB,MAAM,EAAE,QAAQ,EAAE,mBAAmB,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC;QAE1E,MAAM,UAAU,GAAyB,IAAI;aAC1C,UAAU,CAAC,QAAQ,EAAE;YACpB,QAAQ,EAAE,8BAA8B;YACxC,IAAI,EAAE,QAAQ;YACd,YAAY,EAAE,IAAI;YAClB,6HAA6H;YAC7H,0EAA0E;YAC1E,OAAO,EAAE,CAAC,mBAAmB,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC,CAAC,CAAC,SAAS;SAC1F,CAAC;aACD,UAAU,CAAC,CAAC,IAAI,EAAE,EAAE;YACnB,8BAA8B;YAC9B,MAAM,EAAE,aAAa,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC;YACvC,IAAI,OAAO,aAAa,KAAK,QAAQ,IAAI,MAAM,EAAE;gBAC/C,MAAM,gBAAgB,GAAG,MAAM,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;gBAC9C,gBAAgB,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;gBAErC,MAAM,IAAI,mCAAkB,CAC1B,oCAAoC;oBAClC,2DAA2D,gBAAgB,CAAC,IAAI,CAC9E,GAAG,CACJ,IAAI,CACR,CAAC;aACH;QACH,CAAC,EAAE,IAAI,CAAC;aACP,MAAM,EAAE,CAAC;QAEZ,MAAM,MAAM,GAAG,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC1C,IAAI,CAAC,MAAM,EAAE;YACX,OAAO,UAAU,CAAC;SACnB;QAED,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,yBAAyB,CAAC,MAAM,CAAC,CAAC;QAEnE,OAAO,IAAI,CAAC,yBAAyB,CAAC,UAAU,EAAE,aAAa,CAAC,CAAC;IACnE,CAAC;IAED,KAAK,CAAC,GAAG,CAAC,OAA+C;QACvD,MAAM,MAAM,GAAG,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC,CAAC;QACjD,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,YAAY,EAAE,GAAG,OAAO,CAAC;QAErD,IAAI,CAAC,MAAM,EAAE;YACX,MAAM,IAAI,mCAAkB,CAAC,qCAAqC,CAAC,CAAC;SACrE;QAED,OAAO,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,YAAY,CAAC,CAAC;IACpD,CAAC;IAES,mBAAmB,CAAC,OAAiC;;QAC7D,MAAM,eAAe,GAAG,MAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,MAAM,mCAAI,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;QAC3E,IAAI,CAAC,eAAe,EAAE;YACpB,OAAO,SAAS,CAAC;SAClB;QAED,MAAM,CAAC,OAAO,GAAG,EAAE,EAAE,MAAM,GAAG,EAAE,EAAE,aAAa,CAAC,GAAG,eAAe,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAE9E,OAAO;YACL,OAAO;YACP,MAAM;YACN,aAAa;SACd,CAAC;IACJ,CAAC;IAED,kFAAkF;IAC1E,gBAAgB;QACtB,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE;YAC3B,OAAO;SACR;QAED,MAAM,OAAO,GAAG,EAAE,CAAC;QACnB,KAAK,MAAM,CAAC,WAAW,EAAE,OAAO,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,QAAQ,EAAE;YACpE,KAAK,MAAM,CAAC,UAAU,EAAE,MAAM,CAAC,IAAI,OAAO,CAAC,OAAO,EAAE;gBAClD,MAAM,aAAa,GAAG,GAAG,WAAW,IAAI,UAAU,EAAE,CAAC;gBACrD,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;gBAE5B,IAAI,CAAC,MAAM,CAAC,cAAc,EAAE;oBAC1B,SAAS;iBACV;gBAED,KAAK,MAAM,UAAU,IAAI,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,EAAE;oBAC3D,OAAO,CAAC,IAAI,CAAC,GAAG,aAAa,IAAI,UAAU,EAAE,CAAC,CAAC;iBAChD;aACF;SACF;QAED,OAAO,OAAO,CAAC,IAAI,EAAE,CAAC;IACxB,CAAC;CACF;AApGD,4CAoGC","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 { Target } from '@angular-devkit/architect';\nimport { join } from 'path';\nimport { Argv } from 'yargs';\nimport { ArchitectBaseCommandModule } from '../../command-builder/architect-base-command-module';\nimport {\n  CommandModuleError,\n  CommandModuleImplementation,\n  CommandScope,\n  Options,\n  OtherOptions,\n} from '../../command-builder/command-module';\n\nexport interface RunCommandArgs {\n  target: string;\n}\n\nexport class RunCommandModule\n  extends ArchitectBaseCommandModule<RunCommandArgs>\n  implements CommandModuleImplementation<RunCommandArgs>\n{\n  override scope = CommandScope.In;\n\n  command = 'run <target>';\n  describe =\n    'Runs an Architect target with an optional custom builder configuration defined in your project.';\n  longDescriptionPath = join(__dirname, 'long-description.md');\n\n  async builder(argv: Argv): Promise<Argv<RunCommandArgs>> {\n    const { jsonHelp, getYargsCompletions, help } = this.context.args.options;\n\n    const localYargs: Argv<RunCommandArgs> = argv\n      .positional('target', {\n        describe: 'The Architect target to run.',\n        type: 'string',\n        demandOption: true,\n        // Show only in when using --help and auto completion because otherwise comma seperated configuration values will be invalid.\n        // Also, hide choices from JSON help so that we don't display them in AIO.\n        choices: (getYargsCompletions || help) && !jsonHelp ? this.getTargetChoices() : undefined,\n      })\n      .middleware((args) => {\n        // TODO: remove in version 15.\n        const { configuration, target } = args;\n        if (typeof configuration === 'string' && target) {\n          const targetWithConfig = target.split(':', 2);\n          targetWithConfig.push(configuration);\n\n          throw new CommandModuleError(\n            'Unknown argument: configuration.\\n' +\n              `Provide the configuration as part of the target 'ng run ${targetWithConfig.join(\n                ':',\n              )}'.`,\n          );\n        }\n      }, true)\n      .strict();\n\n    const target = this.makeTargetSpecifier();\n    if (!target) {\n      return localYargs;\n    }\n\n    const schemaOptions = await this.getArchitectTargetOptions(target);\n\n    return this.addSchemaOptionsToCommand(localYargs, schemaOptions);\n  }\n\n  async run(options: Options<RunCommandArgs> & OtherOptions): Promise<number> {\n    const target = this.makeTargetSpecifier(options);\n    const { target: _target, ...extraOptions } = options;\n\n    if (!target) {\n      throw new CommandModuleError('Cannot determine project or target.');\n    }\n\n    return this.runSingleTarget(target, extraOptions);\n  }\n\n  protected makeTargetSpecifier(options?: Options<RunCommandArgs>): Target | undefined {\n    const architectTarget = options?.target ?? this.context.args.positional[1];\n    if (!architectTarget) {\n      return undefined;\n    }\n\n    const [project = '', target = '', configuration] = architectTarget.split(':');\n\n    return {\n      project,\n      target,\n      configuration,\n    };\n  }\n\n  /** @returns a sorted list of target specifiers to be used for auto completion. */\n  private getTargetChoices(): string[] | undefined {\n    if (!this.context.workspace) {\n      return;\n    }\n\n    const targets = [];\n    for (const [projectName, project] of this.context.workspace.projects) {\n      for (const [targetName, target] of project.targets) {\n        const currentTarget = `${projectName}:${targetName}`;\n        targets.push(currentTarget);\n\n        if (!target.configurations) {\n          continue;\n        }\n\n        for (const configName of Object.keys(target.configurations)) {\n          targets.push(`${currentTarget}:${configName}`);\n        }\n      }\n    }\n\n    return targets.sort();\n  }\n}\n"]}
94
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cli.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular/cli/src/commands/run/cli.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 { Target } from '@angular-devkit/architect';\nimport { join } from 'path';\nimport { Argv } from 'yargs';\nimport { ArchitectBaseCommandModule } from '../../command-builder/architect-base-command-module';\nimport {\n  CommandModuleError,\n  CommandModuleImplementation,\n  CommandScope,\n  Options,\n  OtherOptions,\n} from '../../command-builder/command-module';\n\nexport interface RunCommandArgs {\n  target: string;\n}\n\nexport class RunCommandModule\n  extends ArchitectBaseCommandModule<RunCommandArgs>\n  implements CommandModuleImplementation<RunCommandArgs>\n{\n  override scope = CommandScope.In;\n\n  command = 'run <target>';\n  describe =\n    'Runs an Architect target with an optional custom builder configuration defined in your project.';\n  longDescriptionPath = join(__dirname, 'long-description.md');\n\n  async builder(argv: Argv): Promise<Argv<RunCommandArgs>> {\n    const { jsonHelp, getYargsCompletions, help } = this.context.args.options;\n\n    const localYargs: Argv<RunCommandArgs> = argv\n      .positional('target', {\n        describe:\n          'The Architect target to run provided in the the following format `project:target[:configuration]`.',\n        type: 'string',\n        demandOption: true,\n        // Show only in when using --help and auto completion because otherwise comma seperated configuration values will be invalid.\n        // Also, hide choices from JSON help so that we don't display them in AIO.\n        choices: (getYargsCompletions || help) && !jsonHelp ? this.getTargetChoices() : undefined,\n      })\n      .middleware((args) => {\n        // TODO: remove in version 15.\n        const { configuration, target } = args;\n        if (typeof configuration === 'string' && target) {\n          const targetWithConfig = target.split(':', 2);\n          targetWithConfig.push(configuration);\n\n          throw new CommandModuleError(\n            'Unknown argument: configuration.\\n' +\n              `Provide the configuration as part of the target 'ng run ${targetWithConfig.join(\n                ':',\n              )}'.`,\n          );\n        }\n      }, true)\n      .strict();\n\n    const target = this.makeTargetSpecifier();\n    if (!target) {\n      return localYargs;\n    }\n\n    const schemaOptions = await this.getArchitectTargetOptions(target);\n\n    return this.addSchemaOptionsToCommand(localYargs, schemaOptions);\n  }\n\n  async run(options: Options<RunCommandArgs> & OtherOptions): Promise<number> {\n    const target = this.makeTargetSpecifier(options);\n    const { target: _target, ...extraOptions } = options;\n\n    if (!target) {\n      throw new CommandModuleError('Cannot determine project or target.');\n    }\n\n    return this.runSingleTarget(target, extraOptions);\n  }\n\n  protected makeTargetSpecifier(options?: Options<RunCommandArgs>): Target | undefined {\n    const architectTarget = options?.target ?? this.context.args.positional[1];\n    if (!architectTarget) {\n      return undefined;\n    }\n\n    const [project = '', target = '', configuration] = architectTarget.split(':');\n\n    return {\n      project,\n      target,\n      configuration,\n    };\n  }\n\n  /** @returns a sorted list of target specifiers to be used for auto completion. */\n  private getTargetChoices(): string[] | undefined {\n    if (!this.context.workspace) {\n      return;\n    }\n\n    const targets = [];\n    for (const [projectName, project] of this.context.workspace.projects) {\n      for (const [targetName, target] of project.targets) {\n        const currentTarget = `${projectName}:${targetName}`;\n        targets.push(currentTarget);\n\n        if (!target.configurations) {\n          continue;\n        }\n\n        for (const configName of Object.keys(target.configurations)) {\n          targets.push(`${currentTarget}:${configName}`);\n        }\n      }\n    }\n\n    return targets.sort();\n  }\n}\n"]}
@@ -1,16 +1,10 @@
1
1
  Architect is the tool that the CLI uses to perform complex tasks such as compilation, according to provided configurations.
2
2
  The CLI commands run Architect targets such as `build`, `serve`, `test`, and `lint`.
3
- Each named target has a default configuration, specified by an "options" object,
4
- and an optional set of named alternate configurations in the "configurations" object.
3
+ Each named target has a default configuration, specified by an `options` object,
4
+ and an optional set of named alternate configurations in the `configurations` object.
5
5
 
6
- For example, the "serve" target for a newly generated app has a predefined
7
- alternate configuration named "production".
6
+ For example, the `serve` target for a newly generated app has a predefined
7
+ alternate configuration named `production`.
8
8
 
9
- You can define new targets and their configuration options in the "architect" section
10
- of the `angular.json` file.
11
- If you do so, you can run them from the command line using the `ng run` command.
12
- Execute the command using the following format.
13
-
14
- ```
15
- ng run project:target[:configuration]
16
- ```
9
+ You can define new targets and their configuration options in the `architect` section
10
+ of the `angular.json` file which you can run them from the command line using the `ng run` command.
@@ -98,7 +98,7 @@ class UpdateCommandModule extends command_module_1.CommandModule {
98
98
  description: 'Version from which to migrate from. ' +
99
99
  `Only available with a single package being updated, and only with 'migrate-only'.`,
100
100
  type: 'string',
101
- implies: ['to', 'migrate-only'],
101
+ implies: ['migrate-only'],
102
102
  conflicts: ['name'],
103
103
  })
104
104
  .option('to', {
@@ -295,11 +295,23 @@ class UpdateCommandModule extends command_module_1.CommandModule {
295
295
  if (description.length) {
296
296
  logger.info(' ' + description.join('.\n '));
297
297
  }
298
- const result = await this.executeSchematic(workflow, migration.collection.name, migration.name);
299
- if (!result.success) {
298
+ const { success, files } = await this.executeSchematic(workflow, migration.collection.name, migration.name);
299
+ if (!success) {
300
300
  return 1;
301
301
  }
302
- logger.info(' Migration completed.');
302
+ let modifiedFilesText;
303
+ switch (files.size) {
304
+ case 0:
305
+ modifiedFilesText = 'No changes made';
306
+ break;
307
+ case 1:
308
+ modifiedFilesText = '1 file modified';
309
+ break;
310
+ default:
311
+ modifiedFilesText = `${files.size} files modified`;
312
+ break;
313
+ }
314
+ logger.info(` Migration completed (${modifiedFilesText}).`);
303
315
  // Commit migration
304
316
  if (commit) {
305
317
  const commitPrefix = `${packageName} migration - ${migration.name}`;
@@ -812,4 +824,4 @@ function coerceVersionNumber(version) {
812
824
  }
813
825
  return (_a = semver.valid(version)) !== null && _a !== void 0 ? _a : undefined;
814
826
  }
815
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cli.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular/cli/src/commands/update/cli.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 { UnsuccessfulWorkflowExecution } from '@angular-devkit/schematics';\nimport { NodeWorkflow } from '@angular-devkit/schematics/tools';\nimport { SpawnSyncReturns, execSync, spawnSync } from 'child_process';\nimport { existsSync, promises as fs } from 'fs';\nimport { createRequire } from 'module';\nimport npa from 'npm-package-arg';\nimport pickManifest from 'npm-pick-manifest';\nimport * as path from 'path';\nimport { join, resolve } from 'path';\nimport * as semver from 'semver';\nimport { Argv } from 'yargs';\nimport { PackageManager } from '../../../lib/config/workspace-schema';\nimport {\n  CommandModule,\n  CommandModuleError,\n  CommandScope,\n  Options,\n} from '../../command-builder/command-module';\nimport { SchematicEngineHost } from '../../command-builder/utilities/schematic-engine-host';\nimport { subscribeToWorkflow } from '../../command-builder/utilities/schematic-workflow';\nimport { colors } from '../../utilities/color';\nimport { disableVersionCheck } from '../../utilities/environment-options';\nimport { assertIsError } from '../../utilities/error';\nimport { writeErrorToLogFile } from '../../utilities/log-file';\nimport {\n  PackageIdentifier,\n  PackageManifest,\n  fetchPackageManifest,\n  fetchPackageMetadata,\n} from '../../utilities/package-metadata';\nimport {\n  PackageTreeNode,\n  findPackageJson,\n  getProjectDependencies,\n  readPackageJson,\n} from '../../utilities/package-tree';\nimport { VERSION } from '../../utilities/version';\n\ninterface UpdateCommandArgs {\n  packages?: string[];\n  force: boolean;\n  next: boolean;\n  'migrate-only'?: boolean;\n  name?: string;\n  from?: string;\n  to?: string;\n  'allow-dirty': boolean;\n  verbose: boolean;\n  'create-commits': boolean;\n}\n\nconst ANGULAR_PACKAGES_REGEXP = /^@(?:angular|nguniversal)\\//;\nconst UPDATE_SCHEMATIC_COLLECTION = path.join(__dirname, 'schematic/collection.json');\n\nexport class UpdateCommandModule extends CommandModule<UpdateCommandArgs> {\n  override scope = CommandScope.In;\n  protected override shouldReportAnalytics = false;\n\n  command = 'update [packages..]';\n  describe = 'Updates your workspace and its dependencies. See https://update.angular.io/.';\n  longDescriptionPath = join(__dirname, 'long-description.md');\n\n  builder(localYargs: Argv): Argv<UpdateCommandArgs> {\n    return localYargs\n      .positional('packages', {\n        description: 'The names of package(s) to update.',\n        type: 'string',\n        array: true,\n      })\n      .option('force', {\n        description: 'Ignore peer dependency version mismatches.',\n        type: 'boolean',\n        default: false,\n      })\n      .option('next', {\n        description: 'Use the prerelease version, including beta and RCs.',\n        type: 'boolean',\n        default: false,\n      })\n      .option('migrate-only', {\n        description: 'Only perform a migration, do not update the installed version.',\n        type: 'boolean',\n      })\n      .option('name', {\n        description:\n          'The name of the migration to run. ' +\n          `Only available with a single package being updated, and only with 'migrate-only' option.`,\n        type: 'string',\n        implies: ['migrate-only'],\n        conflicts: ['to', 'from'],\n      })\n      .option('from', {\n        description:\n          'Version from which to migrate from. ' +\n          `Only available with a single package being updated, and only with 'migrate-only'.`,\n        type: 'string',\n        implies: ['to', 'migrate-only'],\n        conflicts: ['name'],\n      })\n      .option('to', {\n        describe:\n          'Version up to which to apply migrations. Only available with a single package being updated, ' +\n          `and only with 'migrate-only' option. Requires 'from' to be specified. Default to the installed version detected.`,\n        type: 'string',\n        implies: ['from', 'migrate-only'],\n        conflicts: ['name'],\n      })\n      .option('allow-dirty', {\n        describe:\n          'Whether to allow updating when the repository contains modified or untracked files.',\n        type: 'boolean',\n        default: false,\n      })\n      .option('verbose', {\n        describe: 'Display additional details about internal operations during execution.',\n        type: 'boolean',\n        default: false,\n      })\n      .option('create-commits', {\n        describe: 'Create source control commits for updates and migrations.',\n        type: 'boolean',\n        alias: ['C'],\n        default: false,\n      })\n      .check(({ packages, 'allow-dirty': allowDirty, 'migrate-only': migrateOnly }) => {\n        const { logger } = this.context;\n\n        // This allows the user to easily reset any changes from the update.\n        if (packages?.length && !this.checkCleanGit()) {\n          if (allowDirty) {\n            logger.warn(\n              'Repository is not clean. Update changes will be mixed with pre-existing changes.',\n            );\n          } else {\n            throw new CommandModuleError(\n              'Repository is not clean. Please commit or stash any changes before updating.',\n            );\n          }\n        }\n\n        if (migrateOnly) {\n          if (packages?.length !== 1) {\n            throw new CommandModuleError(\n              `A single package must be specified when using the 'migrate-only' option.`,\n            );\n          }\n        }\n\n        return true;\n      })\n      .strict();\n  }\n\n  async run(options: Options<UpdateCommandArgs>): Promise<number | void> {\n    const { logger, packageManager } = this.context;\n\n    packageManager.ensureCompatibility();\n\n    // Check if the current installed CLI version is older than the latest compatible version.\n    // Skip when running `ng update` without a package name as this will not trigger an actual update.\n    if (!disableVersionCheck && options.packages?.length) {\n      const cliVersionToInstall = await this.checkCLIVersion(\n        options.packages,\n        options.verbose,\n        options.next,\n      );\n\n      if (cliVersionToInstall) {\n        logger.warn(\n          'The installed Angular CLI version is outdated.\\n' +\n            `Installing a temporary Angular CLI versioned ${cliVersionToInstall} to perform the update.`,\n        );\n\n        return this.runTempBinary(`@angular/cli@${cliVersionToInstall}`, process.argv.slice(2));\n      }\n    }\n\n    const packages: PackageIdentifier[] = [];\n    for (const request of options.packages ?? []) {\n      try {\n        const packageIdentifier = npa(request);\n\n        // only registry identifiers are supported\n        if (!packageIdentifier.registry) {\n          logger.error(`Package '${request}' is not a registry package identifer.`);\n\n          return 1;\n        }\n\n        if (packages.some((v) => v.name === packageIdentifier.name)) {\n          logger.error(`Duplicate package '${packageIdentifier.name}' specified.`);\n\n          return 1;\n        }\n\n        if (options.migrateOnly && packageIdentifier.rawSpec !== '*') {\n          logger.warn('Package specifier has no effect when using \"migrate-only\" option.');\n        }\n\n        // If next option is used and no specifier supplied, use next tag\n        if (options.next && packageIdentifier.rawSpec === '*') {\n          packageIdentifier.fetchSpec = 'next';\n        }\n\n        packages.push(packageIdentifier as PackageIdentifier);\n      } catch (e) {\n        assertIsError(e);\n        logger.error(e.message);\n\n        return 1;\n      }\n    }\n\n    logger.info(`Using package manager: ${colors.grey(packageManager.name)}`);\n    logger.info('Collecting installed dependencies...');\n\n    const rootDependencies = await getProjectDependencies(this.context.root);\n    logger.info(`Found ${rootDependencies.size} dependencies.`);\n\n    const workflow = new NodeWorkflow(this.context.root, {\n      packageManager: packageManager.name,\n      packageManagerForce: this.packageManagerForce(options.verbose),\n      // __dirname -> favor @schematics/update from this package\n      // Otherwise, use packages from the active workspace (migrations)\n      resolvePaths: [__dirname, this.context.root],\n      schemaValidation: true,\n      engineHostCreator: (options) => new SchematicEngineHost(options.resolvePaths),\n    });\n\n    if (packages.length === 0) {\n      // Show status\n      const { success } = await this.executeSchematic(\n        workflow,\n        UPDATE_SCHEMATIC_COLLECTION,\n        'update',\n        {\n          force: options.force,\n          next: options.next,\n          verbose: options.verbose,\n          packageManager: packageManager.name,\n          packages: [],\n        },\n      );\n\n      return success ? 0 : 1;\n    }\n\n    return options.migrateOnly\n      ? this.migrateOnly(workflow, (options.packages ?? [])[0], rootDependencies, options)\n      : this.updatePackagesAndMigrate(workflow, rootDependencies, options, packages);\n  }\n\n  private async executeSchematic(\n    workflow: NodeWorkflow,\n    collection: string,\n    schematic: string,\n    options: Record<string, unknown> = {},\n  ): Promise<{ success: boolean; files: Set<string> }> {\n    const { logger } = this.context;\n    const workflowSubscription = subscribeToWorkflow(workflow, logger);\n\n    // TODO: Allow passing a schematic instance directly\n    try {\n      await workflow\n        .execute({\n          collection,\n          schematic,\n          options,\n          logger,\n        })\n        .toPromise();\n\n      return { success: !workflowSubscription.error, files: workflowSubscription.files };\n    } catch (e) {\n      if (e instanceof UnsuccessfulWorkflowExecution) {\n        logger.error(`${colors.symbols.cross} Migration failed. See above for further details.\\n`);\n      } else {\n        assertIsError(e);\n        const logPath = writeErrorToLogFile(e);\n        logger.fatal(\n          `${colors.symbols.cross} Migration failed: ${e.message}\\n` +\n            `  See \"${logPath}\" for further details.\\n`,\n        );\n      }\n\n      return { success: false, files: workflowSubscription.files };\n    } finally {\n      workflowSubscription.unsubscribe();\n    }\n  }\n\n  /**\n   * @return Whether or not the migration was performed successfully.\n   */\n  private async executeMigration(\n    workflow: NodeWorkflow,\n    packageName: string,\n    collectionPath: string,\n    migrationName: string,\n    commit?: boolean,\n  ): Promise<number> {\n    const { logger } = this.context;\n    const collection = workflow.engine.createCollection(collectionPath);\n    const name = collection.listSchematicNames().find((name) => name === migrationName);\n    if (!name) {\n      logger.error(`Cannot find migration '${migrationName}' in '${packageName}'.`);\n\n      return 1;\n    }\n\n    logger.info(colors.cyan(`** Executing '${migrationName}' of package '${packageName}' **\\n`));\n    const schematic = workflow.engine.createSchematic(name, collection);\n\n    return this.executePackageMigrations(workflow, [schematic.description], packageName, commit);\n  }\n\n  /**\n   * @return Whether or not the migrations were performed successfully.\n   */\n  private async executeMigrations(\n    workflow: NodeWorkflow,\n    packageName: string,\n    collectionPath: string,\n    from: string,\n    to: string,\n    commit?: boolean,\n  ): Promise<number> {\n    const collection = workflow.engine.createCollection(collectionPath);\n    const migrationRange = new semver.Range(\n      '>' + (semver.prerelease(from) ? from.split('-')[0] + '-0' : from) + ' <=' + to.split('-')[0],\n    );\n    const migrations = [];\n\n    for (const name of collection.listSchematicNames()) {\n      const schematic = workflow.engine.createSchematic(name, collection);\n      const description = schematic.description as typeof schematic.description & {\n        version?: string;\n      };\n      description.version = coerceVersionNumber(description.version);\n      if (!description.version) {\n        continue;\n      }\n\n      if (semver.satisfies(description.version, migrationRange, { includePrerelease: true })) {\n        migrations.push(description as typeof schematic.description & { version: string });\n      }\n    }\n\n    if (migrations.length === 0) {\n      return 0;\n    }\n\n    migrations.sort((a, b) => semver.compare(a.version, b.version) || a.name.localeCompare(b.name));\n\n    this.context.logger.info(\n      colors.cyan(`** Executing migrations of package '${packageName}' **\\n`),\n    );\n\n    return this.executePackageMigrations(workflow, migrations, packageName, commit);\n  }\n\n  private async executePackageMigrations(\n    workflow: NodeWorkflow,\n    migrations: Iterable<{ name: string; description: string; collection: { name: string } }>,\n    packageName: string,\n    commit = false,\n  ): Promise<number> {\n    const { logger } = this.context;\n    for (const migration of migrations) {\n      const [title, ...description] = migration.description.split('. ');\n\n      logger.info(\n        colors.cyan(colors.symbols.pointer) +\n          ' ' +\n          colors.bold(title.endsWith('.') ? title : title + '.'),\n      );\n\n      if (description.length) {\n        logger.info('  ' + description.join('.\\n  '));\n      }\n\n      const result = await this.executeSchematic(\n        workflow,\n        migration.collection.name,\n        migration.name,\n      );\n      if (!result.success) {\n        return 1;\n      }\n\n      logger.info('  Migration completed.');\n\n      // Commit migration\n      if (commit) {\n        const commitPrefix = `${packageName} migration - ${migration.name}`;\n        const commitMessage = migration.description\n          ? `${commitPrefix}\\n\\n${migration.description}`\n          : commitPrefix;\n        const committed = this.commit(commitMessage);\n        if (!committed) {\n          // Failed to commit, something went wrong. Abort the update.\n          return 1;\n        }\n      }\n\n      logger.info(''); // Extra trailing newline.\n    }\n\n    return 0;\n  }\n\n  private async migrateOnly(\n    workflow: NodeWorkflow,\n    packageName: string,\n    rootDependencies: Map<string, PackageTreeNode>,\n    options: Options<UpdateCommandArgs>,\n  ): Promise<number | void> {\n    const { logger } = this.context;\n    const packageDependency = rootDependencies.get(packageName);\n    let packagePath = packageDependency?.path;\n    let packageNode = packageDependency?.package;\n    if (packageDependency && !packageNode) {\n      logger.error('Package found in package.json but is not installed.');\n\n      return 1;\n    } else if (!packageDependency) {\n      // Allow running migrations on transitively installed dependencies\n      // There can technically be nested multiple versions\n      // TODO: If multiple, this should find all versions and ask which one to use\n      const packageJson = findPackageJson(this.context.root, packageName);\n      if (packageJson) {\n        packagePath = path.dirname(packageJson);\n        packageNode = await readPackageJson(packageJson);\n      }\n    }\n\n    if (!packageNode || !packagePath) {\n      logger.error('Package is not installed.');\n\n      return 1;\n    }\n\n    const updateMetadata = packageNode['ng-update'];\n    let migrations = updateMetadata?.migrations;\n    if (migrations === undefined) {\n      logger.error('Package does not provide migrations.');\n\n      return 1;\n    } else if (typeof migrations !== 'string') {\n      logger.error('Package contains a malformed migrations field.');\n\n      return 1;\n    } else if (path.posix.isAbsolute(migrations) || path.win32.isAbsolute(migrations)) {\n      logger.error(\n        'Package contains an invalid migrations field. Absolute paths are not permitted.',\n      );\n\n      return 1;\n    }\n\n    // Normalize slashes\n    migrations = migrations.replace(/\\\\/g, '/');\n\n    if (migrations.startsWith('../')) {\n      logger.error(\n        'Package contains an invalid migrations field. Paths outside the package root are not permitted.',\n      );\n\n      return 1;\n    }\n\n    // Check if it is a package-local location\n    const localMigrations = path.join(packagePath, migrations);\n    if (existsSync(localMigrations)) {\n      migrations = localMigrations;\n    } else {\n      // Try to resolve from package location.\n      // This avoids issues with package hoisting.\n      try {\n        const packageRequire = createRequire(packagePath + '/');\n        migrations = packageRequire.resolve(migrations);\n      } catch (e) {\n        assertIsError(e);\n        if (e.code === 'MODULE_NOT_FOUND') {\n          logger.error('Migrations for package were not found.');\n        } else {\n          logger.error(`Unable to resolve migrations for package.  [${e.message}]`);\n        }\n\n        return 1;\n      }\n    }\n\n    if (options.name) {\n      return this.executeMigration(\n        workflow,\n        packageName,\n        migrations,\n        options.name,\n        options.createCommits,\n      );\n    }\n\n    const from = coerceVersionNumber(options.from);\n    if (!from) {\n      logger.error(`\"from\" value [${options.from}] is not a valid version.`);\n\n      return 1;\n    }\n\n    return this.executeMigrations(\n      workflow,\n      packageName,\n      migrations,\n      from,\n      options.to || packageNode.version,\n      options.createCommits,\n    );\n  }\n\n  // eslint-disable-next-line max-lines-per-function\n  private async updatePackagesAndMigrate(\n    workflow: NodeWorkflow,\n    rootDependencies: Map<string, PackageTreeNode>,\n    options: Options<UpdateCommandArgs>,\n    packages: PackageIdentifier[],\n  ): Promise<number> {\n    const { logger } = this.context;\n\n    const logVerbose = (message: string) => {\n      if (options.verbose) {\n        logger.info(message);\n      }\n    };\n\n    const requests: {\n      identifier: PackageIdentifier;\n      node: PackageTreeNode;\n    }[] = [];\n\n    // Validate packages actually are part of the workspace\n    for (const pkg of packages) {\n      const node = rootDependencies.get(pkg.name);\n      if (!node?.package) {\n        logger.error(`Package '${pkg.name}' is not a dependency.`);\n\n        return 1;\n      }\n\n      // If a specific version is requested and matches the installed version, skip.\n      if (pkg.type === 'version' && node.package.version === pkg.fetchSpec) {\n        logger.info(`Package '${pkg.name}' is already at '${pkg.fetchSpec}'.`);\n        continue;\n      }\n\n      requests.push({ identifier: pkg, node });\n    }\n\n    if (requests.length === 0) {\n      return 0;\n    }\n\n    logger.info('Fetching dependency metadata from registry...');\n\n    const packagesToUpdate: string[] = [];\n    for (const { identifier: requestIdentifier, node } of requests) {\n      const packageName = requestIdentifier.name;\n\n      let metadata;\n      try {\n        // Metadata requests are internally cached; multiple requests for same name\n        // does not result in additional network traffic\n        metadata = await fetchPackageMetadata(packageName, logger, {\n          verbose: options.verbose,\n        });\n      } catch (e) {\n        assertIsError(e);\n        logger.error(`Error fetching metadata for '${packageName}': ` + e.message);\n\n        return 1;\n      }\n\n      // Try to find a package version based on the user requested package specifier\n      // registry specifier types are either version, range, or tag\n      let manifest: PackageManifest | undefined;\n      if (\n        requestIdentifier.type === 'version' ||\n        requestIdentifier.type === 'range' ||\n        requestIdentifier.type === 'tag'\n      ) {\n        try {\n          manifest = pickManifest(metadata, requestIdentifier.fetchSpec);\n        } catch (e) {\n          assertIsError(e);\n          if (e.code === 'ETARGET') {\n            // If not found and next was used and user did not provide a specifier, try latest.\n            // Package may not have a next tag.\n            if (\n              requestIdentifier.type === 'tag' &&\n              requestIdentifier.fetchSpec === 'next' &&\n              !requestIdentifier.rawSpec\n            ) {\n              try {\n                manifest = pickManifest(metadata, 'latest');\n              } catch (e) {\n                assertIsError(e);\n                if (e.code !== 'ETARGET' && e.code !== 'ENOVERSIONS') {\n                  throw e;\n                }\n              }\n            }\n          } else if (e.code !== 'ENOVERSIONS') {\n            throw e;\n          }\n        }\n      }\n\n      if (!manifest) {\n        logger.error(\n          `Package specified by '${requestIdentifier.raw}' does not exist within the registry.`,\n        );\n\n        return 1;\n      }\n\n      if (manifest.version === node.package?.version) {\n        logger.info(`Package '${packageName}' is already up to date.`);\n        continue;\n      }\n\n      if (node.package && ANGULAR_PACKAGES_REGEXP.test(node.package.name)) {\n        const { name, version } = node.package;\n        const toBeInstalledMajorVersion = +manifest.version.split('.')[0];\n        const currentMajorVersion = +version.split('.')[0];\n\n        if (toBeInstalledMajorVersion - currentMajorVersion > 1) {\n          // Only allow updating a single version at a time.\n          if (currentMajorVersion < 6) {\n            // Before version 6, the major versions were not always sequential.\n            // Example @angular/core skipped version 3, @angular/cli skipped versions 2-5.\n            logger.error(\n              `Updating multiple major versions of '${name}' at once is not supported. Please migrate each major version individually.\\n` +\n                `For more information about the update process, see https://update.angular.io/.`,\n            );\n          } else {\n            const nextMajorVersionFromCurrent = currentMajorVersion + 1;\n\n            logger.error(\n              `Updating multiple major versions of '${name}' at once is not supported. Please migrate each major version individually.\\n` +\n                `Run 'ng update ${name}@${nextMajorVersionFromCurrent}' in your workspace directory ` +\n                `to update to latest '${nextMajorVersionFromCurrent}.x' version of '${name}'.\\n\\n` +\n                `For more information about the update process, see https://update.angular.io/?v=${currentMajorVersion}.0-${nextMajorVersionFromCurrent}.0`,\n            );\n          }\n\n          return 1;\n        }\n      }\n\n      packagesToUpdate.push(requestIdentifier.toString());\n    }\n\n    if (packagesToUpdate.length === 0) {\n      return 0;\n    }\n\n    const { success } = await this.executeSchematic(\n      workflow,\n      UPDATE_SCHEMATIC_COLLECTION,\n      'update',\n      {\n        verbose: options.verbose,\n        force: options.force,\n        next: options.next,\n        packageManager: this.context.packageManager.name,\n        packages: packagesToUpdate,\n      },\n    );\n\n    if (success) {\n      try {\n        await fs.rm(path.join(this.context.root, 'node_modules'), {\n          force: true,\n          recursive: true,\n          maxRetries: 3,\n        });\n      } catch {}\n\n      const installationSuccess = await this.context.packageManager.installAll(\n        this.packageManagerForce(options.verbose) ? ['--force'] : [],\n        this.context.root,\n      );\n\n      if (!installationSuccess) {\n        return 1;\n      }\n    }\n\n    if (success && options.createCommits) {\n      if (!this.commit(`Angular CLI update for packages - ${packagesToUpdate.join(', ')}`)) {\n        return 1;\n      }\n    }\n\n    // This is a temporary workaround to allow data to be passed back from the update schematic\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    const migrations = (global as any).externalMigrations as {\n      package: string;\n      collection: string;\n      from: string;\n      to: string;\n    }[];\n\n    if (success && migrations) {\n      const rootRequire = createRequire(this.context.root + '/');\n      for (const migration of migrations) {\n        // Resolve the package from the workspace root, as otherwise it will be resolved from the temp\n        // installed CLI version.\n        let packagePath;\n        logVerbose(\n          `Resolving migration package '${migration.package}' from '${this.context.root}'...`,\n        );\n        try {\n          try {\n            packagePath = path.dirname(\n              // This may fail if the `package.json` is not exported as an entry point\n              rootRequire.resolve(path.join(migration.package, 'package.json')),\n            );\n          } catch (e) {\n            assertIsError(e);\n            if (e.code === 'MODULE_NOT_FOUND') {\n              // Fallback to trying to resolve the package's main entry point\n              packagePath = rootRequire.resolve(migration.package);\n            } else {\n              throw e;\n            }\n          }\n        } catch (e) {\n          assertIsError(e);\n          if (e.code === 'MODULE_NOT_FOUND') {\n            logVerbose(e.toString());\n            logger.error(\n              `Migrations for package (${migration.package}) were not found.` +\n                ' The package could not be found in the workspace.',\n            );\n          } else {\n            logger.error(\n              `Unable to resolve migrations for package (${migration.package}).  [${e.message}]`,\n            );\n          }\n\n          return 1;\n        }\n\n        let migrations;\n\n        // Check if it is a package-local location\n        const localMigrations = path.join(packagePath, migration.collection);\n        if (existsSync(localMigrations)) {\n          migrations = localMigrations;\n        } else {\n          // Try to resolve from package location.\n          // This avoids issues with package hoisting.\n          try {\n            const packageRequire = createRequire(packagePath + '/');\n            migrations = packageRequire.resolve(migration.collection);\n          } catch (e) {\n            assertIsError(e);\n            if (e.code === 'MODULE_NOT_FOUND') {\n              logger.error(`Migrations for package (${migration.package}) were not found.`);\n            } else {\n              logger.error(\n                `Unable to resolve migrations for package (${migration.package}).  [${e.message}]`,\n              );\n            }\n\n            return 1;\n          }\n        }\n        const result = await this.executeMigrations(\n          workflow,\n          migration.package,\n          migrations,\n          migration.from,\n          migration.to,\n          options.createCommits,\n        );\n\n        // A non-zero value is a failure for the package's migrations\n        if (result !== 0) {\n          return result;\n        }\n      }\n    }\n\n    return success ? 0 : 1;\n  }\n  /**\n   * @return Whether or not the commit was successful.\n   */\n  private commit(message: string): boolean {\n    const { logger } = this.context;\n\n    // Check if a commit is needed.\n    let commitNeeded: boolean;\n    try {\n      commitNeeded = hasChangesToCommit();\n    } catch (err) {\n      logger.error(`  Failed to read Git tree:\\n${(err as SpawnSyncReturns<string>).stderr}`);\n\n      return false;\n    }\n\n    if (!commitNeeded) {\n      logger.info('  No changes to commit after migration.');\n\n      return true;\n    }\n\n    // Commit changes and abort on error.\n    try {\n      createCommit(message);\n    } catch (err) {\n      logger.error(\n        `Failed to commit update (${message}):\\n${(err as SpawnSyncReturns<string>).stderr}`,\n      );\n\n      return false;\n    }\n\n    // Notify user of the commit.\n    const hash = findCurrentGitSha();\n    const shortMessage = message.split('\\n')[0];\n    if (hash) {\n      logger.info(`  Committed migration step (${getShortHash(hash)}): ${shortMessage}.`);\n    } else {\n      // Commit was successful, but reading the hash was not. Something weird happened,\n      // but nothing that would stop the update. Just log the weirdness and continue.\n      logger.info(`  Committed migration step: ${shortMessage}.`);\n      logger.warn('  Failed to look up hash of most recent commit, continuing anyways.');\n    }\n\n    return true;\n  }\n\n  private checkCleanGit(): boolean {\n    try {\n      const topLevel = execSync('git rev-parse --show-toplevel', {\n        encoding: 'utf8',\n        stdio: 'pipe',\n      });\n      const result = execSync('git status --porcelain', { encoding: 'utf8', stdio: 'pipe' });\n      if (result.trim().length === 0) {\n        return true;\n      }\n\n      // Only files inside the workspace root are relevant\n      for (const entry of result.split('\\n')) {\n        const relativeEntry = path.relative(\n          path.resolve(this.context.root),\n          path.resolve(topLevel.trim(), entry.slice(3).trim()),\n        );\n\n        if (!relativeEntry.startsWith('..') && !path.isAbsolute(relativeEntry)) {\n          return false;\n        }\n      }\n    } catch {}\n\n    return true;\n  }\n\n  /**\n   * Checks if the current installed CLI version is older or newer than a compatible version.\n   * @returns the version to install or null when there is no update to install.\n   */\n  private async checkCLIVersion(\n    packagesToUpdate: string[],\n    verbose = false,\n    next = false,\n  ): Promise<string | null> {\n    const { version } = await fetchPackageManifest(\n      `@angular/cli@${this.getCLIUpdateRunnerVersion(packagesToUpdate, next)}`,\n      this.context.logger,\n      {\n        verbose,\n        usingYarn: this.context.packageManager.name === PackageManager.Yarn,\n      },\n    );\n\n    return VERSION.full === version ? null : version;\n  }\n\n  private getCLIUpdateRunnerVersion(\n    packagesToUpdate: string[] | undefined,\n    next: boolean,\n  ): string | number {\n    if (next) {\n      return 'next';\n    }\n\n    const updatingAngularPackage = packagesToUpdate?.find((r) => ANGULAR_PACKAGES_REGEXP.test(r));\n    if (updatingAngularPackage) {\n      // If we are updating any Angular package we can update the CLI to the target version because\n      // migrations for @angular/core@13 can be executed using Angular/cli@13.\n      // This is same behaviour as `npx @angular/cli@13 update @angular/core@13`.\n\n      // `@angular/cli@13` -> ['', 'angular/cli', '13']\n      // `@angular/cli` -> ['', 'angular/cli']\n      const tempVersion = coerceVersionNumber(updatingAngularPackage.split('@')[2]);\n\n      return semver.parse(tempVersion)?.major ?? 'latest';\n    }\n\n    // When not updating an Angular package we cannot determine which schematic runtime the migration should to be executed in.\n    // Typically, we can assume that the `@angular/cli` was updated previously.\n    // Example: Angular official packages are typically updated prior to NGRX etc...\n    // Therefore, we only update to the latest patch version of the installed major version of the Angular CLI.\n\n    // This is important because we might end up in a scenario where locally Angular v12 is installed, updating NGRX from 11 to 12.\n    // We end up using Angular ClI v13 to run the migrations if we run the migrations using the CLI installed major version + 1 logic.\n    return VERSION.major;\n  }\n\n  private async runTempBinary(packageName: string, args: string[] = []): Promise<number> {\n    const { success, tempNodeModules } = await this.context.packageManager.installTemp(packageName);\n    if (!success) {\n      return 1;\n    }\n\n    // Remove version/tag etc... from package name\n    // Ex: @angular/cli@latest -> @angular/cli\n    const packageNameNoVersion = packageName.substring(0, packageName.lastIndexOf('@'));\n    const pkgLocation = join(tempNodeModules, packageNameNoVersion);\n    const packageJsonPath = join(pkgLocation, 'package.json');\n\n    // Get a binary location for this package\n    let binPath: string | undefined;\n    if (existsSync(packageJsonPath)) {\n      const content = await fs.readFile(packageJsonPath, 'utf-8');\n      if (content) {\n        const { bin = {} } = JSON.parse(content);\n        const binKeys = Object.keys(bin);\n\n        if (binKeys.length) {\n          binPath = resolve(pkgLocation, bin[binKeys[0]]);\n        }\n      }\n    }\n\n    if (!binPath) {\n      throw new Error(`Cannot locate bin for temporary package: ${packageNameNoVersion}.`);\n    }\n\n    const { status, error } = spawnSync(process.execPath, [binPath, ...args], {\n      stdio: 'inherit',\n      env: {\n        ...process.env,\n        NG_DISABLE_VERSION_CHECK: 'true',\n        NG_CLI_ANALYTICS: 'false',\n      },\n    });\n\n    if (status === null && error) {\n      throw error;\n    }\n\n    return status ?? 0;\n  }\n\n  private packageManagerForce(verbose: boolean): boolean {\n    // npm 7+ can fail due to it incorrectly resolving peer dependencies that have valid SemVer\n    // ranges during an update. Update will set correct versions of dependencies within the\n    // package.json file. The force option is set to workaround these errors.\n    // Example error:\n    // npm ERR! Conflicting peer dependency: @angular/compiler-cli@14.0.0-rc.0\n    // npm ERR! node_modules/@angular/compiler-cli\n    // npm ERR!   peer @angular/compiler-cli@\"^14.0.0 || ^14.0.0-rc\" from @angular-devkit/build-angular@14.0.0-rc.0\n    // npm ERR!   node_modules/@angular-devkit/build-angular\n    // npm ERR!     dev @angular-devkit/build-angular@\"~14.0.0-rc.0\" from the root project\n    if (\n      this.context.packageManager.name === PackageManager.Npm &&\n      this.context.packageManager.version &&\n      semver.gte(this.context.packageManager.version, '7.0.0')\n    ) {\n      if (verbose) {\n        this.context.logger.info(\n          'NPM 7+ detected -- enabling force option for package installation',\n        );\n      }\n\n      return true;\n    }\n\n    return false;\n  }\n}\n\n/**\n * @return Whether or not the working directory has Git changes to commit.\n */\nfunction hasChangesToCommit(): boolean {\n  // List all modified files not covered by .gitignore.\n  // If any files are returned, then there must be something to commit.\n\n  return execSync('git ls-files -m -d -o --exclude-standard').toString() !== '';\n}\n\n/**\n * Precondition: Must have pending changes to commit, they do not need to be staged.\n * Postcondition: The Git working tree is committed and the repo is clean.\n * @param message The commit message to use.\n */\nfunction createCommit(message: string) {\n  // Stage entire working tree for commit.\n  execSync('git add -A', { encoding: 'utf8', stdio: 'pipe' });\n\n  // Commit with the message passed via stdin to avoid bash escaping issues.\n  execSync('git commit --no-verify -F -', { encoding: 'utf8', stdio: 'pipe', input: message });\n}\n\n/**\n * @return The Git SHA hash of the HEAD commit. Returns null if unable to retrieve the hash.\n */\nfunction findCurrentGitSha(): string | null {\n  try {\n    return execSync('git rev-parse HEAD', { encoding: 'utf8', stdio: 'pipe' }).trim();\n  } catch {\n    return null;\n  }\n}\n\nfunction getShortHash(commitHash: string): string {\n  return commitHash.slice(0, 9);\n}\n\nfunction coerceVersionNumber(version: string | undefined): string | undefined {\n  if (!version) {\n    return undefined;\n  }\n\n  if (!/^\\d{1,30}\\.\\d{1,30}\\.\\d{1,30}/.test(version)) {\n    const match = version.match(/^\\d{1,30}(\\.\\d{1,30})*/);\n\n    if (!match) {\n      return undefined;\n    }\n\n    if (!match[1]) {\n      version = version.substring(0, match[0].length) + '.0.0' + version.substring(match[0].length);\n    } else if (!match[2]) {\n      version = version.substring(0, match[0].length) + '.0' + version.substring(match[0].length);\n    } else {\n      return undefined;\n    }\n  }\n\n  return semver.valid(version) ?? undefined;\n}\n"]}
827
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cli.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular/cli/src/commands/update/cli.ts"],"names":[],"mappings":";AAAA;;;;;;GAMG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEH,2DAA2E;AAC3E,4DAAgE;AAChE,iDAAsE;AACtE,2BAAgD;AAChD,mCAAuC;AACvC,sEAAkC;AAClC,0EAA6C;AAC7C,2CAA6B;AAC7B,+BAAqC;AACrC,+CAAiC;AAEjC,2EAAsE;AACtE,yEAK8C;AAC9C,iGAA4F;AAC5F,2FAAyF;AACzF,iDAA+C;AAC/C,6EAA0E;AAC1E,iDAAsD;AACtD,uDAA+D;AAC/D,uEAK0C;AAC1C,+DAKsC;AACtC,qDAAkD;AAelD,MAAM,uBAAuB,GAAG,6BAA6B,CAAC;AAC9D,MAAM,2BAA2B,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,2BAA2B,CAAC,CAAC;AAEtF,MAAa,mBAAoB,SAAQ,8BAAgC;IAAzE;;QACW,UAAK,GAAG,6BAAY,CAAC,EAAE,CAAC;QACd,0BAAqB,GAAG,KAAK,CAAC;QAEjD,YAAO,GAAG,qBAAqB,CAAC;QAChC,aAAQ,GAAG,8EAA8E,CAAC;QAC1F,wBAAmB,GAAG,IAAA,WAAI,EAAC,SAAS,EAAE,qBAAqB,CAAC,CAAC;IAq7B/D,CAAC;IAn7BC,OAAO,CAAC,UAAgB;QACtB,OAAO,UAAU;aACd,UAAU,CAAC,UAAU,EAAE;YACtB,WAAW,EAAE,oCAAoC;YACjD,IAAI,EAAE,QAAQ;YACd,KAAK,EAAE,IAAI;SACZ,CAAC;aACD,MAAM,CAAC,OAAO,EAAE;YACf,WAAW,EAAE,4CAA4C;YACzD,IAAI,EAAE,SAAS;YACf,OAAO,EAAE,KAAK;SACf,CAAC;aACD,MAAM,CAAC,MAAM,EAAE;YACd,WAAW,EAAE,qDAAqD;YAClE,IAAI,EAAE,SAAS;YACf,OAAO,EAAE,KAAK;SACf,CAAC;aACD,MAAM,CAAC,cAAc,EAAE;YACtB,WAAW,EAAE,gEAAgE;YAC7E,IAAI,EAAE,SAAS;SAChB,CAAC;aACD,MAAM,CAAC,MAAM,EAAE;YACd,WAAW,EACT,oCAAoC;gBACpC,0FAA0F;YAC5F,IAAI,EAAE,QAAQ;YACd,OAAO,EAAE,CAAC,cAAc,CAAC;YACzB,SAAS,EAAE,CAAC,IAAI,EAAE,MAAM,CAAC;SAC1B,CAAC;aACD,MAAM,CAAC,MAAM,EAAE;YACd,WAAW,EACT,sCAAsC;gBACtC,mFAAmF;YACrF,IAAI,EAAE,QAAQ;YACd,OAAO,EAAE,CAAC,cAAc,CAAC;YACzB,SAAS,EAAE,CAAC,MAAM,CAAC;SACpB,CAAC;aACD,MAAM,CAAC,IAAI,EAAE;YACZ,QAAQ,EACN,+FAA+F;gBAC/F,kHAAkH;YACpH,IAAI,EAAE,QAAQ;YACd,OAAO,EAAE,CAAC,MAAM,EAAE,cAAc,CAAC;YACjC,SAAS,EAAE,CAAC,MAAM,CAAC;SACpB,CAAC;aACD,MAAM,CAAC,aAAa,EAAE;YACrB,QAAQ,EACN,qFAAqF;YACvF,IAAI,EAAE,SAAS;YACf,OAAO,EAAE,KAAK;SACf,CAAC;aACD,MAAM,CAAC,SAAS,EAAE;YACjB,QAAQ,EAAE,wEAAwE;YAClF,IAAI,EAAE,SAAS;YACf,OAAO,EAAE,KAAK;SACf,CAAC;aACD,MAAM,CAAC,gBAAgB,EAAE;YACxB,QAAQ,EAAE,2DAA2D;YACrE,IAAI,EAAE,SAAS;YACf,KAAK,EAAE,CAAC,GAAG,CAAC;YACZ,OAAO,EAAE,KAAK;SACf,CAAC;aACD,KAAK,CAAC,CAAC,EAAE,QAAQ,EAAE,aAAa,EAAE,UAAU,EAAE,cAAc,EAAE,WAAW,EAAE,EAAE,EAAE;YAC9E,MAAM,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC;YAEhC,oEAAoE;YACpE,IAAI,CAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,MAAM,KAAI,CAAC,IAAI,CAAC,aAAa,EAAE,EAAE;gBAC7C,IAAI,UAAU,EAAE;oBACd,MAAM,CAAC,IAAI,CACT,kFAAkF,CACnF,CAAC;iBACH;qBAAM;oBACL,MAAM,IAAI,mCAAkB,CAC1B,8EAA8E,CAC/E,CAAC;iBACH;aACF;YAED,IAAI,WAAW,EAAE;gBACf,IAAI,CAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,MAAM,MAAK,CAAC,EAAE;oBAC1B,MAAM,IAAI,mCAAkB,CAC1B,0EAA0E,CAC3E,CAAC;iBACH;aACF;YAED,OAAO,IAAI,CAAC;QACd,CAAC,CAAC;aACD,MAAM,EAAE,CAAC;IACd,CAAC;IAED,KAAK,CAAC,GAAG,CAAC,OAAmC;;QAC3C,MAAM,EAAE,MAAM,EAAE,cAAc,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC;QAEhD,cAAc,CAAC,mBAAmB,EAAE,CAAC;QAErC,0FAA0F;QAC1F,kGAAkG;QAClG,IAAI,CAAC,yCAAmB,KAAI,MAAA,OAAO,CAAC,QAAQ,0CAAE,MAAM,CAAA,EAAE;YACpD,MAAM,mBAAmB,GAAG,MAAM,IAAI,CAAC,eAAe,CACpD,OAAO,CAAC,QAAQ,EAChB,OAAO,CAAC,OAAO,EACf,OAAO,CAAC,IAAI,CACb,CAAC;YAEF,IAAI,mBAAmB,EAAE;gBACvB,MAAM,CAAC,IAAI,CACT,kDAAkD;oBAChD,gDAAgD,mBAAmB,yBAAyB,CAC/F,CAAC;gBAEF,OAAO,IAAI,CAAC,aAAa,CAAC,gBAAgB,mBAAmB,EAAE,EAAE,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;aACzF;SACF;QAED,MAAM,QAAQ,GAAwB,EAAE,CAAC;QACzC,KAAK,MAAM,OAAO,IAAI,MAAA,OAAO,CAAC,QAAQ,mCAAI,EAAE,EAAE;YAC5C,IAAI;gBACF,MAAM,iBAAiB,GAAG,IAAA,yBAAG,EAAC,OAAO,CAAC,CAAC;gBAEvC,0CAA0C;gBAC1C,IAAI,CAAC,iBAAiB,CAAC,QAAQ,EAAE;oBAC/B,MAAM,CAAC,KAAK,CAAC,YAAY,OAAO,wCAAwC,CAAC,CAAC;oBAE1E,OAAO,CAAC,CAAC;iBACV;gBAED,IAAI,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,iBAAiB,CAAC,IAAI,CAAC,EAAE;oBAC3D,MAAM,CAAC,KAAK,CAAC,sBAAsB,iBAAiB,CAAC,IAAI,cAAc,CAAC,CAAC;oBAEzE,OAAO,CAAC,CAAC;iBACV;gBAED,IAAI,OAAO,CAAC,WAAW,IAAI,iBAAiB,CAAC,OAAO,KAAK,GAAG,EAAE;oBAC5D,MAAM,CAAC,IAAI,CAAC,mEAAmE,CAAC,CAAC;iBAClF;gBAED,iEAAiE;gBACjE,IAAI,OAAO,CAAC,IAAI,IAAI,iBAAiB,CAAC,OAAO,KAAK,GAAG,EAAE;oBACrD,iBAAiB,CAAC,SAAS,GAAG,MAAM,CAAC;iBACtC;gBAED,QAAQ,CAAC,IAAI,CAAC,iBAAsC,CAAC,CAAC;aACvD;YAAC,OAAO,CAAC,EAAE;gBACV,IAAA,qBAAa,EAAC,CAAC,CAAC,CAAC;gBACjB,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;gBAExB,OAAO,CAAC,CAAC;aACV;SACF;QAED,MAAM,CAAC,IAAI,CAAC,0BAA0B,cAAM,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAC1E,MAAM,CAAC,IAAI,CAAC,sCAAsC,CAAC,CAAC;QAEpD,MAAM,gBAAgB,GAAG,MAAM,IAAA,qCAAsB,EAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QACzE,MAAM,CAAC,IAAI,CAAC,SAAS,gBAAgB,CAAC,IAAI,gBAAgB,CAAC,CAAC;QAE5D,MAAM,QAAQ,GAAG,IAAI,oBAAY,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE;YACnD,cAAc,EAAE,cAAc,CAAC,IAAI;YACnC,mBAAmB,EAAE,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC,OAAO,CAAC;YAC9D,0DAA0D;YAC1D,iEAAiE;YACjE,YAAY,EAAE,CAAC,SAAS,EAAE,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;YAC5C,gBAAgB,EAAE,IAAI;YACtB,iBAAiB,EAAE,CAAC,OAAO,EAAE,EAAE,CAAC,IAAI,2CAAmB,CAAC,OAAO,CAAC,YAAY,CAAC;SAC9E,CAAC,CAAC;QAEH,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE;YACzB,cAAc;YACd,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAC7C,QAAQ,EACR,2BAA2B,EAC3B,QAAQ,EACR;gBACE,KAAK,EAAE,OAAO,CAAC,KAAK;gBACpB,IAAI,EAAE,OAAO,CAAC,IAAI;gBAClB,OAAO,EAAE,OAAO,CAAC,OAAO;gBACxB,cAAc,EAAE,cAAc,CAAC,IAAI;gBACnC,QAAQ,EAAE,EAAE;aACb,CACF,CAAC;YAEF,OAAO,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;SACxB;QAED,OAAO,OAAO,CAAC,WAAW;YACxB,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAC,MAAA,OAAO,CAAC,QAAQ,mCAAI,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,gBAAgB,EAAE,OAAO,CAAC;YACpF,CAAC,CAAC,IAAI,CAAC,wBAAwB,CAAC,QAAQ,EAAE,gBAAgB,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC;IACnF,CAAC;IAEO,KAAK,CAAC,gBAAgB,CAC5B,QAAsB,EACtB,UAAkB,EAClB,SAAiB,EACjB,UAAmC,EAAE;QAErC,MAAM,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC;QAChC,MAAM,oBAAoB,GAAG,IAAA,wCAAmB,EAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;QAEnE,oDAAoD;QACpD,IAAI;YACF,MAAM,QAAQ;iBACX,OAAO,CAAC;gBACP,UAAU;gBACV,SAAS;gBACT,OAAO;gBACP,MAAM;aACP,CAAC;iBACD,SAAS,EAAE,CAAC;YAEf,OAAO,EAAE,OAAO,EAAE,CAAC,oBAAoB,CAAC,KAAK,EAAE,KAAK,EAAE,oBAAoB,CAAC,KAAK,EAAE,CAAC;SACpF;QAAC,OAAO,CAAC,EAAE;YACV,IAAI,CAAC,YAAY,0CAA6B,EAAE;gBAC9C,MAAM,CAAC,KAAK,CAAC,GAAG,cAAM,CAAC,OAAO,CAAC,KAAK,qDAAqD,CAAC,CAAC;aAC5F;iBAAM;gBACL,IAAA,qBAAa,EAAC,CAAC,CAAC,CAAC;gBACjB,MAAM,OAAO,GAAG,IAAA,8BAAmB,EAAC,CAAC,CAAC,CAAC;gBACvC,MAAM,CAAC,KAAK,CACV,GAAG,cAAM,CAAC,OAAO,CAAC,KAAK,sBAAsB,CAAC,CAAC,OAAO,IAAI;oBACxD,UAAU,OAAO,0BAA0B,CAC9C,CAAC;aACH;YAED,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,oBAAoB,CAAC,KAAK,EAAE,CAAC;SAC9D;gBAAS;YACR,oBAAoB,CAAC,WAAW,EAAE,CAAC;SACpC;IACH,CAAC;IAED;;OAEG;IACK,KAAK,CAAC,gBAAgB,CAC5B,QAAsB,EACtB,WAAmB,EACnB,cAAsB,EACtB,aAAqB,EACrB,MAAgB;QAEhB,MAAM,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC;QAChC,MAAM,UAAU,GAAG,QAAQ,CAAC,MAAM,CAAC,gBAAgB,CAAC,cAAc,CAAC,CAAC;QACpE,MAAM,IAAI,GAAG,UAAU,CAAC,kBAAkB,EAAE,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,KAAK,aAAa,CAAC,CAAC;QACpF,IAAI,CAAC,IAAI,EAAE;YACT,MAAM,CAAC,KAAK,CAAC,0BAA0B,aAAa,SAAS,WAAW,IAAI,CAAC,CAAC;YAE9E,OAAO,CAAC,CAAC;SACV;QAED,MAAM,CAAC,IAAI,CAAC,cAAM,CAAC,IAAI,CAAC,iBAAiB,aAAa,iBAAiB,WAAW,QAAQ,CAAC,CAAC,CAAC;QAC7F,MAAM,SAAS,GAAG,QAAQ,CAAC,MAAM,CAAC,eAAe,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC;QAEpE,OAAO,IAAI,CAAC,wBAAwB,CAAC,QAAQ,EAAE,CAAC,SAAS,CAAC,WAAW,CAAC,EAAE,WAAW,EAAE,MAAM,CAAC,CAAC;IAC/F,CAAC;IAED;;OAEG;IACK,KAAK,CAAC,iBAAiB,CAC7B,QAAsB,EACtB,WAAmB,EACnB,cAAsB,EACtB,IAAY,EACZ,EAAU,EACV,MAAgB;QAEhB,MAAM,UAAU,GAAG,QAAQ,CAAC,MAAM,CAAC,gBAAgB,CAAC,cAAc,CAAC,CAAC;QACpE,MAAM,cAAc,GAAG,IAAI,MAAM,CAAC,KAAK,CACrC,GAAG,GAAG,CAAC,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,KAAK,GAAG,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAC9F,CAAC;QACF,MAAM,UAAU,GAAG,EAAE,CAAC;QAEtB,KAAK,MAAM,IAAI,IAAI,UAAU,CAAC,kBAAkB,EAAE,EAAE;YAClD,MAAM,SAAS,GAAG,QAAQ,CAAC,MAAM,CAAC,eAAe,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC;YACpE,MAAM,WAAW,GAAG,SAAS,CAAC,WAE7B,CAAC;YACF,WAAW,CAAC,OAAO,GAAG,mBAAmB,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;YAC/D,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE;gBACxB,SAAS;aACV;YAED,IAAI,MAAM,CAAC,SAAS,CAAC,WAAW,CAAC,OAAO,EAAE,cAAc,EAAE,EAAE,iBAAiB,EAAE,IAAI,EAAE,CAAC,EAAE;gBACtF,UAAU,CAAC,IAAI,CAAC,WAAiE,CAAC,CAAC;aACpF;SACF;QAED,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE;YAC3B,OAAO,CAAC,CAAC;SACV;QAED,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;QAEhG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CACtB,cAAM,CAAC,IAAI,CAAC,uCAAuC,WAAW,QAAQ,CAAC,CACxE,CAAC;QAEF,OAAO,IAAI,CAAC,wBAAwB,CAAC,QAAQ,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,CAAC,CAAC;IAClF,CAAC;IAEO,KAAK,CAAC,wBAAwB,CACpC,QAAsB,EACtB,UAAyF,EACzF,WAAmB,EACnB,MAAM,GAAG,KAAK;QAEd,MAAM,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC;QAChC,KAAK,MAAM,SAAS,IAAI,UAAU,EAAE;YAClC,MAAM,CAAC,KAAK,EAAE,GAAG,WAAW,CAAC,GAAG,SAAS,CAAC,WAAW,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YAElE,MAAM,CAAC,IAAI,CACT,cAAM,CAAC,IAAI,CAAC,cAAM,CAAC,OAAO,CAAC,OAAO,CAAC;gBACjC,GAAG;gBACH,cAAM,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,GAAG,GAAG,CAAC,CACzD,CAAC;YAEF,IAAI,WAAW,CAAC,MAAM,EAAE;gBACtB,MAAM,CAAC,IAAI,CAAC,IAAI,GAAG,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;aAC/C;YAED,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,gBAAgB,CACpD,QAAQ,EACR,SAAS,CAAC,UAAU,CAAC,IAAI,EACzB,SAAS,CAAC,IAAI,CACf,CAAC;YACF,IAAI,CAAC,OAAO,EAAE;gBACZ,OAAO,CAAC,CAAC;aACV;YAED,IAAI,iBAAyB,CAAC;YAC9B,QAAQ,KAAK,CAAC,IAAI,EAAE;gBAClB,KAAK,CAAC;oBACJ,iBAAiB,GAAG,iBAAiB,CAAC;oBACtC,MAAM;gBACR,KAAK,CAAC;oBACJ,iBAAiB,GAAG,iBAAiB,CAAC;oBACtC,MAAM;gBACR;oBACE,iBAAiB,GAAG,GAAG,KAAK,CAAC,IAAI,iBAAiB,CAAC;oBACnD,MAAM;aACT;YAED,MAAM,CAAC,IAAI,CAAC,0BAA0B,iBAAiB,IAAI,CAAC,CAAC;YAE7D,mBAAmB;YACnB,IAAI,MAAM,EAAE;gBACV,MAAM,YAAY,GAAG,GAAG,WAAW,gBAAgB,SAAS,CAAC,IAAI,EAAE,CAAC;gBACpE,MAAM,aAAa,GAAG,SAAS,CAAC,WAAW;oBACzC,CAAC,CAAC,GAAG,YAAY,OAAO,SAAS,CAAC,WAAW,EAAE;oBAC/C,CAAC,CAAC,YAAY,CAAC;gBACjB,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;gBAC7C,IAAI,CAAC,SAAS,EAAE;oBACd,4DAA4D;oBAC5D,OAAO,CAAC,CAAC;iBACV;aACF;YAED,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,0BAA0B;SAC5C;QAED,OAAO,CAAC,CAAC;IACX,CAAC;IAEO,KAAK,CAAC,WAAW,CACvB,QAAsB,EACtB,WAAmB,EACnB,gBAA8C,EAC9C,OAAmC;QAEnC,MAAM,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC;QAChC,MAAM,iBAAiB,GAAG,gBAAgB,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;QAC5D,IAAI,WAAW,GAAG,iBAAiB,aAAjB,iBAAiB,uBAAjB,iBAAiB,CAAE,IAAI,CAAC;QAC1C,IAAI,WAAW,GAAG,iBAAiB,aAAjB,iBAAiB,uBAAjB,iBAAiB,CAAE,OAAO,CAAC;QAC7C,IAAI,iBAAiB,IAAI,CAAC,WAAW,EAAE;YACrC,MAAM,CAAC,KAAK,CAAC,qDAAqD,CAAC,CAAC;YAEpE,OAAO,CAAC,CAAC;SACV;aAAM,IAAI,CAAC,iBAAiB,EAAE;YAC7B,kEAAkE;YAClE,oDAAoD;YACpD,4EAA4E;YAC5E,MAAM,WAAW,GAAG,IAAA,8BAAe,EAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC;YACpE,IAAI,WAAW,EAAE;gBACf,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;gBACxC,WAAW,GAAG,MAAM,IAAA,8BAAe,EAAC,WAAW,CAAC,CAAC;aAClD;SACF;QAED,IAAI,CAAC,WAAW,IAAI,CAAC,WAAW,EAAE;YAChC,MAAM,CAAC,KAAK,CAAC,2BAA2B,CAAC,CAAC;YAE1C,OAAO,CAAC,CAAC;SACV;QAED,MAAM,cAAc,GAAG,WAAW,CAAC,WAAW,CAAC,CAAC;QAChD,IAAI,UAAU,GAAG,cAAc,aAAd,cAAc,uBAAd,cAAc,CAAE,UAAU,CAAC;QAC5C,IAAI,UAAU,KAAK,SAAS,EAAE;YAC5B,MAAM,CAAC,KAAK,CAAC,sCAAsC,CAAC,CAAC;YAErD,OAAO,CAAC,CAAC;SACV;aAAM,IAAI,OAAO,UAAU,KAAK,QAAQ,EAAE;YACzC,MAAM,CAAC,KAAK,CAAC,gDAAgD,CAAC,CAAC;YAE/D,OAAO,CAAC,CAAC;SACV;aAAM,IAAI,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE;YACjF,MAAM,CAAC,KAAK,CACV,iFAAiF,CAClF,CAAC;YAEF,OAAO,CAAC,CAAC;SACV;QAED,oBAAoB;QACpB,UAAU,GAAG,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;QAE5C,IAAI,UAAU,CAAC,UAAU,CAAC,KAAK,CAAC,EAAE;YAChC,MAAM,CAAC,KAAK,CACV,iGAAiG,CAClG,CAAC;YAEF,OAAO,CAAC,CAAC;SACV;QAED,0CAA0C;QAC1C,MAAM,eAAe,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,UAAU,CAAC,CAAC;QAC3D,IAAI,IAAA,eAAU,EAAC,eAAe,CAAC,EAAE;YAC/B,UAAU,GAAG,eAAe,CAAC;SAC9B;aAAM;YACL,wCAAwC;YACxC,4CAA4C;YAC5C,IAAI;gBACF,MAAM,cAAc,GAAG,IAAA,sBAAa,EAAC,WAAW,GAAG,GAAG,CAAC,CAAC;gBACxD,UAAU,GAAG,cAAc,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;aACjD;YAAC,OAAO,CAAC,EAAE;gBACV,IAAA,qBAAa,EAAC,CAAC,CAAC,CAAC;gBACjB,IAAI,CAAC,CAAC,IAAI,KAAK,kBAAkB,EAAE;oBACjC,MAAM,CAAC,KAAK,CAAC,wCAAwC,CAAC,CAAC;iBACxD;qBAAM;oBACL,MAAM,CAAC,KAAK,CAAC,+CAA+C,CAAC,CAAC,OAAO,GAAG,CAAC,CAAC;iBAC3E;gBAED,OAAO,CAAC,CAAC;aACV;SACF;QAED,IAAI,OAAO,CAAC,IAAI,EAAE;YAChB,OAAO,IAAI,CAAC,gBAAgB,CAC1B,QAAQ,EACR,WAAW,EACX,UAAU,EACV,OAAO,CAAC,IAAI,EACZ,OAAO,CAAC,aAAa,CACtB,CAAC;SACH;QAED,MAAM,IAAI,GAAG,mBAAmB,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAC/C,IAAI,CAAC,IAAI,EAAE;YACT,MAAM,CAAC,KAAK,CAAC,iBAAiB,OAAO,CAAC,IAAI,2BAA2B,CAAC,CAAC;YAEvE,OAAO,CAAC,CAAC;SACV;QAED,OAAO,IAAI,CAAC,iBAAiB,CAC3B,QAAQ,EACR,WAAW,EACX,UAAU,EACV,IAAI,EACJ,OAAO,CAAC,EAAE,IAAI,WAAW,CAAC,OAAO,EACjC,OAAO,CAAC,aAAa,CACtB,CAAC;IACJ,CAAC;IAED,kDAAkD;IAC1C,KAAK,CAAC,wBAAwB,CACpC,QAAsB,EACtB,gBAA8C,EAC9C,OAAmC,EACnC,QAA6B;;QAE7B,MAAM,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC;QAEhC,MAAM,UAAU,GAAG,CAAC,OAAe,EAAE,EAAE;YACrC,IAAI,OAAO,CAAC,OAAO,EAAE;gBACnB,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;aACtB;QACH,CAAC,CAAC;QAEF,MAAM,QAAQ,GAGR,EAAE,CAAC;QAET,uDAAuD;QACvD,KAAK,MAAM,GAAG,IAAI,QAAQ,EAAE;YAC1B,MAAM,IAAI,GAAG,gBAAgB,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YAC5C,IAAI,CAAC,CAAA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,OAAO,CAAA,EAAE;gBAClB,MAAM,CAAC,KAAK,CAAC,YAAY,GAAG,CAAC,IAAI,wBAAwB,CAAC,CAAC;gBAE3D,OAAO,CAAC,CAAC;aACV;YAED,8EAA8E;YAC9E,IAAI,GAAG,CAAC,IAAI,KAAK,SAAS,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,KAAK,GAAG,CAAC,SAAS,EAAE;gBACpE,MAAM,CAAC,IAAI,CAAC,YAAY,GAAG,CAAC,IAAI,oBAAoB,GAAG,CAAC,SAAS,IAAI,CAAC,CAAC;gBACvE,SAAS;aACV;YAED,QAAQ,CAAC,IAAI,CAAC,EAAE,UAAU,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC,CAAC;SAC1C;QAED,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE;YACzB,OAAO,CAAC,CAAC;SACV;QAED,MAAM,CAAC,IAAI,CAAC,+CAA+C,CAAC,CAAC;QAE7D,MAAM,gBAAgB,GAAa,EAAE,CAAC;QACtC,KAAK,MAAM,EAAE,UAAU,EAAE,iBAAiB,EAAE,IAAI,EAAE,IAAI,QAAQ,EAAE;YAC9D,MAAM,WAAW,GAAG,iBAAiB,CAAC,IAAI,CAAC;YAE3C,IAAI,QAAQ,CAAC;YACb,IAAI;gBACF,2EAA2E;gBAC3E,gDAAgD;gBAChD,QAAQ,GAAG,MAAM,IAAA,uCAAoB,EAAC,WAAW,EAAE,MAAM,EAAE;oBACzD,OAAO,EAAE,OAAO,CAAC,OAAO;iBACzB,CAAC,CAAC;aACJ;YAAC,OAAO,CAAC,EAAE;gBACV,IAAA,qBAAa,EAAC,CAAC,CAAC,CAAC;gBACjB,MAAM,CAAC,KAAK,CAAC,gCAAgC,WAAW,KAAK,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC;gBAE3E,OAAO,CAAC,CAAC;aACV;YAED,8EAA8E;YAC9E,6DAA6D;YAC7D,IAAI,QAAqC,CAAC;YAC1C,IACE,iBAAiB,CAAC,IAAI,KAAK,SAAS;gBACpC,iBAAiB,CAAC,IAAI,KAAK,OAAO;gBAClC,iBAAiB,CAAC,IAAI,KAAK,KAAK,EAChC;gBACA,IAAI;oBACF,QAAQ,GAAG,IAAA,2BAAY,EAAC,QAAQ,EAAE,iBAAiB,CAAC,SAAS,CAAC,CAAC;iBAChE;gBAAC,OAAO,CAAC,EAAE;oBACV,IAAA,qBAAa,EAAC,CAAC,CAAC,CAAC;oBACjB,IAAI,CAAC,CAAC,IAAI,KAAK,SAAS,EAAE;wBACxB,mFAAmF;wBACnF,mCAAmC;wBACnC,IACE,iBAAiB,CAAC,IAAI,KAAK,KAAK;4BAChC,iBAAiB,CAAC,SAAS,KAAK,MAAM;4BACtC,CAAC,iBAAiB,CAAC,OAAO,EAC1B;4BACA,IAAI;gCACF,QAAQ,GAAG,IAAA,2BAAY,EAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;6BAC7C;4BAAC,OAAO,CAAC,EAAE;gCACV,IAAA,qBAAa,EAAC,CAAC,CAAC,CAAC;gCACjB,IAAI,CAAC,CAAC,IAAI,KAAK,SAAS,IAAI,CAAC,CAAC,IAAI,KAAK,aAAa,EAAE;oCACpD,MAAM,CAAC,CAAC;iCACT;6BACF;yBACF;qBACF;yBAAM,IAAI,CAAC,CAAC,IAAI,KAAK,aAAa,EAAE;wBACnC,MAAM,CAAC,CAAC;qBACT;iBACF;aACF;YAED,IAAI,CAAC,QAAQ,EAAE;gBACb,MAAM,CAAC,KAAK,CACV,yBAAyB,iBAAiB,CAAC,GAAG,uCAAuC,CACtF,CAAC;gBAEF,OAAO,CAAC,CAAC;aACV;YAED,IAAI,QAAQ,CAAC,OAAO,MAAK,MAAA,IAAI,CAAC,OAAO,0CAAE,OAAO,CAAA,EAAE;gBAC9C,MAAM,CAAC,IAAI,CAAC,YAAY,WAAW,0BAA0B,CAAC,CAAC;gBAC/D,SAAS;aACV;YAED,IAAI,IAAI,CAAC,OAAO,IAAI,uBAAuB,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;gBACnE,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC;gBACvC,MAAM,yBAAyB,GAAG,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;gBAClE,MAAM,mBAAmB,GAAG,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;gBAEnD,IAAI,yBAAyB,GAAG,mBAAmB,GAAG,CAAC,EAAE;oBACvD,kDAAkD;oBAClD,IAAI,mBAAmB,GAAG,CAAC,EAAE;wBAC3B,mEAAmE;wBACnE,8EAA8E;wBAC9E,MAAM,CAAC,KAAK,CACV,wCAAwC,IAAI,+EAA+E;4BACzH,gFAAgF,CACnF,CAAC;qBACH;yBAAM;wBACL,MAAM,2BAA2B,GAAG,mBAAmB,GAAG,CAAC,CAAC;wBAE5D,MAAM,CAAC,KAAK,CACV,wCAAwC,IAAI,+EAA+E;4BACzH,kBAAkB,IAAI,IAAI,2BAA2B,gCAAgC;4BACrF,wBAAwB,2BAA2B,mBAAmB,IAAI,QAAQ;4BAClF,mFAAmF,mBAAmB,MAAM,2BAA2B,IAAI,CAC9I,CAAC;qBACH;oBAED,OAAO,CAAC,CAAC;iBACV;aACF;YAED,gBAAgB,CAAC,IAAI,CAAC,iBAAiB,CAAC,QAAQ,EAAE,CAAC,CAAC;SACrD;QAED,IAAI,gBAAgB,CAAC,MAAM,KAAK,CAAC,EAAE;YACjC,OAAO,CAAC,CAAC;SACV;QAED,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAC7C,QAAQ,EACR,2BAA2B,EAC3B,QAAQ,EACR;YACE,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,KAAK,EAAE,OAAO,CAAC,KAAK;YACpB,IAAI,EAAE,OAAO,CAAC,IAAI;YAClB,cAAc,EAAE,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,IAAI;YAChD,QAAQ,EAAE,gBAAgB;SAC3B,CACF,CAAC;QAEF,IAAI,OAAO,EAAE;YACX,IAAI;gBACF,MAAM,aAAE,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,cAAc,CAAC,EAAE;oBACxD,KAAK,EAAE,IAAI;oBACX,SAAS,EAAE,IAAI;oBACf,UAAU,EAAE,CAAC;iBACd,CAAC,CAAC;aACJ;YAAC,WAAM,GAAE;YAEV,MAAM,mBAAmB,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,UAAU,CACtE,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,EAAE,EAC5D,IAAI,CAAC,OAAO,CAAC,IAAI,CAClB,CAAC;YAEF,IAAI,CAAC,mBAAmB,EAAE;gBACxB,OAAO,CAAC,CAAC;aACV;SACF;QAED,IAAI,OAAO,IAAI,OAAO,CAAC,aAAa,EAAE;YACpC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,qCAAqC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE;gBACpF,OAAO,CAAC,CAAC;aACV;SACF;QAED,2FAA2F;QAC3F,8DAA8D;QAC9D,MAAM,UAAU,GAAI,MAAc,CAAC,kBAKhC,CAAC;QAEJ,IAAI,OAAO,IAAI,UAAU,EAAE;YACzB,MAAM,WAAW,GAAG,IAAA,sBAAa,EAAC,IAAI,CAAC,OAAO,CAAC,IAAI,GAAG,GAAG,CAAC,CAAC;YAC3D,KAAK,MAAM,SAAS,IAAI,UAAU,EAAE;gBAClC,8FAA8F;gBAC9F,yBAAyB;gBACzB,IAAI,WAAW,CAAC;gBAChB,UAAU,CACR,gCAAgC,SAAS,CAAC,OAAO,WAAW,IAAI,CAAC,OAAO,CAAC,IAAI,MAAM,CACpF,CAAC;gBACF,IAAI;oBACF,IAAI;wBACF,WAAW,GAAG,IAAI,CAAC,OAAO;wBACxB,wEAAwE;wBACxE,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,cAAc,CAAC,CAAC,CAClE,CAAC;qBACH;oBAAC,OAAO,CAAC,EAAE;wBACV,IAAA,qBAAa,EAAC,CAAC,CAAC,CAAC;wBACjB,IAAI,CAAC,CAAC,IAAI,KAAK,kBAAkB,EAAE;4BACjC,+DAA+D;4BAC/D,WAAW,GAAG,WAAW,CAAC,OAAO,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;yBACtD;6BAAM;4BACL,MAAM,CAAC,CAAC;yBACT;qBACF;iBACF;gBAAC,OAAO,CAAC,EAAE;oBACV,IAAA,qBAAa,EAAC,CAAC,CAAC,CAAC;oBACjB,IAAI,CAAC,CAAC,IAAI,KAAK,kBAAkB,EAAE;wBACjC,UAAU,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC;wBACzB,MAAM,CAAC,KAAK,CACV,2BAA2B,SAAS,CAAC,OAAO,mBAAmB;4BAC7D,mDAAmD,CACtD,CAAC;qBACH;yBAAM;wBACL,MAAM,CAAC,KAAK,CACV,6CAA6C,SAAS,CAAC,OAAO,QAAQ,CAAC,CAAC,OAAO,GAAG,CACnF,CAAC;qBACH;oBAED,OAAO,CAAC,CAAC;iBACV;gBAED,IAAI,UAAU,CAAC;gBAEf,0CAA0C;gBAC1C,MAAM,eAAe,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,SAAS,CAAC,UAAU,CAAC,CAAC;gBACrE,IAAI,IAAA,eAAU,EAAC,eAAe,CAAC,EAAE;oBAC/B,UAAU,GAAG,eAAe,CAAC;iBAC9B;qBAAM;oBACL,wCAAwC;oBACxC,4CAA4C;oBAC5C,IAAI;wBACF,MAAM,cAAc,GAAG,IAAA,sBAAa,EAAC,WAAW,GAAG,GAAG,CAAC,CAAC;wBACxD,UAAU,GAAG,cAAc,CAAC,OAAO,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;qBAC3D;oBAAC,OAAO,CAAC,EAAE;wBACV,IAAA,qBAAa,EAAC,CAAC,CAAC,CAAC;wBACjB,IAAI,CAAC,CAAC,IAAI,KAAK,kBAAkB,EAAE;4BACjC,MAAM,CAAC,KAAK,CAAC,2BAA2B,SAAS,CAAC,OAAO,mBAAmB,CAAC,CAAC;yBAC/E;6BAAM;4BACL,MAAM,CAAC,KAAK,CACV,6CAA6C,SAAS,CAAC,OAAO,QAAQ,CAAC,CAAC,OAAO,GAAG,CACnF,CAAC;yBACH;wBAED,OAAO,CAAC,CAAC;qBACV;iBACF;gBACD,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,iBAAiB,CACzC,QAAQ,EACR,SAAS,CAAC,OAAO,EACjB,UAAU,EACV,SAAS,CAAC,IAAI,EACd,SAAS,CAAC,EAAE,EACZ,OAAO,CAAC,aAAa,CACtB,CAAC;gBAEF,6DAA6D;gBAC7D,IAAI,MAAM,KAAK,CAAC,EAAE;oBAChB,OAAO,MAAM,CAAC;iBACf;aACF;SACF;QAED,OAAO,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IACzB,CAAC;IACD;;OAEG;IACK,MAAM,CAAC,OAAe;QAC5B,MAAM,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC;QAEhC,+BAA+B;QAC/B,IAAI,YAAqB,CAAC;QAC1B,IAAI;YACF,YAAY,GAAG,kBAAkB,EAAE,CAAC;SACrC;QAAC,OAAO,GAAG,EAAE;YACZ,MAAM,CAAC,KAAK,CAAC,+BAAgC,GAAgC,CAAC,MAAM,EAAE,CAAC,CAAC;YAExF,OAAO,KAAK,CAAC;SACd;QAED,IAAI,CAAC,YAAY,EAAE;YACjB,MAAM,CAAC,IAAI,CAAC,yCAAyC,CAAC,CAAC;YAEvD,OAAO,IAAI,CAAC;SACb;QAED,qCAAqC;QACrC,IAAI;YACF,YAAY,CAAC,OAAO,CAAC,CAAC;SACvB;QAAC,OAAO,GAAG,EAAE;YACZ,MAAM,CAAC,KAAK,CACV,4BAA4B,OAAO,OAAQ,GAAgC,CAAC,MAAM,EAAE,CACrF,CAAC;YAEF,OAAO,KAAK,CAAC;SACd;QAED,6BAA6B;QAC7B,MAAM,IAAI,GAAG,iBAAiB,EAAE,CAAC;QACjC,MAAM,YAAY,GAAG,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QAC5C,IAAI,IAAI,EAAE;YACR,MAAM,CAAC,IAAI,CAAC,+BAA+B,YAAY,CAAC,IAAI,CAAC,MAAM,YAAY,GAAG,CAAC,CAAC;SACrF;aAAM;YACL,iFAAiF;YACjF,+EAA+E;YAC/E,MAAM,CAAC,IAAI,CAAC,+BAA+B,YAAY,GAAG,CAAC,CAAC;YAC5D,MAAM,CAAC,IAAI,CAAC,qEAAqE,CAAC,CAAC;SACpF;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAEO,aAAa;QACnB,IAAI;YACF,MAAM,QAAQ,GAAG,IAAA,wBAAQ,EAAC,+BAA+B,EAAE;gBACzD,QAAQ,EAAE,MAAM;gBAChB,KAAK,EAAE,MAAM;aACd,CAAC,CAAC;YACH,MAAM,MAAM,GAAG,IAAA,wBAAQ,EAAC,wBAAwB,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC;YACvF,IAAI,MAAM,CAAC,IAAI,EAAE,CAAC,MAAM,KAAK,CAAC,EAAE;gBAC9B,OAAO,IAAI,CAAC;aACb;YAED,oDAAoD;YACpD,KAAK,MAAM,KAAK,IAAI,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE;gBACtC,MAAM,aAAa,GAAG,IAAI,CAAC,QAAQ,CACjC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAC/B,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,EAAE,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CACrD,CAAC;gBAEF,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,EAAE;oBACtE,OAAO,KAAK,CAAC;iBACd;aACF;SACF;QAAC,WAAM,GAAE;QAEV,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;OAGG;IACK,KAAK,CAAC,eAAe,CAC3B,gBAA0B,EAC1B,OAAO,GAAG,KAAK,EACf,IAAI,GAAG,KAAK;QAEZ,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,IAAA,uCAAoB,EAC5C,gBAAgB,IAAI,CAAC,yBAAyB,CAAC,gBAAgB,EAAE,IAAI,CAAC,EAAE,EACxE,IAAI,CAAC,OAAO,CAAC,MAAM,EACnB;YACE,OAAO;YACP,SAAS,EAAE,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,IAAI,KAAK,iCAAc,CAAC,IAAI;SACpE,CACF,CAAC;QAEF,OAAO,iBAAO,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC;IACnD,CAAC;IAEO,yBAAyB,CAC/B,gBAAsC,EACtC,IAAa;;QAEb,IAAI,IAAI,EAAE;YACR,OAAO,MAAM,CAAC;SACf;QAED,MAAM,sBAAsB,GAAG,gBAAgB,aAAhB,gBAAgB,uBAAhB,gBAAgB,CAAE,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,uBAAuB,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QAC9F,IAAI,sBAAsB,EAAE;YAC1B,6FAA6F;YAC7F,wEAAwE;YACxE,2EAA2E;YAE3E,iDAAiD;YACjD,wCAAwC;YACxC,MAAM,WAAW,GAAG,mBAAmB,CAAC,sBAAsB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAE9E,OAAO,MAAA,MAAA,MAAM,CAAC,KAAK,CAAC,WAAW,CAAC,0CAAE,KAAK,mCAAI,QAAQ,CAAC;SACrD;QAED,2HAA2H;QAC3H,2EAA2E;QAC3E,gFAAgF;QAChF,2GAA2G;QAE3G,+HAA+H;QAC/H,kIAAkI;QAClI,OAAO,iBAAO,CAAC,KAAK,CAAC;IACvB,CAAC;IAEO,KAAK,CAAC,aAAa,CAAC,WAAmB,EAAE,OAAiB,EAAE;QAClE,MAAM,EAAE,OAAO,EAAE,eAAe,EAAE,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;QAChG,IAAI,CAAC,OAAO,EAAE;YACZ,OAAO,CAAC,CAAC;SACV;QAED,8CAA8C;QAC9C,0CAA0C;QAC1C,MAAM,oBAAoB,GAAG,WAAW,CAAC,SAAS,CAAC,CAAC,EAAE,WAAW,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC;QACpF,MAAM,WAAW,GAAG,IAAA,WAAI,EAAC,eAAe,EAAE,oBAAoB,CAAC,CAAC;QAChE,MAAM,eAAe,GAAG,IAAA,WAAI,EAAC,WAAW,EAAE,cAAc,CAAC,CAAC;QAE1D,yCAAyC;QACzC,IAAI,OAA2B,CAAC;QAChC,IAAI,IAAA,eAAU,EAAC,eAAe,CAAC,EAAE;YAC/B,MAAM,OAAO,GAAG,MAAM,aAAE,CAAC,QAAQ,CAAC,eAAe,EAAE,OAAO,CAAC,CAAC;YAC5D,IAAI,OAAO,EAAE;gBACX,MAAM,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;gBACzC,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;gBAEjC,IAAI,OAAO,CAAC,MAAM,EAAE;oBAClB,OAAO,GAAG,IAAA,cAAO,EAAC,WAAW,EAAE,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;iBACjD;aACF;SACF;QAED,IAAI,CAAC,OAAO,EAAE;YACZ,MAAM,IAAI,KAAK,CAAC,4CAA4C,oBAAoB,GAAG,CAAC,CAAC;SACtF;QAED,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,IAAA,yBAAS,EAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,EAAE;YACxE,KAAK,EAAE,SAAS;YAChB,GAAG,EAAE;gBACH,GAAG,OAAO,CAAC,GAAG;gBACd,wBAAwB,EAAE,MAAM;gBAChC,gBAAgB,EAAE,OAAO;aAC1B;SACF,CAAC,CAAC;QAEH,IAAI,MAAM,KAAK,IAAI,IAAI,KAAK,EAAE;YAC5B,MAAM,KAAK,CAAC;SACb;QAED,OAAO,MAAM,aAAN,MAAM,cAAN,MAAM,GAAI,CAAC,CAAC;IACrB,CAAC;IAEO,mBAAmB,CAAC,OAAgB;QAC1C,2FAA2F;QAC3F,uFAAuF;QACvF,yEAAyE;QACzE,iBAAiB;QACjB,0EAA0E;QAC1E,8CAA8C;QAC9C,+GAA+G;QAC/G,wDAAwD;QACxD,sFAAsF;QACtF,IACE,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,IAAI,KAAK,iCAAc,CAAC,GAAG;YACvD,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,OAAO;YACnC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,OAAO,EAAE,OAAO,CAAC,EACxD;YACA,IAAI,OAAO,EAAE;gBACX,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CACtB,mEAAmE,CACpE,CAAC;aACH;YAED,OAAO,IAAI,CAAC;SACb;QAED,OAAO,KAAK,CAAC;IACf,CAAC;CACF;AA37BD,kDA27BC;AAED;;GAEG;AACH,SAAS,kBAAkB;IACzB,qDAAqD;IACrD,qEAAqE;IAErE,OAAO,IAAA,wBAAQ,EAAC,0CAA0C,CAAC,CAAC,QAAQ,EAAE,KAAK,EAAE,CAAC;AAChF,CAAC;AAED;;;;GAIG;AACH,SAAS,YAAY,CAAC,OAAe;IACnC,wCAAwC;IACxC,IAAA,wBAAQ,EAAC,YAAY,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC;IAE5D,0EAA0E;IAC1E,IAAA,wBAAQ,EAAC,6BAA6B,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,CAAC;AAC/F,CAAC;AAED;;GAEG;AACH,SAAS,iBAAiB;IACxB,IAAI;QACF,OAAO,IAAA,wBAAQ,EAAC,oBAAoB,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC;KACnF;IAAC,WAAM;QACN,OAAO,IAAI,CAAC;KACb;AACH,CAAC;AAED,SAAS,YAAY,CAAC,UAAkB;IACtC,OAAO,UAAU,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;AAChC,CAAC;AAED,SAAS,mBAAmB,CAAC,OAA2B;;IACtD,IAAI,CAAC,OAAO,EAAE;QACZ,OAAO,SAAS,CAAC;KAClB;IAED,IAAI,CAAC,+BAA+B,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE;QAClD,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,wBAAwB,CAAC,CAAC;QAEtD,IAAI,CAAC,KAAK,EAAE;YACV,OAAO,SAAS,CAAC;SAClB;QAED,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE;YACb,OAAO,GAAG,OAAO,CAAC,SAAS,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,MAAM,GAAG,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;SAC/F;aAAM,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE;YACpB,OAAO,GAAG,OAAO,CAAC,SAAS,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,IAAI,GAAG,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;SAC7F;aAAM;YACL,OAAO,SAAS,CAAC;SAClB;KACF;IAED,OAAO,MAAA,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,mCAAI,SAAS,CAAC;AAC5C,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 { UnsuccessfulWorkflowExecution } from '@angular-devkit/schematics';\nimport { NodeWorkflow } from '@angular-devkit/schematics/tools';\nimport { SpawnSyncReturns, execSync, spawnSync } from 'child_process';\nimport { existsSync, promises as fs } from 'fs';\nimport { createRequire } from 'module';\nimport npa from 'npm-package-arg';\nimport pickManifest from 'npm-pick-manifest';\nimport * as path from 'path';\nimport { join, resolve } from 'path';\nimport * as semver from 'semver';\nimport { Argv } from 'yargs';\nimport { PackageManager } from '../../../lib/config/workspace-schema';\nimport {\n  CommandModule,\n  CommandModuleError,\n  CommandScope,\n  Options,\n} from '../../command-builder/command-module';\nimport { SchematicEngineHost } from '../../command-builder/utilities/schematic-engine-host';\nimport { subscribeToWorkflow } from '../../command-builder/utilities/schematic-workflow';\nimport { colors } from '../../utilities/color';\nimport { disableVersionCheck } from '../../utilities/environment-options';\nimport { assertIsError } from '../../utilities/error';\nimport { writeErrorToLogFile } from '../../utilities/log-file';\nimport {\n  PackageIdentifier,\n  PackageManifest,\n  fetchPackageManifest,\n  fetchPackageMetadata,\n} from '../../utilities/package-metadata';\nimport {\n  PackageTreeNode,\n  findPackageJson,\n  getProjectDependencies,\n  readPackageJson,\n} from '../../utilities/package-tree';\nimport { VERSION } from '../../utilities/version';\n\ninterface UpdateCommandArgs {\n  packages?: string[];\n  force: boolean;\n  next: boolean;\n  'migrate-only'?: boolean;\n  name?: string;\n  from?: string;\n  to?: string;\n  'allow-dirty': boolean;\n  verbose: boolean;\n  'create-commits': boolean;\n}\n\nconst ANGULAR_PACKAGES_REGEXP = /^@(?:angular|nguniversal)\\//;\nconst UPDATE_SCHEMATIC_COLLECTION = path.join(__dirname, 'schematic/collection.json');\n\nexport class UpdateCommandModule extends CommandModule<UpdateCommandArgs> {\n  override scope = CommandScope.In;\n  protected override shouldReportAnalytics = false;\n\n  command = 'update [packages..]';\n  describe = 'Updates your workspace and its dependencies. See https://update.angular.io/.';\n  longDescriptionPath = join(__dirname, 'long-description.md');\n\n  builder(localYargs: Argv): Argv<UpdateCommandArgs> {\n    return localYargs\n      .positional('packages', {\n        description: 'The names of package(s) to update.',\n        type: 'string',\n        array: true,\n      })\n      .option('force', {\n        description: 'Ignore peer dependency version mismatches.',\n        type: 'boolean',\n        default: false,\n      })\n      .option('next', {\n        description: 'Use the prerelease version, including beta and RCs.',\n        type: 'boolean',\n        default: false,\n      })\n      .option('migrate-only', {\n        description: 'Only perform a migration, do not update the installed version.',\n        type: 'boolean',\n      })\n      .option('name', {\n        description:\n          'The name of the migration to run. ' +\n          `Only available with a single package being updated, and only with 'migrate-only' option.`,\n        type: 'string',\n        implies: ['migrate-only'],\n        conflicts: ['to', 'from'],\n      })\n      .option('from', {\n        description:\n          'Version from which to migrate from. ' +\n          `Only available with a single package being updated, and only with 'migrate-only'.`,\n        type: 'string',\n        implies: ['migrate-only'],\n        conflicts: ['name'],\n      })\n      .option('to', {\n        describe:\n          'Version up to which to apply migrations. Only available with a single package being updated, ' +\n          `and only with 'migrate-only' option. Requires 'from' to be specified. Default to the installed version detected.`,\n        type: 'string',\n        implies: ['from', 'migrate-only'],\n        conflicts: ['name'],\n      })\n      .option('allow-dirty', {\n        describe:\n          'Whether to allow updating when the repository contains modified or untracked files.',\n        type: 'boolean',\n        default: false,\n      })\n      .option('verbose', {\n        describe: 'Display additional details about internal operations during execution.',\n        type: 'boolean',\n        default: false,\n      })\n      .option('create-commits', {\n        describe: 'Create source control commits for updates and migrations.',\n        type: 'boolean',\n        alias: ['C'],\n        default: false,\n      })\n      .check(({ packages, 'allow-dirty': allowDirty, 'migrate-only': migrateOnly }) => {\n        const { logger } = this.context;\n\n        // This allows the user to easily reset any changes from the update.\n        if (packages?.length && !this.checkCleanGit()) {\n          if (allowDirty) {\n            logger.warn(\n              'Repository is not clean. Update changes will be mixed with pre-existing changes.',\n            );\n          } else {\n            throw new CommandModuleError(\n              'Repository is not clean. Please commit or stash any changes before updating.',\n            );\n          }\n        }\n\n        if (migrateOnly) {\n          if (packages?.length !== 1) {\n            throw new CommandModuleError(\n              `A single package must be specified when using the 'migrate-only' option.`,\n            );\n          }\n        }\n\n        return true;\n      })\n      .strict();\n  }\n\n  async run(options: Options<UpdateCommandArgs>): Promise<number | void> {\n    const { logger, packageManager } = this.context;\n\n    packageManager.ensureCompatibility();\n\n    // Check if the current installed CLI version is older than the latest compatible version.\n    // Skip when running `ng update` without a package name as this will not trigger an actual update.\n    if (!disableVersionCheck && options.packages?.length) {\n      const cliVersionToInstall = await this.checkCLIVersion(\n        options.packages,\n        options.verbose,\n        options.next,\n      );\n\n      if (cliVersionToInstall) {\n        logger.warn(\n          'The installed Angular CLI version is outdated.\\n' +\n            `Installing a temporary Angular CLI versioned ${cliVersionToInstall} to perform the update.`,\n        );\n\n        return this.runTempBinary(`@angular/cli@${cliVersionToInstall}`, process.argv.slice(2));\n      }\n    }\n\n    const packages: PackageIdentifier[] = [];\n    for (const request of options.packages ?? []) {\n      try {\n        const packageIdentifier = npa(request);\n\n        // only registry identifiers are supported\n        if (!packageIdentifier.registry) {\n          logger.error(`Package '${request}' is not a registry package identifer.`);\n\n          return 1;\n        }\n\n        if (packages.some((v) => v.name === packageIdentifier.name)) {\n          logger.error(`Duplicate package '${packageIdentifier.name}' specified.`);\n\n          return 1;\n        }\n\n        if (options.migrateOnly && packageIdentifier.rawSpec !== '*') {\n          logger.warn('Package specifier has no effect when using \"migrate-only\" option.');\n        }\n\n        // If next option is used and no specifier supplied, use next tag\n        if (options.next && packageIdentifier.rawSpec === '*') {\n          packageIdentifier.fetchSpec = 'next';\n        }\n\n        packages.push(packageIdentifier as PackageIdentifier);\n      } catch (e) {\n        assertIsError(e);\n        logger.error(e.message);\n\n        return 1;\n      }\n    }\n\n    logger.info(`Using package manager: ${colors.grey(packageManager.name)}`);\n    logger.info('Collecting installed dependencies...');\n\n    const rootDependencies = await getProjectDependencies(this.context.root);\n    logger.info(`Found ${rootDependencies.size} dependencies.`);\n\n    const workflow = new NodeWorkflow(this.context.root, {\n      packageManager: packageManager.name,\n      packageManagerForce: this.packageManagerForce(options.verbose),\n      // __dirname -> favor @schematics/update from this package\n      // Otherwise, use packages from the active workspace (migrations)\n      resolvePaths: [__dirname, this.context.root],\n      schemaValidation: true,\n      engineHostCreator: (options) => new SchematicEngineHost(options.resolvePaths),\n    });\n\n    if (packages.length === 0) {\n      // Show status\n      const { success } = await this.executeSchematic(\n        workflow,\n        UPDATE_SCHEMATIC_COLLECTION,\n        'update',\n        {\n          force: options.force,\n          next: options.next,\n          verbose: options.verbose,\n          packageManager: packageManager.name,\n          packages: [],\n        },\n      );\n\n      return success ? 0 : 1;\n    }\n\n    return options.migrateOnly\n      ? this.migrateOnly(workflow, (options.packages ?? [])[0], rootDependencies, options)\n      : this.updatePackagesAndMigrate(workflow, rootDependencies, options, packages);\n  }\n\n  private async executeSchematic(\n    workflow: NodeWorkflow,\n    collection: string,\n    schematic: string,\n    options: Record<string, unknown> = {},\n  ): Promise<{ success: boolean; files: Set<string> }> {\n    const { logger } = this.context;\n    const workflowSubscription = subscribeToWorkflow(workflow, logger);\n\n    // TODO: Allow passing a schematic instance directly\n    try {\n      await workflow\n        .execute({\n          collection,\n          schematic,\n          options,\n          logger,\n        })\n        .toPromise();\n\n      return { success: !workflowSubscription.error, files: workflowSubscription.files };\n    } catch (e) {\n      if (e instanceof UnsuccessfulWorkflowExecution) {\n        logger.error(`${colors.symbols.cross} Migration failed. See above for further details.\\n`);\n      } else {\n        assertIsError(e);\n        const logPath = writeErrorToLogFile(e);\n        logger.fatal(\n          `${colors.symbols.cross} Migration failed: ${e.message}\\n` +\n            `  See \"${logPath}\" for further details.\\n`,\n        );\n      }\n\n      return { success: false, files: workflowSubscription.files };\n    } finally {\n      workflowSubscription.unsubscribe();\n    }\n  }\n\n  /**\n   * @return Whether or not the migration was performed successfully.\n   */\n  private async executeMigration(\n    workflow: NodeWorkflow,\n    packageName: string,\n    collectionPath: string,\n    migrationName: string,\n    commit?: boolean,\n  ): Promise<number> {\n    const { logger } = this.context;\n    const collection = workflow.engine.createCollection(collectionPath);\n    const name = collection.listSchematicNames().find((name) => name === migrationName);\n    if (!name) {\n      logger.error(`Cannot find migration '${migrationName}' in '${packageName}'.`);\n\n      return 1;\n    }\n\n    logger.info(colors.cyan(`** Executing '${migrationName}' of package '${packageName}' **\\n`));\n    const schematic = workflow.engine.createSchematic(name, collection);\n\n    return this.executePackageMigrations(workflow, [schematic.description], packageName, commit);\n  }\n\n  /**\n   * @return Whether or not the migrations were performed successfully.\n   */\n  private async executeMigrations(\n    workflow: NodeWorkflow,\n    packageName: string,\n    collectionPath: string,\n    from: string,\n    to: string,\n    commit?: boolean,\n  ): Promise<number> {\n    const collection = workflow.engine.createCollection(collectionPath);\n    const migrationRange = new semver.Range(\n      '>' + (semver.prerelease(from) ? from.split('-')[0] + '-0' : from) + ' <=' + to.split('-')[0],\n    );\n    const migrations = [];\n\n    for (const name of collection.listSchematicNames()) {\n      const schematic = workflow.engine.createSchematic(name, collection);\n      const description = schematic.description as typeof schematic.description & {\n        version?: string;\n      };\n      description.version = coerceVersionNumber(description.version);\n      if (!description.version) {\n        continue;\n      }\n\n      if (semver.satisfies(description.version, migrationRange, { includePrerelease: true })) {\n        migrations.push(description as typeof schematic.description & { version: string });\n      }\n    }\n\n    if (migrations.length === 0) {\n      return 0;\n    }\n\n    migrations.sort((a, b) => semver.compare(a.version, b.version) || a.name.localeCompare(b.name));\n\n    this.context.logger.info(\n      colors.cyan(`** Executing migrations of package '${packageName}' **\\n`),\n    );\n\n    return this.executePackageMigrations(workflow, migrations, packageName, commit);\n  }\n\n  private async executePackageMigrations(\n    workflow: NodeWorkflow,\n    migrations: Iterable<{ name: string; description: string; collection: { name: string } }>,\n    packageName: string,\n    commit = false,\n  ): Promise<number> {\n    const { logger } = this.context;\n    for (const migration of migrations) {\n      const [title, ...description] = migration.description.split('. ');\n\n      logger.info(\n        colors.cyan(colors.symbols.pointer) +\n          ' ' +\n          colors.bold(title.endsWith('.') ? title : title + '.'),\n      );\n\n      if (description.length) {\n        logger.info('  ' + description.join('.\\n  '));\n      }\n\n      const { success, files } = await this.executeSchematic(\n        workflow,\n        migration.collection.name,\n        migration.name,\n      );\n      if (!success) {\n        return 1;\n      }\n\n      let modifiedFilesText: string;\n      switch (files.size) {\n        case 0:\n          modifiedFilesText = 'No changes made';\n          break;\n        case 1:\n          modifiedFilesText = '1 file modified';\n          break;\n        default:\n          modifiedFilesText = `${files.size} files modified`;\n          break;\n      }\n\n      logger.info(`  Migration completed (${modifiedFilesText}).`);\n\n      // Commit migration\n      if (commit) {\n        const commitPrefix = `${packageName} migration - ${migration.name}`;\n        const commitMessage = migration.description\n          ? `${commitPrefix}\\n\\n${migration.description}`\n          : commitPrefix;\n        const committed = this.commit(commitMessage);\n        if (!committed) {\n          // Failed to commit, something went wrong. Abort the update.\n          return 1;\n        }\n      }\n\n      logger.info(''); // Extra trailing newline.\n    }\n\n    return 0;\n  }\n\n  private async migrateOnly(\n    workflow: NodeWorkflow,\n    packageName: string,\n    rootDependencies: Map<string, PackageTreeNode>,\n    options: Options<UpdateCommandArgs>,\n  ): Promise<number | void> {\n    const { logger } = this.context;\n    const packageDependency = rootDependencies.get(packageName);\n    let packagePath = packageDependency?.path;\n    let packageNode = packageDependency?.package;\n    if (packageDependency && !packageNode) {\n      logger.error('Package found in package.json but is not installed.');\n\n      return 1;\n    } else if (!packageDependency) {\n      // Allow running migrations on transitively installed dependencies\n      // There can technically be nested multiple versions\n      // TODO: If multiple, this should find all versions and ask which one to use\n      const packageJson = findPackageJson(this.context.root, packageName);\n      if (packageJson) {\n        packagePath = path.dirname(packageJson);\n        packageNode = await readPackageJson(packageJson);\n      }\n    }\n\n    if (!packageNode || !packagePath) {\n      logger.error('Package is not installed.');\n\n      return 1;\n    }\n\n    const updateMetadata = packageNode['ng-update'];\n    let migrations = updateMetadata?.migrations;\n    if (migrations === undefined) {\n      logger.error('Package does not provide migrations.');\n\n      return 1;\n    } else if (typeof migrations !== 'string') {\n      logger.error('Package contains a malformed migrations field.');\n\n      return 1;\n    } else if (path.posix.isAbsolute(migrations) || path.win32.isAbsolute(migrations)) {\n      logger.error(\n        'Package contains an invalid migrations field. Absolute paths are not permitted.',\n      );\n\n      return 1;\n    }\n\n    // Normalize slashes\n    migrations = migrations.replace(/\\\\/g, '/');\n\n    if (migrations.startsWith('../')) {\n      logger.error(\n        'Package contains an invalid migrations field. Paths outside the package root are not permitted.',\n      );\n\n      return 1;\n    }\n\n    // Check if it is a package-local location\n    const localMigrations = path.join(packagePath, migrations);\n    if (existsSync(localMigrations)) {\n      migrations = localMigrations;\n    } else {\n      // Try to resolve from package location.\n      // This avoids issues with package hoisting.\n      try {\n        const packageRequire = createRequire(packagePath + '/');\n        migrations = packageRequire.resolve(migrations);\n      } catch (e) {\n        assertIsError(e);\n        if (e.code === 'MODULE_NOT_FOUND') {\n          logger.error('Migrations for package were not found.');\n        } else {\n          logger.error(`Unable to resolve migrations for package.  [${e.message}]`);\n        }\n\n        return 1;\n      }\n    }\n\n    if (options.name) {\n      return this.executeMigration(\n        workflow,\n        packageName,\n        migrations,\n        options.name,\n        options.createCommits,\n      );\n    }\n\n    const from = coerceVersionNumber(options.from);\n    if (!from) {\n      logger.error(`\"from\" value [${options.from}] is not a valid version.`);\n\n      return 1;\n    }\n\n    return this.executeMigrations(\n      workflow,\n      packageName,\n      migrations,\n      from,\n      options.to || packageNode.version,\n      options.createCommits,\n    );\n  }\n\n  // eslint-disable-next-line max-lines-per-function\n  private async updatePackagesAndMigrate(\n    workflow: NodeWorkflow,\n    rootDependencies: Map<string, PackageTreeNode>,\n    options: Options<UpdateCommandArgs>,\n    packages: PackageIdentifier[],\n  ): Promise<number> {\n    const { logger } = this.context;\n\n    const logVerbose = (message: string) => {\n      if (options.verbose) {\n        logger.info(message);\n      }\n    };\n\n    const requests: {\n      identifier: PackageIdentifier;\n      node: PackageTreeNode;\n    }[] = [];\n\n    // Validate packages actually are part of the workspace\n    for (const pkg of packages) {\n      const node = rootDependencies.get(pkg.name);\n      if (!node?.package) {\n        logger.error(`Package '${pkg.name}' is not a dependency.`);\n\n        return 1;\n      }\n\n      // If a specific version is requested and matches the installed version, skip.\n      if (pkg.type === 'version' && node.package.version === pkg.fetchSpec) {\n        logger.info(`Package '${pkg.name}' is already at '${pkg.fetchSpec}'.`);\n        continue;\n      }\n\n      requests.push({ identifier: pkg, node });\n    }\n\n    if (requests.length === 0) {\n      return 0;\n    }\n\n    logger.info('Fetching dependency metadata from registry...');\n\n    const packagesToUpdate: string[] = [];\n    for (const { identifier: requestIdentifier, node } of requests) {\n      const packageName = requestIdentifier.name;\n\n      let metadata;\n      try {\n        // Metadata requests are internally cached; multiple requests for same name\n        // does not result in additional network traffic\n        metadata = await fetchPackageMetadata(packageName, logger, {\n          verbose: options.verbose,\n        });\n      } catch (e) {\n        assertIsError(e);\n        logger.error(`Error fetching metadata for '${packageName}': ` + e.message);\n\n        return 1;\n      }\n\n      // Try to find a package version based on the user requested package specifier\n      // registry specifier types are either version, range, or tag\n      let manifest: PackageManifest | undefined;\n      if (\n        requestIdentifier.type === 'version' ||\n        requestIdentifier.type === 'range' ||\n        requestIdentifier.type === 'tag'\n      ) {\n        try {\n          manifest = pickManifest(metadata, requestIdentifier.fetchSpec);\n        } catch (e) {\n          assertIsError(e);\n          if (e.code === 'ETARGET') {\n            // If not found and next was used and user did not provide a specifier, try latest.\n            // Package may not have a next tag.\n            if (\n              requestIdentifier.type === 'tag' &&\n              requestIdentifier.fetchSpec === 'next' &&\n              !requestIdentifier.rawSpec\n            ) {\n              try {\n                manifest = pickManifest(metadata, 'latest');\n              } catch (e) {\n                assertIsError(e);\n                if (e.code !== 'ETARGET' && e.code !== 'ENOVERSIONS') {\n                  throw e;\n                }\n              }\n            }\n          } else if (e.code !== 'ENOVERSIONS') {\n            throw e;\n          }\n        }\n      }\n\n      if (!manifest) {\n        logger.error(\n          `Package specified by '${requestIdentifier.raw}' does not exist within the registry.`,\n        );\n\n        return 1;\n      }\n\n      if (manifest.version === node.package?.version) {\n        logger.info(`Package '${packageName}' is already up to date.`);\n        continue;\n      }\n\n      if (node.package && ANGULAR_PACKAGES_REGEXP.test(node.package.name)) {\n        const { name, version } = node.package;\n        const toBeInstalledMajorVersion = +manifest.version.split('.')[0];\n        const currentMajorVersion = +version.split('.')[0];\n\n        if (toBeInstalledMajorVersion - currentMajorVersion > 1) {\n          // Only allow updating a single version at a time.\n          if (currentMajorVersion < 6) {\n            // Before version 6, the major versions were not always sequential.\n            // Example @angular/core skipped version 3, @angular/cli skipped versions 2-5.\n            logger.error(\n              `Updating multiple major versions of '${name}' at once is not supported. Please migrate each major version individually.\\n` +\n                `For more information about the update process, see https://update.angular.io/.`,\n            );\n          } else {\n            const nextMajorVersionFromCurrent = currentMajorVersion + 1;\n\n            logger.error(\n              `Updating multiple major versions of '${name}' at once is not supported. Please migrate each major version individually.\\n` +\n                `Run 'ng update ${name}@${nextMajorVersionFromCurrent}' in your workspace directory ` +\n                `to update to latest '${nextMajorVersionFromCurrent}.x' version of '${name}'.\\n\\n` +\n                `For more information about the update process, see https://update.angular.io/?v=${currentMajorVersion}.0-${nextMajorVersionFromCurrent}.0`,\n            );\n          }\n\n          return 1;\n        }\n      }\n\n      packagesToUpdate.push(requestIdentifier.toString());\n    }\n\n    if (packagesToUpdate.length === 0) {\n      return 0;\n    }\n\n    const { success } = await this.executeSchematic(\n      workflow,\n      UPDATE_SCHEMATIC_COLLECTION,\n      'update',\n      {\n        verbose: options.verbose,\n        force: options.force,\n        next: options.next,\n        packageManager: this.context.packageManager.name,\n        packages: packagesToUpdate,\n      },\n    );\n\n    if (success) {\n      try {\n        await fs.rm(path.join(this.context.root, 'node_modules'), {\n          force: true,\n          recursive: true,\n          maxRetries: 3,\n        });\n      } catch {}\n\n      const installationSuccess = await this.context.packageManager.installAll(\n        this.packageManagerForce(options.verbose) ? ['--force'] : [],\n        this.context.root,\n      );\n\n      if (!installationSuccess) {\n        return 1;\n      }\n    }\n\n    if (success && options.createCommits) {\n      if (!this.commit(`Angular CLI update for packages - ${packagesToUpdate.join(', ')}`)) {\n        return 1;\n      }\n    }\n\n    // This is a temporary workaround to allow data to be passed back from the update schematic\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    const migrations = (global as any).externalMigrations as {\n      package: string;\n      collection: string;\n      from: string;\n      to: string;\n    }[];\n\n    if (success && migrations) {\n      const rootRequire = createRequire(this.context.root + '/');\n      for (const migration of migrations) {\n        // Resolve the package from the workspace root, as otherwise it will be resolved from the temp\n        // installed CLI version.\n        let packagePath;\n        logVerbose(\n          `Resolving migration package '${migration.package}' from '${this.context.root}'...`,\n        );\n        try {\n          try {\n            packagePath = path.dirname(\n              // This may fail if the `package.json` is not exported as an entry point\n              rootRequire.resolve(path.join(migration.package, 'package.json')),\n            );\n          } catch (e) {\n            assertIsError(e);\n            if (e.code === 'MODULE_NOT_FOUND') {\n              // Fallback to trying to resolve the package's main entry point\n              packagePath = rootRequire.resolve(migration.package);\n            } else {\n              throw e;\n            }\n          }\n        } catch (e) {\n          assertIsError(e);\n          if (e.code === 'MODULE_NOT_FOUND') {\n            logVerbose(e.toString());\n            logger.error(\n              `Migrations for package (${migration.package}) were not found.` +\n                ' The package could not be found in the workspace.',\n            );\n          } else {\n            logger.error(\n              `Unable to resolve migrations for package (${migration.package}).  [${e.message}]`,\n            );\n          }\n\n          return 1;\n        }\n\n        let migrations;\n\n        // Check if it is a package-local location\n        const localMigrations = path.join(packagePath, migration.collection);\n        if (existsSync(localMigrations)) {\n          migrations = localMigrations;\n        } else {\n          // Try to resolve from package location.\n          // This avoids issues with package hoisting.\n          try {\n            const packageRequire = createRequire(packagePath + '/');\n            migrations = packageRequire.resolve(migration.collection);\n          } catch (e) {\n            assertIsError(e);\n            if (e.code === 'MODULE_NOT_FOUND') {\n              logger.error(`Migrations for package (${migration.package}) were not found.`);\n            } else {\n              logger.error(\n                `Unable to resolve migrations for package (${migration.package}).  [${e.message}]`,\n              );\n            }\n\n            return 1;\n          }\n        }\n        const result = await this.executeMigrations(\n          workflow,\n          migration.package,\n          migrations,\n          migration.from,\n          migration.to,\n          options.createCommits,\n        );\n\n        // A non-zero value is a failure for the package's migrations\n        if (result !== 0) {\n          return result;\n        }\n      }\n    }\n\n    return success ? 0 : 1;\n  }\n  /**\n   * @return Whether or not the commit was successful.\n   */\n  private commit(message: string): boolean {\n    const { logger } = this.context;\n\n    // Check if a commit is needed.\n    let commitNeeded: boolean;\n    try {\n      commitNeeded = hasChangesToCommit();\n    } catch (err) {\n      logger.error(`  Failed to read Git tree:\\n${(err as SpawnSyncReturns<string>).stderr}`);\n\n      return false;\n    }\n\n    if (!commitNeeded) {\n      logger.info('  No changes to commit after migration.');\n\n      return true;\n    }\n\n    // Commit changes and abort on error.\n    try {\n      createCommit(message);\n    } catch (err) {\n      logger.error(\n        `Failed to commit update (${message}):\\n${(err as SpawnSyncReturns<string>).stderr}`,\n      );\n\n      return false;\n    }\n\n    // Notify user of the commit.\n    const hash = findCurrentGitSha();\n    const shortMessage = message.split('\\n')[0];\n    if (hash) {\n      logger.info(`  Committed migration step (${getShortHash(hash)}): ${shortMessage}.`);\n    } else {\n      // Commit was successful, but reading the hash was not. Something weird happened,\n      // but nothing that would stop the update. Just log the weirdness and continue.\n      logger.info(`  Committed migration step: ${shortMessage}.`);\n      logger.warn('  Failed to look up hash of most recent commit, continuing anyways.');\n    }\n\n    return true;\n  }\n\n  private checkCleanGit(): boolean {\n    try {\n      const topLevel = execSync('git rev-parse --show-toplevel', {\n        encoding: 'utf8',\n        stdio: 'pipe',\n      });\n      const result = execSync('git status --porcelain', { encoding: 'utf8', stdio: 'pipe' });\n      if (result.trim().length === 0) {\n        return true;\n      }\n\n      // Only files inside the workspace root are relevant\n      for (const entry of result.split('\\n')) {\n        const relativeEntry = path.relative(\n          path.resolve(this.context.root),\n          path.resolve(topLevel.trim(), entry.slice(3).trim()),\n        );\n\n        if (!relativeEntry.startsWith('..') && !path.isAbsolute(relativeEntry)) {\n          return false;\n        }\n      }\n    } catch {}\n\n    return true;\n  }\n\n  /**\n   * Checks if the current installed CLI version is older or newer than a compatible version.\n   * @returns the version to install or null when there is no update to install.\n   */\n  private async checkCLIVersion(\n    packagesToUpdate: string[],\n    verbose = false,\n    next = false,\n  ): Promise<string | null> {\n    const { version } = await fetchPackageManifest(\n      `@angular/cli@${this.getCLIUpdateRunnerVersion(packagesToUpdate, next)}`,\n      this.context.logger,\n      {\n        verbose,\n        usingYarn: this.context.packageManager.name === PackageManager.Yarn,\n      },\n    );\n\n    return VERSION.full === version ? null : version;\n  }\n\n  private getCLIUpdateRunnerVersion(\n    packagesToUpdate: string[] | undefined,\n    next: boolean,\n  ): string | number {\n    if (next) {\n      return 'next';\n    }\n\n    const updatingAngularPackage = packagesToUpdate?.find((r) => ANGULAR_PACKAGES_REGEXP.test(r));\n    if (updatingAngularPackage) {\n      // If we are updating any Angular package we can update the CLI to the target version because\n      // migrations for @angular/core@13 can be executed using Angular/cli@13.\n      // This is same behaviour as `npx @angular/cli@13 update @angular/core@13`.\n\n      // `@angular/cli@13` -> ['', 'angular/cli', '13']\n      // `@angular/cli` -> ['', 'angular/cli']\n      const tempVersion = coerceVersionNumber(updatingAngularPackage.split('@')[2]);\n\n      return semver.parse(tempVersion)?.major ?? 'latest';\n    }\n\n    // When not updating an Angular package we cannot determine which schematic runtime the migration should to be executed in.\n    // Typically, we can assume that the `@angular/cli` was updated previously.\n    // Example: Angular official packages are typically updated prior to NGRX etc...\n    // Therefore, we only update to the latest patch version of the installed major version of the Angular CLI.\n\n    // This is important because we might end up in a scenario where locally Angular v12 is installed, updating NGRX from 11 to 12.\n    // We end up using Angular ClI v13 to run the migrations if we run the migrations using the CLI installed major version + 1 logic.\n    return VERSION.major;\n  }\n\n  private async runTempBinary(packageName: string, args: string[] = []): Promise<number> {\n    const { success, tempNodeModules } = await this.context.packageManager.installTemp(packageName);\n    if (!success) {\n      return 1;\n    }\n\n    // Remove version/tag etc... from package name\n    // Ex: @angular/cli@latest -> @angular/cli\n    const packageNameNoVersion = packageName.substring(0, packageName.lastIndexOf('@'));\n    const pkgLocation = join(tempNodeModules, packageNameNoVersion);\n    const packageJsonPath = join(pkgLocation, 'package.json');\n\n    // Get a binary location for this package\n    let binPath: string | undefined;\n    if (existsSync(packageJsonPath)) {\n      const content = await fs.readFile(packageJsonPath, 'utf-8');\n      if (content) {\n        const { bin = {} } = JSON.parse(content);\n        const binKeys = Object.keys(bin);\n\n        if (binKeys.length) {\n          binPath = resolve(pkgLocation, bin[binKeys[0]]);\n        }\n      }\n    }\n\n    if (!binPath) {\n      throw new Error(`Cannot locate bin for temporary package: ${packageNameNoVersion}.`);\n    }\n\n    const { status, error } = spawnSync(process.execPath, [binPath, ...args], {\n      stdio: 'inherit',\n      env: {\n        ...process.env,\n        NG_DISABLE_VERSION_CHECK: 'true',\n        NG_CLI_ANALYTICS: 'false',\n      },\n    });\n\n    if (status === null && error) {\n      throw error;\n    }\n\n    return status ?? 0;\n  }\n\n  private packageManagerForce(verbose: boolean): boolean {\n    // npm 7+ can fail due to it incorrectly resolving peer dependencies that have valid SemVer\n    // ranges during an update. Update will set correct versions of dependencies within the\n    // package.json file. The force option is set to workaround these errors.\n    // Example error:\n    // npm ERR! Conflicting peer dependency: @angular/compiler-cli@14.0.0-rc.0\n    // npm ERR! node_modules/@angular/compiler-cli\n    // npm ERR!   peer @angular/compiler-cli@\"^14.0.0 || ^14.0.0-rc\" from @angular-devkit/build-angular@14.0.0-rc.0\n    // npm ERR!   node_modules/@angular-devkit/build-angular\n    // npm ERR!     dev @angular-devkit/build-angular@\"~14.0.0-rc.0\" from the root project\n    if (\n      this.context.packageManager.name === PackageManager.Npm &&\n      this.context.packageManager.version &&\n      semver.gte(this.context.packageManager.version, '7.0.0')\n    ) {\n      if (verbose) {\n        this.context.logger.info(\n          'NPM 7+ detected -- enabling force option for package installation',\n        );\n      }\n\n      return true;\n    }\n\n    return false;\n  }\n}\n\n/**\n * @return Whether or not the working directory has Git changes to commit.\n */\nfunction hasChangesToCommit(): boolean {\n  // List all modified files not covered by .gitignore.\n  // If any files are returned, then there must be something to commit.\n\n  return execSync('git ls-files -m -d -o --exclude-standard').toString() !== '';\n}\n\n/**\n * Precondition: Must have pending changes to commit, they do not need to be staged.\n * Postcondition: The Git working tree is committed and the repo is clean.\n * @param message The commit message to use.\n */\nfunction createCommit(message: string) {\n  // Stage entire working tree for commit.\n  execSync('git add -A', { encoding: 'utf8', stdio: 'pipe' });\n\n  // Commit with the message passed via stdin to avoid bash escaping issues.\n  execSync('git commit --no-verify -F -', { encoding: 'utf8', stdio: 'pipe', input: message });\n}\n\n/**\n * @return The Git SHA hash of the HEAD commit. Returns null if unable to retrieve the hash.\n */\nfunction findCurrentGitSha(): string | null {\n  try {\n    return execSync('git rev-parse HEAD', { encoding: 'utf8', stdio: 'pipe' }).trim();\n  } catch {\n    return null;\n  }\n}\n\nfunction getShortHash(commitHash: string): string {\n  return commitHash.slice(0, 9);\n}\n\nfunction coerceVersionNumber(version: string | undefined): string | undefined {\n  if (!version) {\n    return undefined;\n  }\n\n  if (!/^\\d{1,30}\\.\\d{1,30}\\.\\d{1,30}/.test(version)) {\n    const match = version.match(/^\\d{1,30}(\\.\\d{1,30})*/);\n\n    if (!match) {\n      return undefined;\n    }\n\n    if (!match[1]) {\n      version = version.substring(0, match[0].length) + '.0.0' + version.substring(match[0].length);\n    } else if (!match[2]) {\n      version = version.substring(0, match[0].length) + '.0' + version.substring(match[0].length);\n    } else {\n      return undefined;\n    }\n  }\n\n  return semver.valid(version) ?? undefined;\n}\n"]}
@@ -38,6 +38,7 @@ export interface Schema {
38
38
  * Display additional details during the update process.
39
39
  */
40
40
  verbose?: boolean;
41
+ [property: string]: any;
41
42
  }
42
43
  /**
43
44
  * The preferred package manager configuration files to use for registry settings.
@@ -13,4 +13,4 @@ var PackageManager;
13
13
  PackageManager["Pnpm"] = "pnpm";
14
14
  PackageManager["Yarn"] = "yarn";
15
15
  })(PackageManager = exports.PackageManager || (exports.PackageManager = {}));
16
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NoZW1hLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYW5ndWxhci9jbGkvc3JjL2NvbW1hbmRzL3VwZGF0ZS9zY2hlbWF0aWMvc2NoZW1hLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFDQSxtRkFBbUY7QUFDbkYsb0ZBQW9GOzs7QUE0Q3BGOztHQUVHO0FBQ0gsSUFBWSxjQUtYO0FBTEQsV0FBWSxjQUFjO0lBQ3RCLCtCQUFhLENBQUE7SUFDYiw2QkFBVyxDQUFBO0lBQ1gsK0JBQWEsQ0FBQTtJQUNiLCtCQUFhLENBQUE7QUFDakIsQ0FBQyxFQUxXLGNBQWMsR0FBZCxzQkFBYyxLQUFkLHNCQUFjLFFBS3pCIiwic291cmNlc0NvbnRlbnQiOlsiXG4vLyBUSElTIEZJTEUgSVMgQVVUT01BVElDQUxMWSBHRU5FUkFURUQuIFRPIFVQREFURSBUSElTIEZJTEUgWU9VIE5FRUQgVE8gQ0hBTkdFIFRIRVxuLy8gQ09SUkVTUE9ORElORyBKU09OIFNDSEVNQSBGSUxFLCBUSEVOIFJVTiBkZXZraXQtYWRtaW4gYnVpbGQgKG9yIGJhemVsIGJ1aWxkIC4uLikuXG5cbmV4cG9ydCBpbnRlcmZhY2UgU2NoZW1hIHtcbiAgICAvKipcbiAgICAgKiBXaGVuIGZhbHNlICh0aGUgZGVmYXVsdCksIHJlcG9ydHMgYW4gZXJyb3IgaWYgaW5zdGFsbGVkIHBhY2thZ2VzIGFyZSBpbmNvbXBhdGlibGUgd2l0aFxuICAgICAqIHRoZSB1cGRhdGUuXG4gICAgICovXG4gICAgZm9yY2U/OiBib29sZWFuO1xuICAgIC8qKlxuICAgICAqIFdoZW4gdXNpbmcgYC0tbWlncmF0ZU9ubHlgIGZvciBhIHNpbmdsZSBwYWNrYWdlLCB0aGUgdmVyc2lvbiBvZiB0aGF0IHBhY2thZ2UgZnJvbSB3aGljaFxuICAgICAqIHRvIG1pZ3JhdGUuXG4gICAgICovXG4gICAgZnJvbT86IHN0cmluZztcbiAgICAvKipcbiAgICAgKiBQZXJmb3JtIGEgbWlncmF0aW9uLCBidXQgZG8gbm90IHVwZGF0ZSB0aGUgaW5zdGFsbGVkIHZlcnNpb24uXG4gICAgICovXG4gICAgbWlncmF0ZU9ubHk/OiBib29sZWFuO1xuICAgIC8qKlxuICAgICAqIFVwZGF0ZSB0byB0aGUgbGF0ZXN0IHZlcnNpb24sIGluY2x1ZGluZyBiZXRhIGFuZCBSQ3MuXG4gICAgICovXG4gICAgbmV4dD86IGJvb2xlYW47XG4gICAgLyoqXG4gICAgICogVGhlIHByZWZlcnJlZCBwYWNrYWdlIG1hbmFnZXIgY29uZmlndXJhdGlvbiBmaWxlcyB0byB1c2UgZm9yIHJlZ2lzdHJ5IHNldHRpbmdzLlxuICAgICAqL1xuICAgIHBhY2thZ2VNYW5hZ2VyPzogUGFja2FnZU1hbmFnZXI7XG4gICAgLyoqXG4gICAgICogVGhlIHBhY2thZ2Ugb3IgcGFja2FnZXMgdG8gdXBkYXRlLlxuICAgICAqL1xuICAgIHBhY2thZ2VzPzogc3RyaW5nW107XG4gICAgLyoqXG4gICAgICogVGhlIG5wbSByZWdpc3RyeSB0byB1c2UuXG4gICAgICovXG4gICAgcmVnaXN0cnk/OiBzdHJpbmc7XG4gICAgLyoqXG4gICAgICogV2hlbiB1c2luZyBgLS1taWdyYXRlT25seWAgZm9yIGEgc2luZ2xlIHBhY2thZ2UsIHRoZSB2ZXJzaW9uIG9mIHRoYXQgcGFja2FnZSB0byB3aGljaCB0b1xuICAgICAqIG1pZ3JhdGUuXG4gICAgICovXG4gICAgdG8/OiBzdHJpbmc7XG4gICAgLyoqXG4gICAgICogRGlzcGxheSBhZGRpdGlvbmFsIGRldGFpbHMgZHVyaW5nIHRoZSB1cGRhdGUgcHJvY2Vzcy5cbiAgICAgKi9cbiAgICB2ZXJib3NlPzogYm9vbGVhbjtcbn1cblxuLyoqXG4gKiBUaGUgcHJlZmVycmVkIHBhY2thZ2UgbWFuYWdlciBjb25maWd1cmF0aW9uIGZpbGVzIHRvIHVzZSBmb3IgcmVnaXN0cnkgc2V0dGluZ3MuXG4gKi9cbmV4cG9ydCBlbnVtIFBhY2thZ2VNYW5hZ2VyIHtcbiAgICBDbnBtID0gXCJjbnBtXCIsXG4gICAgTnBtID0gXCJucG1cIixcbiAgICBQbnBtID0gXCJwbnBtXCIsXG4gICAgWWFybiA9IFwieWFyblwiLFxufVxuIl19
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NoZW1hLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYW5ndWxhci9jbGkvc3JjL2NvbW1hbmRzL3VwZGF0ZS9zY2hlbWF0aWMvc2NoZW1hLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFDQSxtRkFBbUY7QUFDbkYsb0ZBQW9GOzs7QUE2Q3BGOztHQUVHO0FBQ0gsSUFBWSxjQUtYO0FBTEQsV0FBWSxjQUFjO0lBQ3RCLCtCQUFhLENBQUE7SUFDYiw2QkFBVyxDQUFBO0lBQ1gsK0JBQWEsQ0FBQTtJQUNiLCtCQUFhLENBQUE7QUFDakIsQ0FBQyxFQUxXLGNBQWMsR0FBZCxzQkFBYyxLQUFkLHNCQUFjLFFBS3pCIiwic291cmNlc0NvbnRlbnQiOlsiXG4vLyBUSElTIEZJTEUgSVMgQVVUT01BVElDQUxMWSBHRU5FUkFURUQuIFRPIFVQREFURSBUSElTIEZJTEUgWU9VIE5FRUQgVE8gQ0hBTkdFIFRIRVxuLy8gQ09SUkVTUE9ORElORyBKU09OIFNDSEVNQSBGSUxFLCBUSEVOIFJVTiBkZXZraXQtYWRtaW4gYnVpbGQgKG9yIGJhemVsIGJ1aWxkIC4uLikuXG5cbmV4cG9ydCBpbnRlcmZhY2UgU2NoZW1hIHtcbiAgICAvKipcbiAgICAgKiBXaGVuIGZhbHNlICh0aGUgZGVmYXVsdCksIHJlcG9ydHMgYW4gZXJyb3IgaWYgaW5zdGFsbGVkIHBhY2thZ2VzIGFyZSBpbmNvbXBhdGlibGUgd2l0aFxuICAgICAqIHRoZSB1cGRhdGUuXG4gICAgICovXG4gICAgZm9yY2U/OiBib29sZWFuO1xuICAgIC8qKlxuICAgICAqIFdoZW4gdXNpbmcgYC0tbWlncmF0ZU9ubHlgIGZvciBhIHNpbmdsZSBwYWNrYWdlLCB0aGUgdmVyc2lvbiBvZiB0aGF0IHBhY2thZ2UgZnJvbSB3aGljaFxuICAgICAqIHRvIG1pZ3JhdGUuXG4gICAgICovXG4gICAgZnJvbT86IHN0cmluZztcbiAgICAvKipcbiAgICAgKiBQZXJmb3JtIGEgbWlncmF0aW9uLCBidXQgZG8gbm90IHVwZGF0ZSB0aGUgaW5zdGFsbGVkIHZlcnNpb24uXG4gICAgICovXG4gICAgbWlncmF0ZU9ubHk/OiBib29sZWFuO1xuICAgIC8qKlxuICAgICAqIFVwZGF0ZSB0byB0aGUgbGF0ZXN0IHZlcnNpb24sIGluY2x1ZGluZyBiZXRhIGFuZCBSQ3MuXG4gICAgICovXG4gICAgbmV4dD86IGJvb2xlYW47XG4gICAgLyoqXG4gICAgICogVGhlIHByZWZlcnJlZCBwYWNrYWdlIG1hbmFnZXIgY29uZmlndXJhdGlvbiBmaWxlcyB0byB1c2UgZm9yIHJlZ2lzdHJ5IHNldHRpbmdzLlxuICAgICAqL1xuICAgIHBhY2thZ2VNYW5hZ2VyPzogUGFja2FnZU1hbmFnZXI7XG4gICAgLyoqXG4gICAgICogVGhlIHBhY2thZ2Ugb3IgcGFja2FnZXMgdG8gdXBkYXRlLlxuICAgICAqL1xuICAgIHBhY2thZ2VzPzogc3RyaW5nW107XG4gICAgLyoqXG4gICAgICogVGhlIG5wbSByZWdpc3RyeSB0byB1c2UuXG4gICAgICovXG4gICAgcmVnaXN0cnk/OiBzdHJpbmc7XG4gICAgLyoqXG4gICAgICogV2hlbiB1c2luZyBgLS1taWdyYXRlT25seWAgZm9yIGEgc2luZ2xlIHBhY2thZ2UsIHRoZSB2ZXJzaW9uIG9mIHRoYXQgcGFja2FnZSB0byB3aGljaCB0b1xuICAgICAqIG1pZ3JhdGUuXG4gICAgICovXG4gICAgdG8/OiBzdHJpbmc7XG4gICAgLyoqXG4gICAgICogRGlzcGxheSBhZGRpdGlvbmFsIGRldGFpbHMgZHVyaW5nIHRoZSB1cGRhdGUgcHJvY2Vzcy5cbiAgICAgKi9cbiAgICB2ZXJib3NlPzogYm9vbGVhbjtcbiAgICBbcHJvcGVydHk6IHN0cmluZ106IGFueTtcbn1cblxuLyoqXG4gKiBUaGUgcHJlZmVycmVkIHBhY2thZ2UgbWFuYWdlciBjb25maWd1cmF0aW9uIGZpbGVzIHRvIHVzZSBmb3IgcmVnaXN0cnkgc2V0dGluZ3MuXG4gKi9cbmV4cG9ydCBlbnVtIFBhY2thZ2VNYW5hZ2VyIHtcbiAgICBDbnBtID0gXCJjbnBtXCIsXG4gICAgTnBtID0gXCJucG1cIixcbiAgICBQbnBtID0gXCJwbnBtXCIsXG4gICAgWWFybiA9IFwieWFyblwiLFxufVxuIl19
@@ -21,6 +21,6 @@ class Version {
21
21
  }
22
22
  }
23
23
  // TODO: Convert this to use build-time version stamping after flipping the build script to use bazel
24
- // export const VERSION = new Version('15.2.0-next.0');
24
+ // export const VERSION = new Version('15.2.0-next.2');
25
25
  exports.VERSION = new Version(JSON.parse((0, fs_1.readFileSync)((0, path_1.resolve)(__dirname, '../../package.json'), 'utf-8')).version);
26
26
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2FuZ3VsYXIvY2xpL3NyYy91dGlsaXRpZXMvdmVyc2lvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7OztHQU1HOzs7QUFFSCwyQkFBa0M7QUFDbEMsK0JBQStCO0FBRS9CLCtDQUErQztBQUMvQyxNQUFNLE9BQU87SUFLWCxZQUE0QixJQUFZO1FBQVosU0FBSSxHQUFKLElBQUksQ0FBUTtRQUN0QyxNQUFNLENBQUMsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLLENBQUMsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsR0FBRyxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQ2xFLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBQ25CLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBQ25CLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO0lBQ3JCLENBQUM7Q0FDRjtBQUVELHFHQUFxRztBQUNyRywyREFBMkQ7QUFDOUMsUUFBQSxPQUFPLEdBQUcsSUFBSSxPQUFPLENBRTlCLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBQSxpQkFBWSxFQUFDLElBQUEsY0FBTyxFQUFDLFNBQVMsRUFBRSxvQkFBb0IsQ0FBQyxFQUFFLE9BQU8sQ0FBQyxDQUczRSxDQUFDLE9BQU8sQ0FDVixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbmltcG9ydCB7IHJlYWRGaWxlU3luYyB9IGZyb20gJ2ZzJztcbmltcG9ydCB7IHJlc29sdmUgfSBmcm9tICdwYXRoJztcblxuLy8gU2FtZSBzdHJ1Y3R1cmUgYXMgdXNlZCBpbiBmcmFtZXdvcmsgcGFja2FnZXNcbmNsYXNzIFZlcnNpb24ge1xuICBwdWJsaWMgcmVhZG9ubHkgbWFqb3I6IHN0cmluZztcbiAgcHVibGljIHJlYWRvbmx5IG1pbm9yOiBzdHJpbmc7XG4gIHB1YmxpYyByZWFkb25seSBwYXRjaDogc3RyaW5nO1xuXG4gIGNvbnN0cnVjdG9yKHB1YmxpYyByZWFkb25seSBmdWxsOiBzdHJpbmcpIHtcbiAgICBjb25zdCBbbWFqb3IsIG1pbm9yLCBwYXRjaF0gPSBmdWxsLnNwbGl0KCctJywgMSlbMF0uc3BsaXQoJy4nLCAzKTtcbiAgICB0aGlzLm1ham9yID0gbWFqb3I7XG4gICAgdGhpcy5taW5vciA9IG1pbm9yO1xuICAgIHRoaXMucGF0Y2ggPSBwYXRjaDtcbiAgfVxufVxuXG4vLyBUT0RPOiBDb252ZXJ0IHRoaXMgdG8gdXNlIGJ1aWxkLXRpbWUgdmVyc2lvbiBzdGFtcGluZyBhZnRlciBmbGlwcGluZyB0aGUgYnVpbGQgc2NyaXB0IHRvIHVzZSBiYXplbFxuLy8gZXhwb3J0IGNvbnN0IFZFUlNJT04gPSBuZXcgVmVyc2lvbignMC4wLjAtUExBQ0VIT0xERVInKTtcbmV4cG9ydCBjb25zdCBWRVJTSU9OID0gbmV3IFZlcnNpb24oXG4gIChcbiAgICBKU09OLnBhcnNlKHJlYWRGaWxlU3luYyhyZXNvbHZlKF9fZGlybmFtZSwgJy4uLy4uL3BhY2thZ2UuanNvbicpLCAndXRmLTgnKSkgYXMge1xuICAgICAgdmVyc2lvbjogc3RyaW5nO1xuICAgIH1cbiAgKS52ZXJzaW9uLFxuKTtcbiJdfQ==