Fix typo in release script
[platform/upstream/nasm.git] / misc / release
1 #!/bin/bash -xe
2 #
3 # Generate a NASM release
4 #
5 # Usage: release {test|real} [branch]
6 #
7
8 if [ -z "$SFUSER" ]; then
9   if [ -f "$HOME/.sfuser" ]; then
10     sfuser=`cat "$HOME/.sfuser"`
11   else
12     sfuser=`whoami`
13   fi
14 fi
15
16 if [ -z "$1" ]; then
17   echo "Usage: $0 {test|real}" 1>&2
18   exit 1
19 fi
20
21 if [ "$1" = "real" ]; then
22   real=true
23 else
24   real=false
25 fi
26
27 work=`pwd`/nasm-release.$$
28 mkdir "$work"
29 cd "$work"
30
31 if $real; then
32   # Need to tag the tree, use real account
33   CVS="cvs -z3 -d ${SFUSER}@cvs.nasm.sourceforge.net:/cvsroot/nasm"
34 else
35   # Don't need to tag the tree, can use anonymous
36   echo ':pserver:anonymous@cvs.nasm.sourceforge.net:/cvsroot/nasm A' > "$work"/cvspass
37   export CVS_PASSFILE="$work"/cvspass
38   CVS="cvs -z3 -d :pserver:anonymous@cvs.nasm.sourceforge.net:/cvsroot/nasm"
39 fi
40
41 if [ -n "$2" ]; then
42   branchopt="-r $2"
43 fi
44
45 rm -rf nasm*
46
47 $CVS co $branchopt nasm
48 version=`cat nasm/version`
49 v1=`echo $version | cut -d. -f1`
50 v2=`echo $version | cut -d. -f2`
51 v3=`echo $version | cut -d. -f3`
52
53 # Tag the tree as a release
54 if $real; then
55   cd nasm && $CVS tag -F -a nasm-`echo $version | sed -e 's/\./_/g'`
56 fi
57
58 # Extract file names which have the -kb flag set, meaning they
59 # are binary files
60 bins="$work"/binaries
61 rm -f "$bins"
62 cd nasm
63 find . -type d -name CVS -print | (
64     while read dir; do
65        xdir=`echo "$dir" | sed -e 's|^\./||' -e 's|/CVS$||'`
66        egrep '^/[^/]*/[^/]*/[^/]*/[^/]*-kb[^/]*/' < $dir/Entries | \
67            cut -d/ -f2 | sed -e "s|^|$xdir/|" >> "$bins"
68     done
69 )
70 cd ..
71
72 # We did "co" instead of "export" -- remove CVS directories
73 find nasm -type d -name CVS -print | xargs rm -rf
74
75 # Create files which are in the release but automatically generated
76 cd nasm
77 autoconf
78 ./configure --prefix=/usr/local
79 make dist
80 cd ..
81
82 # Clean up any previous attempt
83 rm -f ../nasm-${version}.tar.gz  ../nasm-${version}-xdoc.tar.gz
84 rm -f ../nasm-${version}.tar.bz2 ../nasm-${version}-xdoc.tar.bz2
85 rm -f ../nasm-${version}.zip     ../nasm-${version}-xdoc.zip
86
87 # Create tarfile (Unix convention: file includes prefix)
88 mv nasm nasm-$version
89 tar cvvf  nasm-${version}.tar nasm-${version}
90 bzip2 -9k nasm-${version}.tar
91 gzip -9   nasm-${version}.tar
92 mv nasm-${version}.tar.gz nasm-${version}.tar.bz2 ..
93
94 # Create zipfile (DOS convention: no prefix, convert file endings)
95 cd nasm-$version
96 zip -9Dlr ../../nasm-${version}.zip -x@"$bins" *        # Text files
97 zip -9Dgr ../../nasm-${version}.zip -i@"$bins" *        # Binary files
98 cd ..
99
100 # Record what we have already generated
101 find nasm-$version -not -type d -print > main
102
103 # Create documentation
104 cd nasm-${version}
105 ./configure --prefix=/usr/local
106 make doc
107 # The .hpj and .rtf files are used to generate a Windows .hlp file.
108 # That requires Windows tools, so that has to be done separately anyway.
109 rm -f doc/nasmdoc.hpj doc/nasmdoc.rtf
110 cd ..
111
112 # Remove non-documentation
113 cat main | xargs rm -f
114
115 # Create doc tarfile
116 tar cvvf nasm-${version}-xdoc.tar nasm-${version}/doc
117 bzip2 -9k nasm-${version}-xdoc.tar
118 gzip -9   nasm-${version}-xdoc.tar
119 mv nasm-${version}-xdoc.tar.gz nasm-${version}-xdoc.tar.bz2 ..
120
121 # Create doc zipfile (DOS convention: no prefix, convert file endings)
122 # (Note: generating Win .hlp files requires additional tools)
123 cd nasm-${version}
124 zip -9Dlr ../../nasm-${version}-xdoc.zip doc -x \*.pdf
125 zip -9Dgr ../../nasm-${version}-xdoc.zip doc -i \*.pdf
126
127 # Clean up
128 cd ..
129 rm -rf "$work"