-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgit-modified
121 lines (109 loc) · 3.22 KB
/
git-modified
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
119
120
121
#!/bin/sh
set -e
usage () {
echo "usage: git modified [-iuqh] [<commit>]" >&2
echo >&2
echo "Prints list of files that are locally modified (and exist). The index is not " >&2
echo "considered, unless the -i flag is provided." >&2
echo "" >&2
echo "If a commit is provided, opens all files that locally exist that have been " >&2
echo "changed in that commit." >&2
echo >&2
echo "This script is ideal for passing all locally modified files into your editor, like:" >&2
echo ' $ vim `git modified`' >&2
echo >&2
echo "Options:" >&2
echo "-i Consider the index, too" >&2
echo "-u Print only files that are unmerged (files with conflicts)" >&2
echo "-q Be quiet, only return with 0 exit code when files are modified" >&2
echo "-h Show this help" >&2
}
index=0
unmerged=0
quiet=0
while getopts iuqh flag; do
case "$flag" in
i) index=1;;
u) unmerged=1;;
q) quiet=1;;
h) usage; exit 2;;
esac
done
shift $(($OPTIND - 1))
commit=""
if [ $# -ge 1 ]; then
commit="$1"
fi
#
# git status cheat sheet:
#
# X Y Meaning
# -------------------------------------------------
# [MD] not updated
# M [ MD] updated in index
# A [ MD] added to index
# D [ M] deleted from index
# R [ MD] renamed in index
# C [ MD] copied in index
# [MARC] index and work tree matches
# [ MARC] M work tree changed since index
# [ MARC] D deleted in work tree
# -------------------------------------------------
# D D unmerged, both deleted
# A U unmerged, added by us
# U D unmerged, deleted by them
# U A unmerged, added by them
# D U unmerged, deleted by us
# A A unmerged, both added
# U U unmerged, both modified
# -------------------------------------------------
# ? ? untracked
# ! ! ignored
# -------------------------------------------------
status () {
git status --porcelain | grep -vEe '^.D' | grep -vEe '^D '
}
fix_rename_notation () {
sed -Ee 's/.* -> (.*)/\1/'
}
make_relative () {
root="$(git root)"
while read f; do
echo "$(realpath --relative-to=. "$root/$f")"
done
}
modified_in_index () {
status | cut -c 4- | fix_rename_notation | make_relative
}
modified_unmerged () {
status | grep -Ee '^(U.|.U)' | cut -c 4- | fix_rename_notation | make_relative
}
modified_locally () {
status | cut -c 2- | grep -vEe '^[ ]' | cut -c 3- | fix_rename_notation | make_relative
}
fail_if_empty () {
empty=1
while read line; do
if [ $quiet -eq 0 ]; then
echo "$line"
fi
empty=0
done
test $empty -eq 0
}
if [ -z "$commit" ]; then
if [ $unmerged -eq 1 ]; then
modified_unmerged | fail_if_empty
elif [ $index -eq 1 ]; then
modified_in_index | fail_if_empty
else
modified_locally | fail_if_empty
fi
else
TAB=" " # literal tab char
git log -1 --name-status --pretty=format:"" "$commit" | cut -f2- | rev | cut -d"$TAB" -f1 | rev | make_relative | while read f; do
if [ -f "$f" ]; then
echo "$f"
fi
done | fail_if_empty
fi