diff options
| author | dhuth <derickhuth@gmail.com> | 2015-05-07 14:38:02 -0600 | 
|---|---|---|
| committer | dhuth <derickhuth@gmail.com> | 2015-05-07 14:38:02 -0600 | 
| commit | f5c39e4c6ff55520948c2ef331c968cd84b817d9 (patch) | |
| tree | 6c8174dadfe11a2a515c29940872a02d81f8d990 /omega/install-sh | |
| parent | 59aaf19943ba29cefdf1d8478ff33f7d2b8b3920 (diff) | |
| download | chill-f5c39e4c6ff55520948c2ef331c968cd84b817d9.tar.gz chill-f5c39e4c6ff55520948c2ef331c968cd84b817d9.tar.bz2 chill-f5c39e4c6ff55520948c2ef331c968cd84b817d9.zip | |
Added autoreconf generated files.
Diffstat (limited to 'omega/install-sh')
| -rwxr-xr-x | omega/install-sh | 323 | 
1 files changed, 323 insertions, 0 deletions
| diff --git a/omega/install-sh b/omega/install-sh new file mode 100755 index 0000000..4d4a951 --- /dev/null +++ b/omega/install-sh @@ -0,0 +1,323 @@ +#!/bin/sh +# install - install a program, script, or datafile + +scriptversion=2005-05-14.22 + +# This originates from X11R5 (mit/util/scripts/install.sh), which was +# later released in X11R6 (xc/config/util/install.sh) with the +# following copyright and license. +# +# Copyright (C) 1994 X Consortium +# +# Permission is hereby granted, free of charge, to any person obtaining a copy +# of this software and associated documentation files (the "Software"), to +# deal in the Software without restriction, including without limitation the +# rights to use, copy, modify, merge, publish, distribute, sublicense, and/or +# sell copies of the Software, and to permit persons to whom the Software is +# furnished to do so, subject to the following conditions: +# +# The above copyright notice and this permission notice shall be included in +# all copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL THE +# X CONSORTIUM BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN +# AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNEC- +# TION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. +# +# Except as contained in this notice, the name of the X Consortium shall not +# be used in advertising or otherwise to promote the sale, use or other deal- +# ings in this Software without prior written authorization from the X Consor- +# tium. +# +# +# FSF changes to this file are in the public domain. +# +# Calling this script install-sh is preferred over install.sh, to prevent +# `make' implicit rules from creating a file called install from it +# when there is no Makefile. +# +# This script is compatible with the BSD install script, but was written +# from scratch.  It can only install one file at a time, a restriction +# shared with many OS's install programs. + +# set DOITPROG to echo to test this script + +# Don't use :- since 4.3BSD and earlier shells don't like it. +doit="${DOITPROG-}" + +# put in absolute paths if you don't have them in your path; or use env. vars. + +mvprog="${MVPROG-mv}" +cpprog="${CPPROG-cp}" +chmodprog="${CHMODPROG-chmod}" +chownprog="${CHOWNPROG-chown}" +chgrpprog="${CHGRPPROG-chgrp}" +stripprog="${STRIPPROG-strip}" +rmprog="${RMPROG-rm}" +mkdirprog="${MKDIRPROG-mkdir}" + +chmodcmd="$chmodprog 0755" +chowncmd= +chgrpcmd= +stripcmd= +rmcmd="$rmprog -f" +mvcmd="$mvprog" +src= +dst= +dir_arg= +dstarg= +no_target_directory= + +usage="Usage: $0 [OPTION]... [-T] SRCFILE DSTFILE +   or: $0 [OPTION]... SRCFILES... DIRECTORY +   or: $0 [OPTION]... -t DIRECTORY SRCFILES... +   or: $0 [OPTION]... -d DIRECTORIES... + +In the 1st form, copy SRCFILE to DSTFILE. +In the 2nd and 3rd, copy all SRCFILES to DIRECTORY. +In the 4th, create DIRECTORIES. + +Options: +-c         (ignored) +-d         create directories instead of installing files. +-g GROUP   $chgrpprog installed files to GROUP. +-m MODE    $chmodprog installed files to MODE. +-o USER    $chownprog installed files to USER. +-s         $stripprog installed files. +-t DIRECTORY  install into DIRECTORY. +-T         report an error if DSTFILE is a directory. +--help     display this help and exit. +--version  display version info and exit. + +Environment variables override the default commands: +  CHGRPPROG CHMODPROG CHOWNPROG CPPROG MKDIRPROG MVPROG RMPROG STRIPPROG +" + +while test -n "$1"; do +  case $1 in +    -c) shift +        continue;; + +    -d) dir_arg=true +        shift +        continue;; + +    -g) chgrpcmd="$chgrpprog $2" +        shift +        shift +        continue;; + +    --help) echo "$usage"; exit $?;; + +    -m) chmodcmd="$chmodprog $2" +        shift +        shift +        continue;; + +    -o) chowncmd="$chownprog $2" +        shift +        shift +        continue;; + +    -s) stripcmd=$stripprog +        shift +        continue;; + +    -t) dstarg=$2 +	shift +	shift +	continue;; + +    -T) no_target_directory=true +	shift +	continue;; + +    --version) echo "$0 $scriptversion"; exit $?;; + +    *)  # When -d is used, all remaining arguments are directories to create. +	# When -t is used, the destination is already specified. +	test -n "$dir_arg$dstarg" && break +        # Otherwise, the last argument is the destination.  Remove it from $@. +	for arg +	do +          if test -n "$dstarg"; then +	    # $@ is not empty: it contains at least $arg. +	    set fnord "$@" "$dstarg" +	    shift # fnord +	  fi +	  shift # arg +	  dstarg=$arg +	done +	break;; +  esac +done + +if test -z "$1"; then +  if test -z "$dir_arg"; then +    echo "$0: no input file specified." >&2 +    exit 1 +  fi +  # It's OK to call `install-sh -d' without argument. +  # This can happen when creating conditional directories. +  exit 0 +fi + +for src +do +  # Protect names starting with `-'. +  case $src in +    -*) src=./$src ;; +  esac + +  if test -n "$dir_arg"; then +    dst=$src +    src= + +    if test -d "$dst"; then +      mkdircmd=: +      chmodcmd= +    else +      mkdircmd=$mkdirprog +    fi +  else +    # Waiting for this to be detected by the "$cpprog $src $dsttmp" command +    # might cause directories to be created, which would be especially bad +    # if $src (and thus $dsttmp) contains '*'. +    if test ! -f "$src" && test ! -d "$src"; then +      echo "$0: $src does not exist." >&2 +      exit 1 +    fi + +    if test -z "$dstarg"; then +      echo "$0: no destination specified." >&2 +      exit 1 +    fi + +    dst=$dstarg +    # Protect names starting with `-'. +    case $dst in +      -*) dst=./$dst ;; +    esac + +    # If destination is a directory, append the input filename; won't work +    # if double slashes aren't ignored. +    if test -d "$dst"; then +      if test -n "$no_target_directory"; then +	echo "$0: $dstarg: Is a directory" >&2 +	exit 1 +      fi +      dst=$dst/`basename "$src"` +    fi +  fi + +  # This sed command emulates the dirname command. +  dstdir=`echo "$dst" | sed -e 's,/*$,,;s,[^/]*$,,;s,/*$,,;s,^$,.,'` + +  # Make sure that the destination directory exists. + +  # Skip lots of stat calls in the usual case. +  if test ! -d "$dstdir"; then +    defaultIFS=' +	 ' +    IFS="${IFS-$defaultIFS}" + +    oIFS=$IFS +    # Some sh's can't handle IFS=/ for some reason. +    IFS='%' +    set x `echo "$dstdir" | sed -e 's@/@%@g' -e 's@^%@/@'` +    shift +    IFS=$oIFS + +    pathcomp= + +    while test $# -ne 0 ; do +      pathcomp=$pathcomp$1 +      shift +      if test ! -d "$pathcomp"; then +        $mkdirprog "$pathcomp" +	# mkdir can fail with a `File exist' error in case several +	# install-sh are creating the directory concurrently.  This +	# is OK. +	test -d "$pathcomp" || exit +      fi +      pathcomp=$pathcomp/ +    done +  fi + +  if test -n "$dir_arg"; then +    $doit $mkdircmd "$dst" \ +      && { test -z "$chowncmd" || $doit $chowncmd "$dst"; } \ +      && { test -z "$chgrpcmd" || $doit $chgrpcmd "$dst"; } \ +      && { test -z "$stripcmd" || $doit $stripcmd "$dst"; } \ +      && { test -z "$chmodcmd" || $doit $chmodcmd "$dst"; } + +  else +    dstfile=`basename "$dst"` + +    # Make a couple of temp file names in the proper directory. +    dsttmp=$dstdir/_inst.$$_ +    rmtmp=$dstdir/_rm.$$_ + +    # Trap to clean up those temp files at exit. +    trap 'ret=$?; rm -f "$dsttmp" "$rmtmp" && exit $ret' 0 +    trap '(exit $?); exit' 1 2 13 15 + +    # Copy the file name to the temp name. +    $doit $cpprog "$src" "$dsttmp" && + +    # and set any options; do chmod last to preserve setuid bits. +    # +    # If any of these fail, we abort the whole thing.  If we want to +    # ignore errors from any of these, just make sure not to ignore +    # errors from the above "$doit $cpprog $src $dsttmp" command. +    # +    { test -z "$chowncmd" || $doit $chowncmd "$dsttmp"; } \ +      && { test -z "$chgrpcmd" || $doit $chgrpcmd "$dsttmp"; } \ +      && { test -z "$stripcmd" || $doit $stripcmd "$dsttmp"; } \ +      && { test -z "$chmodcmd" || $doit $chmodcmd "$dsttmp"; } && + +    # Now rename the file to the real destination. +    { $doit $mvcmd -f "$dsttmp" "$dstdir/$dstfile" 2>/dev/null \ +      || { +	   # The rename failed, perhaps because mv can't rename something else +	   # to itself, or perhaps because mv is so ancient that it does not +	   # support -f. + +	   # Now remove or move aside any old file at destination location. +	   # We try this two ways since rm can't unlink itself on some +	   # systems and the destination file might be busy for other +	   # reasons.  In this case, the final cleanup might fail but the new +	   # file should still install successfully. +	   { +	     if test -f "$dstdir/$dstfile"; then +	       $doit $rmcmd -f "$dstdir/$dstfile" 2>/dev/null \ +	       || $doit $mvcmd -f "$dstdir/$dstfile" "$rmtmp" 2>/dev/null \ +	       || { +		 echo "$0: cannot unlink or rename $dstdir/$dstfile" >&2 +		 (exit 1); exit 1 +	       } +	     else +	       : +	     fi +	   } && + +	   # Now rename the file to the real destination. +	   $doit $mvcmd "$dsttmp" "$dstdir/$dstfile" +	 } +    } +  fi || { (exit 1); exit 1; } +done + +# The final little trick to "correctly" pass the exit status to the exit trap. +{ +  (exit 0); exit 0 +} + +# Local variables: +# eval: (add-hook 'write-file-hooks 'time-stamp) +# time-stamp-start: "scriptversion=" +# time-stamp-format: "%:y-%02m-%02d.%02H" +# time-stamp-end: "$" +# End: | 
