From 28356a878f56e96dc113a76e7dc51df40a3dc306 Mon Sep 17 00:00:00 2001 From: Mark Abspoel Date: Mon, 13 Nov 2023 14:07:00 +0100 Subject: [PATCH] feat: rejoin splits --- src/helpers/git.ts | 14 +++++++++++--- src/index.ts | 7 +++++-- 2 files changed, 16 insertions(+), 5 deletions(-) diff --git a/src/helpers/git.ts b/src/helpers/git.ts index 5acf6ec..a3b11cd 100644 --- a/src/helpers/git.ts +++ b/src/helpers/git.ts @@ -23,9 +23,17 @@ async function tagExists(tag: string, directory: string): Promise { } async function publishSubSplit(binary: string, target: string, branch: string, name: string, directory: string): Promise { - let hash = await getExecOutput(binary, [`--prefix=${directory}`, `--origin=origin/${branch}`]); - - await exec('git', ['push', target, `${hash.trim()}:refs/heads/${branch}`, '-f']); + const hash = (await getExecOutput(binary, [`--prefix=${directory}`, `--origin=origin/${branch}`])).trim(); + const isAncestor = await exec('git', ['merge-base', '--is-ancestor', hash, 'HEAD']); + if (isAncestor != 0) { + const tree_hash = (await getExecOutput('git', ['write-tree'])).trim(); + const message = `Split '${target}' into commit '{hash}'`; + // Note: if we do more than one split, we can merge all of these join commits into a single one + const merged_hash = await getExecOutput('git', ['commit-tree', '-p', 'HEAD', '-p', hash.trim(), '-m', message, tree_hash]); + await exec('git', ['reset', '--hard', merged_hash]); + await exec('git', ['push']); + } + await exec('git', ['push', target, `${hash}:refs/heads/${branch}`, '-f']); } async function commitHashHasTag(hash: string, clonePath: string) { diff --git a/src/index.ts b/src/index.ts index bb3a2e4..97dec6d 100644 --- a/src/index.ts +++ b/src/index.ts @@ -98,9 +98,12 @@ async function promiseAllInBatches(subtreeSplits: subtreeSplit[], batchSize: num } // On push sync commits - await promiseAllInBatches(subtreeSplits, batchSize, async (split: subtreeSplit) => { + for (let split of subtreeSplits) { await publishSubSplit(splitshPath, split.name, branch, split.name, split.directory); - }); + } + // await promiseAllInBatches(subtreeSplits, batchSize, async (split: subtreeSplit) => { + // await publishSubSplit(splitshPath, split.name, branch, split.name, split.directory); + // }); } else if (context.eventName === 'create') { // Tag created let event = context.payload as CreateEvent;