3 # Generate a NASM release
5 # Usage: release version [destination]
10 echo "Usage: $0 version [destination]" 1>&2
15 if [ -z "$WHERE" ]; then
19 if [ -n "$GIT_DIR" ]; then
25 if [ x`cat version` != x"${version}" ]; then
26 echo "${version}" > version
27 git update-index version
28 git commit -m "Version ${version}" -- version
30 git tag -m "NASM version ${version}" -f "nasm-${version}"
38 git clone -s -l "$HERE" nasm
39 rm -rf nasm/.git nasm/.gitignore
41 # Create files which are in the release but automatically generated
44 ./configure --prefix=/usr/local
50 # Clean up any previous attempt
51 rm -f ../nasm-"$version".tar.gz ../nasm-"$version"-xdoc.tar.gz
52 rm -f ../nasm-"$version".tar.bz2 ../nasm-"$version"-xdoc.tar.bz2
53 rm -f ../nasm-"$version".zip ../nasm-"$version"-xdoc.zip
55 # Create tarfile (Unix convention: file includes prefix)
56 mv nasm nasm-"$version"
57 tar cvvf nasm-"$version".tar nasm-"$version"
58 bzip2 -9k nasm-"$version".tar
59 gzip -9 nasm-"$version".tar
60 mv nasm-"$version".tar.gz nasm-"$version".tar.bz2 ..
62 # Create zipfile (DOS convention: no prefix, convert file endings)
64 zip -9Dlr ../../nasm-"$version".zip * -x \*.jpg -x \*.zip # Text files
65 zip -9Dgr ../../nasm-"$version".zip * -i \*.jpg -i \*.zip # Binary files
68 # Record what we have already generated
69 find nasm-"$version" -not -type d -print > main
71 # Create documentation
73 ./configure --prefix=/usr/local
75 # Remove intermediate files.
79 # Remove non-documentation
80 cat main | xargs rm -f
83 tar cvvf nasm-"$version"-xdoc.tar nasm-"$version"/doc
84 bzip2 -9k nasm-"$version"-xdoc.tar
85 gzip -9 nasm-"$version"-xdoc.tar
86 mv nasm-"$version"-xdoc.tar.gz nasm-"$version"-xdoc.tar.bz2 ..
88 # Create doc zipfile (DOS convention: no prefix, convert file endings)
89 # (Note: generating Win .hlp files requires additional tools)
91 zip -9Dlr ../../nasm-"$version"-xdoc.zip doc -x \*.pdf
92 zip -9Dgr ../../nasm-"$version"-xdoc.zip doc -i \*.pdf