mirror of
https://github.com/frebib/dotfiles.git
synced 2024-06-14 12:57:23 +00:00
git: Allow git cleanmerged/defbranch to take args
These aliases now make zero assumptions about either branch or origin names. They default to origin, and the primary branch is determined from the refs/remotes/$remote/HEAD symbolic-ref, which will be pulled from the remote if it's not known locally. With these it is now possible to act on any remote/branch combination: # Get default branch for 'upstream' remote $ git defbranch upstream # Delete branches merged into the default branch of the 'upstream' # remote $ git cleanmerged upstream # Delete branches merged into the upstream/foo branch $ git cleanmerged upstream foo Signed-off-by: Joe Groocock <me@frebib.net>
This commit is contained in:
parent
56fd0ad602
commit
a7af23bfbb
19
git/config
19
git/config
@ -37,8 +37,23 @@
|
||||
count = !echo $(pwd) && git rev-list HEAD --count
|
||||
unpushed = !git log --oneline @{u}..HEAD
|
||||
leaders = !git shortlog -s -n --all --no-merges
|
||||
defbranch = !git symbolic-ref refs/remotes/origin/HEAD | sed \"s@^refs/remotes/origin/@@\"
|
||||
cleanmerged = !git branch --merged \"origin/$(git defbranch)\" | grep -ve \"^\\\\*\" -e \"^. $(git defbranch)$\" | xargs -r git branch -d
|
||||
defbranch = "!defbranch() { \
|
||||
r=\"${1:-origin}\"; \
|
||||
{ \
|
||||
git symbolic-ref \"refs/remotes/$r/HEAD\" || { \
|
||||
git remote set-head \"$r\" -a >&2 && \
|
||||
git symbolic-ref \"refs/remotes/$r/HEAD\"; \
|
||||
}; \
|
||||
} 2>/dev/null \
|
||||
| sed \"s@^refs/remotes/$r/@@\"; \
|
||||
}; defbranch"
|
||||
cleanmerged = "!cleanmerged() { \
|
||||
r=\"${1:-origin}\"; \
|
||||
b=\"${2:-$(git defbranch \"$r\")}\"; \
|
||||
git branch --merged \"$r/$b\" | \
|
||||
grep -ve \"^\\\\*\" -e \"^. $b$\" | \
|
||||
xargs -r git branch -d; \
|
||||
}; cleanmerged"
|
||||
[advice]
|
||||
statusHints = false
|
||||
pushUpdateRejected = false
|
||||
|
Loading…
Reference in New Issue
Block a user