From ddeca9403738286b15f964347097116b686c9959 Mon Sep 17 00:00:00 2001 From: Peter Evans <18365890+peter-evans@users.noreply.github.com> Date: Tue, 17 Nov 2020 11:42:31 +0900 Subject: [PATCH] perf: set diff quiet and switch isdirty command order --- dist/index.js | 39 ++++++++++++++-------------------- src/create-or-update-branch.ts | 11 +--------- src/git-command-manager.ts | 29 ++++++++++++------------- 3 files changed, 31 insertions(+), 48 deletions(-) diff --git a/dist/index.js b/dist/index.js index 2018a13..e1a6acd 100644 --- a/dist/index.js +++ b/dist/index.js @@ -93,12 +93,6 @@ function isEven(git, branch1, branch2) { !(yield isBehind(git, branch1, branch2))); }); } -function hasDiff(git, branch1, branch2) { - return __awaiter(this, void 0, void 0, function* () { - const result = yield git.diff([`${branch1}..${branch2}`]); - return result.length > 0; - }); -} function splitLines(multilineString) { return multilineString .split('\n') @@ -192,7 +186,7 @@ function createOrUpdateBranch(git, commitMessage, base, branch, branchRemoteName // squash merged but not deleted. We need to reset to make sure it doesn't appear // to have a diff with the base due to different commits for the same changes. // For changes on base this reset is equivalent to a rebase of the pull request branch. - if ((yield hasDiff(git, branch, tempBranch)) || + if ((yield git.hasDiff([`${branch}..${tempBranch}`])) || !(yield isAhead(git, base, tempBranch))) { core.info(`Resetting '${branch}'`); // Alternatively, git switch -C branch tempBranch @@ -662,16 +656,6 @@ class GitCommandManager { return output.exitCode === 0; }); } - diff(options) { - return __awaiter(this, void 0, void 0, function* () { - const args = ['-c', 'core.pager=cat', 'diff']; - if (options) { - args.push(...options); - } - const output = yield this.exec(args); - return output.stdout.trim(); - }); - } fetch(refSpec, remoteName, options) { return __awaiter(this, void 0, void 0, function* () { const args = ['-c', 'protocol.version=2', 'fetch']; @@ -712,19 +696,28 @@ class GitCommandManager { getWorkingDirectory() { return this.workingDirectory; } + hasDiff(options) { + return __awaiter(this, void 0, void 0, function* () { + const args = ['diff', '--quiet']; + if (options) { + args.push(...options); + } + const output = yield this.exec(args, true); + return output.exitCode === 1; + }); + } isDirty(untracked) { return __awaiter(this, void 0, void 0, function* () { - const diffArgs = ['--abbrev=40', '--full-index', '--raw']; - // Check staged changes - if (yield this.diff([...diffArgs, '--staged'])) { + // Check untracked changes + if (untracked && (yield this.status(['--porcelain', '-unormal']))) { return true; } // Check working index changes - if (yield this.diff(diffArgs)) { + if (yield this.hasDiff()) { return true; } - // Check untracked changes - if (untracked && (yield this.status(['--porcelain', '-unormal']))) { + // Check staged changes + if (yield this.hasDiff(['--staged'])) { return true; } return false; diff --git a/src/create-or-update-branch.ts b/src/create-or-update-branch.ts index 0b074fc..63454a6 100644 --- a/src/create-or-update-branch.ts +++ b/src/create-or-update-branch.ts @@ -78,15 +78,6 @@ async function isEven( ) } -async function hasDiff( - git: GitCommandManager, - branch1: string, - branch2: string -): Promise { - const result = await git.diff([`${branch1}..${branch2}`]) - return result.length > 0 -} - function splitLines(multilineString: string): string[] { return multilineString .split('\n') @@ -205,7 +196,7 @@ export async function createOrUpdateBranch( // to have a diff with the base due to different commits for the same changes. // For changes on base this reset is equivalent to a rebase of the pull request branch. if ( - (await hasDiff(git, branch, tempBranch)) || + (await git.hasDiff([`${branch}..${tempBranch}`])) || !(await isAhead(git, base, tempBranch)) ) { core.info(`Resetting '${branch}'`) diff --git a/src/git-command-manager.ts b/src/git-command-manager.ts index 1c69d9c..8dc6a9b 100644 --- a/src/git-command-manager.ts +++ b/src/git-command-manager.ts @@ -96,15 +96,6 @@ export class GitCommandManager { return output.exitCode === 0 } - async diff(options?: string[]): Promise { - const args = ['-c', 'core.pager=cat', 'diff'] - if (options) { - args.push(...options) - } - const output = await this.exec(args) - return output.stdout.trim() - } - async fetch( refSpec: string[], remoteName?: string, @@ -153,18 +144,26 @@ export class GitCommandManager { return this.workingDirectory } + async hasDiff(options?: string[]): Promise { + const args = ['diff', '--quiet'] + if (options) { + args.push(...options) + } + const output = await this.exec(args, true) + return output.exitCode === 1 + } + async isDirty(untracked: boolean): Promise { - const diffArgs = ['--abbrev=40', '--full-index', '--raw'] - // Check staged changes - if (await this.diff([...diffArgs, '--staged'])) { + // Check untracked changes + if (untracked && (await this.status(['--porcelain', '-unormal']))) { return true } // Check working index changes - if (await this.diff(diffArgs)) { + if (await this.hasDiff()) { return true } - // Check untracked changes - if (untracked && (await this.status(['--porcelain', '-unormal']))) { + // Check staged changes + if (await this.hasDiff(['--staged'])) { return true } return false