X-Git-Url: http://git.pld-linux.org/?a=blobdiff_plain;f=builder.sh;h=edc1fac45662656f3130a20d52d037d3b731cb16;hb=7605fe955fadcae244bd3abb16e1d733285189d9;hp=a466ef6be379136ccc4ad8a620e37ab23652bee8;hpb=560c4b1a39a445afdcb79b55f8383187669c179a;p=packages%2Frpm-build-tools.git diff --git a/builder.sh b/builder.sh old mode 100644 new mode 100755 index a466ef6..edc1fac --- a/builder.sh +++ b/builder.sh @@ -17,25 +17,35 @@ # 9 - Requested tag already exist # 10 - Refused to build fractional release # 100 - Unknown error (should not happen) +# 110 - Functions not yet implemented # Notes (todo/bugs): -# - builder -u fetches current version first (well that's okay, how you compare versions if you have no old spec?) # - when Icon: field is present, -5 and -a5 doesn't work # - builder -R skips installing BR if spec is not present before builder invocation (need to run builder twice) # - does not respect NoSource: X, and tries to cvs up such files [ example: VirtualBox-bin.spec and its Source0 ] # TODO: # - ability to do ./builder -bb foo.spec foo2.spec foo3.spec - -RCSID='$Id$' -r=${RCSID#* * } -rev=${r%% *} +# - funny bug, if source-md5 is set then builder will download from distfiles even if there is no url present: +# Source10: forwardfix.pl +# # Source10-md5: 8bf85f7368933a4e0cb4f875bac28733 +# - builder --help: +# basename: missing operand +# Try `basename --help' for more information. +# -- and the normal usage info -- + +PROGRAM=${0##*/} +APPDIR=$(d=$0; [ -L "$d" ] && d=$(readlink -f "$d"); dirname "$d") +RCSID='$Id: builder,v 1.645 2011/02/13 17:54:10 glen Exp $' r=${RCSID#* * } rev=${r%% *} VERSION="v0.35/$rev" VERSIONSTRING="\ -Build package utility from PLD Linux CVS repository -$VERSION (C) 1999-2009 Free Penguins". +Build package utility from PLD Linux Packages repository +$VERSION (C) 1999-2011 Free Penguins". PATH="/bin:/usr/bin:/usr/sbin:/sbin:/usr/X11R6/bin" +# required rpm-build-macros +RPM_MACROS_VER=1.534 + COMMAND="build" TARGET="" @@ -45,7 +55,6 @@ QUIET="" CLEAN="" DEBUG="" NOURLS="" -NOCVS="" NOCVSSPEC="" NODIST="" NOINIT="" @@ -54,8 +63,6 @@ UPDATE="" ADD5="" NO5="" ALWAYS_CVSUP=${ALWAYS_CVSUP:-"yes"} -CVSROOT="" -GREEDSRC="" # use rpm 4.4.6+ digest format instead of comments if non-zero USEDIGEST= @@ -67,6 +74,9 @@ USER_AGENT="PLD/Builder($VERSION)" # See LOGFILE example. DATE=`date +%Y-%m-%d_%H-%M-%S` +# target arch, can also be used for log file naming +TARGET=$(rpm -E %{_target}) + # Example: LOGFILE='../log.$PACKAGE_NAME' # Example: LOGFILE='../LOGS/log.$PACKAGE_NAME.$DATE' # Example: LOGFILE='$PACKAGE_NAME/$PACKAGE_NAME.$DATE.log' @@ -87,7 +97,7 @@ BCOND="" GROUP_BCONDS="no" # create symlinks for tools in PACKAGE_DIR, see get_spec() -SYMLINK_TOOLS="yes" +SYMLINK_TOOLS="no" PATCHES="" SOURCES="" @@ -96,15 +106,25 @@ PACKAGE_RELEASE="" PACKAGE_VERSION="" PACKAGE_NAME="" ASSUMED_NAME="" -PROTOCOL="ftp" +PROTOCOL="http" + +# use lftp by default when available +USE_LFTP= +lftp --version > /dev/null 2>&1 && USE_LFTP=yes + WGET_RETRIES=${MAX_WGET_RETRIES:-0} -CVS_COMMAND=${CVS_COMMAND:-cvs} CVS_FORCE="" CVSIGNORE_DF="yes" -CVS_RETRIES=${MAX_CVS_RETRIES:-1000} -CVS_SERVER="cvs.pld-linux.org" CVSTAG="" +GIT_SERVER="git://carme.pld-linux.org" +GIT_PUSH="draenog@carme.pld-linux.org" +PACKAGES_DIR="packages" +HEAD_DETACHED="" +DEPTH="" +ALL_BRANCHES="" +REMOTE_PLD="origin" +NEW_REPO="" RES_FILE="" @@ -135,6 +155,7 @@ else fi fi +UPDATE_POLDEK_INDEXES_OPTS="" # Here we load saved user environment used to # predefine options set above, or passed to builder @@ -148,6 +169,7 @@ fi # Example of ~/.builderrc: # #UPDATE_POLDEK_INDEXES="yes" +#UPDATE_POLDEK_INDEXES_OPTS="--mo=nodiff" #FETCH_BUILD_REQUIRES="yes" #REMOVE_BUILD_REQUIRES="force" #GROUP_BCONDS="yes" @@ -181,6 +203,10 @@ elif [ -n "$USE_AXEL" ]; then GETURI="axel -a $AXEL_OPTS" GETURI2="$GETURI" OUTFILEOPT="-o" +elif [ -n "$USE_LFTP" ]; then + GETURI=download_lftp + GETURI2=$GETURI + OUTFILEOPT="" else wget --help 2>&1 | grep -q -- ' --no-check-certificate ' && WGET_OPTS="$WGET_OPTS --no-check-certificate" wget --help 2>&1 | grep -q -- ' --inet ' && WGET_OPTS="$WGET_OPTS --inet" @@ -194,7 +220,7 @@ fi GETLOCAL="cp -a" -if (rpm --version 2>&1 | grep -q '4.0.[0-2]'); then +if rpm --version 2>&1 | grep -q '4.0.[0-2]'; then RPM="rpm" RPMBUILD="rpm" else @@ -203,17 +229,19 @@ else fi # -# are we using cvs-nserver ? +# sanity checks # -CVS_NSERVER=0 -$CVS_COMMAND --version 2>&1 | grep -q 'CVS-nserver' -[ $? -eq 0 ] && CVS_NSERVER=1 +if [ -d $HOME/rpm/SOURCES ]; then + echo "ERROR: ~/rpm/{SPECS,SOURCES} structure is obsolete" >&2 + echo "ERROR: get rid of your ~/rpm/SOURCES" >&2 + exit 1 +fi POLDEK_INDEX_DIR="$($RPM --eval %_rpmdir)/" POLDEK_CMD="$SU_SUDO /usr/bin/poldek --noask" run_poldek() { - RES_FILE=$(mktemp -t builder.XXXXXX || ${TMPDIR:-/tmp}/builder.$RANDOM) + RES_FILE=$(tempfile) if [ -n "$LOGFILE" ]; then LOG=`eval echo $LOGFILE` if [ -n "$LASTLOG_FILE" ]; then @@ -231,78 +259,102 @@ run_poldek() { #--------------------------------------------- # functions +download_lftp() { + local outfile=$1 url=$2 retval tmpfile + # TODO: use mktemp + tmpfile=$outfile.tmp + lftp -c " + $([ "$DEBUG" = "yes" ] && echo "debug 5;") + set ssl:verify-certificate no; + set net:max-retries $WGET_RETRIES; + set http:user-agent \"$USER_AGENT\"; + pget -n 10 -c \"$url\" -o \"$tmpfile\" + " + + retval=$? + if [ $retval -eq 0 ]; then + mv -f "$tmpfile" "$outfile" + else + rm -f "$tmpfile" + fi + return $retval +} + usage() { if [ -n "$DEBUG" ]; then set -xv; fi echo "\ -Usage: builder [-D|--debug] [-V|--version] [--short-version] [-a|--as_anon] [-b|-ba|--build] +Usage: builder [--all-branches] [-D|--debug] [-V|--version] [--short-version] [-a|--add_cvs] [-b|-ba|--build] [-bb|--build-binary] [-bs|--build-source] [-bc] [-bi] [-bl] [-u|--try-upgrade] -[{-cf|--cvs-force}] [{-B|--branch} ] [{-d|--cvsroot} ] -[-g|--get] [-h|--help] [--http] [{-l|--logtofile} ] [-m|--mr-proper] -[-q|--quiet] [--date [-r ] [{-T|--tag ] +[{-cf|--cvs-force}] [{-B|--branch} ] [--depth ] +[-g|--get] [-h|--help] [--ftp] [--http] [{-l|--logtofile} ] [-m|--mr-proper] +[-q|--quiet] [--date [-r ] [{-T|--tag ] [-Tvs|--tag-version-stable] [-Ts|--tag-stable] [-Tv|--tag-version] -[{-Tp|--tag-prefix} ] [{-tt|--test-tag}] [--use-greed-sources] +[{-Tp|--tag-prefix} ] [{-tt|--test-tag}] [-nu|--no-urls] [-v|--verbose] [--opts ] [--short-circuit] [--show-bconds] [--with/--without ] [--define ] -[.spec][:cvstag] +[.spec][:tag] +-4 - force ipv4 when transferring files -5, --update-md5 - update md5 comments in spec, implies -nd -ncs +-6 - force ipv6 when transferring files -a5, --add-md5 - add md5 comments to URL sources, implies -nc -nd -ncs +--all-branches - make shallow fetch of all branches; --depth required -n5, --no-md5 - ignore md5 comments in spec -D, --debug - enable builder script debugging mode, -debug - produce rpm debug package (same as --opts -debug) -V, --version - output builder version string --short-version - output builder short version --a, --as_anon - get files via pserver as cvs@$CVS_SERVER, --b, -ba, --build - get all files from CVS repo or HTTP/FTP and build package +-a, --add_vcs - try add new package to PLD repo. +-b, -ba, --build - get all files from PLD repo or HTTP/FTP and build package from .spec, --bb, --build-binary - get all files from CVS repo or HTTP/FTP and build binary +-bb, --build-binary - get all files from PLD repo or HTTP/FTP and build binary only package from .spec, -bp, --build-prep - execute the %prep phase of .spec, -bc - execute the %build phase of .spec, -bi - execute the %install phase of .spec --bl - execute the %files phase of .spec --bs, --build-source - get all files from CVS repo or HTTP/FTP and only pack +-bl - execute the %files phase of .spec +-bs, --build-source - get all files from PLD repo or HTTP/FTP and only pack them into src.rpm, --short-circuit - short-circuit build -B, --branch - add branch --c, --clean - clean all temporarily created files (in BUILD, SOURCES, - SPECS and \$RPM_BUILD_ROOT and CVS/Entries) after rpmbuild commands. +-c, --clean - clean all temporarily created files (in BUILD\$RPM_BUILD_ROOT) after rpmbuild commands. + may be used with building process. -m, --mr-proper - clean all temporarily created files (in BUILD, SOURCES, - SPECS and \$RPM_BUILD_ROOT and CVS/Entries). Doesn't run - any rpm building. --cf, --cvs-force - use -F when tagging (useful when moving branches) --d , --cvsroot - - setup \$CVSROOT, + SPECS and \$RPM_BUILD_ROOT). Doesn't run any rpm building. +-cf, --cvs-force - use -f when tagging --define - define a macro with value , +--depth - make shallow fetch --alt_kernel - same as --define 'alt_kernel ' --nodeps - rpm won't check any dependences --g, --get - get .spec and all related files from CVS repo +-g, --get - get .spec and all related files from PLD repo or HTTP/FTP, -h, --help - this message, ---http - use http instead of ftp, +-jN, -j N - set %_smp_mflags to propagate concurrent jobs +--ftp, --http - use ftp or http protocol to access distfiles server -l , --logtofile - log all to file, --nc, --no-cvs - don't download sources from CVS, if source URL is given, -ncs, --no-cvs-specs - - don't check specs in CVS + - don't pull from PLD repo -nd, --no-distfiles - don't download from distfiles -nm, --no-mirrors - don't download from mirror, if source URL is given, -nu, --no-urls - don't try to download from FTP/HTTP location, -ns, --no-srcs - don't download Sources/Patches -ns0, --no-source0 - don't download Source0 -nn, --no-net - don't download anything from the net --pm, --prefer-mirrors - prefer mirrors (if any) over distfiles for SOURCES +-pm, --prefer-mirrors + - prefer mirrors (if any) over distfiles for SOURCES --no-init - don't initialize builder paths (SPECS and SOURCES) -ske, ---skip-existing-files - skip existing files in get_files +--skip-existing-files + - skip existing files in get_files --opts - additional options for rpm -q, --quiet - be quiet, ---date yyyy-mm-dd - build package using resources from specified CVS date, --r , --cvstag - - build package using resources from specified CVS tag, --A - build package using CVS resources as any sticky tags/date/kopts being reset. +--date yyyy-mm-dd - build package using resources from specified date, +-r , --cvstag + - build package using resources from specified branch/tag, +-A - build package using master branch as any sticky tags/branch/date being reset. -R, --fetch-build-requires - fetch what is BuildRequired, -RB, --remove-build-requires @@ -311,30 +363,33 @@ Usage: builder [-D|--debug] [-V|--version] [--short-version] [-a|--as_anon] [-b| -FRB, --force-remove-build-requires - remove all you fetched with -R or --fetch-build-requires remember, this option works without confirmation, --sd, --source-distfiles - list sources available from distfiles (intended for offline +-sd, --source-distfiles + - list sources available from distfiles (intended for offline operations; does not work when Icon field is present but icon file is absent), --sc, --source-cvs - list sources available from CVS --sdp, --source-distfiles-paths - list sources available from distfiles - +-sc, --source-cvs - list sources available from PLD repo +-sdp, --source-distfiles-paths + - list sources available from distfiles - paths relative to distfiles directory (intended for offline operations; does not work when Icon field is present but icon file is absent), -sf, --source-files - list sources - bare filenames (intended for offline operations; does not work when Icon field is present but icon file is absent), --sp, --source-paths - list sources - filenames with full local paths (intended for +-lsp, --source-paths + - list sources - filenames with full local paths (intended for offline operations; does not work when Icon field is present but icon file is absent), -su, --source-urls - list urls - urls to sources and patches intended for copying urls with spec with lots of macros in urls --T , --tag - - add cvs tag for files, +-T , --tag + - add git tag for files, -Tvs, --tag-version-stable - - add cvs tags STABLE and NAME-VERSION-RELEASE for files, + - add git tags STABLE and NAME-VERSION-RELEASE for files, -Ts, --tag-stable - - add cvs tag STABLE for files, + - add git tag STABLE for files, -Tv, --tag-version - - add cvs tag NAME-VERSION-RELEASE for files, + - add git tag NAME-VERSION-RELEASE for files, -Tp, --tag-prefix - add to NAME-VERSION-RELEASE tags, -tt, --test-tag @@ -345,30 +400,69 @@ Usage: builder [-D|--debug] [-V|--version] [--short-version] [-a|--as_anon] [-b| -u, --try-upgrade - check version, and try to upgrade package -un, --try-upgrade-with-float-version - as above, but allow float version ---use-greed-sources - - try download source from tag head if don't find it in - current tag + php-pear-Services_Digg/ +--upgrade-version - upgrade to specified version in try-upgrade -U, --update - refetch sources, don't use distfiles, and update md5 comments -Upi, --update-poldek-indexes - refresh or make poldek package index files. +-sp, --skip-patch + - don't apply . may be repeated. -np, --nopatch - - don't apply + - abort instead of applying patch --show-bconds - show available conditional builds, which can be used - with --with and/or --without switches. ---show-bcond-args - show active bconds, from ~/.bcondrc. this is used by - ./repackage.sh script. in other words, the output is - parseable by scripts. +--show-bcond-args - show active bconds, from ~/.bcondrc. this is used by ./repackage.sh script. + In other words, the output is parseable by scripts. +--show-avail-bconds - show available bconds --with/--without - conditional build package depending on %_with_/ %_without_ macro switch. You may now use --with feat1 feat2 feat3 --without feat4 feat5 --with feat6 constructions. Set GROUP_BCONDS to yes to make use of it. --target , --target= - - build for platform . ---init-rpm-dir - initialize ~/rpm directory structure + - build for platform . +--init-rpm-dir - initialize ~/rpm directory structure " } +# create tempfile. as secure as possible +tempfile() { + mktemp -t builder.XXXXXX || ${TMPDIR:-/tmp}/builder.$RANDOM.$$ +} + +tempdir() { + mktemp -d builder.XXXXXX +} + +# inserts git log instead of %changelog +# outputs name of modified file created by tempfile +insert_gitlog() { + local SPECFILE=$1 specdir=$(tempdir) gitlog=$(tempfile) speclog=$(tempfile) + + # allow this being customized + local log_entries=$(rpm -E '%{?_buildchangelogtruncate}') + + # rpm5.org/rpm.org do not parse any other date format than 'Wed Jan 1 1997' + # otherwise i'd use --date=iso here + # http://rpm5.org/cvs/fileview?f=rpm/build/parseChangelog.c&v=2.44.2.1 + # http://rpm.org/gitweb?p=rpm.git;a=blob;f=build/parseChangelog.c#l31 + # NOTE: changelog date is always in UTC for rpmbuild + # * 1265749244 +0000 Random Hacker 9370900 + git rev-list -${log_entries:-20} HEAD | while read sha1; do + local logfmt='%B%n' + git notes list $sha1 &> /dev/null && logfmt=%N + git log -n 1 $sha1 --format=format:"* %ad %an <%ae> %h%n${logfmt}%n" --date=raw | sed '/^$/q' + done > $gitlog + gawk '/^\* /{printf("* %s %s\n", strftime("%a %b %d %Y", $2), substr($0, length($1)+length($2)+length($3)+4)); next}{print}' $gitlog > $speclog + sed '/^%changelog/,$d' $SPECFILE | sed -e "\${ + a%changelog + r $speclog + } + " > $specdir/$SPECFILE + rm -f $gitlog $speclog + echo $specdir +} + # change dependency to specname # common changes: # - perl(Package::Name) -> perl-Package-Name @@ -382,13 +476,13 @@ depspecname() { update_shell_title() { [ -t 1 ] || return local len=${COLUMNS:-80} - local msg=$(echo "$*" | cut -c-$len) + local msg="$(echo "$*" | cut -c-$len)" if [ -n "$BE_VERBOSE" ]; then echo >&2 "$(date +%s.%N) $*" fi - if [ "x$TITLECHANGE" == "xyes" -o "x$TITLECHANGE" == "x" ]; then + if [ "x$TITLECHANGE" = "xyes" -o "x$TITLECHANGE" = "x" ]; then local pkg if [ -n "$PACKAGE_NAME" ]; then pkg=${PACKAGE_NAME}-${PACKAGE_VERSION}-${PACKAGE_RELEASE} @@ -438,16 +532,20 @@ minirpm() { %x8664 x86_64 amd64 ia32e %alt_kernel %{nil} %_alt_kernel %{nil} -%requires_releq_kernel_up %{nil} -%requires_releq_kernel_smp %{nil} -%requires_releq_kernel %{nil} +%bootstrap_release() %{1} +%requires_releq_kernel_up(s:n:) %{nil} +%requires_releq_kernel_smp(s:n:) %{nil} +%requires_releq_kernel(s:n:) %{nil} %requires_releq() %{nil} %pyrequires_eq() %{nil} %requires_eq() %{nil} %requires_eq_to() %{nil} -%releq_kernel_up ERROR -%releq_kernel_smp ERROR -%releq_kernel ERROR +%requires_ge() %{nil} +%requires_ge_to() %{nil} +%requires_ge() %{nil} +%releq_kernel_up(n:) ERROR +%releq_kernel_smp(n:) ERROR +%releq_kernel(n:) ERROR %kgcc_package ERROR %_fontsdir ERROR %ruby_version ERROR @@ -480,6 +578,9 @@ minirpm() { %remove_etc_shells(p) %{p:} %lua_add_etc_shells() %{nil} %lua_remove_etc_shells() %{nil} +%required_jdk %{nil} +%buildrequires_jdk %{nil} +%pear_package_print_optionalpackages %{nil} EOF if [ "$NOINIT" = "yes" ] ; then cat >> $BUILDER_MACROS <<'EOF' @@ -542,7 +643,7 @@ rpm_dump() { get_icons() { update_shell_title "get icons" - ICONS=$(awk '/^Icon:/ {print $2}' ${ASSUMED_NAME}/${SPECFILE}) + ICONS=$(awk '/^Icon:/ {print $2}' $PACKAGE_DIR/${SPECFILE}) if [ -z "$ICONS" ]; then return fi @@ -563,7 +664,7 @@ parse_spec() { cd $PACKAGE_DIR cache_rpm_dump - if (rpm_dump | grep -qEi ":.*nosource.*1"); then + if rpm_dump | grep -qEi ":.*nosource.*1"; then FAIL_IF_NO_SOURCES="no" fi @@ -619,11 +720,14 @@ Exit_error() { exit 2 ;; "err_no_spec_in_repo" ) remove_build_requires - echo >&2 "Error: spec file not stored in CVS repo." + echo >&2 "Error: spec file not stored in PLD repo." exit 3 ;; "err_no_source_in_repo" ) remove_build_requires - echo >&2 "Error: some source, patch or icon files not stored in CVS repo. ($2)" + echo >&2 "Error: some source, patch or icon files not stored in PLD repo. ($2)" + exit 4 ;; + "err_cvs_add_failed" ) + echo >&2 "Error: failed to add package to PLD repo." exit 4 ;; "err_build_fail" ) remove_build_requires @@ -635,7 +739,7 @@ Exit_error() { exit 6 ;; "err_tag_exists" ) remove_build_requires - echo >&2 "Tag ${2} already exists (spec release: ${3})." + echo >&2 "Tag ${2} already exists" exit 9 ;; "err_fract_rel" ) remove_build_requires @@ -649,6 +753,14 @@ Exit_error() { remove_build_requires echo >&2 "Error: conditions reject building this spec (${2})." exit 12 ;; + "err_remote_problem" ) + remove_build_requires + echo >&2 "Error: problem with remote (${2})" + exit 13 ;; + "err_not_implemented" ) + remove_build_requires + echo >&2 "Error: functionality not yet imlemented" + exit 110 ;; esac echo >&2 "Unknown error." exit 100 @@ -662,16 +774,66 @@ init_builder() { if [ "$NOINIT" != "yes" ] ; then TOP_DIR=$(eval $RPM $RPMOPTS --eval '%{_topdir}') - REPO_DIR=$TOP_DIR/packages - PACKAGE_DIR=$TOP_DIR/packages/$ASSUMED_NAME + + local macros_ver=$(rpm -E %?rpm_build_macros) + if [ -z "$macros_ver" ]; then + REPO_DIR=$TOP_DIR/packages + PACKAGE_DIR=$TOP_DIR/packages/$ASSUMED_NAME + else + if awk "BEGIN{exit($macros_ver>=$RPM_MACROS_VER)}"; then + echo >&2 "builder requires rpm-build-macros >= $RPM_MACROS_VER" + exit 1 + fi + REPO_DIR=$TOP_DIR + PACKAGE_DIR=$REPO_DIR/$ASSUMED_NAME + fi else REPO_DIR="." PACKAGE_DIR="." fi + export GIT_WORK_TREE=$PACKAGE_DIR + export GIT_DIR=$PACKAGE_DIR/.git + + if [ -d "$GIT_DIR" ] && [ -z "$CVSTAG" ]; then + if CVSTAG=$(GIT_DIR=$GIT_DIR git symbolic-ref HEAD) 2>/dev/null; then + CVSTAG=${CVSTAG#refs/heads/} + if [ "$CVSTAG" != "master" ]; then + echo >&2 "builder: Active branch $CVSTAG. Use -r BRANCHNAME to override" + fi + else + echo >&2 "On detached HEAD. Use -r BRANCHNAME to override" + HEAD_DETACHED="yes" + fi + elif [ "$CVSTAG" = "HEAD" ]; then + # assume -r HEAD is same as -A + CVSTAG="master" + fi __PWD=$(pwd) } +create_git_repo() { + update_shell_title "add_package" + + if [ -n "$DEBUG" ]; then + set -x + set -v + fi + + cd "$REPO_DIR" + SPECFILE=$(basename $SPECFILE) + if [ ! -f "$ASSUMED_NAME/$SPECFILE" ]; then + echo "ERROR: No package to add ($ASSUMED_NAME/$SPECFILE)" >&2 + exit 101 + fi + [ -d "$ASSUMED_NAME/.git" ] || NEW_REPO=yes + # ssh $GIT_SERVER create ${ASSUMED_NAME} || Exit_error err_cvs_add_failed + git init + git remote add $REMOTE_PLD ${GIT_SERVER}/${PACKAGES_DIR}/${ASSUMED_NAME}.git && \ + git remote set-url --push $REMOTE_PLD ssh://${GIT_PUSH}/${PACKAGES_DIR}/${ASSUMED_NAME} \ + || Exit_error err_remote_problem $REMOTE_PLD +} + get_spec() { update_shell_title "get_spec" @@ -683,33 +845,83 @@ get_spec() { cd "$REPO_DIR" if [ ! -f "$ASSUMED_NAME/$SPECFILE" ]; then - SPECFILE="$(basename $SPECFILE .spec).spec" + # XXX: still needed? + SPECFILE=$(basename $SPECFILE) fi - if [ "$NOCVSSPEC" != "yes" ]; then - if [ ! -s CVS/Root -a "$NOCVSSPEC" != "yes" ]; then - echo "Warning: No CVS access defined - using local .spec file" - NOCVSSPEC="yes" + if [ "$NOCVSSPEC" != "yes" ]; then + if [ -z "$DEPTH" ]; then + if [ -d "$ASSUMED_NAME/.git" ]; then + git fetch $REMOTE_PLD || Exit_error err_no_spec_in_repo + elif [ "$ADD_PACKAGE_CVS" = "yes" ]; then + if [ ! -r "$ASSUMED_NAME/$SPECFILE" ]; then + echo "ERROR: No package to add ($ASSUMED_NAME/$SPECFILE)" >&2 + exit 101 + fi + Exit_error err_not_implemented + else + ( + unset GIT_WORK_TREE + git clone -o $REMOTE_PLD ${GIT_SERVER}/${PACKAGES_DIR}/${ASSUMED_NAME}.git || { + # softfail if new package, i.e not yet added to PLD rep + [ ! -f "$ASSUMED_NAME/$SPECFILE" ] && Exit_error err_no_spec_in_repo + echo "Warning: package not in CVS - assuming new package" + NOCVSSPEC="yes" + } + git remote set-url --push $REMOTE_PLD ssh://${GIT_PUSH}/${PACKAGES_DIR}/${ASSUMED_NAME} + ) + fi + else + if [ ! -d "$ASSUMED_NAME/.git" ]; then + if [ ! -d "$ASSUMED_NAME" ]; then + mkdir $ASSUMED_NAME + fi + git init + git remote add $REMOTE_PLD ${GIT_SERVER}:${PACKAGES_DIR}/${ASSUMED_NAME}.git + CVSTAG=${CVSTAG:-"master"} + fi + local refs='' + if [ -z "$ALL_BRANCHES" ]; then + refs="${CVSTAG}:remotes/${REMOTE_PLD}/${CVSTAG}" + fi + git fetch $DEPTH $REMOTE_PLD $refs || { + echo >&2 "Error: branch $CVSTAG does not exist" + exit 3 + } fi + git fetch $REMOTE_PLD 'refs/notes/*:refs/notes/*' - if [ -d "$ASSUMED_NAME" ]; then - cvsup "$ASSUMED_NAME/$SPECFILE" || Exit_error err_no_spec_in_repo - else - cvsup -c -d $ASSUMED_NAME "packages/$ASSUMED_NAME/$SPECFILE" || Exit_error err_no_spec_in_repo - - # remove Entries.Static -- so 'cvs up' would update all files in a repo - rm "$ASSUMED_NAME/CVS/Entries.Static" - cvsignore_df .cvsignore - - # create symlinks for tools - if [ "$SYMLINK_TOOLS" != "no" ]; then - for a in dropin md5 adapter builder {relup,compile,repackage,rsync}.sh; do - [ -f $a ] || continue - ln -s ../$a $ASSUMED_NAME - cvsignore_df $a - done + cvsignore_df .gitignore + + # add default log format to .gitignore if it is relative to package dir + if [ -n "$LOGFILE" -a "$LOGFILE" = "${LOGFILE##*/}" ]; then + # substitute known "macros" to glob + local logfile=$(echo "$LOGFILE" | sed -e 's,\$\(PACKAGE_NAME\|DATE\),*,g') + if [ "$logfile" ]; then + cvsignore_df "$logfile" fi fi + + # create symlinks for tools + if [ "$SYMLINK_TOOLS" != "no" ]; then + for a in dropin md5 adapter builder {relup,compile,repackage,pearize}.sh pldnotify.awk; do + # skip tools that don't exist in top dir + [ -f $a ] || continue + # skip tools that already exist + [ -f $ASSUMED_NAME/$a ] && continue + ln -s ../$a $ASSUMED_NAME + cvsignore_df $a + done + fi + fi + + if [ -n "$CVSTAG" ]; then + git checkout "$CVSTAG" -- 2>/dev/null || git checkout -t "${REMOTE_PLD}/$CVSTAG" > /dev/null || exit + git symbolic-ref -q HEAD > /dev/null && + git merge '@{u}' + if [ -n "$CVSDATE" ]; then + git checkout $(git rev-list -n1 --before="'$CVSDATE'" $CVSTAG) || exit 1 + fi fi if [ ! -f "$ASSUMED_NAME/$SPECFILE" ]; then @@ -728,15 +940,15 @@ get_spec() { find_mirror() { cd "$REPO_DIR" local url="$1" - if [ ! -f "mirrors" -a "$NOCVSSPEC" != "yes" ] ; then - $CVS_COMMAND update mirrors >&2 + if [ ! -f "mirrors" ] ; then + ln -s rpm-build-tools/mirrors . fi IFS="|" local origin mirror name rest ol prefix while read origin mirror name rest; do # skip comments and empty lines - if [ -z "$origin" ] || [[ $origin == \#* ]]; then + if [ -z "$origin" ] || [ "${origin#\#}" != "$origin" ]; then continue fi ol=$(echo -n "$origin" | wc -c) @@ -752,11 +964,14 @@ find_mirror() { # Warning: unpredictable results if same URL used twice src_no() { + local file="$1" + # escape some regexp characters if part of file name + file=$(echo "$file" | sed -e 's#\([\+\*\.\&\#\?]\)#\\\1#g') cd $PACKAGE_DIR rpm_dump | \ - grep "SOURCEURL[0-9]*[ ]*$1""[ ]*$" | \ - sed -e 's/.*SOURCEURL\([0-9][0-9]*\).*/\1/' | \ - head -n 1 | xargs + grep -E "(SOURCE|PATCH)URL[0-9]*[ ]*${file}""[ ]*$" | \ + sed -e 's/.*\(SOURCE\|PATCH\)URL\([0-9][0-9]*\).*/\1\2/' | \ + head -n 1 | tr OURCEATH ourceath | xargs } src_md5() { @@ -767,13 +982,8 @@ src_md5() { local md5 if [ -f additional-md5sums ]; then - local spec_rev=$(grep $SPECFILE CVS/Entries 2>/dev/null | sed -e s:/$SPECFILE/:: -e s:/.*::) - if [ -z "$spec_rev" ]; then - spec_rev=$(head -n 1 $SPECFILE | sed -e 's/.*\$Revision: \([0-9.]*\).*/\1/') - fi - local spec="$SPECFILE[0-9.,]*,$(echo $spec_rev | sed 's/\./\\./g')" md5=$(grep -s -v '^#' additional-md5sums | \ - grep -E "[ ]$(basename "$1")[ ]+${spec}([ ,]|\$)" | \ + grep -E "[ ]$(basename "$1")([ ,]|\$)" | \ sed -e 's/^\([0-9a-f]\{32\}\).*/\1/' | \ grep -E '^[0-9a-f]{32}$') @@ -786,7 +996,7 @@ src_md5() { fi fi - source_md5=`grep -i "#[ ]*Source$no-md5[ ]*:" $SPECFILE | sed -e 's/.*://'` + source_md5=`grep -i "^#[ ]*$no-md5[ ]*:" $SPECFILE | sed -e 's/.*://'` if [ -n "$source_md5" ]; then echo $source_md5 else @@ -796,7 +1006,7 @@ src_md5() { else # we have empty SourceX-md5, but it is still possible # that we have NoSourceX-md5 AND NoSource: X - nosource_md5=`grep -i "#[ ]*NoSource$no-md5[ ]*:" $SPECFILE | sed -e 's/.*://'` + nosource_md5=`grep -i "^#[ ]*No$no-md5[ ]*:" $SPECFILE | sed -e 's/.*://'` if [ -n "$nosource_md5" -a -n "`grep -i "^NoSource:[ ]*$no$" $SPECFILE`" ] ; then echo $nosource_md5 fi @@ -831,7 +1041,7 @@ cvsignore_df() { if [ "$CVSIGNORE_DF" != "yes" ]; then return fi - cvsignore=${PACKAGE_DIR}/.cvsignore + cvsignore=${PACKAGE_DIR}/.gitignore # add only if not yet there if ! awk -vf="$1" -vc=1 '$0 == f { c = 0 } END { exit c }' $cvsignore 2>/dev/null; then @@ -839,54 +1049,6 @@ cvsignore_df() { fi } -cvsup() { - update_shell_title "cvsup" - local OPTIONS="up " - - if [ "$1" = "-c" ]; then - OPTIONS="co " - shift - fi - if [ -n "$CVSROOT" ]; then - OPTIONS="-d $CVSROOT $OPTIONS" - fi - - if [ -z "$CVSDATE" -a -z "$CVSTAG" ]; then - OPTIONS="$OPTIONS -A" - else - if [ -n "$CVSDATE" ]; then - OPTIONS="$OPTIONS -D $CVSDATE" - fi - if [ -n "$CVSTAG" ]; then - OPTIONS="$OPTIONS -r $CVSTAG" - fi - fi - - local result=1 - local retries_counter=0 - if [ $# = 1 ]; then - update_shell_title "cvsup: $*" - else - update_shell_title "cvsup: $# files" - fi - while [ "$result" != "0" -a "$retries_counter" -le "$CVS_RETRIES" ]; do - retries_counter=$(( $retries_counter + 1 )) - output=$(LC_ALL=C $CVS_COMMAND $OPTIONS "$@" 2>&1) - result=$? - [ -n "$output" ] && echo "$output" - if (echo "$output" | grep -qE "(Cannot connect to|connect to .* failed|Connection reset by peer|Connection timed out|Unknown host)") && [ "$result" -ne "0" -a "$retries_counter" -le "$CVS_RETRIES" ]; then - echo "Trying again [$*]... ($retries_counter)" - update_shell_title "cvsup: retry #$retries_counter" - sleep 2 - continue - else - break - fi - done - update_shell_title "cvsup: done!" - return $result -} - # returns true if "$1" is ftp, http or https protocol url is_url() { case "$1" in @@ -918,10 +1080,10 @@ update_md5() { local srcno=$(src_no "$i") if [ -n "$ADD5" ]; then [ "$fp" = "$i" ] && continue # FIXME what is this check doing? - grep -qiE '^#[ ]*Source'$srcno'-md5[ ]*:' $PACKAGE_DIR/$SPECFILE && continue + grep -qiE '^#[ ]*'$srcno'-md5[ ]*:' $PACKAGE_DIR/$SPECFILE && continue grep -qiE '^BuildRequires:[ ]*digest[(]%SOURCE'$srcno'[)][ ]*=' $PACKAGE_DIR/$SPECFILE && continue else - grep -qiE '^#[ ]*Source'$srcno'-md5[ ]*:' $PACKAGE_DIR/$SPECFILE || grep -qiE '^BuildRequires:[ ]*digest[(]%SOURCE'$srcno'[)][ ]*=' $PACKAGE_DIR/$SPECFILE || continue + grep -qiE '^#[ ]*'$srcno'-md5[ ]*:' $PACKAGE_DIR/$SPECFILE || grep -qiE '^BuildRequires:[ ]*digest[(]%SOURCE'$srcno'[)][ ]*=' $PACKAGE_DIR/$SPECFILE || continue fi if [ ! -f "$fp" ] || [ $ALWAYS_CVSUP = "yes" ]; then need_files="$need_files $i" @@ -937,22 +1099,22 @@ update_md5() { for i in "$@"; do local fp=$(nourl "$i") local srcno=$(src_no "$i") - local md5=$(grep -iE '^#[ ]*(No)?Source'$srcno'-md5[ ]*:' $PACKAGE_DIR/$SPECFILE ) + local md5=$(grep -iE '^#[ ]*(No)?'$srcno'-md5[ ]*:' $PACKAGE_DIR/$SPECFILE ) if [ -z "$md5" ]; then md5=$(grep -iE '^[ ]*BuildRequires:[ ]*digest[(]%SOURCE'$srcno'[)][ ]*=' $PACKAGE_DIR/$SPECFILE ) fi if [ -n "$ADD5" ] && is_url $i || [ -n "$md5" ]; then - local tag="# Source$srcno-md5:\t" + local tag="# $srcno-md5:\t" if [[ "$md5" == *NoSource* ]]; then - tag="# NoSource$srcno-md5:\t" + tag="# No$srcno-md5:\t" elif [ -n "$USEDIGEST" ]; then tag="BuildRequires:\tdigest(%SOURCE$srcno) = " fi md5=$(md5sum "$fp" | cut -f1 -d' ') - echo "Updating Source$srcno ($md5: $fp)." + echo "Updating $srcno ($md5: $fp)." perl -i -ne ' - print unless (/^\s*#\s*(No)?Source'$srcno'-md5\s*:/i or /^\s*BuildRequires:\s*digest\(%SOURCE'$srcno'\)/i); - print "'"$tag$md5"'\n" if /^Source'$srcno'\s*:\s+/; + print unless (/^\s*#\s*(No)?'$srcno'-md5\s*:/i or /^\s*BuildRequires:\s*digest\(%SOURCE'$srcno'\)/i); + print "'"$tag$md5"'\n" if /^'$srcno'\s*:\s+/i; ' \ $PACKAGE_DIR/$SPECFILE fi @@ -960,18 +1122,27 @@ update_md5() { } check_md5() { + local bad [ "$NO5" = "yes" ] && return update_shell_title "check md5" for i in "$@"; do - if good_md5 "$i" && good_size "$i"; then - continue + bad=0 + if ! good_md5 "$i"; then + echo -n "MD5 sum mismatch." + bad=1 + fi + if ! good_size "$i"; then + echo -n "0 sized file." + bad=1 fi - echo "MD5 sum mismatch or 0 size. Use -U to refetch sources," - echo "or -5 to update md5 sums, if you're sure files are correct." - Exit_error err_no_source_in_repo $i + if [ $bad -eq 1 ]; then + echo " Use -U to refetch sources," + echo "or -5 to update md5 sums, if you're sure files are correct." + Exit_error err_no_source_in_repo $i + fi done } @@ -986,11 +1157,6 @@ get_files() { if [ $# -gt 0 ]; then cd "$PACKAGE_DIR" - if [ ! -s CVS/Root -a "$NOCVS" != "yes" ]; then - echo "Warning: No CVS access defined for SOURCES" - NOCVS="yes" - fi - local nc=0 local get_files_cvs="" for i in "$@"; do @@ -1083,14 +1249,6 @@ get_files() { rm -f "$target" FROM_DISTFILES=0 fi - elif [ "$NOCVS" != "yes" -a -z "$srcmd5" ]; then - if [ $# -gt 1 ]; then - get_files_cvs="$get_files_cvs $fp" - update_shell_title "$fp (will cvs up later)" - cvsup=1 - else - cvsup $fp - fi fi if [ -z "$NOURLS" ] && [ ! -f "$fp" -o -n "$UPDATE" ] && [ "`echo $i | grep -E 'ftp://|http://|https://'`" ]; then @@ -1100,10 +1258,10 @@ get_files() { im="$i" fi update_shell_title "${GETURI%% *}: $im" - ${GETURI} "$im" ${OUTFILEOPT} "$target" || \ + ${GETURI} ${OUTFILEOPT} "$target" "$im" || \ if [ "`echo $im | grep -E 'ftp://'`" ]; then update_shell_title "${GETURI2%% *}: $im" - ${GETURI2} "$im" ${OUTFILEOPT} "$target" + ${GETURI2} ${OUTFILEOPT} "$target" "$im" fi test -s "$target" || rm -f "$target" fi @@ -1116,11 +1274,7 @@ get_files() { # the md5 check must be moved elsewhere as if we've called from update_md5 the md5 is wrong. if [ ! -f "$fp" -a "$FAIL_IF_NO_SOURCES" != "no" ]; then - if [ -n "GREEDSRC" ]; then - get_greed_sources $i - else - Exit_error err_no_source_in_repo $i - fi + Exit_error err_no_source_in_repo $i fi # we check md5 here just only to refetch immediately @@ -1152,9 +1306,6 @@ get_files() { done SHELL_TITLE_PREFIX="" - if [ "$get_files_cvs" ]; then - cvsup $get_files_cvs - fi if [ "$CHMOD" = "yes" ]; then CHMOD_FILES=$(nourl "$@") @@ -1165,6 +1316,17 @@ get_files() { fi } +tag_exist() { + _tag="$1" + echo "Searching for tag $_tag..." + if [ -n "$DEPTH" ]; then + local ref=`git ls-remote $REMOTE_PLD "refs/tags/$_tag"` + [ -n "$ref" ] && echo "$ref" && Exit_error err_tag_exists "$_tag" + else + git show-ref "refs/tags/$_tag" && Exit_error err_tag_exists "$_tag" + fi +} + make_tagver() { if [ -n "$DEBUG" ]; then set -x @@ -1190,26 +1352,6 @@ make_tagver() { echo -n "$TAGVER" } -# bool is_tag_a_branch(tag) -# -# returns 1 if a tag is a branch set on SPECFILE -is_tag_a_branch() { - if [ -n "$DEBUG" ]; then - set -x - set -v - fi - - if [ $# -ne 1 ]; then - return 0; - fi - - TAG=$1 - - cd "$PACKAGE_DIR" - $CVS_COMMAND status -v $SPECFILE | grep -Eiq "${TAG}.+(branch: [0-9.]+)" - return $? -} - tag_files() { TAG_FILES="$@" @@ -1224,114 +1366,47 @@ tag_files() { local TAGVER if [ "$TAG_VERSION" = "yes" ]; then TAGVER=`make_tagver` - echo "CVS tag: $TAGVER" + echo "tag: $TAGVER" fi if [ -n "$TAG" ]; then - echo "CVS tag: $TAG" + echo "tag: $TAG" fi local OPTIONS="tag $CVS_FORCE" - if [ -n "$CVSROOT" ]; then - OPTIONS="-d $CVSROOT $OPTIONS" - fi - # if a tagname we are about to set already exists - # and happens to be a branch (common case with AC-branch) - # pass -B (allows -F to disturb branch tag) local _tag=$TAG if [ "$TAG_VERSION" = "yes" ]; then _tag=$TAGVER fi; - is_tag_a_branch $_tag - if [ $? -eq 0 -a $CVS_NSERVER -eq 0 ]; then - OPTIONS="$OPTIONS -B" - fi; cd "$PACKAGE_DIR" - local tag_files - for i in $TAG_FILES; do - # don't tag files stored on distfiles - [ -n "`src_md5 $i`" ] && continue - local fp=`nourl "$i"` - if [ -f "$fp" ]; then - tag_files="$tag_files $fp" - elif [ -n "GREEDSRC" ]; then - get_greed_sources $i - else - Exit_error err_no_source_in_repo $i - fi - done - if [ "$tag_files" ]; then - if [ "$TAG_VERSION" = "yes" ]; then - update_shell_title "tag sources: $TAGVER" - printf "Tagging %d files\n" $(echo $tag_files | wc -w) - $CVS_COMMAND $OPTIONS $TAGVER $tag_files || exit - fi - if [ -n "$TAG" ]; then - update_shell_title "tag sources: $TAG" - - while [ "$tag_files" ]; do - local chunk=$(echo $tag_files | tr ' ' '\n' | head -n 100) - printf "Tagging %d files\n" $(echo $chunk | wc -w) - $CVS_COMMAND $OPTIONS $TAG $chunk || exit - tag_files=$(echo $tag_files | tr ' ' '\n' | tail +101) - done - fi - fi - - cd "$PACKAGE_DIR" if [ "$TAG_VERSION" = "yes" ]; then - update_shell_title "tag spec: $TAGVER" - $CVS_COMMAND $OPTIONS $TAGVER $SPECFILE || exit + update_shell_title "tag sources: $TAGVER" + git $OPTIONS $TAGVER || exit + git push $CVS_FORCE $REMOTE_PLD tag $TAGVER || Exit_error err_remote_problem $REMOTE_PLD fi if [ -n "$TAG" ]; then - update_shell_title "tag spec: $TAG" - $CVS_COMMAND $OPTIONS $TAG $SPECFILE || exit + update_shell_title "tag sources: $TAG" + git $OPTIONS $TAG $chunk || exit + git push $CVS_FORCE $REMOTE_PLD tag $TAG || Exit_error err_remote_problem $REMOTE_PLD fi } branch_files() { TAG=$1 - echo "CVS branch tag: $TAG" + echo "Git branch: $TAG" shift - TAG_FILES="$@" - if [ -n "$DEBUG" ]; then set -x set -v fi - local OPTIONS="tag $CVS_FORCE -b" - - # branch exists? - is_tag_a_branch $TAG - if [ $? -eq 1 ]; then - OPTIONS="$OPTIONS -B" - fi - - if [ -n "$CVSROOT" ]; then - OPTIONS="-d $CVSROOT $OPTIONS" - fi - cd "$PACKAGE_DIR" - local tag_files - for i in $TAG_FILES; do - local fp=`nourl "$i"` - if [ -f "$fp" ]; then - tag_files="$tag_files $fp" - elif [ -n "GREEDSRC" ]; then - get_greed_sources $i - else - Exit_error err_no_source_in_repo $i - fi - done - if [ "$tag_files" ]; then - $CVS_COMMAND $OPTIONS $TAG $tag_files || exit - fi + local OPTIONS="branch $CVS_FORCE" cd "$PACKAGE_DIR" - $CVS_COMMAND $OPTIONS $TAG $SPECFILE || exit + git $OPTIONS $TAG || exit } @@ -1347,41 +1422,89 @@ check_buildarch() { fi } -build_package() { - update_shell_title "build_package" - if [ -n "$DEBUG" ]; then - set -x - set -v - fi +# from relup.sh +set_release() { + local specfile="$1" + local rel="$2" + local newrel="$3" + sed -i -e " + s/^\(%define[ \t]\+_\?rel[ \t]\+\)$rel\$/\1$newrel/ + s/^\(Release:[ \t]\+\)$rel\$/\1$newrel/ + " $specfile +} - cd "$PACKAGE_DIR" +set_version() { + local specfile="$1" + local ver="$2" subver=$ver + local newver="$3" newsubver=$newver + + # try handling subver, everything that's not numeric-dotted in version + if grep -Eq '%define\s+subver' $specfile; then + subver=$(echo "$ver" | sed -re 's,^[0-9.]+,,') + ver=${ver%$subver} + newsubver=$(echo "$newver" | sed -re 's,^[0-9.]+,,') + newver=${newver%$newsubver} + fi + sed -i -e " + s/^\(%define[ \t]\+_\?ver[ \t]\+\)$ver\$/\1$newver/ + s/^\(%define[ \t]\+subver[ \t]\+\)$subver\$/\1$newsubver/ + s/^\(Version:[ \t]\+\)$ver\$/\1$newver/ + " $specfile +} +try_upgrade() { if [ -n "$TRY_UPGRADE" ]; then + local TNOTIFY TNEWVER TOLDVER update_shell_title "build_package: try_upgrade" - if [ -n "$FLOAT_VERSION" ]; then - TNOTIFY=$(./pldnotify.awk $SPECFILE -n) || exit 1 + + cd "$PACKAGE_DIR" + + if [ "$UPGRADE_VERSION" ]; then + TNEWVER=$UPGRADE_VERSION else - TNOTIFY=$(./pldnotify.awk $SPECFILE) || exit 1 - fi + if [ -n "$FLOAT_VERSION" ]; then + TNOTIFY=$($APPDIR/pldnotify.awk ${BE_VERBOSE:+-vDEBUG=1} $SPECFILE -n) || exit 1 + else + TNOTIFY=$($APPDIR/pldnotify.awk ${BE_VERBOSE:+-vDEBUG=1} $SPECFILE) || exit 1 + fi + + # pldnotify.awk does not set exit codes, but it has match for ERROR + # in output which means so. + if [[ "$TNOTIFY" = *ERROR* ]]; then + echo >&2 "$TNOTIFY" + exit 1 + fi - TNEWVER=$(echo $TNOTIFY | awk '{ match($4,/\[NEW\]/); print $5 }') + TNEWVER=$(echo $TNOTIFY | awk '{ match($4,/\[NEW\]/); print $5 }') + fi if [ -n "$TNEWVER" ]; then TOLDVER=`echo $TNOTIFY | awk '{ print $3; }'` - echo "New version found, updating spec file to version " $TNEWVER + echo "New version found, updating spec file from $TOLDVER to version $TNEWVER" if [ "$REVERT_BROKEN_UPGRADE" = "yes" ]; then cp -f $SPECFILE $SPECFILE.bak fi chmod +w $SPECFILE - eval "perl -pi -e 's/Version:\t"$TOLDVER"/Version:\t"$TNEWVER"/gs' $SPECFILE" - eval "perl -pi -e 's/Release:\t[1-9]{0,4}/Release:\t0.1/' $SPECFILE" + set_release $SPECFILE $PACKAGE_RELEASE 1 + set_version $SPECFILE $PACKAGE_VERSION $TNEWVER parse_spec - NODIST="yes" get_files $SOURCES $PATCHES - update_md5 $SOURCES - - unset TOLDVER TNEWVER TNOTIFY + if [ "$PACKAGE_VERSION" != "$TNEWVER" ]; then + echo >&2 "Upgrading version failed, you need to update spec yourself" + exit 1 + fi + return 1 fi fi + return 0 +} + +build_package() { + update_shell_title "build_package" + if [ -n "$DEBUG" ]; then + set -x + set -v + fi + cd "$PACKAGE_DIR" case "$COMMAND" in @@ -1413,11 +1536,12 @@ build_package() { if [ -n "$LASTLOG_FILE" ]; then echo "LASTLOG=$LOG" > $LASTLOG_FILE fi - RES_FILE=$(mktemp -t builder.XXXXXX || ${TMPDIR:-/tmp}/builder.$RANDOM) + RES_FILE=$(tempfile) + local specdir=$(insert_gitlog $SPECFILE) - (time eval ${NICE_COMMAND} $RPMBUILD $TARGET_SWITCH $BUILD_SWITCH -v $QUIET $CLEAN $RPMOPTS $RPMBUILDOPTS $BCOND --define \'_specdir $PACKAGE_DIR\' --define \'_sourcedir $PACKAGE_DIR\' $SPECFILE; echo $? > $RES_FILE) 2>&1 |tee $LOG + (time eval ${NICE_COMMAND} $RPMBUILD $TARGET_SWITCH $BUILD_SWITCH -v $QUIET $CLEAN $RPMOPTS $RPMBUILDOPTS $BCOND --define \'_specdir $PACKAGE_DIR\' --define \'_sourcedir $PACKAGE_DIR\' $specdir/$SPECFILE; echo $? > $RES_FILE) 2>&1 |tee $LOG RETVAL=`cat $RES_FILE` - rm $RES_FILE + rm -r $RES_FILE $specdir if [ -n "$LOGDIROK" ] && [ -n "$LOGDIRFAIL" ]; then if [ "$RETVAL" -eq "0" ]; then mv $LOG $LOGDIROK @@ -1426,15 +1550,19 @@ build_package() { fi fi else - eval ${NICE_COMMAND} $RPMBUILD $TARGET_SWITCH $BUILD_SWITCH -v $QUIET $CLEAN $RPMOPTS $RPMBUILDOPTS $BCOND --define \'_specdir $PACKAGE_DIR\' --define \'_sourcedir $PACKAGE_DIR\' $SPECFILE + local specdir=$(insert_gitlog $SPECFILE) + eval ${NICE_COMMAND} $RPMBUILD $TARGET_SWITCH $BUILD_SWITCH -v $QUIET $CLEAN $RPMOPTS $RPMBUILDOPTS $BCOND --define \'_specdir $PACKAGE_DIR\' --define \'_sourcedir $PACKAGE_DIR\' $specdir/$SPECFILE RETVAL=$? + rm -r $specdir fi if [ "$RETVAL" -ne "0" ]; then if [ -n "$TRY_UPGRADE" ]; then - echo "\n!!! Package with new version cannot be built automagically\n" + echo "\nUpgrade package to new version failed." if [ "$REVERT_BROKEN_UPGRADE" = "yes" ]; then + echo "Restoring old spec file." mv -f $SPECFILE.bak $SPECFILE fi + echo "" fi Exit_error err_build_fail fi @@ -1471,7 +1599,7 @@ process_bcondrc() { # w32codec-installer license_agreement # php +mysqli # --- - if ([ -f $HOME/.bcondrc ] || ([ -n $HOME_ETC ] && [ -f $HOME_ETC/.bcondrc ])); then + if [ -f $HOME/.bcondrc ] || ([ -n $HOME_ETC ] && [ -f $HOME_ETC/.bcondrc ]); then : else return @@ -1517,7 +1645,7 @@ set_bconds_values() { AVAIL_BCONDS_WITHOUT="" AVAIL_BCONDS_WITH="" - if egrep -q '^# *_with' ${SPECFILE}; then + if grep -Eq '^# *_with' ${SPECFILE}; then echo >&2 "ERROR: This spec has old style bconds." exit 1 fi @@ -1536,19 +1664,25 @@ set_bconds_values() { case "$opt" in without_*) bcond=${opt#without_} - if [[ "$BCOND" = *--without?${bcond}* ]]; then + case "$BCOND" in + *--without?${bcond}*) AVAIL_BCONDS_WITHOUT="$AVAIL_BCONDS_WITHOUT <$bcond>" - else + ;; + *) AVAIL_BCONDS_WITHOUT="$AVAIL_BCONDS_WITHOUT $bcond" - fi + ;; + esac ;; with_*) bcond=${opt#with_} - if [[ "$BCOND" = *--with?${bcond}* ]]; then + case "$BCOND" in + *--with?${bcond}*) AVAIL_BCONDS_WITH="$AVAIL_BCONDS_WITH <$bcond>" - else + ;; + *) AVAIL_BCONDS_WITH="$AVAIL_BCONDS_WITH $bcond" - fi + ;; + esac ;; *) echo >&2 "ERROR: unexpected '$opt' in set_bconds_values" @@ -1598,15 +1732,15 @@ spawn_sub_builder() { update_shell_title "spawn_sub_builder $package_name" sub_builder_opts='' - if [ "${FETCH_BUILD_REQUIRES}" == "yes" ]; then + if [ "${FETCH_BUILD_REQUIRES}" = "yes" ]; then sub_builder_opts="${sub_builder_opts} -R" fi - if [ "${REMOVE_BUILD_REQUIRES}" == "nice" ]; then + if [ "${REMOVE_BUILD_REQUIRES}" = "nice" ]; then sub_builder_opts="${sub_builder_opts} -RB" - elif [ "${REMOVE_BUILD_REQUIRES}" == "force" ]; then + elif [ "${REMOVE_BUILD_REQUIRES}" = "force" ]; then sub_builder_opts="${sub_builder_opts} -FRB" fi - if [ "${UPDATE_POLDEK_INDEXES}" == "yes" ]; then + if [ "${UPDATE_POLDEK_INDEXES}" = "yes" ]; then sub_builder_opts="${sub_builder_opts} -Upi" fi @@ -1635,21 +1769,24 @@ remove_build_requires() { display_bconds() { if [ "$AVAIL_BCONDS_WITH" -o "$AVAIL_BCONDS_WITHOUT" ]; then if [ "$BCOND" ]; then - echo -ne "\nBuilding $SPECFILE with the following conditional flags:\n" - echo -ne "$BCOND" + echo "" + echo "Building $SPECFILE with the following conditional flags:" + echo -n "$BCOND" else - echo -ne "\nNo conditional flags passed" + echo "" + echo "No conditional flags passed" fi - echo -ne "\n\nfrom available:\n" - echo -ne "--with :\t$AVAIL_BCONDS_WITH\n--without:\t$AVAIL_BCONDS_WITHOUT\n\n" + echo "" + echo "from available:" + echo "--with :\t$AVAIL_BCONDS_WITH" + echo "--without:\t$AVAIL_BCONDS_WITHOUT" + echo "" fi } display_branches() { - if [ "$NOCVSSPEC" != "yes" ]; then - echo -ne "Available branches: " - $CVS_COMMAND status -v "${SPECFILE}" | awk '!/Sticky Tag:/ && /\(branch:/ { print $1 } ' | xargs - fi + echo -n "Available branches: " + git branch -r | grep "^ ${REMOTE_PLD}" | grep -v ${REMOTE_PLD}/HEAD | sed "s#^ *${REMOTE_PLD}/##" | xargs } # checks a given list of packages/files/provides agains current rpmdb. @@ -1743,10 +1880,12 @@ fetch_build_requires() fi # XXX is this ugliest code written in human history still needed? - echo -ne "\nAll packages installed by fetch_build_requires() are written to:\n" - echo -ne "`pwd`/.${SPECFILE}_INSTALLED_PACKAGES\n" - echo -ne "\nIf anything fails, you may get rid of them by executing:\n" - echo "poldek -e \`cat `pwd`/.${SPECFILE}_INSTALLED_PACKAGES\`\n\n" + echo "All packages installed by fetch_build_requires() are written to:" + echo "`pwd`/.${SPECFILE}_INSTALLED_PACKAGES" + echo "" + echo "If anything fails, you may get rid of them by executing:" + echo "poldek -e \`cat `pwd`/.${SPECFILE}_INSTALLED_PACKAGES\`" + echo "" echo > `pwd`/.${SPECFILE}_INSTALLED_PACKAGES for package_item in $(cat $SPECFILE | grep -B100000 ^%changelog|grep -v ^#|grep BuildRequires|grep -v ^-|sed -e "s/^.*BuildRequires://g"|awk '{print $1}'|sed -e s,perl\(,perl-,g -e s,::,-,g -e s,\(.*\),,g -e s,%{,,g -e s,},,g|grep -v OpenGL-devel|sed -e s,sh-utils,coreutils,g -e s,fileutils,coreutils,g -e s,textutils,coreutils,g -e s,kgcc_package,gcc,g -e s,\),,g) do @@ -1819,11 +1958,11 @@ fetch_build_requires() for package_name in `cat ".$package-req.txt"|grep -v ^#` do if [ "$package_name" = "$package" ]; then - echo -ne "Installing BuildRequired package:\t$package_name\n" + echo "Installing BuildRequired package:\t$package_name" update_shell_title "Installing BuildRequired package: ${package_name}" install_required_packages $package else - echo -ne "Installing (sub)Required package:\t$package_name\n" + echo "Installing (sub)Required package:\t$package_name" update_shell_title "Installing (sub)Required package: ${package_name}" install_required_packages $package_name fi @@ -1834,7 +1973,7 @@ fetch_build_requires() ;; *) echo "Attempting to run spawn sub - builder..." - echo -ne "Package installation failed:\t$package_name\n" + echo "Package installation failed:\t$package_name" run_sub_builder $package_name if [ $? -eq 0 ]; then install_required_packages $package_name @@ -1854,7 +1993,7 @@ fetch_build_requires() rm -f ".$package-req.txt" else echo "Attempting to run spawn sub - builder..." - echo -ne "Package installation failed:\t$package\n" + echo "Package installation failed:\t$package" run_sub_builder $package if [ $? -eq 0 ]; then install_required_packages $package @@ -1886,67 +2025,34 @@ fetch_build_requires() } init_rpm_dir() { - TOP_DIR=$(eval $RPM $RPMOPTS --eval '%{_topdir}') - CVSROOT=":pserver:cvs@$CVS_SERVER:/cvsroot" - - echo "Initialising rpm directories to $TOP_DIR from $CVSROOT" - mkdir -p $TOP_DIR/{RPMS,BUILD,SRPMS} - cd $TOP_DIR - $CVS_COMMAND -d $CVSROOT co packages/{.cvsignore,rpm.groups,dropin,mirrors,md5,adapter{,.awk},fetchsrc_request,builder,{relup,compile,repackage}.sh} - - init_builder - - echo "To checkout *all* .spec files (read-only):" - echo "- run cvs co SPECS" - - echo "To checkout *all* packages:" - echo "- run cvs up -dP in $TOP_DIR/packages dir" - - echo "" - echo "To commit with your developer account:" - echo "- edit $TOP_DIR/packages/CVS/Root" -} + local TOP_DIR=$(eval $RPM $RPMOPTS --eval '%{_topdir}') + local rpmdir=$(eval $RPM $RPMOPTS --eval '%{_rpmdir}') + local buildir=$(eval $RPM $RPMOPTS --eval '%{_builddir}') + local srpmdir=$(eval $RPM $RPMOPTS --eval '%{_srcrpmdir}') + local tmp -get_greed_sources() { - CVSROOT=":pserver:cvs@$CVS_SERVER:/cvsroot" - if [ -n "BE_VERBOSE" ]; then - echo "Try greed download: $1 from: $CVSROOT" - fi - $CVS_COMMAND -d $CVSROOT get SOURCES/$1 - if [ $? != 0 ]; then - Exit_error err_no_source_in_repo $1 - fi - -} + echo "Initializing rpm directories to $TOP_DIR from $GIT_SERVER" + mkdir -p $TOP_DIR $rpmdir $buildir $srpmdir -# remove entries from CVS/Entries -cvs_entry_remove() { - local cvsdir="$1"; shift - if [ ! -d "$cvsdir" ]; then - echo >&2 "cvs_entry_remove: $cvsdir is not a directory" - exit 1 + cd "$TOP_DIR" + if [ ! -e ../rpm-build-tools ]; then + git clone ${GIT_SERVER}:${PACKAGES_DIR}/rpm-build-tools.git ../rpm-build-tools fi - - for file in "$@"; do - rm -f $cvsdir/CVS/Entries.new || return 1 - awk -ve="${file##*/}" -F/ '$2 != e {print}' $cvsdir/CVS/Entries > $cvsdir/CVS/Entries.new || return 1 - mv -f $cvsdir/CVS/Entries.new $cvsdir/CVS/Entries || return 1 + for a in adapter builder; do + ln -s ../rpm-build-tools/${a}.sh $a done - return 0 + init_builder } mr_proper() { init_builder NOCVSSPEC="yes" DONT_PRINT_REVISION="yes" - get_spec - parse_spec - - # remove from CVS/Entries - cvs_entry_remove $PACKAGE_DIR $SPECFILE $SOURCES $PATCHES # remove spec and sources - $RPMBUILD --clean --rmsource --rmspec --nodeps --define \'_specdir $PACKAGE_DIR\' --define \'_sourcedir $PACKAGE_DIR\' $SPECFILE + $RPMBUILD --clean --rmsource --rmspec --nodeps --define "_specdir $PACKAGE_DIR" --define "_sourcedir $PACKAGE_DIR" --define "_builddir $builddir" $PACKAGE_DIR/$SPECFILE + rm -rf $PACKAGE_DIR/{.git,.gitignore} + rmdir --ignore-fail-on-non-empty $PACKAGE_DIR } #--------------------------------------------- @@ -1959,6 +2065,12 @@ fi while [ $# -gt 0 ]; do case "${1}" in + -4|-6) + # NOTE: we should be fetcher specific, like fille WGET_OPTS, but + # unfortunately $GETURI is already formed + GETURI="$GETURI $1" + shift + ;; -5 | --update-md5) COMMAND="update_md5" NODIST="yes" @@ -1967,7 +2079,6 @@ while [ $# -gt 0 ]; do -a5 | --add-md5 ) COMMAND="update_md5" NODIST="yes" - NOCVS="yes" NOCVSSPEC="yes" ADD5="yes" shift ;; @@ -1980,8 +2091,12 @@ while [ $# -gt 0 ]; do COMMAND="version"; shift ;; --short-version ) COMMAND="short-version"; shift ;; - -a | --as_anon ) - CVSROOT=":pserver:cvs@$CVS_SERVER:/cvsroot"; shift ;; + -a | --add_cvs) + COMMAND="add_cvs"; + shift ;; + --all-branches ) + ALL_BRANCHES="yes" + shift ;; -b | -ba | --build ) COMMAND="build"; shift ;; -bb | --build-binary ) @@ -1999,17 +2114,29 @@ while [ $# -gt 0 ]; do -B | --branch ) COMMAND="branch"; shift; TAG="${1}"; shift;; -c | --clean ) - CLEAN="--clean --rmspec --rmsource"; shift ;; + CLEAN="--clean"; shift ;; -cf | --cvs-force ) - CVS_FORCE="-F"; shift;; - -d | --cvsroot ) - shift; CVSROOT="${1}"; shift ;; + CVS_FORCE="-f"; shift;; + --depth ) + DEPTH="--depth=$2" + shift 2 + ;; -g | --get ) COMMAND="get"; shift ;; -h | --help ) COMMAND="usage"; shift ;; + --ftp ) + PROTOCOL="ftp"; shift ;; --http ) PROTOCOL="http"; shift ;; + -j) + RPMOPTS="${RPMOPTS} --define \"_smp_mflags -j$2\"" + shift 2 + ;; + -j[0-9]*) + RPMOPTS="${RPMOPTS} --define \"_smp_mflags $1\"" + shift + ;; -l | --logtofile ) shift; LOGFILE="${1}"; shift ;; -ni| --nice ) @@ -2018,8 +2145,6 @@ while [ $# -gt 0 ]; do SKIP_EXISTING_FILES="yes"; shift ;; -m | --mr-proper ) COMMAND="mr-proper"; shift ;; - -nc | --no-cvs ) - NOCVS="yes"; shift ;; -ncs | --no-cvs-specs ) NOCVSSPEC="yes"; shift ;; -nd | --no-distfiles ) @@ -2033,7 +2158,6 @@ while [ $# -gt 0 ]; do -ns0 | --no-source0 ) NOSOURCE0="yes"; shift ;; -nn | --no-net ) - NOCVS="yes" NOCVSSPEC="yes" NODIST="yes" NOMIRRORS="yes" @@ -2051,6 +2175,8 @@ while [ $# -gt 0 ]; do shift; RPMOPTS="${RPMOPTS} ${1}"; shift ;; --nopatch | -np ) shift; RPMOPTS="${RPMOPTS} --define \"patch${1} : ignoring patch${1}; exit 1; \""; shift ;; + --skip-patch | -sp ) + shift; RPMOPTS="${RPMOPTS} --define \"patch${1} : skiping patch${1}\""; shift ;; --topdir) RPMOPTS="${RPMOPTS} --define \"_topdir $2\"" shift 2 @@ -2084,14 +2210,16 @@ while [ $# -gt 0 ]; do -q | --quiet ) QUIET="--quiet"; shift ;; --date ) - CVSDATE="${2}"; shift 2 ;; + CVSDATE="${2}"; shift 2 + date -d "$CVSDATE" > /dev/null 2>&1 || { echo >&2 "No valid date specified"; exit 3; } + ;; -r | --cvstag ) CVSTAG="$2" shift 2 ;; -A) shift - CVSTAG="HEAD" + CVSTAG="master" ;; -R | --fetch-build-requires) FETCH_BUILD_REQUIRES="yes" @@ -2106,19 +2234,19 @@ while [ $# -gt 0 ]; do -sc | --sources-cvs) COMMAND="list-sources-cvs" shift ;; - -sd | --sources-distfiles) + -sd | --source-distfiles) COMMAND="list-sources-distfiles" shift ;; - -sdp | --sources-distfiles-paths) + -sdp | --source-distfiles-paths) COMMAND="list-sources-distfiles-paths" shift ;; - -sf | --sources-files) + -sf | --source-files) COMMAND="list-sources-files" shift ;; - -sp | --sources-paths) + -lsp | --source-paths) COMMAND="list-sources-local-paths" shift ;; - -su | --sources-urls) + -su | --source-urls) COMMAND="list-sources-urls" shift ;; -Tvs | --tag-version-stable ) @@ -2163,11 +2291,10 @@ while [ $# -gt 0 ]; do --init-rpm-dir) COMMAND="init_rpm_dir" shift ;; - --use-greed-sources ) - GREEDSRC="1" - shift;; -u | --try-upgrade ) TRY_UPGRADE="1"; shift ;; + --upgrade-version ) + shift; UPGRADE_VERSION="$1"; shift;; -un | --try-upgrade-with-float-version ) TRY_UPGRADE="1"; FLOAT_VERSION="1"; shift ;; -v | --verbose ) @@ -2201,6 +2328,10 @@ while [ $# -gt 0 ]; do COMMAND="show_bcond_args" shift ;; + --show-avail-bconds) + COMMAND="show_avail_bconds" + shift + ;; --nodeps) shift RPMOPTS="${RPMOPTS} --nodeps" @@ -2212,33 +2343,28 @@ while [ $# -gt 0 ]; do Exit_error err_invalid_cmdline "$1" ;; *) - SPECFILE="${1}" + SPECFILE=${1%/}; shift # check if specname was passed as specname:cvstag if [ "${SPECFILE##*:}" != "${SPECFILE}" ]; then CVSTAG="${SPECFILE##*:}" SPECFILE="${SPECFILE%%:*}" fi + # always have SPECFILE ending with .spec extension + SPECFILE=${SPECFILE%%.spec}.spec ASSUMED_NAME=$(basename ${SPECFILE%%.spec}) - shift esac done -[ -d "$ASSUMED_NAME" ] && CVS_ENTRIES="$ASSUMED_NAME/CVS/Entries" || CVS_ENTRIES="CVS/Entries" -if [ -f "$CVS_ENTRIES" ] && [ -z "$CVSTAG" ]; then - CVSTAG=$(awk -vSPECFILE=$(basename ${SPECFILE%.spec}.spec) -F/ '$2 == SPECFILE && $6 ~ /^T/{print substr($6, 2)}' ${CVS_ENTRIES}) - if [ "$CVSTAG" ]; then - echo >&2 "builder: Sticky tag $CVSTAG active. Use -r TAGNAME to override." - fi -elif [ "$CVSTAG" = "HEAD" ]; then - # assume -r HEAD is same as -A - CVSTAG="" -fi - if [ "$CVSTAG" ]; then # pass $CVSTAG used by builder to rpmbuild too, so specs could use it RPMOPTS="$RPMOPTS --define \"_cvstag $CVSTAG\"" fi +if [ -n "$ALL_BRANCHES" -a -z "$DEPTH" ]; then + echo >&2 "--all branches requires --depth " + Exit_error err_invalid_cmdline +fi + if [ -n "$DEBUG" ]; then set -x set -v @@ -2263,151 +2389,201 @@ update_shell_title "$COMMAND" case "$COMMAND" in "show_bconds") init_builder - if [ -n "$SPECFILE" ]; then - get_spec > /dev/null - parse_spec - set_bconds_values - display_bconds + if [ -z "$SPECFILE" ]; then + Exit_error err_no_spec_in_cmdl fi + get_spec > /dev/null + parse_spec + set_bconds_values + display_bconds ;; "show_bcond_args") init_builder - if [ -n "$SPECFILE" ]; then - get_spec > /dev/null - parse_spec - set_bconds_values - echo "$BCOND" + if [ -z "$SPECFILE" ]; then + Exit_error err_no_spec_in_cmdl fi + get_spec > /dev/null + parse_spec + set_bconds_values + echo "$BCOND" + ;; + "show_avail_bconds") + init_builder + if [ -z "$SPECFILE" ]; then + Exit_error err_no_spec_in_cmdl + fi + + get_spec > /dev/null + parse_spec + local bcond_avail=$(find_spec_bcond $SPECFILE) + local opt bcond bconds + for opt in $bcond_avail; do + case "$opt" in + without_*) + bcond=${opt#without_} + bconds="$bconds $bcond" + ;; + with_*) + bcond=${opt#with_} + bconds="$bconds $bcond" + ;; + *) + echo >&2 "ERROR: unexpected '$opt' in show_avail_bconds" + exit 1 + ;; + esac + done + echo $bconds + ;; "build" | "build-binary" | "build-source" | "build-prep" | "build-build" | "build-install" | "build-list") init_builder - if [ -n "$SPECFILE" ]; then - # display SMP make flags if set - smp_mflags=$(rpm -E %{?_smp_mflags}) - if [ "$smp_mflags" ]; then - echo >&2 "builder: SMP make flags are set to $smp_mflags" - fi + if [ -z "$SPECFILE" ]; then + Exit_error err_no_spec_in_cmdl + fi - get_spec - parse_spec - set_bconds_values - display_bconds - display_branches - if [ "$COMMAND" != "build-source" ]; then - check_buildarch - fi - fetch_build_requires - if [ "$INTEGER_RELEASE" = "yes" ]; then - echo "Checking release $PACKAGE_RELEASE..." - if echo $PACKAGE_RELEASE | grep -q '^[^.]*\.[^.]*$' 2>/dev/null ; then - Exit_error err_fract_rel "$PACKAGE_RELEASE" - fi + # display SMP make flags if set + smp_mflags=$(rpm -E %{?_smp_mflags}) + if [ "$smp_mflags" ]; then + echo "builder: SMP make flags are set to $smp_mflags" + fi + + get_spec + parse_spec + set_bconds_values + display_bconds + display_branches + if [ "$COMMAND" != "build-source" ]; then + check_buildarch + fi + fetch_build_requires + if [ "$INTEGER_RELEASE" = "yes" ]; then + echo "Checking release $PACKAGE_RELEASE..." + if echo $PACKAGE_RELEASE | grep -q '^[^.]*\.[^.]*$' 2>/dev/null ; then + Exit_error err_fract_rel "$PACKAGE_RELEASE" fi + fi - # ./builder -bs test.spec -r AC-branch -Tp auto-ac- -tt - if [ -n "$TEST_TAG" ]; then - local TAGVER=`make_tagver` - echo "Searching for tag $TAGVER..." - TAGREL=$($CVS_COMMAND status -v $SPECFILE | grep -E "^[[:space:]]*${TAGVER}[[[:space:]]" | sed -e 's#.*(revision: ##g' -e 's#).*##g') - if [ -n "$TAGREL" ]; then - Exit_error err_tag_exists "$TAGVER" "$TAGREL" + # ./builder -bs test.spec -r AC-branch -Tp auto-ac- -tt + if [ -n "$TEST_TAG" ]; then + local TAGVER=`make_tagver` + tag_exist $TAGVER + # - do not allow to build from HEAD when XX-branch exists + TREE_PREFIX=$(echo "$TAG_PREFIX" | sed -e 's#^auto/\([a-zA-Z]\+\)/.*#\1#g') + if [ "$TREE_PREFIX" != "$TAG_PREFIX" ]; then + TAG_BRANCH="${TREE_PREFIX}-branch" + if [ -n "$DEPTH" ]; then + cmd_branches="git ls-remote --heads" + ref_prefix=refs/heads + else + cmd_branches="git show-ref" + ref_prefix=refs/remotes/${REMOTE_PLD} fi - - # - do not allow to build from HEAD when XX-branch exists - TREE_PREFIX=$(echo "$TAG_PREFIX" | sed -e 's#^auto-\([a-zA-Z]\+\)-.*#\1#g') - if [ "$TREE_PREFIX" != "$TAG_PREFIX" ]; then - TAG_BRANCH="${TREE_PREFIX}-branch" - TAG_STATUS=$($CVS_COMMAND status -v $SPECFILE | grep -Ei "${TAG_BRANCH}.+(branch: [0-9.]+)") - if [ -n "$TAG_STATUS" -a "$CVSTAG" = "HEAD" ]; then - Exit_error err_branch_exists "$TAG_STATUS" - fi + TAG_STATUS=$($cmd_branches | grep -i "${ref_prefix}/$TAG_BRANCH$") + if [ -n "$TAG_STATUS" -a "$TAG_STATUS" != "$CVSTAG" ]; then + Exit_error err_branch_exists "$TAG_STATUS" fi - fi - if [ -n "$NOSOURCE0" ] ; then - SOURCES=`echo $SOURCES | xargs | sed -e 's/[^ ]*//'` - fi - get_files $SOURCES $PATCHES - check_md5 $SOURCES - build_package - if [ "$UPDATE_POLDEK_INDEXES" = "yes" -a "$COMMAND" != "build-prep" ]; then - run_poldek --sdir="${POLDEK_INDEX_DIR}" --mkidxz - fi - remove_build_requires - else - Exit_error err_no_spec_in_cmdl fi + + if [ -n "$NOSOURCE0" ] ; then + SOURCES=`echo $SOURCES | xargs | sed -e 's/[^ ]*//'` + fi + try_upgrade + case $? in + 0) + get_files $SOURCES $PATCHES + check_md5 $SOURCES + ;; + *) + NODIST="yes" get_files $SOURCES $PATCHES + update_md5 $SOURCES $PATCHES + ;; + esac + build_package + if [ "$UPDATE_POLDEK_INDEXES" = "yes" ] && [ "$COMMAND" = "build" -o "$COMMAND" = "build-binary" ]; then + run_poldek --sdir="${POLDEK_INDEX_DIR}" ${UPDATE_POLDEK_INDEXES_OPTS} --mkidxz + fi + remove_build_requires ;; "branch" ) init_builder - if [ -n "$SPECFILE" ]; then - get_spec + if [ -z "$SPECFILE" ]; then + Exit_error err_no_spec_in_cmdl + fi + + get_spec + parse_spec + branch_files $TAG + ;; + "add_cvs" ) + init_builder + if [ -z "$SPECFILE" ]; then + Exit_error err_no_spec_in_cmdl + fi + + create_git_repo + if [ -n "$NEW_REPO" ]; then parse_spec - # don't fetch sources from remote locations - new_SOURCES="" - for file in $SOURCES; do - [ -n "`src_md5 $file`" ] && continue - new_SOURCES="$new_SOURCES $file" + local file + for file in $SOURCES $PATCHES; do + if [ -z $(src_md5 "$file") ]; then + git add $file || Exit_error err_no_source_in_repo $file + else + cvsignore_df `nourl $file` + fi done - SOURCES="$new_SOURCES" - get_files $SOURCES $PATCHES - check_md5 $SOURCES - branch_files $TAG $SOURCES $PATCHES $ICONS + git add $SPECFILE + git commit -m 'Initial commit' + git push --dry-run $REMOTE_PLD master || Exit_error err_cvs_add_failed else - Exit_error err_no_spec_in_cmdl + echo "You had already git repository. Push chosen branches to remote: ${REMOTE_PLD}" fi ;; "get" ) init_builder - if [ -n "$SPECFILE" ]; then - get_spec - parse_spec - - if [ -n "$NOSOURCE0" ] ; then - SOURCES=`echo $SOURCES | xargs | sed -e 's/[^ ]*//'` - fi - get_files $SOURCES $PATCHES - check_md5 $SOURCES - else + if [ -z "$SPECFILE" ]; then Exit_error err_no_spec_in_cmdl fi + + get_spec + parse_spec + + if [ -n "$NOSOURCE0" ] ; then + SOURCES=`echo $SOURCES | xargs | sed -e 's/[^ ]*//'` + fi + get_files $SOURCES $PATCHES + check_md5 $SOURCES ;; "update_md5" ) init_builder - if [ -n "$SPECFILE" ]; then - get_spec - parse_spec - - if [ -n "$NOSOURCE0" ] ; then - SOURCES=`echo $SOURCES | xargs | sed -e 's/[^ ]*//'` - fi - update_md5 $SOURCES - else + if [ -z "$SPECFILE" ]; then Exit_error err_no_spec_in_cmdl fi + + get_spec + parse_spec + + if [ -n "$NOSOURCE0" ] ; then + SOURCES=`echo $SOURCES | xargs | sed -e 's/[^ ]*//'` + fi + update_md5 $SOURCES $PATCHES ;; "tag" ) NOURLS=1 NODIST="yes" init_builder - if [ -n "$SPECFILE" ]; then - get_spec - parse_spec - - # don't fetch sources from remote locations - new_SOURCES="" - for file in $SOURCES; do - [ -n "`src_md5 $file`" ] && continue - new_SOURCES="$new_SOURCES $file" - done - SOURCES="$new_SOURCES" - get_files $SOURCES $PATCHES - check_md5 $SOURCES - tag_files $SOURCES $PATCHES $ICONS - else + if [ -z "$SPECFILE" ]; then Exit_error err_no_spec_in_cmdl fi + + parse_spec + if [ ! -d .git ]; then + echo "No git reposiotory" >&2 + exit 101 + fi + tag_files ;; "mr-proper" ) mr_proper