Socket
Socket
Sign inDemoInstall

@angular-devkit/schematics-cli

Package Overview
Dependencies
Maintainers
2
Versions
732
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@angular-devkit/schematics-cli - npm Package Compare versions

Comparing version 0.0.3 to 0.0.4

22

bin/schematics.js

@@ -9,4 +9,4 @@ #!/usr/bin/env node

const minimist = require("minimist");
const Observable_1 = require("rxjs/Observable");
require("rxjs/add/operator/ignoreElements");
const of_1 = require("rxjs/observable/of");
const operators_1 = require("rxjs/operators");
/**

@@ -116,3 +116,3 @@ * Show usage of the CLI tool, and exit the process.

/** This host is the original Tree created from the current directory. */
const host = Observable_1.Observable.of(new schematics_1.FileSystemTree(new tools_1.FileSystemHost(process.cwd())));
const host = of_1.of(new schematics_1.FileSystemTree(new tools_1.FileSystemHost(process.cwd())));
// We need two sinks if we want to output what will happen, and actually do the work.

@@ -185,7 +185,5 @@ // Note that fsSink is technically not used if `--dry-run` is passed, but creating the Sink

schematic.call(args, host, { debug, logger: logger.asApi() })
.map((tree) => schematics_1.Tree.optimize(tree))
.concatMap((tree) => {
return dryRunSink.commit(tree).ignoreElements().concat(Observable_1.Observable.of(tree));
})
.concatMap((tree) => {
.pipe(operators_1.map((tree) => schematics_1.Tree.optimize(tree)), operators_1.concatMap((tree) => {
return dryRunSink.commit(tree).pipe(operators_1.ignoreElements(), operators_1.concat(of_1.of(tree)));
}), operators_1.concatMap((tree) => {
if (!error) {

@@ -199,6 +197,6 @@ // Output the logging queue.

if (dryRun || error) {
return Observable_1.Observable.of(tree);
return of_1.of(tree);
}
return fsSink.commit(tree).ignoreElements().concat(Observable_1.Observable.of(tree));
})
return fsSink.commit(tree).pipe(operators_1.ignoreElements(), operators_1.concat(of_1.of(tree)));
}))
.subscribe({

@@ -215,2 +213,2 @@ error(err) {

});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"schematics.js","sourceRoot":"/Users/hansl/Sources/hansl/devkit/","sources":["packages/angular_devkit/schematics_cli/bin/schematics.ts"],"names":[],"mappings":"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","sourcesContent":["#!/usr/bin/env node\n/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport {\n  schema,\n  tags,\n  terminal,\n} from '@angular-devkit/core';\nimport { createConsoleLogger } from '@angular-devkit/core/node';\nimport {\n  DryRunEvent,\n  DryRunSink,\n  FileSystemSink,\n  FileSystemTree,\n  SchematicEngine,\n  Tree,\n  formats,\n} from '@angular-devkit/schematics';\nimport {\n  FileSystemHost,\n  NodeModulesEngineHost,\n  validateOptionsWithSchema,\n} from '@angular-devkit/schematics/tools';\nimport * as minimist from 'minimist';\nimport { Observable } from 'rxjs/Observable';\nimport 'rxjs/add/operator/ignoreElements';\n\n\n/**\n * Show usage of the CLI tool, and exit the process.\n */\nfunction usage(exitCode = 0): never {\n  logger.info(tags.stripIndent`\n    schematics [CollectionName:]SchematicName [options, ...]\n\n    By default, if the collection name is not specified, use the internal collection provided\n    by the Schematics CLI.\n\n    Options:\n        --debug             Debug mode. This is true by default if the collection is a relative\n                            path (in that case, turn off with --debug=false).\n        --dry-run           Do not output anything, but instead just show what actions would be\n                            performed. Default to true if debug is also true.\n        --force             Force overwriting files that would otherwise be an error.\n        --list-schematics   List all schematics from the collection, by name.\n        --verbose           Show more information.\n\n        --help              Show this message.\n\n    Any additional option is passed to the Schematics depending on\n  `);\n\n  process.exit(exitCode);\n  throw 0;  // The node typing sometimes don't have a never type for process.exit().\n}\n\n\n/**\n * Parse the name of schematic passed in argument, and return a {collection, schematic} named\n * tuple. The user can pass in `collection-name:schematic-name`, and this function will either\n * return `{collection: 'collection-name', schematic: 'schematic-name'}`, or it will error out\n * and show usage.\n *\n * In the case where a collection name isn't part of the argument, the default is to use the\n * schematics package (@schematics/schematics) as the collection.\n *\n * This logic is entirely up to the tooling.\n *\n * @param str The argument to parse.\n * @return {{collection: string, schematic: (string)}}\n */\nfunction parseSchematicName(str: string | null): { collection: string, schematic: string } {\n  let collection = '@schematics/schematics';\n\n  if (!str || str === null) {\n    usage(1);\n  }\n\n  let schematic: string = str as string;\n  if (schematic.indexOf(':') != -1) {\n    [collection, schematic] = schematic.split(':', 2);\n\n    if (!schematic) {\n      usage(2);\n    }\n  }\n\n  return { collection, schematic };\n}\n\n\n/** Parse the command line. */\nconst booleanArgs = [ 'debug', 'dry-run', 'force', 'help', 'list-schematics', 'verbose' ];\nconst argv = minimist(process.argv.slice(2), {\n  boolean: booleanArgs,\n  default: {\n    'debug': null,\n    'dry-run': null,\n  },\n  '--': true,\n});\n\n/** Create the DevKit Logger used through the CLI. */\nconst logger = createConsoleLogger(argv['verbose']);\n\nif (argv.help) {\n  usage();\n}\n\n/** Get the collection an schematic name from the first argument. */\nconst {\n  collection: collectionName,\n  schematic: schematicName,\n} = parseSchematicName(argv._.shift() || null);\nconst isLocalCollection = collectionName.startsWith('.') || collectionName.startsWith('/');\n\n\n/**\n * Create the SchematicEngine, which is used by the Schematic library as callbacks to load a\n * Collection or a Schematic.\n */\nconst engineHost = new NodeModulesEngineHost();\nconst engine = new SchematicEngine(engineHost);\n\n\n// Add support for schemaJson.\nconst registry = new schema.CoreSchemaRegistry(formats.standardFormats);\nengineHost.registerOptionsTransform(validateOptionsWithSchema(registry));\n\n\n/**\n * The collection to be used.\n * @type {Collection|any}\n */\nconst collection = engine.createCollection(collectionName);\nif (collection === null) {\n  logger.fatal(`Invalid collection name: \"${collectionName}\".`);\n  process.exit(3);\n  throw 3;  // TypeScript doesn't know that process.exit() never returns.\n}\n\n\n/** If the user wants to list schematics, we simply show all the schematic names. */\nif (argv['list-schematics']) {\n  logger.info(engine.listSchematicNames(collection).join('\\n'));\n  process.exit(0);\n  throw 0;  // TypeScript doesn't know that process.exit() never returns.\n}\n\n\n/** Create the schematic from the collection. */\nconst schematic = collection.createSchematic(schematicName);\n\n/** Gather the arguments for later use. */\nconst debug: boolean = argv.debug === null ? isLocalCollection : argv.debug;\nconst dryRun: boolean = argv['dry-run'] === null ? debug : argv['dry-run'];\nconst force = argv['force'];\n\n/** This host is the original Tree created from the current directory. */\nconst host = Observable.of(new FileSystemTree(new FileSystemHost(process.cwd())));\n\n// We need two sinks if we want to output what will happen, and actually do the work.\n// Note that fsSink is technically not used if `--dry-run` is passed, but creating the Sink\n// does not have any side effect.\nconst dryRunSink = new DryRunSink(process.cwd(), force);\nconst fsSink = new FileSystemSink(process.cwd(), force);\n\n\n// We keep a boolean to tell us whether an error would occur if we were to commit to an\n// actual filesystem. In this case we simply show the dry-run, but skip the fsSink commit.\nlet error = false;\n\n// Indicate to the user when nothing has been done.\nlet nothingDone = true;\n\n\nconst loggingQueue: string[] = [];\n\n// Logs out dry run events.\ndryRunSink.reporter.subscribe((event: DryRunEvent) => {\n  nothingDone = false;\n\n  switch (event.kind) {\n    case 'error':\n      const desc = event.description == 'alreadyExist' ? 'already exists' : 'does not exist.';\n      logger.warn(`ERROR! ${event.path} ${desc}.`);\n      error = true;\n      break;\n    case 'update':\n      loggingQueue.push(tags.oneLine`\n        ${terminal.white('UPDATE')} ${event.path} (${event.content.length} bytes)\n      `);\n      break;\n    case 'create':\n      loggingQueue.push(tags.oneLine`\n        ${terminal.green('CREATE')} ${event.path} (${event.content.length} bytes)\n      `);\n      break;\n    case 'delete':\n      loggingQueue.push(`${terminal.yellow('DELETE')} ${event.path}`);\n      break;\n    case 'rename':\n      loggingQueue.push(`${terminal.blue('RENAME')} ${event.path} => ${event.to}`);\n      break;\n  }\n});\n\n\n/**\n * Remove every options from argv that we support in schematics itself.\n */\nconst args = Object.assign({}, argv);\ndelete args['--'];\nfor (const key of booleanArgs) {\n  delete args[key];\n}\n\n/**\n * Add options from `--` to args.\n */\nconst argv2 = minimist(argv['--']);\nfor (const key of Object.keys(argv2)) {\n  args[key] = argv2[key];\n}\ndelete args._;\n\n\n/**\n * The main path. Call the schematic with the host. This creates a new Context for the schematic\n * to run in, then call the schematic rule using the input Tree. This returns a new Tree as if\n * the schematic was applied to it.\n *\n * We then optimize this tree. This removes any duplicated actions or actions that would result\n * in a noop (for example, creating then deleting a file). This is not necessary but will greatly\n * improve performance as hitting the file system is costly.\n *\n * Then we proceed to run the dryRun commit. We run this before we then commit to the filesystem\n * (if --dry-run was not passed or an error was detected by dryRun).\n */\nschematic.call(args, host, { debug, logger: logger.asApi() })\n  .map((tree: Tree) => Tree.optimize(tree))\n  .concatMap((tree: Tree) => {\n    return dryRunSink.commit(tree).ignoreElements().concat(Observable.of(tree));\n  })\n  .concatMap((tree: Tree) => {\n    if (!error) {\n      // Output the logging queue.\n      loggingQueue.forEach(log => logger.info(log));\n    }\n\n    if (nothingDone) {\n      logger.info('Nothing to be done.');\n    }\n\n    if (dryRun || error) {\n      return Observable.of(tree);\n    }\n\n    return fsSink.commit(tree).ignoreElements().concat(Observable.of(tree));\n  })\n  .subscribe({\n    error(err: Error) {\n      if (debug) {\n        logger.fatal('An error occured:\\n' + err.stack);\n      } else {\n        logger.fatal(err.message);\n      }\n      process.exit(1);\n    },\n  });\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"schematics.js","sourceRoot":"/usr/local/google/home/alexeagle/Projects/devkit/","sources":["packages/angular_devkit/schematics_cli/bin/schematics.ts"],"names":[],"mappings":"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","sourcesContent":["#!/usr/bin/env node\n/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport {\n  schema,\n  tags,\n  terminal,\n} from '@angular-devkit/core';\nimport { createConsoleLogger } from '@angular-devkit/core/node';\nimport {\n  DryRunEvent,\n  DryRunSink,\n  FileSystemSink,\n  FileSystemTree,\n  SchematicEngine,\n  Tree,\n  formats,\n} from '@angular-devkit/schematics';\nimport {\n  FileSystemHost,\n  NodeModulesEngineHost,\n  validateOptionsWithSchema,\n} from '@angular-devkit/schematics/tools';\nimport * as minimist from 'minimist';\nimport { of as observableOf } from 'rxjs/observable/of';\nimport {\n  concat,\n  concatMap,\n  ignoreElements,\n  map,\n} from 'rxjs/operators';\n\n/**\n * Show usage of the CLI tool, and exit the process.\n */\nfunction usage(exitCode = 0): never {\n  logger.info(tags.stripIndent`\n    schematics [CollectionName:]SchematicName [options, ...]\n\n    By default, if the collection name is not specified, use the internal collection provided\n    by the Schematics CLI.\n\n    Options:\n        --debug             Debug mode. This is true by default if the collection is a relative\n                            path (in that case, turn off with --debug=false).\n        --dry-run           Do not output anything, but instead just show what actions would be\n                            performed. Default to true if debug is also true.\n        --force             Force overwriting files that would otherwise be an error.\n        --list-schematics   List all schematics from the collection, by name.\n        --verbose           Show more information.\n\n        --help              Show this message.\n\n    Any additional option is passed to the Schematics depending on\n  `);\n\n  process.exit(exitCode);\n  throw 0;  // The node typing sometimes don't have a never type for process.exit().\n}\n\n\n/**\n * Parse the name of schematic passed in argument, and return a {collection, schematic} named\n * tuple. The user can pass in `collection-name:schematic-name`, and this function will either\n * return `{collection: 'collection-name', schematic: 'schematic-name'}`, or it will error out\n * and show usage.\n *\n * In the case where a collection name isn't part of the argument, the default is to use the\n * schematics package (@schematics/schematics) as the collection.\n *\n * This logic is entirely up to the tooling.\n *\n * @param str The argument to parse.\n * @return {{collection: string, schematic: (string)}}\n */\nfunction parseSchematicName(str: string | null): { collection: string, schematic: string } {\n  let collection = '@schematics/schematics';\n\n  if (!str || str === null) {\n    usage(1);\n  }\n\n  let schematic: string = str as string;\n  if (schematic.indexOf(':') != -1) {\n    [collection, schematic] = schematic.split(':', 2);\n\n    if (!schematic) {\n      usage(2);\n    }\n  }\n\n  return { collection, schematic };\n}\n\n\n/** Parse the command line. */\nconst booleanArgs = [ 'debug', 'dry-run', 'force', 'help', 'list-schematics', 'verbose' ];\nconst argv = minimist(process.argv.slice(2), {\n  boolean: booleanArgs,\n  default: {\n    'debug': null,\n    'dry-run': null,\n  },\n  '--': true,\n});\n\n/** Create the DevKit Logger used through the CLI. */\nconst logger = createConsoleLogger(argv['verbose']);\n\nif (argv.help) {\n  usage();\n}\n\n/** Get the collection an schematic name from the first argument. */\nconst {\n  collection: collectionName,\n  schematic: schematicName,\n} = parseSchematicName(argv._.shift() || null);\nconst isLocalCollection = collectionName.startsWith('.') || collectionName.startsWith('/');\n\n\n/**\n * Create the SchematicEngine, which is used by the Schematic library as callbacks to load a\n * Collection or a Schematic.\n */\nconst engineHost = new NodeModulesEngineHost();\nconst engine = new SchematicEngine(engineHost);\n\n\n// Add support for schemaJson.\nconst registry = new schema.CoreSchemaRegistry(formats.standardFormats);\nengineHost.registerOptionsTransform(validateOptionsWithSchema(registry));\n\n\n/**\n * The collection to be used.\n * @type {Collection|any}\n */\nconst collection = engine.createCollection(collectionName);\nif (collection === null) {\n  logger.fatal(`Invalid collection name: \"${collectionName}\".`);\n  process.exit(3);\n  throw 3;  // TypeScript doesn't know that process.exit() never returns.\n}\n\n\n/** If the user wants to list schematics, we simply show all the schematic names. */\nif (argv['list-schematics']) {\n  logger.info(engine.listSchematicNames(collection).join('\\n'));\n  process.exit(0);\n  throw 0;  // TypeScript doesn't know that process.exit() never returns.\n}\n\n\n/** Create the schematic from the collection. */\nconst schematic = collection.createSchematic(schematicName);\n\n/** Gather the arguments for later use. */\nconst debug: boolean = argv.debug === null ? isLocalCollection : argv.debug;\nconst dryRun: boolean = argv['dry-run'] === null ? debug : argv['dry-run'];\nconst force = argv['force'];\n\n/** This host is the original Tree created from the current directory. */\nconst host = observableOf(new FileSystemTree(new FileSystemHost(process.cwd())));\n\n// We need two sinks if we want to output what will happen, and actually do the work.\n// Note that fsSink is technically not used if `--dry-run` is passed, but creating the Sink\n// does not have any side effect.\nconst dryRunSink = new DryRunSink(process.cwd(), force);\nconst fsSink = new FileSystemSink(process.cwd(), force);\n\n\n// We keep a boolean to tell us whether an error would occur if we were to commit to an\n// actual filesystem. In this case we simply show the dry-run, but skip the fsSink commit.\nlet error = false;\n\n// Indicate to the user when nothing has been done.\nlet nothingDone = true;\n\n\nconst loggingQueue: string[] = [];\n\n// Logs out dry run events.\ndryRunSink.reporter.subscribe((event: DryRunEvent) => {\n  nothingDone = false;\n\n  switch (event.kind) {\n    case 'error':\n      const desc = event.description == 'alreadyExist' ? 'already exists' : 'does not exist.';\n      logger.warn(`ERROR! ${event.path} ${desc}.`);\n      error = true;\n      break;\n    case 'update':\n      loggingQueue.push(tags.oneLine`\n        ${terminal.white('UPDATE')} ${event.path} (${event.content.length} bytes)\n      `);\n      break;\n    case 'create':\n      loggingQueue.push(tags.oneLine`\n        ${terminal.green('CREATE')} ${event.path} (${event.content.length} bytes)\n      `);\n      break;\n    case 'delete':\n      loggingQueue.push(`${terminal.yellow('DELETE')} ${event.path}`);\n      break;\n    case 'rename':\n      loggingQueue.push(`${terminal.blue('RENAME')} ${event.path} => ${event.to}`);\n      break;\n  }\n});\n\n\n/**\n * Remove every options from argv that we support in schematics itself.\n */\nconst args = Object.assign({}, argv);\ndelete args['--'];\nfor (const key of booleanArgs) {\n  delete args[key];\n}\n\n/**\n * Add options from `--` to args.\n */\nconst argv2 = minimist(argv['--']);\nfor (const key of Object.keys(argv2)) {\n  args[key] = argv2[key];\n}\ndelete args._;\n\n\n/**\n * The main path. Call the schematic with the host. This creates a new Context for the schematic\n * to run in, then call the schematic rule using the input Tree. This returns a new Tree as if\n * the schematic was applied to it.\n *\n * We then optimize this tree. This removes any duplicated actions or actions that would result\n * in a noop (for example, creating then deleting a file). This is not necessary but will greatly\n * improve performance as hitting the file system is costly.\n *\n * Then we proceed to run the dryRun commit. We run this before we then commit to the filesystem\n * (if --dry-run was not passed or an error was detected by dryRun).\n */\nschematic.call(args, host, { debug, logger: logger.asApi() })\n  .pipe(\n    map((tree: Tree) => Tree.optimize(tree)),\n    concatMap((tree: Tree) => {\n      return dryRunSink.commit(tree).pipe(\n        ignoreElements(),\n        concat(observableOf(tree)));\n    }),\n    concatMap((tree: Tree) => {\n      if (!error) {\n        // Output the logging queue.\n        loggingQueue.forEach(log => logger.info(log));\n      }\n\n      if (nothingDone) {\n        logger.info('Nothing to be done.');\n      }\n\n      if (dryRun || error) {\n        return observableOf(tree);\n      }\n\n      return fsSink.commit(tree).pipe(\n        ignoreElements(),\n        concat(observableOf(tree)));\n    }))\n  .subscribe({\n    error(err: Error) {\n      if (debug) {\n        logger.fatal('An error occured:\\n' + err.stack);\n      } else {\n        logger.fatal(err.message);\n      }\n      process.exit(1);\n    },\n  });\n"]}
{
"name": "@angular-devkit/schematics-cli",
"version": "0.0.3",
"version": "0.0.4",
"description": "Angular Schematics - CLI",

@@ -21,5 +21,5 @@ "bin": {

"dependencies": {
"@angular-devkit/core": "0.0.24",
"@angular-devkit/schematics": "0.0.45",
"@schematics/schematics": "0.0.12",
"@angular-devkit/core": "0.0.25",
"@angular-devkit/schematics": "0.0.46",
"@schematics/schematics": "0.0.13",
"minimist": "^1.2.0",

@@ -26,0 +26,0 @@ "rxjs": "^5.5.2"

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc