Add git-squash-merge script
This commit is contained in:
parent
adcbb914f1
commit
150182149a
|
@ -146,7 +146,10 @@
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
home.packages = [ pkgs.git-instafix ];
|
home.packages = with pkgs; [
|
||||||
|
git-instafix
|
||||||
|
git-squash-merge
|
||||||
|
];
|
||||||
|
|
||||||
home.sessionVariables = {
|
home.sessionVariables = {
|
||||||
GIT_INSTAFIX_UPSTREAM = "origin/main";
|
GIT_INSTAFIX_UPSTREAM = "origin/main";
|
||||||
|
|
|
@ -5,6 +5,7 @@ let
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
build-glove80 = callPackage ./build-glove80.nix { };
|
build-glove80 = callPackage ./build-glove80.nix { };
|
||||||
|
git-squash-merge = callPackage ./git-squash-merge.nix { };
|
||||||
|
|
||||||
vimPlugins = prev.vimPlugins // {
|
vimPlugins = prev.vimPlugins // {
|
||||||
conf-vim = callPackage ./vim-plugins/conf-vim.nix { };
|
conf-vim = callPackage ./vim-plugins/conf-vim.nix { };
|
||||||
|
|
40
nix/pkgs/git-squash-merge.nix
Normal file
40
nix/pkgs/git-squash-merge.nix
Normal file
|
@ -0,0 +1,40 @@
|
||||||
|
{ pkgs }:
|
||||||
|
|
||||||
|
pkgs.writeShellApplication {
|
||||||
|
name = "git-squash-merge";
|
||||||
|
|
||||||
|
runtimeInputs = with pkgs; [
|
||||||
|
bashInteractive
|
||||||
|
coreutils
|
||||||
|
git
|
||||||
|
];
|
||||||
|
|
||||||
|
text = ''
|
||||||
|
branch_to_merge=$1
|
||||||
|
target_branch=''${2:-main}
|
||||||
|
|
||||||
|
if [[ -z "$branch_to_merge" ]]; then
|
||||||
|
echo "Usage: $0 <branch-to-merge> [target-branch]"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if ! git checkout "$target_branch"; then
|
||||||
|
echo "Error: Failed to checkout target branch '$target_branch'."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if ! git merge --squash "$branch_to_merge"; then
|
||||||
|
echo "Error: Squash merge from '$branch_to_merge' to '$target_branch' failed."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
squashed_commit_messages=$(git log "$target_branch..$branch_to_merge" --reverse --pretty=format:"%h %s%n%b%n")
|
||||||
|
|
||||||
|
temp_file=$(mktemp)
|
||||||
|
echo -e "$squashed_commit_messages" > "$temp_file"
|
||||||
|
|
||||||
|
GIT_COMMIT_EDITMSG="$temp_file" git commit --edit
|
||||||
|
|
||||||
|
rm -f "$temp_file"
|
||||||
|
'';
|
||||||
|
}
|
Loading…
Reference in a new issue