]> git.pld-linux.org Git - packages/rpm-build-tools.git/blame - builder.sh
- %pyrequires_eq %{nil}
[packages/rpm-build-tools.git] / builder.sh
CommitLineData
cd445739
AM
1#!/bin/sh
2# -----------
3# $Id$
4# Exit codes:
2a5f078d 5# 0 - succesful
6# 1 - help displayed
7# 2 - no spec file name in cmdl parameters
8# 3 - spec file not stored in repo
9# 4 - some source, patch or icon files not stored in repo
10# 5 - package build failed
11# 6 - spec file with errors
12# 7 - wrong source in /etc/poldek.conf
13# 8 - Failed installing buildrequirements and subrequirements
14# 9 - Requested tag already exist
15# 10 - Refused to build fractional release
16# 100 - Unknown error (should not happen)
cd445739
AM
17
18# Notes (todo):
f7b91886 19# - builder -u fetches current version first (well that's okay, how you compare versions if you have no old spec?)
cd445739 20# - when Icon: field is present, -5 and -a5 doesn't work
f3ada241 21# - builder -R skips installing BR if spec is not present before builder invocation (need to run builder twice)
931a4acf 22
4003ad8c 23VERSION="\
c9acaed9 24Build package utility from PLD Linux CVS repository
ebaff775 25v0.14 (C) 1999-2006 Free Penguins".
d6a77ddb 26PATH="/bin:/usr/bin:/usr/sbin:/sbin:/usr/X11R6/bin"
b03f053b 27
cd445739 28COMMAND="build"
64ea5308 29TARGET=""
cd445739 30
bde1c404 31SPECFILE=""
d287305c 32BE_VERBOSE=""
4003ad8c 33QUIET=""
cd445739
AM
34CLEAN=""
35DEBUG=""
36NOURLS=""
37NOCVS=""
38NOCVSSPEC=""
39NODIST=""
40UPDATE=""
41UPDATE5=""
42ADD5=""
43NO5=""
44ALWAYS_CVSUP=${ALWAYS_CVSUP:-"yes"}
c8f50498 45CVSROOT=""
cd445739
AM
46
47# It can be used i.e. in log file naming.
48# See LOGFILE example.
49DATE=`date +%Y-%m-%d_%H-%M-%S`
50
51# Example: LOGFILE='../log.$PACKAGE_NAME'
52# Example: LOGFILE='../LOGS/log.$PACKAGE_NAME.$DATE'
53# Yes, you can use variable name! Note _single_ quotes!
54LOGFILE=''
55
56LOGDIR=""
57LOGDIROK=""
58LOGDIRFAIL=""
59LASTLOG_FILE=""
60
61CHMOD="no"
62CHMOD_MODE="0444"
63RPMOPTS=""
64BCOND=""
65GROUP_BCONDS="no"
947025e5 66CVSIGNORE_DF="no"
d287305c 67
68PATCHES=""
69SOURCES=""
cd445739 70ICONS=""
d287305c 71PACKAGE_RELEASE=""
72PACKAGE_VERSION=""
73PACKAGE_NAME=""
cd445739
AM
74PROTOCOL="ftp"
75WGET_RETRIES=${MAX_WGET_RETRIES:-0}
76CVS_RETRIES=${MAX_CVS_RETRIES:-1000}
77
78CVSTAG=""
79RES_FILE=""
80
81CVS_SERVER="cvs.pld-linux.org"
82DISTFILES_SERVER="://distfiles.pld-linux.org"
d4730dae 83ATTICDISTFILES_SERVER="://attic-distfiles.pld-linux.org"
cd445739 84
36d03934 85DEF_NICE_LEVEL=19
cd445739
AM
86
87FAIL_IF_NO_SOURCES="yes"
88
18e5347d
ER
89# let get_files skip over files which are present to get those damn files fetched
90SKIP_EXISTING_FILES="no"
91
ab4a2b6e
ER
92if [ -x /usr/bin/rpm-getdeps ]; then
93 FETCH_BUILD_REQUIRES_RPMGETDEPS="yes"
94else
95 FETCH_BUILD_REQUIRES_RPMGETDEPS="no"
96fi
97
cd445739
AM
98# Here we load saved user environment used to
99# predefine options set above, or passed to builder
100# in command line.
101# This one reads global system environment settings:
102if [ -f ~/etc/builderrc ]; then
103 . ~/etc/builderrc
104fi
105# And this one cascades settings using user personal
106# builder settings.
107# Example of ~/.builderrc:
108#
109#UPDATE_POLDEK_INDEXES="yes"
110#FETCH_BUILD_REQUIRES="yes"
111#REMOVE_BUILD_REQUIRES="force"
112#GROUP_BCONDS="yes"
113#LOGFILE='../LOGS/log.$PACKAGE_NAME.$DATE'
114#
a83e5405 115SU_SUDO=""
cd445739
AM
116if [ -n "$HOME_ETC" ]; then
117 USER_CFG="$HOME_ETC/.builderrc"
118else
119 USER_CFG=~/.builderrc
120fi
121
122[ -f "$USER_CFG" ] && . "$USER_CFG"
123
06f3864d
AM
124wget --help 2>&1 | grep -q ' \-\-no-check\-certificate ' && WGET_OPTS="$WGET_OPTS --no-check-certificate"
125
ca2e6c31 126if [ -n "$USE_PROZILLA" ]; then
7e365483
KK
127 GETURI="proz --no-getch -r -P ./ -t$WGET_RETRIES $PROZILLA_OPTS"
128 GETURI2="$GETURI"
129 OUTFILEOPT="-O"
ca2e6c31 130elif [ -n "$USE_AXEL" ]; then
cede92b3 131 GETURI="axel -a $AXEL_OPTS"
7e365483
KK
132 GETURI2="$GETURI"
133 OUTFILEOPT="-o"
ca2e6c31 134else
7e365483
KK
135 wget --help 2>&1 | grep -q ' \-\-inet ' && WGET_OPTS="$WGET_OPTS --inet"
136 wget --help 2>&1 | grep -q ' \-\-retry\-connrefused ' && WGET_OPTS="$WGET_OPTS --retry-connrefused"
6f9a5d76 137
7e365483
KK
138 GETURI="wget --passive-ftp -c -nd -t$WGET_RETRIES $WGET_OPTS"
139 GETURI2="wget -c -nd -t$WGET_RETRIES $WGET_OPTS"
140 OUTFILEOPT="-O"
2bc5451f 141fi
11468b23 142
11468b23
AM
143GETLOCAL="cp -a"
144
145if (rpm --version 2>&1 | grep -q '4.0.[0-2]'); then
146 RPM="rpm"
147 RPMBUILD="rpm"
148else
149 RPM="rpm"
150 RPMBUILD="rpmbuild"
151fi
152
153POLDEK_INDEX_DIR="`$RPM --eval %_rpmdir`/"
a83e5405 154POLDEK_CMD="$SU_SUDO /usr/bin/poldek --noask"
11468b23 155
cd445739
AM
156run_poldek()
157{
158 RES_FILE=~/tmp/poldek-exit-status.$RANDOM
159 if [ -n "$LOGFILE" ]; then
160 LOG=`eval echo $LOGFILE`
161 if [ -n "$LASTLOG_FILE" ]; then
162 echo "LASTLOG=$LOG" > $LASTLOG_FILE
163 fi
040282bb 164 (nice -n ${DEF_NICE_LEVEL} ${POLDEK_CMD} `while test $# -gt 0; do echo "$1 ";shift;done` ; echo $? > ${RES_FILE})|tee -a $LOG
cd445739
AM
165 return $exit_pldk
166 else
167 (nice -n ${DEF_NICE_LEVEL} ${POLDEK_CMD} `while test $# -gt 0; do echo "$1 ";shift;done` ; echo $? > ${RES_FILE}) 1>&2 >/dev/null
168 return `cat ${RES_FILE}`
169 rm -rf ${RES_FILE}
170 fi
171}
172
cd445739
AM
173#---------------------------------------------
174# functions
da946cd6 175
5a491465 176usage()
177{
cd445739
AM
178 if [ -n "$DEBUG" ]; then set -xv; fi
179 echo "\
180Usage: builder [-D|--debug] [-V|--version] [-a|--as_anon] [-b|-ba|--build]
81f85806 181
cd445739
AM
182[-bb|--build-binary] [-bs|--build-source] [-u|--try-upgrade]
183[{-B|--branch} <branch>] [{-d|--cvsroot} <cvsroot>] [-g|--get]
184[-h|--help] [--http] [{-l,--logtofile} <logfile>] [-m|--mr-proper]
185[-q|--quiet] [--date <yyyy-mm-dd> [-r <cvstag>] [{-T--tag <cvstag>]
186[-Tvs|--tag-version-stable] [-Tvn|--tag-version-nest]
187[-Ts|--tag-stable] [-Tn|--tag-nest] [-Tv|--tag-version]
188[{-Tp|--tag-prefix} <prefix>] [{-tt|--test-tag}]
dfe2cb9a 189[-nu|--no-urls] [-v|--verbose] [--opts <rpm opts>] [--show-bconds]
f19103b5 190[--with/--without <feature>] [--define <macro> <value>] <package>[.spec][:cvstag]
2a5f078d 191
cd445739
AM
192-5, --update-md5 - update md5 comments in spec, implies -nd -ncs
193-a5, --add-md5 - add md5 comments to URL sources, implies -nc -nd -ncs
194-n5, --no-md5 - ignore md5 comments in spec
9243e80b
ER
195-D, --debug - enable builder script debugging mode,
196-debug - produce rpm debug package (same as --opts -debug)
cd445739
AM
197-V, --version - output builder version
198-a, --as_anon - get files via pserver as cvs@$CVS_SERVER,
199-b, -ba, --build - get all files from CVS repo or HTTP/FTP and build package
200 from <package>.spec,
201-bb, --build-binary - get all files from CVS repo or HTTP/FTP and build binary
202 only package from <package>.spec,
c56807e0
ER
203-bp, --build-prep - execute the %prep phase of <package>.spec,
204-bc - reserved (not implemented)
205-bi reserved (not implemented)
cd445739
AM
206-bs, --build-source - get all files from CVS repo or HTTP/FTP and only pack
207 them into src.rpm,
c56807e0 208--short-circuit - reserved (not implemented)
cd445739
AM
209-B, --branch - add branch
210-c, --clean - clean all temporarily created files (in BUILD, SOURCES,
211 SPECS and \$RPM_BUILD_ROOT),
2a5f078d 212-d <cvsroot>, --cvsroot <cvsroot>
cd445739
AM
213 - setup \$CVSROOT,
214--define <macro> <value>
215 - define a macro <macro> with value <value>,
216--nodeps - rpm won't check any dependences
217-g, --get - get <package>.spec and all related files from CVS repo
218 or HTTP/FTP,
219-h, --help - this message,
220--http - use http instead of ftp,
221-l <logfile>, --logtofile <logfile>
222 - log all to file,
223-m, --mr-proper - only remove all files related to spec file and all work
224 resources,
225-nc, --no-cvs - don't download sources from CVS, if source URL is given,
226-ncs, --no-cvs-specs
227 - don't check specs in CVS
228-nd, --no-distfiles - don't download from distfiles
229-nm, --no-mirrors - don't download from mirror, if source URL is given,
230-nu, --no-urls - don't try to download from FTP/HTTP location,
231-ns, --no-srcs - don't download Sources
232-ns0, --no-source0 - don't download Source0
233-nn, --no-net - don't download anything from the net
18e5347d
ER
234-ske,
235--skip-existing-files - skip existing files in get_files
cd445739
AM
236--opts <rpm opts> - additional options for rpm
237-q, --quiet - be quiet,
238--date yyyy-mm-dd - build package using resources from specified CVS date,
239-r <cvstag>, --cvstag <cvstag>
240 - build package using resources from specified CVS tag,
241-R, --fetch-build-requires
242 - fetch what is BuildRequired,
243-RB, --remove-build-requires
244 - remove all you fetched with -R or --fetch-build-requires
245 remember, this option requires confirmation,
246-FRB, --force-remove-build-requires
247 - remove all you fetched with -R or --fetch-build-requires
248 remember, this option works without confirmation,
a7eefc54 249-sf, --source-files - list sources - bare filenames (intended for offline
250 operations; does not work when Icon field is present
251 but icon file is absent),
252-sp, --source-paths - list sources - filenames with full local paths (intended for
253 offline operations; does not work when Icon field is present
254 but icon file is absent),
2dddf439
ER
255-su, --source-urls - list urls - urls to sources and patches
256 intended for copying urls with spec with lots of macros in urls
cd445739
AM
257-T <cvstag> , --tag <cvstag>
258 - add cvs tag <cvstag> for files,
259-Tvs, --tag-version-stable
094bd95b 260 - add cvs tags STABLE and NAME-VERSION-RELEASE for files,
cd445739 261-Tvn, --tag-version-nest
1691a37b 262 - add cvs tags NEST and NAME-VERSION-RELEASE for files,
cd445739
AM
263-Ts, --tag-stable
264 - add cvs tag STABLE for files,
265-Tn, --tag-nest
266 - add cvs tag NEST for files,
267-Tv, --tag-version
1691a37b 268 - add cvs tag NAME-VERSION-RELEASE for files,
cd445739
AM
269-Tp, --tag-prefix <prefix>
270 - add <prefix> to NAME-VERSION-RELEASE tags,
271-tt, --test-tag <prefix>
272 - fail if tag is already present,
50321881
JK
273-ir, --integer-release-only
274 - allow only integer and snapshot releases
cd445739
AM
275-v, --verbose - be verbose,
276-u, --try-upgrade - check version, and try to upgrade package
277-un, --try-upgrade-with-float-version
278 - as above, but allow float version
deccc50e 279-U, --update - refetch sources, don't use distfiles, and update md5 comments
cd445739
AM
280-Upi, --update-poldek-indexes
281 - refresh or make poldek package index files.
c890b916 282-np, --nopatch <patchnumber>
bed98670 283 - don't apply <patchnumber>
dfe2cb9a
MK
284--show-bconds - show available conditional builds, which can be used
285 - with --with and/or --without switches.
cd445739
AM
286--with/--without <feature>
287 - conditional build package depending on %_with_<feature>/
288 %_without_<feature> macro switch. You may now use
289 --with feat1 feat2 feat3 --without feat4 feat5 --with feat6
290 constructions. Set GROUP_BCONDS to yes to make use of it.
6dd19291 291--target <platform>, --target=<platform>
64ea5308 292 - build for platform <platform>.
5a491465 293"
294}
295
c890b916 296update_shell_title() {
a0d6396b 297 [ -t 1 ] || return
0b65d15e
ER
298 local len=${COLUMNS:-80}
299 local msg=$(echo "$*" | cut -c-$len)
300
8aa5bc76 301 echo >&2 "$(date +%s.%N) $*"
f2e42a41 302 msg="builder[$SPECFILE] ${SHELL_TITLE_PREFIX:+$SHELL_TITLE_PREFIX }$msg"
c890b916
ER
303 case "$TERM" in
304 cygwin|xterm*)
2dddf439 305 echo >&2 -ne "\033]1;$msg\007\033]2;$msg\007"
c890b916
ER
306 ;;
307 screen*)
2dddf439 308 echo >&2 -ne "\033]0;$msg\007"
c890b916
ER
309 ;;
310 esac
311}
312
7e40520f
ER
313# set TARGET from BuildArch: from SPECFILE
314set_spec_target() {
315 if [ -n "$SPECFILE" ] && [ -z "$TARGET" ]; then
316 tmp=$(awk '/^BuildArch:/ { print $NF}' $SPECFILE)
317 if [ "$tmp" ]; then
318 TARGET="$tmp"
319 case "$RPMBUILD" in
320 "rpmbuild")
321 TARGET_SWITCH="--target $TARGET" ;;
322 "rpm")
323 TARGET_SWITCH="--target=$TARGET" ;;
324 esac
325 fi
326 fi
327}
328
cd445739 329cache_rpm_dump () {
b2aeec7d
AM
330 if [ -n "$DEBUG" ]; then
331 set -x;
332 set -v;
333 fi
7e40520f 334
13974367 335 update_shell_title "cache_rpm_dump"
cd445739 336rpm_dump_cache=`
fa4bf1df
ER
337 # we reset macros not to contain macros.build as all the %() macros are
338 # executed here, while none of them are actually needed
339 # what we need from dump is NAME, VERSION, RELEASE and PATCHES/SOURCES.
340 # macros.build + macros contained at the time of this writing 70 %() macros
fb7318ec 341 local macrofiles="/usr/lib/rpm/macros:/usr/lib/rpm/macros.build:$SPECS_DIR/.rpmmacros:~/etc/.rpmmacros:~/.rpmmacros"
ebaff775 342 local dump='%{echo:dummy: PACKAGE_NAME %{name} }%dump'
7cb24972
ER
343 # FIXME: better ideas than .rpmrc?
344 printf 'include:/usr/lib/rpm/rpmrc\nmacrofiles:%s\n' $macrofiles > .rpmrc
fb198857
ER
345# TODO: move these to /usr/lib/rpm/macros
346 cat > .rpmmacros <<'EOF'
347%requires_releq_kernel_up %{nil}
348%requires_releq_kernel_smp %{nil}
fbc3c28b 349%pyrequires_eq %{nil}
fb198857
ER
350%releq_kernel_up ERROR
351%releq_kernel_smp ERROR
352EOF
cd445739
AM
353 case "$RPMBUILD" in
354 rpm )
7cb24972 355 rpm --rcfile .rpmrc -bp --nodeps --define "prep $dump" $BCOND $TARGET_SWITCH $SPECFILE 2>&1
cd445739
AM
356 ;;
357 rpmbuild )
c94b1395 358 rpmbuild --rcfile .rpmrc --nodigest --nodeps --nosignature --nobuild --define "prep $dump" $BCOND $TARGET_SWITCH $SPECFILE 2>&1
cd445739
AM
359 ;;
360 esac`
fb198857
ER
361 if [ $? -gt 0 ]; then
362 echo "$rpm_dump_cache" | sed -ne '/^error:/,$p' >&2
363 Exit_error err_build_fail;
364 fi
13974367 365 update_shell_title "cache_rpm_dump: OK!"
cd445739
AM
366}
367
368rpm_dump () {
369 if [ -z "$rpm_dump_cache" ] ; then
370 echo "internal error: cache_rpm_dump not called!" 1>&2
371 fi
372 echo "$rpm_dump_cache"
373}
374
59398507 375parse_spec()
376{
af4d5315 377 update_shell_title "parsing specfile"
cd445739
AM
378 if [ -n "$DEBUG" ]; then
379 set -x;
380 set -v;
381 fi
b2975fc3 382
cd445739 383 cd $SPECS_DIR
cd445739 384 cache_rpm_dump
00fcec7e 385
cd445739
AM
386 if [ "$NOSRCS" != "yes" ]; then
387 SOURCES="`rpm_dump | awk '/SOURCEURL[0-9]+/ {print $3}'`"
388 fi
7cb24972 389
cd445739
AM
390 if (rpm_dump | grep -qEi ":.*nosource.*1"); then
391 FAIL_IF_NO_SOURCES="no"
392 fi
393
394 PATCHES="`rpm_dump | awk '/PATCHURL[0-9]+/ {print $3}'`"
395 ICONS="`awk '/^Icon:/ {print $2}' ${SPECFILE}`"
fa4bf1df
ER
396 PACKAGE_NAME=$(rpm_dump | awk '$2 == "PACKAGE_NAME" { print $3}')
397 PACKAGE_VERSION=$(rpm_dump | awk '$2 == "PACKAGE_VERSION" { print $3}')
398 PACKAGE_RELEASE=$(rpm_dump | awk '$2 == "PACKAGE_RELEASE" { print $3}')
78eab2a1 399
cd445739
AM
400 if [ -n "$BE_VERBOSE" ]; then
401 echo "- Sources : `nourl $SOURCES`"
402 if [ -n "$PATCHES" ]; then
403 echo "- Patches : `nourl $PATCHES`"
404 else
405 echo "- Patches : *no patches needed*"
406 fi
407 if [ -n "$ICONS" ]; then
408 echo "- Icon : `nourl $ICONS`"
409 else
410 echo "- Icon : *no package icon*"
411 fi
412 echo "- Name : $PACKAGE_NAME"
413 echo "- Version : $PACKAGE_VERSION"
414 echo "- Release : $PACKAGE_RELEASE"
415 fi
13974367
ER
416
417 update_shell_title "parse_spec: OK!"
cd445739
AM
418}
419
420Exit_error()
421{
422 if [ -n "$DEBUG" ]; then
423 set -x;
424 set -v;
425 fi
426
427 cd "$__PWD"
428
429 case "$1" in
430 "err_no_spec_in_cmdl" )
431 remove_build_requires
432 echo "ERROR: spec file name not specified.";
433 exit 2 ;;
434 "err_no_spec_in_repo" )
435 remove_build_requires
436 echo "Error: spec file not stored in CVS repo.";
437 exit 3 ;;
438 "err_no_source_in_repo" )
439 remove_build_requires
440 echo "Error: some source, patch or icon files not stored in CVS repo. ($2)";
441 exit 4 ;;
442 "err_build_fail" )
443 remove_build_requires
444 echo "Error: package build failed. (${2:-no more info})";
445 exit 5 ;;
78eab2a1
AM
446 "err_no_package_data" )
447 remove_build_requires
448 echo "Error: couldn't get out package name/version/release from spec file."
449 exit 6 ;;
50321881
JK
450 "err_tag_exists" )
451 remove_build_requires
452 echo "Tag ${2} already exists (spec release: ${3}).";
453 exit 9 ;;
454 "err_fract_rel" )
455 remove_build_requires
456 echo "Release ${2} not integer and not a snapshot.";
457 exit 10 ;;
fb96e0b5
AM
458 "err_branch_exists" )
459 remove_build_requires
460 echo "Tree branch already exists (${2}).";
461 exit 11 ;;
50321881 462
cd445739 463 esac
50321881 464 echo "Unknown error."
2a5f078d 465 exit 100
cd445739
AM
466}
467
468init_builder()
469{
470 if [ -n "$DEBUG" ]; then
471 set -x;
472 set -v;
0dd6320d 473 fi
cd445739
AM
474
475 SOURCE_DIR="`$RPM --eval '%{_sourcedir}'`"
476 SPECS_DIR="`$RPM --eval '%{_specdir}'`"
477
478 __PWD="`pwd`"
00fcec7e 479}
480
d6a77ddb 481get_spec()
1471f6d6 482{
c890b916 483
2e5be021 484 update_shell_title "get_spec"
c890b916 485
cd445739
AM
486 if [ -n "$DEBUG" ]; then
487 set -x;
488 set -v;
489 fi
490
491 cd "$SPECS_DIR"
049ab214 492 if [ ! -f "$SPECFILE" ]; then
cd445739
AM
493 SPECFILE="`basename $SPECFILE .spec`.spec";
494 fi
495 if [ "$NOCVSSPEC" != "yes" ]; then
cd445739 496
049ab214
ER
497 if [ ! -s CVS/Root -a "$NOCVSSPEC" != "yes" ]; then
498 echo "Warning: No CVS access defined - using local .spec file"
499 NOCVSSPEC="yes"
cd445739
AM
500 fi
501
049ab214 502 cvsup "$SPECFILE" || Exit_error err_no_spec_in_repo
cd445739 503 fi
049ab214 504
cd445739
AM
505 if [ ! -f "$SPECFILE" ]; then
506 Exit_error err_no_spec_in_repo;
507 fi
508
509 if [ "$CHMOD" = "yes" -a -n "$SPECFILE" ]; then
510 chmod $CHMOD_MODE $SPECFILE
511 fi
512 unset OPTIONS
a7eefc54 513 [ -n "$DONT_PRINT_REVISION" ] || grep -E -m 1 "^#.*Revision:.*Date" $SPECFILE
7e40520f
ER
514
515 set_spec_target
cd445739
AM
516}
517
518find_mirror()
519{
520 cd "$SPECS_DIR"
521 url="$1"
522 if [ ! -f "mirrors" -a "$NOCVSSPEC" != "yes" ] ; then
523 cvs update mirrors >&2
524 fi
525
526 IFS="|"
527 while read origin mirror name rest
528 do
529 ol=`echo -n "$origin"|wc -c`
530 prefix="`echo -n "$url" | head -c $ol`"
531 if [ "$prefix" = "$origin" ] ; then
532 suffix="`echo "$url"|cut -b $ol-`"
533 echo -n "$mirror$suffix"
534 return 0
535 fi
536 done < mirrors
537 echo "$url"
538}
539
540src_no ()
541{
542 cd $SPECS_DIR
543 rpm_dump | \
544 grep "SOURCEURL[0-9]*[ ]*$1""[ ]*$" | \
545 sed -e 's/.*SOURCEURL\([0-9][0-9]*\).*/\1/' | \
546 head -n 1 | xargs
1471f6d6 547}
548
cd445739 549src_md5 ()
8ba5cdda 550{
cd445739
AM
551 [ X"$NO5" = X"yes" ] && return
552 no=$(src_no "$1")
553 [ -z "$no" ] && return
554 cd $SPECS_DIR
47a8df12 555 spec_rev=$(grep $SPECFILE CVS/Entries 2>/dev/null | sed -e s:/$SPECFILE/:: -e s:/.*::)
cd445739
AM
556 if [ -z "$spec_rev" ]; then
557 spec_rev="$(head -n 1 $SPECFILE | sed -e 's/.*\$Revision: \([0-9.]*\).*/\1/')"
558 fi
559 spec="$SPECFILE[0-9.,]*,$(echo $spec_rev | sed 's/\./\\./g')"
560 md5=$(grep -s -v '^#' additional-md5sums | \
561 grep -E "[ ]$(basename "$1")[ ]+${spec}([ ,]|\$)" | \
562 sed -e 's/^\([0-9a-f]\{32\}\).*/\1/' | \
563 grep -E '^[0-9a-f]{32}$')
564 if [ X"$md5" = X"" ] ; then
6203ea52
AG
565 source_md5=`grep -i "#[ ]*Source$no-md5[ ]*:" $SPECFILE | sed -e 's/.*://'`
566 if [ ! -z "$source_md5" ] ; then
7e365483 567 echo $source_md5;
6203ea52 568 else
7e365483
KK
569 # we have empty SourceX-md5, but it is still possible
570 # that we have NoSourceX-md5 AND NoSource: X
571 nosource_md5=`grep -i "#[ ]*NoSource$no-md5[ ]*:" $SPECFILE | sed -e 's/.*://'`
572 if [ ! -z "$nosource_md5" -a ! X"`grep -i "^NoSource:[ ]*$no$" $SPECFILE`" = X"" ] ; then
573 echo $nosource_md5;
574 fi;
6203ea52 575 fi;
cd445739
AM
576 else
577 if [ $(echo "$md5" | wc -l) != 1 ] ; then
578 echo "$SPECFILE: more then one entry in additional-md5sums for $1" 1>&2
579 fi
580 echo "$md5" | tail -n 1
581 fi
582}
583
584distfiles_url ()
585{
1246dc2a 586 echo "$PROTOCOL$DISTFILES_SERVER/distfiles/by-md5/$(src_md5 "$1" | sed -e 's|^\(.\)\(.\)|\1/\2/&|')/$(basename "$1")"
cd445739
AM
587}
588
589distfiles_attic_url ()
590{
1246dc2a 591 echo "$PROTOCOL$ATTICDISTFILES_SERVER/distfiles/Attic/by-md5/$(src_md5 "$1" | sed -e 's|^\(.\)\(.\)|\1/\2/&|')/$(basename "$1")"
cd445739
AM
592}
593
594good_md5 ()
595{
596 md5=$(src_md5 "$1")
597 [ "$md5" = "" ] || \
598 [ "$md5" = "$(md5sum $(nourl "$1") 2> /dev/null | sed -e 's/ .*//')" ]
8ba5cdda
PG
599}
600
a4b50627
AF
601good_size ()
602{
deccc50e
AM
603 size="$(find $(nourl "$1") -printf "%s" 2>/dev/null)"
604 [ -n "$size" -a "$size" -gt 0 ]
a4b50627
AF
605}
606
947025e5 607cvsignore_df ()
608{
609 if [ "$CVSIGNORE_DF" != "yes" ]; then
610 return
611 fi
612 cvsignore=${SOURCE_DIR}/.cvsignore
613 if ! grep -q "^$1\$" $cvsignore 2> /dev/null; then
614 echo "$1" >> $cvsignore
615 fi
616}
617
e7fa3b9f
ER
618cvsup()
619{
620 update_shell_title "cvsup"
621 local OPTIONS="up "
622 if [ -n "$CVSROOT" ]; then
623 OPTIONS="-d $CVSROOT $OPTIONS"
e7fa3b9f 624 fi
b1c6aace 625
e7fa3b9f
ER
626 if [ -z "$CVSDATE" -a -z "$CVSTAG" ]; then
627 OPTIONS="$OPTIONS -A"
628 else
629 if [ -n "$CVSDATE" ]; then
630 OPTIONS="$OPTIONS -D $CVSDATE"
631 fi
632 if [ -n "$CVSTAG" ]; then
633 OPTIONS="$OPTIONS -r $CVSTAG"
634 fi
635 fi
636
637 local result=1
638 local retries_counter=0
639 update_shell_title "cvsup: $# files"
640 while [ "$result" != "0" -a "$retries_counter" -le "$CVS_RETRIES" ]; do
641 retries_counter=$(( $retries_counter + 1 ))
642 output=$(LC_ALL=C cvs $OPTIONS "$@" 2>&1)
643 result=$?
644 [ -n "$output" ] && echo "$output"
645 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
646 echo "Trying again [$*]... ($retries_counter)"
647 update_shell_title "cvsup: retry #$retries_counter"
648 sleep 2
649 continue
650 else
651 break
652 fi
653 done
654 update_shell_title "cvsup: done!"
049ab214 655 return $result
e7fa3b9f
ER
656}
657
cd445739
AM
658get_files()
659{
7cb24972 660 update_shell_title "get_files"
cd445739
AM
661
662 if [ -n "$DEBUG" ]; then
663 set -x;
664 set -v;
665 fi
666
f09c0772 667 if [ $# -gt 0 ]; then
cd445739
AM
668 cd "$SOURCE_DIR"
669
b1c6aace 670 if [ ! -s CVS/Root -a "$NOCVS" != "yes" ]; then
049ab214 671 echo "Warning: No CVS access defined for SOURCES"
b1c6aace
ER
672 NOCVS="yes"
673 fi
674
f2e42a41 675 local nc=0
e7fa3b9f 676 local get_files_cvs=""
3815b69a 677 for i in "$@"; do
f2e42a41 678 nc=$((nc + 1))
dcebdffb 679 local cvsup=0
3815b69a 680 SHELL_TITLE_PREFIX="get_files[$nc/$#]"
f2e42a41 681 update_shell_title "$i"
f09c0772
ER
682 local fp=`nourl "$i"`
683 if [ -f "$fp" ] && [ "$SKIP_EXISTING_FILES" = "yes" ]; then
18e5347d
ER
684 continue
685 fi
cd445739
AM
686 if [ -n "$UPDATE5" ]; then
687 if [ -n "$ADD5" ]; then
f09c0772 688 [ "$fp" = "$i" ] && continue
cd445739
AM
689 grep -qiE '^#[ ]*Source'$(src_no $i)'-md5[ ]*:' $SPECS_DIR/$SPECFILE && continue
690 else
691 grep -qiE '^#[ ]*Source'$(src_no $i)'-md5[ ]*:' $SPECS_DIR/$SPECFILE || continue
692 fi
693 fi
694 FROM_DISTFILES=0
f09c0772 695 if [ ! -f "$fp" ] || [ $ALWAYS_CVSUP = "yes" ]; then
cd445739
AM
696 if echo $i | grep -vE '(http|ftp|https|cvs|svn)://' | grep -qE '\.(gz|bz2)$']; then
697 echo "Warning: no URL given for $i"
698 fi
699
700 if [ -n "$(src_md5 "$i")" ] && [ -z "$NODIST" ]; then
a4b50627 701 if good_md5 "$i" && good_size "$i"; then
deccc50e 702 echo "$(nourl "$i") having proper md5sum already exists"
cd445739
AM
703 continue
704 fi
4ea1c265 705 target="$fp"
cd445739
AM
706 url=$(distfiles_url "$i")
707 url_attic=$(distfiles_attic_url "$i")
708 FROM_DISTFILES=1
33da77c4 709 if [ "`echo $url | grep -E '^(\.|/)'`" ]; then
18a52930 710 update_shell_title "${GETLOCAL%% *}: $url"
cd445739
AM
711 ${GETLOCAL} $url $target
712 else
713 if [ -z "$NOMIRRORS" ]; then
714 url="`find_mirror "$url"`"
715 fi
18a52930 716 update_shell_title "${GETURI%% *}: $url"
ca2e6c31 717 ${GETURI} ${OUTFILEOPT} "$target" "$url" || \
33da77c4 718 if [ "`echo $url | grep -E 'ftp://'`" ]; then
18a52930 719 update_shell_title "${GETURI2%% *}: $url"
ca2e6c31 720 ${GETURI2} ${OUTFILEOPT} "$target" "$url"
cd445739
AM
721 fi
722 fi
723 if ! test -s "$target"; then
724 rm -f "$target"
725 if [ `echo $url_attic | grep -E '^(\.|/)'` ]; then
18a52930 726 update_shell_title "${GETLOCAL%% *}: $url_attic"
cd445739
AM
727 ${GETLOCAL} $url_attic $target
728 else
729 if [ -z "$NOMIRRORS" ]; then
730 url_attic="`find_mirror "$url_attic"`"
731 fi
18a52930 732 update_shell_title "${GETURI%% *}: $url_attic"
ca2e6c31 733 ${GETURI} ${OUTFILEOPT} "$target" "$url_attic" || \
33da77c4 734 if [ "`echo $url_attic | grep -E 'ftp://'`" ]; then
18a52930 735 update_shell_title "${GETURI2%% *}: $url_attic"
ca2e6c31 736 ${GETURI2} ${OUTFILEOPT} "$target" "$url_attic"
cd445739
AM
737 fi
738 fi
739 fi
947025e5 740 if test -s "$target"; then
741 cvsignore_df $target
742 else
cd445739
AM
743 rm -f "$target"
744 FROM_DISTFILES=0
745 fi
746 elif [ -z "$(src_md5 "$i")" -a "$NOCVS" != "yes" ]; then
dcebdffb 747 get_files_cvs="$get_files_cvs $fp"
51616f76 748 update_shell_title "$fp (will cvs up later)"
dcebdffb 749 cvsup=1
cd445739
AM
750 fi
751
f09c0772 752 if [ -z "$NOURLS" ] && [ ! -f "$fp" -o -n "$UPDATE" ] && [ "`echo $i | grep -E 'ftp://|http://|https://'`" ]; then
cd445739
AM
753 if [ -z "$NOMIRRORS" ]; then
754 im="`find_mirror "$i"`"
755 else
756 im="$i"
757 fi
18a52930 758 update_shell_title "${GETURI%% *}: $im"
cd445739 759 ${GETURI} "$im" || \
33da77c4 760 if [ "`echo $im | grep -E 'ftp://'`" ]; then
18a52930 761 update_shell_title "${GETURI2%% *}: $im"
cd445739 762 ${GETURI2} "$im"
7e365483 763 fi
cd445739
AM
764 fi
765
dcebdffb
ER
766 if [ "$cvsup" = 1 ]; then
767 continue
768 fi
769
cd445739
AM
770 fi
771 srcno=$(src_no $i)
f09c0772 772 if [ ! -f "$fp" -a "$FAIL_IF_NO_SOURCES" != "no" ]; then
cd445739
AM
773 Exit_error err_no_source_in_repo $i;
774 elif [ -n "$UPDATE5" ] && \
775 ( ( [ -n "$ADD5" ] && echo $i | grep -q -E 'ftp://|http://|https://' && \
776 [ -z "$(grep -E -i '^NoSource[ ]*:[ ]*'$i'([ ]|$)' $SPECS_DIR/$SPECFILE)" ] ) || \
777 grep -q -i -E '^#[ ]*source'$(src_no $i)'-md5[ ]*:' $SPECS_DIR/$SPECFILE )
778 then
deccc50e 779 echo "Updating source-$srcno md5."
f09c0772 780 md5=$(md5sum "$fp" | cut -f1 -d' ')
cd445739 781 perl -i -ne '
deccc50e
AM
782 print unless /^\s*#\s*Source'$srcno'-md5\s*:/i;
783 print "# Source'$srcno'-md5:\t'$md5'\n"
cd445739
AM
784 if /^Source'$srcno'\s*:\s+/;
785 ' \
786 $SPECS_DIR/$SPECFILE
787 fi
2a5f078d 788
a4b50627 789 if good_md5 "$i" && good_size "$i"; then
cd445739
AM
790 :
791 elif [ "$FROM_DISTFILES" = 1 ]; then
deccc50e 792 # wrong md5 from distfiles: remove the file and try again
cd445739 793 # but only once ...
deccc50e 794 echo "MD5 sum mismatch. Trying full fetch."
cd445739
AM
795 FROM_DISTFILES=2
796 rm -f $target
18a52930 797 update_shell_title "${GETURI%% *}: $url"
ca2e6c31 798 ${GETURI} ${OUTFILEOPT} "$target" "$url" || \
33da77c4 799 if [ "`echo $url | grep -E 'ftp://'`" ]; then
18a52930 800 update_shell_title "${GETURI2%% *}: $url"
ca2e6c31 801 ${GETURI2} ${OUTFILEOPT} "$target" "$url"
cd445739
AM
802 fi
803 if ! test -s "$target"; then
804 rm -f "$target"
18a52930 805 update_shell_title "${GETURI%% *}: $url_attic"
ca2e6c31 806 ${GETURI} ${OUTFILEOPT} "$target" "$url_attic" || \
33da77c4 807 if [ "`echo $url_attic | grep -E 'ftp://'`" ]; then
18a52930 808 update_shell_title "${GETURI2%% *}: $url_attic"
ca2e6c31 809 ${GETURI2} ${OUTFILEOPT} "$target" "$url_attic"
cd445739
AM
810 fi
811 fi
812 test -s "$target" || rm -f "$target"
813 fi
814
a4b50627 815 if good_md5 "$i" && good_size "$i" ; then
cd445739
AM
816 :
817 else
deccc50e
AM
818 echo "MD5 sum mismatch or 0 size. Use -U to refetch sources,"
819 echo "or -5 to update md5 sums, if you're sure files are correct."
cd445739
AM
820 Exit_error err_no_source_in_repo $i
821 fi
822 done
e7fa3b9f
ER
823 SHELL_TITLE_PREFIX=""
824
825 if [ "$get_files_cvs" ]; then
826 cvsup $get_files_cvs
827 fi
cd445739
AM
828
829 if [ "$CHMOD" = "yes" ]; then
3815b69a 830 CHMOD_FILES="`nourl "$@"`"
cd445739
AM
831 if [ -n "$CHMOD_FILES" ]; then
832 chmod $CHMOD_MODE $CHMOD_FILES
833 fi
834 fi
cd445739
AM
835 fi
836}
837
838make_tagver() {
78eab2a1
AM
839
840 if [ -n "$DEBUG" ]; then
841 set -x;
842 set -v;
843 fi
2a5f078d 844
cd445739
AM
845 # Check whether first character of PACKAGE_NAME is legal for tag name
846 if [ -z "${PACKAGE_NAME##[_0-9]*}" -a -z "$TAG_PREFIX" ]; then
847 TAG_PREFIX=tag_
848 fi
849 TAGVER=$TAG_PREFIX$PACKAGE_NAME-`echo $PACKAGE_VERSION | sed -e "s/\./\_/g" -e "s/@/#/g"`-`echo $PACKAGE_RELEASE | sed -e "s/\./\_/g" -e "s/@/#/g"`
850 # Remove #kernel.version_release from TAGVER because tagging sources
851 # could occur with different kernel-headers than kernel-headers used at build time.
852 TAGVER=$(echo "$TAGVER" | sed -e 's/#.*//g')
853 echo -n "$TAGVER"
854}
855
856tag_files()
857{
858 TAG_FILES="$@"
859
860 if [ -n "$DEBUG" ]; then
861 set -x;
862 set -v;
863 fi
864
865 if [ -n "$1$2$3$4$5$6$7$8$9${10}" ]; then
866 echo "Version: $PACKAGE_VERSION"
867 echo "Release: $PACKAGE_RELEASE"
868
869 TAGVER=`make_tagver`
870
871 if [ "$TAG_VERSION" = "yes" ]; then
872 echo "CVS tag: $TAGVER"
873 fi
874 if [ -n "$TAG" ]; then
875 echo "CVS tag: $TAG"
876 fi
877
878 OPTIONS="tag -F"
879 if [ -n "$CVSROOT" ]; then
880 OPTIONS="-d $CVSROOT $OPTIONS"
881 fi
882
883 cd "$SOURCE_DIR"
884 for i in $TAG_FILES
885 do
886 # don't tag files stored on distfiles
887 [ -n "`src_md5 $i`" ] && continue
888 if [ -f "`nourl $i`" ]; then
889 if [ "$TAG_VERSION" = "yes" ]; then
890 cvs $OPTIONS $TAGVER `nourl $i`
891 fi
892 if [ -n "$TAG" ]; then
893 cvs $OPTIONS $TAG `nourl $i`
894 fi
895 else
896 Exit_error err_no_source_in_repo $i
897 fi
898 done
899
900 cd "$SPECS_DIR"
901 if [ "$TAG_VERSION" = "yes" ]; then
902 cvs $OPTIONS $TAGVER $SPECFILE
903 fi
904 if [ -n "$TAG" ]; then
905 cvs $OPTIONS $TAG $SPECFILE
906 fi
907
908 unset OPTIONS
909 fi
910}
911
912branch_files()
913{
914 TAG=$1
915 echo "CVS branch tag: $TAG"
916 shift;
917
918 TAG_FILES="$@"
919
920 if [ -n "$DEBUG" ]; then
921 set -x;
922 set -v;
923 fi
924
925 if [ -n "$1$2$3$4$5$6$7$8$9${10}" ]; then
926
927 OPTIONS="tag -b"
928 if [ -n "$CVSROOT" ]; then
929 OPTIONS="-d $CVSROOT $OPTIONS"
930 fi
931 cd "$SOURCE_DIR"
932 for i in $TAG_FILES
933 do
934 if [ -f `nourl $i` ]; then
935 cvs $OPTIONS $TAG `nourl $i`
936 else
937 Exit_error err_no_source_in_repo $i
938 fi
939 done
940 cd "$SPECS_DIR"
941 cvs $OPTIONS $TAG $SPECFILE
942
943 unset OPTIONS
944 fi
945}
946
947
948
59398507 949build_package()
950{
2e5be021 951 update_shell_title "build_package"
cd445739
AM
952 if [ -n "$DEBUG" ]; then
953 set -x;
954 set -v;
955 fi
5a491465 956
cd445739
AM
957 cd "$SPECS_DIR"
958
959 if [ -n "$TRY_UPGRADE" ]; then
2e5be021 960 update_shell_title "build_package: try_upgrade"
cd445739 961 if [ -n "$FLOAT_VERSION" ]; then
cc538c24 962 TNOTIFY=`./pldnotify.awk $SPECFILE -n` || exit 1
cd445739 963 else
cc538c24 964 TNOTIFY=`./pldnotify.awk $SPECFILE` || exit 1
cd445739
AM
965 fi
966
967 TNEWVER=`echo $TNOTIFY | awk '{ match($4,/\[NEW\]/); print $5 }'`
968
969 if [ -n "$TNEWVER" ]; then
970 TOLDVER=`echo $TNOTIFY | awk '{ print $3; }'`
971 echo "New version found, updating spec file to version " $TNEWVER
972 cp -f $SPECFILE $SPECFILE.bak
973 chmod +w $SPECFILE
974 eval "perl -pi -e 's/Version:\t"$TOLDVER"/Version:\t"$TNEWVER"/gs' $SPECFILE"
f7b91886 975 eval "perl -pi -e 's/Release:\t[1-9]{0,4}/Release:\t0.1/' $SPECFILE"
cd445739 976 parse_spec;
7f347798 977 if [ -n "$ICONS" ]; then
978 get_files $ICONS;
979 parse_spec;
980 fi
4ea1c265 981 NODIST="yes" UPDATE5="yes" get_files $SOURCES $PATCHES;
cd445739
AM
982 unset TOLDVER TNEWVER TNOTIFY
983 fi
984 fi
985 cd "$SPECS_DIR"
2a5f078d 986
cd445739
AM
987 case "$COMMAND" in
988 build )
989 BUILD_SWITCH="-ba" ;;
990 build-binary )
991 BUILD_SWITCH="-bb" ;;
992 build-source )
993 BUILD_SWITCH="-bs --nodeps" ;;
994 build-prep )
995 BUILD_SWITCH="-bp --nodeps" ;;
996 esac
c890b916 997
2e5be021 998 update_shell_title "build_package: $COMMAND"
cd445739
AM
999 if [ -n "$LOGFILE" ]; then
1000 LOG=`eval echo $LOGFILE`
1001 if [ -d "$LOG" ]; then
1002 echo "Log file $LOG is a directory."
1003 echo "Parse error in the spec?"
1004 Exit_error err_build_fail;
1005 fi
1006 if [ -n "$LASTLOG_FILE" ]; then
1007 echo "LASTLOG=$LOG" > $LASTLOG_FILE
1008 fi
1009 RES_FILE=~/tmp/$RPMBUILD-exit-status.$RANDOM
21bc1a97 1010 (time eval nice -n ${DEF_NICE_LEVEL} $RPMBUILD $BUILD_SWITCH -v $QUIET $CLEAN $RPMOPTS $BCOND $TARGET_SWITCH $SPECFILE; echo $? > $RES_FILE) 2>&1 |tee $LOG
cd445739
AM
1011 RETVAL=`cat $RES_FILE`
1012 rm $RES_FILE
1013 if [ -n "$LOGDIROK" ] && [ -n "$LOGDIRFAIL" ]; then
1014 if [ "$RETVAL" -eq "0" ]; then
1015 mv $LOG $LOGDIROK
1016 else
1017 mv $LOG $LOGDIRFAIL
1018 fi
1019 fi
8ba5cdda 1020 else
8f96ab6c 1021 eval nice -n ${DEF_NICE_LEVEL} $RPMBUILD $BUILD_SWITCH -v $QUIET $CLEAN $RPMOPTS $BCOND $TARGET_SWITCH $SPECFILE
cd445739 1022 RETVAL=$?
8ba5cdda 1023 fi
cd445739
AM
1024 if [ "$RETVAL" -ne "0" ]; then
1025 if [ -n "$TRY_UPGRADE" ]; then
1026 echo "\n!!! Package with new version cannot be build automagically\n"
1027 mv -f $SPECFILE.bak $SPECFILE
1028 fi
1029 Exit_error err_build_fail;
1030 fi
1031 unset BUILD_SWITCH
1032}
1033
1034nourl()
1035{
1036 echo "$@" | sed 's#\<\(ftp\|http\|https\|cvs\|svn\)://[^ ]*/##g'
1037}
1038
cd445739
AM
1039install_required_packages()
1040{
1041 run_poldek -vi $1
1042 return $?
1043}
1044
fa4bf1df
ER
1045find_spec_bcond() {
1046 # taken from find-spec-bcond, but with just getting the list
1047 local SPEC="$1"
1048 # quick revert hint: '$RPMBUILD --bcond $SPEC'
1049 awk -F"\n" '
1050 /^%changelog/ { exit }
1051 /_with(out)?_[_a-zA-Z0-9]+/{
1052 match($0, /_with(out)?_[_a-zA-Z0-9]+/);
1053 print substr($0, RSTART, RLENGTH);
1054 }
1055 /^%bcond_with/{
1056 match($0, /bcond_with(out)?[ \t]+[_a-zA-Z0-9]+/);
1057 bcond = substr($0, RSTART +5 , RLENGTH -5);
1058 gsub(/[ \t]+/,"_",bcond);
1059 print bcond
1060 }' $SPEC | LC_ALL=C sort -u
1061}
1062
cd445739
AM
1063set_bconds_values()
1064{
0b65d15e 1065 update_shell_title "set bcond values"
c890b916 1066
cd445739
AM
1067 AVAIL_BCONDS_WITHOUT=""
1068 AVAIL_BCONDS_WITH=""
1069 if `grep -q ^%bcond ${SPECFILE}`; then
1070 BCOND_VERSION="NEW"
36d03934 1071 elif `egrep -q ^#\ *_with ${SPECFILE}`; then
cd445739
AM
1072 BCOND_VERSION="OLD"
1073 else
fa4bf1df 1074 return
cd445739 1075 fi
301cbfd4 1076
fa4bf1df
ER
1077 local bcond_avail=$(find_spec_bcond $SPECFILE)
1078
301cbfd4
ER
1079 # expand bconds from ~/.bcondrc
1080 # The file structure is like gentoo's package.use:
1081 # ---
1082 # * -selinux
1083 # samba -mysql -pgsql
47a8df12 1084 # w32codec-installer license_agreement
301cbfd4
ER
1085 # php +mysqli
1086 # ---
fa4bf1df 1087 if ([ -f $HOME/.bcondrc ] || ([ -n $HOME_ETC ] && [ -f $HOME_ETC/.bcondrc ])); then
3e1cbfe0 1088 SN=${SPECFILE%%\.spec}
301cbfd4 1089
fa4bf1df
ER
1090 local bcondrc=$HOME/.bcondrc
1091 [ -n $HOME_ETC ] && [ -f $HOME_ETC/.bcondrc ] && bcondrc=$HOME_ETC/.bcondrc
c8a3e2ac 1092
301cbfd4
ER
1093 while read pkg flags; do
1094 # ignore comments
1095 [[ "$pkg" == \#* ]] && continue
1096
1097 # any package or current package?
fa4bf1df 1098 if [ "$pkg" = "*" ] || [ "$pkg" = "$PACKAGE_NAME" ] || [ "$pkg" = "$SN" ]; then
301cbfd4 1099 for flag in $flags; do
fa4bf1df 1100 local opt=${flag#[+-]}
301cbfd4
ER
1101
1102 # use only flags which are in this package.
fa4bf1df 1103 if [[ $bcond_avail = *${opt}* ]]; then
3b5101f0
ER
1104 if [[ $flag = -* ]]; then
1105 BCOND="$BCOND --without $opt"
301cbfd4 1106 else
3b5101f0 1107 BCOND="$BCOND --with $opt"
301cbfd4
ER
1108 fi
1109 fi
1110 done
1111 fi
fa4bf1df
ER
1112 done < $bcondrc
1113 update_shell_title "parse ~/.bcondrc: DONE!"
301cbfd4
ER
1114 fi
1115
fa4bf1df 1116 update_shell_title "parse bconds"
cd445739 1117 case "${BCOND_VERSION}" in
fa4bf1df 1118 NONE)
7e365483 1119 :
cd445739 1120 ;;
7e365483 1121 OLD)
cd445739 1122 echo "Warning: This spec has old style bconds. Fix it || die."
fa4bf1df 1123 for opt in `echo "$bcond_avail" | grep ^_without_`
cd445739 1124 do
fa4bf1df
ER
1125 AVAIL_BCOND_WITHOUT=${opt#_without_}
1126 if [[ "$BCOND" = *--without?${AVAIL_BCOND_WITHOUT}* ]]; then
cd445739
AM
1127 AVAIL_BCONDS_WITHOUT="$AVAIL_BCONDS_WITHOUT <$AVAIL_BCOND_WITHOUT>"
1128 else
1129 AVAIL_BCONDS_WITHOUT="$AVAIL_BCONDS_WITHOUT $AVAIL_BCOND_WITHOUT"
1130 fi
1131 done
2a5f078d 1132
fa4bf1df 1133 for opt in `echo "$bcond_avail" | grep ^_with_`
cd445739 1134 do
fa4bf1df
ER
1135 AVAIL_BCOND_WITH=${opt#_with_}
1136 if [[ "$BCOND" = *--with?${AVAIL_BCOND_WITH}* ]]; then
cd445739
AM
1137 AVAIL_BCONDS_WITH="$AVAIL_BCONDS_WITH <$AVAIL_BCOND_WITH>"
1138 else
1139 AVAIL_BCONDS_WITH="$AVAIL_BCONDS_WITH $AVAIL_BCOND_WITH"
1140 fi
1141 done
1142 ;;
1143 NEW)
fa4bf1df
ER
1144 local cond_type="" # with || without
1145 for opt in $bcond_avail; do
cd445739
AM
1146 case "$opt" in
1147 _without)
1148 cond_type="without"
1149 ;;
1150 _with)
1151 cond_type="with"
1152 ;;
f8d24cee 1153 _without_*)
fa4bf1df
ER
1154 AVAIL_BCOND_WITHOUT=${opt#_without_}
1155 if [[ "$BCOND" = *--without?${AVAIL_BCOND_WITHOUT}* ]]; then
f8d24cee 1156 AVAIL_BCONDS_WITHOUT="$AVAIL_BCONDS_WITHOUT <$AVAIL_BCOND_WITHOUT>"
1157 else
1158 AVAIL_BCONDS_WITHOUT="$AVAIL_BCONDS_WITHOUT $AVAIL_BCOND_WITHOUT"
1159 fi
1160 ;;
1161 _with_*)
fa4bf1df
ER
1162 AVAIL_BCOND_WITH=${opt#_with_}
1163 if [[ "$BCOND" = *--with?${AVAIL_BCOND_WITH}* ]]; then
f8d24cee 1164 AVAIL_BCONDS_WITH="$AVAIL_BCONDS_WITH <$AVAIL_BCOND_WITH>"
1165 else
1166 AVAIL_BCONDS_WITH="$AVAIL_BCONDS_WITH $AVAIL_BCOND_WITH"
1167 fi
1168 ;;
cd445739
AM
1169 *)
1170 case "$cond_type" in
1171 with)
1172 cond_type=''
1173 AVAIL_BCOND_WITH="$opt"
fa4bf1df 1174 if [[ "$BCOND" = *--with?${AVAIL_BCOND_WITH}* ]]; then
cd445739
AM
1175 AVAIL_BCONDS_WITH="$AVAIL_BCONDS_WITH <$AVAIL_BCOND_WITH>"
1176 else
1177 AVAIL_BCONDS_WITH="$AVAIL_BCONDS_WITH $AVAIL_BCOND_WITH"
1178 fi
7e365483 1179 ;;
cd445739
AM
1180 without)
1181 cond_type=''
1182 AVAIL_BCOND_WITHOUT="$opt"
fa4bf1df 1183 if [[ "$BCOND" = *--without?${AVAIL_BCOND_WITHOUT}* ]]; then
cd445739
AM
1184 AVAIL_BCONDS_WITHOUT="$AVAIL_BCONDS_WITHOUT <$AVAIL_BCOND_WITHOUT>"
1185 else
1186 AVAIL_BCONDS_WITHOUT="$AVAIL_BCONDS_WITHOUT $AVAIL_BCOND_WITHOUT"
1187 fi
1188 ;;
1189 esac
1190 ;;
1191 esac
1192 done
1193 ;;
1194 esac
1195}
1196
1197run_sub_builder()
1198{
1199 package_name="${1}"
af6b168f 1200 update_shell_title "run_sub_builder $package_name"
cd445739
AM
1201 #
1202