3 # Buildpkg script for producing RPM packages. (Does not require root access.)
4 # Buildpkg is designed to be used by both buildbot (to automate rpm production)
5 # and by J Random User (to build an rpm for kicks). The odd way of handling
6 # all optioins through environment variables is a product of buildbot.
8 # AMVER: the version of amanda we're working on. This will become part of the
9 # rpm name. AMVER must line up with the version number mentioned in the
11 # PKG_DIR: Rpmbuild expects absolute paths, so we provide this var. It also
12 # allows you to build somewhere other than `pwd`. You probably don't want
13 # to use the system-wide location, as the script tries to blow these
17 # Not everyone will want to use the ./configure options we provide. The
18 # easiest way to change them is by editing the .spec file. This isn't so
19 # easy, unfortunately. Look at the %build section, and the %define xxxx
20 # statements immediately above it. good luck.
22 # This is useful for debugging
24 # Check for $AMVER, or pull it from configure.in
25 if [ -z $AMVER ]; then
26 VER=`cat FULL_VERSION`
30 PKG_TARBALL=${AMVER}.tar.gz
31 if [ ! -f "${PKG_TARBALL}" ]; then
32 mkdir ${AMVER} || exit 1
34 tar -cf ${PKG_TARBALL} -z ${AMVER} || exit 1
35 rm -rf ${AMVER} || exit 1
38 # Check for the packaging dirs.
39 if [ -z "$PKG_DIR" ]; then
42 if [ ! -d ${PKG_DIR} ]; then
43 mkdir ${PKG_DIR} || exit 1
55 mkdir rpm/RPMS || exit 1
57 # Make a copy of the tarball in the rpmbuild location
58 cp ${PKG_TARBALL} rpm/SOURCES/${PKG_TARBALL} || exit 1
59 cp packaging/rpm/amanda.spec rpm/SPECS || exit 1
60 # Rpmbuild requires absolute paths. annoying. If you need to change the
61 # default value of some rpm.spec variable, just pass extra --define options.
62 # this is useful for changing %amanda_release or %amanda_version
63 rpmbuild -ba --define "_topdir ${PKG_DIR}/rpm" \
64 ${PKG_DIR}/rpm/SPECS/amanda.spec || exit 1
65 cp rpm/RPMS/*/*.rpm . || exit 1
66 cp rpm/SRPMS/*.rpm . || exit 1