diff.c: make built-in hunk header pattern a separate table
[git/git-svn.git] / git-repack.sh
blobb5c667110d31fe9e083f8b7d4db727ed63333e37
1 #!/bin/sh
3 # Copyright (c) 2005 Linus Torvalds
6 USAGE='[-a] [-d] [-f] [-l] [-n] [-q] [--max-pack-size=N] [--window=N] [--depth=N]'
7 SUBDIRECTORY_OK='Yes'
8 . git-sh-setup
10 no_update_info= all_into_one= remove_redundant=
11 local= quiet= no_reuse= extra=
12 while case "$#" in 0) break ;; esac
14 case "$1" in
15 -n) no_update_info=t ;;
16 -a) all_into_one=t ;;
17 -d) remove_redundant=t ;;
18 -q) quiet=-q ;;
19 -f) no_reuse=--no-reuse-object ;;
20 -l) local=--local ;;
21 --max-pack-size=*) extra="$extra $1" ;;
22 --window=*) extra="$extra $1" ;;
23 --depth=*) extra="$extra $1" ;;
24 *) usage ;;
25 esac
26 shift
27 done
29 # Later we will default repack.UseDeltaBaseOffset to true
30 default_dbo=false
32 case "`git config --bool repack.usedeltabaseoffset ||
33 echo $default_dbo`" in
34 true)
35 extra="$extra --delta-base-offset" ;;
36 esac
38 PACKDIR="$GIT_OBJECT_DIRECTORY/pack"
39 PACKTMP="$GIT_OBJECT_DIRECTORY/.tmp-$$-pack"
40 rm -f "$PACKTMP"-*
41 trap 'rm -f "$PACKTMP"-*' 0 1 2 3 15
43 # There will be more repacking strategies to come...
44 case ",$all_into_one," in
45 ,,)
46 args='--unpacked --incremental'
48 ,t,)
49 if [ -d "$PACKDIR" ]; then
50 for e in `cd "$PACKDIR" && find . -type f -name '*.pack' \
51 | sed -e 's/^\.\///' -e 's/\.pack$//'`
53 if [ -e "$PACKDIR/$e.keep" ]; then
54 : keep
55 else
56 args="$args --unpacked=$e.pack"
57 existing="$existing $e"
59 done
61 [ -z "$args" ] && args='--unpacked --incremental'
63 esac
65 args="$args $local $quiet $no_reuse$extra"
66 names=$(git pack-objects --non-empty --all --reflog $args </dev/null "$PACKTMP") ||
67 exit 1
68 if [ -z "$names" ]; then
69 if test -z "$quiet"; then
70 echo Nothing new to pack.
73 for name in $names ; do
74 fullbases="$fullbases pack-$name"
75 chmod a-w "$PACKTMP-$name.pack"
76 chmod a-w "$PACKTMP-$name.idx"
77 if test "$quiet" != '-q'; then
78 echo "Pack pack-$name created."
80 mkdir -p "$PACKDIR" || exit
82 for sfx in pack idx
84 if test -f "$PACKDIR/pack-$name.$sfx"
85 then
86 mv -f "$PACKDIR/pack-$name.$sfx" \
87 "$PACKDIR/old-pack-$name.$sfx"
89 done &&
90 mv -f "$PACKTMP-$name.pack" "$PACKDIR/pack-$name.pack" &&
91 mv -f "$PACKTMP-$name.idx" "$PACKDIR/pack-$name.idx" &&
92 test -f "$PACKDIR/pack-$name.pack" &&
93 test -f "$PACKDIR/pack-$name.idx" || {
94 echo >&2 "Couldn't replace the existing pack with updated one."
95 echo >&2 "The original set of packs have been saved as"
96 echo >&2 "old-pack-$name.{pack,idx} in $PACKDIR."
97 exit 1
99 rm -f "$PACKDIR/old-pack-$name.pack" "$PACKDIR/old-pack-$name.idx"
100 done
102 if test "$remove_redundant" = t
103 then
104 # We know $existing are all redundant.
105 if [ -n "$existing" ]
106 then
107 sync
108 ( cd "$PACKDIR" &&
109 for e in $existing
111 case " $fullbases " in
112 *" $e "*) ;;
113 *) rm -f "$e.pack" "$e.idx" "$e.keep" ;;
114 esac
115 done
118 git prune-packed $quiet
121 case "$no_update_info" in
122 t) : ;;
123 *) git-update-server-info ;;
124 esac