Join our webinar on Wednesday, June 26, at 1pm EDTHow Chia Mitigates Risk in the Crypto Industry.Register
Socket
Socket
Sign inDemoInstall

makfy

Package Overview
Dependencies
54
Maintainers
1
Versions
43
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

Comparing version 1.4.2 to 2.0.0

dist/lib/config.d.ts

4

CHANGELOG.md
# makfy changelog
## 2.0.0
- whole new syntax to define commands more easily. see README.md for further details.
## 1.4.0

@@ -4,0 +8,0 @@

111

dist/bin/cli.js

@@ -68,2 +68,3 @@ #! /usr/bin/env node

var lib_1 = require("../lib/");
var config_1 = require("../lib/config");
var errors_1 = require("../lib/errors");

@@ -172,49 +173,38 @@ var schema_1 = require("../lib/schema");

try {
var usingDefaultExport = false;
var fileExports = require(absoluteFilename);
// use default export if available
if (fileExports.default) {
usingDefaultExport = true;
fileExports = fileExports.default;
require(absoluteFilename);
if (!loadContents) {
return {};
}
if (!typeChecking_1.isObject(fileExports)) {
exitWithError(2 /* UserFileError */, "module.exports" + (usingDefaultExport ? ".default" : "") + " inside '" + filename + "' is not an object");
return;
}
var contents = void 0;
if (loadContents) {
contents = fs.readFileSync(absoluteFilename, "utf8");
var deps = fileExports.dependencies;
if (deps) {
if (!typeChecking_1.isStringArray(deps)) {
exitWithError(2 /* UserFileError */, "export dependencies must be a string array with paths to files");
}
var rootDir = path.dirname(absoluteFilename);
try {
for (var deps_1 = __values(deps), deps_1_1 = deps_1.next(); !deps_1_1.done; deps_1_1 = deps_1.next()) {
var dep = deps_1_1.value;
var absDepFilename = void 0;
if (path.isAbsolute(dep)) {
absDepFilename = dep;
}
else {
absDepFilename = path.join(rootDir, dep);
}
if (!fs.existsSync(absDepFilename) && !absDepFilename.toLowerCase().endsWith(".js")) {
absDepFilename += ".js";
}
contents += fs.readFileSync(absDepFilename, "utf8");
var contents = fs.readFileSync(absoluteFilename, "utf8");
var deps = config_1.config.dependencies;
if (deps) {
if (!typeChecking_1.isStringArray(deps)) {
exitWithError(2 /* UserFileError */, "export dependencies must be a string array with paths to files");
}
var rootDir = path.dirname(absoluteFilename);
try {
for (var deps_1 = __values(deps), deps_1_1 = deps_1.next(); !deps_1_1.done; deps_1_1 = deps_1.next()) {
var dep = deps_1_1.value;
var absDepFilename = void 0;
if (path.isAbsolute(dep)) {
absDepFilename = dep;
}
}
catch (e_2_1) { e_2 = { error: e_2_1 }; }
finally {
try {
if (deps_1_1 && !deps_1_1.done && (_a = deps_1.return)) _a.call(deps_1);
else {
absDepFilename = path.join(rootDir, dep);
}
finally { if (e_2) throw e_2.error; }
if (!fs.existsSync(absDepFilename) && !absDepFilename.toLowerCase().endsWith(".js")) {
absDepFilename += ".js";
}
contents += fs.readFileSync(absDepFilename, "utf8");
}
}
catch (e_2_1) { e_2 = { error: e_2_1 }; }
finally {
try {
if (deps_1_1 && !deps_1_1.done && (_a = deps_1.return)) _a.call(deps_1);
}
finally { if (e_2) throw e_2.error; }
}
}
return {
exports: fileExports,
contents: contents

@@ -229,6 +219,6 @@ };

var mainAsync = function () { return __awaiter(_this, void 0, void 0, function () {
var e_3, _a, e_4, _b, execute, fileToLoad, exports_1, commandName_1, fileToLoad_1, _c, exports_2, contents_1, commandName_2, commandArgs_1, reservedArgNames_1, reservedArgNames_1_1, resArg, _d, _e, argName, options_1, err_1, prefix;
var e_3, _a, e_4, _b, execute, fileToLoad, commandName_1, fileToLoad_1, contents_1, commandName_2, commandArgs_1, reservedArgNames_1, reservedArgNames_1_1, resArg, _c, _d, argName, options_1, err_1, prefix;
var _this = this;
return __generator(this, function (_f) {
switch (_f.label) {
return __generator(this, function (_e) {
switch (_e.label) {
case 0:

@@ -243,3 +233,4 @@ console_1.resetColors();

fileToLoad = getFileToLoad();
exports_1 = loadFile(fileToLoad, false).exports;
// tslint:disable-next-line: no-unused-expression
loadFile(fileToLoad, false);
commandName_1 = argv._.length > 0 ? argv._[0].trim() : undefined;

@@ -255,3 +246,3 @@ if (commandName_1) {

output = chalk_1.default.bold.gray("listing '" + commandName_1 + "' command...\n\n") +
lib_1.listCommand(exports_1.commands, commandName_1, true);
lib_1.listCommand(config_1.config.commands, commandName_1, true);
console.log(output);

@@ -266,3 +257,3 @@ return [2 /*return*/];

return __generator(this, function (_a) {
output = chalk_1.default.bold.gray("listing all commands...\n\n") + lib_1.listAllCommands(exports_1.commands, true);
output = chalk_1.default.bold.gray("listing all commands...\n\n") + lib_1.listAllCommands(config_1.config.commands, true);
console.log(output);

@@ -281,3 +272,3 @@ return [2 /*return*/];

fileToLoad_1 = getFileToLoad();
_c = loadFile(fileToLoad_1, true), exports_2 = _c.exports, contents_1 = _c.contents;
contents_1 = loadFile(fileToLoad_1, true).contents;
commandName_2 = argv._[0].trim();

@@ -302,4 +293,4 @@ commandArgs_1 = __assign({}, argv);

// remove non alphanumeric extended args
for (_d = __values(Object.keys(argv)), _e = _d.next(); !_e.done; _e = _d.next()) {
argName = _e.value;
for (_c = __values(Object.keys(argv)), _d = _c.next(); !_d.done; _d = _c.next()) {
argName = _d.value;
if (!new RegExp(schema_1.alphanumericExtendedPattern).test(argName)) {

@@ -313,14 +304,7 @@ delete commandArgs_1[argName];

try {
if (_e && !_e.done && (_b = _d.return)) _b.call(_d);
if (_d && !_d.done && (_b = _c.return)) _b.call(_c);
}
finally { if (e_4) throw e_4.error; }
}
options_1 = exports_2.options;
if (options_1 === undefined) {
options_1 = {};
}
if (!typeChecking_1.isObject(options_1)) {
exitWithError(2 /* UserFileError */, formatting_1.errorMessageForObject(["options"], "must be an object or undefined"));
return [2 /*return*/];
}
options_1 = config_1.config.options;
if (argv.profile) {

@@ -338,3 +322,3 @@ options_1.profile = true;

makfyFileContents: contents_1,
commands: exports_2.commands,
commands: config_1.config.commands,
commandName: commandName_2,

@@ -351,11 +335,11 @@ commandArgs: commandArgs_1,

}
_f.label = 1;
_e.label = 1;
case 1:
_f.trys.push([1, 3, 4, 5]);
_e.trys.push([1, 3, 4, 5]);
return [4 /*yield*/, execute()];
case 2:
_f.sent();
_e.sent();
return [3 /*break*/, 5];
case 3:
err_1 = _f.sent();
err_1 = _e.sent();
console_1.resetColors();

@@ -388,2 +372,1 @@ if (err_1 instanceof errors_1.MakfyError) {

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cli.js","sourceRoot":"","sources":["../../src/bin/cli.ts"],"names":[],"mappings":"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","sourcesContent":["#! /usr/bin/env node\r\n\r\nimport chalk from \"chalk\";\r\nimport * as fs from \"fs\";\r\nimport * as path from \"path\";\r\nimport stripColor from \"strip-ansi\";\r\nimport * as tsNode from \"ts-node\";\r\nimport * as yargs from \"yargs\";\r\nimport { listAllCommands, listCommand, MakfyConfig, runCommandAsync } from \"../lib/\";\r\nimport { MakfyError, RunError } from \"../lib/errors\";\r\nimport { alphanumericExtendedPattern } from \"../lib/schema\";\r\nimport { reservedArgNames } from \"../lib/schema/args\";\r\nimport { Commands } from \"../lib/schema/commands\";\r\nimport { PartialOptions } from \"../lib/schema/options\";\r\nimport { resetColors } from \"../lib/utils/console\";\r\nimport { errorMessageForObject, formatContextId } from \"../lib/utils/formatting\";\r\nimport { isObject, isStringArray } from \"../lib/utils/typeChecking\";\r\n\r\nyargs.parserConfiguration({\r\n  \"short-option-groups\": false,\r\n  \"camel-case-expansion\": false,\r\n  \"dot-notation\": false,\r\n  \"parse-numbers\": false,\r\n  \"boolean-negation\": false,\r\n  \"duplicate-arguments-array\": false,\r\n  \"flatten-duplicate-arrays\": false\r\n});\r\n\r\n// enable ts support\r\ntsNode.register({\r\n  pretty: true\r\n});\r\n\r\nconst programName = \"makfy\";\r\nconst argv = yargs.help(false).argv;\r\n\r\nconst enum ErrCode {\r\n  CliError = 1,\r\n  UserFileError = 2,\r\n  ExecError = 3\r\n}\r\n\r\nconst exitWithError = (code: ErrCode, message?: string, prefix?: string): never => {\r\n  resetColors();\r\n  if (message) {\r\n    console.error((prefix ? prefix : \"\") + chalk.bold.red(\"[ERROR] \" + message));\r\n  }\r\n  process.exit(code);\r\n\r\n  // this should never happen\r\n  throw new Error();\r\n};\r\n\r\nconst defaultFilename = programName + \"file\";\r\nconst version = require(\"../../package.json\").version;\r\n\r\nconst printProgramHelp = () => {\r\n  console.log(`${programName} v${version}`);\r\n  console.log();\r\n  console.log(`usage:`);\r\n\r\n  const pad = (str: string) => {\r\n    str = \" \" + str;\r\n    for (let i = stripColor(str).length; i < 34; i++) {\r\n      str += \" \";\r\n    }\r\n    return str;\r\n  };\r\n\r\n  const logHelp1 = (what: string, how: string, showFile: boolean) => {\r\n    const left = pad(chalk.bold.green(` - ${what}`));\r\n    const right = chalk.bold.gray(\r\n      `${programName} ${\r\n        showFile ? chalk.bold.magenta(`[-f ${defaultFilename}] `) : \"\"\r\n      }${chalk.bold.magenta(how)}`\r\n    );\r\n    console.log(left + right);\r\n  };\r\n\r\n  logHelp1(\"run command:\", `<command> ...commandOptions`, true);\r\n  logHelp1(\"list all commands:\", `--list`, true);\r\n  logHelp1(\"list command:\", ` <command> --list`, true);\r\n  logHelp1(\"show help (this):\", `[--help]`, false);\r\n\r\n  const logArgHelp = (argName: string, desc: string) => {\r\n    const left = pad(\" \" + chalk.bold.gray(`[${chalk.bold.magenta(argName)}]`));\r\n    console.log(left + chalk.bold.gray(desc));\r\n  };\r\n\r\n  logArgHelp(\"--profile\", \"force show the time it takes to run each subcommand\");\r\n  logArgHelp(\"--show-time\", \"force show the current time\");\r\n  logArgHelp(\"--color/--no-color\", \"force colored/uncolored output (default: autodetect)\");\r\n};\r\n\r\ninterface FileToLoad {\r\n  filename: string;\r\n  absoluteFilename: string;\r\n}\r\n\r\nconst getFileToLoad = (): FileToLoad => {\r\n  let mainFilename = defaultFilename;\r\n  if (argv.f || argv.file) {\r\n    if (argv.f && argv.file) {\r\n      exitWithError(ErrCode.CliError, `-f and --file cannot be used at the same time`);\r\n    }\r\n    mainFilename = (argv.f || argv.file) as string;\r\n  }\r\n\r\n  const filesToTry: string[] = [mainFilename];\r\n  if (path.extname(mainFilename) === \"\") {\r\n    filesToTry.push(mainFilename + \".ts\");\r\n    filesToTry.push(mainFilename + \".js\");\r\n  }\r\n\r\n  for (const filename of filesToTry) {\r\n    if (fs.existsSync(filename)) {\r\n      console.log(chalk.bold.gray(`using command file '${chalk.bold.magenta(filename)}'...`));\r\n\r\n      const absoluteFilename = path.resolve(filename);\r\n\r\n      return {\r\n        filename,\r\n        absoluteFilename\r\n      };\r\n    }\r\n  }\r\n\r\n  exitWithError(ErrCode.CliError, `command file not found, tried ${filesToTry.join(\", \")}`);\r\n  // this should never happen\r\n  throw new Error();\r\n};\r\n\r\ninterface LoadFileResult {\r\n  exports: {\r\n    commands: Commands;\r\n    options?: PartialOptions;\r\n  };\r\n  contents?: string;\r\n}\r\n\r\nconst loadFile = (fileToLoad: FileToLoad, loadContents: boolean): LoadFileResult | undefined => {\r\n  const { filename, absoluteFilename } = fileToLoad;\r\n\r\n  // try to load the user file\r\n  try {\r\n    let usingDefaultExport = false;\r\n    let fileExports: MakfyConfig = require(absoluteFilename);\r\n\r\n    // use default export if available\r\n    if ((fileExports as any).default) {\r\n      usingDefaultExport = true;\r\n      fileExports = (fileExports as any).default;\r\n    }\r\n\r\n    if (!isObject(fileExports)) {\r\n      exitWithError(\r\n        ErrCode.UserFileError,\r\n        `module.exports${\r\n          usingDefaultExport ? \".default\" : \"\"\r\n        } inside '${filename}' is not an object`\r\n      );\r\n      return;\r\n    }\r\n\r\n    let contents;\r\n    if (loadContents) {\r\n      contents = fs.readFileSync(absoluteFilename, \"utf8\");\r\n      const deps = fileExports.dependencies;\r\n      if (deps) {\r\n        if (!isStringArray(deps)) {\r\n          exitWithError(\r\n            ErrCode.UserFileError,\r\n            `export dependencies must be a string array with paths to files`\r\n          );\r\n        }\r\n\r\n        const rootDir = path.dirname(absoluteFilename);\r\n        for (const dep of deps) {\r\n          let absDepFilename;\r\n          if (path.isAbsolute(dep)) {\r\n            absDepFilename = dep;\r\n          } else {\r\n            absDepFilename = path.join(rootDir, dep);\r\n          }\r\n\r\n          if (!fs.existsSync(absDepFilename) && !absDepFilename.toLowerCase().endsWith(\".js\")) {\r\n            absDepFilename += \".js\";\r\n          }\r\n\r\n          contents += fs.readFileSync(absDepFilename, \"utf8\");\r\n        }\r\n      }\r\n    }\r\n\r\n    return {\r\n      exports: fileExports,\r\n      contents: contents\r\n    };\r\n  } catch (err) {\r\n    exitWithError(ErrCode.UserFileError, `error requiring ${filename}:\\n${err.stack.toString()}`);\r\n    return;\r\n  }\r\n};\r\n\r\nconst mainAsync = async () => {\r\n  resetColors();\r\n\r\n  if (argv.help || argv.h) {\r\n    printProgramHelp();\r\n    exitWithError(ErrCode.CliError);\r\n    return;\r\n  }\r\n\r\n  let execute: () => Promise<void>;\r\n\r\n  if (argv.list || argv.l || argv._.length <= 0) {\r\n    // list\r\n    const fileToLoad = getFileToLoad();\r\n    const { exports } = loadFile(fileToLoad, false)!;\r\n\r\n    const commandName = argv._.length > 0 ? argv._[0].trim() : undefined;\r\n    if (commandName) {\r\n      if (argv._.length > 1) {\r\n        exitWithError(\r\n          ErrCode.CliError,\r\n          `specify only one command to list or don't specify any commands to list them all`\r\n        );\r\n        return;\r\n      }\r\n\r\n      execute = async () => {\r\n        const output =\r\n          chalk.bold.gray(`listing '${commandName}' command...\\n\\n`) +\r\n          listCommand(exports.commands, commandName, true);\r\n        console.log(output);\r\n      };\r\n    } else {\r\n      execute = async () => {\r\n        const output =\r\n          chalk.bold.gray(\"listing all commands...\\n\\n\") + listAllCommands(exports.commands, true);\r\n        console.log(output);\r\n      };\r\n    }\r\n  } else {\r\n    // run\r\n    if (argv._.length > 1) {\r\n      exitWithError(ErrCode.CliError, \"only one command can be run at the same time\");\r\n      return;\r\n    }\r\n\r\n    const fileToLoad = getFileToLoad();\r\n    const { exports, contents } = loadFile(fileToLoad, true)!;\r\n\r\n    const commandName = argv._[0].trim();\r\n\r\n    // remove reserved args\r\n    const commandArgs = { ...argv };\r\n    delete commandArgs._;\r\n    delete commandArgs.$0;\r\n\r\n    for (const resArg of reservedArgNames) {\r\n      delete commandArgs[resArg];\r\n    }\r\n\r\n    // remove non alphanumeric extended args\r\n    for (const argName of Object.keys(argv)) {\r\n      if (!new RegExp(alphanumericExtendedPattern).test(argName)) {\r\n        delete commandArgs[argName];\r\n      }\r\n    }\r\n\r\n    let options = exports.options;\r\n    if (options === undefined) {\r\n      options = {};\r\n    }\r\n    if (!isObject(options)) {\r\n      exitWithError(\r\n        ErrCode.UserFileError,\r\n        errorMessageForObject([\"options\"], `must be an object or undefined`)\r\n      );\r\n      return;\r\n    }\r\n    if (argv.profile) {\r\n      options.profile = true;\r\n    }\r\n    if (argv.showTime) {\r\n      options.showTime = true;\r\n    }\r\n\r\n    execute = async () => {\r\n      await runCommandAsync({\r\n        makfyFilename: fileToLoad.filename,\r\n        makfyFileContents: contents,\r\n        commands: exports.commands,\r\n        commandName: commandName,\r\n        commandArgs: commandArgs,\r\n        options: options\r\n      });\r\n    };\r\n  }\r\n\r\n  try {\r\n    await execute();\r\n  } catch (err) {\r\n    resetColors();\r\n    if (err instanceof MakfyError) {\r\n      const prefix = err.execContext ? formatContextId(err.execContext) : undefined;\r\n      exitWithError(ErrCode.UserFileError, err.message, prefix);\r\n    } else if (err instanceof RunError) {\r\n      // the message should be printed already\r\n      exitWithError(ErrCode.ExecError);\r\n    } else {\r\n      throw err;\r\n    }\r\n  } finally {\r\n    resetColors();\r\n  }\r\n};\r\n\r\ntry {\r\n  //noinspection JSIgnoredPromiseFromCall\r\n  mainAsync();\r\n} catch (err) {\r\n  throw err;\r\n}\r\n"]}

@@ -1,2 +0,2 @@

import { ExecContext } from "./execRuntime";
import { ExecContext } from "./schema/runtime";
export declare class MakfyError extends Error {

@@ -3,0 +3,0 @@ execContext?: ExecContext;

@@ -40,2 +40,1 @@ "use strict";

exports.RunError = RunError;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3JzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2xpYi9lcnJvcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7O0FBRUE7SUFBZ0MsOEJBQUs7SUFHbkMsb0JBQVksT0FBZSxFQUFFLE9BQWdDO1FBQTdELFlBQ0Usa0JBQU0sT0FBTyxDQUFDLFNBSWY7UUFIQyxNQUFNLENBQUMsY0FBYyxDQUFDLEtBQUksRUFBRSxVQUFVLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDbEQsS0FBSSxDQUFDLElBQUksR0FBRyxLQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQztRQUNsQyxLQUFJLENBQUMsV0FBVyxHQUFHLE9BQU8sQ0FBQzs7SUFDN0IsQ0FBQztJQUNILGlCQUFDO0FBQUQsQ0FBQyxBQVRELENBQWdDLEtBQUssR0FTcEM7QUFUWSxnQ0FBVTtBQVd2QjtJQUE4Qiw0QkFBSztJQUdqQyxrQkFBWSxPQUFlLEVBQUUsT0FBZ0M7UUFBN0QsWUFDRSxrQkFBTSxPQUFPLENBQUMsU0FJZjtRQUhDLE1BQU0sQ0FBQyxjQUFjLENBQUMsS0FBSSxFQUFFLFFBQVEsQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUNoRCxLQUFJLENBQUMsSUFBSSxHQUFHLEtBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDO1FBQ2xDLEtBQUksQ0FBQyxXQUFXLEdBQUcsT0FBTyxDQUFDOztJQUM3QixDQUFDO0lBQ0gsZUFBQztBQUFELENBQUMsQUFURCxDQUE4QixLQUFLLEdBU2xDO0FBVFksNEJBQVEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFeGVjQ29udGV4dCB9IGZyb20gXCIuL2V4ZWNSdW50aW1lXCI7XHJcblxyXG5leHBvcnQgY2xhc3MgTWFrZnlFcnJvciBleHRlbmRzIEVycm9yIHtcclxuICBleGVjQ29udGV4dD86IEV4ZWNDb250ZXh0O1xyXG5cclxuICBjb25zdHJ1Y3RvcihtZXNzYWdlOiBzdHJpbmcsIGNvbnRleHQ6IEV4ZWNDb250ZXh0IHwgdW5kZWZpbmVkKSB7XHJcbiAgICBzdXBlcihtZXNzYWdlKTtcclxuICAgIE9iamVjdC5zZXRQcm90b3R5cGVPZih0aGlzLCBNYWtmeUVycm9yLnByb3RvdHlwZSk7XHJcbiAgICB0aGlzLm5hbWUgPSB0aGlzLmNvbnN0cnVjdG9yLm5hbWU7XHJcbiAgICB0aGlzLmV4ZWNDb250ZXh0ID0gY29udGV4dDtcclxuICB9XHJcbn1cclxuXHJcbmV4cG9ydCBjbGFzcyBSdW5FcnJvciBleHRlbmRzIEVycm9yIHtcclxuICBleGVjQ29udGV4dD86IEV4ZWNDb250ZXh0O1xyXG5cclxuICBjb25zdHJ1Y3RvcihtZXNzYWdlOiBzdHJpbmcsIGNvbnRleHQ6IEV4ZWNDb250ZXh0IHwgdW5kZWZpbmVkKSB7XHJcbiAgICBzdXBlcihtZXNzYWdlKTtcclxuICAgIE9iamVjdC5zZXRQcm90b3R5cGVPZih0aGlzLCBSdW5FcnJvci5wcm90b3R5cGUpO1xyXG4gICAgdGhpcy5uYW1lID0gdGhpcy5jb25zdHJ1Y3Rvci5uYW1lO1xyXG4gICAgdGhpcy5leGVjQ29udGV4dCA9IGNvbnRleHQ7XHJcbiAgfVxyXG59XHJcbiJdfQ==

@@ -1,22 +0,4 @@

import { ParsedCommands } from "./parser/commands";
import { GetFileChangesResult, MakfyContext } from "./schema/runtime";
import { HashCollection } from "./utils/hash";
export interface CachedGetFileChangesResult {
result: GetFileChangesResult;
oldHashCollection?: HashCollection;
newHashCollection: HashCollection;
}
export interface ExecContext extends MakfyContext {
parsedCommands: ParsedCommands;
makfyFileContents?: string;
idStack: string[];
cwd?: string;
env?: object;
syncMode: boolean;
getFileChangesResults: {
[hashFilename: string]: CachedGetFileChangesResult;
};
}
import { ExecContext } from "./schema/runtime";
export declare const runCommandAsync: (commandName: string, commandArgs: {
[argName: string]: any;
}, baseContext: ExecContext, unknownArgMeansError: boolean) => Promise<void>;

@@ -1,11 +0,6 @@

import { command, Command, CommandFromFunction, Commands } from "./schema/commands";
import { cmd, Commands } from "./schema/commands";
import { PartialOptions } from "./schema/options";
import { ExecCommand } from "./schema/runtime";
export { command };
export interface MakfyConfig {
commands: Commands;
dependencies?: string[];
options?: PartialOptions;
}
export declare function makfyConfig(makfyConfigData: MakfyConfig): MakfyConfig;
export * from "./simpleArgs";
export * from "./utils";
export { cmd };
export interface RunCommandOptions {

@@ -22,2 +17,3 @@ commands: Commands;

export declare const listAllCommands: (commands: Commands, listArguments?: boolean, listInternal?: boolean) => string;
export declare function run(...inlineCommands: ExecCommand[]): Command<{}> & CommandFromFunction;
export declare function setOptions(opts: PartialOptions): void;
export declare function setDependencies(deps: string[] | undefined): void;

@@ -78,2 +78,5 @@ "use strict";

};
function __export(m) {
for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p];
}
var _this = this;

@@ -83,2 +86,3 @@ Object.defineProperty(exports, "__esModule", { value: true });

var strip_ansi_1 = require("strip-ansi");
var config_1 = require("./config");
var errors_1 = require("./errors");

@@ -89,3 +93,3 @@ var execRuntime = require("./execRuntime");

var commands_2 = require("./schema/commands");
exports.command = commands_2.command;
exports.cmd = commands_2.cmd;
var console_1 = require("./utils/console");

@@ -97,7 +101,4 @@ var formatting_1 = require("./utils/formatting");

var prettyHrTime = require("pretty-hrtime");
// only used for TS typing
function makfyConfig(makfyConfigData) {
return makfyConfigData;
}
exports.makfyConfig = makfyConfig;
__export(require("./simpleArgs"));
__export(require("./utils"));
exports.runCommandAsync = function (runCommandOptions) { return __awaiter(_this, void 0, void 0, function () {

@@ -119,3 +120,3 @@ var e_1, _a, commands, commandName, commandArgs, options, makfyFilename, makfyFileContents, parsedOptions, parsedCommands, currentCommand, parsedCommand, startTime, getFileChangesResults, execContext, savePromises, _b, _c, _d, key, value, err_1, endTime;

}
if (currentCommand.internal) {
if (commands_2.isInternalCommand(commandName)) {
throw new errors_1.MakfyError("internal commands cannot be run directly", undefined);

@@ -261,4 +262,3 @@ }

var commandName = _c.value;
var currentCommand = commands[commandName];
if (!currentCommand.internal || listInternal) {
if (!commands_2.isInternalCommand(commandName) || listInternal) {
output += exports.listCommand(commands, commandName, listArguments);

@@ -277,24 +277,9 @@ }

};
// short syntax
function run() {
var _this = this;
var inlineCommands = [];
for (var _i = 0; _i < arguments.length; _i++) {
inlineCommands[_i] = arguments[_i];
}
var cmd = {
run: function (exec) { return __awaiter(_this, void 0, void 0, function () {
return __generator(this, function (_a) {
switch (_a.label) {
case 0: return [4 /*yield*/, exec.apply(void 0, __spread(inlineCommands))];
case 1:
_a.sent();
return [2 /*return*/];
}
});
}); }
};
return cmd;
function setOptions(opts) {
Object.assign(config_1.config.options, opts);
}
exports.run = run;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/lib/index.ts"],"names":[],"mappings":"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","sourcesContent":["import chalk, { Level } from \"chalk\";\r\nimport stripColor from \"strip-ansi\";\r\nimport { MakfyError, RunError } from \"./errors\";\r\nimport * as execRuntime from \"./execRuntime\";\r\nimport { ParsedArgDefinition } from \"./parser/commandArg\";\r\nimport { parseCommands } from \"./parser/commands\";\r\nimport { parseOptions } from \"./parser/options\";\r\nimport { command, Command, CommandFromFunction, Commands } from \"./schema/commands\";\r\nimport { FullOptions, PartialOptions } from \"./schema/options\";\r\nimport { ExecCommand, ExecFunction } from \"./schema/runtime\";\r\nimport { resetColors } from \"./utils/console\";\r\nimport { errorMessageForObject, getTimeString } from \"./utils/formatting\";\r\nimport { saveHashCollectionFileAsync } from \"./utils/hash\";\r\nimport { TextWriter } from \"./utils/TextWriter\";\r\nimport { isObject } from \"./utils/typeChecking\";\r\n\r\nconst prettyHrTime = require(\"pretty-hrtime\");\r\ntype ExecContext = execRuntime.ExecContext;\r\n\r\nexport { command };\r\n\r\nexport interface MakfyConfig {\r\n  commands: Commands;\r\n  dependencies?: string[];\r\n  options?: PartialOptions;\r\n}\r\n\r\n// only used for TS typing\r\nexport function makfyConfig(makfyConfigData: MakfyConfig): MakfyConfig {\r\n  return makfyConfigData;\r\n}\r\n\r\nexport interface RunCommandOptions {\r\n  commands: Commands;\r\n  commandName: string;\r\n  commandArgs: object | undefined;\r\n  makfyFilename: string;\r\n  makfyFileContents?: string;\r\n  options: PartialOptions | undefined;\r\n}\r\n\r\nexport const runCommandAsync = async (runCommandOptions: RunCommandOptions) => {\r\n  const {\r\n    commands,\r\n    commandName,\r\n    commandArgs,\r\n    options,\r\n    makfyFilename,\r\n    makfyFileContents\r\n  } = runCommandOptions;\r\n\r\n  if (!commandName) {\r\n    throw new MakfyError(\"command name missing\", undefined);\r\n  }\r\n\r\n  const parsedOptions: FullOptions = parseOptions(options, false);\r\n\r\n  const parsedCommands = parseCommands(commands, false);\r\n  const currentCommand = commands[commandName];\r\n  const parsedCommand = parsedCommands[commandName];\r\n  if (!parsedCommand || !currentCommand) {\r\n    throw new MakfyError(`command '${commandName}' not found`, undefined);\r\n  }\r\n\r\n  if (currentCommand.internal) {\r\n    throw new MakfyError(\"internal commands cannot be run directly\", undefined);\r\n  }\r\n\r\n  console.log(\r\n    getTimeString(parsedOptions.showTime) + chalk.bgBlue.bold.white(`${commandName} - running...`)\r\n  );\r\n\r\n  // run\r\n  const startTime = process.hrtime();\r\n\r\n  const getFileChangesResults: ExecContext[\"getFileChangesResults\"] = {};\r\n\r\n  const execContext: ExecContext = {\r\n    // for MakfyContext\r\n    commandName: commandName,\r\n    commandArgs: commandArgs || {},\r\n    commands: commands,\r\n    options: {\r\n      ...parsedOptions,\r\n      colorMode: chalk.supportsColor.level !== Level.None\r\n    },\r\n    makfyFilename: makfyFilename,\r\n\r\n    // for ExecContext\r\n    parsedCommands: parsedCommands,\r\n    makfyFileContents: makfyFileContents,\r\n    syncMode: true,\r\n    idStack: [],\r\n    getFileChangesResults: getFileChangesResults\r\n  };\r\n\r\n  try {\r\n    await execRuntime.runCommandAsync(commandName, commandArgs || {}, execContext, false);\r\n\r\n    // on success save new caches in parallel\r\n    const savePromises = [];\r\n    for (const [key, value] of Object.entries(getFileChangesResults)) {\r\n      savePromises.push(saveHashCollectionFileAsync(key, value.newHashCollection));\r\n    }\r\n    await Promise.all(savePromises);\r\n  } catch (err) {\r\n    if (!(err instanceof RunError) && !(err instanceof MakfyError)) {\r\n      // an error most probably thrown by the execution of run\r\n      throw new MakfyError(err.message, undefined);\r\n    } else {\r\n      throw err;\r\n    }\r\n  }\r\n\r\n  const endTime = process.hrtime(startTime);\r\n  console.log(\r\n    \"\\n\" +\r\n      getTimeString(parsedOptions.showTime) +\r\n      chalk.bold.green(`'${commandName}' done in ${prettyHrTime(endTime)}`)\r\n  );\r\n  resetColors();\r\n};\r\n\r\nexport const listCommand = (commands: Commands, commandName: string, listArguments = true) => {\r\n  if (!commandName) {\r\n    throw new MakfyError(\"missing command name\", undefined);\r\n  }\r\n\r\n  const w = new TextWriter();\r\n\r\n  // this also makes sure the command exists\r\n  const parsedCommands = parseCommands(commands, false);\r\n  const parsedCommand = parsedCommands[commandName];\r\n  if (!parsedCommand) {\r\n    throw new MakfyError(`command '${commandName}' not found`, undefined);\r\n  }\r\n\r\n  const currentCommand = commands[commandName];\r\n\r\n  let title = chalk.bgBlue.bold.white(commandName);\r\n\r\n  const aw = new TextWriter();\r\n  if (listArguments) {\r\n    const argDefsList = Object.entries(parsedCommand.argDefinitions);\r\n    // sort alphabetically\r\n    argDefsList.sort((a, b) => {\r\n      return a[0].toLowerCase().localeCompare(b[0].toLowerCase());\r\n    });\r\n\r\n    if (argDefsList.length > 0) {\r\n      const requiredArgs = argDefsList.filter((e) => e[1].required);\r\n      const optionalArgs = argDefsList.filter((e) => !e[1].required);\r\n\r\n      const formatLeftHelp = (argDef: ParsedArgDefinition) => {\r\n        const { required, leftHelp } = argDef;\r\n        const leftBracket = required ? \"\" : \"[\";\r\n        const rightBracket = required ? \"\" : \"]\";\r\n\r\n        return chalk.bold.gray(` ${leftBracket}${leftHelp}${rightBracket}`);\r\n      };\r\n\r\n      // find left help side max length\r\n      const lengths = argDefsList.map((entry) => stripColor(formatLeftHelp(entry[1])).length);\r\n      const maxLeftLength = Math.max(...lengths) + 4;\r\n\r\n      const writeArgHelp = (argDef: [string, ParsedArgDefinition]) => {\r\n        const { rightHelp } = argDef[1];\r\n\r\n        const formattedLeftHelp = formatLeftHelp(argDef[1]);\r\n        let help = formattedLeftHelp;\r\n\r\n        if (rightHelp) {\r\n          for (let i = stripColor(formattedLeftHelp).length; i < maxLeftLength; i++) {\r\n            help += \" \";\r\n          }\r\n          help += rightHelp;\r\n        }\r\n        aw.writeLine(`  ${help}`);\r\n\r\n        title += formattedLeftHelp;\r\n      };\r\n\r\n      if (requiredArgs.length > 0) {\r\n        requiredArgs.forEach((e) => {\r\n          writeArgHelp(e);\r\n        });\r\n      }\r\n\r\n      if (optionalArgs.length > 0) {\r\n        optionalArgs.forEach((e) => {\r\n          writeArgHelp(e);\r\n        });\r\n      }\r\n    }\r\n  }\r\n\r\n  w.writeLine(title);\r\n  if (currentCommand.desc !== undefined) {\r\n    w.writeLine(chalk.bold.gray(` - ${currentCommand.desc}`));\r\n  }\r\n  w.write(aw.output);\r\n  w.writeLine(chalk.reset(\"\"));\r\n\r\n  return w.output;\r\n};\r\n\r\nexport const listAllCommands = (commands: Commands, listArguments = true, listInternal = false) => {\r\n  if (!isObject(commands)) {\r\n    throw new MakfyError(\r\n      errorMessageForObject([\"commands\"], `must be an object (did you export it?)`),\r\n      undefined\r\n    );\r\n  }\r\n\r\n  let output = \"\";\r\n\r\n  for (const commandName of Object.keys(commands)) {\r\n    const currentCommand = commands[commandName];\r\n    if (!currentCommand.internal || listInternal) {\r\n      output += listCommand(commands, commandName, listArguments);\r\n    }\r\n  }\r\n  return output;\r\n};\r\n\r\n// short syntax\r\nexport function run(...inlineCommands: ExecCommand[]): Command<{}> & CommandFromFunction {\r\n  const cmd: Command<{}> = {\r\n    run: async (exec: ExecFunction) => {\r\n      await exec(...inlineCommands);\r\n    }\r\n  };\r\n  return cmd as Command<{}> & CommandFromFunction;\r\n}\r\n"]}
exports.setOptions = setOptions;
function setDependencies(deps) {
config_1.config.dependencies = deps;
}
exports.setDependencies = setDependencies;

@@ -31,2 +31,1 @@ "use strict";

};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbWFuZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvcGFyc2VyL2NvbW1hbmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxvQ0FBdUM7QUFDdkMsb0NBQTZDO0FBRTdDLCtDQUE0RDtBQUM1RCxrREFBNEQ7QUFDNUQsMkNBQXVFO0FBUTFELFFBQUEsWUFBWSxHQUFHLFVBQzFCLE9BQWdDLEVBQ2hDLE9BQWUsRUFDZixjQUF1QjtJQUV2QixJQUFNLEtBQUssR0FBRyxVQUFDLFFBQTRCLEVBQUUsT0FBZTtRQUMxRCxPQUFPLElBQUksbUJBQVUsQ0FDbkIsa0NBQXFCLENBQUMsQ0FBQyxVQUFVLEVBQUUsT0FBTyxFQUFFLFFBQVEsQ0FBQyxFQUFFLE9BQU8sQ0FBQyxFQUMvRCxTQUFTLENBQ1YsQ0FBQztJQUNKLENBQUMsQ0FBQztJQUVGLElBQUksQ0FBQyxjQUFjLEVBQUU7UUFDbkIsSUFBTSxnQkFBZ0IsR0FBRyx5QkFBZ0IsQ0FBQyxPQUFPLEVBQUUsd0JBQWEsQ0FBQyxDQUFDO1FBQ2xFLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLEVBQUU7WUFDM0IsTUFBTSxLQUFLLENBQUMsU0FBUyxFQUFFLGdCQUFnQixDQUFDLFFBQVEsRUFBRSxDQUFDLENBQUM7U0FDckQ7S0FDRjtJQUVPLElBQUEsbUJBQUksQ0FBYTtJQUV6QixRQUFRO0lBQ1IsSUFBTSxPQUFPLEdBQWtCO1FBQzdCLGNBQWMsRUFBRSxFQUFFO0tBQ25CLENBQUM7SUFFRixJQUFJLElBQUksS0FBSyxTQUFTLEVBQUU7UUFDdEIsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxPQUFPLENBQUMsVUFBQyxPQUFPO1lBQ2hDLElBQU0sYUFBYSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztZQUNwQyxPQUFPLENBQUMsY0FBYyxDQUFDLE9BQU8sQ0FBQyxHQUFHLCtCQUFrQixDQUFDLE9BQU8sRUFBRSxPQUFPLEVBQUUsYUFBYSxFQUFFLElBQUksQ0FBQyxDQUFDO1FBQzlGLENBQUMsQ0FBQyxDQUFDO0tBQ0o7SUFFRCxPQUFPLE9BQU8sQ0FBQztBQUNqQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBNYWtmeUVycm9yIH0gZnJvbSBcIi4uL2Vycm9yc1wiO1xyXG5pbXBvcnQgeyB2YWxpZGF0ZUluc3RhbmNlIH0gZnJvbSBcIi4uL3NjaGVtYVwiO1xyXG5pbXBvcnQgeyBBcmdEZWZpbml0aW9ucyB9IGZyb20gXCIuLi9zY2hlbWEvYXJnc1wiO1xyXG5pbXBvcnQgeyBDb21tYW5kLCBjb21tYW5kU2NoZW1hIH0gZnJvbSBcIi4uL3NjaGVtYS9jb21tYW5kc1wiO1xyXG5pbXBvcnQgeyBlcnJvck1lc3NhZ2VGb3JPYmplY3QgfSBmcm9tIFwiLi4vdXRpbHMvZm9ybWF0dGluZ1wiO1xyXG5pbXBvcnQgeyBwYXJzZUFyZ0RlZmluaXRpb24sIFBhcnNlZEFyZ0RlZmluaXRpb24gfSBmcm9tIFwiLi9jb21tYW5kQXJnXCI7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIFBhcnNlZENvbW1hbmQge1xyXG4gIGFyZ0RlZmluaXRpb25zOiB7XHJcbiAgICBbYXJnTmFtZTogc3RyaW5nXTogUGFyc2VkQXJnRGVmaW5pdGlvbjtcclxuICB9O1xyXG59XHJcblxyXG5leHBvcnQgY29uc3QgcGFyc2VDb21tYW5kID0gKFxyXG4gIGNvbW1hbmQ6IENvbW1hbmQ8QXJnRGVmaW5pdGlvbnM+LFxyXG4gIGNtZE5hbWU6IHN0cmluZyxcclxuICBza2lwVmFsaWRhdGlvbjogYm9vbGVhblxyXG4pOiBQYXJzZWRDb21tYW5kID0+IHtcclxuICBjb25zdCBlcnJvciA9IChwcm9wZXJ0eTogc3RyaW5nIHwgdW5kZWZpbmVkLCBtZXNzYWdlOiBzdHJpbmcpOiBNYWtmeUVycm9yID0+IHtcclxuICAgIHJldHVybiBuZXcgTWFrZnlFcnJvcihcclxuICAgICAgZXJyb3JNZXNzYWdlRm9yT2JqZWN0KFtcImNvbW1hbmRzXCIsIGNtZE5hbWUsIHByb3BlcnR5XSwgbWVzc2FnZSksXHJcbiAgICAgIHVuZGVmaW5lZFxyXG4gICAgKTtcclxuICB9O1xyXG5cclxuICBpZiAoIXNraXBWYWxpZGF0aW9uKSB7XHJcbiAgICBjb25zdCB2YWxpZGF0aW9uUmVzdWx0ID0gdmFsaWRhdGVJbnN0YW5jZShjb21tYW5kLCBjb21tYW5kU2NoZW1hKTtcclxuICAgIGlmICghdmFsaWRhdGlvblJlc3VsdC52YWxpZCkge1xyXG4gICAgICB0aHJvdyBlcnJvcih1bmRlZmluZWQsIHZhbGlkYXRpb25SZXN1bHQudG9TdHJpbmcoKSk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBjb25zdCB7IGFyZ3MgfSA9IGNvbW1hbmQ7XHJcblxyXG4gIC8vIHBhcnNlXHJcbiAgY29uc3QgY21kSW5mbzogUGFyc2VkQ29tbWFuZCA9IHtcclxuICAgIGFyZ0RlZmluaXRpb25zOiB7fVxyXG4gIH07XHJcblxyXG4gIGlmIChhcmdzICE9PSB1bmRlZmluZWQpIHtcclxuICAgIE9iamVjdC5rZXlzKGFyZ3MpLmZvckVhY2goKGFyZ05hbWUpID0+IHtcclxuICAgICAgY29uc3QgYXJnRGVmaW5pdGlvbiA9IGFyZ3NbYXJnTmFtZV07XHJcbiAgICAgIGNtZEluZm8uYXJnRGVmaW5pdGlvbnNbYXJnTmFtZV0gPSBwYXJzZUFyZ0RlZmluaXRpb24oY21kTmFtZSwgYXJnTmFtZSwgYXJnRGVmaW5pdGlvbiwgdHJ1ZSk7XHJcbiAgICB9KTtcclxuICB9XHJcblxyXG4gIHJldHVybiBjbWRJbmZvO1xyXG59O1xyXG4iXX0=

@@ -159,2 +159,1 @@ "use strict";

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"commandArg.js","sourceRoot":"","sources":["../../../src/lib/parser/commandArg.ts"],"names":[],"mappings":"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","sourcesContent":["import chalk from \"chalk\";\r\nimport { MakfyError } from \"../errors\";\r\nimport { validateInstance } from \"../schema\";\r\nimport {\r\n  ArgDefinition,\r\n  argSchema,\r\n  EnumArgDefinition,\r\n  FlagArgDefinition,\r\n  StringArgDefinition\r\n} from \"../schema/args\";\r\nimport { argNameToDashedArgName, errorMessageForObject } from \"../utils/formatting\";\r\n\r\nconst enum Type {\r\n  Flag,\r\n  String,\r\n  Enum\r\n}\r\n\r\nconst normalizeType = (type: string) => {\r\n  if (type === \"f\" || type === \"flag\") {\r\n    return Type.Flag;\r\n  }\r\n  if (type === \"s\" || type === \"string\") {\r\n    return Type.String;\r\n  }\r\n  if (type === \"e\" || type === \"enum\") {\r\n    return Type.Enum;\r\n  }\r\n  return undefined;\r\n};\r\n\r\nexport type ParseArgFunction = (value: any) => any;\r\n\r\nexport interface ParsedArgDefinition {\r\n  leftHelp: string;\r\n  rightHelp?: string;\r\n  required: boolean;\r\n  parse: ParseArgFunction;\r\n}\r\n\r\nexport const parseArgDefinition = (\r\n  cmdName: string,\r\n  argName: string,\r\n  argDefinition: ArgDefinition,\r\n  skipValidation: boolean\r\n): ParsedArgDefinition => {\r\n  const error = (property: string | undefined, message: string): MakfyError => {\r\n    return new MakfyError(\r\n      errorMessageForObject([\"commands\", cmdName, \"args\", argName, property], message),\r\n      undefined\r\n    );\r\n  };\r\n\r\n  if (!skipValidation) {\r\n    const validationResult = validateInstance(argDefinition, argSchema);\r\n    if (!validationResult.valid) {\r\n      throw error(undefined, validationResult.toString());\r\n    }\r\n  }\r\n\r\n  const normalizedType = normalizeType(argDefinition.type);\r\n\r\n  const validateError = (err: string): MakfyError => {\r\n    return new MakfyError(`argument '${argName}' - ${err}`, undefined);\r\n  };\r\n\r\n  let parse: ParseArgFunction;\r\n  let required;\r\n  const argRequiredMessage = \"argument is required\";\r\n\r\n  if (normalizedType === Type.Flag) {\r\n    let { byDefault } = argDefinition as FlagArgDefinition;\r\n    byDefault = false;\r\n    required = false;\r\n\r\n    parse = (value: any) => {\r\n      if (value === undefined) {\r\n        value = byDefault;\r\n      }\r\n      if (value === undefined) {\r\n        throw validateError(argRequiredMessage);\r\n      }\r\n      if (typeof value === \"boolean\") {\r\n        return value;\r\n      }\r\n      if (value === \"true\") {\r\n        return true;\r\n      }\r\n      if (value === \"false\") {\r\n        return false;\r\n      }\r\n      throw validateError(`a flag argument cannot have a value`);\r\n    };\r\n  } else if (normalizedType === Type.String) {\r\n    const { byDefault } = argDefinition as StringArgDefinition;\r\n    required = byDefault === undefined;\r\n\r\n    parse = (value: any) => {\r\n      if (value === undefined) {\r\n        value = byDefault;\r\n      }\r\n      if (value === undefined) {\r\n        throw validateError(argRequiredMessage);\r\n      }\r\n      if (typeof value === \"number\") {\r\n        value = String(value);\r\n      }\r\n      if (typeof value !== \"string\") {\r\n        throw validateError(\"argument must be a string\");\r\n      }\r\n      return value;\r\n    };\r\n  } else if (normalizedType === Type.Enum) {\r\n    const { byDefault, values } = argDefinition as EnumArgDefinition;\r\n    required = byDefault === undefined;\r\n\r\n    parse = (value: any) => {\r\n      if (value === undefined) {\r\n        value = byDefault;\r\n      }\r\n      if (value === undefined) {\r\n        throw validateError(argRequiredMessage);\r\n      }\r\n      if (typeof value === \"number\") {\r\n        value = String(value);\r\n      }\r\n      if (typeof value !== \"string\" || !values.includes(value)) {\r\n        throw validateError(`argument must be one of: ${values.join(\", \")}`);\r\n      }\r\n      return value;\r\n    };\r\n  } else {\r\n    throw new Error(\"internal error - validation failed?\");\r\n  }\r\n\r\n  return {\r\n    ...getHelpForArg(argName, argDefinition),\r\n    required,\r\n    parse\r\n  };\r\n};\r\n\r\nconst getHelpForArg = (argName: string, argDefinition: ArgDefinition) => {\r\n  const { byDefault, desc } = argDefinition;\r\n  const normalizedType = normalizeType(argDefinition.type);\r\n\r\n  const getLeftHelp = (equals: string | undefined, required: boolean) => {\r\n    let str = argNameToDashedArgName(argName);\r\n    if (required) {\r\n      str = chalk.bold.red(str);\r\n    } else {\r\n      str = chalk.bold.magenta(str);\r\n    }\r\n\r\n    if (equals) {\r\n      str += chalk.bold.gray(`=${equals}`);\r\n    }\r\n\r\n    return str;\r\n  };\r\n\r\n  const getRightHelp = (equals: string | undefined, defaultValue: any) => {\r\n    let str = \"\";\r\n    if (desc) {\r\n      str = chalk.bold.gray(desc);\r\n    }\r\n    if (defaultValue) {\r\n      str += chalk.bold.gray(\" (default: \" + defaultValue + \")\");\r\n    }\r\n\r\n    return str.length > 0 ? str : undefined;\r\n  };\r\n\r\n  const getHelp = (equals: string | undefined, defaultValue: any) => {\r\n    return {\r\n      leftHelp: getLeftHelp(equals, defaultValue === undefined),\r\n      rightHelp: getRightHelp(equals, defaultValue)\r\n    };\r\n  };\r\n\r\n  switch (normalizedType) {\r\n    case Type.Flag:\r\n      return getHelp(undefined, \"false\");\r\n    case Type.String:\r\n      return getHelp(\"string\", byDefault);\r\n    case Type.Enum:\r\n      const { values } = argDefinition as EnumArgDefinition;\r\n      return getHelp(values.join(\"|\"), byDefault);\r\n    default:\r\n      throw new Error(`internal error - unknown type: ${normalizedType}`);\r\n  }\r\n};\r\n"]}

@@ -27,3 +27,3 @@ "use strict";

parseInfo[cmdName] = command_1.parseCommand(command, cmdName, true);
if (!command.internal) {
if (!commands_1.isInternalCommand(cmdName)) {
publicCommands++;

@@ -37,2 +37,1 @@ }

};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbWFuZHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL3BhcnNlci9jb21tYW5kcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLG9DQUF1QztBQUN2QyxvQ0FBNkM7QUFDN0MsK0NBQThEO0FBQzlELGtEQUE0RDtBQUM1RCxzREFBaUQ7QUFDakQscUNBQXdEO0FBTTNDLFFBQUEsYUFBYSxHQUFHLFVBQUMsUUFBa0IsRUFBRSxjQUF1QjtJQUN2RSxJQUFNLEtBQUssR0FBRyxVQUFDLFFBQTRCLEVBQUUsT0FBZTtRQUMxRCxPQUFPLElBQUksbUJBQVUsQ0FBQyxrQ0FBcUIsQ0FBQyxDQUFDLFVBQVUsRUFBRSxRQUFRLENBQUMsRUFBRSxPQUFPLENBQUMsRUFBRSxTQUFTLENBQUMsQ0FBQztJQUMzRixDQUFDLENBQUM7SUFFRixJQUFJLENBQUMsdUJBQVEsQ0FBQyxRQUFRLENBQUMsRUFBRTtRQUN2QixNQUFNLEtBQUssQ0FBQyxTQUFTLEVBQUUsd0NBQXdDLENBQUMsQ0FBQztLQUNsRTtJQUVELElBQUksQ0FBQyxjQUFjLEVBQUU7UUFDbkIsSUFBTSxnQkFBZ0IsR0FBRyx5QkFBZ0IsQ0FBQyxRQUFRLEVBQUUseUJBQWMsQ0FBQyxDQUFDO1FBQ3BFLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLEVBQUU7WUFDM0IsTUFBTSxLQUFLLENBQUMsU0FBUyxFQUFFLGdCQUFnQixDQUFDLFFBQVEsRUFBRSxDQUFDLENBQUM7U0FDckQ7S0FDRjtJQUVELElBQUksY0FBYyxHQUFHLENBQUMsQ0FBQztJQUV2QixJQUFNLFNBQVMsR0FBbUIsRUFBRSxDQUFDO0lBRXJDLE1BQU0sQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsT0FBTyxDQUFDLFVBQUMsT0FBTztRQUNwQyxJQUFNLE9BQU8sR0FBRyxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUM7UUFFbEMsU0FBUyxDQUFDLE9BQU8sQ0FBQyxHQUFHLHNCQUFZLENBQUMsT0FBTyxFQUFFLE9BQU8sRUFBRSxJQUFJLENBQUMsQ0FBQztRQUUxRCxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsRUFBRTtZQUNyQixjQUFjLEVBQUUsQ0FBQztTQUNsQjtJQUNILENBQUMsQ0FBQyxDQUFDO0lBRUgsSUFBSSxjQUFjLElBQUksQ0FBQyxFQUFFO1FBQ3ZCLE1BQU0sS0FBSyxDQUFDLFNBQVMsRUFBRSw2REFBNkQsQ0FBQyxDQUFDO0tBQ3ZGO0lBRUQsT0FBTyxTQUFTLENBQUM7QUFDbkIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWFrZnlFcnJvciB9IGZyb20gXCIuLi9lcnJvcnNcIjtcclxuaW1wb3J0IHsgdmFsaWRhdGVJbnN0YW5jZSB9IGZyb20gXCIuLi9zY2hlbWFcIjtcclxuaW1wb3J0IHsgQ29tbWFuZHMsIGNvbW1hbmRzU2NoZW1hIH0gZnJvbSBcIi4uL3NjaGVtYS9jb21tYW5kc1wiO1xyXG5pbXBvcnQgeyBlcnJvck1lc3NhZ2VGb3JPYmplY3QgfSBmcm9tIFwiLi4vdXRpbHMvZm9ybWF0dGluZ1wiO1xyXG5pbXBvcnQgeyBpc09iamVjdCB9IGZyb20gXCIuLi91dGlscy90eXBlQ2hlY2tpbmdcIjtcclxuaW1wb3J0IHsgcGFyc2VDb21tYW5kLCBQYXJzZWRDb21tYW5kIH0gZnJvbSBcIi4vY29tbWFuZFwiO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBQYXJzZWRDb21tYW5kcyB7XHJcbiAgW2NtZE5hbWU6IHN0cmluZ106IFBhcnNlZENvbW1hbmQ7XHJcbn1cclxuXHJcbmV4cG9ydCBjb25zdCBwYXJzZUNvbW1hbmRzID0gKGNvbW1hbmRzOiBDb21tYW5kcywgc2tpcFZhbGlkYXRpb246IGJvb2xlYW4pOiBQYXJzZWRDb21tYW5kcyA9PiB7XHJcbiAgY29uc3QgZXJyb3IgPSAocHJvcGVydHk6IHN0cmluZyB8IHVuZGVmaW5lZCwgbWVzc2FnZTogc3RyaW5nKTogTWFrZnlFcnJvciA9PiB7XHJcbiAgICByZXR1cm4gbmV3IE1ha2Z5RXJyb3IoZXJyb3JNZXNzYWdlRm9yT2JqZWN0KFtcImNvbW1hbmRzXCIsIHByb3BlcnR5XSwgbWVzc2FnZSksIHVuZGVmaW5lZCk7XHJcbiAgfTtcclxuXHJcbiAgaWYgKCFpc09iamVjdChjb21tYW5kcykpIHtcclxuICAgIHRocm93IGVycm9yKHVuZGVmaW5lZCwgYG11c3QgYmUgYW4gb2JqZWN0IChkaWQgeW91IGV4cG9ydCBpdD8pYCk7XHJcbiAgfVxyXG5cclxuICBpZiAoIXNraXBWYWxpZGF0aW9uKSB7XHJcbiAgICBjb25zdCB2YWxpZGF0aW9uUmVzdWx0ID0gdmFsaWRhdGVJbnN0YW5jZShjb21tYW5kcywgY29tbWFuZHNTY2hlbWEpO1xyXG4gICAgaWYgKCF2YWxpZGF0aW9uUmVzdWx0LnZhbGlkKSB7XHJcbiAgICAgIHRocm93IGVycm9yKHVuZGVmaW5lZCwgdmFsaWRhdGlvblJlc3VsdC50b1N0cmluZygpKTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIGxldCBwdWJsaWNDb21tYW5kcyA9IDA7XHJcblxyXG4gIGNvbnN0IHBhcnNlSW5mbzogUGFyc2VkQ29tbWFuZHMgPSB7fTtcclxuXHJcbiAgT2JqZWN0LmtleXMoY29tbWFuZHMpLmZvckVhY2goKGNtZE5hbWUpID0+IHtcclxuICAgIGNvbnN0IGNvbW1hbmQgPSBjb21tYW5kc1tjbWROYW1lXTtcclxuXHJcbiAgICBwYXJzZUluZm9bY21kTmFtZV0gPSBwYXJzZUNvbW1hbmQoY29tbWFuZCwgY21kTmFtZSwgdHJ1ZSk7XHJcblxyXG4gICAgaWYgKCFjb21tYW5kLmludGVybmFsKSB7XHJcbiAgICAgIHB1YmxpY0NvbW1hbmRzKys7XHJcbiAgICB9XHJcbiAgfSk7XHJcblxyXG4gIGlmIChwdWJsaWNDb21tYW5kcyA8PSAwKSB7XHJcbiAgICB0aHJvdyBlcnJvcih1bmRlZmluZWQsIGBtdXN0IGhhdmUgYXQgbGVhc3Qgb25lIGNvbW1hbmQgKG5vdCBjb3VudGluZyBpbnRlcm5hbCBvbmVzKWApO1xyXG4gIH1cclxuXHJcbiAgcmV0dXJuIHBhcnNlSW5mbztcclxufTtcclxuIl19

@@ -32,2 +32,1 @@ "use strict";

};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3B0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvcGFyc2VyL29wdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7OztBQUFBLG9DQUF1QztBQUN2QyxvQ0FBNkM7QUFDN0MsNkNBQStFO0FBQy9FLGtEQUE0RDtBQUU1RCxJQUFNLGNBQWMsR0FBZ0I7SUFDbEMsT0FBTyxFQUFFLEtBQUs7SUFDZCxRQUFRLEVBQUUsS0FBSztDQUNoQixDQUFDO0FBRVcsUUFBQSxZQUFZLEdBQUcsVUFDMUIsT0FBbUMsRUFDbkMsY0FBdUI7SUFFdkIsSUFBTSxXQUFXLGdCQUFRLGNBQWMsRUFBSyxPQUFPLENBQUUsQ0FBQztJQUV0RCxJQUFJLENBQUMsY0FBYyxFQUFFO1FBQ25CLElBQU0sZ0JBQWdCLEdBQUcseUJBQWdCLENBQUMsV0FBVyxFQUFFLHVCQUFhLENBQUMsQ0FBQztRQUN0RSxJQUFJLENBQUMsZ0JBQWdCLENBQUMsS0FBSyxFQUFFO1lBQzNCLE1BQU0sSUFBSSxtQkFBVSxDQUNsQixrQ0FBcUIsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxFQUFFLGdCQUFnQixDQUFDLFFBQVEsRUFBRSxDQUFDLEVBQy9ELFNBQVMsQ0FDVixDQUFDO1NBQ0g7S0FDRjtJQUVELE9BQU8sV0FBVyxDQUFDO0FBQ3JCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1ha2Z5RXJyb3IgfSBmcm9tIFwiLi4vZXJyb3JzXCI7XHJcbmltcG9ydCB7IHZhbGlkYXRlSW5zdGFuY2UgfSBmcm9tIFwiLi4vc2NoZW1hXCI7XHJcbmltcG9ydCB7IEZ1bGxPcHRpb25zLCBvcHRpb25zU2NoZW1hLCBQYXJ0aWFsT3B0aW9ucyB9IGZyb20gXCIuLi9zY2hlbWEvb3B0aW9uc1wiO1xyXG5pbXBvcnQgeyBlcnJvck1lc3NhZ2VGb3JPYmplY3QgfSBmcm9tIFwiLi4vdXRpbHMvZm9ybWF0dGluZ1wiO1xyXG5cclxuY29uc3QgZGVmYXVsdE9wdGlvbnM6IEZ1bGxPcHRpb25zID0ge1xyXG4gIHByb2ZpbGU6IGZhbHNlLFxyXG4gIHNob3dUaW1lOiBmYWxzZVxyXG59O1xyXG5cclxuZXhwb3J0IGNvbnN0IHBhcnNlT3B0aW9ucyA9IChcclxuICBvcHRpb25zOiBQYXJ0aWFsT3B0aW9ucyB8IHVuZGVmaW5lZCxcclxuICBza2lwVmFsaWRhdGlvbjogYm9vbGVhblxyXG4pOiBGdWxsT3B0aW9ucyA9PiB7XHJcbiAgY29uc3QgZnVsbE9wdGlvbnMgPSB7IC4uLmRlZmF1bHRPcHRpb25zLCAuLi5vcHRpb25zIH07XHJcblxyXG4gIGlmICghc2tpcFZhbGlkYXRpb24pIHtcclxuICAgIGNvbnN0IHZhbGlkYXRpb25SZXN1bHQgPSB2YWxpZGF0ZUluc3RhbmNlKGZ1bGxPcHRpb25zLCBvcHRpb25zU2NoZW1hKTtcclxuICAgIGlmICghdmFsaWRhdGlvblJlc3VsdC52YWxpZCkge1xyXG4gICAgICB0aHJvdyBuZXcgTWFrZnlFcnJvcihcclxuICAgICAgICBlcnJvck1lc3NhZ2VGb3JPYmplY3QoW1wib3B0aW9uc1wiXSwgdmFsaWRhdGlvblJlc3VsdC50b1N0cmluZygpKSxcclxuICAgICAgICB1bmRlZmluZWRcclxuICAgICAgKTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIHJldHVybiBmdWxsT3B0aW9ucztcclxufTtcclxuIl19

@@ -101,2 +101,1 @@ "use strict";

};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJncy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvc2NoZW1hL2FyZ3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLGtEQUFrRDs7O0FBR2xELHVCQUFpRDtBQUVwQyxRQUFBLGdCQUFnQixHQUFHO0lBQzlCLEdBQUc7SUFDSCxNQUFNO0lBQ04sR0FBRztJQUNILE1BQU07SUFDTixHQUFHO0lBQ0gsTUFBTTtJQUNOLEdBQUc7SUFDSCxTQUFTO0lBQ1QsT0FBTztJQUNQLFNBQVM7SUFDVCxVQUFVO0lBQ1YsU0FBUztJQUNULFVBQVU7SUFDVixXQUFXO0NBQ1osQ0FBQztBQVNXLFFBQUEsYUFBYSxHQUFXO0lBQ25DLEVBQUUsRUFBRSxVQUFVO0lBQ2QsSUFBSSxFQUFFLFFBQVE7SUFDZCxRQUFRLEVBQUUsQ0FBQyxNQUFNLENBQUM7SUFDbEIsVUFBVSxFQUFFO1FBQ1YsSUFBSSxFQUFFO1lBQ0osSUFBSSxFQUFFLFFBQVE7WUFDZCxJQUFJLEVBQUUsQ0FBQyxHQUFHLEVBQUUsTUFBTSxDQUFDLENBQUMsZ0RBQWdEO1NBQ3JFO1FBQ0QsU0FBUyxFQUFFO1lBQ1QsSUFBSSxFQUFFLFNBQVM7WUFDZixJQUFJLEVBQUUsQ0FBQyxLQUFLLENBQUMsQ0FBQyxnREFBZ0Q7U0FDL0Q7UUFDRCxJQUFJLEVBQUU7WUFDSixJQUFJLEVBQUUsUUFBUTtTQUNmO0tBQ0Y7SUFDRCxvQkFBb0IsRUFBRSxLQUFLO0NBQzVCLENBQUM7QUFTVyxRQUFBLGVBQWUsR0FBVztJQUNyQyxFQUFFLEVBQUUsWUFBWTtJQUNoQixJQUFJLEVBQUUsUUFBUTtJQUNkLFFBQVEsRUFBRSxDQUFDLE1BQU0sQ0FBQztJQUNsQixVQUFVLEVBQUU7UUFDVixJQUFJLEVBQUU7WUFDSixJQUFJLEVBQUUsUUFBUTtZQUNkLElBQUksRUFBRSxDQUFDLEdBQUcsRUFBRSxRQUFRLENBQUMsQ0FBQyxnREFBZ0Q7U0FDdkU7UUFDRCxTQUFTLEVBQUU7WUFDVCxJQUFJLEVBQUUsUUFBUTtTQUNmO1FBQ0QsSUFBSSxFQUFFO1lBQ0osSUFBSSxFQUFFLFFBQVE7U0FDZjtLQUNGO0lBQ0Qsb0JBQW9CLEVBQUUsS0FBSztDQUM1QixDQUFDO0FBV1csUUFBQSxhQUFhLEdBQVc7SUFDbkMsRUFBRSxFQUFFLFVBQVU7SUFDZCxJQUFJLEVBQUUsUUFBUTtJQUNkLFFBQVEsRUFBRSxDQUFDLE1BQU0sRUFBRSxRQUFRLENBQUM7SUFDNUIsVUFBVSxFQUFFO1FBQ1YsSUFBSSxFQUFFO1lBQ0osSUFBSSxFQUFFLFFBQVE7WUFDZCxJQUFJLEVBQUUsQ0FBQyxHQUFHLEVBQUUsTUFBTSxDQUFDLENBQUMsZ0RBQWdEO1NBQ3JFO1FBQ0QsTUFBTSxFQUFFO1lBQ04sSUFBSSxFQUFFLE9BQU87WUFDYixRQUFRLEVBQUUsQ0FBQztZQUNYLFdBQVcsRUFBRSxJQUFJO1lBQ2pCLEtBQUssRUFBRTtnQkFDTCxJQUFJLEVBQUUsUUFBUTtnQkFDZCxPQUFPLEVBQUUsOEJBQTJCO2FBQ3JDO1NBQ0Y7UUFDRCxTQUFTLEVBQUU7WUFDVCxJQUFJLEVBQUUsUUFBUTtZQUNkLE9BQU8sRUFBRSw4QkFBMkI7WUFDcEMsYUFBYSxFQUFFLElBQUk7U0FDVjtRQUNYLElBQUksRUFBRTtZQUNKLElBQUksRUFBRSxRQUFRO1NBQ2Y7S0FDRjtJQUNELG9CQUFvQixFQUFFLEtBQUs7Q0FDNUIsQ0FBQztBQVVXLFFBQUEsU0FBUyxHQUFXO0lBQy9CLEVBQUUsRUFBRSxNQUFNO0lBQ1YsS0FBSyxFQUFFLENBQUMscUJBQWEsRUFBRSx1QkFBZSxFQUFFLHFCQUFhLENBQUM7Q0FDdkQsQ0FBQztBQUVXLFFBQUEsVUFBVSxHQUFXO0lBQ2hDLEVBQUUsRUFBRSxPQUFPO0lBQ1gsSUFBSSxFQUFFLFFBQVE7SUFDZCxpQkFBaUI7UUFDZixHQUFDLDhCQUEyQixJQUFHLGlCQUFTO1dBQ3pDO0lBQ0Qsb0JBQW9CLEVBQUUsS0FBSztJQUMzQixzQkFBc0IsRUFBRSx3QkFBZ0I7Q0FDL0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8vIHRzbGludDpkaXNhYmxlOm5vLW9iamVjdC1saXRlcmFsLXR5cGUtYXNzZXJ0aW9uXHJcblxyXG5pbXBvcnQgeyBTY2hlbWEgfSBmcm9tIFwianNvbnNjaGVtYVwiO1xyXG5pbXBvcnQgeyBhbHBoYW51bWVyaWNFeHRlbmRlZFBhdHRlcm4gfSBmcm9tIFwiLi9cIjtcclxuXHJcbmV4cG9ydCBjb25zdCByZXNlcnZlZEFyZ05hbWVzID0gW1xyXG4gIFwiZlwiLFxyXG4gIFwiZmlsZVwiLFxyXG4gIFwibFwiLFxyXG4gIFwibGlzdFwiLFxyXG4gIFwiaFwiLFxyXG4gIFwiaGVscFwiLFxyXG4gIFwidlwiLFxyXG4gIFwidmVyc2lvblwiLFxyXG4gIFwiY29sb3JcIixcclxuICBcIm5vQ29sb3JcIixcclxuICBcIm5vLWNvbG9yXCIsXHJcbiAgXCJwcm9maWxlXCIsXHJcbiAgXCJzaG93VGltZVwiLFxyXG4gIFwic2hvdy10aW1lXCJcclxuXTtcclxuXHJcbi8vIGFuIG9wdGlvbmFsIGZsYWcsIGZhbHNlIGJ5IGRlZmF1bHRcclxuZXhwb3J0IGludGVyZmFjZSBGbGFnQXJnRGVmaW5pdGlvbiB7XHJcbiAgdHlwZTogXCJmbGFnXCIgfCBcImZcIjtcclxuICBieURlZmF1bHQ/OiBmYWxzZTtcclxuICBkZXNjPzogc3RyaW5nO1xyXG59XHJcblxyXG5leHBvcnQgY29uc3QgZmxhZ0FyZ1NjaGVtYTogU2NoZW1hID0ge1xyXG4gIGlkOiBcIi9mbGFnQXJnXCIsXHJcbiAgdHlwZTogXCJvYmplY3RcIixcclxuICByZXF1aXJlZDogW1widHlwZVwiXSxcclxuICBwcm9wZXJ0aWVzOiB7XHJcbiAgICB0eXBlOiB7XHJcbiAgICAgIHR5cGU6IFwic3RyaW5nXCIsXHJcbiAgICAgIGVudW06IFtcImZcIiwgXCJmbGFnXCJdIC8vIHRzbGludDpkaXNhYmxlLWxpbmU6b2JqZWN0LWxpdGVyYWwta2V5LXF1b3Rlc1xyXG4gICAgfSxcclxuICAgIGJ5RGVmYXVsdDoge1xyXG4gICAgICB0eXBlOiBcImJvb2xlYW5cIixcclxuICAgICAgZW51bTogW2ZhbHNlXSAvLyB0c2xpbnQ6ZGlzYWJsZS1saW5lOm9iamVjdC1saXRlcmFsLWtleS1xdW90ZXNcclxuICAgIH0sXHJcbiAgICBkZXNjOiB7XHJcbiAgICAgIHR5cGU6IFwic3RyaW5nXCJcclxuICAgIH1cclxuICB9LFxyXG4gIGFkZGl0aW9uYWxQcm9wZXJ0aWVzOiBmYWxzZVxyXG59O1xyXG5cclxuLy8gYW55IHN0cmluZywgcmVxdWlyZWQgaWYgbm8gZGVmYXVsdCB2YWx1ZSBpcyBnaXZlblxyXG5leHBvcnQgaW50ZXJmYWNlIFN0cmluZ0FyZ0RlZmluaXRpb24ge1xyXG4gIHR5cGU6IFwic3RyaW5nXCIgfCBcInNcIjtcclxuICBieURlZmF1bHQ/OiBzdHJpbmc7XHJcbiAgZGVzYz86IHN0cmluZztcclxufVxyXG5cclxuZXhwb3J0IGNvbnN0IHN0cmluZ0FyZ1NjaGVtYTogU2NoZW1hID0ge1xyXG4gIGlkOiBcIi9zdHJpbmdBcmdcIixcclxuICB0eXBlOiBcIm9iamVjdFwiLFxyXG4gIHJlcXVpcmVkOiBbXCJ0eXBlXCJdLFxyXG4gIHByb3BlcnRpZXM6IHtcclxuICAgIHR5cGU6IHtcclxuICAgICAgdHlwZTogXCJzdHJpbmdcIixcclxuICAgICAgZW51bTogW1wic1wiLCBcInN0cmluZ1wiXSAvLyB0c2xpbnQ6ZGlzYWJsZS1saW5lOm9iamVjdC1saXRlcmFsLWtleS1xdW90ZXNcclxuICAgIH0sXHJcbiAgICBieURlZmF1bHQ6IHtcclxuICAgICAgdHlwZTogXCJzdHJpbmdcIlxyXG4gICAgfSxcclxuICAgIGRlc2M6IHtcclxuICAgICAgdHlwZTogXCJzdHJpbmdcIlxyXG4gICAgfVxyXG4gIH0sXHJcbiAgYWRkaXRpb25hbFByb3BlcnRpZXM6IGZhbHNlXHJcbn07XHJcblxyXG4vLyBhbiBlbnVtLCByZXF1aXJlZCBpZiBub3QgZGVmYXVsdCB2YWx1ZSBpcyBnaXZlblxyXG4vLyB0aGUgZGVmYXVsdCB2YWx1ZSBtdXN0IGJlIGluc2lkZSB0aGUgZW51bSBnaXZlbiBpbiB2YWx1ZXM7IHZhbHVlcyBtdXN0IGNvbnRhaW4gYXQgbGVhc3Qgb25lIGVsZW1lbnRcclxuZXhwb3J0IGludGVyZmFjZSBFbnVtQXJnRGVmaW5pdGlvbiB7XHJcbiAgdHlwZTogXCJlbnVtXCIgfCBcImVcIjtcclxuICB2YWx1ZXM6IHN0cmluZ1tdO1xyXG4gIGJ5RGVmYXVsdD86IHN0cmluZztcclxuICBkZXNjPzogc3RyaW5nO1xyXG59XHJcblxyXG5leHBvcnQgY29uc3QgZW51bUFyZ1NjaGVtYTogU2NoZW1hID0ge1xyXG4gIGlkOiBcIi9lbnVtQXJnXCIsXHJcbiAgdHlwZTogXCJvYmplY3RcIixcclxuICByZXF1aXJlZDogW1widHlwZVwiLCBcInZhbHVlc1wiXSxcclxuICBwcm9wZXJ0aWVzOiB7XHJcbiAgICB0eXBlOiB7XHJcbiAgICAgIHR5cGU6IFwic3RyaW5nXCIsXHJcbiAgICAgIGVudW06IFtcImVcIiwgXCJlbnVtXCJdIC8vIHRzbGludDpkaXNhYmxlLWxpbmU6b2JqZWN0LWxpdGVyYWwta2V5LXF1b3Rlc1xyXG4gICAgfSxcclxuICAgIHZhbHVlczoge1xyXG4gICAgICB0eXBlOiBcImFycmF5XCIsXHJcbiAgICAgIG1pbkl0ZW1zOiAxLFxyXG4gICAgICB1bmlxdWVJdGVtczogdHJ1ZSxcclxuICAgICAgaXRlbXM6IHtcclxuICAgICAgICB0eXBlOiBcInN0cmluZ1wiLFxyXG4gICAgICAgIHBhdHRlcm46IGFscGhhbnVtZXJpY0V4dGVuZGVkUGF0dGVyblxyXG4gICAgICB9XHJcbiAgICB9LFxyXG4gICAgYnlEZWZhdWx0OiB7XHJcbiAgICAgIHR5cGU6IFwic3RyaW5nXCIsXHJcbiAgICAgIHBhdHRlcm46IGFscGhhbnVtZXJpY0V4dGVuZGVkUGF0dGVybixcclxuICAgICAgbWF0Y2hlc1ZhbHVlczogdHJ1ZVxyXG4gICAgfSBhcyBTY2hlbWEsXHJcbiAgICBkZXNjOiB7XHJcbiAgICAgIHR5cGU6IFwic3RyaW5nXCJcclxuICAgIH1cclxuICB9LFxyXG4gIGFkZGl0aW9uYWxQcm9wZXJ0aWVzOiBmYWxzZVxyXG59O1xyXG5cclxuZXhwb3J0IHR5cGUgQXJnRGVmaW5pdGlvbiA9IEZsYWdBcmdEZWZpbml0aW9uIHwgU3RyaW5nQXJnRGVmaW5pdGlvbiB8IEVudW1BcmdEZWZpbml0aW9uO1xyXG5cclxuZXhwb3J0IHR5cGUgQXJnSW5zdGFuY2U8VCBleHRlbmRzIEFyZ0RlZmluaXRpb24+ID0gVCBleHRlbmRzIEZsYWdBcmdEZWZpbml0aW9uXHJcbiAgPyBib29sZWFuXHJcbiAgOiBUIGV4dGVuZHMgU3RyaW5nQXJnRGVmaW5pdGlvblxyXG4gICAgPyBzdHJpbmdcclxuICAgIDogVCBleHRlbmRzIEVudW1BcmdEZWZpbml0aW9uID8gc3RyaW5nIDogc3RyaW5nIHwgYm9vbGVhbjtcclxuXHJcbmV4cG9ydCBjb25zdCBhcmdTY2hlbWE6IFNjaGVtYSA9IHtcclxuICBpZDogXCIvYXJnXCIsXHJcbiAgb25lT2Y6IFtmbGFnQXJnU2NoZW1hLCBzdHJpbmdBcmdTY2hlbWEsIGVudW1BcmdTY2hlbWFdXHJcbn07XHJcblxyXG5leHBvcnQgY29uc3QgYXJnc1NjaGVtYTogU2NoZW1hID0ge1xyXG4gIGlkOiBcIi9hcmdzXCIsXHJcbiAgdHlwZTogXCJvYmplY3RcIixcclxuICBwYXR0ZXJuUHJvcGVydGllczoge1xyXG4gICAgW2FscGhhbnVtZXJpY0V4dGVuZGVkUGF0dGVybl06IGFyZ1NjaGVtYVxyXG4gIH0sXHJcbiAgYWRkaXRpb25hbFByb3BlcnRpZXM6IGZhbHNlLFxyXG4gIGZvcmJpZGRlblByb3BlcnR5TmFtZXM6IHJlc2VydmVkQXJnTmFtZXNcclxufSBhcyBTY2hlbWE7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEFyZ0RlZmluaXRpb25zIHtcclxuICBbYXJnTmFtZTogc3RyaW5nXTogQXJnRGVmaW5pdGlvbjtcclxufVxyXG5cclxuZXhwb3J0IHR5cGUgQXJnc0luc3RhbmNlPFRBcmdEZWZzIGV4dGVuZHMgQXJnRGVmaW5pdGlvbnM+ID0ge1xyXG4gIFtrIGluIGtleW9mIFRBcmdEZWZzXTogQXJnSW5zdGFuY2U8VEFyZ0RlZnNba10+XHJcbn07XHJcbiJdfQ==
import { Schema } from "jsonschema";
import { ArgDefinitions, ArgsInstance } from "./args";
import { ExecFunction, ExecUtils } from "./runtime";
import { ExecCommand, ExecFunction } from "./runtime";
export declare type CommandRunFn<TArgDefs extends ArgDefinitions> = (exec: ExecFunction, args: ArgsInstance<TArgDefs>) => Promise<void>;
export interface Command<TArgDefs extends ArgDefinitions> {
desc?: string;
args?: TArgDefs;
internal?: boolean;
run(exec: ExecFunction, args: ArgsInstance<TArgDefs>, utils: ExecUtils): void;
run: CommandRunFn<TArgDefs>;
}
export interface CommandFromFunction {
readonly $fromCommandFunction: undefined;
}
export declare const commandSchema: Schema;
export interface Commands {
[commandName: string]: Command<ArgDefinitions> & CommandFromFunction;
[commandName: string]: Command<ArgDefinitions>;
}
export declare const commandsSchema: Schema;
export declare function command<TArgDefs extends ArgDefinitions = {}>(cmd: Command<TArgDefs>): Command<TArgDefs> & CommandFromFunction;
export declare function isInternalCommand(commandName: string): boolean;
export declare class CommandBuilder<TArgDefs extends ArgDefinitions> {
private readonly name;
private _command;
constructor(name: string);
desc(desc: string): this;
args<TNewArgDefs extends ArgDefinitions>(argDefs: TNewArgDefs): CommandBuilder<TNewArgDefs>;
argsDesc(argDescs: {
[k in keyof TArgDefs]?: string;
}): this;
run(runFn: CommandRunFn<TArgDefs>): void;
run(...inlineCommands: ExecCommand[]): void;
}
export declare function cmd(name: string): CommandBuilder<{}>;
"use strict";
// tslint:disable:no-object-literal-type-assertion
var __assign = (this && this.__assign) || function () {
__assign = Object.assign || function(t) {
for (var s, i = 1, n = arguments.length; i < n; i++) {
s = arguments[i];
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
t[p] = s[p];
}
return t;
};
return __assign.apply(this, arguments);
};
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
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) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
var __generator = (this && this.__generator) || function (thisArg, body) {
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
function verb(n) { return function (v) { return step([n, v]); }; }
function step(op) {
if (f) throw new TypeError("Generator is already executing.");
while (_) try {
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
if (y = 0, t) op = [op[0] & 2, t.value];
switch (op[0]) {
case 0: case 1: t = op; break;
case 4: _.label++; return { value: op[1], done: false };
case 5: _.label++; y = op[1]; op = [0]; continue;
case 7: op = _.ops.pop(); _.trys.pop(); continue;
default:
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
if (t[2]) _.ops.pop();
_.trys.pop(); continue;
}
op = body.call(thisArg, _);
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
}
};
var __read = (this && this.__read) || function (o, n) {
var m = typeof Symbol === "function" && o[Symbol.iterator];
if (!m) return o;
var i = m.call(o), r, ar = [], e;
try {
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
}
catch (error) { e = { error: error }; }
finally {
try {
if (r && !r.done && (m = i["return"])) m.call(i);
}
finally { if (e) throw e.error; }
}
return ar;
};
var __spread = (this && this.__spread) || function () {
for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));
return ar;
};
Object.defineProperty(exports, "__esModule", { value: true });
var _a;
var config_1 = require("../config");
var _1 = require("./");

@@ -18,5 +85,2 @@ var args_1 = require("./args");

isFunction: true
},
internal: {
type: "boolean"
}

@@ -34,6 +98,60 @@ },

};
function command(cmd) {
return cmd;
function isInternalCommand(commandName) {
return commandName.startsWith("_");
}
exports.command = command;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbWFuZHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL3NjaGVtYS9jb21tYW5kcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsa0RBQWtEOzs7QUFHbEQsdUJBQWlEO0FBQ2pELCtCQUFrRTtBQWVyRCxRQUFBLGFBQWEsR0FBVztJQUNuQyxFQUFFLEVBQUUsVUFBVTtJQUNkLElBQUksRUFBRSxRQUFRO0lBQ2QsUUFBUSxFQUFFLENBQUMsS0FBSyxDQUFDO0lBQ2pCLFVBQVUsRUFBRTtRQUNWLElBQUksRUFBRTtZQUNKLElBQUksRUFBRSxRQUFRO1NBQ2Y7UUFDRCxJQUFJLEVBQUUsaUJBQVU7UUFDaEIsR0FBRyxFQUFFO1lBQ0gsVUFBVSxFQUFFLElBQUk7U0FDUDtRQUNYLFFBQVEsRUFBRTtZQUNSLElBQUksRUFBRSxTQUFTO1NBQ2hCO0tBQ0Y7SUFDRCxvQkFBb0IsRUFBRSxLQUFLO0NBQzVCLENBQUM7QUFNVyxRQUFBLGNBQWMsR0FBVztJQUNwQyxFQUFFLEVBQUUsV0FBVztJQUNmLElBQUksRUFBRSxRQUFRO0lBQ2QsaUJBQWlCO1FBQ2YsR0FBQyw4QkFBMkIsSUFBRyxxQkFBYTtXQUM3QztJQUNELG9CQUFvQixFQUFFLEtBQUs7Q0FDNUIsQ0FBQztBQUVGLFNBQWdCLE9BQU8sQ0FDckIsR0FBc0I7SUFFdEIsT0FBTyxHQUE4QyxDQUFDO0FBQ3hELENBQUM7QUFKRCwwQkFJQyIsInNvdXJjZXNDb250ZW50IjpbIi8vIHRzbGludDpkaXNhYmxlOm5vLW9iamVjdC1saXRlcmFsLXR5cGUtYXNzZXJ0aW9uXHJcblxyXG5pbXBvcnQgeyBTY2hlbWEgfSBmcm9tIFwianNvbnNjaGVtYVwiO1xyXG5pbXBvcnQgeyBhbHBoYW51bWVyaWNFeHRlbmRlZFBhdHRlcm4gfSBmcm9tIFwiLi9cIjtcclxuaW1wb3J0IHsgQXJnRGVmaW5pdGlvbnMsIEFyZ3NJbnN0YW5jZSwgYXJnc1NjaGVtYSB9IGZyb20gXCIuL2FyZ3NcIjtcclxuaW1wb3J0IHsgRXhlY0Z1bmN0aW9uLCBFeGVjVXRpbHMgfSBmcm9tIFwiLi9ydW50aW1lXCI7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIENvbW1hbmQ8VEFyZ0RlZnMgZXh0ZW5kcyBBcmdEZWZpbml0aW9ucz4ge1xyXG4gIGRlc2M/OiBzdHJpbmc7XHJcbiAgYXJncz86IFRBcmdEZWZzO1xyXG4gIGludGVybmFsPzogYm9vbGVhbjtcclxuICBydW4oZXhlYzogRXhlY0Z1bmN0aW9uLCBhcmdzOiBBcmdzSW5zdGFuY2U8VEFyZ0RlZnM+LCB1dGlsczogRXhlY1V0aWxzKTogdm9pZDtcclxufVxyXG5cclxuLy8gZmFrZSwgb25seSB1c2VkIHRvIGZvcmNlIGNvbW1hbmRzIHRvIGNvbWUgZnJvbSB0aGUgY29tbWFuZCBmdW5jdGlvblxyXG5leHBvcnQgaW50ZXJmYWNlIENvbW1hbmRGcm9tRnVuY3Rpb24ge1xyXG4gIHJlYWRvbmx5ICRmcm9tQ29tbWFuZEZ1bmN0aW9uOiB1bmRlZmluZWQ7XHJcbn1cclxuXHJcbmV4cG9ydCBjb25zdCBjb21tYW5kU2NoZW1hOiBTY2hlbWEgPSB7XHJcbiAgaWQ6IFwiL2NvbW1hbmRcIixcclxuICB0eXBlOiBcIm9iamVjdFwiLFxyXG4gIHJlcXVpcmVkOiBbXCJydW5cIl0sXHJcbiAgcHJvcGVydGllczoge1xyXG4gICAgZGVzYzoge1xyXG4gICAgICB0eXBlOiBcInN0cmluZ1wiXHJcbiAgICB9LFxyXG4gICAgYXJnczogYXJnc1NjaGVtYSxcclxuICAgIHJ1bjoge1xyXG4gICAgICBpc0Z1bmN0aW9uOiB0cnVlXHJcbiAgICB9IGFzIFNjaGVtYSxcclxuICAgIGludGVybmFsOiB7XHJcbiAgICAgIHR5cGU6IFwiYm9vbGVhblwiXHJcbiAgICB9XHJcbiAgfSxcclxuICBhZGRpdGlvbmFsUHJvcGVydGllczogZmFsc2VcclxufTtcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgQ29tbWFuZHMge1xyXG4gIFtjb21tYW5kTmFtZTogc3RyaW5nXTogQ29tbWFuZDxBcmdEZWZpbml0aW9ucz4gJiBDb21tYW5kRnJvbUZ1bmN0aW9uO1xyXG59XHJcblxyXG5leHBvcnQgY29uc3QgY29tbWFuZHNTY2hlbWE6IFNjaGVtYSA9IHtcclxuICBpZDogXCIvY29tbWFuZHNcIixcclxuICB0eXBlOiBcIm9iamVjdFwiLFxyXG4gIHBhdHRlcm5Qcm9wZXJ0aWVzOiB7XHJcbiAgICBbYWxwaGFudW1lcmljRXh0ZW5kZWRQYXR0ZXJuXTogY29tbWFuZFNjaGVtYVxyXG4gIH0sXHJcbiAgYWRkaXRpb25hbFByb3BlcnRpZXM6IGZhbHNlXHJcbn07XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gY29tbWFuZDxUQXJnRGVmcyBleHRlbmRzIEFyZ0RlZmluaXRpb25zID0ge30+KFxyXG4gIGNtZDogQ29tbWFuZDxUQXJnRGVmcz5cclxuKTogQ29tbWFuZDxUQXJnRGVmcz4gJiBDb21tYW5kRnJvbUZ1bmN0aW9uIHtcclxuICByZXR1cm4gY21kIGFzIENvbW1hbmQ8VEFyZ0RlZnM+ICYgQ29tbWFuZEZyb21GdW5jdGlvbjtcclxufVxyXG4iXX0=
exports.isInternalCommand = isInternalCommand;
var CommandBuilder = /** @class */ (function () {
function CommandBuilder(name) {
this.name = name;
this._command = {};
}
CommandBuilder.prototype.desc = function (desc) {
this._command.desc = desc;
return this;
};
CommandBuilder.prototype.args = function (argDefs) {
this._command.args = argDefs;
return this;
};
CommandBuilder.prototype.argsDesc = function (argDescs) {
var _this = this;
this._command.args = this._command.args || {};
Object.keys(argDescs).forEach(function (argName) {
var desc = argDescs[argName];
var argObj = (_this._command.args[argName] = _this._command.args[argName] || {});
Object.assign(argObj, { desc: desc });
});
return this;
};
// base
CommandBuilder.prototype.run = function () {
var _this = this;
var cmdOrCommands = [];
for (var _i = 0; _i < arguments.length; _i++) {
cmdOrCommands[_i] = arguments[_i];
}
var runFn;
if (cmdOrCommands.length === 1 && typeof cmdOrCommands[0] === "function") {
runFn = cmdOrCommands[0];
}
else {
runFn = function (exec) { return __awaiter(_this, void 0, void 0, function () {
return __generator(this, function (_a) {
switch (_a.label) {
case 0: return [4 /*yield*/, exec.apply(void 0, __spread(cmdOrCommands))];
case 1:
_a.sent();
return [2 /*return*/];
}
});
}); };
}
config_1.config.commands[this.name] = __assign({}, this._command, { run: runFn });
};
return CommandBuilder;
}());
exports.CommandBuilder = CommandBuilder;
function cmd(name) {
return new CommandBuilder(name);
}
exports.cmd = cmd;
import { Schema, ValidatorResult } from "jsonschema";
export declare const alphanumericExtendedPattern = "^[a-zA-Z0-9][-:_a-zA-Z0-9]*$";
export declare const alphanumericExtendedPattern = "^_?[a-zA-Z0-9][-:_a-zA-Z0-9]*$";
export declare const validateInstance: (obj: any, sch: Schema) => ValidatorResult;

@@ -16,3 +16,3 @@ "use strict";

// export const alphanumericPattern = '^[a-zA-Z0-9]+$';
exports.alphanumericExtendedPattern = "^[a-zA-Z0-9][-:_a-zA-Z0-9]*$";
exports.alphanumericExtendedPattern = "^_?[a-zA-Z0-9][-:_a-zA-Z0-9]*$";
exports.validateInstance = function (obj, sch) {

@@ -81,2 +81,1 @@ var v = new jsonschema_1.Validator();

};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL3NjaGVtYS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsa0RBQWtEOzs7Ozs7Ozs7Ozs7QUFFbEQseUNBQXdGO0FBRXhGLHVEQUF1RDtBQUMxQyxRQUFBLDJCQUEyQixHQUFHLDhCQUE4QixDQUFDO0FBRTdELFFBQUEsZ0JBQWdCLEdBQUcsVUFBQyxHQUFRLEVBQUUsR0FBVztJQUNwRCxJQUFNLENBQUMsR0FBRyxJQUFJLHNCQUFTLEVBQUUsQ0FBQztJQUV6QixDQUFDLENBQUMsVUFBa0IsQ0FBQyxVQUFVLEdBQUcsVUFBQyxRQUFhLEVBQUUsTUFBYztRQUMvRCxJQUFJLENBQUUsTUFBYyxDQUFDLFVBQVUsRUFBRTtZQUMvQixPQUFPO1NBQ1I7UUFFRCxJQUFJLE9BQU8sUUFBUSxLQUFLLFVBQVUsRUFBRTtZQUNsQyxPQUFPLG9CQUFvQixDQUFDO1NBQzdCO1FBQ0QsT0FBTyxTQUFTLENBQUM7SUFDbkIsQ0FBQyxDQUFDO0lBRUQsQ0FBQyxDQUFDLFVBQWtCLENBQUMsYUFBYSxHQUFHLFVBQ3BDLFFBQWEsRUFDYixNQUFjLEVBQ2QsT0FBZ0IsRUFDaEIsR0FBa0I7UUFFbEIsSUFBSSxDQUFFLE1BQWMsQ0FBQyxhQUFhLEVBQUU7WUFDbEMsT0FBTztTQUNSO1FBRUQsSUFBSSxRQUFRLEtBQUssU0FBUyxFQUFFO1lBQzFCLE9BQU8sU0FBUyxDQUFDO1NBQ2xCO1FBQ0QsSUFBTSxJQUFJLEdBQUcsR0FBRyxDQUFDLFlBQVksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDekMsSUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ3hCLElBQU0sR0FBRyxHQUFHLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNwQixJQUFNLE1BQU0sR0FBRyxHQUFHLENBQUMsT0FBTyxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLE1BQU0sQ0FBQztRQUM3QyxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsRUFBRTtZQUMxQixPQUFPLFNBQVMsQ0FBQztTQUNsQjtRQUVELElBQUksT0FBTyxRQUFRLEtBQUssUUFBUSxFQUFFO1lBQ2hDLE9BQU8sa0JBQWtCLENBQUM7U0FDM0I7UUFDRCxJQUFJLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsRUFBRTtZQUM5QixPQUFPLHFCQUFtQixNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBRyxDQUFDO1NBQy9DO1FBRUQsT0FBTyxTQUFTLENBQUM7SUFDbkIsQ0FBQyxDQUFDO0lBRUQsQ0FBQyxDQUFDLFVBQWtCLENBQUMsc0JBQXNCLEdBQUcsVUFBQyxRQUFhLEVBQUUsTUFBYzs7UUFDM0UsSUFBTSxjQUFjLEdBQWMsTUFBYyxDQUFDLHNCQUFzQixDQUFDO1FBQ3hFLElBQUksQ0FBQyxjQUFjLEVBQUU7WUFDbkIsT0FBTyxTQUFTLENBQUM7U0FDbEI7UUFFRCxJQUFJLE9BQU8sUUFBUSxLQUFLLFFBQVEsSUFBSSxRQUFRLEtBQUssSUFBSSxFQUFFO1lBQ3JELE9BQU8sU0FBUyxDQUFDO1NBQ2xCOztZQUVELEtBQW1CLElBQUEsS0FBQSxTQUFBLE1BQU0sQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUEsZ0JBQUEsNEJBQUU7Z0JBQXJDLElBQU0sSUFBSSxXQUFBO2dCQUNiLElBQUksY0FBYyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsRUFBRTtvQkFDakMsT0FBTyx3QkFBc0IsSUFBSSx1Q0FBb0MsQ0FBQztpQkFDdkU7YUFDRjs7Ozs7Ozs7O1FBRUQsT0FBTyxTQUFTLENBQUM7SUFDbkIsQ0FBQyxDQUFDO0lBRUYsT0FBTyxDQUFDLENBQUMsUUFBUSxDQUFDLEdBQUcsRUFBRSxHQUFHLEVBQUU7UUFDMUIsWUFBWSxFQUFFLElBQUk7S0FDUixDQUFDLENBQUM7QUFDaEIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gdHNsaW50OmRpc2FibGU6bm8tb2JqZWN0LWxpdGVyYWwtdHlwZS1hc3NlcnRpb25cclxuXHJcbmltcG9ydCB7IE9wdGlvbnMsIFNjaGVtYSwgU2NoZW1hQ29udGV4dCwgVmFsaWRhdG9yLCBWYWxpZGF0b3JSZXN1bHQgfSBmcm9tIFwianNvbnNjaGVtYVwiO1xyXG5cclxuLy8gZXhwb3J0IGNvbnN0IGFscGhhbnVtZXJpY1BhdHRlcm4gPSAnXlthLXpBLVowLTldKyQnO1xyXG5leHBvcnQgY29uc3QgYWxwaGFudW1lcmljRXh0ZW5kZWRQYXR0ZXJuID0gXCJeW2EtekEtWjAtOV1bLTpfYS16QS1aMC05XSokXCI7XHJcblxyXG5leHBvcnQgY29uc3QgdmFsaWRhdGVJbnN0YW5jZSA9IChvYmo6IGFueSwgc2NoOiBTY2hlbWEpOiBWYWxpZGF0b3JSZXN1bHQgPT4ge1xyXG4gIGNvbnN0IHYgPSBuZXcgVmFsaWRhdG9yKCk7XHJcblxyXG4gICh2LmF0dHJpYnV0ZXMgYXMgYW55KS5pc0Z1bmN0aW9uID0gKGluc3RhbmNlOiBhbnksIHNjaGVtYTogU2NoZW1hKSA9PiB7XHJcbiAgICBpZiAoIShzY2hlbWEgYXMgYW55KS5pc0Z1bmN0aW9uKSB7XHJcbiAgICAgIHJldHVybjtcclxuICAgIH1cclxuXHJcbiAgICBpZiAodHlwZW9mIGluc3RhbmNlICE9PSBcImZ1bmN0aW9uXCIpIHtcclxuICAgICAgcmV0dXJuIFwibXVzdCBiZSBhIGZ1bmN0aW9uXCI7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xyXG4gIH07XHJcblxyXG4gICh2LmF0dHJpYnV0ZXMgYXMgYW55KS5tYXRjaGVzVmFsdWVzID0gKFxyXG4gICAgaW5zdGFuY2U6IGFueSxcclxuICAgIHNjaGVtYTogU2NoZW1hLFxyXG4gICAgb3B0aW9uczogT3B0aW9ucyxcclxuICAgIGN0eDogU2NoZW1hQ29udGV4dFxyXG4gICkgPT4ge1xyXG4gICAgaWYgKCEoc2NoZW1hIGFzIGFueSkubWF0Y2hlc1ZhbHVlcykge1xyXG4gICAgICByZXR1cm47XHJcbiAgICB9XHJcblxyXG4gICAgaWYgKGluc3RhbmNlID09PSB1bmRlZmluZWQpIHtcclxuICAgICAgcmV0dXJuIHVuZGVmaW5lZDtcclxuICAgIH1cclxuICAgIGNvbnN0IHBhdGggPSBjdHgucHJvcGVydHlQYXRoLnNwbGl0KFwiLlwiKTtcclxuICAgIGNvbnN0IGNvbW1hbmQgPSBwYXRoWzFdO1xyXG4gICAgY29uc3QgYXJnID0gcGF0aFszXTtcclxuICAgIGNvbnN0IHZhbHVlcyA9IG9ialtjb21tYW5kXS5hcmdzW2FyZ10udmFsdWVzO1xyXG4gICAgaWYgKCFBcnJheS5pc0FycmF5KHZhbHVlcykpIHtcclxuICAgICAgcmV0dXJuIHVuZGVmaW5lZDtcclxuICAgIH1cclxuXHJcbiAgICBpZiAodHlwZW9mIGluc3RhbmNlICE9PSBcInN0cmluZ1wiKSB7XHJcbiAgICAgIHJldHVybiBcIm11c3QgYmUgYSBzdHJpbmdcIjtcclxuICAgIH1cclxuICAgIGlmICghdmFsdWVzLmluY2x1ZGVzKGluc3RhbmNlKSkge1xyXG4gICAgICByZXR1cm4gYG11c3QgYmUgb25lIG9mOiAke3ZhbHVlcy5qb2luKFwiLCBcIil9YDtcclxuICAgIH1cclxuXHJcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xyXG4gIH07XHJcblxyXG4gICh2LmF0dHJpYnV0ZXMgYXMgYW55KS5mb3JiaWRkZW5Qcm9wZXJ0eU5hbWVzID0gKGluc3RhbmNlOiBhbnksIHNjaGVtYTogU2NoZW1hKSA9PiB7XHJcbiAgICBjb25zdCBmb3JiaWRkZW5OYW1lczogc3RyaW5nW10gPSAoc2NoZW1hIGFzIGFueSkuZm9yYmlkZGVuUHJvcGVydHlOYW1lcztcclxuICAgIGlmICghZm9yYmlkZGVuTmFtZXMpIHtcclxuICAgICAgcmV0dXJuIHVuZGVmaW5lZDtcclxuICAgIH1cclxuXHJcbiAgICBpZiAodHlwZW9mIGluc3RhbmNlICE9PSBcIm9iamVjdFwiIHx8IGluc3RhbmNlID09PSBudWxsKSB7XHJcbiAgICAgIHJldHVybiB1bmRlZmluZWQ7XHJcbiAgICB9XHJcblxyXG4gICAgZm9yIChjb25zdCBwcm9wIG9mIE9iamVjdC5rZXlzKGluc3RhbmNlKSkge1xyXG4gICAgICBpZiAoZm9yYmlkZGVuTmFtZXMuaW5jbHVkZXMocHJvcCkpIHtcclxuICAgICAgICByZXR1cm4gYHRoZSBwcm9wZXJ0eSBuYW1lICcke3Byb3B9JyBpcyByZXNlcnZlZCBhbmQgY2Fubm90IGJlIHJldXNlZGA7XHJcbiAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xyXG4gIH07XHJcblxyXG4gIHJldHVybiB2LnZhbGlkYXRlKG9iaiwgc2NoLCB7XHJcbiAgICBuZXN0ZWRFcnJvcnM6IHRydWVcclxuICB9IGFzIE9wdGlvbnMpO1xyXG59O1xyXG4iXX0=

@@ -17,2 +17,1 @@ "use strict";

};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3B0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvc2NoZW1hL29wdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFTYSxRQUFBLGFBQWEsR0FBVztJQUNuQyxFQUFFLEVBQUUsVUFBVTtJQUNkLElBQUksRUFBRSxRQUFRO0lBQ2QsUUFBUSxFQUFFLEVBQUU7SUFDWixVQUFVLEVBQUU7UUFDVixPQUFPLEVBQUU7WUFDUCxJQUFJLEVBQUUsU0FBUztTQUNoQjtRQUNELFFBQVEsRUFBRTtZQUNSLElBQUksRUFBRSxTQUFTO1NBQ2hCO0tBQ0Y7SUFDRCxvQkFBb0IsRUFBRSxLQUFLO0NBQzVCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTY2hlbWEgfSBmcm9tIFwianNvbnNjaGVtYVwiO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBGdWxsT3B0aW9ucyB7XHJcbiAgcHJvZmlsZTogYm9vbGVhbjtcclxuICBzaG93VGltZTogYm9vbGVhbjtcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBQYXJ0aWFsT3B0aW9ucyBleHRlbmRzIFBhcnRpYWw8RnVsbE9wdGlvbnM+IHt9XHJcblxyXG5leHBvcnQgY29uc3Qgb3B0aW9uc1NjaGVtYTogU2NoZW1hID0ge1xyXG4gIGlkOiBcIi9vcHRpb25zXCIsXHJcbiAgdHlwZTogXCJvYmplY3RcIixcclxuICByZXF1aXJlZDogW10sXHJcbiAgcHJvcGVydGllczoge1xyXG4gICAgcHJvZmlsZToge1xyXG4gICAgICB0eXBlOiBcImJvb2xlYW5cIlxyXG4gICAgfSxcclxuICAgIHNob3dUaW1lOiB7XHJcbiAgICAgIHR5cGU6IFwiYm9vbGVhblwiXHJcbiAgICB9XHJcbiAgfSxcclxuICBhZGRpdGlvbmFsUHJvcGVydGllczogZmFsc2VcclxufTtcclxuIl19

@@ -0,1 +1,3 @@

import { ParsedCommands } from "../parser/commands";
import { HashCollection } from "../utils/hash";
import { Commands } from "./commands";

@@ -13,8 +15,12 @@ import { FullOptions } from "./options";

}>;
export interface GetFileChangesOptions {
log: boolean;
}
export interface ExtendedFullOptions extends FullOptions {
colorMode: boolean;
}
export interface MakfyContext {
commandName: string;
commandArgs: object;
commands: Commands;
options: ExtendedFullOptions;
makfyFilename: string;
}
export interface GetFileChangesResult {

@@ -28,18 +34,17 @@ hasChanges: boolean;

}
export interface MakfyContext {
commandName: string;
commandArgs: object;
commands: Commands;
options: ExtendedFullOptions;
makfyFilename: string;
export interface CachedGetFileChangesResult {
result: GetFileChangesResult;
oldHashCollection?: HashCollection;
newHashCollection: HashCollection;
}
export interface ExecUtils {
makfyContext: MakfyContext;
escape(...parts: string[]): string;
fixPath(path: string, style: "autodetect" | "windows" | "posix"): string;
setEnvVar(name: string, value: string | undefined): string;
expandGlobsAsync(globPatterns: string[]): Promise<string[]>;
getFileChangesAsync(contextName: string, globPatterns: string[] | string, options?: Partial<GetFileChangesOptions>): Promise<GetFileChangesResult>;
cleanCache(): void;
limitPromiseConcurrency<T>(concurrency: number): (fn: () => PromiseLike<T>) => Promise<T>;
export interface ExecContext extends MakfyContext {
parsedCommands: ParsedCommands;
makfyFileContents?: string;
idStack: string[];
cwd?: string;
env?: object;
syncMode: boolean;
getFileChangesResults: {
[hashFilename: string]: CachedGetFileChangesResult;
};
}
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnVudGltZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvc2NoZW1hL3J1bnRpbWUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1hbmRzIH0gZnJvbSBcIi4vY29tbWFuZHNcIjtcclxuaW1wb3J0IHsgRnVsbE9wdGlvbnMgfSBmcm9tIFwiLi9vcHRpb25zXCI7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEV4ZWNPYmplY3Qge1xyXG4gIF86IHN0cmluZzsgLy8gY29tbWFuZCBuYW1lXHJcbiAgYXJncz86IHtcclxuICAgIFthcmdOYW1lOiBzdHJpbmddOiBzdHJpbmcgfCBib29sZWFuO1xyXG4gIH07XHJcbn1cclxuXHJcbmV4cG9ydCB0eXBlIEV4ZWNDb21tYW5kID0gc3RyaW5nIHwgRXhlY09iamVjdCB8IChzdHJpbmcgfCBFeGVjT2JqZWN0KVtdO1xyXG5cclxuZXhwb3J0IHR5cGUgRXhlY0Z1bmN0aW9uID0gKC4uLmNvbW1hbmRzOiBFeGVjQ29tbWFuZFtdKSA9PiBQcm9taXNlPHsga2VlcENvbnRleHQ6IEV4ZWNGdW5jdGlvbiB9PjtcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgR2V0RmlsZUNoYW5nZXNPcHRpb25zIHtcclxuICBsb2c6IGJvb2xlYW47XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgRXh0ZW5kZWRGdWxsT3B0aW9ucyBleHRlbmRzIEZ1bGxPcHRpb25zIHtcclxuICBjb2xvck1vZGU6IGJvb2xlYW47XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgR2V0RmlsZUNoYW5nZXNSZXN1bHQge1xyXG4gIGhhc0NoYW5nZXM6IGJvb2xlYW47XHJcbiAgY2xlYW5SdW46IGJvb2xlYW47XHJcbiAgYWRkZWQ6IHN0cmluZ1tdO1xyXG4gIHJlbW92ZWQ6IHN0cmluZ1tdO1xyXG4gIG1vZGlmaWVkOiBzdHJpbmdbXTtcclxuICB1bm1vZGlmaWVkOiBzdHJpbmdbXTtcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBNYWtmeUNvbnRleHQge1xyXG4gIGNvbW1hbmROYW1lOiBzdHJpbmc7XHJcbiAgY29tbWFuZEFyZ3M6IG9iamVjdDtcclxuICBjb21tYW5kczogQ29tbWFuZHM7XHJcbiAgb3B0aW9uczogRXh0ZW5kZWRGdWxsT3B0aW9ucztcclxuICBtYWtmeUZpbGVuYW1lOiBzdHJpbmc7XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgRXhlY1V0aWxzIHtcclxuICBtYWtmeUNvbnRleHQ6IE1ha2Z5Q29udGV4dDtcclxuICBlc2NhcGUoLi4ucGFydHM6IHN0cmluZ1tdKTogc3RyaW5nO1xyXG4gIGZpeFBhdGgocGF0aDogc3RyaW5nLCBzdHlsZTogXCJhdXRvZGV0ZWN0XCIgfCBcIndpbmRvd3NcIiB8IFwicG9zaXhcIik6IHN0cmluZztcclxuICBzZXRFbnZWYXIobmFtZTogc3RyaW5nLCB2YWx1ZTogc3RyaW5nIHwgdW5kZWZpbmVkKTogc3RyaW5nO1xyXG4gIGV4cGFuZEdsb2JzQXN5bmMoZ2xvYlBhdHRlcm5zOiBzdHJpbmdbXSk6IFByb21pc2U8c3RyaW5nW10+O1xyXG4gIGdldEZpbGVDaGFuZ2VzQXN5bmMoXHJcbiAgICBjb250ZXh0TmFtZTogc3RyaW5nLFxyXG4gICAgZ2xvYlBhdHRlcm5zOiBzdHJpbmdbXSB8IHN0cmluZyxcclxuICAgIG9wdGlvbnM/OiBQYXJ0aWFsPEdldEZpbGVDaGFuZ2VzT3B0aW9ucz5cclxuICApOiBQcm9taXNlPEdldEZpbGVDaGFuZ2VzUmVzdWx0PjtcclxuICBjbGVhbkNhY2hlKCk6IHZvaWQ7XHJcblxyXG4gIC8vIGludGVybmFsIG9ubHkgZm9yIG5vd1xyXG4gIGxpbWl0UHJvbWlzZUNvbmN1cnJlbmN5PFQ+KGNvbmN1cnJlbmN5OiBudW1iZXIpOiAoZm46ICgpID0+IFByb21pc2VMaWtlPFQ+KSA9PiBQcm9taXNlPFQ+O1xyXG59XHJcbiJdfQ==

@@ -72,2 +72,1 @@ "use strict";

};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc29sZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvdXRpbHMvY29uc29sZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxpQkFnQkE7O0FBaEJBLCtCQUEwQjtBQUMxQixxQ0FBa0Q7QUFFckMsUUFBQSxXQUFXLEdBQUc7SUFDekIsSUFBTSxLQUFLLEdBQUcsZUFBSyxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsQ0FBQztJQUM5QixPQUFPLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUM1QixPQUFPLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztBQUM5QixDQUFDLENBQUM7QUFFVyxRQUFBLGtCQUFrQixHQUFHLFVBQU8sR0FBZ0I7SUFBaEIsb0JBQUEsRUFBQSxRQUFnQjs7Ozt3QkFDdkQscUJBQU0sK0JBQXFCLENBQUMsT0FBTyxDQUFDLE1BQU0sRUFBRSxHQUFHLENBQUMsRUFBQTs7b0JBQWhELFNBQWdELENBQUM7Ozs7O0NBQ2xELENBQUM7QUFFVyxRQUFBLG9CQUFvQixHQUFHLFVBQU8sR0FBZ0I7SUFBaEIsb0JBQUEsRUFBQSxRQUFnQjs7Ozt3QkFDekQscUJBQU0sK0JBQXFCLENBQUMsT0FBTyxDQUFDLE1BQU0sRUFBRSxHQUFHLENBQUMsRUFBQTs7b0JBQWhELFNBQWdELENBQUM7Ozs7O0NBQ2xELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgY2hhbGsgZnJvbSBcImNoYWxrXCI7XHJcbmltcG9ydCB7IHNvY2tldEZsdXNoV3JpdGVBc3luYyB9IGZyb20gXCIuL3NvY2tldHNcIjtcclxuXHJcbmV4cG9ydCBjb25zdCByZXNldENvbG9ycyA9ICgpID0+IHtcclxuICBjb25zdCByZXNldCA9IGNoYWxrLnJlc2V0KFwiXCIpO1xyXG4gIHByb2Nlc3Muc3Rkb3V0LndyaXRlKHJlc2V0KTtcclxuICBwcm9jZXNzLnN0ZGVyci53cml0ZShyZXNldCk7XHJcbn07XHJcblxyXG5leHBvcnQgY29uc3QgYmxvY2tpbmdDb25zb2xlTG9nID0gYXN5bmMgKHN0cjogc3RyaW5nID0gXCJcIikgPT4ge1xyXG4gIGF3YWl0IHNvY2tldEZsdXNoV3JpdGVBc3luYyhwcm9jZXNzLnN0ZG91dCwgc3RyKTtcclxufTtcclxuXHJcbmV4cG9ydCBjb25zdCBibG9ja2luZ0NvbnNvbGVFcnJvciA9IGFzeW5jIChzdHI6IHN0cmluZyA9IFwiXCIpID0+IHtcclxuICBhd2FpdCBzb2NrZXRGbHVzaFdyaXRlQXN5bmMocHJvY2Vzcy5zdGRlcnIsIHN0cik7XHJcbn07XHJcbiJdfQ==

@@ -1,2 +0,2 @@

import { ExecContext } from "../execRuntime";
import { ExecContext } from "../schema/runtime";
export declare const getTimeString: (show: boolean) => string;

@@ -3,0 +3,0 @@ export declare const errorMessageForObject: (parts: (string | undefined)[], message: string) => string;

@@ -92,2 +92,1 @@ "use strict";

};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybWF0dGluZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvdXRpbHMvZm9ybWF0dGluZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLCtCQUEwQjtBQUliLFFBQUEsYUFBYSxHQUFHLFVBQUMsSUFBYTtJQUN6QyxJQUFJLENBQUMsSUFBSSxFQUFFO1FBQ1QsT0FBTyxFQUFFLENBQUM7S0FDWDtJQUNELE9BQU8sZUFBSyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBSSxJQUFJLElBQUksQ0FBQyxJQUFJLElBQUksRUFBRSxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUMsa0JBQWtCLEVBQUUsT0FBSSxDQUFDLENBQUM7QUFDdEYsQ0FBQyxDQUFDO0FBRVcsUUFBQSxxQkFBcUIsR0FBRyxVQUFDLEtBQTZCLEVBQUUsT0FBZTtJQUNsRixPQUFVLEtBQUssQ0FBQyxNQUFNLENBQUMsVUFBQyxDQUFDLElBQUssT0FBQSxDQUFDLEtBQUssU0FBUyxFQUFmLENBQWUsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsV0FBTSxPQUFTLENBQUM7QUFDMUUsQ0FBQyxDQUFDO0FBRVcsUUFBQSxzQkFBc0IsR0FBRyxVQUFDLE9BQWU7SUFDcEQsT0FBTyxDQUFDLE9BQU8sQ0FBQyxNQUFNLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLE9BQU8sQ0FBQztBQUN0RCxDQUFDLENBQUM7QUFFRixxQkFBcUI7QUFDUixRQUFBLHVCQUF1QixHQUFHLFVBQUMsR0FBUTs7SUFDOUMsSUFBTSxHQUFHLEdBQUcsRUFBRSxDQUFDO0lBRWYsZUFBZTtJQUNmLElBQUksR0FBRyxDQUFDLEVBQUUsRUFBRTtRQUNWLEdBQUcsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxDQUFDO0tBQ2xCO0lBRUQsaUJBQWlCO0lBQ2pCLElBQUksR0FBRyxDQUFDLENBQUMsRUFBRTtRQUNULEdBQUcsQ0FBQyxJQUFJLE9BQVIsR0FBRyxXQUFTLEdBQUcsQ0FBQyxDQUFDLEdBQUU7S0FDcEI7O1FBRUQsS0FBc0IsSUFBQSxLQUFBLFNBQUEsTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQSxnQkFBQSw0QkFBRTtZQUFuQyxJQUFNLE9BQU8sV0FBQTtZQUNoQixRQUFRLE9BQU8sRUFBRTtnQkFDZixLQUFLLElBQUksQ0FBQztnQkFDVixLQUFLLEdBQUc7b0JBQ04sTUFBTTtnQkFDUjtvQkFDRSxJQUFNLFFBQVEsR0FBRyxHQUFHLENBQUMsT0FBTyxDQUFDLENBQUM7b0JBQzlCLElBQUksUUFBUSxLQUFLLFNBQVMsSUFBSSxRQUFRLEtBQUssSUFBSSxFQUFFO3dCQUMvQyxHQUFHLENBQUMsSUFBSSxDQUFDLDhCQUFzQixDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUM7cUJBQzNDO3lCQUFNO3dCQUNMLEdBQUcsQ0FBQyxJQUFJLE9BQVIsR0FBRyxXQUFTLENBQUMsOEJBQXNCLENBQUMsT0FBTyxDQUFDLEVBQUUsUUFBUSxDQUFDLFFBQVEsRUFBRSxDQUFDLEdBQUU7cUJBQ3JFO29CQUNELE1BQU07YUFDVDtTQUNGOzs7Ozs7Ozs7SUFFRCxPQUFPLEdBQUcsQ0FBQztBQUNiLENBQUMsQ0FBQztBQUVXLFFBQUEsb0JBQW9CLEdBQUcsVUFBQyxPQUFpQixFQUFFLFFBQWlCO0lBQ3ZFLE9BQU8scUJBQWEsQ0FBQyxRQUFRLENBQUMsR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLGVBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDO0FBQzdFLENBQUMsQ0FBQztBQUVXLFFBQUEsZUFBZSxHQUFHLFVBQUMsT0FBb0I7SUFDbEQsT0FBTyw0QkFBb0IsQ0FBQyxPQUFPLENBQUMsT0FBTyxFQUFFLE9BQU8sQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUM7QUFDekUsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGNoYWxrIGZyb20gXCJjaGFsa1wiO1xyXG5pbXBvcnQgeyBFeGVjQ29udGV4dCB9IGZyb20gXCIuLi9leGVjUnVudGltZVwiO1xyXG5pbXBvcnQgU29ja2V0ID0gTm9kZUpTLlNvY2tldDtcclxuXHJcbmV4cG9ydCBjb25zdCBnZXRUaW1lU3RyaW5nID0gKHNob3c6IGJvb2xlYW4pID0+IHtcclxuICBpZiAoIXNob3cpIHtcclxuICAgIHJldHVybiBcIlwiO1xyXG4gIH1cclxuICByZXR1cm4gY2hhbGsuYm9sZC5ncmF5KGBbJHtuZXcgRGF0ZShuZXcgRGF0ZSgpLmdldFRpbWUoKSkudG9Mb2NhbGVUaW1lU3RyaW5nKCl9XSBgKTtcclxufTtcclxuXHJcbmV4cG9ydCBjb25zdCBlcnJvck1lc3NhZ2VGb3JPYmplY3QgPSAocGFydHM6IChzdHJpbmcgfCB1bmRlZmluZWQpW10sIG1lc3NhZ2U6IHN0cmluZykgPT4ge1xyXG4gIHJldHVybiBgJHtwYXJ0cy5maWx0ZXIoKGUpID0+IGUgIT09IHVuZGVmaW5lZCkuam9pbihcIi5cIil9IC0gJHttZXNzYWdlfWA7XHJcbn07XHJcblxyXG5leHBvcnQgY29uc3QgYXJnTmFtZVRvRGFzaGVkQXJnTmFtZSA9IChhcmdOYW1lOiBzdHJpbmcpID0+IHtcclxuICByZXR1cm4gKGFyZ05hbWUubGVuZ3RoIDw9IDEgPyBcIi1cIiA6IFwiLS1cIikgKyBhcmdOYW1lO1xyXG59O1xyXG5cclxuLy8gVE9ETzogcmVtb3ZlIHRoaXM/XHJcbmV4cG9ydCBjb25zdCBvYmplY3RUb0NvbW1hbmRMaW5lQXJncyA9IChvYmo6IGFueSkgPT4ge1xyXG4gIGNvbnN0IGFyciA9IFtdO1xyXG5cclxuICAvLyBjb21tYW5kIG5hbWVcclxuICBpZiAob2JqLiQwKSB7XHJcbiAgICBhcnIucHVzaChvYmouJDApO1xyXG4gIH1cclxuXHJcbiAgLy8gbm9uIGFyZ3MgYXJyYXlcclxuICBpZiAob2JqLl8pIHtcclxuICAgIGFyci5wdXNoKC4uLm9iai5fKTtcclxuICB9XHJcblxyXG4gIGZvciAoY29uc3QgYXJnTmFtZSBvZiBPYmplY3Qua2V5cyhvYmopKSB7XHJcbiAgICBzd2l0Y2ggKGFyZ05hbWUpIHtcclxuICAgICAgY2FzZSBcIiQwXCI6XHJcbiAgICAgIGNhc2UgXCJfXCI6XHJcbiAgICAgICAgYnJlYWs7XHJcbiAgICAgIGRlZmF1bHQ6XHJcbiAgICAgICAgY29uc3QgYXJnVmFsdWUgPSBvYmpbYXJnTmFtZV07XHJcbiAgICAgICAgaWYgKGFyZ1ZhbHVlID09PSB1bmRlZmluZWQgfHwgYXJnVmFsdWUgPT09IG51bGwpIHtcclxuICAgICAgICAgIGFyci5wdXNoKGFyZ05hbWVUb0Rhc2hlZEFyZ05hbWUoYXJnTmFtZSkpO1xyXG4gICAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgICBhcnIucHVzaCguLi5bYXJnTmFtZVRvRGFzaGVkQXJnTmFtZShhcmdOYW1lKSwgYXJnVmFsdWUudG9TdHJpbmcoKV0pO1xyXG4gICAgICAgIH1cclxuICAgICAgICBicmVhaztcclxuICAgIH1cclxuICB9XHJcblxyXG4gIHJldHVybiBhcnI7XHJcbn07XHJcblxyXG5leHBvcnQgY29uc3QgZm9ybWF0Q29udGV4dElkU3RhY2sgPSAoaWRTdGFjazogc3RyaW5nW10sIHNob3dUaW1lOiBib29sZWFuKSA9PiB7XHJcbiAgcmV0dXJuIGdldFRpbWVTdHJpbmcoc2hvd1RpbWUpICsgaWRTdGFjay5qb2luKGNoYWxrLmJvbGQuZ3JheShcIi9cIikpICsgXCIgIFwiO1xyXG59O1xyXG5cclxuZXhwb3J0IGNvbnN0IGZvcm1hdENvbnRleHRJZCA9IChjb250ZXh0OiBFeGVjQ29udGV4dCkgPT4ge1xyXG4gIHJldHVybiBmb3JtYXRDb250ZXh0SWRTdGFjayhjb250ZXh0LmlkU3RhY2ssIGNvbnRleHQub3B0aW9ucy5zaG93VGltZSk7XHJcbn07XHJcbiJdfQ==

@@ -152,2 +152,1 @@ "use strict";

}); };
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2xvYnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL3V0aWxzL2dsb2JzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLGlCQW1EQTs7QUFuREEsSUFBTSxJQUFJLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0FBRWhCLFFBQUEsc0JBQXNCLEdBQUcsVUFBTyxXQUFtQjs7UUFDOUQsc0JBQU8sSUFBSSxPQUFPLENBQVcsVUFBQyxPQUFPLEVBQUUsTUFBTTtnQkFDM0MsSUFBSSxDQUNGLFdBQVcsRUFDWCxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFLEVBQzNDLFVBQUMsR0FBaUIsRUFBRSxLQUFlO29CQUNqQyxJQUFJLEdBQUcsRUFBRTt3QkFDUCxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUM7d0JBQ1osT0FBTztxQkFDUjtvQkFFRCxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUM7Z0JBQ2pCLENBQUMsQ0FDRixDQUFDO1lBQ0osQ0FBQyxDQUFDLEVBQUM7O0tBQ0osQ0FBQztBQUVXLFFBQUEsdUJBQXVCLEdBQUcsVUFBTyxZQUFzQjs7Ozs7Z0JBQ2xFLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLFlBQVksQ0FBQyxFQUFFO29CQUNoQyxNQUFNLElBQUksS0FBSyxDQUFDLHNDQUFzQyxDQUFDLENBQUM7aUJBQ3pEO2dCQUVLLEdBQUcsR0FBRyxJQUFJLEdBQUcsRUFBRSxDQUFDOzs7O2dCQUNFLGlCQUFBLFNBQUEsWUFBWSxDQUFBOzs7O2dCQUEzQixXQUFXO2dCQUNsQixJQUFJLE9BQU8sV0FBVyxLQUFLLFFBQVEsRUFBRTtvQkFDbkMsTUFBTSxJQUFJLEtBQUssQ0FBQyxpQ0FBaUMsQ0FBQyxDQUFDO2lCQUNwRDtnQkFDRCxXQUFXLEdBQUcsV0FBVyxDQUFDLElBQUksRUFBRSxDQUFDO2dCQUMzQixRQUFRLEdBQUcsV0FBVyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsQ0FBQztnQkFDOUMsSUFBSSxRQUFRLEVBQUU7b0JBQ1osV0FBVyxHQUFHLFdBQVcsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUM7b0JBQ3BDLFdBQVcsR0FBRyxXQUFXLENBQUMsSUFBSSxFQUFFLENBQUM7aUJBQ2xDO2dCQUVELElBQUksV0FBVyxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7b0JBQzVCLE1BQU0sSUFBSSxLQUFLLENBQUMsa0NBQWtDLENBQUMsQ0FBQztpQkFDckQ7Z0JBRWEscUJBQU0sOEJBQXNCLENBQUMsV0FBVyxDQUFDLEVBQUE7O2dCQUFqRCxLQUFLLEdBQUcsU0FBeUM7O29CQUN2RCxLQUFtQixVQUFBLFNBQUEsS0FBSyxDQUFBLDJFQUFFO3dCQUFmLElBQUk7d0JBQ2IsSUFBSSxRQUFRLEVBQUU7NEJBQ1osR0FBRyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQzt5QkFDbEI7NkJBQU07NEJBQ0wsR0FBRyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQzt5QkFDZjtxQkFDRjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O29CQUVILCtCQUFXLEdBQUcsR0FBRTs7O0tBQ2pCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJjb25zdCBnbG9iID0gcmVxdWlyZShcImdsb2JcIik7XHJcblxyXG5leHBvcnQgY29uc3QgdW5yb2xsR2xvYlBhdHRlcm5Bc3luYyA9IGFzeW5jIChnbG9iUGF0dGVybjogc3RyaW5nKTogUHJvbWlzZTxzdHJpbmdbXT4gPT4ge1xyXG4gIHJldHVybiBuZXcgUHJvbWlzZTxzdHJpbmdbXT4oKHJlc29sdmUsIHJlamVjdCkgPT4ge1xyXG4gICAgZ2xvYihcclxuICAgICAgZ2xvYlBhdHRlcm4sXHJcbiAgICAgIHsgc3RyaWN0OiB0cnVlLCBub2RpcjogdHJ1ZSwgZm9sbG93OiB0cnVlIH0sXHJcbiAgICAgIChlcnI6IEVycm9yIHwgbnVsbCwgZmlsZXM6IHN0cmluZ1tdKSA9PiB7XHJcbiAgICAgICAgaWYgKGVycikge1xyXG4gICAgICAgICAgcmVqZWN0KGVycik7XHJcbiAgICAgICAgICByZXR1cm47XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICByZXNvbHZlKGZpbGVzKTtcclxuICAgICAgfVxyXG4gICAgKTtcclxuICB9KTtcclxufTtcclxuXHJcbmV4cG9ydCBjb25zdCB1bnJvbGxHbG9iUGF0dGVybnNBc3luYyA9IGFzeW5jIChnbG9iUGF0dGVybnM6IHN0cmluZ1tdKTogUHJvbWlzZTxzdHJpbmdbXT4gPT4ge1xyXG4gIGlmICghQXJyYXkuaXNBcnJheShnbG9iUGF0dGVybnMpKSB7XHJcbiAgICB0aHJvdyBuZXcgRXJyb3IoXCJnbG9iIHBhdHRlcm5zIG11c3QgYmUgYSBzdHJpbmcgYXJyYXlcIik7XHJcbiAgfVxyXG5cclxuICBjb25zdCBzZXQgPSBuZXcgU2V0KCk7XHJcbiAgZm9yIChsZXQgZ2xvYlBhdHRlcm4gb2YgZ2xvYlBhdHRlcm5zKSB7XHJcbiAgICBpZiAodHlwZW9mIGdsb2JQYXR0ZXJuICE9PSBcInN0cmluZ1wiKSB7XHJcbiAgICAgIHRocm93IG5ldyBFcnJvcihcImEgZ2xvYiBwYXR0ZXJuIG11c3QgYmUgYSBzdHJpbmdcIik7XHJcbiAgICB9XHJcbiAgICBnbG9iUGF0dGVybiA9IGdsb2JQYXR0ZXJuLnRyaW0oKTtcclxuICAgIGNvbnN0IG5lZ2F0aXZlID0gZ2xvYlBhdHRlcm4uc3RhcnRzV2l0aChcIiEhXCIpO1xyXG4gICAgaWYgKG5lZ2F0aXZlKSB7XHJcbiAgICAgIGdsb2JQYXR0ZXJuID0gZ2xvYlBhdHRlcm4uc3Vic3RyKDIpO1xyXG4gICAgICBnbG9iUGF0dGVybiA9IGdsb2JQYXR0ZXJuLnRyaW0oKTtcclxuICAgIH1cclxuXHJcbiAgICBpZiAoZ2xvYlBhdHRlcm4ubGVuZ3RoID09PSAwKSB7XHJcbiAgICAgIHRocm93IG5ldyBFcnJvcihcImEgZ2xvYiBwYXR0ZXJuIG11c3Qgbm90IGJlIGVtcHR5XCIpO1xyXG4gICAgfVxyXG5cclxuICAgIGNvbnN0IGZpbGVzID0gYXdhaXQgdW5yb2xsR2xvYlBhdHRlcm5Bc3luYyhnbG9iUGF0dGVybik7XHJcbiAgICBmb3IgKGNvbnN0IGZpbGUgb2YgZmlsZXMpIHtcclxuICAgICAgaWYgKG5lZ2F0aXZlKSB7XHJcbiAgICAgICAgc2V0LmRlbGV0ZShmaWxlKTtcclxuICAgICAgfSBlbHNlIHtcclxuICAgICAgICBzZXQuYWRkKGZpbGUpO1xyXG4gICAgICB9XHJcbiAgICB9XHJcbiAgfVxyXG4gIHJldHVybiBbLi4uc2V0XTtcclxufTtcclxuIl19

@@ -250,2 +250,1 @@ "use strict";

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hash.js","sourceRoot":"","sources":["../../../src/lib/utils/hash.ts"],"names":[],"mappings":"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","sourcesContent":["import * as crypto from \"crypto\";\r\nimport * as fs from \"fs\";\r\nimport * as path from \"path\";\r\nimport { GetFileChangesResult } from \"../schema/runtime\";\r\n\r\nexport type HashType = \"sha1\";\r\n\r\nexport interface HashEntry {\r\n  hash?: string;\r\n  size: number;\r\n}\r\n\r\nexport interface Hashes {\r\n  [path: string]: HashEntry;\r\n}\r\n\r\nexport interface HashCollection {\r\n  hashType: HashType;\r\n  hashes: Hashes;\r\n}\r\n\r\nexport const cacheFolderName = \".makfy-cache\";\r\n\r\nexport const generateHashEntryAsync = async (\r\n  filePath: string,\r\n  hashType: HashType,\r\n  onlySize: boolean\r\n): Promise<HashEntry> => {\r\n  const stat = fs.statSync(filePath);\r\n  const size = stat.size;\r\n\r\n  if (onlySize) {\r\n    return {\r\n      size: size\r\n    };\r\n  }\r\n\r\n  const hash = crypto.createHash(hashType);\r\n  const stream = fs.createReadStream(filePath);\r\n\r\n  return new Promise<HashEntry>((resolve, reject) => {\r\n    stream.once(\"error\", (err: Error) => {\r\n      reject(err);\r\n    });\r\n\r\n    stream.on(\"data\", (data: Buffer) => {\r\n      hash.update(data);\r\n    });\r\n\r\n    stream.once(\"end\", () => {\r\n      const hashEntry: HashEntry = {\r\n        hash: hash.digest(\"base64\"),\r\n        size: size\r\n      };\r\n\r\n      resolve(hashEntry);\r\n    });\r\n  });\r\n};\r\n\r\nexport const generateHashCollectionAsync = async (\r\n  files: string[],\r\n  hashType: HashType,\r\n  onlySize: boolean\r\n): Promise<HashCollection> => {\r\n  const hashes: {\r\n    [k: string]: HashEntry;\r\n  } = {};\r\n\r\n  for (const file of files) {\r\n    hashes[file] = await generateHashEntryAsync(file, hashType, onlySize);\r\n  }\r\n\r\n  return {\r\n    hashType: hashType,\r\n    hashes: hashes\r\n  };\r\n};\r\n\r\n/**\r\n * Gets a delta between two hash collections.\r\n * @param oldHashCollection\r\n * @param newHashCollection\r\n * @return {Promise<GetFileChangesResult>}\r\n */\r\nexport const getHashCollectionDelta = (\r\n  oldHashCollection: HashCollection | undefined,\r\n  newHashCollection: HashCollection\r\n): GetFileChangesResult => {\r\n  const result: GetFileChangesResult = {\r\n    hasChanges: false,\r\n    cleanRun: false,\r\n    removed: [],\r\n    modified: [],\r\n    unmodified: [],\r\n    added: []\r\n  };\r\n\r\n  if (oldHashCollection === undefined) {\r\n    result.hasChanges = true;\r\n    result.cleanRun = true;\r\n    result.added = Object.keys(newHashCollection.hashes);\r\n    return result;\r\n  }\r\n\r\n  if (oldHashCollection.hashType !== newHashCollection.hashType) {\r\n    throw new Error(\"hash type mistmatch\");\r\n  }\r\n\r\n  const oldHashes = oldHashCollection.hashes;\r\n  const newHashes = newHashCollection.hashes;\r\n\r\n  const union = new Set<string>([...Object.keys(oldHashes), ...Object.keys(newHashes)]);\r\n  for (const e of union) {\r\n    const oldHash = oldHashes[e];\r\n    const newHash = newHashes[e];\r\n    if (oldHash && newHash) {\r\n      if (oldHash.size === newHash.size && oldHash.hash === newHash.hash) {\r\n        result.unmodified.push(e);\r\n      } else {\r\n        result.hasChanges = true;\r\n        result.modified.push(e);\r\n      }\r\n    } else if (oldHash) {\r\n      result.hasChanges = true;\r\n      result.removed.push(e);\r\n    } else if (newHash) {\r\n      result.hasChanges = true;\r\n      result.added.push(e);\r\n    } else {\r\n      throw new Error(\"no old and no new hash, this should not happen\");\r\n    }\r\n  }\r\n\r\n  return result;\r\n};\r\n\r\n/**\r\n * Tries to load a hash file.\r\n * @param hashFilePath Path to the hash file\r\n * @return {Promise<HashCollection>} The hash collection.\r\n */\r\nexport const loadHashCollectionFileAsync = async (\r\n  hashFilePath: string\r\n): Promise<HashCollection> => {\r\n  return new Promise<HashCollection>((resolve, reject) => {\r\n    fs.readFile(hashFilePath, \"utf8\", (err, data) => {\r\n      if (err) {\r\n        reject(err);\r\n        return;\r\n      }\r\n\r\n      resolve(JSON.parse(data));\r\n    });\r\n  });\r\n};\r\n\r\nexport const saveHashCollectionFileAsync = async (\r\n  hashFilePath: string,\r\n  hashCollection: HashCollection\r\n) => {\r\n  return new Promise<void>((resolve, reject) => {\r\n    fs.writeFile(hashFilePath, JSON.stringify(hashCollection), (err) => {\r\n      if (err) {\r\n        reject(err);\r\n        return;\r\n      }\r\n      resolve();\r\n    });\r\n  });\r\n};\r\n\r\nexport const getHashCollectionFilename = (\r\n  scriptContents: string,\r\n  contextName: string,\r\n  hashType: HashType\r\n) => {\r\n  const hash = crypto\r\n    .createHash(hashType)\r\n    .update(scriptContents + contextName + hashType)\r\n    .digest(\"hex\");\r\n\r\n  return path.join(cacheFolderName, `${hash}.hash`);\r\n};\r\n\r\nexport const createCacheFolder = () => {\r\n  if (!fs.existsSync(cacheFolderName)) {\r\n    fs.mkdirSync(cacheFolderName);\r\n  }\r\n};\r\n"]}

@@ -148,2 +148,1 @@ "use strict";

exports.OutputBuffer = OutputBuffer;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiT3V0cHV0QnVmZmVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2xpYi91dGlscy9PdXRwdXRCdWZmZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFDQSwrQkFBMEI7QUFDMUIseUNBQW9DO0FBQ3BDLHFDQUFrRDtBQWNsRDtJQUdFLHNCQUNtQixXQUFtQixFQUNuQixhQUF1QztRQUR2QyxnQkFBVyxHQUFYLFdBQVcsQ0FBUTtRQUNuQixrQkFBYSxHQUFiLGFBQWEsQ0FBMEI7UUFKbEQsWUFBTyxHQUF1QixFQUFFLENBQUM7SUFLdEMsQ0FBQztJQUVKLDRCQUFLLEdBQUwsVUFBTSxPQUF5QjtRQUM3QixJQUFJLE9BQU8sQ0FBQyxJQUFJLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRTtZQUMzQixJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztTQUM1QjtJQUNILENBQUM7SUFFRCxrQ0FBVyxHQUFYLFVBQVksSUFBWSxFQUFFLEdBQVc7UUFDbkMsSUFBSSxvQkFBVSxDQUFDLEdBQUcsQ0FBQyxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUU7WUFDOUIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUM7Z0JBQ2hCLElBQUksRUFBRSxJQUFJO2dCQUNWLElBQUksRUFBRSxNQUFNLENBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxNQUFNLENBQUM7YUFDL0IsQ0FBQyxDQUFDO1NBQ0o7SUFDSCxDQUFDO0lBRUssaUNBQVUsR0FBaEI7Ozs7Ozt3QkFDUSxVQUFVLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQzt3QkFFaEMsa0JBQWtCLEdBQUcsSUFBSSxDQUFDOzs7O3dCQUVkLEtBQUEsU0FBQSxJQUFJLENBQUMsT0FBTyxDQUFBOzs7O3dCQUFqQixDQUFDO3dCQUNKLElBQUksR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDO3dCQUNwQixJQUFJLElBQUksS0FBSyxRQUFRLEVBQUU7NEJBQ3JCLFFBQVEsR0FBRyxJQUFJLENBQUM7NEJBQ2hCLGtCQUFrQixHQUFHLElBQUksQ0FBQzt5QkFDM0I7d0JBRUssWUFBWSxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDO3dCQUNoRCxJQUFJLENBQUMsWUFBWSxFQUFFOzRCQUNqQix3QkFBUzt5QkFDVjt3QkFFTyxNQUFNLEdBQVksWUFBWSxPQUF4QixFQUFFLEtBQUssR0FBSyxZQUFZLE1BQWpCLENBQWtCO3dCQUVuQyxHQUFHLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDLENBQUM7d0JBRWxDLEdBQUcsR0FBRyxHQUFHLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FBQzt3QkFFekIsS0FBSyxHQUFHLEdBQUcsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUM7d0JBQ3hCLGFBQWEsR0FBYSxFQUFFLENBQUM7d0JBQ25DLEtBQVMsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsS0FBSyxDQUFDLE1BQU0sRUFBRSxDQUFDLEVBQUUsRUFBRTs0QkFDakMsSUFBSSxHQUFHLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQzs0QkFDcEIsSUFBSSxLQUFLLEVBQUU7Z0NBQ1QsSUFBSSxHQUFHLGVBQUssQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDOzZCQUN4Qzs0QkFDRCxJQUNFLENBQUMsQ0FBQyxLQUFLLEtBQUssQ0FBQyxNQUFNLEdBQUcsQ0FBQyxJQUFJLG9CQUFVLENBQUMsSUFBSSxDQUFDLENBQUMsTUFBTSxJQUFJLENBQUMsQ0FBQztnQ0FDeEQsQ0FBQyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsa0JBQWtCLENBQUMsRUFDaEM7Z0NBQ0EsYUFBYSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQzs2QkFDMUI7aUNBQU07Z0NBQ0wsYUFBYSxDQUFDLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDLENBQUM7NkJBQ3ZDO3lCQUNGO3dCQUVLLElBQUksR0FBRyxhQUFhLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO3dCQUN0QyxxQkFBTSwrQkFBcUIsQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLEVBQUE7O3dCQUF6QyxTQUF5QyxDQUFDO3dCQUVwQyxhQUFhLEdBQUcsb0JBQVUsQ0FBQyxJQUFJLENBQUMsQ0FBQzt3QkFDdkMsa0JBQWtCOzRCQUNoQixhQUFhLENBQUMsTUFBTSxHQUFHLENBQUMsSUFBSSxhQUFhLENBQUMsYUFBYSxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsS0FBSyxJQUFJLENBQUM7Ozs7Ozs7Ozs7Ozs7Ozs7O3dCQUdqRixJQUFJLENBQUMsT0FBTyxHQUFHLEVBQUUsQ0FBQzs7Ozs7S0FDbkI7SUFFRCw4QkFBTyxHQUFQO1FBQ0UsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUM7SUFDakMsQ0FBQztJQUNILG1CQUFDO0FBQUQsQ0FBQyxBQTdFRCxJQTZFQztBQTdFWSxvQ0FBWSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBTb2NrZXQgPSBOb2RlSlMuU29ja2V0O1xyXG5pbXBvcnQgY2hhbGsgZnJvbSBcImNoYWxrXCI7XHJcbmltcG9ydCBzdHJpcENvbG9yIGZyb20gXCJzdHJpcC1hbnNpXCI7XHJcbmltcG9ydCB7IHNvY2tldEZsdXNoV3JpdGVBc3luYyB9IGZyb20gXCIuL3NvY2tldHNcIjtcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgT3V0cHV0QnVmZmVyRGF0YSB7XHJcbiAgdHlwZTogc3RyaW5nO1xyXG4gIGRhdGE6IEJ1ZmZlcjtcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBPdXRwdXRCdWZmZXJTb2NrZXRDb25maWcge1xyXG4gIFtpZDogc3RyaW5nXToge1xyXG4gICAgc29ja2V0OiBTb2NrZXQ7XHJcbiAgICBjb2xvcj86IHN0cmluZztcclxuICB9O1xyXG59XHJcblxyXG5leHBvcnQgY2xhc3MgT3V0cHV0QnVmZmVyIHtcclxuICBwcml2YXRlIF9vdXRwdXQ6IE91dHB1dEJ1ZmZlckRhdGFbXSA9IFtdO1xyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByaXZhdGUgcmVhZG9ubHkgX2xpbmVQcmVmaXg6IHN0cmluZyxcclxuICAgIHByaXZhdGUgcmVhZG9ubHkgX3NvY2tldENvbmZpZzogT3V0cHV0QnVmZmVyU29ja2V0Q29uZmlnXHJcbiAgKSB7fVxyXG5cclxuICB3cml0ZShidWZEYXRhOiBPdXRwdXRCdWZmZXJEYXRhKSB7XHJcbiAgICBpZiAoYnVmRGF0YS5kYXRhLmxlbmd0aCA+IDApIHtcclxuICAgICAgdGhpcy5fb3V0cHV0LnB1c2goYnVmRGF0YSk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICB3cml0ZVN0cmluZyh0eXBlOiBzdHJpbmcsIHN0cjogc3RyaW5nKSB7XHJcbiAgICBpZiAoc3RyaXBDb2xvcihzdHIpLmxlbmd0aCA+IDApIHtcclxuICAgICAgdGhpcy5fb3V0cHV0LnB1c2goe1xyXG4gICAgICAgIHR5cGU6IHR5cGUsXHJcbiAgICAgICAgZGF0YTogQnVmZmVyLmZyb20oc3RyLCBcInV0ZjhcIilcclxuICAgICAgfSk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBhc3luYyBmbHVzaEFzeW5jKCkge1xyXG4gICAgY29uc3QgbGluZVByZWZpeCA9IHRoaXMuX2xpbmVQcmVmaXg7XHJcblxyXG4gICAgbGV0IGxhc3RFbmRlZEluTmV3TGluZSA9IHRydWU7XHJcbiAgICBsZXQgbGFzdFR5cGU7XHJcbiAgICBmb3IgKGNvbnN0IGIgb2YgdGhpcy5fb3V0cHV0KSB7XHJcbiAgICAgIGNvbnN0IHR5cGUgPSBiLnR5cGU7XHJcbiAgICAgIGlmICh0eXBlICE9PSBsYXN0VHlwZSkge1xyXG4gICAgICAgIGxhc3RUeXBlID0gdHlwZTtcclxuICAgICAgICBsYXN0RW5kZWRJbk5ld0xpbmUgPSB0cnVlO1xyXG4gICAgICB9XHJcblxyXG4gICAgICBjb25zdCBzb2NrZXRDb25maWcgPSB0aGlzLl9zb2NrZXRDb25maWdbYi50eXBlXTtcclxuICAgICAgaWYgKCFzb2NrZXRDb25maWcpIHtcclxuICAgICAgICBjb250aW51ZTtcclxuICAgICAgfVxyXG5cclxuICAgICAgY29uc3QgeyBzb2NrZXQsIGNvbG9yIH0gPSBzb2NrZXRDb25maWc7XHJcblxyXG4gICAgICBsZXQgc3RyID0gYi5kYXRhLnRvU3RyaW5nKFwidXRmOFwiKTtcclxuXHJcbiAgICAgIHN0ciA9IHN0ci5zcGxpdChcIlxcclwiKS5qb2luKFwiXCIpO1xyXG5cclxuICAgICAgY29uc3QgbGluZXMgPSBzdHIuc3BsaXQoXCJcXG5cIik7XHJcbiAgICAgIGNvbnN0IHByZWZpeGVkTGluZXM6IHN0cmluZ1tdID0gW107XHJcbiAgICAgIGZvciAobGV0IGkgPSAwOyBpIDwgbGluZXMubGVuZ3RoOyBpKyspIHtcclxuICAgICAgICBsZXQgbGluZSA9IGxpbmVzW2ldO1xyXG4gICAgICAgIGlmIChjb2xvcikge1xyXG4gICAgICAgICAgbGluZSA9IGNoYWxrLmJvbGQua2V5d29yZChjb2xvcikobGluZSk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGlmIChcclxuICAgICAgICAgIChpID09PSBsaW5lcy5sZW5ndGggLSAxICYmIHN0cmlwQ29sb3IobGluZSkubGVuZ3RoIDw9IDApIHx8XHJcbiAgICAgICAgICAoaSA9PT0gMCAmJiAhbGFzdEVuZGVkSW5OZXdMaW5lKVxyXG4gICAgICAgICkge1xyXG4gICAgICAgICAgcHJlZml4ZWRMaW5lcy5wdXNoKGxpbmUpO1xyXG4gICAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgICBwcmVmaXhlZExpbmVzLnB1c2gobGluZVByZWZpeCArIGxpbmUpO1xyXG4gICAgICAgIH1cclxuICAgICAgfVxyXG5cclxuICAgICAgY29uc3QgdGV4dCA9IHByZWZpeGVkTGluZXMuam9pbihcIlxcblwiKTtcclxuICAgICAgYXdhaXQgc29ja2V0Rmx1c2hXcml0ZUFzeW5jKHNvY2tldCwgdGV4dCk7XHJcblxyXG4gICAgICBjb25zdCB1bmNvbG9yZWRUZXh0ID0gc3RyaXBDb2xvcih0ZXh0KTtcclxuICAgICAgbGFzdEVuZGVkSW5OZXdMaW5lID1cclxuICAgICAgICB1bmNvbG9yZWRUZXh0Lmxlbmd0aCA+IDAgJiYgdW5jb2xvcmVkVGV4dFt1bmNvbG9yZWRUZXh0Lmxlbmd0aCAtIDFdID09PSBcIlxcblwiO1xyXG4gICAgfVxyXG5cclxuICAgIHRoaXMuX291dHB1dCA9IFtdO1xyXG4gIH1cclxuXHJcbiAgaGFzRGF0YSgpIHtcclxuICAgIHJldHVybiB0aGlzLl9vdXRwdXQubGVuZ3RoID4gMDtcclxuICB9XHJcbn1cclxuIl19

@@ -39,2 +39,1 @@ "use strict";

};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvbWlzZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvdXRpbHMvcHJvbWlzZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFhLFFBQUEsdUJBQXVCLEdBQUcsVUFDckMsV0FBbUI7SUFFbkIsSUFBSSxXQUFXLEdBQUcsQ0FBQyxFQUFFO1FBQ25CLE1BQU0sSUFBSSxLQUFLLENBQUMsNEJBQTRCLENBQUMsQ0FBQztLQUMvQztJQUVELElBQU0sS0FBSyxHQUFtQixFQUFFLENBQUM7SUFDakMsSUFBSSxXQUFXLEdBQUcsQ0FBQyxDQUFDO0lBRXBCLElBQU0sSUFBSSxHQUFHO1FBQ1gsV0FBVyxFQUFFLENBQUM7UUFFZCxJQUFJLEtBQUssQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFO1lBQ3BCLElBQU0sTUFBTSxHQUFHLEtBQUssQ0FBQyxLQUFLLEVBQUUsQ0FBQztZQUM3QixJQUFJLE1BQU0sS0FBSyxTQUFTLEVBQUU7Z0JBQ3hCLE1BQU0sRUFBRSxDQUFDO2FBQ1Y7U0FDRjtJQUNILENBQUMsQ0FBQztJQUVGLE9BQU8sVUFBQyxjQUFjO1FBQ3BCLE9BQUEsSUFBSSxPQUFPLENBQUksVUFBQyxPQUFPLEVBQUUsTUFBTTtZQUM3QixJQUFNLEdBQUcsR0FBRztnQkFDVixXQUFXLEVBQUUsQ0FBQztnQkFFZCxjQUFjLEVBQUUsQ0FBQyxJQUFJLENBQ25CLFVBQUMsR0FBUTtvQkFDUCxPQUFPLENBQUMsR0FBRyxDQUFDLENBQUM7b0JBQ2IsSUFBSSxFQUFFLENBQUM7Z0JBQ1QsQ0FBQyxFQUNELFVBQUMsR0FBUTtvQkFDUCxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUM7b0JBQ1osSUFBSSxFQUFFLENBQUM7Z0JBQ1QsQ0FBQyxDQUNGLENBQUM7WUFDSixDQUFDLENBQUM7WUFFRixJQUFJLFdBQVcsR0FBRyxXQUFXLEVBQUU7Z0JBQzdCLEdBQUcsRUFBRSxDQUFDO2FBQ1A7aUJBQU07Z0JBQ0wsS0FBSyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQzthQUNqQjtRQUNILENBQUMsQ0FBQztJQXJCRixDQXFCRSxDQUFDO0FBQ1AsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IGxpbWl0UHJvbWlzZUNvbmN1cnJlbmN5ID0gPFQ+KFxyXG4gIGNvbmN1cnJlbmN5OiBudW1iZXJcclxuKTogKChmbjogKCkgPT4gUHJvbWlzZUxpa2U8VD4pID0+IFByb21pc2U8VD4pID0+IHtcclxuICBpZiAoY29uY3VycmVuY3kgPCAxKSB7XHJcbiAgICB0aHJvdyBuZXcgRXJyb3IoYCdjb25jdXJyZW5jeScgbXVzdCBiZSA+PSAxYCk7XHJcbiAgfVxyXG5cclxuICBjb25zdCBxdWV1ZTogKCgpID0+IHZvaWQpW10gPSBbXTtcclxuICBsZXQgYWN0aXZlQ291bnQgPSAwO1xyXG5cclxuICBjb25zdCBuZXh0ID0gKCkgPT4ge1xyXG4gICAgYWN0aXZlQ291bnQtLTtcclxuXHJcbiAgICBpZiAocXVldWUubGVuZ3RoID4gMCkge1xyXG4gICAgICBjb25zdCBuZXdSdW4gPSBxdWV1ZS5zaGlmdCgpO1xyXG4gICAgICBpZiAobmV3UnVuICE9PSB1bmRlZmluZWQpIHtcclxuICAgICAgICBuZXdSdW4oKTtcclxuICAgICAgfVxyXG4gICAgfVxyXG4gIH07XHJcblxyXG4gIHJldHVybiAod3JhcHBlZFByb21pc2UpID0+XHJcbiAgICBuZXcgUHJvbWlzZTxUPigocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XHJcbiAgICAgIGNvbnN0IHJ1biA9ICgpID0+IHtcclxuICAgICAgICBhY3RpdmVDb3VudCsrO1xyXG5cclxuICAgICAgICB3cmFwcGVkUHJvbWlzZSgpLnRoZW4oXHJcbiAgICAgICAgICAodmFsOiBhbnkpID0+IHtcclxuICAgICAgICAgICAgcmVzb2x2ZSh2YWwpO1xyXG4gICAgICAgICAgICBuZXh0KCk7XHJcbiAgICAgICAgICB9LFxyXG4gICAgICAgICAgKGVycjogYW55KSA9PiB7XHJcbiAgICAgICAgICAgIHJlamVjdChlcnIpO1xyXG4gICAgICAgICAgICBuZXh0KCk7XHJcbiAgICAgICAgICB9XHJcbiAgICAgICAgKTtcclxuICAgICAgfTtcclxuXHJcbiAgICAgIGlmIChhY3RpdmVDb3VudCA8IGNvbmN1cnJlbmN5KSB7XHJcbiAgICAgICAgcnVuKCk7XHJcbiAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgcXVldWUucHVzaChydW4pO1xyXG4gICAgICB9XHJcbiAgICB9KTtcclxufTtcclxuIl19

@@ -51,2 +51,1 @@ "use strict";

exports.escapeShell = escapeShell;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2hlbGxlc2NhcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL3V0aWxzL3NoZWxsZXNjYXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBRUEsU0FBUyxjQUFjLENBQUMsSUFBWTtJQUNsQyxJQUFJLENBQUMsb0JBQW9CLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFO1FBQ3BDLE9BQU8sQ0FBQyxHQUFHLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsU0FBUyxDQUFDLEdBQUcsR0FBRyxDQUFDLENBQUMsT0FBTyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztLQUN2RTtTQUFNO1FBQ0wsT0FBTyxJQUFJLENBQUM7S0FDYjtBQUNILENBQUM7QUFFRCxTQUFTLGVBQWUsQ0FBQyxJQUFZO0lBQ25DLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEVBQUU7UUFDcEMsT0FBTyxHQUFHLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUFDLEdBQUcsR0FBRyxDQUFDO0tBQzdDO1NBQU07UUFDTCxPQUFPLElBQUksQ0FBQztLQUNiO0FBQ0gsQ0FBQztBQUVZLFFBQUEsT0FBTyxHQUFHLFVBQUMsS0FBZ0IsRUFBRSxJQUFZO0lBQ3BELElBQU0sTUFBTSxHQUFHLEtBQUssS0FBSyxJQUFJLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDO0lBQzNDLElBQU0sTUFBTSxHQUFHLEtBQUssS0FBSyxJQUFJLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDO0lBRTNDLElBQU0sWUFBWSxHQUFHLElBQUksQ0FBQztJQUMxQixJQUFJLEdBQUcsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ25CLElBQUksR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUN2QyxJQUFJLE9BQU8sQ0FBQyxRQUFRLEtBQUssT0FBTyxJQUFJLEtBQUssS0FBSyxJQUFJLEVBQUU7UUFDbEQsc0JBQXNCO1FBQ3RCLElBQUksSUFBSSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsRUFBRTtZQUN0QixJQUFJLElBQUksQ0FBQyxNQUFNLEdBQUcsQ0FBQyxJQUFJLElBQUksQ0FBQyxDQUFDLENBQUMsS0FBSyxHQUFHLElBQUksSUFBSSxDQUFDLENBQUMsQ0FBQyxLQUFLLEdBQUcsRUFBRTtnQkFDekQsTUFBTSxJQUFJLEtBQUssQ0FBQyxNQUFJLFlBQVksNkJBQTBCLENBQUMsQ0FBQzthQUM3RDtZQUVELHdCQUF3QjtZQUN4QixJQUFJLEdBQUcsTUFBSSxJQUFJLENBQUMsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUcsQ0FBQztTQUN2QztLQUNGO0lBRUQsT0FBTyxJQUFJLENBQUM7QUFDZCxDQUFDLENBQUM7QUFFRixTQUFnQixXQUFXLENBQUMsS0FBZ0IsRUFBRSxhQUFnQztJQUM1RSxJQUFNLE1BQU0sR0FBRyxLQUFLLEtBQUssS0FBSyxDQUFDLENBQUMsQ0FBQyxlQUFlLENBQUMsQ0FBQyxDQUFDLGNBQWMsQ0FBQztJQUVsRSxJQUFNLEdBQUcsR0FBYSxFQUFFLENBQUM7SUFFekIsSUFBSSxPQUFPLGFBQWEsS0FBSyxRQUFRLEVBQUU7UUFDckMsT0FBTyxNQUFNLENBQUMsYUFBYSxDQUFDLENBQUM7S0FDOUI7U0FBTTtRQUNMLGFBQWEsQ0FBQyxPQUFPLENBQUMsVUFBQyxNQUFNO1lBQzNCLEdBQUcsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUM7UUFDM0IsQ0FBQyxDQUFDLENBQUM7UUFDSCxPQUFPLEdBQUcsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7S0FDdEI7QUFDSCxDQUFDO0FBYkQsa0NBYUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgdHlwZSBTaGVsbFR5cGUgPSBcInNoXCIgfCBcImNtZFwiO1xyXG5cclxuZnVuY3Rpb24gX2VzY2FwZVNoZWxsU2gocGF0aDogc3RyaW5nKSB7XHJcbiAgaWYgKCEvXltBLVphLXowLTlfXFwvLV0rJC8udGVzdChwYXRoKSkge1xyXG4gICAgcmV0dXJuIChcIidcIiArIHBhdGgucmVwbGFjZSgvJy9nLCBcIidcXFwiJ1xcXCInXCIpICsgXCInXCIpLnJlcGxhY2UoLycnL2csIFwiXCIpO1xyXG4gIH0gZWxzZSB7XHJcbiAgICByZXR1cm4gcGF0aDtcclxuICB9XHJcbn1cclxuXHJcbmZ1bmN0aW9uIF9lc2NhcGVTaGVsbENtZChwYXRoOiBzdHJpbmcpIHtcclxuICBpZiAoIS9eW0EtWmEtejAtOV9cXC8tXSskLy50ZXN0KHBhdGgpKSB7XHJcbiAgICByZXR1cm4gJ1wiJyArIHBhdGgucmVwbGFjZSgvXCIvZywgJ1wiXCInKSArICdcIic7XHJcbiAgfSBlbHNlIHtcclxuICAgIHJldHVybiBwYXRoO1xyXG4gIH1cclxufVxyXG5cclxuZXhwb3J0IGNvbnN0IGZpeFBhdGggPSAoc2hlbGw6IFNoZWxsVHlwZSwgcGF0aDogc3RyaW5nKSA9PiB7XHJcbiAgY29uc3Qgb2xkU2VwID0gc2hlbGwgPT09IFwic2hcIiA/IFwiXFxcXFwiIDogXCIvXCI7XHJcbiAgY29uc3QgbmV3U2VwID0gc2hlbGwgPT09IFwic2hcIiA/IFwiL1wiIDogXCJcXFxcXCI7XHJcblxyXG4gIGNvbnN0IG9yaWdpbmFsUGF0aCA9IHBhdGg7XHJcbiAgcGF0aCA9IHBhdGgudHJpbSgpO1xyXG4gIHBhdGggPSBwYXRoLnNwbGl0KG9sZFNlcCkuam9pbihuZXdTZXApO1xyXG4gIGlmIChwcm9jZXNzLnBsYXRmb3JtID09PSBcIndpbjMyXCIgJiYgc2hlbGwgPT09IFwic2hcIikge1xyXG4gICAgLy8gbW9zdCBwcm9iYWJseSBtaW5nd1xyXG4gICAgaWYgKHBhdGguaW5jbHVkZXMoXCI6XCIpKSB7XHJcbiAgICAgIGlmIChwYXRoLmxlbmd0aCA8IDIgfHwgcGF0aFsxXSAhPT0gXCI6XCIgfHwgcGF0aFsyXSAhPT0gXCIvXCIpIHtcclxuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYCcke29yaWdpbmFsUGF0aH0nIC0gcGF0aCBjYW5ub3QgYmUgZml4ZWRgKTtcclxuICAgICAgfVxyXG5cclxuICAgICAgLy8gZnJvbSBDOlxcLi4uIHRvIC9DLy4uLlxyXG4gICAgICBwYXRoID0gYC8ke3BhdGhbMF19JHtwYXRoLnN1YnN0cigyKX1gO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgcmV0dXJuIHBhdGg7XHJcbn07XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gZXNjYXBlU2hlbGwoc2hlbGw6IFNoZWxsVHlwZSwgc3RyaW5nT3JBcnJheTogc3RyaW5nIHwgc3RyaW5nW10pIHtcclxuICBjb25zdCBlc2NhcGUgPSBzaGVsbCA9PT0gXCJjbWRcIiA/IF9lc2NhcGVTaGVsbENtZCA6IF9lc2NhcGVTaGVsbFNoO1xyXG5cclxuICBjb25zdCByZXQ6IHN0cmluZ1tdID0gW107XHJcblxyXG4gIGlmICh0eXBlb2Ygc3RyaW5nT3JBcnJheSA9PT0gXCJzdHJpbmdcIikge1xyXG4gICAgcmV0dXJuIGVzY2FwZShzdHJpbmdPckFycmF5KTtcclxuICB9IGVsc2Uge1xyXG4gICAgc3RyaW5nT3JBcnJheS5mb3JFYWNoKChtZW1iZXIpID0+IHtcclxuICAgICAgcmV0LnB1c2goZXNjYXBlKG1lbWJlcikpO1xyXG4gICAgfSk7XHJcbiAgICByZXR1cm4gcmV0LmpvaW4oXCIgXCIpO1xyXG4gIH1cclxufVxyXG4iXX0=

@@ -57,2 +57,1 @@ "use strict";

}); };
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic29ja2V0cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvdXRpbHMvc29ja2V0cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxpQkFZQTs7QUFWYSxRQUFBLHFCQUFxQixHQUFHLFVBQU8sTUFBYyxFQUFFLEdBQVc7OztvQkFDckUscUJBQU0sSUFBSSxPQUFPLENBQUMsVUFBQyxPQUFPO29CQUN4QixJQUFNLE9BQU8sR0FBRyxNQUFNLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO29CQUNsQyxJQUFJLE9BQU8sRUFBRTt3QkFDWCxPQUFPLEVBQUUsQ0FBQztxQkFDWDt5QkFBTTt3QkFDTCxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxPQUFPLENBQUMsQ0FBQztxQkFDL0I7Z0JBQ0gsQ0FBQyxDQUFDLEVBQUE7O2dCQVBGLFNBT0UsQ0FBQzs7OztLQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgU29ja2V0ID0gTm9kZUpTLlNvY2tldDtcclxuXHJcbmV4cG9ydCBjb25zdCBzb2NrZXRGbHVzaFdyaXRlQXN5bmMgPSBhc3luYyAoc29ja2V0OiBTb2NrZXQsIHN0cjogc3RyaW5nKSA9PiB7XHJcbiAgYXdhaXQgbmV3IFByb21pc2UoKHJlc29sdmUpID0+IHtcclxuICAgIGNvbnN0IGZsdXNoZWQgPSBzb2NrZXQud3JpdGUoc3RyKTtcclxuICAgIGlmIChmbHVzaGVkKSB7XHJcbiAgICAgIHJlc29sdmUoKTtcclxuICAgIH0gZWxzZSB7XHJcbiAgICAgIHNvY2tldC5vbmNlKFwiZHJhaW5cIiwgcmVzb2x2ZSk7XHJcbiAgICB9XHJcbiAgfSk7XHJcbn07XHJcbiJdfQ==

@@ -17,2 +17,1 @@ "use strict";

exports.TextWriter = TextWriter;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVGV4dFdyaXRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvdXRpbHMvVGV4dFdyaXRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBO0lBQUE7UUFDRSxXQUFNLEdBQVcsRUFBRSxDQUFDO0lBVXRCLENBQUM7SUFSQywwQkFBSyxHQUFMLFVBQU0sR0FBWTtRQUNoQixJQUFJLENBQUMsTUFBTSxJQUFJLEdBQUcsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7SUFDaEMsQ0FBQztJQUVELDhCQUFTLEdBQVQsVUFBVSxHQUFZO1FBQ3BCLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDaEIsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNuQixDQUFDO0lBQ0gsaUJBQUM7QUFBRCxDQUFDLEFBWEQsSUFXQztBQVhZLGdDQUFVIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNsYXNzIFRleHRXcml0ZXIge1xyXG4gIG91dHB1dDogc3RyaW5nID0gXCJcIjtcclxuXHJcbiAgd3JpdGUoc3RyPzogc3RyaW5nKSB7XHJcbiAgICB0aGlzLm91dHB1dCArPSBzdHIgPyBzdHIgOiBcIlwiO1xyXG4gIH1cclxuXHJcbiAgd3JpdGVMaW5lKHN0cj86IHN0cmluZykge1xyXG4gICAgdGhpcy53cml0ZShzdHIpO1xyXG4gICAgdGhpcy53cml0ZShcIlxcblwiKTtcclxuICB9XHJcbn1cclxuIl19

@@ -41,2 +41,1 @@ "use strict";

};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZUNoZWNraW5nLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2xpYi91dGlscy90eXBlQ2hlY2tpbmcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQWEsUUFBQSxRQUFRLEdBQUcsVUFBQyxHQUFRO0lBQy9CLE9BQU8sR0FBRyxLQUFLLElBQUksSUFBSSxPQUFPLEdBQUcsS0FBSyxRQUFRLENBQUM7QUFDakQsQ0FBQyxDQUFDO0FBRVcsUUFBQSxVQUFVLEdBQUcsVUFBQyxJQUFTO0lBQ2xDLE9BQU8sT0FBTyxJQUFJLEtBQUssVUFBVSxDQUFDO0FBQ3BDLENBQUMsQ0FBQztBQUVXLFFBQUEsYUFBYSxHQUFHLFVBQUMsR0FBUTs7SUFDcEMsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLEVBQUU7UUFDdkIsT0FBTyxLQUFLLENBQUM7S0FDZDs7UUFDRCxLQUFnQixJQUFBLFFBQUEsU0FBQSxHQUFHLENBQUEsd0JBQUEseUNBQUU7WUFBaEIsSUFBTSxDQUFDLGdCQUFBO1lBQ1YsSUFBSSxPQUFPLENBQUMsS0FBSyxRQUFRLEVBQUU7Z0JBQ3pCLE9BQU8sS0FBSyxDQUFDO2FBQ2Q7U0FDRjs7Ozs7Ozs7O0lBQ0QsT0FBTyxJQUFJLENBQUM7QUFDZCxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgaXNPYmplY3QgPSAob2JqOiBhbnkpID0+IHtcclxuICByZXR1cm4gb2JqICE9PSBudWxsICYmIHR5cGVvZiBvYmogPT09IFwib2JqZWN0XCI7XHJcbn07XHJcblxyXG5leHBvcnQgY29uc3QgaXNGdW5jdGlvbiA9IChmdW5jOiBhbnkpID0+IHtcclxuICByZXR1cm4gdHlwZW9mIGZ1bmMgPT09IFwiZnVuY3Rpb25cIjtcclxufTtcclxuXHJcbmV4cG9ydCBjb25zdCBpc1N0cmluZ0FycmF5ID0gKGFycjogYW55KSA9PiB7XHJcbiAgaWYgKCFBcnJheS5pc0FycmF5KGFycikpIHtcclxuICAgIHJldHVybiBmYWxzZTtcclxuICB9XHJcbiAgZm9yIChjb25zdCBlIG9mIGFycikge1xyXG4gICAgaWYgKHR5cGVvZiBlICE9PSBcInN0cmluZ1wiKSB7XHJcbiAgICAgIHJldHVybiBmYWxzZTtcclxuICAgIH1cclxuICB9XHJcbiAgcmV0dXJuIHRydWU7XHJcbn07XHJcbiJdfQ==
{
"name": "makfy",
"version": "1.4.2",
"version": "2.0.0",
"description": "makfy - npm scripts on steroids!",

@@ -11,5 +11,4 @@ "main": "dist/lib/index.js",

"scripts": {
"build": "tsc -p .",
"clean": "rimraf ./dist",
"prepublishOnly": "yarn clean && yarn build"
"build": "rimraf ./dist && tsc -p .",
"prepublishOnly": "yarn build"
},

@@ -16,0 +15,0 @@ "files": [

@@ -8,5 +8,10 @@ <p align="center">

Install it globally `npm install -g makfy`
or locally `npm install --save-dev makfy`
Install it globally
`npm install -g makfy` / `yarn add global makfy`
or locally
`npm install --save-dev makfy` / `yarn add --dev makfy`
**To support this project star it on [github](https://github.com/xaviergonz/makfy)!**

@@ -59,44 +64,17 @@

js
```js
module.exports = {
commands: {
clean: {
run: async (exec) => {
await exec(
// running sequentially
"rimraf ./dist-a",
"rimraf ./dist-b",
// and these run after the other ones too, but in parallel!
["rimraf ./dist-c", "rimraf ./dist-d"]
);
}
})
}
};
```
ts
```ts
import { command, makfyConfig } from "makfy";
import { cmd } from "makfy";
// or
const { cmd } = require("makfy");
// note how in TS makfyConfig and command are used to get better typing validation
// these can also be used in js, but it is not necessary
export default makfyConfig({
commands: {
clean: command({
run: async (exec) => {
await exec(
// running sequentially
"rimraf ./dist-a",
"rimraf ./dist-b",
// and these run after the other ones too, but in parallel!
["rimraf ./dist-c", "rimraf ./dist-d"]
);
}
})
}
});
cmd("clean")
.run(async (exec) => {
await exec(
// running sequentially
"rimraf ./dist-a",
"rimraf ./dist-b",
// and these run after the other ones too, but in parallel!
["rimraf ./dist-c", "rimraf ./dist-d"]
);
});
```

@@ -106,19 +84,20 @@

js
```ts
import { cmd, flag } from "makfy";
// or
const { cmd } = require("makfy");
```js
module.exports = {
commands: {
clean: {
desc: "clean the project",
args: {
prod: { type: "flag", desc: "production clean" },
dev: { type: "flag", desc: "dev clean" }
},
run: async (exec, args) => {
await exec(args.prod ? "rimraf ./dist-prod" : null, args.dev ? "rimraf ./dist-dev" : null);
}
}
}
};
cmd("clean")
.desc("clean the project")
.args({
prod: flag(),
dev: flag()
})
.argsDesc({
prod: "production clean",
dev: "dev clean"
})
.run(async (exec, {prod, desc}) => {
await exec(prod ? "rimraf ./dist-prod" : null, dev ? "rimraf ./dist-dev" : null);
});
```

@@ -140,21 +119,25 @@

js
```ts
import { cmd } from "makfy";
// or
const { cmd } = require("makfy");
```js
module.exports = {
commands: {
build: {
run: async(exec) => {
await exec(
'@clean',
{ _: 'clean' }, // same as above
... // whatever commands go next
);
}
}
clean: {
...
}
}
};
cmd("build")
.run(async (exec) => {
await exec(
"@clean",
{ _: "clean" }, // same as above
... // whatever commands go next
);
});
// shorter version
cmd("build")
.run(
"@clean",
{ _: 'clean' }, // same as above
... // whatever commands go next
);
cmd("clean")...
```

@@ -164,21 +147,25 @@

js
```ts
import { cmd } from "makfy";
// or
const { cmd } = require("makfy");
```js
module.exports = {
commands: {
build: {
run: async(exec) => {
await exec(
'@clean --dev --prod',
{ _: 'clean', args: { dev: true, prod: true }}, // same as above
... // whatever commands go next
);
}
}
clean: {
...
}
}
};
cmd("build")
.run(async (exec) => {
await exec(
"@clean --dev --prod",
{ _: "clean", args: { dev: true, prod: true }}, // same as above
... // whatever commands go next
);
});
// shorter version
cmd("build")
.run(
"@clean --dev --prod",
{ _: "clean", args: { dev: true, prod: true }}, // same as above
... // whatever commands go next
);
cmd("clean")...
```

@@ -189,67 +176,69 @@

js
```ts
import { cmd, getFileChanges } from "makfy";
// or
const { cmd, getFileChanges } = require("makfy");
```js
module.exports = {
commands: {
compile: {
run: async (exec, args, utils) => {
const delta = await utils.getFileChanges("typescript", ["./src/**/*.ts", "./src/**/*.tsx"]);
cmd("compile")
.run(async (exec) => {
const delta = await getFileChanges("typescript", ["./src/**/*.ts", "./src/**/*.tsx"]);
if (delta.hasChanges) {
await exec(
// here you would remove all target files generated by this step
// then compile new target files
"tsc -p ."
// additionally you could even only run the compiler over delta.added + delta.modified files
);
}
}
if (delta.hasChanges) {
await exec(
// here you would remove all target files generated by this step
// then compile new target files
"tsc -p ."
// additionally you could even only run the compiler over delta.added + delta.modified files
);
}
}
};
});
```
## Documentation
### `cmd` short syntax
The basic structure of a `makfyfile.(js|ts)` is as follows:
If your command doesn't need any to access any arguments then you can use the `cmd("commandName").run(...commands)` function to make it shorter to write:
js
```ts
import { cmd } from "makfy";
// or
const { cmd } = require("makfy");
```js
module.exports = {
commands: {
[commandName]: {
run: async(exec, args, utils) => Promise<void>,
desc?: string,
args?: {
[argName]: ArgDefinition
},
internal?: boolean
} | run(...commandsToRun)
},
dependencies?: string[],
options?: Options
};
cmd("clean")
.desc("cleans stuff")
.run(
// running sequentially
"rimraf ./dist-a",
"rimraf ./dist-b",
// and these run after the other ones too, but in parallel!
["rimraf ./dist-c", "rimraf ./dist-d"]
);
```
ts
## Documentation
The basic structure of a `makfyfile.(js|ts)` is as follows:
```ts
import { command, makfyConfig } from "makfy";
import { cmd, setDependencies, setOptions, flag, choice, str } from "makfy";
// or
const { cmd, setDepenencies, setOptions, flag, choice, str } = require("makfy");
export default makfyConfig({
commands: commands({
[commandName]: command({
run: async(exec, args, utils) => Promise<void>,
desc?: string,
args?: {
[argName]: ArgDefinition
},
internal?: boolean
}) | run(...commandsToRun)
}),
dependencies?: string[],
options?: Options
});
cmd("commandName")
.desc?("command description")
.args?({
[argName]:
| flag()
| choice(["option1", "option2", "default"?])
| str("default"?)
})
.argsDesc?({
[argName]: "arg description"
})
// one of these two
.run(async (exec, args) => {...})
.run("cmd1", "cmd2", ...)
// optionally...
setDependencies(string[] | undefined);
setOptions(Options);
```

@@ -259,11 +248,11 @@

### `commands: { [commandName]: Command }`
#### `cmd(commandName)`
`commands` is an object with alphanumeric keys, which are the command names.
Adds a command to the list of possible commands. If `commandName` starts with `_` then it will be
considered an internal command that cannot be invoked/listed using the CLI, yet can be run by other
commands.
#### `Command: { run, desc?, args? }`
- **`.run(async (exec, args) => Promise<void>)`**
- **`run: async(exec, args, utils) => Promise<void>`**
> An async function that takes three arguments, `exec`, `args` and `utils`.
> An async function that takes three arguments, `exec` and `args`.
>

@@ -315,12 +304,13 @@ > - **`exec: async(...commands: ExecCommand[]) => Promise<void>`**

> > An object where each property is the argument value as coming from the command line or exec sub-command invocation.
>
> - **`utils: object`**
> > An object with nifty utility methods. See the end of the docs for more info.
- **`desc?: string`**
- **`.run(...commands: ExecCommand[])`**
> An optional property that defines what the command does so it is shown when using `makfy --list`.
> Short syntax to run an argument-less command.
- **`args?: { [argName]: ArgDefinition }`**
- **`.desc?(string)`**
> An optional description that defines what the command does so it is shown when using `makfy --list`.
- **`.args?({ [argName]: ArgDefinition })`**
> An optional object of argument definitions that can be passed to that command using `makfy commandName ...args` and that will be automatically validated.

@@ -330,22 +320,21 @@ >

>
> - **Flag option - `{ type: 'flag' | 'f' }`**
> - **Flag option - `flag()`**
>
> > An optional flag, false by default unless you use `--argName`
>
> - **String option - `{ type: 'string' | 's', byDefault?: string }`**
> - **String option - `str(byDefault?: string)`**
>
> > A string option, required if no `byDefault` is given (`--argName=string`, use quotes if it has to have spaces)
>
> - **Enum option - `{ type: 'enum' | 'e', values: string[], byDefault?: string }`**
> - **Choice (AKA enum) option - `choice(values: string[], byDefault?: string })`**
>
> > An enum option where only `values` are valid, required if no `byDefault` is given (`--argName=string`)
>
> All of them accept a `desc?: string` property in case you want to add a given help string to them.
> > An choice (enum) option where only `values` are valid, required if no `byDefault` is given (`--argName=string`)
- **`internal?: boolean`**
> An optional boolean that indicates that it is an internal command, that is, it should not be shown when listing and cannot be invoked directly from the command line (default: `false`).
- **`.argsDesc?({ [argName]: string })`**
### `dependencies?: string[]`
> An optional object of argument descriptions that will be shown as help when using `makfy --list`.
`dependencies` is only ever needed if you use the `getFilesChangedAsync()` utility method, since it is
### `setDependencies(string[] | undefined)`
`setDependencies` is only ever needed if you use the `getFilesChangedAsync()` utility method, since it is
used to determine when it a clean run is triggered.

@@ -355,5 +344,5 @@ As a rule of thumb, if you do a local require such as `require('./foo/bar')` in your

### `options?: {profile?, showTime?}`
### `setOptions({profile?, showTime?})`
`options` is an optional object that can be exported to set the default of some options:
`setOptions` takes an optional object that can be exported to set the default of some options:

@@ -368,43 +357,10 @@ - `profile: boolean`

### Short syntax
### Utility methods (imported from makfy package)
If your command doesn't need any arguments or any description then you can use the `run` function to make it shorter to write:
- `escape(...parts: string[]): string`
js
```js
const { run } = require('makfy');
...
clean: run(
// running sequentially
"rimraf ./dist-a",
"rimraf ./dist-b",
// and these run after the other ones too, but in parallel!
["rimraf ./dist-c", "rimraf ./dist-d"]
)
```
ts
```ts
import { run } from 'makfy';
...
// note how command() is not needed when using run
clean: run(
// running sequentially
"rimraf ./dist-a",
"rimraf ./dist-b",
// and these run after the other ones too, but in parallel!
["rimraf ./dist-c", "rimraf ./dist-d"]
)
```
### Utility methods (provided by `utils`)
- `escape: (...parts: string[]) => string`
> Escapes all parts of a given shell command.
> For example, `escape('hello', 'to this world')` will return `hello "to this world"` under a cmd shell and `hello 'to this world'` under other shells .
- `fixPath: (path: string, style: 'autodetect' | 'windows' | 'posix') => string`
- `fixPath(path: string, style: 'autodetect' | 'windows' | 'posix'): string`

@@ -414,3 +370,3 @@ > Fixes a path so it is valid under a given OS, by swapping `/` and `\` if needed, plus converting `c:\...` to `/c/...` in mingw in windows.

- `setEnvVar: (name: string, value: string | undefined) => string`
- `setEnvVar(name: string, value: string | undefined): string`

@@ -420,3 +376,3 @@ > Returns a command string that can be used inside `exec` to set/clear an environment variable.

- `expandGlobsAsync: async (globPatterns: string[]) => Promise<string[]>`
- `async expandGlobsAsync(globPatterns: string[]): Promise<string[]>`

@@ -426,3 +382,3 @@ > Expand one or more glob patterns into and array of single files. Note that if the glob pattern starts with `'!!'` then matched files will be removed from previous glob pattern results rather than added.

- `getFileChangesAsync: async (contextName: string, globPatterns: string[] | string, options: { log = true }) => Promise<GetFileChangesResult>`
- `async getFileChangesAsync(contextName: string, globPatterns: string[] | string, options: { log = true }): Promise<GetFileChangesResult>`

@@ -454,3 +410,3 @@ > Returns an object which includes the changes to the given files (given a certain context) since the last successful run.

- `cleanCache: () => void`
- `cleanCache(): void`

@@ -489,3 +445,3 @@ > Cleans the `.makfy-cache` folder. Use it if you want to make sure all next calls to `getFileChangesAsync` work as if it was a clean run.

- _Set/unset an environment variable:_ Just invoke `utils.setEnvVar` inside an `exec` call. Alternatively use [cross-env](https://www.npmjs.com/package/cross-env).
- _Set/unset an environment variable:_ Just invoke `setEnvVar` inside an `exec` call. Alternatively use [cross-env](https://www.npmjs.com/package/cross-env).
- _Delete files/directories:_ [rimraf](https://www.npmjs.com/package/rimraf)

@@ -506,2 +462,2 @@ - _Copy files/directories:_ [ncp](https://www.npmjs.com/package/ncp)

**Note:** In unix style shells you need to export the variable for it to be tracked (e.g. `export NODE_ENV=production`). Consider using `utils.setEnvVar`, which does this for you.
**Note:** In unix style shells you need to export the variable for it to be tracked (e.g. `export NODE_ENV=production`). Consider using `setEnvVar`, which does this for you.

Sorry, the diff of this file is too big to display

SocketSocket SOC 2 Logo

Product

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

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc