turbo-gulp
Version:
Gulp tasks to boost high-quality projects.
89 lines (87 loc) • 13.3 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
const incident_1 = require("incident");
const node_async_1 = require("./node-async");
async function execGit(cmd, args = [], options) {
return new node_async_1.SpawnedProcess("git", [cmd, ...args], Object.assign({ stdio: "pipe" }, options)).toPromise();
}
exports.execGit = execGit;
async function assertCleanBranch(allowedBranches) {
let stdout;
stdout = (await execGit("symbolic-ref", ["HEAD"])).stdout;
let onAllowedBranch = false;
for (const branch of allowedBranches) {
if (stdout.toString("utf8").trim() === `refs/heads/${branch}`) {
onAllowedBranch = true;
}
}
if (!onAllowedBranch) {
throw new Error(`HEAD must be on one of the branches: ${JSON.stringify(allowedBranches)}`);
}
stdout = (await execGit("status", ["--porcelain"])).stdout;
if (stdout.toString("utf8").trim().length > 0) {
throw new Error("Working copy is dirty");
}
}
exports.assertCleanBranch = assertCleanBranch;
/**
* Get the hash of the HEAD commit.
*
* @return The hash of the HEAD commit.
*/
async function getHeadHash() {
return (await execGit("rev-parse", ["--verify", "HEAD"])).stdout.toString("utf8").trim();
}
exports.getHeadHash = getHeadHash;
async function tagExists(tag) {
return (await execGit("tag", ["-l", tag])).stdout.toString("utf8").trim().length > 0;
}
exports.tagExists = tagExists;
/**
* Clone a repository into a new directory
*/
async function gitClone(options) {
const args = [];
if (options.branch !== undefined) {
args.push("--branch", options.branch);
}
if (options.depth !== undefined) {
args.push("--depth", options.depth.toString(10));
}
args.push(options.repository, options.directory);
const result = await execGit("clone", args);
if (result.exit.type === "code" && result.exit.code !== 0) {
throw new incident_1.Incident("GitClone", { options, result }, result.stderr.toString("utf8"));
}
}
exports.gitClone = gitClone;
/**
* Clone a repository into a new directory
*/
async function gitAdd(options) {
const args = ["--", ...options.paths];
const result = await execGit("add", args, { cwd: options.repository });
if (result.exit.type === "code" && result.exit.code !== 0) {
throw new incident_1.Incident("GitAdd", { options, result }, result.stderr.toString("utf8"));
}
}
exports.gitAdd = gitAdd;
async function gitCommit(options) {
const args = ["-m", options.message];
if (options.author !== undefined) {
args.push("--author", options.author);
}
const result = await execGit("commit", args, { cwd: options.repository });
if (result.exit.type === "code" && result.exit.code !== 0) {
throw new incident_1.Incident("GitCommit", { options, result }, result.stderr.toString("utf8"));
}
}
exports.gitCommit = gitCommit;
async function gitPush(options) {
const result = await execGit("push", [options.remote], { cwd: options.local });
if (result.exit.type === "code" && result.exit.code !== 0) {
throw new incident_1.Incident("GitPush", { options, result }, result.stderr.toString("utf8"));
}
}
exports.gitPush = gitPush;
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["utils/git.ts"],"names":[],"mappings":"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","file":"utils/git.js","sourcesContent":["import { Incident } from \"incident\";\nimport { AbsPosixPath } from \"../types\";\nimport { SpawnedProcess, SpawnOptions, SpawnResult } from \"./node-async\";\n\nexport async function execGit(cmd: string, args: string[] = [], options?: SpawnOptions): Promise<SpawnResult> {\n  return new SpawnedProcess(\n    \"git\",\n    [cmd, ...args],\n    {stdio: \"pipe\", ...options},\n  ).toPromise();\n}\n\nexport async function assertCleanBranch(allowedBranches: string[]): Promise<void> {\n  let stdout: Buffer;\n  stdout = (await execGit(\"symbolic-ref\", [\"HEAD\"])).stdout;\n  let onAllowedBranch: boolean = false;\n  for (const branch of allowedBranches) {\n    if (stdout.toString(\"utf8\").trim() === `refs/heads/${branch}`) {\n      onAllowedBranch = true;\n    }\n  }\n  if (!onAllowedBranch) {\n    throw new Error(`HEAD must be on one of the branches: ${JSON.stringify(allowedBranches)}`);\n  }\n  stdout = (await execGit(\"status\", [\"--porcelain\"])).stdout;\n  if (stdout.toString(\"utf8\").trim().length > 0) {\n    throw new Error(\"Working copy is dirty\");\n  }\n}\n\n/**\n * Get the hash of the HEAD commit.\n *\n * @return The hash of the HEAD commit.\n */\nexport async function getHeadHash(): Promise<string> {\n  return (await execGit(\"rev-parse\", [\"--verify\", \"HEAD\"])).stdout.toString(\"utf8\").trim();\n}\n\nexport async function tagExists(tag: string): Promise<boolean> {\n  return (await execGit(\"tag\", [\"-l\", tag])).stdout.toString(\"utf8\").trim().length > 0;\n}\n\nexport interface GitCloneOptions {\n  branch?: string;\n  depth?: number;\n  repository: string;\n  directory: AbsPosixPath;\n}\n\n/**\n * Clone a repository into a new directory\n */\nexport async function gitClone(options: GitCloneOptions): Promise<void> {\n  const args: string[] = [];\n  if (options.branch !== undefined) {\n    args.push(\"--branch\", options.branch);\n  }\n  if (options.depth !== undefined) {\n    args.push(\"--depth\", options.depth.toString(10));\n  }\n  args.push(options.repository, options.directory);\n  const result: SpawnResult = await execGit(\"clone\", args);\n  if (result.exit.type === \"code\" && result.exit.code !== 0) {\n    throw new Incident(\"GitClone\", {options, result}, result.stderr.toString(\"utf8\"));\n  }\n}\n\nexport interface GitAddOptions {\n  paths: string[];\n  repository: AbsPosixPath;\n}\n\n/**\n * Clone a repository into a new directory\n */\nexport async function gitAdd(options: GitAddOptions): Promise<void> {\n  const args: string[] = [\"--\", ...options.paths];\n  const result: SpawnResult = await execGit(\"add\", args, {cwd: options.repository});\n  if (result.exit.type === \"code\" && result.exit.code !== 0) {\n    throw new Incident(\"GitAdd\", {options, result}, result.stderr.toString(\"utf8\"));\n  }\n}\n\nexport interface GitCommitOptions {\n  message: string;\n  author?: string;\n  repository: AbsPosixPath;\n}\n\nexport async function gitCommit(options: GitCommitOptions): Promise<void> {\n  const args: string[] = [\"-m\", options.message];\n  if (options.author !== undefined) {\n    args.push(\"--author\", options.author);\n  }\n  const result: SpawnResult = await execGit(\"commit\", args, {cwd: options.repository});\n  if (result.exit.type === \"code\" && result.exit.code !== 0) {\n    throw new Incident(\"GitCommit\", {options, result}, result.stderr.toString(\"utf8\"));\n  }\n}\n\nexport interface GitPushOptions {\n  local: AbsPosixPath;\n  remote: string;\n}\n\nexport async function gitPush(options: GitPushOptions): Promise<void> {\n  const result: SpawnResult = await execGit(\"push\", [options.remote], {cwd: options.local});\n  if (result.exit.type === \"code\" && result.exit.code !== 0) {\n    throw new Incident(\"GitPush\", {options, result}, result.stderr.toString(\"utf8\"));\n  }\n}\n"],"sourceRoot":".."}