-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathgitdiff.sh
executable file
·118 lines (104 loc) · 3.18 KB
/
gitdiff.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
#!/bin/bash
## /*
# @usage gitdiff [-am] [base-branch]
#
# @description
# This script is used to get a quick look at all the files that have been added,
# modified, and/or deleted in the current branch's latest commit and either a
# specified branch (the first parameter) or the master branch (default; from remote).
# You can optionally specify that you only want to view currently modified files
# or commits AND modified files.
# description@
#
# @options
# -a Show the diff between the base-branch and HEAD, including any currently
# modified files in the working tree.
# -m Only show a diff of HEAD with any currently modified/deleted/renamed
# files in the working tree.
# options@
#
# @notes
# - If your project does not have a master branch, you will need to pass the first
# parameter for each use.
# - You may specify a hash as an argument instead of a base-branch name.
# notes@
#
# @examples
# $ gitdiff stage # Shows diff between the stage branch and HEAD
# $ gitdiff 3bdaf1 # Shows diff between commit 3bdaf1 and HEAD
# $ gitdiff -m # Shows diff between HEAD and any dirty files in the working tree.
# examples@
#
# @dependencies
# functions/1000.set_remote.sh
# functions/5000.branch_exists.sh
# dependencies@
#
# @file gitdiff.sh
## */
$loadfuncs
__set_remote
echo
branch="master"
[ -n "$_remote" ] && branch="${_remote}/master"
if [ -n "$1" ]; then
case "$1" in
-m)
showModified=true
[ -n "$2" ] && branch="$2";;
-a)
showAll=true
[ -n "$2" ] && branch="$2";;
*)
branch=$1;;
esac
fi
# make sure branch exists
if ! __branch_exists "$branch"; then
# maybe the user passed a hash instead of a branch?
if ! git log -1 --oneline "$branch" &>/dev/null; then
echo ${E}" Branch (or hash) \`$branch\` does not exist! Aborting... "${X}
exit 1
fi
fi
# get 7 digit shortened hash for each commit
hashFrom=$(git rev-parse --short $branch)
hashTo=$(git rev-parse --short HEAD)
hashes="${hashFrom}..${hashTo}"
[ "$hashFrom" == "$hashTo" ] && hashesSame=true || hashesSame=
# Based on options passed to this script, figure out what the diff hashes should be
if [ $showModified ]; then
hashes="$hashTo"
elif [ $showAll ]; then
hashes="$hashFrom"
fi
# tell us if we have two hashes for the specs
grep -q '\.' <<< "$hashes" && hasRange=true || hasRange=
echo ${O}${H2HL}
if [ ! $hashesSame ] && [ ! $showModified ]; then
echo "$ git --no-pager log --oneline -30 ${hashFrom}..${hashTo}"
git --no-pager log --oneline -30 ${hashFrom}..${hashTo}
echo
echo
fi
echo "$ git diff --name-status ${hashes}"
if [ "$WINDOWS" == "true" ]; then
git diff --name-status $hashes
else
while read STATUS ADDR
do
echo " # $ADDR ($STATUS)"
done < <(git diff --name-status ${hashes})
fi
echo
echo "git diff -w ${hashes}"
echo ${H2HL}${X}
# only need to ask to do a diff if there ARE differences.
if [ -n "$(git diff --name-status $hashes)" ]; then
echo
echo ${Q}"Do diff? y (n)"${X}
read yn
if [ "$yn" = "y" ] || [ "$yn" = "Y" ]; then
git diff -w $hashes
fi
fi