[BACK]Return to update_openbsd CVS log [TXT][DIR] Up to [local] / openbsd / update_openbsd

Diff for /openbsd/update_openbsd/update_openbsd between version 1.8 and 1.11

version 1.8, 2008/10/13 19:31:49 version 1.11, 2008/11/09 07:22:52
Line 1 
Line 1 
 #!/bin/sh  #!/bin/sh
 # $RedRiver: update_openbsd,v 1.7 2008/10/11 22:19:52 andrew Exp $  # $RedRiver: update_openbsd,v 1.10 2008/11/05 17:07:58 andrew Exp $
   
 if [ -e /etc/update_openbsd.conf ]; then  if [ -e /etc/update_openbsd.conf ]; then
     . /etc/update_openbsd.conf      . /etc/update_openbsd.conf
Line 15 
Line 15 
   
 DESTDIR=${DESTDIR:=/}  DESTDIR=${DESTDIR:=/}
 SYSMERGE=${SYSMERGE:=/usr/sbin/sysmerge}  SYSMERGE=${SYSMERGE:=/usr/sbin/sysmerge}
 if [ ! -e $SYSMERGE ]; then  FORCE_DIR=${FORCE_DIR:=No}
     SYSMERGE=  
 fi  
   
 installed_sets() {  installed_sets() {
     local misc=/usr/share/doc/README      local misc=/usr/share/doc/README
Line 44 
Line 42 
 }  }
 INSTALLED_SETS=${INSTALLED_SETS:=`installed_sets`}  INSTALLED_SETS=${INSTALLED_SETS:=`installed_sets`}
   
   sets_exist () {
           local _proto=${FTP%%://*}
   
           if [ X"ftp" == X"${_proto}" ]; then
               echo "ls base*.tgz" | ${FTP_CMD} ${FTP}/ | awk '{ print $9 }'
           elif [ X"http" == X"${_proto}" ]; then
               ${FTP_CMD} -V -o - ${FTP}/ | grep '"base[0-9][0-9].tgz' | sed -e 's/.*\(base..\.tgz\).*/\1/'
           else
               echo Unsupported FTP ${FTP} >&2
               exit 2
           fi
   }
   
 set_version() {  set_version() {
     CUR_VER=`uname -r`      CUR_VER=`uname -r`
     NEW_VER=`dc -e "$CUR_VER 0.1 + p"`      NEW_VER=`dc -e "$CUR_VER 0.1 + p"`
Line 53 
Line 63 
   
     local _cv=`echo $CUR_VER | sed -e 's/\.//'`      local _cv=`echo $CUR_VER | sed -e 's/\.//'`
     local _nv=`echo $NEW_VER | sed -e 's/\.//'`      local _nv=`echo $NEW_VER | sed -e 's/\.//'`
     local _v=""      local _v
   
     if [ X"" != X"$FORCE_DIR" -a -d $FORCE_DIR ]; then      if [ X"No" != X"$FORCE_DIR" -a -d $FORCE_DIR ]; then
         _dir=$FORCE_DIR          _dir=$FORCE_DIR
         if [ -e ${_dir}/base${_nv}.tgz ]; then          if [ -e ${_dir}/base${_nv}.tgz ]; then
             _v=$_nv              _v=$_nv
Line 80 
Line 90 
     fi      fi
   
     if [ X"" == X"${_v}" ]; then      if [ X"" == X"${_v}" ]; then
         if [ X"" == X"${FORCE_DIR}" ]; then          if [ X"No" == X"${FORCE_DIR}" ]; then
             _dir=${NEW_VER}              _dir=${NEW_VER}
         else          else
             _dir=${FORCE_DIR}              _dir=${FORCE_DIR}
         fi          fi
         FTP=${MIRROR}/${_dir}/`machine`          FTP=${MIRROR}/${_dir}/`machine`
   
         local _file=`echo "ls base${_cv}.tgz" | ${FTP_CMD} ${FTP}/ | awk '{ print $9 }'`          _file=`sets_exist`
   
         if [ X"base${_cv}.tgz" == X"${_file}" ]; then          if [ X"" == X"${_file}" ]; then
               if [ X"No" != X"$FORCE_DIR" ]; then
                   echo No sets in forced [${FTP}] >&2
                   exit 2
               fi
   
             NEW_VER=$CUR_VER              NEW_VER=$CUR_VER
             _v=$_cv              _dir=${NEW_VER}
               FTP=${MIRROR}/${_dir}/`machine`
   
               _file=`sets_exist`
               if [ X"" == X"${_file}" ]; then
                   echo No sets in [${FTP}] >&2
                   exit 2
               fi
           fi
   
           _v=${_file##*base}
           _v=${_v%.tgz*}
   
           if [ X"" == X"${_v}" ]; then
               echo No version in file [$_file] >&2
               exit 2
           elif [ X"${_cv}" == X"${_v}" ]; then
               NEW_VER=$CUR_VER
           elif [ X"${_nv}" == X"${_v}" ]; then
               NEW_VER=$NEW_VER
         else          else
             _v=$_nv              echo Invalid version [$_v] >&2
               exit 2
         fi          fi
   
         if [ X"" == X"$FORCE_DIR" ]; then          if [ X"No" == X"$FORCE_DIR" ]; then
             _dir=$NEW_VER              _dir=$NEW_VER
         fi          fi
   
Line 110 
Line 145 
     if [ X"" == X"$RELEASEDIR" ]; then      if [ X"" == X"$RELEASEDIR" ]; then
         RELEASEDIR=`pwd`/$_dir          RELEASEDIR=`pwd`/$_dir
     fi      fi
   
     FILE_VER=$_v      FILE_VER=$_v
     FTP=${MIRROR}/${_dir}/`machine`      FTP=${MIRROR}/${_dir}/`machine`
 }  }
Line 145 
Line 181 
         $FTP_CMD ${FTP}/MD5          $FTP_CMD ${FTP}/MD5
     fi      fi
   
     ls bsd* *.tgz > index      ls bsd* *.tgz | sed -e 's/\(.*\)/(\1)/' > index
     grep -f index MD5 | md5 -c      grep -f index MD5 | md5 -c
   
     if [ $? -ne 0 ]; then      if [ $? -ne 0 ]; then
Line 273 
Line 309 
   
 update_etc() {  update_etc() {
     echo '### UPDATING ETC ###'      echo '### UPDATING ETC ###'
       if [ ! -e $SYSMERGE ]; then
           SYSMERGE=
       fi
   
     if [ X"" == X"$SYSMERGE" ]; then      if [ X"" == X"$SYSMERGE" ]; then
         if [ -e /var/tmp/temproot ]; then          if [ -e /var/tmp/temproot ]; then
             MERGEMASTER=`which mergemaster`              MERGEMASTER=`which mergemaster`

Legend:
Removed from v.1.8  
changed lines
  Added in v.1.11

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>