VERSION="\
Build package utility from PLD CVS repository
-V 0.11 (C) 1999-2003 Free Penguins".
+V 0.11 (C) 1999-2004 Free Penguins".
PATH="/bin:/usr/bin:/usr/sbin:/sbin:/usr/X11R6/bin"
COMMAND="build"
GETLOCAL="cp -a"
if (rpm --version 2>&1 | grep -q '4.0.[0-2]'); then
- RPM="rpm"
- RPMBUILD="rpm"
+ RPM="rpm"
+ RPMBUILD="rpm"
else
- RPM="rpm"
- RPMBUILD="rpmbuild"
+ RPM="rpm"
+ RPMBUILD="rpmbuild"
fi
POLDEK_INDEX_DIR="`$RPM --eval %_rpmdir`/"
POLDEK_SOURCE="cvs"
-POLDEK_CMD="/usr/bin/poldek"
+POLDEK_CMD="/usr/bin/poldek --noask"
# Here we load saved user environment used to
# predefine options set above, or passed to builder
# in command line.
# This one reads global system environment settings:
if [ -f ~/etc/builderrc ]; then
- . ~/etc/builderrc
+ . ~/etc/builderrc
fi
# And this one cascades settings using user personal
# builder settings.
#LOGFILE='../LOGS/log.$PACKAGE_NAME.$DATE'
#
if [ -n "$HOME_ETC" ]; then
- USER_CFG=$HOME_ETC/.builderrc
+ USER_CFG="$HOME_ETC/.builderrc"
else
USER_CFG=~/.builderrc
fi
-[ -f $USER_CFG ] && . $USER_CFG
+[ -f "$USER_CFG" ] && . "$USER_CFG"
run_poldek()
{
-nu, --no-urls - don't try to download from FTP/HTTP location,
-ns, --no-srcs - don't download Sources
-ns0, --no-source0 - don't download Source0
+-nn, --no-net - don't download anything from the net
--opts <rpm opts> - additional options for rpm
-q, --quiet - be quiet,
--date yyyy-mm-dd - build package using resources from specified CVS date,
PATCHES="`rpm_dump | awk '/PATCHURL[0-9]+/ {print $3}'`"
ICONS="`awk '/^Icon:/ {print $2}' ${SPECFILE}`"
- PACKAGE_NAME="`$RPM -q --qf '%{NAME}\n' --specfile ${SPECFILE} 2> /dev/null | head -1`"
- PACKAGE_VERSION="`$RPM -q --qf '%{VERSION}\n' --specfile ${SPECFILE} 2> /dev/null| head -1`"
- PACKAGE_RELEASE="`$RPM -q --qf '%{RELEASE}\n' --specfile ${SPECFILE} 2> /dev/null | head -1`"
+ PACKAGE_NAME="`$RPM -q --qf '%{NAME}\n' --specfile ${SPECFILE} 2> /dev/null | head -n 1`"
+ PACKAGE_VERSION="`$RPM -q --qf '%{VERSION}\n' --specfile ${SPECFILE} 2> /dev/null| head -n 1`"
+ PACKAGE_RELEASE="`$RPM -q --qf '%{RELEASE}\n' --specfile ${SPECFILE} 2> /dev/null | head -n 1`"
if [ -n "$BE_VERBOSE" ]; then
echo "- Sources : `nourl $SOURCES`"
set -v;
fi
+ CWD="$(pwd)"
+ cd "$SPECS_DIR"
+ if [ \! -f "$SPECFILE" ]; then
+ SPECFILE="`basename $SPECFILE .spec`.spec";
+ fi
+ cd "$CWD"
if [ "$NOCVSSPEC" != "yes" ]; then
- cd $SPECS_DIR
+ cd "$SPECS_DIR"
OPTIONS="up "
rpm_dump | \
grep "SOURCEURL[0-9]*[ ]*$1""[ ]*$" | \
sed -e 's/.*SOURCEURL\([0-9][0-9]*\).*/\1/' | \
- head -1 | xargs
+ head -n 1 | xargs
}
src_md5 ()
cd $SPECS_DIR
spec_rev=$(grep $SPECFILE CVS/Entries | sed -e s:/$SPECFILE/:: -e s:/.*::)
if [ -z "$spec_rev" ]; then
- spec_rev="$(head -1 $SPECFILE | sed -e 's/.*\$Revision: \([0-9.]*\).*/\1/')"
+ spec_rev="$(head -n 1 $SPECFILE | sed -e 's/.*\$Revision: \([0-9.]*\).*/\1/')"
fi
spec="$SPECFILE[0-9.,]*,$(echo $spec_rev | sed 's/\./\\./g')"
md5=$(grep -s -v '^#' additional-md5sums | \
if [ $(echo "$md5" | wc -l) != 1 ] ; then
echo "$SPECFILE: more then one entry in additional-md5sums for $1" 1>&2
fi
- echo "$md5" | tail -1
+ echo "$md5" | tail -n 1
fi
}
echo "$PROTOCOL$DISTFILES_SERVER/by-md5/$(src_md5 "$1" | sed -e 's|^\(.\)\(.\)|\1/\2/&|')/$(basename "$1")"
}
+distfiles_attic_url ()
+{
+ echo "$PROTOCOL$DISTFILES_SERVER/Attic/by-md5/$(src_md5 "$1" | sed -e 's|^\(.\)\(.\)|\1/\2/&|')/$(basename "$1")"
+}
+
good_md5 ()
{
md5=$(src_md5 "$1")
fi
if [ -n "$1$2$3$4$5$6$7$8$9${10}" ]; then
- cd $SOURCE_DIR
+ cd "$SOURCE_DIR"
OPTIONS="up "
if [ -n "$CVSROOT" ]; then
fi
target=$(nourl "$i")
url=$(distfiles_url "$i")
+ url_attic=$(distfiles_attic_url "$i")
+ FROM_DISTFILES=1
if [ `echo $url | grep -E '^(\.|/)'` ]; then
${GETLOCAL} $url $target
else
- FROM_DISTFILES=1
if [ -z "$NOMIRRORS" ]; then
url="`find_mirror "$url"`"
fi
if [ `echo $url | grep -E 'ftp://'` ]; then
${GETURI2} -O "$target" "$url"
fi
- if ! test -s "$target"; then
- rm -f "$target"
- FROM_DISTFILES=0
+ fi
+ if ! test -s "$target"; then
+ rm -f "$target"
+ if [ `echo $url_attic | grep -E '^(\.|/)'` ]; then
+ ${GETLOCAL} $url_attic $target
+ else
+ if [ -z "$NOMIRRORS" ]; then
+ url_attic="`find_mirror "$url_attic"`"
+ fi
+ ${GETURI} -O "$target" "$url_attic" || \
+ if [ `echo $url_attic | grep -E 'ftp://'` ]; then
+ ${GETURI2} -O "$target" "$url_attic"
+ fi
fi
fi
+ if ! test -s "$target"; then
+ rm -f "$target"
+ FROM_DISTFILES=0
+ fi
elif [ -z "$(src_md5 "$i")" -a "$NOCVS" != "yes" ]; then
# ( echo $i | grep -qvE '(ftp|http|https)://' ); -- if CVS should be used, but URLs preferred
result=1
fi
done
fi
-
+
if [ -z "$NOURLS" ] && [ ! -f "`nourl $i`" -o -n "$UPDATE" ] && [ `echo $i | grep -E 'ftp://|http://|https://'` ]; then
if [ -z "$NOMIRRORS" ]; then
im="`find_mirror "$i"`"
fi
fi
-
fi
srcno=$(src_no $i)
if [ ! -f "`nourl $i`" -a "$FAIL_IF_NO_SOURCES" != "no" ]; then
if [ `echo $url | grep -E 'ftp://'` ]; then
${GETURI2} -O "$target" "$url"
fi
+ if ! test -s "$target"; then
+ rm -f "$target"
+ ${GETURI} -O "$target" "$url_attic" || \
+ if [ `echo $url_attic | grep -E 'ftp://'` ]; then
+ ${GETURI2} -O "$target" "$url_attic"
+ fi
+ fi
test -s "$target" || rm -f "$target"
fi
OPTIONS="-d $CVSROOT $OPTIONS"
fi
- cd $SOURCE_DIR
+ cd "$SOURCE_DIR"
for i in $TAG_FILES
do
- # don't tag non cvs files (ie. stored on distfiles)
- [ "`nourl $i`" != "$i" ] && continue
+ # don't tag files stored on distfiles
+ [ -n "`src_md5 $i`" ] && continue
if [ -f "`nourl $i`" ]; then
if [ "$TAG_VERSION" = "yes" ]; then
cvs $OPTIONS $TAGVER `nourl $i`
fi
done
- cd $SPECS_DIR
+ cd "$SPECS_DIR"
if [ "$TAG_VERSION" = "yes" ]; then
cvs $OPTIONS $TAGVER $SPECFILE
fi
if [ -n "$CVSROOT" ]; then
OPTIONS="-d $CVSROOT $OPTIONS"
fi
- cd $SOURCE_DIR
+ cd "$SOURCE_DIR"
for i in $TAG_FILES
do
if [ -f `nourl $i` ]; then
Exit_error err_no_source_in_repo $i
fi
done
- cd $SPECS_DIR
+ cd "$SPECS_DIR"
cvs $OPTIONS $TAG $SPECFILE
unset OPTIONS
set -v;
fi
- cd $SPECS_DIR
+ cd "$SPECS_DIR"
if [ -n "$TRY_UPGRADE" ]; then
if [ -n "$FLOAT_VERSION" ]; then
unset TOLDVER TNEWVER TNOTIFY
fi
fi
- cd $SPECS_DIR
+ cd "$SPECS_DIR"
case "$COMMAND" in
build )
esac
if [ -n "$LOGFILE" ]; then
LOG=`eval echo $LOGFILE`
+ if [ -d "$LOG" ]; then
+ echo "Log file $LOG is a directory."
+ echo "Parse error in the spec?"
+ Exit_error err_build_fail;
+ fi
if [ -n "$LASTLOG_FILE" ]; then
echo "LASTLOG=$LOG" > $LASTLOG_FILE
fi
if [ "$BCOND" != "" ]; then
echo -ne "$BCOND"
else
- echo -ne "No --with || --without conditions passed to $0!"
+ echo -ne "No --with || --without conditions passed to $0"
fi
echo -ne "\n\nfrom available:\n\n"
echo -ne "--with :\t$AVAIL_BCONDS_WITH\n--without:\t$AVAIL_BCONDS_WITHOUT\n\n"
NOSRCS="yes"; shift ;;
-ns0 | --no-source0 )
NOSOURCE0="yes"; shift ;;
+ -nn | --no-net )
+ NOCVS="yes"
+ NOCVSSPEC="yes"
+ NODIST="yes"
+ NOMIRRORS="yes"
+ NOURLS="yes"
+ NOSRCS="yes"
+ shift;;
--opts )
shift; RPMOPTS="${1}"; shift ;;
--with | --without )
RPMOPTS="${RPMOPTS} --nodeps"
;;
* )
- SPECFILE="`basename ${1} .spec`.spec";
+ SPECFILE="${1}"
export PROMPT_COMMAND=`echo -ne "\033]0;${SPECFILE}\007"`
shift ;;
esac
fi
;;
"tag" )
+ NOURLS=1
+ NODIST=1
init_builder;
if [ -n "$SPECFILE" ]; then
get_spec;
new_SOURCES=""
for file in $SOURCES
do
- [ "`nourl $file`" != "$file" ] && continue
+ [ -n "`src_md5 $file`" ] && continue
new_SOURCES="$new_SOURCES $file"
done
SOURCES="$new_SOURCES"