release.sh: fix broken && chain
[msysgit.git] / share / WinGit / release.sh
blobcea1c29a8ecdf222bb6f59a32f422f142b2f4d1d
1 #!/bin/sh
3 force=
4 do_compile=t
5 while test $# -gt 0
6 do
7 case "$1" in
8 -f|--force)
9 force=t
10 shift
12 -n|--no-compile)
13 do_compile=
14 shift
17 break
18 esac
19 done
21 test -z "$1" && {
22 echo "Usage: $0 [-f] [-n] <version>" >&2
23 exit 1
26 version=$1
28 test -z "$force" && {
29 die () {
30 echo "$*" >&2
31 echo "If that is okay, please call '$0 -f $version'" >&2
32 exit 1
35 (cd /git &&
36 git update-index --refresh &&
37 git diff-files --quiet &&
38 git diff-index --cached HEAD --) ||
39 die "Git submodule has dirty files"
40 (cd / &&
41 git update-index --refresh &&
42 git diff-files --quiet &&
43 git diff-index --cached HEAD --) ||
44 die "msysGit super project not up-to-date"
47 create_msysgit_tag () {
48 i=0 &&
49 while ! git tag -a -m "Git for Windows $1" \
50 $(git describe HEAD | cut -d- -f1).msysgit.$i
52 i=$[$i+1]
53 done
56 # compile everything needed for standard setup
57 test "$do_compile" && {
58 wordpad /share/WinGit/ReleaseNotes.rtf && {
59 # create a commit if ReleaseNotes changed
60 if test ! -z "$(git diff /share/WinGit/ReleaseNotes.rtf)"
61 then
62 git add /share/WinGit/ReleaseNotes.rtf &&
63 git commit -m "Git for Windows $version"
64 fi &&
65 (cd /git &&
66 create_msysgit_tag $version &&
67 make install) &&
68 (cd /src/git-cheetah/explorer/ && make)
69 } || exit 1
72 test -z "$force" && {
73 die () {
74 echo "$*" >&2
75 echo "If that is okay, please call '$0 -f $version'" >&2
76 exit 1
79 (cd /git &&
80 git update-index --refresh &&
81 git diff-files --quiet &&
82 git diff-index --cached HEAD --) ||
83 die "Git submodule has dirty files"
84 (cd /git &&
85 test git.exe = $(ls -t git.exe $(git ls-files) | head -n 1)) ||
86 die "Git's git.exe is not up-to-date (run 'cd /git && make' to fix)"
87 for f in /bin/git* /libexec/git-core/git*
89 case "$f" in
90 *.manifest)
91 continue
93 */gitk)
94 basename=gitk-git/gitk
96 */git-citool|*/git-gui)
97 basename=git-gui/git-gui
99 */git-gui--askpass|*/git-gui.tcl)
100 basename=git-gui/$(basename "$f")
103 basename=$(basename "$f")
105 esac
106 cmp "$f" "/git/$basename" ||
107 die "Installed Git disagrees with contents of /git/ ($f)"
108 done
109 (cd / &&
110 git update-index --refresh &&
111 git diff-files --quiet &&
112 git diff-index --cached HEAD --) ||
113 die "msysGit super project not up-to-date"
114 (cd /git &&
115 test ! -z "$(git tag --contains HEAD)") ||
116 die "Git's HEAD is untagged"
119 TMPDIR=/tmp/WinGit
120 unset DONT_REMOVE_BUILTINS
122 /share/WinGit/copy-files.sh $TMPDIR &&
123 sed -e '/share\/msysGit/d' -e "s/msysGit/Git (version $version)/" \
124 < /etc/motd > $TMPDIR/etc/motd &&
125 cp /share/resources/gpl-2.0.rtf /share/resources/git.bmp /share/resources/gitsmall.bmp $TMPDIR &&
126 homewinpath=$(cd ~ ; pwd -W) &&
127 sed -e "s/%APPVERSION%/$version/" -e "s@%OUTPUTDIR%@$homewinpath@" \
128 < /share/WinGit/install.iss > $TMPDIR/install.iss &&
129 cp /share/WinGit/*.inc.iss $TMPDIR &&
130 echo "Launching Inno Setup compiler ..." &&
131 (/share/InnoSetup/ISCC.exe "$TMPDIR/install.iss" -q > /tmp/install.out;
132 echo $? > /tmp/install.status) &&
133 (grep -Ev "\s*Reading|\s*Compressing" < /tmp/install.out;
134 test 0 = "$(cat /tmp/install.status)") &&
135 (cd / && git tag -a -m "Git for Windows $1" Git-$1) &&
136 echo "Installer is available as $homewinpath/Git-$version.exe"