diff options
author | dougb <dougb@FreeBSD.org> | 2006-05-20 14:25:56 +0800 |
---|---|---|
committer | dougb <dougb@FreeBSD.org> | 2006-05-20 14:25:56 +0800 |
commit | cbffdef767ddb835caf98d83e6f191fd01bdf5ba (patch) | |
tree | b4d026a97abe948749a4749f87510d1a4685af7d | |
parent | cd930a573e0985476b394c41e5ec9f65480080a8 (diff) | |
download | freebsd-ports-gnome-cbffdef767ddb835caf98d83e6f191fd01bdf5ba.tar.gz freebsd-ports-gnome-cbffdef767ddb835caf98d83e6f191fd01bdf5ba.tar.zst freebsd-ports-gnome-cbffdef767ddb835caf98d83e6f191fd01bdf5ba.zip |
1. Implemented recursive 'make config' at the beginning of the run, so it's
easier to leave it running unattended for large updates. (This can be
toggled off.)
2. Implemented a completely unattended mode which accepts the defaults for
all portmaster dialogues. (Note, this does not help with ports that have
interaction other than 'make config', such as ghostscript, etc.)
3. Added -u to sort(1) calls to try and address a bug report about duplicate
lines in +REQUIRED_BY files. I was not able to reproduce this bug, but
better safe than sorry.
4. Verbose mode is now slightly more informative about what's happening.
5. More common code factored out into functions.
6. The -n flag now cancels the build of the port called on the command line too.
7. Improved (?) the stale distfile deletion routine to better handle ports
that have multiple distfiles.
8. We now launch 'make checksum' (which performs a fetch if needed) in the
background while recursing through dependencies.
9. Various code cleanups, such as adding -t to a mktemp invocation that was
missing it, more local variables in functions, more consistent flag variable
values, etc.
-rw-r--r-- | ports-mgmt/portmaster/files/portmaster.8 | 36 | ||||
-rw-r--r-- | ports-mgmt/portmaster/files/portmaster.sh.in | 439 | ||||
-rw-r--r-- | sysutils/portmaster/files/portmaster.8 | 36 | ||||
-rw-r--r-- | sysutils/portmaster/files/portmaster.sh.in | 439 |
4 files changed, 672 insertions, 278 deletions
diff --git a/ports-mgmt/portmaster/files/portmaster.8 b/ports-mgmt/portmaster/files/portmaster.8 index db5378c4ac12..b1144a9fcf8f 100644 --- a/ports-mgmt/portmaster/files/portmaster.8 +++ b/ports-mgmt/portmaster/files/portmaster.8 @@ -24,7 +24,7 @@ .\" .\" $FreeBSD$ .\" -.Dd February 20, 2006 +.Dd May 19, 2006 .Dt PORTMASTER 8 .Os .Sh NAME @@ -32,19 +32,19 @@ .Nd manage your ports .Sh SYNOPSIS .Nm -.Op Fl Canv [f|i] [D|d] m Ar arguments for make +.Op Fl CGanv [uf|i] [D|d] m Ar arguments for make .Op Ar name of port directory in /var/db/pkg .Pp -.Op Fl Canv [f|i] [D|d] m Ar arguments for make +.Op Fl CGanv [uf|i] [D|d] m Ar arguments for make .Op Ar glob pattern from /var/db/pkg .Pp -.Op Fl Canv [f|i] [D|d] m Ar arguments for make +.Op Fl CGanv [uf|i] [D|d] m Ar arguments for make .Op Fl p Ar port directory in /usr/ports .Pp -.Op Fl Canv [f|i] [D|d] m Ar arguments for make +.Op Fl CGanv [uf|i] [D|d] m Ar arguments for make .Op Ar full path to /usr/ports/foo/bar .Pp -.Op Fl Cnv [f|i] [D|d] m Ar arguments for make +.Op Fl CGnv [uf|i] [D|d] m Ar arguments for make .Op Fl r Ar name/glob of port in /var/db/pkg .Pp .Op Fl h @@ -69,21 +69,37 @@ it. In the rare case where you do need to recompile ports which depend on a port you are updating, the -r option exists to accomplish this. -.Pp +By default +.Nm +will first recurse through the port to update, +and all of its dependencies (if any) to handle +any port OPTIONS via the 'make config' interface. +It will then start building all ports that need +updating. +While recursing through dependencies, +a 'make checksum' process will be launched +in the background to either verify that the +correct distfiles are available, +or start downloading the new ones. +.Sh OPTIONS The options are as follows: .Bl -tag -width F1 .It Fl C Prevents 'make clean' being run in port directory +.It Fl G +Prevents the recursive 'make config' .It Fl a check all ports, update as necessary .It Fl n -do not launch child process to update dependencies +do not actually perform any updates .It Fl v verbose output .It Fl f always rebuild ports (overrides -i) .It Fl i interactive update mode +.It Fl u +unattended mode, accepts defaults for all portmaster dialogues .It Fl D prevents cleaning of distfiles .It Fl d @@ -101,9 +117,9 @@ display help file list all installed ports by category .El .Sh FILES -.Bl -tag -width ".Pa $HOME/.portmaster.rc" -compact +.Bl -tag -width ".Pa $HOME/.portmasterrc" -compact .It Pa /etc/portmaster.rc -.It Pa $HOME/.portmaster.rc +.It Pa $HOME/.portmasterrc Optional system and user configuration files. The variables set in the script's getopts routine can be specified in these files to enable those options. diff --git a/ports-mgmt/portmaster/files/portmaster.sh.in b/ports-mgmt/portmaster/files/portmaster.sh.in index 5ecb1de0cd84..d0baa17bd3eb 100644 --- a/ports-mgmt/portmaster/files/portmaster.sh.in +++ b/ports-mgmt/portmaster/files/portmaster.sh.in @@ -1,6 +1,6 @@ #!/bin/sh -# Local version: 1.56 +# Local version: 1.63 # $FreeBSD$ # Copyright (c) 2005-2006 Douglas Barton, All rights reserved @@ -16,15 +16,16 @@ usage () { echo "portmaster version $VERSION_NUMBER" echo '' echo 'Usage:' - echo "${0##*/} [-Canv f|i D|d] <full name of port directory in $pdb>" - echo "${0##*/} [-Canv f|i D|d] <glob pattern of directory in $pdb>" - echo "${0##*/} [-Canv f|i D|d] -p <port directory in $pd>" - echo "${0##*/} [-Canv f|i D|d] <full path to $pd/foo/bar>" - echo "${0##*/} [-Cnv f|i D|d] -r <name/glob of port directory in $pdb>" + echo "${0##*/} [-CGanv uf|i D|d] <full name of port directory in $pdb>" + echo "${0##*/} [-CGanv uf|i D|d] <glob pattern of directory in $pdb>" + echo "${0##*/} [-CGanv uf|i D|d] -p <port directory in $pd>" + echo "${0##*/} [-CGanv uf|i D|d] <full path to $pd/foo/bar>" + echo "${0##*/} [-CGnv uf|i D|d] -r <name/glob of port directory in $pdb>" echo "${0##*/} -h" echo "${0##*/} -l" echo '' echo "-C prevents 'make clean' being run in port directory" + echo "-G prevents recursive 'make config'" echo '-a check all ports, update as necessary' echo '-n do not launch child process to update dependencies' echo '-v verbose output' @@ -34,6 +35,7 @@ usage () { echo '-d always clean distfiles' echo "-m <arguments for the 'make' command line>" echo '-r rebuild port, and all ports that depend on it' + echo "-u unattended mode -- accept defaults for all but 'make config'" echo '-h display this help file' echo '-l list installed ports by category' echo '' @@ -51,29 +53,36 @@ safe_exit () { echo '' rm -f $grep_deps $req_deps test -n "$FORCE_PARENT" && rm -f $UPDATES_DONE_LIST + test -n "$CONFIG_PARENT" && rm -f $CONFIG_SEEN_LIST exit 0 } update_contents () { - tempfile=`mktemp tempfile-${new_port}` + local tempfile + + tempfile=`mktemp -t tempfile-${new_port}` sed "s/@pkgdep $1/@pkgdep $2/" $dep_port_contents > $tempfile && mv $tempfile $pdb/$dep_port/+CONTENTS chmod 644 $pdb/$dep_port/+CONTENTS } dep_warn () { + local num_ports1 + echo '' echo "===>>> Warning! Potential unrecorded dependencies on $new_port" echo "===>>> From existing +CONTENTS files:" grep "pkgdep ${short_port}-" $pdb/*/+CONTENTS | - sort | sed "s#$pdb/##" + sort -u | sed "s#$pdb/##" num_ports1=`grep "pkgdep ${short_port}-" $pdb/*/+CONTENTS | - wc -l | awk '{print $1}'` + sort -u | wc -l | awk '{print $1}'` echo "===>>> $num_ports1 ports" echo '' } update_reqfile () { + local num_ports2 sdiff_deps + dep_warn num_ports2=`wc -l $req_deps | awk '{print $1}'` echo "===>>> From $pdb/$upg_port/+REQUIRED_BY:" @@ -84,17 +93,21 @@ update_reqfile () { echo "===>>> Use dependencies from existing +REQUIRED_BY file [r]" echo "===>>> Use sdiff to edit both files into a new file [s]" echo '' - echo -n "===>>> Update dependency list? [r] " - read DEPUPDATE - - case "$DEPUPDATE" in - [cC]) mv $grep_deps $req_deps ;; - [sS]) sdiff_deps=`mktemp -t sdiff-deps-${short_port}` - sdiff -o $sdiff_deps --text --suppress-common-lines \ - --width=`tput columns` $req_deps $grep_deps - mv $sdiff_deps $req_deps - ;; - esac + if [ -z "$UNATTENDED" ]; then + echo -n "===>>> Update dependency list? [r] " + read DEPUPDATE + + case "$DEPUPDATE" in + [cC]) mv $grep_deps $req_deps ;; + [sS]) sdiff_deps=`mktemp -t sdiff-deps-${short_port}` + sdiff -o $sdiff_deps --text --suppress-common-lines \ + --width=`tput columns` $req_deps $grep_deps + mv $sdiff_deps $req_deps + ;; + esac + else + echo "===>>> Default (use +REQUIRED_BY file) in unattended mode" + fi } update_port () { @@ -109,12 +122,17 @@ update_port () { echo '' if [ -z "$NO_ACTION" ]; then ($0 $ARGS $@) || fail "Update for $upd failed" + else + test -n "$VERBOSE" && + echo "===>>> Build canceled due to -n flag" fi if [ -n "$UPDATE_ALL" ]; then echo "===>>> Returning to update check of installed ports" elif [ -n "$UPDATE_REQ_BYS" ]; then return 0 + elif [ -n "$CONFIG_ONLY" ]; then + echo "===>>> Continuing 'make config' dependency check for $portdir" else echo "===>>> Returning to dependency check for $portdir" fi @@ -122,8 +140,21 @@ update_port () { return 0 } +check_interactive () { + local UPD_OR_NOT + + if [ -n "$INTERACTIVE_UPDATE" ]; then + echo -n "===>>> Update ${1}? [y] " + read UPD_OR_NOT + case "$UPD_OR_NOT" in + [nN]*) return 1 ;; + esac + fi + return 0 +} + check_for_updates () { - local upd_port port_ver do_update UPD_OR_NOT + local upd_port port_ver do_update upd_port=`grep ' ORIGIN' $pdb/$1/+CONTENTS | cut -f2 -d':'` @@ -154,12 +185,8 @@ check_for_updates () { fi if [ -n "$do_update" ]; then - if [ -n "$INTERACTIVE_UPDATE" ]; then - echo -n "===>>> Update ${1}? [y] " - read UPD_OR_NOT - case "$UPD_OR_NOT" in - [nN]*) return 0 ;; - esac + if ! check_interactive $1 ; then + return 0 fi update_port $1 || return 1 @@ -169,6 +196,9 @@ check_for_updates () { } find_moved_port () { + # newportdir is used globally + local m + newportdir=`sed -ne "s#^${1}|\([^|]*\)|.*#\1#p" $pd/MOVED` if [ ! -n "$newportdir" ]; then m=`sed -ne "s#^${1}||.*|\(.*\)#\1#p" $pd/MOVED` @@ -213,6 +243,110 @@ ports_by_category () { done } +dependency_check () { + local dep_port_list dep_port cur_p upd_args p op old_p + + # Print a message here because sometimes all-depends-list takes + # a long time to return. + if [ -n "$CONFIG_ONLY" ]; then + echo "===>>> Checking $portdir dependencies for recursive 'make config'" + else + echo "===>>> Checking if dependencies of $portdir are up to date" + fi + + dep_port_list=`make $MAKE_ARGS all-depends-list` + if [ -z "$dep_port_list" ]; then + echo "===>>> No dependencies for $portdir" + return 0 + fi + + for dep_port in $dep_port_list; do + test -n "$VERBOSE" && + echo "===>>> Checking dependency: $dep_port" + + if [ -n "$CONFIG_SEEN_LIST" ]; then + if [ `grep "${dep_port}$" $CONFIG_SEEN_LIST` ]; then + continue + else + echo "$dep_port" >> $CONFIG_SEEN_LIST + fi + fi + + if [ -n "$UPDATES_DONE_LIST" ]; then + if [ `grep "${dep_port}$" $UPDATES_DONE_LIST` ]; then + continue + fi + fi + + cur_p=`grep -l " ORIGIN:${dep_port#$pd/}$" $pdb/*/+CONTENTS` + if [ -n "$cur_p" ]; then + cur_p=${cur_p%/+CONTENTS} + cur_p=${cur_p##*/} + upd_args=$cur_p + else + upd_args="-p $dep_port" # Sensible default + # Check to see if the dependency has moved because + # if so, we need to update the old port to fix it + p=${dep_port#$pd/} + op=`sed -ne "s#\([^|]*\)|$p|.*#\1#p" $pd/MOVED` + # In case there is more than one match, use the latest + op=`echo $op | sed 's/.* //'` + + if [ -n "$op" ]; then + old_p=`grep -l " ORIGIN:${op}$" $pdb/*/+CONTENTS` + if [ -n "$old_p" ]; then + old_p=${old_p%/+CONTENTS} + old_p=${old_p##*/} + upd_args=$old_p + fi + fi + fi + + if [ -n "$FORCE" ]; then + echo "===>>> Forcing update for $dep_port" + update_port $upd_args + continue + fi + + # If not forcing the update + if [ -n "$cur_p" ]; then + check_for_updates $cur_p + elif [ -n "$old_p" ]; then + check_for_updates $old_p + else + if ! check_interactive $dep_port ; then + continue + fi + + update_port -p $dep_port + fi + done + if [ -n "$CONFIG_ONLY" ]; then + echo "===>>> Recursive 'make config' check complete for $portdir" + else + echo "===>>> Dependency check complete for $portdir" + fi +} + +unset_recursive_config () { + rm -f $CONFIG_SEEN_LIST + unset CONFIG_ONLY CONFIG_SEEN_LIST + + # Overload this variable to simplify the code + NO_RECURSIVE_CONFIG=yes + export NO_RECURSIVE_CONFIG +} + +req_by_error () { + local DISCARD + + echo "===>>> WARNING! $pdb/$1/+REQUIRED_BY " + echo "===>>> shows that $2 requires $1, but " + echo "===>>> $2 does not seem to be installed" + echo -n "===>>> Press Enter to proceed " + read DISCARD +} + pd=`make $MAKE_ARGS -f/dev/null -V PORTSDIR 2>/dev/null` pdb=`make $MAKE_ARGS -f/dev/null -V PKG_DBDIR 2>/dev/null` @@ -231,14 +365,15 @@ fi : ${pdb:=/var/db/pkg} # Save switches for potential child processes -while getopts 'CDadfhilnm:p:r:v' COMMAND_LINE_ARGUMENT ; do +while getopts 'CDGadfhilm:np:r:uv' COMMAND_LINE_ARGUMENT ; do case "${COMMAND_LINE_ARGUMENT}" in C) DONT_PRE_CLEAN=yes; ARGS="-C $ARGS" ;; D) DONT_SCRUB_DISTFILES=yes; ARGS="-D $ARGS" ;; + G) NO_RECURSIVE_CONFIG=yes; ARGS="-G $ARGS" ;; a) UPDATE_ALL=yes ;; d) ALWAYS_SCRUB_DISTFILES=yes; ARGS="-d $ARGS" ;; f) FORCE_PARENT=yes - FORCE=yes + FORCE=yes UPDATES_DONE_LIST=`mktemp -t updates_done_list` export FORCE UPDATES_DONE_LIST ;; @@ -249,40 +384,91 @@ while getopts 'CDadfhilnm:p:r:v' COMMAND_LINE_ARGUMENT ; do n) NO_ACTION=yes ;; p) portdir="${OPTARG#$pd/}" ;; r) UPDATE_REQ_BYS=yes; upg_port=$OPTARG ;; + u) UNATTENDED=yes; ARGS="-u $ARGS" ;; v) VERBOSE=yes; ARGS="-v $ARGS" ;; esac done -test -n "$FORCE" && unset INTERACTIVE_UPDATE - if [ -n "$LIST" ]; then ports_by_category + num_roots=0 + num_trunks=0 + num_branches=0 + num_leaves=0 + echo "===>>> Root ports (No dependencies, not depended on)" for port in $roots; do echo "===>>> ${port##*/}" + num_roots=$(( $num_roots + 1 )) done + echo "===>>> $num_roots root ports" echo '' echo "===>>> Trunk ports (No dependencies, are depended on)" for port in $trunks; do echo "===>>> ${port##*/}" + num_trunks=$(( $num_trunks + 1 )) done + echo "===>>> $num_trunks trunk ports" echo '' echo "===>>> Branch ports (Have dependencies, are depended on)" for port in $branches; do echo "===>>> ${port##*/}" + num_branches=$(( $num_branches + 1 )) done + echo "===>>> $num_branches branch ports" echo '' echo "===>>> Leaf ports (Have dependencies, not depended on)" for port in $leaves; do echo "===>>> ${port##*/}" + num_leaves=$(( $num_leaves + 1 )) done + echo "===>>> $num_leaves leaf ports" + echo '' + num_ports=$(( $num_roots + $num_trunks + $num_branches + $num_leaves )) + echo "===>>> $num_ports total installed ports" exit 0 fi +test -n "$FORCE" && unset INTERACTIVE_UPDATE +if [ -n "$UNATTENDED" ]; then + unset INTERACTIVE_UPDATE + + if [ -z "$DONT_SCRUB_DISTFILES" -a -z "$ALWAYS_SCRUB_DISTFILES" ]; then + ALWAYS_SCRUB_DISTFILES=yes + ARGS="-d $ARGS" + fi +fi + +if [ -z "$CONFIG_ONLY" -a -z "$NO_RECURSIVE_CONFIG" ]; then + CONFIG_SEEN_LIST=`mktemp -t config_seen_list` + CONFIG_ONLY=yes + export CONFIG_SEEN_LIST CONFIG_ONLY + + CONFIG_PARENT=yes +fi + if [ -n "$UPDATE_ALL" ]; then echo "===>>> Starting check of installed ports for available updates" ports_by_category + + if [ -n "$CONFIG_SEEN_LIST" ]; then + echo "===>>> Checking ports for recursive 'make config'" + for pkg in $roots $trunks $branches $leaves; do + p=`grep ' ORIGIN' $pkg/+CONTENTS | cut -f2 -d':'` + if [ `grep "${pd}/${p}$" $CONFIG_SEEN_LIST` ]; then + continue + else + echo "${pd}/${p}" >> $CONFIG_SEEN_LIST + check_for_updates ${pkg##*/} || + fail 'Update failed' + fi + done + unset_recursive_config + echo '' + echo "===>>> Starting build for ports that need updating <<<===" + fi + for pkg in $roots $trunks $branches $leaves; do if [ ! -d "$pkg" ]; then # This port probably got updated as a dependency @@ -306,7 +492,7 @@ if [ -n "$UPDATE_ALL" ]; then check_for_updates ${pkg##*/} || fail 'Update failed' done echo "===>>> Update check of installed ports complete" - exit 0 + safe_exit fi # Exercised in the common case of not using -p option @@ -337,7 +523,7 @@ case "$upg_port" in read GLOB_DIR case "$GLOB_DIR" in [yY]) upg_port=${dir#$pdb/} - selected=true + selected=yes break ;; esac @@ -360,72 +546,56 @@ fi cd $pd/$portdir || usage -# Do this here so that the dependency list is accurate -make $MAKE_ARGS config +echo "===>>> Launching 'make checksum' for $portdir in background" +fetchlog=`mktemp -t fetchlog-${portdir##*/}` +(make $MAKE_ARGS checksum >$fetchlog 2>&1 ; rm $fetchlog)& -echo "===>>> Checking if dependencies of $portdir are up to date" -dep_port_list=`make $MAKE_ARGS all-depends-list` -if [ -n "$dep_port_list" ]; then - for dep_port in $dep_port_list; do - test -n "$VERBOSE" && - echo "===>>> Checking dependency: $dep_port" +# Do this here so that the dependency list is accurate +# But only if we have not done it recursively first +test -z "$NO_RECURSIVE_CONFIG" && make $MAKE_ARGS config - if [ -n "$UPDATES_DONE_LIST" ]; then - if [ `grep "${dep_port}$" $UPDATES_DONE_LIST` ]; then - continue - fi - fi +if [ -n "$CONFIG_ONLY" ]; then + dependency_check - cur_p=`grep -l " ORIGIN:${dep_port#$pd/}$" $pdb/*/+CONTENTS` - if [ -n "$cur_p" ]; then - cur_p=${cur_p%/+CONTENTS} - cur_p=${cur_p##*/} - upd_args=$cur_p - else - upd_args="-p $dep_port" # Sensible default - # Check to see if the dependency has moved because - # if so, we need to update the old port to fix it - p=${dep_port#$pd/} - op=`sed -ne "s#\([^|]*\)|$p|.*#\1#p" $pd/MOVED` - # In case there is more than one match, use the latest - op=`echo $op | sed 's/.* //'` + if [ -z "$CONFIG_PARENT" ]; then + safe_exit + else + if [ -n "$UPDATE_REQ_BYS" -a \ + -r "$pdb/$upg_port/+REQUIRED_BY" ]; then + echo "$pd/$portdir" >> $CONFIG_SEEN_LIST - if [ -n "$op" ]; then - old_p=`grep -l " ORIGIN:${op}$" $pdb/*/+CONTENTS` - if [ -n "$old_p" ]; then - old_p=${old_p%/+CONTENTS} - old_p=${old_p##*/} - upd_args=$old_p + echo '' + echo "===>>> Checking ports that depend on $upg_port" + for req_by in `cat $pdb/$upg_port/+REQUIRED_BY`; do + test -n "$VERBOSE" && + echo "===>>> $req_by is required by $upg_port" + if [ ! -d "$pdb/$req_by" ]; then + req_by_error $upg_port $req_by + continue + fi + if ! check_interactive ${req_by} ; then + continue fi - fi - fi - if [ -n "$FORCE" ]; then - echo "===>>> Forcing update for $dep_port" - update_port $upd_args - continue + update_port $req_by + done + echo "===>>> Done checking ports that depend on $upg_port" fi - # If not forcing the update - if [ -n "$cur_p" ]; then - check_for_updates $cur_p - elif [ -n "$old_p" ]; then - check_for_updates $old_p - else - if [ -n "$INTERACTIVE_UPDATE" ]; then - echo -n "===>>> Install $dep_port? [y] " - read UPD_OR_NOT - case "$UPD_OR_NOT" in - [nN]*) continue ;; - esac - fi + unset_recursive_config + fi + echo '' + echo "===>>> Starting build for $portdir <<<===" + echo '' +fi - update_port -p $dep_port - fi - done - echo "===>>> Dependency check complete for $portdir" -else - echo "===>>> No dependencies for $portdir" +cd $pd/$portdir +dependency_check + +if [ -n "$NO_ACTION" ]; then + test -n "$VERBOSE" && + echo "===>>> Build canceled due to -n flag" + safe_exit fi case "$DONT_PRE_CLEAN" in @@ -434,7 +604,17 @@ esac # In case we went elsewhere in the dependency check cd $pd/$portdir -make $MAKE_ARGS || fail 'make failed' + +while [ -f "$fetchlog" ]; do + echo '' + echo "===>>> Waiting on fetch to complete for $portdir <<<===" + tail -10 $fetchlog | grep -v '^$' + echo '' + echo "===>>> Waiting on fetch to complete for $portdir <<<===" + sleep 3 +done + +make $MAKE_ARGS || fail "make failed for $portdir" new_port=`make $MAKE_ARGS -V PKGNAME` prefix=`make $MAKE_ARGS -V PKGNAMEPREFIX` @@ -445,11 +625,11 @@ short_port="${prefix}${portname}${suffix}" # Check for dependencies here in case +REQUIRED_BY is not up to date or missing grep_deps=`mktemp -t grep-deps-${short_port}` grep -l "pkgdep ${short_port}-" $pdb/*/+CONTENTS | cut -f 5 -d '/' | - sort > $grep_deps + sort -u > $grep_deps if [ -s "$pdb/$upg_port/+REQUIRED_BY" ]; then req_deps=`mktemp -t req-deps-${short_port}` - sort $pdb/$upg_port/+REQUIRED_BY > $req_deps + sort -u $pdb/$upg_port/+REQUIRED_BY > $req_deps fi if [ ! -s "$grep_deps" -a ! -s "$req_deps" ]; then @@ -463,13 +643,17 @@ elif [ -s "$grep_deps" -a -s "$req_deps" ]; then elif [ -s "$grep_deps" -a ! -s "$req_deps" ]; then dep_warn echo -n "===>>> Install these as the new +REQUIRED_BY file? [n] " - read INSTALLDEPS + if [ -z "$UNATTENDED" ]; then + read INSTALLDEPS - case "$INSTALLDEPS" in - [yY]) req_deps=`mktemp -t req-deps-${short_port}` - mv $grep_deps $req_deps - ;; - esac + case "$INSTALLDEPS" in + [yY]) req_deps=`mktemp -t req-deps-${short_port}` + mv $grep_deps $req_deps + ;; + esac + else + echo "===>>> Default (no) in unattended mode" + fi else # It should not happen that req_deps exist but grep_deps does not fail "$pdb/$upg_port/+REQUIRED_BY indicates a dependency on this port, but no other ports have this dependency recorded" @@ -512,29 +696,34 @@ if [ -z "$DONT_SCRUB_DISTFILES" ]; then test -n "$dist_subdir" && distdir="${distdir}/${dist_subdir}" distfiles=`make $MAKE_ARGS -V DISTFILES` - distname=`make $MAKE_ARGS -V DISTNAME | cut -f 1 -d '-'` cd $distdir || fail "cd to $distdir failed!" - for file in ${distname}*; do - # This generally means the pattern did not match - case "$file" in - *\*) continue ;; - esac + for distfile in $distfiles; do + for file in ${distfile%%[_-]*}*; do + # This generally means the pattern did not match + case "$file" in + *\*) continue ;; + esac - case "$distfiles" in - *${file}*) continue ;; # Do not delete current version - *) if [ -n "$ALWAYS_SCRUB_DISTFILES" ]; then - echo "===>>> Deleting stale distfile: $file" - rm -f $file - continue - fi + case "$distfiles" in + *${file}*) + test -n "$VERBOSE" && + echo "===>>> Keeping new distfile: $file" + continue # Do not delete current version + ;; + *) if [ -n "$ALWAYS_SCRUB_DISTFILES" ]; then + echo "===>>> Deleting stale distfile: $file" + rm -f $file + continue + fi - echo -n "===>>> Delete $file? [n] " - read DELORNOT - case "$DELORNOT" in - [yY]) rm -f $file ;; + echo -n "===>>> Delete $file? [n] " + read DELORNOT + case "$DELORNOT" in + [yY]) rm -f $file ;; + esac + ;; esac - ;; - esac + done done fi @@ -545,19 +734,11 @@ if [ -n "$UPDATE_REQ_BYS" -a -r "$pdb/$new_port/+REQUIRED_BY" ]; then test -n "$VERBOSE" && echo "===>>> $req_by is required by $new_port" if [ ! -d "$pdb/$req_by" ]; then - echo -n "===>>> WARNING! $pdb/$new_port/+REQUIRED_BY " - echo -n "shows that $req_by requires $new_port, but " - echo "$req_by does not seem to be installed" - echo -n "===>>> Press Enter to proceed " - read DISCARD + req_by_error $new_port $req_by continue fi - if [ -n "$INTERACTIVE_UPDATE" ]; then - echo -n "===>>> Update ${req_by}? [y] " - read UPD_OR_NOT - case "$UPD_OR_NOT" in - [nN]*) continue ;; - esac + if ! check_interactive ${req_by} ; then + continue fi update_port $req_by diff --git a/sysutils/portmaster/files/portmaster.8 b/sysutils/portmaster/files/portmaster.8 index db5378c4ac12..b1144a9fcf8f 100644 --- a/sysutils/portmaster/files/portmaster.8 +++ b/sysutils/portmaster/files/portmaster.8 @@ -24,7 +24,7 @@ .\" .\" $FreeBSD$ .\" -.Dd February 20, 2006 +.Dd May 19, 2006 .Dt PORTMASTER 8 .Os .Sh NAME @@ -32,19 +32,19 @@ .Nd manage your ports .Sh SYNOPSIS .Nm -.Op Fl Canv [f|i] [D|d] m Ar arguments for make +.Op Fl CGanv [uf|i] [D|d] m Ar arguments for make .Op Ar name of port directory in /var/db/pkg .Pp -.Op Fl Canv [f|i] [D|d] m Ar arguments for make +.Op Fl CGanv [uf|i] [D|d] m Ar arguments for make .Op Ar glob pattern from /var/db/pkg .Pp -.Op Fl Canv [f|i] [D|d] m Ar arguments for make +.Op Fl CGanv [uf|i] [D|d] m Ar arguments for make .Op Fl p Ar port directory in /usr/ports .Pp -.Op Fl Canv [f|i] [D|d] m Ar arguments for make +.Op Fl CGanv [uf|i] [D|d] m Ar arguments for make .Op Ar full path to /usr/ports/foo/bar .Pp -.Op Fl Cnv [f|i] [D|d] m Ar arguments for make +.Op Fl CGnv [uf|i] [D|d] m Ar arguments for make .Op Fl r Ar name/glob of port in /var/db/pkg .Pp .Op Fl h @@ -69,21 +69,37 @@ it. In the rare case where you do need to recompile ports which depend on a port you are updating, the -r option exists to accomplish this. -.Pp +By default +.Nm +will first recurse through the port to update, +and all of its dependencies (if any) to handle +any port OPTIONS via the 'make config' interface. +It will then start building all ports that need +updating. +While recursing through dependencies, +a 'make checksum' process will be launched +in the background to either verify that the +correct distfiles are available, +or start downloading the new ones. +.Sh OPTIONS The options are as follows: .Bl -tag -width F1 .It Fl C Prevents 'make clean' being run in port directory +.It Fl G +Prevents the recursive 'make config' .It Fl a check all ports, update as necessary .It Fl n -do not launch child process to update dependencies +do not actually perform any updates .It Fl v verbose output .It Fl f always rebuild ports (overrides -i) .It Fl i interactive update mode +.It Fl u +unattended mode, accepts defaults for all portmaster dialogues .It Fl D prevents cleaning of distfiles .It Fl d @@ -101,9 +117,9 @@ display help file list all installed ports by category .El .Sh FILES -.Bl -tag -width ".Pa $HOME/.portmaster.rc" -compact +.Bl -tag -width ".Pa $HOME/.portmasterrc" -compact .It Pa /etc/portmaster.rc -.It Pa $HOME/.portmaster.rc +.It Pa $HOME/.portmasterrc Optional system and user configuration files. The variables set in the script's getopts routine can be specified in these files to enable those options. diff --git a/sysutils/portmaster/files/portmaster.sh.in b/sysutils/portmaster/files/portmaster.sh.in index 5ecb1de0cd84..d0baa17bd3eb 100644 --- a/sysutils/portmaster/files/portmaster.sh.in +++ b/sysutils/portmaster/files/portmaster.sh.in @@ -1,6 +1,6 @@ #!/bin/sh -# Local version: 1.56 +# Local version: 1.63 # $FreeBSD$ # Copyright (c) 2005-2006 Douglas Barton, All rights reserved @@ -16,15 +16,16 @@ usage () { echo "portmaster version $VERSION_NUMBER" echo '' echo 'Usage:' - echo "${0##*/} [-Canv f|i D|d] <full name of port directory in $pdb>" - echo "${0##*/} [-Canv f|i D|d] <glob pattern of directory in $pdb>" - echo "${0##*/} [-Canv f|i D|d] -p <port directory in $pd>" - echo "${0##*/} [-Canv f|i D|d] <full path to $pd/foo/bar>" - echo "${0##*/} [-Cnv f|i D|d] -r <name/glob of port directory in $pdb>" + echo "${0##*/} [-CGanv uf|i D|d] <full name of port directory in $pdb>" + echo "${0##*/} [-CGanv uf|i D|d] <glob pattern of directory in $pdb>" + echo "${0##*/} [-CGanv uf|i D|d] -p <port directory in $pd>" + echo "${0##*/} [-CGanv uf|i D|d] <full path to $pd/foo/bar>" + echo "${0##*/} [-CGnv uf|i D|d] -r <name/glob of port directory in $pdb>" echo "${0##*/} -h" echo "${0##*/} -l" echo '' echo "-C prevents 'make clean' being run in port directory" + echo "-G prevents recursive 'make config'" echo '-a check all ports, update as necessary' echo '-n do not launch child process to update dependencies' echo '-v verbose output' @@ -34,6 +35,7 @@ usage () { echo '-d always clean distfiles' echo "-m <arguments for the 'make' command line>" echo '-r rebuild port, and all ports that depend on it' + echo "-u unattended mode -- accept defaults for all but 'make config'" echo '-h display this help file' echo '-l list installed ports by category' echo '' @@ -51,29 +53,36 @@ safe_exit () { echo '' rm -f $grep_deps $req_deps test -n "$FORCE_PARENT" && rm -f $UPDATES_DONE_LIST + test -n "$CONFIG_PARENT" && rm -f $CONFIG_SEEN_LIST exit 0 } update_contents () { - tempfile=`mktemp tempfile-${new_port}` + local tempfile + + tempfile=`mktemp -t tempfile-${new_port}` sed "s/@pkgdep $1/@pkgdep $2/" $dep_port_contents > $tempfile && mv $tempfile $pdb/$dep_port/+CONTENTS chmod 644 $pdb/$dep_port/+CONTENTS } dep_warn () { + local num_ports1 + echo '' echo "===>>> Warning! Potential unrecorded dependencies on $new_port" echo "===>>> From existing +CONTENTS files:" grep "pkgdep ${short_port}-" $pdb/*/+CONTENTS | - sort | sed "s#$pdb/##" + sort -u | sed "s#$pdb/##" num_ports1=`grep "pkgdep ${short_port}-" $pdb/*/+CONTENTS | - wc -l | awk '{print $1}'` + sort -u | wc -l | awk '{print $1}'` echo "===>>> $num_ports1 ports" echo '' } update_reqfile () { + local num_ports2 sdiff_deps + dep_warn num_ports2=`wc -l $req_deps | awk '{print $1}'` echo "===>>> From $pdb/$upg_port/+REQUIRED_BY:" @@ -84,17 +93,21 @@ update_reqfile () { echo "===>>> Use dependencies from existing +REQUIRED_BY file [r]" echo "===>>> Use sdiff to edit both files into a new file [s]" echo '' - echo -n "===>>> Update dependency list? [r] " - read DEPUPDATE - - case "$DEPUPDATE" in - [cC]) mv $grep_deps $req_deps ;; - [sS]) sdiff_deps=`mktemp -t sdiff-deps-${short_port}` - sdiff -o $sdiff_deps --text --suppress-common-lines \ - --width=`tput columns` $req_deps $grep_deps - mv $sdiff_deps $req_deps - ;; - esac + if [ -z "$UNATTENDED" ]; then + echo -n "===>>> Update dependency list? [r] " + read DEPUPDATE + + case "$DEPUPDATE" in + [cC]) mv $grep_deps $req_deps ;; + [sS]) sdiff_deps=`mktemp -t sdiff-deps-${short_port}` + sdiff -o $sdiff_deps --text --suppress-common-lines \ + --width=`tput columns` $req_deps $grep_deps + mv $sdiff_deps $req_deps + ;; + esac + else + echo "===>>> Default (use +REQUIRED_BY file) in unattended mode" + fi } update_port () { @@ -109,12 +122,17 @@ update_port () { echo '' if [ -z "$NO_ACTION" ]; then ($0 $ARGS $@) || fail "Update for $upd failed" + else + test -n "$VERBOSE" && + echo "===>>> Build canceled due to -n flag" fi if [ -n "$UPDATE_ALL" ]; then echo "===>>> Returning to update check of installed ports" elif [ -n "$UPDATE_REQ_BYS" ]; then return 0 + elif [ -n "$CONFIG_ONLY" ]; then + echo "===>>> Continuing 'make config' dependency check for $portdir" else echo "===>>> Returning to dependency check for $portdir" fi @@ -122,8 +140,21 @@ update_port () { return 0 } +check_interactive () { + local UPD_OR_NOT + + if [ -n "$INTERACTIVE_UPDATE" ]; then + echo -n "===>>> Update ${1}? [y] " + read UPD_OR_NOT + case "$UPD_OR_NOT" in + [nN]*) return 1 ;; + esac + fi + return 0 +} + check_for_updates () { - local upd_port port_ver do_update UPD_OR_NOT + local upd_port port_ver do_update upd_port=`grep ' ORIGIN' $pdb/$1/+CONTENTS | cut -f2 -d':'` @@ -154,12 +185,8 @@ check_for_updates () { fi if [ -n "$do_update" ]; then - if [ -n "$INTERACTIVE_UPDATE" ]; then - echo -n "===>>> Update ${1}? [y] " - read UPD_OR_NOT - case "$UPD_OR_NOT" in - [nN]*) return 0 ;; - esac + if ! check_interactive $1 ; then + return 0 fi update_port $1 || return 1 @@ -169,6 +196,9 @@ check_for_updates () { } find_moved_port () { + # newportdir is used globally + local m + newportdir=`sed -ne "s#^${1}|\([^|]*\)|.*#\1#p" $pd/MOVED` if [ ! -n "$newportdir" ]; then m=`sed -ne "s#^${1}||.*|\(.*\)#\1#p" $pd/MOVED` @@ -213,6 +243,110 @@ ports_by_category () { done } +dependency_check () { + local dep_port_list dep_port cur_p upd_args p op old_p + + # Print a message here because sometimes all-depends-list takes + # a long time to return. + if [ -n "$CONFIG_ONLY" ]; then + echo "===>>> Checking $portdir dependencies for recursive 'make config'" + else + echo "===>>> Checking if dependencies of $portdir are up to date" + fi + + dep_port_list=`make $MAKE_ARGS all-depends-list` + if [ -z "$dep_port_list" ]; then + echo "===>>> No dependencies for $portdir" + return 0 + fi + + for dep_port in $dep_port_list; do + test -n "$VERBOSE" && + echo "===>>> Checking dependency: $dep_port" + + if [ -n "$CONFIG_SEEN_LIST" ]; then + if [ `grep "${dep_port}$" $CONFIG_SEEN_LIST` ]; then + continue + else + echo "$dep_port" >> $CONFIG_SEEN_LIST + fi + fi + + if [ -n "$UPDATES_DONE_LIST" ]; then + if [ `grep "${dep_port}$" $UPDATES_DONE_LIST` ]; then + continue + fi + fi + + cur_p=`grep -l " ORIGIN:${dep_port#$pd/}$" $pdb/*/+CONTENTS` + if [ -n "$cur_p" ]; then + cur_p=${cur_p%/+CONTENTS} + cur_p=${cur_p##*/} + upd_args=$cur_p + else + upd_args="-p $dep_port" # Sensible default + # Check to see if the dependency has moved because + # if so, we need to update the old port to fix it + p=${dep_port#$pd/} + op=`sed -ne "s#\([^|]*\)|$p|.*#\1#p" $pd/MOVED` + # In case there is more than one match, use the latest + op=`echo $op | sed 's/.* //'` + + if [ -n "$op" ]; then + old_p=`grep -l " ORIGIN:${op}$" $pdb/*/+CONTENTS` + if [ -n "$old_p" ]; then + old_p=${old_p%/+CONTENTS} + old_p=${old_p##*/} + upd_args=$old_p + fi + fi + fi + + if [ -n "$FORCE" ]; then + echo "===>>> Forcing update for $dep_port" + update_port $upd_args + continue + fi + + # If not forcing the update + if [ -n "$cur_p" ]; then + check_for_updates $cur_p + elif [ -n "$old_p" ]; then + check_for_updates $old_p + else + if ! check_interactive $dep_port ; then + continue + fi + + update_port -p $dep_port + fi + done + if [ -n "$CONFIG_ONLY" ]; then + echo "===>>> Recursive 'make config' check complete for $portdir" + else + echo "===>>> Dependency check complete for $portdir" + fi +} + +unset_recursive_config () { + rm -f $CONFIG_SEEN_LIST + unset CONFIG_ONLY CONFIG_SEEN_LIST + + # Overload this variable to simplify the code + NO_RECURSIVE_CONFIG=yes + export NO_RECURSIVE_CONFIG +} + +req_by_error () { + local DISCARD + + echo "===>>> WARNING! $pdb/$1/+REQUIRED_BY " + echo "===>>> shows that $2 requires $1, but " + echo "===>>> $2 does not seem to be installed" + echo -n "===>>> Press Enter to proceed " + read DISCARD +} + pd=`make $MAKE_ARGS -f/dev/null -V PORTSDIR 2>/dev/null` pdb=`make $MAKE_ARGS -f/dev/null -V PKG_DBDIR 2>/dev/null` @@ -231,14 +365,15 @@ fi : ${pdb:=/var/db/pkg} # Save switches for potential child processes -while getopts 'CDadfhilnm:p:r:v' COMMAND_LINE_ARGUMENT ; do +while getopts 'CDGadfhilm:np:r:uv' COMMAND_LINE_ARGUMENT ; do case "${COMMAND_LINE_ARGUMENT}" in C) DONT_PRE_CLEAN=yes; ARGS="-C $ARGS" ;; D) DONT_SCRUB_DISTFILES=yes; ARGS="-D $ARGS" ;; + G) NO_RECURSIVE_CONFIG=yes; ARGS="-G $ARGS" ;; a) UPDATE_ALL=yes ;; d) ALWAYS_SCRUB_DISTFILES=yes; ARGS="-d $ARGS" ;; f) FORCE_PARENT=yes - FORCE=yes + FORCE=yes UPDATES_DONE_LIST=`mktemp -t updates_done_list` export FORCE UPDATES_DONE_LIST ;; @@ -249,40 +384,91 @@ while getopts 'CDadfhilnm:p:r:v' COMMAND_LINE_ARGUMENT ; do n) NO_ACTION=yes ;; p) portdir="${OPTARG#$pd/}" ;; r) UPDATE_REQ_BYS=yes; upg_port=$OPTARG ;; + u) UNATTENDED=yes; ARGS="-u $ARGS" ;; v) VERBOSE=yes; ARGS="-v $ARGS" ;; esac done -test -n "$FORCE" && unset INTERACTIVE_UPDATE - if [ -n "$LIST" ]; then ports_by_category + num_roots=0 + num_trunks=0 + num_branches=0 + num_leaves=0 + echo "===>>> Root ports (No dependencies, not depended on)" for port in $roots; do echo "===>>> ${port##*/}" + num_roots=$(( $num_roots + 1 )) done + echo "===>>> $num_roots root ports" echo '' echo "===>>> Trunk ports (No dependencies, are depended on)" for port in $trunks; do echo "===>>> ${port##*/}" + num_trunks=$(( $num_trunks + 1 )) done + echo "===>>> $num_trunks trunk ports" echo '' echo "===>>> Branch ports (Have dependencies, are depended on)" for port in $branches; do echo "===>>> ${port##*/}" + num_branches=$(( $num_branches + 1 )) done + echo "===>>> $num_branches branch ports" echo '' echo "===>>> Leaf ports (Have dependencies, not depended on)" for port in $leaves; do echo "===>>> ${port##*/}" + num_leaves=$(( $num_leaves + 1 )) done + echo "===>>> $num_leaves leaf ports" + echo '' + num_ports=$(( $num_roots + $num_trunks + $num_branches + $num_leaves )) + echo "===>>> $num_ports total installed ports" exit 0 fi +test -n "$FORCE" && unset INTERACTIVE_UPDATE +if [ -n "$UNATTENDED" ]; then + unset INTERACTIVE_UPDATE + + if [ -z "$DONT_SCRUB_DISTFILES" -a -z "$ALWAYS_SCRUB_DISTFILES" ]; then + ALWAYS_SCRUB_DISTFILES=yes + ARGS="-d $ARGS" + fi +fi + +if [ -z "$CONFIG_ONLY" -a -z "$NO_RECURSIVE_CONFIG" ]; then + CONFIG_SEEN_LIST=`mktemp -t config_seen_list` + CONFIG_ONLY=yes + export CONFIG_SEEN_LIST CONFIG_ONLY + + CONFIG_PARENT=yes +fi + if [ -n "$UPDATE_ALL" ]; then echo "===>>> Starting check of installed ports for available updates" ports_by_category + + if [ -n "$CONFIG_SEEN_LIST" ]; then + echo "===>>> Checking ports for recursive 'make config'" + for pkg in $roots $trunks $branches $leaves; do + p=`grep ' ORIGIN' $pkg/+CONTENTS | cut -f2 -d':'` + if [ `grep "${pd}/${p}$" $CONFIG_SEEN_LIST` ]; then + continue + else + echo "${pd}/${p}" >> $CONFIG_SEEN_LIST + check_for_updates ${pkg##*/} || + fail 'Update failed' + fi + done + unset_recursive_config + echo '' + echo "===>>> Starting build for ports that need updating <<<===" + fi + for pkg in $roots $trunks $branches $leaves; do if [ ! -d "$pkg" ]; then # This port probably got updated as a dependency @@ -306,7 +492,7 @@ if [ -n "$UPDATE_ALL" ]; then check_for_updates ${pkg##*/} || fail 'Update failed' done echo "===>>> Update check of installed ports complete" - exit 0 + safe_exit fi # Exercised in the common case of not using -p option @@ -337,7 +523,7 @@ case "$upg_port" in read GLOB_DIR case "$GLOB_DIR" in [yY]) upg_port=${dir#$pdb/} - selected=true + selected=yes break ;; esac @@ -360,72 +546,56 @@ fi cd $pd/$portdir || usage -# Do this here so that the dependency list is accurate -make $MAKE_ARGS config +echo "===>>> Launching 'make checksum' for $portdir in background" +fetchlog=`mktemp -t fetchlog-${portdir##*/}` +(make $MAKE_ARGS checksum >$fetchlog 2>&1 ; rm $fetchlog)& -echo "===>>> Checking if dependencies of $portdir are up to date" -dep_port_list=`make $MAKE_ARGS all-depends-list` -if [ -n "$dep_port_list" ]; then - for dep_port in $dep_port_list; do - test -n "$VERBOSE" && - echo "===>>> Checking dependency: $dep_port" +# Do this here so that the dependency list is accurate +# But only if we have not done it recursively first +test -z "$NO_RECURSIVE_CONFIG" && make $MAKE_ARGS config - if [ -n "$UPDATES_DONE_LIST" ]; then - if [ `grep "${dep_port}$" $UPDATES_DONE_LIST` ]; then - continue - fi - fi +if [ -n "$CONFIG_ONLY" ]; then + dependency_check - cur_p=`grep -l " ORIGIN:${dep_port#$pd/}$" $pdb/*/+CONTENTS` - if [ -n "$cur_p" ]; then - cur_p=${cur_p%/+CONTENTS} - cur_p=${cur_p##*/} - upd_args=$cur_p - else - upd_args="-p $dep_port" # Sensible default - # Check to see if the dependency has moved because - # if so, we need to update the old port to fix it - p=${dep_port#$pd/} - op=`sed -ne "s#\([^|]*\)|$p|.*#\1#p" $pd/MOVED` - # In case there is more than one match, use the latest - op=`echo $op | sed 's/.* //'` + if [ -z "$CONFIG_PARENT" ]; then + safe_exit + else + if [ -n "$UPDATE_REQ_BYS" -a \ + -r "$pdb/$upg_port/+REQUIRED_BY" ]; then + echo "$pd/$portdir" >> $CONFIG_SEEN_LIST - if [ -n "$op" ]; then - old_p=`grep -l " ORIGIN:${op}$" $pdb/*/+CONTENTS` - if [ -n "$old_p" ]; then - old_p=${old_p%/+CONTENTS} - old_p=${old_p##*/} - upd_args=$old_p + echo '' + echo "===>>> Checking ports that depend on $upg_port" + for req_by in `cat $pdb/$upg_port/+REQUIRED_BY`; do + test -n "$VERBOSE" && + echo "===>>> $req_by is required by $upg_port" + if [ ! -d "$pdb/$req_by" ]; then + req_by_error $upg_port $req_by + continue + fi + if ! check_interactive ${req_by} ; then + continue fi - fi - fi - if [ -n "$FORCE" ]; then - echo "===>>> Forcing update for $dep_port" - update_port $upd_args - continue + update_port $req_by + done + echo "===>>> Done checking ports that depend on $upg_port" fi - # If not forcing the update - if [ -n "$cur_p" ]; then - check_for_updates $cur_p - elif [ -n "$old_p" ]; then - check_for_updates $old_p - else - if [ -n "$INTERACTIVE_UPDATE" ]; then - echo -n "===>>> Install $dep_port? [y] " - read UPD_OR_NOT - case "$UPD_OR_NOT" in - [nN]*) continue ;; - esac - fi + unset_recursive_config + fi + echo '' + echo "===>>> Starting build for $portdir <<<===" + echo '' +fi - update_port -p $dep_port - fi - done - echo "===>>> Dependency check complete for $portdir" -else - echo "===>>> No dependencies for $portdir" +cd $pd/$portdir +dependency_check + +if [ -n "$NO_ACTION" ]; then + test -n "$VERBOSE" && + echo "===>>> Build canceled due to -n flag" + safe_exit fi case "$DONT_PRE_CLEAN" in @@ -434,7 +604,17 @@ esac # In case we went elsewhere in the dependency check cd $pd/$portdir -make $MAKE_ARGS || fail 'make failed' + +while [ -f "$fetchlog" ]; do + echo '' + echo "===>>> Waiting on fetch to complete for $portdir <<<===" + tail -10 $fetchlog | grep -v '^$' + echo '' + echo "===>>> Waiting on fetch to complete for $portdir <<<===" + sleep 3 +done + +make $MAKE_ARGS || fail "make failed for $portdir" new_port=`make $MAKE_ARGS -V PKGNAME` prefix=`make $MAKE_ARGS -V PKGNAMEPREFIX` @@ -445,11 +625,11 @@ short_port="${prefix}${portname}${suffix}" # Check for dependencies here in case +REQUIRED_BY is not up to date or missing grep_deps=`mktemp -t grep-deps-${short_port}` grep -l "pkgdep ${short_port}-" $pdb/*/+CONTENTS | cut -f 5 -d '/' | - sort > $grep_deps + sort -u > $grep_deps if [ -s "$pdb/$upg_port/+REQUIRED_BY" ]; then req_deps=`mktemp -t req-deps-${short_port}` - sort $pdb/$upg_port/+REQUIRED_BY > $req_deps + sort -u $pdb/$upg_port/+REQUIRED_BY > $req_deps fi if [ ! -s "$grep_deps" -a ! -s "$req_deps" ]; then @@ -463,13 +643,17 @@ elif [ -s "$grep_deps" -a -s "$req_deps" ]; then elif [ -s "$grep_deps" -a ! -s "$req_deps" ]; then dep_warn echo -n "===>>> Install these as the new +REQUIRED_BY file? [n] " - read INSTALLDEPS + if [ -z "$UNATTENDED" ]; then + read INSTALLDEPS - case "$INSTALLDEPS" in - [yY]) req_deps=`mktemp -t req-deps-${short_port}` - mv $grep_deps $req_deps - ;; - esac + case "$INSTALLDEPS" in + [yY]) req_deps=`mktemp -t req-deps-${short_port}` + mv $grep_deps $req_deps + ;; + esac + else + echo "===>>> Default (no) in unattended mode" + fi else # It should not happen that req_deps exist but grep_deps does not fail "$pdb/$upg_port/+REQUIRED_BY indicates a dependency on this port, but no other ports have this dependency recorded" @@ -512,29 +696,34 @@ if [ -z "$DONT_SCRUB_DISTFILES" ]; then test -n "$dist_subdir" && distdir="${distdir}/${dist_subdir}" distfiles=`make $MAKE_ARGS -V DISTFILES` - distname=`make $MAKE_ARGS -V DISTNAME | cut -f 1 -d '-'` cd $distdir || fail "cd to $distdir failed!" - for file in ${distname}*; do - # This generally means the pattern did not match - case "$file" in - *\*) continue ;; - esac + for distfile in $distfiles; do + for file in ${distfile%%[_-]*}*; do + # This generally means the pattern did not match + case "$file" in + *\*) continue ;; + esac - case "$distfiles" in - *${file}*) continue ;; # Do not delete current version - *) if [ -n "$ALWAYS_SCRUB_DISTFILES" ]; then - echo "===>>> Deleting stale distfile: $file" - rm -f $file - continue - fi + case "$distfiles" in + *${file}*) + test -n "$VERBOSE" && + echo "===>>> Keeping new distfile: $file" + continue # Do not delete current version + ;; + *) if [ -n "$ALWAYS_SCRUB_DISTFILES" ]; then + echo "===>>> Deleting stale distfile: $file" + rm -f $file + continue + fi - echo -n "===>>> Delete $file? [n] " - read DELORNOT - case "$DELORNOT" in - [yY]) rm -f $file ;; + echo -n "===>>> Delete $file? [n] " + read DELORNOT + case "$DELORNOT" in + [yY]) rm -f $file ;; + esac + ;; esac - ;; - esac + done done fi @@ -545,19 +734,11 @@ if [ -n "$UPDATE_REQ_BYS" -a -r "$pdb/$new_port/+REQUIRED_BY" ]; then test -n "$VERBOSE" && echo "===>>> $req_by is required by $new_port" if [ ! -d "$pdb/$req_by" ]; then - echo -n "===>>> WARNING! $pdb/$new_port/+REQUIRED_BY " - echo -n "shows that $req_by requires $new_port, but " - echo "$req_by does not seem to be installed" - echo -n "===>>> Press Enter to proceed " - read DISCARD + req_by_error $new_port $req_by continue fi - if [ -n "$INTERACTIVE_UPDATE" ]; then - echo -n "===>>> Update ${req_by}? [y] " - read UPD_OR_NOT - case "$UPD_OR_NOT" in - [nN]*) continue ;; - esac + if ! check_interactive ${req_by} ; then + continue fi update_port $req_by |