9 # For some reason, solaris sh exits as soon as both stderr and stdout
10 # are redirected to file at the exec, so if we run on solaris, use ksh
20 if [ "`uname`" = "SunOS" ]
32 echo "Usage: ${PROGNAME} <configfile>" >&2;
51 [ -f "${SCRIPTDIR}/common.sh" ] || { echo "Broken config ?" >&2; exit 1; }
52 . "${SCRIPTDIR}"/common.sh
55 STAMP="`date +%Y%m%d%H%M%S`"
56 WORKDIR="${EMPTARGET}.${ARCH}"
57 [ -n "${EXTRASUFFIX}" ] && WORKDIR="${WORKDIR}.${EXTRASUFFIX}"
58 LOGFILE="${LOGDIR}/${WORKDIR}.${STAMP}"
69 BOXDIR="${SCRIPTDIR}/${BOXDIR}"
73 cd "${BOXDIR}" || err "Could not chdir to ${BOXDIR}"
75 echo "Nightly build starting at `date`"
80 mkdir "${WORKDIR}" || warn "Could not create ${BOXDIR}/${WORKDIR}"
81 cd "${WORKDIR}" || err "Could not cd to ${BOXDIR}/${WORKDIR}"
83 echo "Getting source from CVS:"
86 while ! cvs -z3 -d:ext:"${SFLOGIN}"@cvs.sourceforge.net:/cvsroot/empserver co empserver >/dev/null
88 sleep "`expr 5 + ${RETR}`"
89 RETR="`expr 1 + ${RETR}`"
90 [ "${RETR}" -gt 100 ] && err "CVS Timeout after ${RETR} retres."
95 # Run local patches ${LOCALPATCHDIR}/*.patch
96 case "${LOCALPATCHDIR}"
101 LOCALPATCHDIR="${SCRIPTDIR}/${LOCALPATCHDIR}"
105 if [ -n "${LOCALPATCHDIR}" -a -d "${LOCALPATCHDIR}/." ]
107 echo "Applying local patches from ${LOCALPATCHDIR}:"
108 for i in "${LOCALPATCHDIR}"/*.patch
110 if patch -Np0 < "${i}" >/dev/null
114 echo "========== ${i}: NOT OK! ${?} =========="
121 cd empserver || err "Could not cd to ${BOXDIR}/${WORKDIR}/empserver."
124 echo "Preparing build.conf"
125 sed -e "s,^USERNAME = .*$,USERNAME = ${EMPLOGIN}," \
126 -e "s,^HOSTNAME = .*$,HOSTNAME = localhost," \
127 -e "s,^IPADDR = .*$,IPADDR = 127.0.0.1," \
128 -e "s,^EMPDIR = .*$,EMPDIR = ${BOXDIR}/${WORKDIR}/emp4," \
129 < build.conf > build.conf.new && \
130 mv build.conf.new build.conf || \
131 err "Could not prep build.conf"
132 echo "Done (build.conf)."
135 # TODO: this should be fixed another way...
136 echo "Generating empty Makedepends."
137 touch src/client/Makedepend src/doconfig/Makedepend src/lib/as/Makedepend src/lib/commands/Makedepend src/lib/common/Makedepend src/lib/empthread/Makedepend src/lib/gen/Makedepend src/lib/global/Makedepend src/lib/lwp/Makedepend src/lib/player/Makedepend src/lib/subs/Makedepend src/lib/update/Makedepend src/server/Makedepend src/util/Makedepend || err "Could tot touch Makedepends"
142 echo "Building server"
143 if make "${EMPTARGET}" >/dev/null
145 warn "make did not return 0."
150 # Try to run startup utilities
151 if [ -d ../emp4 -a -d ../emp4/bin -a -d ../emp4/data ]
153 cd ../emp4/bin || err "Could not cd to ../emp4/bin"
154 echo "Determining type of files in bindir"
156 echo "Done (file *)."
158 echo "Running files and fairland"
159 echo y | ./files || warn "Error running files"
160 ./fairland 10 30 >/dev/null || warn "Error running fairland"
161 echo "Done (files & fairland)."
166 echo "Cleaning sandbox"
167 cd "${BOXDIR}" || err "Could not cd back to sanbox root !"
168 rm -r "${WORKDIR}" || warn "Directory ${WORKDIR} could not be cleanly removed !"
169 rm -rf "${WORKDIR}" || warn "Directory ${WORKDIR} could not be forcibly removed !"
170 [ -d "${WORKDIR}/." ] && warn "Directory ${WORKDIR} still present"
171 echo "Done (cleaning)."
173 echo "Nightly build finished at `date`"