Big News: Socket raises $60M Series C at a $1B valuation to secure software supply chains for AI-driven development.Announcement
Sign In

@angular-devkit/architect-cli

Package Overview
Dependencies
Maintainers
2
Versions
928
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

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

Comparing version
0.14.0-beta.1
to
0.14.0-beta.2
+15
src/progress.d.ts
/// <reference types="node" />
export declare class MultiProgressBar<Key, T> {
private _status;
private _stream;
private _bars;
constructor(_status: string, _stream?: NodeJS.WriteStream);
private _add;
complete(id: Key): void;
add(id: Key, data: T): void;
get(key: Key): T | undefined;
has(key: Key): boolean;
update(key: Key, data: T, current?: number, total?: number): void;
render(max?: number, sort?: (a: T, b: T) => number): void;
terminate(): void;
}
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
/**
* @license
* Copyright Google Inc. All Rights Reserved.
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://angular.io/license
*/
const core_1 = require("@angular-devkit/core");
const ProgressBar = require("progress");
const readline = require("readline");
class MultiProgressBar {
constructor(_status, _stream = process.stderr) {
this._status = _status;
this._stream = _stream;
this._bars = new Map();
}
_add(id, data) {
const width = Math.min(80, core_1.terminal.getCapabilities(this._stream).columns || 80);
const value = {
data,
bar: new ProgressBar(this._status, {
clear: true,
total: 1,
width: width,
complete: '#',
incomplete: '.',
stream: this._stream,
}),
};
this._bars.set(id, value);
readline.moveCursor(this._stream, 0, 1);
return value;
}
complete(id) {
const maybeBar = this._bars.get(id);
if (maybeBar) {
maybeBar.bar.complete = true;
}
}
add(id, data) {
this._add(id, data);
}
get(key) {
const maybeValue = this._bars.get(key);
return maybeValue && maybeValue.data;
}
has(key) {
return this._bars.has(key);
}
update(key, data, current, total) {
let maybeBar = this._bars.get(key);
if (!maybeBar) {
maybeBar = this._add(key, data);
}
maybeBar.data = data;
if (total !== undefined) {
maybeBar.bar.total = total;
}
if (current !== undefined) {
maybeBar.bar.curr = Math.max(0, Math.min(current, maybeBar.bar.total));
}
}
render(max = Infinity, sort) {
const stream = this._stream;
readline.moveCursor(stream, 0, -this._bars.size);
readline.cursorTo(stream, 0);
let values = this._bars.values();
if (sort) {
values = [...values].sort((a, b) => sort(a.data, b.data));
}
for (const { data, bar } of values) {
if (max-- == 0) {
return;
}
bar.render(data);
readline.moveCursor(stream, 0, 1);
readline.cursorTo(stream, 0);
}
}
terminate() {
for (const { bar } of this._bars.values()) {
bar.terminate();
}
this._bars.clear();
}
}
exports.MultiProgressBar = MultiProgressBar;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZ3Jlc3MuanMiLCJzb3VyY2VSb290IjoiLi8iLCJzb3VyY2VzIjpbInBhY2thZ2VzL2FuZ3VsYXJfZGV2a2l0L2FyY2hpdGVjdF9jbGkvc3JjL3Byb2dyZXNzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUE7Ozs7OztHQU1HO0FBQ0gsK0NBQWdEO0FBQ2hELHdDQUF3QztBQUN4QyxxQ0FBcUM7QUFFckMsTUFBYSxnQkFBZ0I7SUFHM0IsWUFBb0IsT0FBZSxFQUFVLFVBQVUsT0FBTyxDQUFDLE1BQU07UUFBakQsWUFBTyxHQUFQLE9BQU8sQ0FBUTtRQUFVLFlBQU8sR0FBUCxPQUFPLENBQWlCO1FBRjdELFVBQUssR0FBRyxJQUFJLEdBQUcsRUFBc0MsQ0FBQztJQUVVLENBQUM7SUFDakUsSUFBSSxDQUFDLEVBQU8sRUFBRSxJQUFPO1FBQzNCLE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxFQUFFLGVBQVEsQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDLE9BQU8sSUFBSSxFQUFFLENBQUMsQ0FBQztRQUNqRixNQUFNLEtBQUssR0FBRztZQUNaLElBQUk7WUFDSixHQUFHLEVBQUUsSUFBSSxXQUFXLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRTtnQkFDakMsS0FBSyxFQUFFLElBQUk7Z0JBQ1gsS0FBSyxFQUFFLENBQUM7Z0JBQ1IsS0FBSyxFQUFFLEtBQUs7Z0JBQ1osUUFBUSxFQUFFLEdBQUc7Z0JBQ2IsVUFBVSxFQUFFLEdBQUc7Z0JBQ2YsTUFBTSxFQUFFLElBQUksQ0FBQyxPQUFPO2FBQ3JCLENBQUM7U0FDSCxDQUFDO1FBQ0YsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsRUFBRSxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBQzFCLFFBQVEsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFFeEMsT0FBTyxLQUFLLENBQUM7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QUFFO1lBQ3pDLEdBQUcsQ0FBQyxTQUFTLEVBQUUsQ0FBQztTQUNqQjtRQUNELElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDckIsQ0FBQztDQUNGO0FBdEZELDRDQXNGQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgSW5jLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cbmltcG9ydCB7IHRlcm1pbmFsIH0gZnJvbSAnQGFuZ3VsYXItZGV2a2l0L2NvcmUnO1xuaW1wb3J0ICogYXMgUHJvZ3Jlc3NCYXIgZnJvbSAncHJvZ3Jlc3MnO1xuaW1wb3J0ICogYXMgcmVhZGxpbmUgZnJvbSAncmVhZGxpbmUnO1xuXG5leHBvcnQgY2xhc3MgTXVsdGlQcm9ncmVzc0JhcjxLZXksIFQ+IHtcbiAgcHJpdmF0ZSBfYmFycyA9IG5ldyBNYXA8S2V5LCB7IGRhdGE6IFQsIGJhcjogUHJvZ3Jlc3NCYXIgfT4oKTtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIF9zdGF0dXM6IHN0cmluZywgcHJpdmF0ZSBfc3RyZWFtID0gcHJvY2Vzcy5zdGRlcnIpIHt9XG4gIHByaXZhdGUgX2FkZChpZDogS2V5LCBkYXRhOiBUKTogeyBkYXRhOiBULCBiYXI6IFByb2dyZXNzQmFyIH0ge1xuICAgIGNvbnN0IHdpZHRoID0gTWF0aC5taW4oODAsIHRlcm1pbmFsLmdldENhcGFiaWxpdGllcyh0aGlzLl9zdHJlYW0pLmNvbHVtbnMgfHwgODApO1xuICAgIGNvbnN0IHZhbHVlID0ge1xuICAgICAgZGF0YSxcbiAgICAgIGJhcjogbmV3IFByb2dyZXNzQmFyKHRoaXMuX3N0YXR1cywge1xuICAgICAgICBjbGVhcjogdHJ1ZSxcbiAgICAgICAgdG90YWw6IDEsXG4gICAgICAgIHdpZHRoOiB3aWR0aCxcbiAgICAgICAgY29tcGxldGU6ICcjJyxcbiAgICAgICAgaW5jb21wbGV0ZTogJy4nLFxuICAgICAgICBzdHJlYW06IHRoaXMuX3N0cmVhbSxcbiAgICAgIH0pLFxuICAgIH07XG4gICAgdGhpcy5fYmFycy5zZXQoaWQsIHZhbHVlKTtcbiAgICByZWFkbGluZS5tb3ZlQ3Vyc29yKHRoaXMuX3N0cmVhbSwgMCwgMSk7XG5cbiAgICByZXR1cm4gdmFsdWU7XG4gIH1cblxuICBjb21wbGV0ZShpZDogS2V5KSB7XG4gICAgY29uc3QgbWF5YmVCYXIgPSB0aGlzLl9iYXJzLmdldChpZCk7XG4gICAgaWYgKG1heWJlQmFyKSB7XG4gICAgICBtYXliZUJhci5iYXIuY29tcGxldGUgPSB0cnVlO1xuICAgIH1cbiAgfVxuXG4gIGFkZChpZDogS2V5LCBkYXRhOiBUKSB7XG4gICAgdGhpcy5fYWRkKGlkLCBkYXRhKTtcbiAgfVxuXG4gIGdldChrZXk6IEtleSk6IFQgfCB1bmRlZmluZWQge1xuICAgIGNvbnN0IG1heWJlVmFsdWUgPSB0aGlzLl9iYXJzLmdldChrZXkpO1xuXG4gICAgcmV0dXJuIG1heWJlVmFsdWUgJiYgbWF5YmVWYWx1ZS5kYXRhO1xuICB9XG4gIGhhcyhrZXk6IEtleSkge1xuICAgIHJldHVybiB0aGlzLl9iYXJzLmhhcyhrZXkpO1xuICB9XG4gIHVwZGF0ZShrZXk6IEtleSwgZGF0YTogVCwgY3VycmVudD86IG51bWJlciwgdG90YWw/OiBudW1iZXIpIHtcbiAgICBsZXQgbWF5YmVCYXIgPSB0aGlzLl9iYXJzLmdldChrZXkpO1xuXG4gICAgaWYgKCFtYXliZUJhcikge1xuICAgICAgbWF5YmVCYXIgPSB0aGlzLl9hZGQoa2V5LCBkYXRhKTtcbiAgICB9XG5cbiAgICBtYXliZUJhci5kYXRhID0gZGF0YTtcbiAgICBpZiAodG90YWwgIT09IHVuZGVmaW5lZCkge1xuICAgICAgbWF5YmVCYXIuYmFyLnRvdGFsID0gdG90YWw7XG4gICAgfVxuICAgIGlmIChjdXJyZW50ICE9PSB1bmRlZmluZWQpIHtcbiAgICAgIG1heWJlQmFyLmJhci5jdXJyID0gTWF0aC5tYXgoMCwgTWF0aC5taW4oY3VycmVudCwgbWF5YmVCYXIuYmFyLnRvdGFsKSk7XG4gICAgfVxuICB9XG5cbiAgcmVuZGVyKG1heCA9IEluZmluaXR5LCBzb3J0PzogKGE6IFQsIGI6IFQpID0+IG51bWJlcikge1xuICAgIGNvbnN0IHN0cmVhbSA9IHRoaXMuX3N0cmVhbTtcblxuICAgIHJlYWRsaW5lLm1vdmVDdXJzb3Ioc3RyZWFtLCAwLCAtdGhpcy5fYmFycy5zaXplKTtcbiAgICByZWFkbGluZS5jdXJzb3JUbyhzdHJlYW0sIDApO1xuXG4gICAgbGV0IHZhbHVlczogSXRlcmFibGU8eyBkYXRhOiBULCBiYXI6IFByb2dyZXNzQmFyIH0+ID0gdGhpcy5fYmFycy52YWx1ZXMoKTtcbiAgICBpZiAoc29ydCkge1xuICAgICAgdmFsdWVzID0gWy4uLnZhbHVlc10uc29ydCgoYSwgYikgPT4gc29ydChhLmRhdGEsIGIuZGF0YSkpO1xuICAgIH1cblxuICAgIGZvciAoY29uc3QgeyBkYXRhLCBiYXIgfSBvZiB2YWx1ZXMpIHtcbiAgICAgIGlmIChtYXgtLSA9PSAwKSB7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cblxuICAgICAgYmFyLnJlbmRlcihkYXRhKTtcbiAgICAgIHJlYWRsaW5lLm1vdmVDdXJzb3Ioc3RyZWFtLCAwLCAxKTtcbiAgICAgIHJlYWRsaW5lLmN1cnNvclRvKHN0cmVhbSwgMCk7XG4gICAgfVxuICB9XG5cbiAgdGVybWluYXRlKCkge1xuICAgIGZvciAoY29uc3QgeyBiYXIgfSBvZiB0aGlzLl9iYXJzLnZhbHVlcygpKSB7XG4gICAgICBiYXIudGVybWluYXRlKCk7XG4gICAgfVxuICAgIHRoaXMuX2JhcnMuY2xlYXIoKTtcbiAgfVxufVxuIl19
+1
-1
#!/usr/bin/env node
import 'symbol-observable';
export {};
#!/usr/bin/env node
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
require("symbol-observable");
// symbol polyfill must go first
// tslint:disable-next-line:ordered-imports import-groups
const architect_1 = require("@angular-devkit/architect");
const node_1 = require("@angular-devkit/architect/node");
const core_1 = require("@angular-devkit/core");
const node_1 = require("@angular-devkit/core/node");
const node_2 = require("@angular-devkit/core/node");
const fs_1 = require("fs");
const minimist = require("minimist");
const path = require("path");
const rxjs_1 = require("rxjs");
const operators_1 = require("rxjs/operators");
const progress_1 = require("../src/progress");
function findUp(names, from) {

@@ -35,3 +32,3 @@ if (!Array.isArray(names)) {

*/
function usage(exitCode = 0) {
function usage(logger, exitCode = 0) {
logger.info(core_1.tags.stripIndent `

@@ -53,69 +50,116 @@ architect [project][:target][:configuration] [options, ...]

}
/** Parse the command line. */
const argv = minimist(process.argv.slice(2), { boolean: ['help'] });
/** Create the DevKit Logger used through the CLI. */
const logger = node_1.createConsoleLogger(argv['verbose']);
// Check the target.
const targetStr = argv._.shift();
if (!targetStr && argv.help) {
// Show architect usage if there's no target.
usage();
function _targetStringFromTarget({ project, target, configuration }) {
return `${project}:${target}${configuration !== undefined ? ':' + configuration : ''}`;
}
// Split a target into its parts.
let project, targetName, configuration;
if (targetStr) {
[project, targetName, configuration] = targetStr.split(':');
async function _executeTarget(parentLogger, workspace, root, argv, registry) {
const architectHost = new node_1.WorkspaceNodeModulesArchitectHost(workspace, root);
const architect = new architect_1.index2.Architect(architectHost, registry);
// Split a target into its parts.
const targetStr = argv._.shift() || '';
const [project, target, configuration] = targetStr.split(':');
const targetSpec = { project, target, configuration };
delete argv['help'];
delete argv['_'];
const logger = new core_1.logging.Logger('jobs');
const logs = [];
logger.subscribe(entry => logs.push(Object.assign({}, entry, { message: `${entry.name}: ` + entry.message })));
const run = await architect.scheduleTarget(targetSpec, argv, { logger });
const bars = new progress_1.MultiProgressBar(':name :bar (:current/:total) :status');
run.progress.subscribe(update => {
const data = bars.get(update.id) || {
id: update.id,
builder: update.builder,
target: update.target,
status: update.status || '',
name: ((update.target ? _targetStringFromTarget(update.target) : update.builder.name)
+ ' '.repeat(80)).substr(0, 40),
};
if (update.status !== undefined) {
data.status = update.status;
}
switch (update.state) {
case architect_1.index2.BuilderProgressState.Error:
data.status = 'Error: ' + update.error;
bars.update(update.id, data);
break;
case architect_1.index2.BuilderProgressState.Stopped:
data.status = 'Done.';
bars.complete(update.id);
bars.update(update.id, data, update.total, update.total);
break;
case architect_1.index2.BuilderProgressState.Waiting:
bars.update(update.id, data);
break;
case architect_1.index2.BuilderProgressState.Running:
bars.update(update.id, data, update.current, update.total);
break;
}
bars.render();
});
// Wait for full completion of the builder.
try {
const result = await run.result;
if (result.success) {
parentLogger.info(core_1.terminal.green('SUCCESS'));
}
else {
parentLogger.info(core_1.terminal.yellow('FAILURE'));
}
parentLogger.info('\nLogs:');
logs.forEach(l => parentLogger.next(l));
await run.stop();
bars.terminate();
return result.success ? 0 : 1;
}
catch (err) {
parentLogger.info(core_1.terminal.red('ERROR'));
parentLogger.info('\nLogs:');
logs.forEach(l => parentLogger.next(l));
parentLogger.fatal('Exception:');
parentLogger.fatal(err.stack);
return 2;
}
}
// Load workspace configuration file.
const currentPath = process.cwd();
const configFileNames = [
'angular.json',
'.angular.json',
'workspace.json',
'.workspace.json',
];
const configFilePath = findUp(configFileNames, currentPath);
if (!configFilePath) {
logger.fatal(`Workspace configuration file (${configFileNames.join(', ')}) cannot be found in `
+ `'${currentPath}' or in parent directories.`);
process.exit(3);
throw 3; // TypeScript doesn't know that process.exit() never returns.
}
const root = core_1.dirname(core_1.normalize(configFilePath));
const configContent = fs_1.readFileSync(configFilePath, 'utf-8');
const workspaceJson = JSON.parse(configContent);
const host = new node_1.NodeJsSyncHost();
const workspace = new core_1.experimental.workspace.Workspace(root, host);
let lastBuildEvent = { success: true };
workspace.loadWorkspaceFromJson(workspaceJson).pipe(operators_1.concatMap(ws => new architect_1.Architect(ws).loadArchitect()), operators_1.concatMap(architect => {
const overrides = Object.assign({}, argv);
delete overrides['help'];
delete overrides['_'];
const targetSpec = {
project,
target: targetName,
configuration,
overrides,
};
// TODO: better logging of what's happening.
if (argv.help) {
// TODO: add target help
return rxjs_1.throwError('Target help NYI.');
// architect.help(targetOptions, logger);
async function main(args) {
/** Parse the command line. */
const argv = minimist(args, { boolean: ['help'] });
/** Create the DevKit Logger used through the CLI. */
const logger = node_2.createConsoleLogger(argv['verbose']);
// Check the target.
const targetStr = argv._[0] || '';
if (!targetStr || argv.help) {
// Show architect usage if there's no target.
usage(logger);
}
else {
const builderConfig = architect.getBuilderConfiguration(targetSpec);
return architect.run(builderConfig, { logger });
// Load workspace configuration file.
const currentPath = process.cwd();
const configFileNames = [
'angular.json',
'.angular.json',
'workspace.json',
'.workspace.json',
];
const configFilePath = findUp(configFileNames, currentPath);
if (!configFilePath) {
logger.fatal(`Workspace configuration file (${configFileNames.join(', ')}) cannot be found in `
+ `'${currentPath}' or in parent directories.`);
return 3;
}
})).subscribe({
next: (buildEvent => lastBuildEvent = buildEvent),
complete: () => process.exit(lastBuildEvent.success ? 0 : 1),
error: (err) => {
logger.fatal(err.message);
if (err.stack) {
logger.fatal(err.stack);
}
process.exit(1);
},
const root = core_1.dirname(core_1.normalize(configFilePath));
const configContent = fs_1.readFileSync(configFilePath, 'utf-8');
const workspaceJson = JSON.parse(configContent);
const registry = new core_1.schema.CoreSchemaRegistry();
registry.addPostTransform(core_1.schema.transforms.addUndefinedDefaults);
const host = new node_2.NodeJsSyncHost();
const workspace = new core_1.experimental.workspace.Workspace(root, host);
await workspace.loadWorkspaceFromJson(workspaceJson).toPromise();
return await _executeTarget(logger, workspace, root, argv, registry);
}
main(process.argv.slice(2))
.then(code => {
process.exit(code);
}, err => {
console.error('Error: ' + err.stack || err.message || err);
process.exit(-1);
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"architect.js","sourceRoot":"./","sources":["packages/angular_devkit/architect_cli/bin/architect.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 */\n\nimport 'symbol-observable';\n// symbol polyfill must go first\n// tslint:disable-next-line:ordered-imports import-groups\nimport { Architect } from '@angular-devkit/architect';\nimport { dirname, experimental, normalize, tags } from '@angular-devkit/core';\nimport { NodeJsSyncHost, createConsoleLogger } from '@angular-devkit/core/node';\nimport { existsSync, readFileSync } from 'fs';\nimport * as minimist from 'minimist';\nimport * as path from 'path';\nimport { throwError } from 'rxjs';\nimport { concatMap } from 'rxjs/operators';\n\n\nfunction findUp(names: string | string[], from: string) {\n  if (!Array.isArray(names)) {\n    names = [names];\n  }\n  const root = path.parse(from).root;\n\n  let currentDir = from;\n  while (currentDir && currentDir !== root) {\n    for (const name of names) {\n      const p = path.join(currentDir, name);\n      if (existsSync(p)) {\n        return p;\n      }\n    }\n\n    currentDir = path.dirname(currentDir);\n  }\n\n  return null;\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    architect [project][:target][:configuration] [options, ...]\n\n    Run a project target.\n    If project/target/configuration are not specified, the workspace defaults will be used.\n\n    Options:\n        --help              Show available options for project target.\n                            Shows this message instead when ran without the run argument.\n\n\n    Any additional option is passed the target, overriding existing options.\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/** Parse the command line. */\nconst argv = minimist(process.argv.slice(2), { boolean: ['help'] });\n\n/** Create the DevKit Logger used through the CLI. */\nconst logger = createConsoleLogger(argv['verbose']);\n\n// Check the target.\nconst targetStr = argv._.shift();\nif (!targetStr && argv.help) {\n  // Show architect usage if there's no target.\n  usage();\n}\n\n// Split a target into its parts.\nlet project: string, targetName: string, configuration: string;\nif (targetStr) {\n  [project, targetName, configuration] = targetStr.split(':');\n}\n\n// Load workspace configuration file.\nconst currentPath = process.cwd();\nconst configFileNames = [\n  'angular.json',\n  '.angular.json',\n  'workspace.json',\n  '.workspace.json',\n];\n\nconst configFilePath = findUp(configFileNames, currentPath);\n\nif (!configFilePath) {\n  logger.fatal(`Workspace configuration file (${configFileNames.join(', ')}) cannot be found in `\n    + `'${currentPath}' or in parent directories.`);\n  process.exit(3);\n  throw 3;  // TypeScript doesn't know that process.exit() never returns.\n}\n\nconst root = dirname(normalize(configFilePath));\nconst configContent = readFileSync(configFilePath, 'utf-8');\nconst workspaceJson = JSON.parse(configContent);\n\nconst host = new NodeJsSyncHost();\nconst workspace = new experimental.workspace.Workspace(root, host);\n\nlet lastBuildEvent = { success: true };\n\nworkspace.loadWorkspaceFromJson(workspaceJson).pipe(\n  concatMap(ws => new Architect(ws).loadArchitect()),\n  concatMap(architect => {\n\n    const overrides = { ...argv };\n    delete overrides['help'];\n    delete overrides['_'];\n\n    const targetSpec = {\n      project,\n      target: targetName,\n      configuration,\n      overrides,\n    };\n\n    // TODO: better logging of what's happening.\n    if (argv.help) {\n      // TODO: add target help\n      return throwError('Target help NYI.');\n      // architect.help(targetOptions, logger);\n    } else {\n      const builderConfig = architect.getBuilderConfiguration(targetSpec);\n\n      return architect.run(builderConfig, { logger });\n    }\n  }),\n).subscribe({\n  next: (buildEvent => lastBuildEvent = buildEvent),\n  complete: () => process.exit(lastBuildEvent.success ? 0 : 1),\n  error: (err: Error) => {\n    logger.fatal(err.message);\n    if (err.stack) {\n      logger.fatal(err.stack);\n    }\n    process.exit(1);\n  },\n});\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"architect.js","sourceRoot":"./","sources":["packages/angular_devkit/architect_cli/bin/architect.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 { index2 } from '@angular-devkit/architect';\nimport { WorkspaceNodeModulesArchitectHost } from '@angular-devkit/architect/node';\nimport {\n  dirname,\n  experimental,\n  json,\n  logging,\n  normalize,\n  schema,\n  tags, terminal,\n} from '@angular-devkit/core';\nimport { NodeJsSyncHost, createConsoleLogger } from '@angular-devkit/core/node';\nimport { existsSync, readFileSync } from 'fs';\nimport * as minimist from 'minimist';\nimport * as path from 'path';\nimport { MultiProgressBar } from '../src/progress';\n\n\nfunction findUp(names: string | string[], from: string) {\n  if (!Array.isArray(names)) {\n    names = [names];\n  }\n  const root = path.parse(from).root;\n\n  let currentDir = from;\n  while (currentDir && currentDir !== root) {\n    for (const name of names) {\n      const p = path.join(currentDir, name);\n      if (existsSync(p)) {\n        return p;\n      }\n    }\n\n    currentDir = path.dirname(currentDir);\n  }\n\n  return null;\n}\n\n/**\n * Show usage of the CLI tool, and exit the process.\n */\nfunction usage(logger: logging.Logger, exitCode = 0): never {\n  logger.info(tags.stripIndent`\n    architect [project][:target][:configuration] [options, ...]\n\n    Run a project target.\n    If project/target/configuration are not specified, the workspace defaults will be used.\n\n    Options:\n        --help              Show available options for project target.\n                            Shows this message instead when ran without the run argument.\n\n\n    Any additional option is passed the target, overriding existing options.\n  `);\n\n  process.exit(exitCode);\n  throw 0;  // The node typing sometimes don't have a never type for process.exit().\n}\n\nfunction _targetStringFromTarget({project, target, configuration}: index2.Target) {\n  return `${project}:${target}${configuration !== undefined ? ':' + configuration : ''}`;\n}\n\n\ninterface BarInfo {\n  status?: string;\n  builder: index2.BuilderInfo;\n  target?: index2.Target;\n}\n\n\nasync function _executeTarget(\n  parentLogger: logging.Logger,\n  workspace: experimental.workspace.Workspace,\n  root: string,\n  argv: minimist.ParsedArgs,\n  registry: json.schema.SchemaRegistry,\n) {\n  const architectHost = new WorkspaceNodeModulesArchitectHost(workspace, root);\n  const architect = new index2.Architect(architectHost, registry);\n\n  // Split a target into its parts.\n  const targetStr = argv._.shift() || '';\n  const [project, target, configuration] = targetStr.split(':');\n  const targetSpec = { project, target, configuration };\n\n  delete argv['help'];\n  delete argv['_'];\n\n  const logger = new logging.Logger('jobs');\n  const logs: logging.LogEntry[] = [];\n  logger.subscribe(entry => logs.push({ ...entry, message: `${entry.name}: ` + entry.message }));\n\n  const run = await architect.scheduleTarget(targetSpec, argv, { logger });\n  const bars = new MultiProgressBar<number, BarInfo>(':name :bar (:current/:total) :status');\n\n  run.progress.subscribe(\n    update => {\n      const data = bars.get(update.id) || {\n        id: update.id,\n        builder: update.builder,\n        target: update.target,\n        status: update.status || '',\n        name: ((update.target ? _targetStringFromTarget(update.target) : update.builder.name)\n                + ' '.repeat(80)\n              ).substr(0, 40),\n      };\n\n      if (update.status !== undefined) {\n        data.status = update.status;\n      }\n\n      switch (update.state) {\n        case index2.BuilderProgressState.Error:\n          data.status = 'Error: ' + update.error;\n          bars.update(update.id, data);\n          break;\n\n        case index2.BuilderProgressState.Stopped:\n          data.status = 'Done.';\n          bars.complete(update.id);\n          bars.update(update.id, data, update.total, update.total);\n          break;\n\n        case index2.BuilderProgressState.Waiting:\n          bars.update(update.id, data);\n          break;\n\n        case index2.BuilderProgressState.Running:\n          bars.update(update.id, data, update.current, update.total);\n          break;\n      }\n\n      bars.render();\n    },\n  );\n\n  // Wait for full completion of the builder.\n  try {\n    const result = await run.result;\n\n    if (result.success) {\n      parentLogger.info(terminal.green('SUCCESS'));\n    } else {\n      parentLogger.info(terminal.yellow('FAILURE'));\n    }\n\n    parentLogger.info('\\nLogs:');\n    logs.forEach(l => parentLogger.next(l));\n\n    await run.stop();\n    bars.terminate();\n\n    return result.success ? 0 : 1;\n  } catch (err) {\n    parentLogger.info(terminal.red('ERROR'));\n    parentLogger.info('\\nLogs:');\n    logs.forEach(l => parentLogger.next(l));\n\n    parentLogger.fatal('Exception:');\n    parentLogger.fatal(err.stack);\n\n    return 2;\n  }\n}\n\n\nasync function main(args: string[]): Promise<number> {\n  /** Parse the command line. */\n  const argv = minimist(args, { boolean: ['help'] });\n\n  /** Create the DevKit Logger used through the CLI. */\n  const logger = createConsoleLogger(argv['verbose']);\n\n  // Check the target.\n  const targetStr = argv._[0] || '';\n  if (!targetStr || argv.help) {\n    // Show architect usage if there's no target.\n    usage(logger);\n  }\n\n  // Load workspace configuration file.\n  const currentPath = process.cwd();\n  const configFileNames = [\n    'angular.json',\n    '.angular.json',\n    'workspace.json',\n    '.workspace.json',\n  ];\n\n  const configFilePath = findUp(configFileNames, currentPath);\n\n  if (!configFilePath) {\n    logger.fatal(`Workspace configuration file (${configFileNames.join(', ')}) cannot be found in `\n      + `'${currentPath}' or in parent directories.`);\n\n    return 3;\n  }\n\n  const root = dirname(normalize(configFilePath));\n  const configContent = readFileSync(configFilePath, 'utf-8');\n  const workspaceJson = JSON.parse(configContent);\n\n  const registry = new schema.CoreSchemaRegistry();\n  registry.addPostTransform(schema.transforms.addUndefinedDefaults);\n\n  const host = new NodeJsSyncHost();\n  const workspace = new experimental.workspace.Workspace(root, host);\n\n  await workspace.loadWorkspaceFromJson(workspaceJson).toPromise();\n\n  return await _executeTarget(logger, workspace, root, argv, registry);\n}\n\nmain(process.argv.slice(2))\n  .then(code => {\n    process.exit(code);\n  }, err => {\n    console.error('Error: ' + err.stack || err.message || err);\n    process.exit(-1);\n  });\n"]}
{
"name": "@angular-devkit/architect-cli",
"version": "0.14.0-beta.1",
"version": "0.14.0-beta.2",
"description": "Angular Architect CLI",

@@ -20,7 +20,10 @@ "bin": {

"dependencies": {
"@angular-devkit/core": "8.0.0-beta.1",
"@angular-devkit/architect": "0.14.0-beta.1",
"@angular-devkit/architect": "0.14.0-beta.2",
"@angular-devkit/core": "8.0.0-beta.2",
"@types/progress": "^2.0.3",
"ascii-progress": "^1.0.5",
"minimist": "1.2.0",
"symbol-observable": "1.2.0",
"rxjs": "6.3.3"
"progress": "^2.0.3",
"rxjs": "6.3.3",
"symbol-observable": "1.2.0"
},

@@ -27,0 +30,0 @@ "repository": {