xref: /aosp_15_r20/external/libevent/build-aux/install-sh (revision 663afb9b963571284e0f0a60f257164ab54f64bf)
1*663afb9bSAndroid Build Coastguard Worker#!/bin/sh
2*663afb9bSAndroid Build Coastguard Worker# install - install a program, script, or datafile
3*663afb9bSAndroid Build Coastguard Worker
4*663afb9bSAndroid Build Coastguard Workerscriptversion=2018-03-11.20; # UTC
5*663afb9bSAndroid Build Coastguard Worker
6*663afb9bSAndroid Build Coastguard Worker# This originates from X11R5 (mit/util/scripts/install.sh), which was
7*663afb9bSAndroid Build Coastguard Worker# later released in X11R6 (xc/config/util/install.sh) with the
8*663afb9bSAndroid Build Coastguard Worker# following copyright and license.
9*663afb9bSAndroid Build Coastguard Worker#
10*663afb9bSAndroid Build Coastguard Worker# Copyright (C) 1994 X Consortium
11*663afb9bSAndroid Build Coastguard Worker#
12*663afb9bSAndroid Build Coastguard Worker# Permission is hereby granted, free of charge, to any person obtaining a copy
13*663afb9bSAndroid Build Coastguard Worker# of this software and associated documentation files (the "Software"), to
14*663afb9bSAndroid Build Coastguard Worker# deal in the Software without restriction, including without limitation the
15*663afb9bSAndroid Build Coastguard Worker# rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
16*663afb9bSAndroid Build Coastguard Worker# sell copies of the Software, and to permit persons to whom the Software is
17*663afb9bSAndroid Build Coastguard Worker# furnished to do so, subject to the following conditions:
18*663afb9bSAndroid Build Coastguard Worker#
19*663afb9bSAndroid Build Coastguard Worker# The above copyright notice and this permission notice shall be included in
20*663afb9bSAndroid Build Coastguard Worker# all copies or substantial portions of the Software.
21*663afb9bSAndroid Build Coastguard Worker#
22*663afb9bSAndroid Build Coastguard Worker# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
23*663afb9bSAndroid Build Coastguard Worker# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
24*663afb9bSAndroid Build Coastguard Worker# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL THE
25*663afb9bSAndroid Build Coastguard Worker# X CONSORTIUM BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
26*663afb9bSAndroid Build Coastguard Worker# AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNEC-
27*663afb9bSAndroid Build Coastguard Worker# TION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
28*663afb9bSAndroid Build Coastguard Worker#
29*663afb9bSAndroid Build Coastguard Worker# Except as contained in this notice, the name of the X Consortium shall not
30*663afb9bSAndroid Build Coastguard Worker# be used in advertising or otherwise to promote the sale, use or other deal-
31*663afb9bSAndroid Build Coastguard Worker# ings in this Software without prior written authorization from the X Consor-
32*663afb9bSAndroid Build Coastguard Worker# tium.
33*663afb9bSAndroid Build Coastguard Worker#
34*663afb9bSAndroid Build Coastguard Worker#
35*663afb9bSAndroid Build Coastguard Worker# FSF changes to this file are in the public domain.
36*663afb9bSAndroid Build Coastguard Worker#
37*663afb9bSAndroid Build Coastguard Worker# Calling this script install-sh is preferred over install.sh, to prevent
38*663afb9bSAndroid Build Coastguard Worker# 'make' implicit rules from creating a file called install from it
39*663afb9bSAndroid Build Coastguard Worker# when there is no Makefile.
40*663afb9bSAndroid Build Coastguard Worker#
41*663afb9bSAndroid Build Coastguard Worker# This script is compatible with the BSD install script, but was written
42*663afb9bSAndroid Build Coastguard Worker# from scratch.
43*663afb9bSAndroid Build Coastguard Worker
44*663afb9bSAndroid Build Coastguard Workertab='	'
45*663afb9bSAndroid Build Coastguard Workernl='
46*663afb9bSAndroid Build Coastguard Worker'
47*663afb9bSAndroid Build Coastguard WorkerIFS=" $tab$nl"
48*663afb9bSAndroid Build Coastguard Worker
49*663afb9bSAndroid Build Coastguard Worker# Set DOITPROG to "echo" to test this script.
50*663afb9bSAndroid Build Coastguard Worker
51*663afb9bSAndroid Build Coastguard Workerdoit=${DOITPROG-}
52*663afb9bSAndroid Build Coastguard Workerdoit_exec=${doit:-exec}
53*663afb9bSAndroid Build Coastguard Worker
54*663afb9bSAndroid Build Coastguard Worker# Put in absolute file names if you don't have them in your path;
55*663afb9bSAndroid Build Coastguard Worker# or use environment vars.
56*663afb9bSAndroid Build Coastguard Worker
57*663afb9bSAndroid Build Coastguard Workerchgrpprog=${CHGRPPROG-chgrp}
58*663afb9bSAndroid Build Coastguard Workerchmodprog=${CHMODPROG-chmod}
59*663afb9bSAndroid Build Coastguard Workerchownprog=${CHOWNPROG-chown}
60*663afb9bSAndroid Build Coastguard Workercmpprog=${CMPPROG-cmp}
61*663afb9bSAndroid Build Coastguard Workercpprog=${CPPROG-cp}
62*663afb9bSAndroid Build Coastguard Workermkdirprog=${MKDIRPROG-mkdir}
63*663afb9bSAndroid Build Coastguard Workermvprog=${MVPROG-mv}
64*663afb9bSAndroid Build Coastguard Workerrmprog=${RMPROG-rm}
65*663afb9bSAndroid Build Coastguard Workerstripprog=${STRIPPROG-strip}
66*663afb9bSAndroid Build Coastguard Worker
67*663afb9bSAndroid Build Coastguard Workerposix_mkdir=
68*663afb9bSAndroid Build Coastguard Worker
69*663afb9bSAndroid Build Coastguard Worker# Desired mode of installed file.
70*663afb9bSAndroid Build Coastguard Workermode=0755
71*663afb9bSAndroid Build Coastguard Worker
72*663afb9bSAndroid Build Coastguard Workerchgrpcmd=
73*663afb9bSAndroid Build Coastguard Workerchmodcmd=$chmodprog
74*663afb9bSAndroid Build Coastguard Workerchowncmd=
75*663afb9bSAndroid Build Coastguard Workermvcmd=$mvprog
76*663afb9bSAndroid Build Coastguard Workerrmcmd="$rmprog -f"
77*663afb9bSAndroid Build Coastguard Workerstripcmd=
78*663afb9bSAndroid Build Coastguard Worker
79*663afb9bSAndroid Build Coastguard Workersrc=
80*663afb9bSAndroid Build Coastguard Workerdst=
81*663afb9bSAndroid Build Coastguard Workerdir_arg=
82*663afb9bSAndroid Build Coastguard Workerdst_arg=
83*663afb9bSAndroid Build Coastguard Worker
84*663afb9bSAndroid Build Coastguard Workercopy_on_change=false
85*663afb9bSAndroid Build Coastguard Workeris_target_a_directory=possibly
86*663afb9bSAndroid Build Coastguard Worker
87*663afb9bSAndroid Build Coastguard Workerusage="\
88*663afb9bSAndroid Build Coastguard WorkerUsage: $0 [OPTION]... [-T] SRCFILE DSTFILE
89*663afb9bSAndroid Build Coastguard Worker   or: $0 [OPTION]... SRCFILES... DIRECTORY
90*663afb9bSAndroid Build Coastguard Worker   or: $0 [OPTION]... -t DIRECTORY SRCFILES...
91*663afb9bSAndroid Build Coastguard Worker   or: $0 [OPTION]... -d DIRECTORIES...
92*663afb9bSAndroid Build Coastguard Worker
93*663afb9bSAndroid Build Coastguard WorkerIn the 1st form, copy SRCFILE to DSTFILE.
94*663afb9bSAndroid Build Coastguard WorkerIn the 2nd and 3rd, copy all SRCFILES to DIRECTORY.
95*663afb9bSAndroid Build Coastguard WorkerIn the 4th, create DIRECTORIES.
96*663afb9bSAndroid Build Coastguard Worker
97*663afb9bSAndroid Build Coastguard WorkerOptions:
98*663afb9bSAndroid Build Coastguard Worker     --help     display this help and exit.
99*663afb9bSAndroid Build Coastguard Worker     --version  display version info and exit.
100*663afb9bSAndroid Build Coastguard Worker
101*663afb9bSAndroid Build Coastguard Worker  -c            (ignored)
102*663afb9bSAndroid Build Coastguard Worker  -C            install only if different (preserve the last data modification time)
103*663afb9bSAndroid Build Coastguard Worker  -d            create directories instead of installing files.
104*663afb9bSAndroid Build Coastguard Worker  -g GROUP      $chgrpprog installed files to GROUP.
105*663afb9bSAndroid Build Coastguard Worker  -m MODE       $chmodprog installed files to MODE.
106*663afb9bSAndroid Build Coastguard Worker  -o USER       $chownprog installed files to USER.
107*663afb9bSAndroid Build Coastguard Worker  -s            $stripprog installed files.
108*663afb9bSAndroid Build Coastguard Worker  -t DIRECTORY  install into DIRECTORY.
109*663afb9bSAndroid Build Coastguard Worker  -T            report an error if DSTFILE is a directory.
110*663afb9bSAndroid Build Coastguard Worker
111*663afb9bSAndroid Build Coastguard WorkerEnvironment variables override the default commands:
112*663afb9bSAndroid Build Coastguard Worker  CHGRPPROG CHMODPROG CHOWNPROG CMPPROG CPPROG MKDIRPROG MVPROG
113*663afb9bSAndroid Build Coastguard Worker  RMPROG STRIPPROG
114*663afb9bSAndroid Build Coastguard Worker"
115*663afb9bSAndroid Build Coastguard Worker
116*663afb9bSAndroid Build Coastguard Workerwhile test $# -ne 0; do
117*663afb9bSAndroid Build Coastguard Worker  case $1 in
118*663afb9bSAndroid Build Coastguard Worker    -c) ;;
119*663afb9bSAndroid Build Coastguard Worker
120*663afb9bSAndroid Build Coastguard Worker    -C) copy_on_change=true;;
121*663afb9bSAndroid Build Coastguard Worker
122*663afb9bSAndroid Build Coastguard Worker    -d) dir_arg=true;;
123*663afb9bSAndroid Build Coastguard Worker
124*663afb9bSAndroid Build Coastguard Worker    -g) chgrpcmd="$chgrpprog $2"
125*663afb9bSAndroid Build Coastguard Worker        shift;;
126*663afb9bSAndroid Build Coastguard Worker
127*663afb9bSAndroid Build Coastguard Worker    --help) echo "$usage"; exit $?;;
128*663afb9bSAndroid Build Coastguard Worker
129*663afb9bSAndroid Build Coastguard Worker    -m) mode=$2
130*663afb9bSAndroid Build Coastguard Worker        case $mode in
131*663afb9bSAndroid Build Coastguard Worker          *' '* | *"$tab"* | *"$nl"* | *'*'* | *'?'* | *'['*)
132*663afb9bSAndroid Build Coastguard Worker            echo "$0: invalid mode: $mode" >&2
133*663afb9bSAndroid Build Coastguard Worker            exit 1;;
134*663afb9bSAndroid Build Coastguard Worker        esac
135*663afb9bSAndroid Build Coastguard Worker        shift;;
136*663afb9bSAndroid Build Coastguard Worker
137*663afb9bSAndroid Build Coastguard Worker    -o) chowncmd="$chownprog $2"
138*663afb9bSAndroid Build Coastguard Worker        shift;;
139*663afb9bSAndroid Build Coastguard Worker
140*663afb9bSAndroid Build Coastguard Worker    -s) stripcmd=$stripprog;;
141*663afb9bSAndroid Build Coastguard Worker
142*663afb9bSAndroid Build Coastguard Worker    -t)
143*663afb9bSAndroid Build Coastguard Worker        is_target_a_directory=always
144*663afb9bSAndroid Build Coastguard Worker        dst_arg=$2
145*663afb9bSAndroid Build Coastguard Worker        # Protect names problematic for 'test' and other utilities.
146*663afb9bSAndroid Build Coastguard Worker        case $dst_arg in
147*663afb9bSAndroid Build Coastguard Worker          -* | [=\(\)!]) dst_arg=./$dst_arg;;
148*663afb9bSAndroid Build Coastguard Worker        esac
149*663afb9bSAndroid Build Coastguard Worker        shift;;
150*663afb9bSAndroid Build Coastguard Worker
151*663afb9bSAndroid Build Coastguard Worker    -T) is_target_a_directory=never;;
152*663afb9bSAndroid Build Coastguard Worker
153*663afb9bSAndroid Build Coastguard Worker    --version) echo "$0 $scriptversion"; exit $?;;
154*663afb9bSAndroid Build Coastguard Worker
155*663afb9bSAndroid Build Coastguard Worker    --) shift
156*663afb9bSAndroid Build Coastguard Worker        break;;
157*663afb9bSAndroid Build Coastguard Worker
158*663afb9bSAndroid Build Coastguard Worker    -*) echo "$0: invalid option: $1" >&2
159*663afb9bSAndroid Build Coastguard Worker        exit 1;;
160*663afb9bSAndroid Build Coastguard Worker
161*663afb9bSAndroid Build Coastguard Worker    *)  break;;
162*663afb9bSAndroid Build Coastguard Worker  esac
163*663afb9bSAndroid Build Coastguard Worker  shift
164*663afb9bSAndroid Build Coastguard Workerdone
165*663afb9bSAndroid Build Coastguard Worker
166*663afb9bSAndroid Build Coastguard Worker# We allow the use of options -d and -T together, by making -d
167*663afb9bSAndroid Build Coastguard Worker# take the precedence; this is for compatibility with GNU install.
168*663afb9bSAndroid Build Coastguard Worker
169*663afb9bSAndroid Build Coastguard Workerif test -n "$dir_arg"; then
170*663afb9bSAndroid Build Coastguard Worker  if test -n "$dst_arg"; then
171*663afb9bSAndroid Build Coastguard Worker    echo "$0: target directory not allowed when installing a directory." >&2
172*663afb9bSAndroid Build Coastguard Worker    exit 1
173*663afb9bSAndroid Build Coastguard Worker  fi
174*663afb9bSAndroid Build Coastguard Workerfi
175*663afb9bSAndroid Build Coastguard Worker
176*663afb9bSAndroid Build Coastguard Workerif test $# -ne 0 && test -z "$dir_arg$dst_arg"; then
177*663afb9bSAndroid Build Coastguard Worker  # When -d is used, all remaining arguments are directories to create.
178*663afb9bSAndroid Build Coastguard Worker  # When -t is used, the destination is already specified.
179*663afb9bSAndroid Build Coastguard Worker  # Otherwise, the last argument is the destination.  Remove it from $@.
180*663afb9bSAndroid Build Coastguard Worker  for arg
181*663afb9bSAndroid Build Coastguard Worker  do
182*663afb9bSAndroid Build Coastguard Worker    if test -n "$dst_arg"; then
183*663afb9bSAndroid Build Coastguard Worker      # $@ is not empty: it contains at least $arg.
184*663afb9bSAndroid Build Coastguard Worker      set fnord "$@" "$dst_arg"
185*663afb9bSAndroid Build Coastguard Worker      shift # fnord
186*663afb9bSAndroid Build Coastguard Worker    fi
187*663afb9bSAndroid Build Coastguard Worker    shift # arg
188*663afb9bSAndroid Build Coastguard Worker    dst_arg=$arg
189*663afb9bSAndroid Build Coastguard Worker    # Protect names problematic for 'test' and other utilities.
190*663afb9bSAndroid Build Coastguard Worker    case $dst_arg in
191*663afb9bSAndroid Build Coastguard Worker      -* | [=\(\)!]) dst_arg=./$dst_arg;;
192*663afb9bSAndroid Build Coastguard Worker    esac
193*663afb9bSAndroid Build Coastguard Worker  done
194*663afb9bSAndroid Build Coastguard Workerfi
195*663afb9bSAndroid Build Coastguard Worker
196*663afb9bSAndroid Build Coastguard Workerif test $# -eq 0; then
197*663afb9bSAndroid Build Coastguard Worker  if test -z "$dir_arg"; then
198*663afb9bSAndroid Build Coastguard Worker    echo "$0: no input file specified." >&2
199*663afb9bSAndroid Build Coastguard Worker    exit 1
200*663afb9bSAndroid Build Coastguard Worker  fi
201*663afb9bSAndroid Build Coastguard Worker  # It's OK to call 'install-sh -d' without argument.
202*663afb9bSAndroid Build Coastguard Worker  # This can happen when creating conditional directories.
203*663afb9bSAndroid Build Coastguard Worker  exit 0
204*663afb9bSAndroid Build Coastguard Workerfi
205*663afb9bSAndroid Build Coastguard Worker
206*663afb9bSAndroid Build Coastguard Workerif test -z "$dir_arg"; then
207*663afb9bSAndroid Build Coastguard Worker  if test $# -gt 1 || test "$is_target_a_directory" = always; then
208*663afb9bSAndroid Build Coastguard Worker    if test ! -d "$dst_arg"; then
209*663afb9bSAndroid Build Coastguard Worker      echo "$0: $dst_arg: Is not a directory." >&2
210*663afb9bSAndroid Build Coastguard Worker      exit 1
211*663afb9bSAndroid Build Coastguard Worker    fi
212*663afb9bSAndroid Build Coastguard Worker  fi
213*663afb9bSAndroid Build Coastguard Workerfi
214*663afb9bSAndroid Build Coastguard Worker
215*663afb9bSAndroid Build Coastguard Workerif test -z "$dir_arg"; then
216*663afb9bSAndroid Build Coastguard Worker  do_exit='(exit $ret); exit $ret'
217*663afb9bSAndroid Build Coastguard Worker  trap "ret=129; $do_exit" 1
218*663afb9bSAndroid Build Coastguard Worker  trap "ret=130; $do_exit" 2
219*663afb9bSAndroid Build Coastguard Worker  trap "ret=141; $do_exit" 13
220*663afb9bSAndroid Build Coastguard Worker  trap "ret=143; $do_exit" 15
221*663afb9bSAndroid Build Coastguard Worker
222*663afb9bSAndroid Build Coastguard Worker  # Set umask so as not to create temps with too-generous modes.
223*663afb9bSAndroid Build Coastguard Worker  # However, 'strip' requires both read and write access to temps.
224*663afb9bSAndroid Build Coastguard Worker  case $mode in
225*663afb9bSAndroid Build Coastguard Worker    # Optimize common cases.
226*663afb9bSAndroid Build Coastguard Worker    *644) cp_umask=133;;
227*663afb9bSAndroid Build Coastguard Worker    *755) cp_umask=22;;
228*663afb9bSAndroid Build Coastguard Worker
229*663afb9bSAndroid Build Coastguard Worker    *[0-7])
230*663afb9bSAndroid Build Coastguard Worker      if test -z "$stripcmd"; then
231*663afb9bSAndroid Build Coastguard Worker        u_plus_rw=
232*663afb9bSAndroid Build Coastguard Worker      else
233*663afb9bSAndroid Build Coastguard Worker        u_plus_rw='% 200'
234*663afb9bSAndroid Build Coastguard Worker      fi
235*663afb9bSAndroid Build Coastguard Worker      cp_umask=`expr '(' 777 - $mode % 1000 ')' $u_plus_rw`;;
236*663afb9bSAndroid Build Coastguard Worker    *)
237*663afb9bSAndroid Build Coastguard Worker      if test -z "$stripcmd"; then
238*663afb9bSAndroid Build Coastguard Worker        u_plus_rw=
239*663afb9bSAndroid Build Coastguard Worker      else
240*663afb9bSAndroid Build Coastguard Worker        u_plus_rw=,u+rw
241*663afb9bSAndroid Build Coastguard Worker      fi
242*663afb9bSAndroid Build Coastguard Worker      cp_umask=$mode$u_plus_rw;;
243*663afb9bSAndroid Build Coastguard Worker  esac
244*663afb9bSAndroid Build Coastguard Workerfi
245*663afb9bSAndroid Build Coastguard Worker
246*663afb9bSAndroid Build Coastguard Workerfor src
247*663afb9bSAndroid Build Coastguard Workerdo
248*663afb9bSAndroid Build Coastguard Worker  # Protect names problematic for 'test' and other utilities.
249*663afb9bSAndroid Build Coastguard Worker  case $src in
250*663afb9bSAndroid Build Coastguard Worker    -* | [=\(\)!]) src=./$src;;
251*663afb9bSAndroid Build Coastguard Worker  esac
252*663afb9bSAndroid Build Coastguard Worker
253*663afb9bSAndroid Build Coastguard Worker  if test -n "$dir_arg"; then
254*663afb9bSAndroid Build Coastguard Worker    dst=$src
255*663afb9bSAndroid Build Coastguard Worker    dstdir=$dst
256*663afb9bSAndroid Build Coastguard Worker    test -d "$dstdir"
257*663afb9bSAndroid Build Coastguard Worker    dstdir_status=$?
258*663afb9bSAndroid Build Coastguard Worker  else
259*663afb9bSAndroid Build Coastguard Worker
260*663afb9bSAndroid Build Coastguard Worker    # Waiting for this to be detected by the "$cpprog $src $dsttmp" command
261*663afb9bSAndroid Build Coastguard Worker    # might cause directories to be created, which would be especially bad
262*663afb9bSAndroid Build Coastguard Worker    # if $src (and thus $dsttmp) contains '*'.
263*663afb9bSAndroid Build Coastguard Worker    if test ! -f "$src" && test ! -d "$src"; then
264*663afb9bSAndroid Build Coastguard Worker      echo "$0: $src does not exist." >&2
265*663afb9bSAndroid Build Coastguard Worker      exit 1
266*663afb9bSAndroid Build Coastguard Worker    fi
267*663afb9bSAndroid Build Coastguard Worker
268*663afb9bSAndroid Build Coastguard Worker    if test -z "$dst_arg"; then
269*663afb9bSAndroid Build Coastguard Worker      echo "$0: no destination specified." >&2
270*663afb9bSAndroid Build Coastguard Worker      exit 1
271*663afb9bSAndroid Build Coastguard Worker    fi
272*663afb9bSAndroid Build Coastguard Worker    dst=$dst_arg
273*663afb9bSAndroid Build Coastguard Worker
274*663afb9bSAndroid Build Coastguard Worker    # If destination is a directory, append the input filename.
275*663afb9bSAndroid Build Coastguard Worker    if test -d "$dst"; then
276*663afb9bSAndroid Build Coastguard Worker      if test "$is_target_a_directory" = never; then
277*663afb9bSAndroid Build Coastguard Worker        echo "$0: $dst_arg: Is a directory" >&2
278*663afb9bSAndroid Build Coastguard Worker        exit 1
279*663afb9bSAndroid Build Coastguard Worker      fi
280*663afb9bSAndroid Build Coastguard Worker      dstdir=$dst
281*663afb9bSAndroid Build Coastguard Worker      dstbase=`basename "$src"`
282*663afb9bSAndroid Build Coastguard Worker      case $dst in
283*663afb9bSAndroid Build Coastguard Worker	*/) dst=$dst$dstbase;;
284*663afb9bSAndroid Build Coastguard Worker	*)  dst=$dst/$dstbase;;
285*663afb9bSAndroid Build Coastguard Worker      esac
286*663afb9bSAndroid Build Coastguard Worker      dstdir_status=0
287*663afb9bSAndroid Build Coastguard Worker    else
288*663afb9bSAndroid Build Coastguard Worker      dstdir=`dirname "$dst"`
289*663afb9bSAndroid Build Coastguard Worker      test -d "$dstdir"
290*663afb9bSAndroid Build Coastguard Worker      dstdir_status=$?
291*663afb9bSAndroid Build Coastguard Worker    fi
292*663afb9bSAndroid Build Coastguard Worker  fi
293*663afb9bSAndroid Build Coastguard Worker
294*663afb9bSAndroid Build Coastguard Worker  case $dstdir in
295*663afb9bSAndroid Build Coastguard Worker    */) dstdirslash=$dstdir;;
296*663afb9bSAndroid Build Coastguard Worker    *)  dstdirslash=$dstdir/;;
297*663afb9bSAndroid Build Coastguard Worker  esac
298*663afb9bSAndroid Build Coastguard Worker
299*663afb9bSAndroid Build Coastguard Worker  obsolete_mkdir_used=false
300*663afb9bSAndroid Build Coastguard Worker
301*663afb9bSAndroid Build Coastguard Worker  if test $dstdir_status != 0; then
302*663afb9bSAndroid Build Coastguard Worker    case $posix_mkdir in
303*663afb9bSAndroid Build Coastguard Worker      '')
304*663afb9bSAndroid Build Coastguard Worker        # Create intermediate dirs using mode 755 as modified by the umask.
305*663afb9bSAndroid Build Coastguard Worker        # This is like FreeBSD 'install' as of 1997-10-28.
306*663afb9bSAndroid Build Coastguard Worker        umask=`umask`
307*663afb9bSAndroid Build Coastguard Worker        case $stripcmd.$umask in
308*663afb9bSAndroid Build Coastguard Worker          # Optimize common cases.
309*663afb9bSAndroid Build Coastguard Worker          *[2367][2367]) mkdir_umask=$umask;;
310*663afb9bSAndroid Build Coastguard Worker          .*0[02][02] | .[02][02] | .[02]) mkdir_umask=22;;
311*663afb9bSAndroid Build Coastguard Worker
312*663afb9bSAndroid Build Coastguard Worker          *[0-7])
313*663afb9bSAndroid Build Coastguard Worker            mkdir_umask=`expr $umask + 22 \
314*663afb9bSAndroid Build Coastguard Worker              - $umask % 100 % 40 + $umask % 20 \
315*663afb9bSAndroid Build Coastguard Worker              - $umask % 10 % 4 + $umask % 2
316*663afb9bSAndroid Build Coastguard Worker            `;;
317*663afb9bSAndroid Build Coastguard Worker          *) mkdir_umask=$umask,go-w;;
318*663afb9bSAndroid Build Coastguard Worker        esac
319*663afb9bSAndroid Build Coastguard Worker
320*663afb9bSAndroid Build Coastguard Worker        # With -d, create the new directory with the user-specified mode.
321*663afb9bSAndroid Build Coastguard Worker        # Otherwise, rely on $mkdir_umask.
322*663afb9bSAndroid Build Coastguard Worker        if test -n "$dir_arg"; then
323*663afb9bSAndroid Build Coastguard Worker          mkdir_mode=-m$mode
324*663afb9bSAndroid Build Coastguard Worker        else
325*663afb9bSAndroid Build Coastguard Worker          mkdir_mode=
326*663afb9bSAndroid Build Coastguard Worker        fi
327*663afb9bSAndroid Build Coastguard Worker
328*663afb9bSAndroid Build Coastguard Worker        posix_mkdir=false
329*663afb9bSAndroid Build Coastguard Worker        case $umask in
330*663afb9bSAndroid Build Coastguard Worker          *[123567][0-7][0-7])
331*663afb9bSAndroid Build Coastguard Worker            # POSIX mkdir -p sets u+wx bits regardless of umask, which
332*663afb9bSAndroid Build Coastguard Worker            # is incompatible with FreeBSD 'install' when (umask & 300) != 0.
333*663afb9bSAndroid Build Coastguard Worker            ;;
334*663afb9bSAndroid Build Coastguard Worker          *)
335*663afb9bSAndroid Build Coastguard Worker            # Note that $RANDOM variable is not portable (e.g. dash);  Use it
336*663afb9bSAndroid Build Coastguard Worker            # here however when possible just to lower collision chance.
337*663afb9bSAndroid Build Coastguard Worker            tmpdir=${TMPDIR-/tmp}/ins$RANDOM-$$
338*663afb9bSAndroid Build Coastguard Worker
339*663afb9bSAndroid Build Coastguard Worker            trap 'ret=$?; rmdir "$tmpdir/a/b" "$tmpdir/a" "$tmpdir" 2>/dev/null; exit $ret' 0
340*663afb9bSAndroid Build Coastguard Worker
341*663afb9bSAndroid Build Coastguard Worker            # Because "mkdir -p" follows existing symlinks and we likely work
342*663afb9bSAndroid Build Coastguard Worker            # directly in world-writeable /tmp, make sure that the '$tmpdir'
343*663afb9bSAndroid Build Coastguard Worker            # directory is successfully created first before we actually test
344*663afb9bSAndroid Build Coastguard Worker            # 'mkdir -p' feature.
345*663afb9bSAndroid Build Coastguard Worker            if (umask $mkdir_umask &&
346*663afb9bSAndroid Build Coastguard Worker                $mkdirprog $mkdir_mode "$tmpdir" &&
347*663afb9bSAndroid Build Coastguard Worker                exec $mkdirprog $mkdir_mode -p -- "$tmpdir/a/b") >/dev/null 2>&1
348*663afb9bSAndroid Build Coastguard Worker            then
349*663afb9bSAndroid Build Coastguard Worker              if test -z "$dir_arg" || {
350*663afb9bSAndroid Build Coastguard Worker                   # Check for POSIX incompatibilities with -m.
351*663afb9bSAndroid Build Coastguard Worker                   # HP-UX 11.23 and IRIX 6.5 mkdir -m -p sets group- or
352*663afb9bSAndroid Build Coastguard Worker                   # other-writable bit of parent directory when it shouldn't.
353*663afb9bSAndroid Build Coastguard Worker                   # FreeBSD 6.1 mkdir -m -p sets mode of existing directory.
354*663afb9bSAndroid Build Coastguard Worker                   test_tmpdir="$tmpdir/a"
355*663afb9bSAndroid Build Coastguard Worker                   ls_ld_tmpdir=`ls -ld "$test_tmpdir"`
356*663afb9bSAndroid Build Coastguard Worker                   case $ls_ld_tmpdir in
357*663afb9bSAndroid Build Coastguard Worker                     d????-?r-*) different_mode=700;;
358*663afb9bSAndroid Build Coastguard Worker                     d????-?--*) different_mode=755;;
359*663afb9bSAndroid Build Coastguard Worker                     *) false;;
360*663afb9bSAndroid Build Coastguard Worker                   esac &&
361*663afb9bSAndroid Build Coastguard Worker                   $mkdirprog -m$different_mode -p -- "$test_tmpdir" && {
362*663afb9bSAndroid Build Coastguard Worker                     ls_ld_tmpdir_1=`ls -ld "$test_tmpdir"`
363*663afb9bSAndroid Build Coastguard Worker                     test "$ls_ld_tmpdir" = "$ls_ld_tmpdir_1"
364*663afb9bSAndroid Build Coastguard Worker                   }
365*663afb9bSAndroid Build Coastguard Worker                 }
366*663afb9bSAndroid Build Coastguard Worker              then posix_mkdir=:
367*663afb9bSAndroid Build Coastguard Worker              fi
368*663afb9bSAndroid Build Coastguard Worker              rmdir "$tmpdir/a/b" "$tmpdir/a" "$tmpdir"
369*663afb9bSAndroid Build Coastguard Worker            else
370*663afb9bSAndroid Build Coastguard Worker              # Remove any dirs left behind by ancient mkdir implementations.
371*663afb9bSAndroid Build Coastguard Worker              rmdir ./$mkdir_mode ./-p ./-- "$tmpdir" 2>/dev/null
372*663afb9bSAndroid Build Coastguard Worker            fi
373*663afb9bSAndroid Build Coastguard Worker            trap '' 0;;
374*663afb9bSAndroid Build Coastguard Worker        esac;;
375*663afb9bSAndroid Build Coastguard Worker    esac
376*663afb9bSAndroid Build Coastguard Worker
377*663afb9bSAndroid Build Coastguard Worker    if
378*663afb9bSAndroid Build Coastguard Worker      $posix_mkdir && (
379*663afb9bSAndroid Build Coastguard Worker        umask $mkdir_umask &&
380*663afb9bSAndroid Build Coastguard Worker        $doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir"
381*663afb9bSAndroid Build Coastguard Worker      )
382*663afb9bSAndroid Build Coastguard Worker    then :
383*663afb9bSAndroid Build Coastguard Worker    else
384*663afb9bSAndroid Build Coastguard Worker
385*663afb9bSAndroid Build Coastguard Worker      # The umask is ridiculous, or mkdir does not conform to POSIX,
386*663afb9bSAndroid Build Coastguard Worker      # or it failed possibly due to a race condition.  Create the
387*663afb9bSAndroid Build Coastguard Worker      # directory the slow way, step by step, checking for races as we go.
388*663afb9bSAndroid Build Coastguard Worker
389*663afb9bSAndroid Build Coastguard Worker      case $dstdir in
390*663afb9bSAndroid Build Coastguard Worker        /*) prefix='/';;
391*663afb9bSAndroid Build Coastguard Worker        [-=\(\)!]*) prefix='./';;
392*663afb9bSAndroid Build Coastguard Worker        *)  prefix='';;
393*663afb9bSAndroid Build Coastguard Worker      esac
394*663afb9bSAndroid Build Coastguard Worker
395*663afb9bSAndroid Build Coastguard Worker      oIFS=$IFS
396*663afb9bSAndroid Build Coastguard Worker      IFS=/
397*663afb9bSAndroid Build Coastguard Worker      set -f
398*663afb9bSAndroid Build Coastguard Worker      set fnord $dstdir
399*663afb9bSAndroid Build Coastguard Worker      shift
400*663afb9bSAndroid Build Coastguard Worker      set +f
401*663afb9bSAndroid Build Coastguard Worker      IFS=$oIFS
402*663afb9bSAndroid Build Coastguard Worker
403*663afb9bSAndroid Build Coastguard Worker      prefixes=
404*663afb9bSAndroid Build Coastguard Worker
405*663afb9bSAndroid Build Coastguard Worker      for d
406*663afb9bSAndroid Build Coastguard Worker      do
407*663afb9bSAndroid Build Coastguard Worker        test X"$d" = X && continue
408*663afb9bSAndroid Build Coastguard Worker
409*663afb9bSAndroid Build Coastguard Worker        prefix=$prefix$d
410*663afb9bSAndroid Build Coastguard Worker        if test -d "$prefix"; then
411*663afb9bSAndroid Build Coastguard Worker          prefixes=
412*663afb9bSAndroid Build Coastguard Worker        else
413*663afb9bSAndroid Build Coastguard Worker          if $posix_mkdir; then
414*663afb9bSAndroid Build Coastguard Worker            (umask=$mkdir_umask &&
415*663afb9bSAndroid Build Coastguard Worker             $doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir") && break
416*663afb9bSAndroid Build Coastguard Worker            # Don't fail if two instances are running concurrently.
417*663afb9bSAndroid Build Coastguard Worker            test -d "$prefix" || exit 1
418*663afb9bSAndroid Build Coastguard Worker          else
419*663afb9bSAndroid Build Coastguard Worker            case $prefix in
420*663afb9bSAndroid Build Coastguard Worker              *\'*) qprefix=`echo "$prefix" | sed "s/'/'\\\\\\\\''/g"`;;
421*663afb9bSAndroid Build Coastguard Worker              *) qprefix=$prefix;;
422*663afb9bSAndroid Build Coastguard Worker            esac
423*663afb9bSAndroid Build Coastguard Worker            prefixes="$prefixes '$qprefix'"
424*663afb9bSAndroid Build Coastguard Worker          fi
425*663afb9bSAndroid Build Coastguard Worker        fi
426*663afb9bSAndroid Build Coastguard Worker        prefix=$prefix/
427*663afb9bSAndroid Build Coastguard Worker      done
428*663afb9bSAndroid Build Coastguard Worker
429*663afb9bSAndroid Build Coastguard Worker      if test -n "$prefixes"; then
430*663afb9bSAndroid Build Coastguard Worker        # Don't fail if two instances are running concurrently.
431*663afb9bSAndroid Build Coastguard Worker        (umask $mkdir_umask &&
432*663afb9bSAndroid Build Coastguard Worker         eval "\$doit_exec \$mkdirprog $prefixes") ||
433*663afb9bSAndroid Build Coastguard Worker          test -d "$dstdir" || exit 1
434*663afb9bSAndroid Build Coastguard Worker        obsolete_mkdir_used=true
435*663afb9bSAndroid Build Coastguard Worker      fi
436*663afb9bSAndroid Build Coastguard Worker    fi
437*663afb9bSAndroid Build Coastguard Worker  fi
438*663afb9bSAndroid Build Coastguard Worker
439*663afb9bSAndroid Build Coastguard Worker  if test -n "$dir_arg"; then
440*663afb9bSAndroid Build Coastguard Worker    { test -z "$chowncmd" || $doit $chowncmd "$dst"; } &&
441*663afb9bSAndroid Build Coastguard Worker    { test -z "$chgrpcmd" || $doit $chgrpcmd "$dst"; } &&
442*663afb9bSAndroid Build Coastguard Worker    { test "$obsolete_mkdir_used$chowncmd$chgrpcmd" = false ||
443*663afb9bSAndroid Build Coastguard Worker      test -z "$chmodcmd" || $doit $chmodcmd $mode "$dst"; } || exit 1
444*663afb9bSAndroid Build Coastguard Worker  else
445*663afb9bSAndroid Build Coastguard Worker
446*663afb9bSAndroid Build Coastguard Worker    # Make a couple of temp file names in the proper directory.
447*663afb9bSAndroid Build Coastguard Worker    dsttmp=${dstdirslash}_inst.$$_
448*663afb9bSAndroid Build Coastguard Worker    rmtmp=${dstdirslash}_rm.$$_
449*663afb9bSAndroid Build Coastguard Worker
450*663afb9bSAndroid Build Coastguard Worker    # Trap to clean up those temp files at exit.
451*663afb9bSAndroid Build Coastguard Worker    trap 'ret=$?; rm -f "$dsttmp" "$rmtmp" && exit $ret' 0
452*663afb9bSAndroid Build Coastguard Worker
453*663afb9bSAndroid Build Coastguard Worker    # Copy the file name to the temp name.
454*663afb9bSAndroid Build Coastguard Worker    (umask $cp_umask &&
455*663afb9bSAndroid Build Coastguard Worker     { test -z "$stripcmd" || {
456*663afb9bSAndroid Build Coastguard Worker	 # Create $dsttmp read-write so that cp doesn't create it read-only,
457*663afb9bSAndroid Build Coastguard Worker	 # which would cause strip to fail.
458*663afb9bSAndroid Build Coastguard Worker	 if test -z "$doit"; then
459*663afb9bSAndroid Build Coastguard Worker	   : >"$dsttmp" # No need to fork-exec 'touch'.
460*663afb9bSAndroid Build Coastguard Worker	 else
461*663afb9bSAndroid Build Coastguard Worker	   $doit touch "$dsttmp"
462*663afb9bSAndroid Build Coastguard Worker	 fi
463*663afb9bSAndroid Build Coastguard Worker       }
464*663afb9bSAndroid Build Coastguard Worker     } &&
465*663afb9bSAndroid Build Coastguard Worker     $doit_exec $cpprog "$src" "$dsttmp") &&
466*663afb9bSAndroid Build Coastguard Worker
467*663afb9bSAndroid Build Coastguard Worker    # and set any options; do chmod last to preserve setuid bits.
468*663afb9bSAndroid Build Coastguard Worker    #
469*663afb9bSAndroid Build Coastguard Worker    # If any of these fail, we abort the whole thing.  If we want to
470*663afb9bSAndroid Build Coastguard Worker    # ignore errors from any of these, just make sure not to ignore
471*663afb9bSAndroid Build Coastguard Worker    # errors from the above "$doit $cpprog $src $dsttmp" command.
472*663afb9bSAndroid Build Coastguard Worker    #
473*663afb9bSAndroid Build Coastguard Worker    { test -z "$chowncmd" || $doit $chowncmd "$dsttmp"; } &&
474*663afb9bSAndroid Build Coastguard Worker    { test -z "$chgrpcmd" || $doit $chgrpcmd "$dsttmp"; } &&
475*663afb9bSAndroid Build Coastguard Worker    { test -z "$stripcmd" || $doit $stripcmd "$dsttmp"; } &&
476*663afb9bSAndroid Build Coastguard Worker    { test -z "$chmodcmd" || $doit $chmodcmd $mode "$dsttmp"; } &&
477*663afb9bSAndroid Build Coastguard Worker
478*663afb9bSAndroid Build Coastguard Worker    # If -C, don't bother to copy if it wouldn't change the file.
479*663afb9bSAndroid Build Coastguard Worker    if $copy_on_change &&
480*663afb9bSAndroid Build Coastguard Worker       old=`LC_ALL=C ls -dlL "$dst"     2>/dev/null` &&
481*663afb9bSAndroid Build Coastguard Worker       new=`LC_ALL=C ls -dlL "$dsttmp"  2>/dev/null` &&
482*663afb9bSAndroid Build Coastguard Worker       set -f &&
483*663afb9bSAndroid Build Coastguard Worker       set X $old && old=:$2:$4:$5:$6 &&
484*663afb9bSAndroid Build Coastguard Worker       set X $new && new=:$2:$4:$5:$6 &&
485*663afb9bSAndroid Build Coastguard Worker       set +f &&
486*663afb9bSAndroid Build Coastguard Worker       test "$old" = "$new" &&
487*663afb9bSAndroid Build Coastguard Worker       $cmpprog "$dst" "$dsttmp" >/dev/null 2>&1
488*663afb9bSAndroid Build Coastguard Worker    then
489*663afb9bSAndroid Build Coastguard Worker      rm -f "$dsttmp"
490*663afb9bSAndroid Build Coastguard Worker    else
491*663afb9bSAndroid Build Coastguard Worker      # Rename the file to the real destination.
492*663afb9bSAndroid Build Coastguard Worker      $doit $mvcmd -f "$dsttmp" "$dst" 2>/dev/null ||
493*663afb9bSAndroid Build Coastguard Worker
494*663afb9bSAndroid Build Coastguard Worker      # The rename failed, perhaps because mv can't rename something else
495*663afb9bSAndroid Build Coastguard Worker      # to itself, or perhaps because mv is so ancient that it does not
496*663afb9bSAndroid Build Coastguard Worker      # support -f.
497*663afb9bSAndroid Build Coastguard Worker      {
498*663afb9bSAndroid Build Coastguard Worker        # Now remove or move aside any old file at destination location.
499*663afb9bSAndroid Build Coastguard Worker        # We try this two ways since rm can't unlink itself on some
500*663afb9bSAndroid Build Coastguard Worker        # systems and the destination file might be busy for other
501*663afb9bSAndroid Build Coastguard Worker        # reasons.  In this case, the final cleanup might fail but the new
502*663afb9bSAndroid Build Coastguard Worker        # file should still install successfully.
503*663afb9bSAndroid Build Coastguard Worker        {
504*663afb9bSAndroid Build Coastguard Worker          test ! -f "$dst" ||
505*663afb9bSAndroid Build Coastguard Worker          $doit $rmcmd -f "$dst" 2>/dev/null ||
506*663afb9bSAndroid Build Coastguard Worker          { $doit $mvcmd -f "$dst" "$rmtmp" 2>/dev/null &&
507*663afb9bSAndroid Build Coastguard Worker            { $doit $rmcmd -f "$rmtmp" 2>/dev/null; :; }
508*663afb9bSAndroid Build Coastguard Worker          } ||
509*663afb9bSAndroid Build Coastguard Worker          { echo "$0: cannot unlink or rename $dst" >&2
510*663afb9bSAndroid Build Coastguard Worker            (exit 1); exit 1
511*663afb9bSAndroid Build Coastguard Worker          }
512*663afb9bSAndroid Build Coastguard Worker        } &&
513*663afb9bSAndroid Build Coastguard Worker
514*663afb9bSAndroid Build Coastguard Worker        # Now rename the file to the real destination.
515*663afb9bSAndroid Build Coastguard Worker        $doit $mvcmd "$dsttmp" "$dst"
516*663afb9bSAndroid Build Coastguard Worker      }
517*663afb9bSAndroid Build Coastguard Worker    fi || exit 1
518*663afb9bSAndroid Build Coastguard Worker
519*663afb9bSAndroid Build Coastguard Worker    trap '' 0
520*663afb9bSAndroid Build Coastguard Worker  fi
521*663afb9bSAndroid Build Coastguard Workerdone
522*663afb9bSAndroid Build Coastguard Worker
523*663afb9bSAndroid Build Coastguard Worker# Local variables:
524*663afb9bSAndroid Build Coastguard Worker# eval: (add-hook 'before-save-hook 'time-stamp)
525*663afb9bSAndroid Build Coastguard Worker# time-stamp-start: "scriptversion="
526*663afb9bSAndroid Build Coastguard Worker# time-stamp-format: "%:y-%02m-%02d.%02H"
527*663afb9bSAndroid Build Coastguard Worker# time-stamp-time-zone: "UTC0"
528*663afb9bSAndroid Build Coastguard Worker# time-stamp-end: "; # UTC"
529*663afb9bSAndroid Build Coastguard Worker# End:
530