@angular-devkit/architect-cli
Advanced tools
| /// <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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZ3Jlc3MuanMiLCJzb3VyY2VSb290IjoiLi8iLCJzb3VyY2VzIjpbInBhY2thZ2VzL2FuZ3VsYXJfZGV2a2l0L2FyY2hpdGVjdF9jbGkvc3JjL3Byb2dyZXNzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUE7Ozs7OztHQU1HO0FBQ0gsK0NBQWdEO0FBQ2hELHdDQUF3QztBQUN4QyxxQ0FBcUM7QUFFckMsTUFBYSxnQkFBZ0I7SUFHM0IsWUFBb0IsT0FBZSxFQUFVLFVBQVUsT0FBTyxDQUFDLE1BQU07UUFBakQsWUFBTyxHQUFQLE9BQU8sQ0FBUTtRQUFVLFlBQU8sR0FBUCxPQUFPLENBQWlCO1FBRjdELFVBQUssR0FBRyxJQUFJLEdBQUcsRUFBc0MsQ0FBQztJQUVVLENBQUM7SUFDakUsSUFBSSxDQUFDLEVBQU8sRUFBRSxJQUFPO1FBQzNCLE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxFQUFFLGVBQVEsQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDLE9BQU8sSUFBSSxFQUFFLENBQUMsQ0FBQztRQUNqRixNQUFNLEtBQUssR0FBRztZQUNaLElBQUk7WUFDSixHQUFHLEVBQUUsSUFBSSxXQUFXLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRTtnQkFDakMsS0FBSyxFQUFFLElBQUk7Z0JBQ1gsS0FBSyxFQUFFLENBQUM7Z0JBQ1IsS0FBSyxFQUFFLEtBQUs7Z0JBQ1osUUFBUSxFQUFFLEdBQUc7Z0JBQ2IsVUFBVSxFQUFFLEdBQUc7Z0JBQ2YsTUFBTSxFQUFFLElBQUksQ0FBQyxPQUFPO2FBQ3JCLENBQUM7U0FDSCxDQUFDO1FBQ0YsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsRUFBRSxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBQzFCLFFBQVEsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFFeEMsT0FBTyxLQUFLLENBQUM7SUFDZixDQUFDO0lBRUQsUUFBUSxDQUFDLEVBQU87UUFDZCxNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUNwQyxJQUFJLFFBQVEsRUFBRTtZQUNaLFFBQVEsQ0FBQyxHQUFHLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQztTQUM5QjtJQUNILENBQUM7SUFFRCxHQUFHLENBQUMsRUFBTyxFQUFFLElBQU87UUFDbEIsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDdEIsQ0FBQztJQUVELEdBQUcsQ0FBQyxHQUFRO1FBQ1YsTUFBTSxVQUFVLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUM7UUFFdkMsT0FBTyxVQUFVLElBQUksVUFBVSxDQUFDLElBQUksQ0FBQztJQUN2QyxDQUFDO0lBQ0QsR0FBRyxDQUFDLEdBQVE7UUFDVixPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzdCLENBQUM7SUFDRCxNQUFNLENBQUMsR0FBUSxFQUFFLElBQU8sRUFBRSxPQUFnQixFQUFFLEtBQWM7UUFDeEQsSUFBSSxRQUFRLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUM7UUFFbkMsSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUNiLFFBQVEsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxJQUFJLENBQUMsQ0FBQztTQUNqQztRQUVELFFBQVEsQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDO1FBQ3JCLElBQUksS0FBSyxLQUFLLFNBQVMsRUFBRTtZQUN2QixRQUFRLENBQUMsR0FBRyxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUM7U0FDNUI7UUFDRCxJQUFJLE9BQU8sS0FBSyxTQUFTLEVBQUU7WUFDekIsUUFBUSxDQUFDLEdBQUcsQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQUUsSUFBSSxDQUFDLEdBQUcsQ0FBQyxPQUFPLEVBQUUsUUFBUSxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO1NBQ3hFO0lBQ0gsQ0FBQztJQUVELE1BQU0sQ0FBQyxHQUFHLEdBQUcsUUFBUSxFQUFFLElBQTZCO1FBQ2xELE1BQU0sTUFBTSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUM7UUFFNUIsUUFBUSxDQUFDLFVBQVUsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNqRCxRQUFRLENBQUMsUUFBUSxDQUFDLE1BQU0sRUFBRSxDQUFDLENBQUMsQ0FBQztRQUU3QixJQUFJLE1BQU0sR0FBNEMsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLEVBQUUsQ0FBQztRQUMxRSxJQUFJLElBQUksRUFBRTtZQUNSLE1BQU0sR0FBRyxDQUFDLEdBQUcsTUFBTSxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7U0FDM0Q7UUFFRCxLQUFLLE1BQU0sRUFBRSxJQUFJLEVBQUUsR0FBRyxFQUFFLElBQUksTUFBTSxFQUFFO1lBQ2xDLElBQUksR0FBRyxFQUFFLElBQUksQ0FBQyxFQUFFO2dCQUNkLE9BQU87YUFDUjtZQUVELEdBQUcsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDakIsUUFBUSxDQUFDLFVBQVUsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO1lBQ2xDLFFBQVEsQ0FBQyxRQUFRLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQyxDQUFDO1NBQzlCO0lBQ0gsQ0FBQztJQUVELFNBQVM7UUFDUCxLQUFLLE1BQU0sRUFBRSxHQUFHLEVBQUUsSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sRUFBRSxFQUFFO1lBQ3pDLEdBQUcsQ0FBQyxTQUFTLEVBQUUsQ0FBQztTQUNqQjtRQUNELElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDckIsQ0FBQztDQUNGO0FBdEZELDRDQXNGQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgSW5jLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cbmltcG9ydCB7IHRlcm1pbmFsIH0gZnJvbSAnQGFuZ3VsYXItZGV2a2l0L2NvcmUnO1xuaW1wb3J0ICogYXMgUHJvZ3Jlc3NCYXIgZnJvbSAncHJvZ3Jlc3MnO1xuaW1wb3J0ICogYXMgcmVhZGxpbmUgZnJvbSAncmVhZGxpbmUnO1xuXG5leHBvcnQgY2xhc3MgTXVsdGlQcm9ncmVzc0JhcjxLZXksIFQ+IHtcbiAgcHJpdmF0ZSBfYmFycyA9IG5ldyBNYXA8S2V5LCB7IGRhdGE6IFQsIGJhcjogUHJvZ3Jlc3NCYXIgfT4oKTtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIF9zdGF0dXM6IHN0cmluZywgcHJpdmF0ZSBfc3RyZWFtID0gcHJvY2Vzcy5zdGRlcnIpIHt9XG4gIHByaXZhdGUgX2FkZChpZDogS2V5LCBkYXRhOiBUKTogeyBkYXRhOiBULCBiYXI6IFByb2dyZXNzQmFyIH0ge1xuICAgIGNvbnN0IHdpZHRoID0gTWF0aC5taW4oODAsIHRlcm1pbmFsLmdldENhcGFiaWxpdGllcyh0aGlzLl9zdHJlYW0pLmNvbHVtbnMgfHwgODApO1xuICAgIGNvbnN0IHZhbHVlID0ge1xuICAgICAgZGF0YSxcbiAgICAgIGJhcjogbmV3IFByb2dyZXNzQmFyKHRoaXMuX3N0YXR1cywge1xuICAgICAgICBjbGVhcjogdHJ1ZSxcbiAgICAgICAgdG90YWw6IDEsXG4gICAgICAgIHdpZHRoOiB3aWR0aCxcbiAgICAgICAgY29tcGxldGU6ICcjJyxcbiAgICAgICAgaW5jb21wbGV0ZTogJy4nLFxuICAgICAgICBzdHJlYW06IHRoaXMuX3N0cmVhbSxcbiAgICAgIH0pLFxuICAgIH07XG4gICAgdGhpcy5fYmFycy5zZXQoaWQsIHZhbHVlKTtcbiAgICByZWFkbGluZS5tb3ZlQ3Vyc29yKHRoaXMuX3N0cmVhbSwgMCwgMSk7XG5cbiAgICByZXR1cm4gdmFsdWU7XG4gIH1cblxuICBjb21wbGV0ZShpZDogS2V5KSB7XG4gICAgY29uc3QgbWF5YmVCYXIgPSB0aGlzLl9iYXJzLmdldChpZCk7XG4gICAgaWYgKG1heWJlQmFyKSB7XG4gICAgICBtYXliZUJhci5iYXIuY29tcGxldGUgPSB0cnVlO1xuICAgIH1cbiAgfVxuXG4gIGFkZChpZDogS2V5LCBkYXRhOiBUKSB7XG4gICAgdGhpcy5fYWRkKGlkLCBkYXRhKTtcbiAgfVxuXG4gIGdldChrZXk6IEtleSk6IFQgfCB1bmRlZmluZWQge1xuICAgIGNvbnN0IG1heWJlVmFsdWUgPSB0aGlzLl9iYXJzLmdldChrZXkpO1xuXG4gICAgcmV0dXJuIG1heWJlVmFsdWUgJiYgbWF5YmVWYWx1ZS5kYXRhO1xuICB9XG4gIGhhcyhrZXk6IEtleSkge1xuICAgIHJldHVybiB0aGlzLl9iYXJzLmhhcyhrZXkpO1xuICB9XG4gIHVwZGF0ZShrZXk6IEtleSwgZGF0YTogVCwgY3VycmVudD86IG51bWJlciwgdG90YWw/OiBudW1iZXIpIHtcbiAgICBsZXQgbWF5YmVCYXIgPSB0aGlzLl9iYXJzLmdldChrZXkpO1xuXG4gICAgaWYgKCFtYXliZUJhcikge1xuICAgICAgbWF5YmVCYXIgPSB0aGlzLl9hZGQoa2V5LCBkYXRhKTtcbiAgICB9XG5cbiAgICBtYXliZUJhci5kYXRhID0gZGF0YTtcbiAgICBpZiAodG90YWwgIT09IHVuZGVmaW5lZCkge1xuICAgICAgbWF5YmVCYXIuYmFyLnRvdGFsID0gdG90YWw7XG4gICAgfVxuICAgIGlmIChjdXJyZW50ICE9PSB1bmRlZmluZWQpIHtcbiAgICAgIG1heWJlQmFyLmJhci5jdXJyID0gTWF0aC5tYXgoMCwgTWF0aC5taW4oY3VycmVudCwgbWF5YmVCYXIuYmFyLnRvdGFsKSk7XG4gICAgfVxuICB9XG5cbiAgcmVuZGVyKG1heCA9IEluZmluaXR5LCBzb3J0PzogKGE6IFQsIGI6IFQpID0+IG51bWJlcikge1xuICAgIGNvbnN0IHN0cmVhbSA9IHRoaXMuX3N0cmVhbTtcblxuICAgIHJlYWRsaW5lLm1vdmVDdXJzb3Ioc3RyZWFtLCAwLCAtdGhpcy5fYmFycy5zaXplKTtcbiAgICByZWFkbGluZS5jdXJzb3JUbyhzdHJlYW0sIDApO1xuXG4gICAgbGV0IHZhbHVlczogSXRlcmFibGU8eyBkYXRhOiBULCBiYXI6IFByb2dyZXNzQmFyIH0+ID0gdGhpcy5fYmFycy52YWx1ZXMoKTtcbiAgICBpZiAoc29ydCkge1xuICAgICAgdmFsdWVzID0gWy4uLnZhbHVlc10uc29ydCgoYSwgYikgPT4gc29ydChhLmRhdGEsIGIuZGF0YSkpO1xuICAgIH1cblxuICAgIGZvciAoY29uc3QgeyBkYXRhLCBiYXIgfSBvZiB2YWx1ZXMpIHtcbiAgICAgIGlmIChtYXgtLSA9PSAwKSB7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cblxuICAgICAgYmFyLnJlbmRlcihkYXRhKTtcbiAgICAgIHJlYWRsaW5lLm1vdmVDdXJzb3Ioc3RyZWFtLCAwLCAxKTtcbiAgICAgIHJlYWRsaW5lLmN1cnNvclRvKHN0cmVhbSwgMCk7XG4gICAgfVxuICB9XG5cbiAgdGVybWluYXRlKCkge1xuICAgIGZvciAoY29uc3QgeyBiYXIgfSBvZiB0aGlzLl9iYXJzLnZhbHVlcygpKSB7XG4gICAgICBiYXIudGVybWluYXRlKCk7XG4gICAgfVxuICAgIHRoaXMuX2JhcnMuY2xlYXIoKTtcbiAgfVxufVxuIl19 |
| #!/usr/bin/env node | ||
| import 'symbol-observable'; | ||
| export {}; |
+114
-70
| #!/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"]} |
+8
-5
| { | ||
| "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": { |
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
Filesystem access
Supply chain riskAccesses the file system, and could potentially read sensitive data.
Found 1 instance in 1 package
Filesystem access
Supply chain riskAccesses the file system, and could potentially read sensitive data.
Found 1 instance in 1 package
35672
116.59%6
50%264
127.59%8
60%1
Infinity%+ Added
+ Added
+ Added
+ Added
+ Added
+ Added
+ Added
+ Added
+ Added
+ Added
+ Added
+ Added
+ Added
+ Added
+ Added
+ Added
- Removed
- Removed
- Removed