[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.4 and 1.5

version 1.4, 2008/08/12 23:44:19 version 1.5, 2008/10/11 23:12:33
Line 1 
Line 1 
 #!/bin/sh  #!/bin/sh
 # $RedRiver: update_openbsd,v 1.3 2008/08/12 22:42:09 andrew Exp $  # $RedRiver: update_openbsd,v 1.4 2008/08/12 22:44:19 andrew Exp $
   
 SYSMERGE=/usr/sbin/sysmerge  SYSMERGE=/usr/sbin/sysmerge
 MIRROR=ftp://ftp.openbsd.org/pub/OpenBSD  MIRROR=ftp://ftp.openbsd.org/pub/OpenBSD
Line 14 
Line 14 
 fi  fi
   
 installed_sets() {  installed_sets() {
     misc=/usr/share/doc/README      local misc=/usr/share/doc/README
     man=/usr/share/man/cat1/intro.0      local man=/usr/share/man/cat1/intro.0
     comp=/usr/bin/cc      local comp=/usr/bin/cc
     game=/usr/games/      local game=/usr/games/
     xbase=/usr/X11R6/      local xbase=/usr/X11R6/
     xetc=/etc/X11/xinit/xinitrc      local xetc=/etc/X11/xinit/xinitrc
     xfont=/usr/X11R6/lib/X11/fonts      local xfont=/usr/X11R6/lib/X11/fonts
     xserv=/usr/X11R6/bin/X      local xserv=/usr/X11R6/bin/X
     xshare=/usr/X11R6/bin/startx      local xshare=/usr/X11R6/bin/startx
   
     echo base      local _c _d _e
     echo etc      echo -n base
       echo -n ' etc'
     for _d in misc man comp game xbase xetc xfont xserv xshare; do      for _d in misc man comp game xbase xetc xfont xserv xshare; do
         eval _e=\$${_d}          eval _e=\$${_d}
         _c=`ls $_e 2> /dev/null | wc -l`          _c=`ls $_e 2> /dev/null | wc -l`
         #echo $_c $_d $_e          #echo $_c $_d $_e
         if [ $_c -ne 0 ]; then          if [ $_c -ne 0 ]; then
             echo $_d              echo -n " $_d"
         fi          fi
     done      done
 }  }
Line 39 
Line 40 
 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"`
       FILE_VER=""
       FTP=""
   
     if [ -d $NEW_VER ]; then      local _cv=`echo $CUR_VER | sed -e 's/\.//'`
         DIR=$NEW_VER      local _nv=`echo $NEW_VER | sed -e 's/\.//'`
     fi      local _v=""
   
     if [ -d $CUR_VER ]; then      if [ X"" != X"$FORCE_DIR" -a -d $FORCE_DIR ]; then
           _dir=$FORCE_DIR
           if [ -e ${_dir}/base${_nv}.tgz ]; then
               _v=$_nv
           elif [ -e ${_dir}/base${_cv}.tgz ]; then
               NEW_VER=$CUR_VER
               _v=$_cv
           fi
   
       elif [ -d $CUR_VER ]; then
           _dir=$CUR_VER
         NEW_VER=$CUR_VER          NEW_VER=$CUR_VER
         DIR=$NEW_VER          if [ -e ${_dir}/base${_cv}.tgz ]; then
     fi              _v=$_cv
           fi
   
     if [ X"" != X"$FORCE_DIR" ]; then      elif [ -d $NEW_VER ]; then
         if [ -d $FORCE_DIR ]; then          _dir=$NEW_VER
             DIR=$FORCE_DIR          if [ -e ${_dir}/base${_nv}.tgz ]; then
               _v=$_nv
             _cv=`echo $CUR_VER | sed -e 's/\.//'`  
             if [ -e $DIR/base${_cv}.tgz ]; then  
                 NEW_VER=$CUR_VER  
             fi  
         fi          fi
   
     fi      fi
   
     if [ X"" == X"$DIR" ]; then      if [ X"" == X"${_v}" ]; then
         FTP=${MIRROR}/${NEW_VER}/`machine`          if [ X"" == X"${FORCE_DIR}" ]; then
               _dir=${NEW_VER}
           else
               _dir=${FORCE_DIR}
           fi
           FTP=${MIRROR}/${_dir}/`machine`
   
         #echo "ls\nquit\n" | ftp $MIRROR | grep "$NEW_VER"          local _file=`echo "ls base${_cv}.tgz" | ${FTP_CMD} ${FTP}/ | awk '{ print $9 }'`
         $FTP_CMD ${FTP}/MD5 > /dev/null  
   
         if [ -e MD5 ]; then          if [ X"base${_cv}.tgz" == X"${_file}" ]; then
             rm -f MD5  
         else  
             NEW_VER=$CUR_VER              NEW_VER=$CUR_VER
               _v=$_cv
           else
               _v=$_nv
         fi          fi
   
         if [ X"$FORCE_DIR" == X"" ]; then          if [ X"" == X"$FORCE_DIR" ]; then
             DIR=$NEW_VER              _dir=$NEW_VER
         else  
             DIR=$FORCE_DIR  
         fi          fi
   
         FTP=${MIRROR}/${DIR}/`machine`  
     fi      fi
   
     if [ X"" != X"$RELEASEDIR" ]; then      if [ X"" == X"${_v}" ]; then
         DIR=$RELEASEDIR          echo ERROR: Unable to determine file version! >&2
           exit 1
     fi      fi
   
     if [ -d $DIR ]; then      if [ X"" == X"$RELEASEDIR" ]; then
        cd $DIR          RELEASEDIR=`pwd`/$_dir
        RELEASEDIR=`pwd`  
     fi      fi
       FILE_VER=$_v
     _v=`echo $NEW_VER | sed -e 's/\.//'`      FTP=${MIRROR}/${_dir}/`machine`
 }  }
   
 get_sets() {  get_sets() {
       echo '### GETTING SETS ###'
     if [ X"" == X"$FTP" ]; then      if [ X"" == X"$FTP" ]; then
         echo Error, no FTP site is set! >&2          echo ERROR: No FTP site set! >&2
         exit 1          exit 1
     fi      fi
   
     if [ X"" == X"$RELEASEDIR" ]; then      mkdir -p ${RELEASEDIR}
         RELEASEDIR=$DIR  
     fi  
   
     mkdir -p $RELEASEDIR  
     cd $RELEASEDIR      cd $RELEASEDIR
     RELEASEDIR=`pwd`  
   
     for _b in /bsd* bsd bsd.mp bsd.rd; do      local _v=$FILE_VER
   
       for _b in `echo /bsd* bsd bsd.mp bsd.rd | sort -u`; do
         if [ -e /${_b} -a ! -e ./${_b} ]; then          if [ -e /${_b} -a ! -e ./${_b} ]; then
             echo $FTP_CMD ${FTP}/${_b}              echo $FTP_CMD ${FTP}/${_b}
             $FTP_CMD ${FTP}/${_b}              $FTP_CMD ${FTP}/${_b}
         fi          fi
     done      done
   
     for _s in `installed_sets`; do      for _s in $INSTALLED_SETS; do
         echo $FTP_CMD ${FTP}/${_s}${_v}.tgz          if [ ! -e ./${_s}${_v}.tgz ]; then
         $FTP_CMD ${FTP}/${_s}${_v}.tgz              echo $FTP_CMD ${FTP}/${_s}${_v}.tgz
               $FTP_CMD ${FTP}/${_s}${_v}.tgz
           fi
     done      done
   
     echo $FTP_CMD ${FTP}/MD5      echo $FTP_CMD ${FTP}/MD5
Line 125 
Line 138 
     grep -f index MD5 | md5 -c      grep -f index MD5 | md5 -c
   
     if [ $? -ne 0 ]; then      if [ $? -ne 0 ]; then
         echo !!! WARNING: MD5 does not match !!! >&2          echo ERROR: MD5 does not match! >&2
         exit 1          exit 1
     fi      fi
 }  }
   
 install_kernel() {  install_kernel() {
       echo '### INSTALLING KERNEL ###'
     if [ X"$USER" != X"root" -a X"$SUDO" == X"" ]; then      if [ X"$USER" != X"root" -a X"$SUDO" == X"" ]; then
         echo ${0##*/} must be run as root or SUDO must be set! >&2          echo ${0##*/} must be run as root or SUDO must be set! >&2
         exit 1          exit 1
     fi      fi
   
     if [ X"" == X"$RELEASEDIR" ]; then      if [ X"" == X"$RELEASEDIR" ]; then
         echo "ERROR: no source for new kernels!" >&2          echo ERROR: no source for new kernels! >&2
         exit 1          exit 1
     else      else
         cd $RELEASEDIR          cd $RELEASEDIR
     fi      fi
   
     if [ ! -e bsd ]; then      if [ ! -e bsd ]; then
         echo "new bsd kernel does not exist!" >&2          echo ERROR: new bsd kernel does not exist! >&2
         exit 1          exit 1
     fi      fi
   
     if [ -e /bsd.mp -a ! -e bsd.mp ]; then      if [ -e /bsd.mp -a ! -e bsd.mp ]; then
         echo "new bsd.mp kernel does not exist!" >&2          echo ERROR: new bsd.mp kernel does not exist! >&2
         exit 1          exit 1
     fi      fi
   
     if [ ! -e bsd.rd ]; then      if [ ! -e bsd.rd ]; then
         echo "new bsd.rd kernel does not exist!" >&2          echo ERROR: new bsd.rd kernel does not exist! >&2
         exit 1          exit 1
     fi      fi
   
       local _v=$FILE_VER
     if [ -e base${_v}.tgz ]; then      if [ -e base${_v}.tgz ]; then
         echo Extracting new firmware from base${_v}.tgz          echo Extracting new firmware from base${_v}.tgz
         $SUDO tar -C $DESTDIR -xzphf base${_v}.tgz "*etc/firmware/*"          $SUDO tar -C $DESTDIR -xzphf base${_v}.tgz "*etc/firmware/*"
Line 174 
Line 188 
     for _b in bsd*; do      for _b in bsd*; do
         $SUDO rm -f /nbsd          $SUDO rm -f /nbsd
   
         if [ X"$_b" == X"bsd" ]; then          if [ X"${_b}" == X"bsd" ]; then
             echo Copying bsd to /bsd.sp              echo Copying bsd to /bsd.sp
             $SUDO cp bsd /nbsd && $SUDO mv /nbsd /bsd.sp              $SUDO cp bsd /nbsd && $SUDO mv /nbsd /bsd.sp
             if [ $? -ne 0 ]; then              if [ $? -ne 0 ]; then
                 echo "ERROR: Couldn't copy new SP kernel!" >&2                  echo ERROR: Could not copy new SP kernel! >&2
                 exit 1                  exit 1
             fi              fi
         else          else
Line 186 
Line 200 
                 echo Copying $_b to /                  echo Copying $_b to /
                 $SUDO cp ${_b} /nbsd && $SUDO mv /nbsd /${_b}                  $SUDO cp ${_b} /nbsd && $SUDO mv /nbsd /${_b}
                 if [ $? -ne 0 ]; then                  if [ $? -ne 0 ]; then
                     echo "ERROR: Couldn't copy new $_b kernel!" >&2                      echo ERROR: Could not copy new $_b kernel! >&2
                     exit 1                      exit 1
                 fi                  fi
             fi              fi
Line 202 
Line 216 
             $SUDO ln -sf /bsd.sp /bsd              $SUDO ln -sf /bsd.sp /bsd
         fi          fi
         if [ $? -ne 0 ]; then          if [ $? -ne 0 ]; then
             echo "ERROR: Couldn't symlink new kernel!" >&2              echo ERROR: Could not symlink new kernel! >&2
             exit 1              exit 1
         fi          fi
     fi      fi
 }  }
   
 install_sets() {  install_sets() {
       echo '### INSTALLING SETS ###'
     if [ X"$USER" != X"root" -a X"$SUDO" == X"" ]; then      if [ X"$USER" != X"root" -a X"$SUDO" == X"" ]; then
         echo ${0##*/} must be run as root or SUDO must be set! >&2          echo ${0##*/} must be run as root or SUDO must be set! >&2
         exit 1          exit 1
     fi      fi
   
     if [ X"" == X"$RELEASEDIR" ]; then      if [ X"" == X"$RELEASEDIR" ]; then
         echo "ERROR: no source for sets!" >&2          echo ERROR: no source for sets! >&2
         exit 1          exit 1
     else      else
         cd $RELEASEDIR          cd $RELEASEDIR
     fi      fi
   
       local _v=$FILE_VER
   
     for _f in *${_v}.tgz; do      for _f in *${_v}.tgz; do
         _path=$DESTDIR          _path=$DESTDIR
         if [ X"etc${_v}.tgz"  == X"$_f" \          if [ X"etc${_v}.tgz"  == X"$_f" \
Line 235 
Line 252 
         $SUDO mkdir -p $_path          $SUDO mkdir -p $_path
         $SUDO tar -C $_path -xzphf ${RELEASEDIR}/${_f}          $SUDO tar -C $_path -xzphf ${RELEASEDIR}/${_f}
         if [ $? -ne 0 ]; then          if [ $? -ne 0 ]; then
             echo "Error extracting ${_f}!" >&2              echo ERROR: Could not extract ${_f}! >&2
             exit 1              exit 1
         fi          fi
     done      done
Line 244 
Line 261 
 }  }
   
 update_etc() {  update_etc() {
       echo '### UPDATING ETC ###'
     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`
   
             if [ $? != 0 ]; then              if [ $? != 0 ]; then
                 $SUDO pkg_add -i mergemaster                  $SUDO pkg_add -i mergemaster
   
                 MERGEMASTER=`which mergemaster`                  MERGEMASTER=`which mergemaster`
                 if [ $? != 0 ]; then                  if [ $? != 0 ]; then
                     echo ERROR: mergemaster not installed! >&2                      echo ERROR: mergemaster not installed! >&2
Line 271 
Line 290 
             cd $RELEASEDIR              cd $RELEASEDIR
         fi          fi
   
         _cv=`echo $CUR_VER | sed -e 's/\.//'`          local _v=$FILE_VER
         if [ -e etc${_cv}.tgz ]; then          if [ -e etc${_v}.tgz ]; then
             _args="$_args -s etc${_cv}.tgz"              _args="$_args -s etc${_v}.tgz"
         fi          fi
         if [ -e xetc${_cv}.tgz ]; then          if [ -e xetc${_v}.tgz ]; then
             _args="$_args -x xetc${_cv}.tgz"              _args="$_args -x xetc${_v}.tgz"
         fi          fi
         if [ X"" == X"$_args" ]; then          if [ X"" == X"$_args" ]; then
             echo ERROR: No upgrade sets found! >&2              echo ERROR: No upgrade sets found! >&2
Line 290 
Line 309 
   
 DESTDIR=${DESTDIR:=/}  DESTDIR=${DESTDIR:=/}
 PKG_PATH=${PKG_PATH:=/usr/ports/packages/`machine`/all/:${MIRROR}/`uname -r`/packages/`machine`/}  PKG_PATH=${PKG_PATH:=/usr/ports/packages/`machine`/all/:${MIRROR}/`uname -r`/packages/`machine`/}
   INSTALLED_SETS=${INSTALLED_SETS:=`installed_sets`}
   
 if [ X"" != X"$SYSMERGE" ]; then  if [ X"" != X"$SYSMERGE" ]; then
     if [ ! -e $SYSMERGE ]; then      if [ ! -e $SYSMERGE ]; then
Line 303 
Line 323 
 echo "-= update_openbsd - helper script to update OpenBSD =-"  echo "-= update_openbsd - helper script to update OpenBSD =-"
 echo "------------------------------------------------------"  echo "------------------------------------------------------"
 echo  echo
 echo "       DIR: $DIR"  
 echo "RELEASEDIR: $RELEASEDIR"  echo "RELEASEDIR: $RELEASEDIR"
 echo "   DESTDIR: $DESTDIR"  echo "   DESTDIR: $DESTDIR"
 echo "   CUR_VER: $CUR_VER"  echo "   CUR_VER: $CUR_VER"
 echo "   NEW_VER: $NEW_VER"  echo "   NEW_VER: $NEW_VER"
   #echo "  FILE_VER: $FILE_VER"
 echo "      SUDO: $SUDO"  echo "      SUDO: $SUDO"
 echo "  SYSMERGE: $SYSMERGE"  echo "  SYSMERGE: $SYSMERGE"
 echo "    MIRROR: $MIRROR"  echo "    MIRROR: $MIRROR"
   echo "      SETS: $INSTALLED_SETS"
 echo  echo
   
 if [ X"" == X"$RELEASEDIR" ]; then  get_sets
     echo '### GETTING SETS ###'  
     get_sets  
 fi  
   
 if [ X"" != X"$SUDO" ]; then  if [ X"" != X"$SUDO" ]; then
     echo Please enter your sudo password if prompted.      echo Please enter your sudo password if prompted.
Line 324 
Line 342 
     $SUDO -v      $SUDO -v
 fi  fi
   
 echo '### INSTALLING KERNEL ###'  
 install_kernel  install_kernel
   
 if [ $CUR_VER == $NEW_VER -o X"" != X"$FORCE_DIR" ]; then  if [ $CUR_VER == $NEW_VER ]; then
     echo '### INSTALLING SETS ###'  
     install_sets      install_sets
   
     echo '### UPDATING ETC ###'  
     update_etc      update_etc
   
     echo '### UPDATING PACKAGES ###'      echo '### UPDATING PACKAGES ###'

Legend:
Removed from v.1.4  
changed lines
  Added in v.1.5

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