This repository has been archived on 2023-01-27. You can view files and clone it, but cannot push or open issues or pull requests.
cad/lib/process/index.js
2022-10-15 19:16:08 +02:00

163 lines
5.9 KiB
JavaScript

"use strict";
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.Helper = exports.Process = exports.STATUS = void 0;
const debug = require("../../log");
const child_process_1 = require("child_process");
var STATUS;
(function (STATUS) {
STATUS[STATUS["OK"] = 0] = "OK";
STATUS[STATUS["ERROR"] = 1] = "ERROR";
STATUS[STATUS["PENDING"] = 2] = "PENDING";
})(STATUS = exports.STATUS || (exports.STATUS = {}));
const fatalHandler = (message, fn) => {
if (message.startsWith('fatal:')) {
fn('\t\ ' + message);
return true;
}
return false;
};
// tslint:disable-next-line:no-empty
const subscribe = (signal, collector = () => { }, options = {}) => {
const buffer = [];
signal.on('message', (message) => debug.debug('message', message));
signal.on('error', (error) => debug.error('std-error', error));
signal.on('data', (data) => {
const message = data.toString();
buffer.push(message); // .replace(/[\x00-\x1F\x7F-\x9F]/g, "")
collector(buffer);
options.debug && console.log("\n Process : \n\t", data);
});
};
const merge = (buffer, data) => buffer.concat(data);
const hook = (process, resolve, reject, cmd, options = {}) => {
let buffer = [];
const collector = (data) => { buffer = buffer.concat(data); };
subscribe(process.stdout, collector, options);
subscribe(process.stderr, collector, options);
process.on('exit', (code, signal) => {
if (code) {
resolve({
code: STATUS.ERROR,
command: cmd,
error: code,
messages: buffer
});
}
else {
resolve({
code: STATUS.OK,
command: cmd,
messages: buffer
});
}
});
return process;
};
class Process {
constructor(options = {}) {
this.binary = 'magick';
this.cwd = '';
this.args = '';
this.binary = options.binary || this.binary;
this.cwd = options.cwd || process.cwd();
}
optionsToString(options) {
const args = [];
// tslint:disable-next-line:forin
for (const k in options) {
const val = options[k];
if (k.length === 1) {
// val is true, add '-k'
if (val === true) {
args.push('-' + k);
}
else if (val !== false) {
// if val is not false, add '-k val'
args.push('-' + k + ' ' + val);
}
}
else {
if (val === true) {
args.push('--' + k);
}
else if (val !== false) {
args.push('--' + k + '=' + val);
}
}
}
return args.join(' ');
}
optionsToArray(options) {
const args = [];
// tslint:disable-next-line:forin
for (const k in options) {
const val = options[k];
if (k.length === 1) {
// val is true, add '-k'
if (val === true) {
args.push('-' + k);
}
else if (val !== false) {
// if val is not false, add '-k val'
args.push('-' + k + ' ' + val);
}
}
else {
if (val === true) {
args.push('--' + k);
}
else if (val !== false) {
args.push('--' + k + '=' + val);
}
}
}
return args;
}
exec(command, options = {}, args = []) {
return __awaiter(this, void 0, void 0, function* () {
args = [command].concat(args);
return new Promise((resolve, reject) => {
console.log("run " + this.binary + ' ' + args.join(' ') + " in " + this.cwd);
const p = child_process_1.exec(this.binary + ' ' + args.join(' '), {
cwd: this.cwd
});
return hook(p, resolve, reject, this.binary + ' ' + args.join(' '), options);
});
});
}
}
exports.Process = Process;
class Helper {
static run(cwd, command, gitArgs, debug_stream = false) {
return __awaiter(this, void 0, void 0, function* () {
// debug.info(`Run ${command} in ${cwd}`,gitArgs);
const gitProcess = new Process({
cwd: cwd,
binary: command
});
const p = gitProcess.exec('', {
debug: debug_stream
}, gitArgs);
if (!debug_stream) {
const spinner = debug.spinner('Run ' + command + ' with ' + gitArgs.join(' ') + ' in ' + cwd).start();
p.then(() => spinner.stopAndPersist());
p.catch((e) => debug.error('Error git command : ' + command, e));
}
else {
debug.info('Run ' + command + ' with ' + gitArgs.join(' ') + ' in ' + cwd);
}
return p;
});
}
}
exports.Helper = Helper;
//# sourceMappingURL=index.js.map