@dashkite/tempo
Version:
Mono/polyrepo project management
49 lines (48 loc) • 23 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
const _nodefs = /*#__PURE__*/ _interop_require_default(require("node:fs"));
const _nodepath = /*#__PURE__*/ _interop_require_default(require("node:path"));
const _commander = require("commander");
const _metarepo = /*#__PURE__*/ _interop_require_default(require("./metarepo"));
const _command = /*#__PURE__*/ _interop_require_default(require("./command"));
function _interop_require_default(obj) {
return obj && obj.__esModule ? obj : {
default: obj
};
}
var Tags, command, i, len, ref;
Tags = {
parse: function(tags) {
return tags.split("+");
}
};
// TODO get version from package.json
_commander.program.version(function({ path, json, pkg }) {
path = _nodepath.default.join(__dirname, "..", "..", "..", "package.json");
json = _nodefs.default.readFileSync(path, "utf8");
pkg = JSON.parse(json);
return pkg.version;
}({})).enablePositionalOptions();
_commander.program.command("add").description("add a project to a metarepo").alias("a").argument("<repo>", "The relative path of the repo").action(_command.default.wrap(_metarepo.default.add));
_commander.program.command("remove").description("remove a project from a metarepo").aliases([
"rm",
"del",
"delete"
]).argument("<repo>", "The relative path of the repo").action(_command.default.wrap(_metarepo.default.remove));
_commander.program.command("clone").description("clone a metarepo").argument("<metarepo>", "The relative path of the repo").option("-b, --branch <branch>", "Branch name to use").action(_command.default.wrap(_metarepo.default.clone));
_commander.program.command("sync").description("sync a metarepo with remote").action(_command.default.wrap(_metarepo.default.sync));
_commander.program.command("import").description("import respositories from a list").argument("<path>", "The path of the import file").action(_command.default.wrap(_metarepo.default.import));
_commander.program.command("exec").description("run a command across repos").option("-i, --include <include>", "YAML file containing repos to include").option("-x, --exclude <exclude>", "YAML file containing repos to exclude").option("-t, --tags <tags>", "Tags to include, separated by +", Tags.parse).option("-s, --serial", "Run command for each repo serially").option("-P, --no-progress", "Don't show progress bar").passThroughOptions().argument("<command>", "The command to run").argument("[arguments...]", "Arguments to pass, if any").action(_command.default.wrap(_metarepo.default.exec));
_commander.program.command("run").description("run a saved script").option("-i, --include <include>", "YAML or JSON file of repos to include").option("-x, --exclude <exclude>", "YAML or JSON file of repos to exclude").option("-t, --tags <tags>", "Tags to include, separated by +", Tags.parse).option("-s, --serial", "Run command for each repo serially").option("-P, --no-progress", "Don't show progress bar").argument("<script>", "The script to run").argument("[arguments...]", "Arguments to pass, if any").action(_command.default.wrap(_metarepo.default.run));
_commander.program.command("tag").description("add tags to a repository").option("-r, --repos <repos...>", "The name of an individual repo").option("-i, --include <include>", "YAML or JSON file of repos to include").option("-x, --exclude <exclude>", "YAML or JSON file of repos to exclude").argument("<tags...>", "The tags to apply to a set of repos").action(_command.default.wrap(_metarepo.default.tag));
_commander.program.command("untag").description("remove tags from a repository").option("-r, --repos <repos...>", "The name of an individual repo").option("-i, --include <include>", "YAML or JSON file of repos to include").option("-x, --exclude <exclude>", "YAML or JSON file of repos to exclude").argument("<tags...>", "The tags to apply to a set of repos").action(_command.default.wrap(_metarepo.default.untag));
ref = _commander.program.commands;
for(i = 0, len = ref.length; i < len; i++){
command = ref[i];
command.option("-v, --verbose", "Perform debug logging").option("-l, --logfile <filename>", "Override the default logfile").option("-P, --no-progress", "Don't show progress bar");
}
_commander.program.parseAsync(); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"","sourceRoot":"","sources":["/@dashkite/tempo/src/cli.coffee"],"names":[],"mappings":"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","sourcesContent":["import FS from \"node:fs\"\nimport Path from \"node:path\"\nimport { program } from \"commander\"\nimport Metarepo from \"./metarepo\"\nimport Command from \"./command\"\n\nTags =\n  \n  parse: ( tags ) -> tags.split \"+\"\n\nprogram\n  # TODO get version from package.json\n  .version do ({ path, json, pkg } = {}) ->\n    path = Path.join __dirname, \"..\", \"..\", \"..\", \"package.json\"\n    json = FS.readFileSync path, \"utf8\"\n    pkg = JSON.parse json\n    pkg.version\n  .enablePositionalOptions()\n\nprogram\n  .command \"add\"\n  .description \"add a project to a metarepo\"\n  .alias \"a\"\n  .argument \"<repo>\", \"The relative path of the repo\"\n  .action Command.wrap Metarepo.add\n\nprogram\n  .command \"remove\"\n  .description \"remove a project from a metarepo\"\n  .aliases [ \"rm\", \"del\", \"delete\" ]\n  .argument \"<repo>\", \"The relative path of the repo\"\n  .action Command.wrap Metarepo.remove\n  \nprogram\n  .command \"clone\"\n  .description \"clone a metarepo\"\n  .argument \"<metarepo>\", \"The relative path of the repo\"\n  .option \"-b, --branch <branch>\", \"Branch name to use\"\n  .action Command.wrap Metarepo.clone\n\nprogram\n  .command \"sync\"\n  .description \"sync a metarepo with remote\"\n  .action Command.wrap Metarepo.sync\n\nprogram\n  .command \"import\"\n  .description \"import respositories from a list\"\n  .argument \"<path>\", \"The path of the import file\"\n  .action Command.wrap Metarepo.import\n\nprogram\n  .command \"exec\"\n  .description \"run a command across repos\"\n  .option \"-i, --include <include>\", \"YAML file containing repos to include\"\n  .option \"-x, --exclude <exclude>\", \"YAML file containing repos to exclude\"\n  .option \"-t, --tags <tags>\", \"Tags to include, separated by +\", Tags.parse\n  .option \"-s, --serial\", \"Run command for each repo serially\"\n  .option \"-P, --no-progress\", \"Don't show progress bar\"\n  .passThroughOptions()\n  .argument \"<command>\", \"The command to run\"\n  .argument \"[arguments...]\", \"Arguments to pass, if any\"\n  .action Command.wrap Metarepo.exec\n\nprogram\n  .command \"run\"\n  .description \"run a saved script\"\n  .option \"-i, --include <include>\", \"YAML or JSON file of repos to include\"\n  .option \"-x, --exclude <exclude>\", \"YAML or JSON file of repos to exclude\"\n  .option \"-t, --tags <tags>\", \"Tags to include, separated by +\", Tags.parse\n  .option \"-s, --serial\", \"Run command for each repo serially\"\n  .option \"-P, --no-progress\", \"Don't show progress bar\"\n  .argument \"<script>\", \"The script to run\"\n  .argument \"[arguments...]\", \"Arguments to pass, if any\"\n  .action Command.wrap Metarepo.run\n\nprogram\n  .command \"tag\"\n  .description \"add tags to a repository\"\n  .option \"-r, --repos <repos...>\", \"The name of an individual repo\"\n  .option \"-i, --include <include>\", \"YAML or JSON file of repos to include\"\n  .option \"-x, --exclude <exclude>\", \"YAML or JSON file of repos to exclude\"\n  .argument \"<tags...>\", \"The tags to apply to a set of repos\"\n  .action Command.wrap Metarepo.tag\n\nprogram\n  .command \"untag\"\n  .description \"remove tags from a repository\"\n  .option \"-r, --repos <repos...>\", \"The name of an individual repo\"\n  .option \"-i, --include <include>\", \"YAML or JSON file of repos to include\"\n  .option \"-x, --exclude <exclude>\", \"YAML or JSON file of repos to exclude\"\n  .argument \"<tags...>\", \"The tags to apply to a set of repos\"\n  .action Command.wrap Metarepo.untag\n\nfor command in program.commands\n  command\n    .option \"-v, --verbose\", \"Perform debug logging\"\n    .option \"-l, --logfile <filename>\", \"Override the default logfile\"\n    .option \"-P, --no-progress\", \"Don't show progress bar\"\n\nprogram.parseAsync()"]}
//# sourceURL=/@dashkite/tempo/src/cli.coffee
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"","sources":["/@dashkite/tempo/src/cli.coffee"],"sourceRoot":"","sourcesContent":["import FS from \"node:fs\"\nimport Path from \"node:path\"\nimport { program } from \"commander\"\nimport Metarepo from \"./metarepo\"\nimport Command from \"./command\"\n\nTags =\n  \n  parse: ( tags ) -> tags.split \"+\"\n\nprogram\n  # TODO get version from package.json\n  .version do ({ path, json, pkg } = {}) ->\n    path = Path.join __dirname, \"..\", \"..\", \"..\", \"package.json\"\n    json = FS.readFileSync path, \"utf8\"\n    pkg = JSON.parse json\n    pkg.version\n  .enablePositionalOptions()\n\nprogram\n  .command \"add\"\n  .description \"add a project to a metarepo\"\n  .alias \"a\"\n  .argument \"<repo>\", \"The relative path of the repo\"\n  .action Command.wrap Metarepo.add\n\nprogram\n  .command \"remove\"\n  .description \"remove a project from a metarepo\"\n  .aliases [ \"rm\", \"del\", \"delete\" ]\n  .argument \"<repo>\", \"The relative path of the repo\"\n  .action Command.wrap Metarepo.remove\n  \nprogram\n  .command \"clone\"\n  .description \"clone a metarepo\"\n  .argument \"<metarepo>\", \"The relative path of the repo\"\n  .option \"-b, --branch <branch>\", \"Branch name to use\"\n  .action Command.wrap Metarepo.clone\n\nprogram\n  .command \"sync\"\n  .description \"sync a metarepo with remote\"\n  .action Command.wrap Metarepo.sync\n\nprogram\n  .command \"import\"\n  .description \"import respositories from a list\"\n  .argument \"<path>\", \"The path of the import file\"\n  .action Command.wrap Metarepo.import\n\nprogram\n  .command \"exec\"\n  .description \"run a command across repos\"\n  .option \"-i, --include <include>\", \"YAML file containing repos to include\"\n  .option \"-x, --exclude <exclude>\", \"YAML file containing repos to exclude\"\n  .option \"-t, --tags <tags>\", \"Tags to include, separated by +\", Tags.parse\n  .option \"-s, --serial\", \"Run command for each repo serially\"\n  .option \"-P, --no-progress\", \"Don't show progress bar\"\n  .passThroughOptions()\n  .argument \"<command>\", \"The command to run\"\n  .argument \"[arguments...]\", \"Arguments to pass, if any\"\n  .action Command.wrap Metarepo.exec\n\nprogram\n  .command \"run\"\n  .description \"run a saved script\"\n  .option \"-i, --include <include>\", \"YAML or JSON file of repos to include\"\n  .option \"-x, --exclude <exclude>\", \"YAML or JSON file of repos to exclude\"\n  .option \"-t, --tags <tags>\", \"Tags to include, separated by +\", Tags.parse\n  .option \"-s, --serial\", \"Run command for each repo serially\"\n  .option \"-P, --no-progress\", \"Don't show progress bar\"\n  .argument \"<script>\", \"The script to run\"\n  .argument \"[arguments...]\", \"Arguments to pass, if any\"\n  .action Command.wrap Metarepo.run\n\nprogram\n  .command \"tag\"\n  .description \"add tags to a repository\"\n  .option \"-r, --repos <repos...>\", \"The name of an individual repo\"\n  .option \"-i, --include <include>\", \"YAML or JSON file of repos to include\"\n  .option \"-x, --exclude <exclude>\", \"YAML or JSON file of repos to exclude\"\n  .argument \"<tags...>\", \"The tags to apply to a set of repos\"\n  .action Command.wrap Metarepo.tag\n\nprogram\n  .command \"untag\"\n  .description \"remove tags from a repository\"\n  .option \"-r, --repos <repos...>\", \"The name of an individual repo\"\n  .option \"-i, --include <include>\", \"YAML or JSON file of repos to include\"\n  .option \"-x, --exclude <exclude>\", \"YAML or JSON file of repos to exclude\"\n  .argument \"<tags...>\", \"The tags to apply to a set of repos\"\n  .action Command.wrap Metarepo.untag\n\nfor command in program.commands\n  command\n    .option \"-v, --verbose\", \"Perform debug logging\"\n    .option \"-l, --logfile <filename>\", \"Override the default logfile\"\n    .option \"-P, --no-progress\", \"Don't show progress bar\"\n\nprogram.parseAsync()"],"names":[],"mappings":"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"}