From 284a88a8607cc7077aec376ca5f4b0c1b7e12c70 Mon Sep 17 00:00:00 2001 From: Michael Allen Date: Tue, 11 Aug 2015 16:47:32 +0100 Subject: Provide a bash way to show remote commits --- git-base.sh | 25 +++++++++++++++++++++++++ 1 file changed, 25 insertions(+) (limited to 'git-base.sh') diff --git a/git-base.sh b/git-base.sh index 3cf24b5..f75e89b 100755 --- a/git-base.sh +++ b/git-base.sh @@ -419,3 +419,28 @@ zsh_color_local_commits() { fi echo "$local_commits" } + +bash_color_remote_commits() { + local remote_master="\xF0\x9D\x98\xAE" # an italic m to represent master + local green_ahead_arrow="\033[1;32m←\033[0m" + local red_behind_arrow="\033[1;31m→\033[0m" + local yellow_diverged_arrow="\033[1;33m⇄\033[0m" + local not_upstream="\033[1;31m⚡\033[0m" + + if remote_branch="$(remote_branch_name)"; then + remote_ahead="$(remote_ahead_of_master "$remote_branch")" + remote_behind="$(remote_behind_of_master "$remote_branch")" + + if [[ "$remote_behind" -gt "0" && "$remote_ahead" -gt "0" ]]; then + remote="$remote_master $remote_behind $yellow_diverged_arrow $remote_ahead " + elif [[ "$remote_ahead" -gt "0" ]]; then + remote="$remote_master $green_ahead_arrow $remote_ahead " + elif [[ "$remote_behind" -gt "0" ]]; then + remote="$remote_master $remote_behind $red_behind_arrow " + fi + else + remote="upstream $not_upstream " + fi + + echo "$remote" +} -- cgit v1.2.3