perf: set diff quiet and switch isdirty command order

This commit is contained in:
Peter Evans 2020-11-17 11:42:31 +09:00
parent 0fd77ba8cc
commit ddeca94037
3 changed files with 31 additions and 48 deletions

39
dist/index.js vendored
View file

@ -93,12 +93,6 @@ function isEven(git, branch1, branch2) {
!(yield isBehind(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) { function splitLines(multilineString) {
return multilineString return multilineString
.split('\n') .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 // 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. // 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. // 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))) { !(yield isAhead(git, base, tempBranch))) {
core.info(`Resetting '${branch}'`); core.info(`Resetting '${branch}'`);
// Alternatively, git switch -C branch tempBranch // Alternatively, git switch -C branch tempBranch
@ -662,16 +656,6 @@ class GitCommandManager {
return output.exitCode === 0; 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) { fetch(refSpec, remoteName, options) {
return __awaiter(this, void 0, void 0, function* () { return __awaiter(this, void 0, void 0, function* () {
const args = ['-c', 'protocol.version=2', 'fetch']; const args = ['-c', 'protocol.version=2', 'fetch'];
@ -712,19 +696,28 @@ class GitCommandManager {
getWorkingDirectory() { getWorkingDirectory() {
return this.workingDirectory; 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) { isDirty(untracked) {
return __awaiter(this, void 0, void 0, function* () { return __awaiter(this, void 0, void 0, function* () {
const diffArgs = ['--abbrev=40', '--full-index', '--raw']; // Check untracked changes
// Check staged changes if (untracked && (yield this.status(['--porcelain', '-unormal']))) {
if (yield this.diff([...diffArgs, '--staged'])) {
return true; return true;
} }
// Check working index changes // Check working index changes
if (yield this.diff(diffArgs)) { if (yield this.hasDiff()) {
return true; return true;
} }
// Check untracked changes // Check staged changes
if (untracked && (yield this.status(['--porcelain', '-unormal']))) { if (yield this.hasDiff(['--staged'])) {
return true; return true;
} }
return false; return false;

View file

@ -78,15 +78,6 @@ async function isEven(
) )
} }
async function hasDiff(
git: GitCommandManager,
branch1: string,
branch2: string
): Promise<boolean> {
const result = await git.diff([`${branch1}..${branch2}`])
return result.length > 0
}
function splitLines(multilineString: string): string[] { function splitLines(multilineString: string): string[] {
return multilineString return multilineString
.split('\n') .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. // 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. // For changes on base this reset is equivalent to a rebase of the pull request branch.
if ( if (
(await hasDiff(git, branch, tempBranch)) || (await git.hasDiff([`${branch}..${tempBranch}`])) ||
!(await isAhead(git, base, tempBranch)) !(await isAhead(git, base, tempBranch))
) { ) {
core.info(`Resetting '${branch}'`) core.info(`Resetting '${branch}'`)

View file

@ -96,15 +96,6 @@ export class GitCommandManager {
return output.exitCode === 0 return output.exitCode === 0
} }
async diff(options?: string[]): Promise<string> {
const args = ['-c', 'core.pager=cat', 'diff']
if (options) {
args.push(...options)
}
const output = await this.exec(args)
return output.stdout.trim()
}
async fetch( async fetch(
refSpec: string[], refSpec: string[],
remoteName?: string, remoteName?: string,
@ -153,18 +144,26 @@ export class GitCommandManager {
return this.workingDirectory return this.workingDirectory
} }
async hasDiff(options?: string[]): Promise<boolean> {
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<boolean> { async isDirty(untracked: boolean): Promise<boolean> {
const diffArgs = ['--abbrev=40', '--full-index', '--raw'] // Check untracked changes
// Check staged changes if (untracked && (await this.status(['--porcelain', '-unormal']))) {
if (await this.diff([...diffArgs, '--staged'])) {
return true return true
} }
// Check working index changes // Check working index changes
if (await this.diff(diffArgs)) { if (await this.hasDiff()) {
return true return true
} }
// Check untracked changes // Check staged changes
if (untracked && (await this.status(['--porcelain', '-unormal']))) { if (await this.hasDiff(['--staged'])) {
return true return true
} }
return false return false