git cat-file -s
выведет размер объекта в байтах в git. git diff-tree
может сказать вам разницу между одним деревом и другим.
Объединение этого в сценарий с именем git-file-size-diff
, расположенный где-нибудь в вашей PATH, даст вам возможность вызывать git file-size-diff <tree-ish> <tree-ish>
. Мы можем попробовать что-то вроде следующего:
#!/bin/bash
USAGE='[--cached] [<rev-list-options>...]
Show file size changes between two commits or the index and a commit.'
. "$(git --exec-path)/git-sh-setup"
args=$(git rev-parse --sq "$@")
[ -n "$args" ] || usage
cmd="diff-tree -r"
[[ $args =~ "--cached" ]] && cmd="diff-index"
eval "git $cmd $args" | {
total=0
while read A B C D M P
do
case $M in
M) bytes=$(( $(git cat-file -s $D) - $(git cat-file -s $C) )) ;;
A) bytes=$(git cat-file -s $D) ;;
D) bytes=-$(git cat-file -s $C) ;;
*)
echo >&2 warning: unhandled mode $M in \"$A $B $C $D $M $P\"
continue
;;
esac
total=$(( $total + $bytes ))
printf '%d\t%s\n' $bytes "$P"
done
echo total $total
}
При использовании это выглядит следующим образом:
$ git file-size-diff HEAD~850..HEAD~845
-234 Documentation/RelNotes/1.7.7.txt
112 Documentation/git.txt
-4 GIT-VERSION-GEN
43 builtin/grep.c
42 diff-lib.c
594 git-rebase--interactive.sh
381 t/t3404-rebase-interactive.sh
114 t/test-lib.sh
743 tree-walk.c
28 tree-walk.h
67 unpack-trees.c
28 unpack-trees.h
total 1914
Используя git-rev-parse
, он должен принимать все обычные способы указания диапазонов фиксации.
РЕДАКТИРОВАТЬ: обновлено для записи совокупной суммы. Обратите внимание, что bash выполняет чтение while в подоболочке, отсюда и дополнительные фигурные скобки, чтобы не потерять итоговую сумму при выходе из подоболочки.
РЕДАКТИРОВАТЬ: добавлена поддержка сравнения индекса с другим деревом с использованием аргумента --cached
для вызова git diff-index
вместо git diff-tree
. например:
$ git file-size-diff --cached master
-570 Makefile
-134 git-gui.sh
-1 lib/browser.tcl
931 lib/commit.tcl
18 lib/index.tcl
total 244
person
patthoyts
schedule
01.06.2012