ffi 1.0.11 → 1.0.12.pre
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of ffi might be problematic. Click here for more details.
- data/Rakefile +1 -1
- data/ext/ffi_c/AbstractMemory.c +9 -0
- data/ext/ffi_c/AbstractMemory.h +4 -0
- data/ext/ffi_c/Buffer.c +8 -0
- data/ext/ffi_c/Call.c +8 -0
- data/ext/ffi_c/ClosurePool.c +12 -0
- data/ext/ffi_c/DynamicLibrary.c +7 -1
- data/ext/ffi_c/Function.c +11 -1
- data/ext/ffi_c/Function.h +6 -0
- data/ext/ffi_c/FunctionInfo.c +8 -0
- data/ext/ffi_c/LastError.c +8 -0
- data/ext/ffi_c/MemoryPointer.c +8 -0
- data/ext/ffi_c/MemoryPointer.h +6 -0
- data/ext/ffi_c/MethodHandle.c +8 -0
- data/ext/ffi_c/Platform.c +8 -0
- data/ext/ffi_c/Pointer.c +8 -0
- data/ext/ffi_c/Pointer.h +6 -0
- data/ext/ffi_c/Struct.c +6 -0
- data/ext/ffi_c/StructByReference.c +8 -0
- data/ext/ffi_c/StructByValue.c +8 -0
- data/ext/ffi_c/StructLayout.c +6 -0
- data/ext/ffi_c/Thread.c +7 -0
- data/ext/ffi_c/Thread.h +6 -0
- data/ext/ffi_c/Type.c +3 -0
- data/ext/ffi_c/Types.h +4 -0
- data/ext/ffi_c/Variadic.c +8 -0
- data/ext/ffi_c/endian.h +3 -0
- data/ext/ffi_c/extconf.rb +6 -1
- data/ext/ffi_c/libffi.vc.mk +26 -0
- data/ext/ffi_c/libffi.vc64.mk +26 -0
- data/ext/ffi_c/libffi/ChangeLog +541 -0
- data/ext/ffi_c/libffi/ChangeLog.libffi +13 -87
- data/ext/ffi_c/libffi/LICENSE +3 -3
- data/ext/ffi_c/libffi/Makefile.am +41 -32
- data/ext/ffi_c/libffi/Makefile.in +95 -66
- data/ext/ffi_c/libffi/Makefile.vc +141 -0
- data/ext/ffi_c/libffi/Makefile.vc64 +141 -0
- data/ext/ffi_c/libffi/README +40 -4
- data/ext/ffi_c/libffi/aclocal.m4 +729 -7854
- data/ext/ffi_c/libffi/build-ios.sh +67 -0
- data/ext/ffi_c/libffi/compile +11 -10
- data/ext/ffi_c/libffi/config.guess +4 -1
- data/ext/ffi_c/libffi/config.sub +6 -3
- data/ext/ffi_c/libffi/configure +6264 -6354
- data/ext/ffi_c/libffi/configure.ac +155 -63
- data/ext/ffi_c/libffi/depcomp +81 -35
- data/ext/ffi_c/libffi/doc/libffi.info +78 -18
- data/ext/ffi_c/libffi/doc/libffi.texi +64 -5
- data/ext/ffi_c/libffi/doc/stamp-vti +4 -4
- data/ext/ffi_c/libffi/doc/version.texi +4 -4
- data/ext/ffi_c/libffi/fficonfig.h.in +18 -0
- data/ext/ffi_c/libffi/fficonfig.hw +57 -0
- data/ext/ffi_c/libffi/include/Makefile.in +21 -3
- data/ext/ffi_c/libffi/include/ffi.h.in +42 -14
- data/ext/ffi_c/libffi/include/ffi.h.vc +427 -0
- data/ext/ffi_c/libffi/include/ffi.h.vc64 +427 -0
- data/ext/ffi_c/libffi/include/ffi_common.h +9 -5
- data/ext/ffi_c/libffi/install-sh +364 -167
- data/ext/ffi_c/libffi/ltmain.sh +2599 -1369
- data/ext/ffi_c/libffi/m4/ax_cc_maxopt.m4 +176 -0
- data/ext/ffi_c/libffi/m4/ax_cflags_warn_all.m4 +195 -0
- data/ext/ffi_c/libffi/m4/ax_check_compiler_flags.m4 +76 -0
- data/ext/ffi_c/libffi/m4/ax_compiler_vendor.m4 +63 -0
- data/ext/ffi_c/libffi/m4/ax_configure_args.m4 +70 -0
- data/ext/ffi_c/libffi/m4/ax_enable_builddir.m4 +300 -0
- data/ext/ffi_c/libffi/m4/ax_gcc_archflag.m4 +215 -0
- data/ext/ffi_c/libffi/m4/ax_gcc_x86_cpuid.m4 +79 -0
- data/ext/ffi_c/libffi/m4/libtool.m4 +1239 -768
- data/ext/ffi_c/libffi/m4/ltoptions.m4 +7 -6
- data/ext/ffi_c/libffi/m4/ltversion.m4 +6 -6
- data/ext/ffi_c/libffi/m4/lt~obsolete.m4 +9 -3
- data/ext/ffi_c/libffi/man/Makefile.in +21 -3
- data/ext/ffi_c/libffi/mdate-sh +0 -0
- data/ext/ffi_c/libffi/missing +60 -44
- data/ext/ffi_c/libffi/msvcc.sh +197 -0
- data/ext/ffi_c/libffi/src/alpha/osf.S +39 -18
- data/ext/ffi_c/libffi/src/arm/ffi.c +443 -24
- data/ext/ffi_c/libffi/src/arm/ffitarget.h +17 -1
- data/ext/ffi_c/libffi/src/arm/gentramp.sh +118 -0
- data/ext/ffi_c/libffi/src/arm/sysv.S +206 -15
- data/ext/ffi_c/libffi/src/arm/trampoline.S +4450 -0
- data/ext/ffi_c/libffi/src/avr32/ffi.c +4 -2
- data/ext/ffi_c/libffi/src/avr32/ffitarget.h +2 -2
- data/ext/ffi_c/libffi/src/closures.c +17 -35
- data/ext/ffi_c/libffi/src/cris/ffi.c +1 -1
- data/ext/ffi_c/libffi/src/cris/ffitarget.h +2 -2
- data/ext/ffi_c/libffi/src/dlmalloc.c +66 -4
- data/ext/ffi_c/libffi/src/frv/ffitarget.h +2 -6
- data/ext/ffi_c/libffi/src/ia64/ffi.c +7 -5
- data/ext/ffi_c/libffi/src/ia64/ffitarget.h +2 -2
- data/ext/ffi_c/libffi/src/java_raw_api.c +1 -1
- data/ext/ffi_c/libffi/src/m32r/ffitarget.h +2 -2
- data/ext/ffi_c/libffi/src/m68k/ffi.c +10 -0
- data/ext/ffi_c/libffi/src/m68k/ffitarget.h +2 -2
- data/ext/ffi_c/libffi/src/m68k/sysv.S +36 -0
- data/ext/ffi_c/libffi/src/mips/ffi.c +12 -5
- data/ext/ffi_c/libffi/src/mips/ffitarget.h +18 -11
- data/ext/ffi_c/libffi/src/mips/n32.S +4 -4
- data/ext/ffi_c/libffi/src/moxie/eabi.S +128 -0
- data/ext/ffi_c/libffi/src/moxie/ffi.c +276 -0
- data/ext/ffi_c/libffi/src/pa/ffi.c +7 -4
- data/ext/ffi_c/libffi/src/pa/ffitarget.h +6 -5
- data/ext/ffi_c/libffi/src/powerpc/aix.S +5 -1
- data/ext/ffi_c/libffi/src/powerpc/aix_closure.S +2 -0
- data/ext/ffi_c/libffi/src/powerpc/asm.h +1 -1
- data/ext/ffi_c/libffi/src/powerpc/darwin.S +215 -77
- data/ext/ffi_c/libffi/src/powerpc/darwin_closure.S +358 -100
- data/ext/ffi_c/libffi/src/powerpc/ffi.c +11 -5
- data/ext/ffi_c/libffi/src/powerpc/ffi_darwin.c +603 -172
- data/ext/ffi_c/libffi/src/powerpc/ffitarget.h +17 -4
- data/ext/ffi_c/libffi/src/prep_cif.c +16 -13
- data/ext/ffi_c/libffi/src/s390/ffitarget.h +4 -2
- data/ext/ffi_c/libffi/src/sh/ffitarget.h +2 -2
- data/ext/ffi_c/libffi/src/sh64/ffitarget.h +2 -2
- data/ext/ffi_c/libffi/src/sparc/ffi.c +55 -11
- data/ext/ffi_c/libffi/src/sparc/ffitarget.h +5 -3
- data/ext/ffi_c/libffi/src/x86/ffi.c +54 -92
- data/ext/ffi_c/libffi/src/x86/ffi64.c +17 -8
- data/ext/ffi_c/libffi/src/x86/ffitarget.h +15 -14
- data/ext/ffi_c/libffi/src/x86/sysv.S +40 -26
- data/ext/ffi_c/libffi/src/x86/unix64.S +4 -0
- data/ext/ffi_c/libffi/src/x86/win32.S +379 -191
- data/ext/ffi_c/libffi/src/x86/win64.S +15 -7
- data/ext/ffi_c/libffi/testsuite/Makefile.am +1 -1
- data/ext/ffi_c/libffi/testsuite/Makefile.in +22 -4
- data/ext/ffi_c/libffi/testsuite/lib/libffi.exp +350 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/call.exp +1 -5
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_longdouble_split.c +1 -1
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_longdouble_split2.c +1 -1
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_sint64.c +1 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_uint64.c +1 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_double_va.c +3 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_longdouble.c +2 -2
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_longdouble_va.c +3 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_pointer.c +1 -1
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_pointer_stack.c +1 -1
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_ulonglong.c +1 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/err_bad_abi.c +2 -3
- data/ext/ffi_c/libffi/testsuite/libffi.call/err_bad_typedef.c +2 -1
- data/ext/ffi_c/libffi/testsuite/libffi.call/ffitest.h +36 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/huge_struct.c +17 -17
- data/ext/ffi_c/libffi/testsuite/libffi.call/return_ll1.c +1 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/stret_medium2.c +1 -0
- data/ext/ffi_c/libffi/testsuite/libffi.special/ffitestcxx.h +1 -1
- data/ext/ffi_c/libffi/testsuite/libffi.special/special.exp +1 -3
- data/ext/ffi_c/win32/stdint.h +199 -0
- data/gen/Rakefile +18 -2
- data/lib/ffi/platform/arm-linux/types.conf +102 -0
- data/lib/ffi/platform/i486-gnu/types.conf +107 -0
- data/lib/ffi/platform/ia64-linux/types.conf +102 -0
- data/lib/ffi/platform/mips-linux/types.conf +102 -0
- data/lib/ffi/platform/mipsel-linux/types.conf +102 -0
- data/lib/ffi/platform/powerpc-linux/types.conf +100 -0
- data/lib/ffi/platform/s390-linux/types.conf +102 -0
- data/lib/ffi/platform/s390x-linux/types.conf +102 -0
- data/lib/ffi/platform/sparc-linux/types.conf +102 -0
- data/lib/ffi/tools/types_generator.rb +8 -1
- data/lib/ffi_c.bundle +0 -0
- metadata +72 -42
data/ext/ffi_c/libffi/install-sh
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
#!/bin/sh
|
2
2
|
# install - install a program, script, or datafile
|
3
3
|
|
4
|
-
scriptversion=
|
4
|
+
scriptversion=2009-04-28.21; # UTC
|
5
5
|
|
6
6
|
# This originates from X11R5 (mit/util/scripts/install.sh), which was
|
7
7
|
# later released in X11R6 (xc/config/util/install.sh) with the
|
@@ -39,38 +39,68 @@ scriptversion=2004-12-17.09
|
|
39
39
|
# when there is no Makefile.
|
40
40
|
#
|
41
41
|
# This script is compatible with the BSD install script, but was written
|
42
|
-
# from scratch.
|
43
|
-
|
42
|
+
# from scratch.
|
43
|
+
|
44
|
+
nl='
|
45
|
+
'
|
46
|
+
IFS=" "" $nl"
|
44
47
|
|
45
48
|
# set DOITPROG to echo to test this script
|
46
49
|
|
47
50
|
# Don't use :- since 4.3BSD and earlier shells don't like it.
|
48
|
-
doit
|
51
|
+
doit=${DOITPROG-}
|
52
|
+
if test -z "$doit"; then
|
53
|
+
doit_exec=exec
|
54
|
+
else
|
55
|
+
doit_exec=$doit
|
56
|
+
fi
|
57
|
+
|
58
|
+
# Put in absolute file names if you don't have them in your path;
|
59
|
+
# or use environment vars.
|
60
|
+
|
61
|
+
chgrpprog=${CHGRPPROG-chgrp}
|
62
|
+
chmodprog=${CHMODPROG-chmod}
|
63
|
+
chownprog=${CHOWNPROG-chown}
|
64
|
+
cmpprog=${CMPPROG-cmp}
|
65
|
+
cpprog=${CPPROG-cp}
|
66
|
+
mkdirprog=${MKDIRPROG-mkdir}
|
67
|
+
mvprog=${MVPROG-mv}
|
68
|
+
rmprog=${RMPROG-rm}
|
69
|
+
stripprog=${STRIPPROG-strip}
|
70
|
+
|
71
|
+
posix_glob='?'
|
72
|
+
initialize_posix_glob='
|
73
|
+
test "$posix_glob" != "?" || {
|
74
|
+
if (set -f) 2>/dev/null; then
|
75
|
+
posix_glob=
|
76
|
+
else
|
77
|
+
posix_glob=:
|
78
|
+
fi
|
79
|
+
}
|
80
|
+
'
|
49
81
|
|
50
|
-
|
82
|
+
posix_mkdir=
|
51
83
|
|
52
|
-
|
53
|
-
|
54
|
-
chmodprog="${CHMODPROG-chmod}"
|
55
|
-
chownprog="${CHOWNPROG-chown}"
|
56
|
-
chgrpprog="${CHGRPPROG-chgrp}"
|
57
|
-
stripprog="${STRIPPROG-strip}"
|
58
|
-
rmprog="${RMPROG-rm}"
|
59
|
-
mkdirprog="${MKDIRPROG-mkdir}"
|
84
|
+
# Desired mode of installed file.
|
85
|
+
mode=0755
|
60
86
|
|
61
|
-
chmodcmd="$chmodprog 0755"
|
62
|
-
chowncmd=
|
63
87
|
chgrpcmd=
|
64
|
-
|
88
|
+
chmodcmd=$chmodprog
|
89
|
+
chowncmd=
|
90
|
+
mvcmd=$mvprog
|
65
91
|
rmcmd="$rmprog -f"
|
66
|
-
|
92
|
+
stripcmd=
|
93
|
+
|
67
94
|
src=
|
68
95
|
dst=
|
69
96
|
dir_arg=
|
70
|
-
|
97
|
+
dst_arg=
|
98
|
+
|
99
|
+
copy_on_change=false
|
71
100
|
no_target_directory=
|
72
101
|
|
73
|
-
usage="
|
102
|
+
usage="\
|
103
|
+
Usage: $0 [OPTION]... [-T] SRCFILE DSTFILE
|
74
104
|
or: $0 [OPTION]... SRCFILES... DIRECTORY
|
75
105
|
or: $0 [OPTION]... -t DIRECTORY SRCFILES...
|
76
106
|
or: $0 [OPTION]... -d DIRECTORIES...
|
@@ -80,81 +110,86 @@ In the 2nd and 3rd, copy all SRCFILES to DIRECTORY.
|
|
80
110
|
In the 4th, create DIRECTORIES.
|
81
111
|
|
82
112
|
Options:
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
-
|
87
|
-
-
|
88
|
-
-
|
89
|
-
-
|
90
|
-
-
|
91
|
-
|
92
|
-
|
113
|
+
--help display this help and exit.
|
114
|
+
--version display version info and exit.
|
115
|
+
|
116
|
+
-c (ignored)
|
117
|
+
-C install only if different (preserve the last data modification time)
|
118
|
+
-d create directories instead of installing files.
|
119
|
+
-g GROUP $chgrpprog installed files to GROUP.
|
120
|
+
-m MODE $chmodprog installed files to MODE.
|
121
|
+
-o USER $chownprog installed files to USER.
|
122
|
+
-s $stripprog installed files.
|
123
|
+
-t DIRECTORY install into DIRECTORY.
|
124
|
+
-T report an error if DSTFILE is a directory.
|
93
125
|
|
94
126
|
Environment variables override the default commands:
|
95
|
-
CHGRPPROG CHMODPROG CHOWNPROG CPPROG MKDIRPROG MVPROG
|
127
|
+
CHGRPPROG CHMODPROG CHOWNPROG CMPPROG CPPROG MKDIRPROG MVPROG
|
128
|
+
RMPROG STRIPPROG
|
96
129
|
"
|
97
130
|
|
98
|
-
while test -
|
131
|
+
while test $# -ne 0; do
|
99
132
|
case $1 in
|
100
|
-
-c)
|
101
|
-
continue;;
|
133
|
+
-c) ;;
|
102
134
|
|
103
|
-
-
|
104
|
-
|
105
|
-
|
135
|
+
-C) copy_on_change=true;;
|
136
|
+
|
137
|
+
-d) dir_arg=true;;
|
106
138
|
|
107
139
|
-g) chgrpcmd="$chgrpprog $2"
|
108
|
-
|
109
|
-
shift
|
110
|
-
continue;;
|
140
|
+
shift;;
|
111
141
|
|
112
|
-
--help) echo "$usage"; exit
|
142
|
+
--help) echo "$usage"; exit $?;;
|
113
143
|
|
114
|
-
-m)
|
115
|
-
|
116
|
-
|
117
|
-
|
144
|
+
-m) mode=$2
|
145
|
+
case $mode in
|
146
|
+
*' '* | *' '* | *'
|
147
|
+
'* | *'*'* | *'?'* | *'['*)
|
148
|
+
echo "$0: invalid mode: $mode" >&2
|
149
|
+
exit 1;;
|
150
|
+
esac
|
151
|
+
shift;;
|
118
152
|
|
119
153
|
-o) chowncmd="$chownprog $2"
|
120
|
-
|
121
|
-
|
122
|
-
|
123
|
-
|
124
|
-
-
|
125
|
-
|
126
|
-
|
127
|
-
|
128
|
-
|
129
|
-
|
130
|
-
|
131
|
-
|
132
|
-
|
133
|
-
-T) no_target_directory=true
|
134
|
-
shift
|
135
|
-
continue;;
|
136
|
-
|
137
|
-
--version) echo "$0 $scriptversion"; exit 0;;
|
138
|
-
|
139
|
-
*) # When -d is used, all remaining arguments are directories to create.
|
140
|
-
# When -t is used, the destination is already specified.
|
141
|
-
test -n "$dir_arg$dstarg" && break
|
142
|
-
# Otherwise, the last argument is the destination. Remove it from $@.
|
143
|
-
for arg
|
144
|
-
do
|
145
|
-
if test -n "$dstarg"; then
|
146
|
-
# $@ is not empty: it contains at least $arg.
|
147
|
-
set fnord "$@" "$dstarg"
|
148
|
-
shift # fnord
|
149
|
-
fi
|
150
|
-
shift # arg
|
151
|
-
dstarg=$arg
|
152
|
-
done
|
154
|
+
shift;;
|
155
|
+
|
156
|
+
-s) stripcmd=$stripprog;;
|
157
|
+
|
158
|
+
-t) dst_arg=$2
|
159
|
+
shift;;
|
160
|
+
|
161
|
+
-T) no_target_directory=true;;
|
162
|
+
|
163
|
+
--version) echo "$0 $scriptversion"; exit $?;;
|
164
|
+
|
165
|
+
--) shift
|
153
166
|
break;;
|
167
|
+
|
168
|
+
-*) echo "$0: invalid option: $1" >&2
|
169
|
+
exit 1;;
|
170
|
+
|
171
|
+
*) break;;
|
154
172
|
esac
|
173
|
+
shift
|
155
174
|
done
|
156
175
|
|
157
|
-
if test -z "$
|
176
|
+
if test $# -ne 0 && test -z "$dir_arg$dst_arg"; then
|
177
|
+
# When -d is used, all remaining arguments are directories to create.
|
178
|
+
# When -t is used, the destination is already specified.
|
179
|
+
# Otherwise, the last argument is the destination. Remove it from $@.
|
180
|
+
for arg
|
181
|
+
do
|
182
|
+
if test -n "$dst_arg"; then
|
183
|
+
# $@ is not empty: it contains at least $arg.
|
184
|
+
set fnord "$@" "$dst_arg"
|
185
|
+
shift # fnord
|
186
|
+
fi
|
187
|
+
shift # arg
|
188
|
+
dst_arg=$arg
|
189
|
+
done
|
190
|
+
fi
|
191
|
+
|
192
|
+
if test $# -eq 0; then
|
158
193
|
if test -z "$dir_arg"; then
|
159
194
|
echo "$0: no input file specified." >&2
|
160
195
|
exit 1
|
@@ -164,24 +199,47 @@ if test -z "$1"; then
|
|
164
199
|
exit 0
|
165
200
|
fi
|
166
201
|
|
202
|
+
if test -z "$dir_arg"; then
|
203
|
+
trap '(exit $?); exit' 1 2 13 15
|
204
|
+
|
205
|
+
# Set umask so as not to create temps with too-generous modes.
|
206
|
+
# However, 'strip' requires both read and write access to temps.
|
207
|
+
case $mode in
|
208
|
+
# Optimize common cases.
|
209
|
+
*644) cp_umask=133;;
|
210
|
+
*755) cp_umask=22;;
|
211
|
+
|
212
|
+
*[0-7])
|
213
|
+
if test -z "$stripcmd"; then
|
214
|
+
u_plus_rw=
|
215
|
+
else
|
216
|
+
u_plus_rw='% 200'
|
217
|
+
fi
|
218
|
+
cp_umask=`expr '(' 777 - $mode % 1000 ')' $u_plus_rw`;;
|
219
|
+
*)
|
220
|
+
if test -z "$stripcmd"; then
|
221
|
+
u_plus_rw=
|
222
|
+
else
|
223
|
+
u_plus_rw=,u+rw
|
224
|
+
fi
|
225
|
+
cp_umask=$mode$u_plus_rw;;
|
226
|
+
esac
|
227
|
+
fi
|
228
|
+
|
167
229
|
for src
|
168
230
|
do
|
169
231
|
# Protect names starting with `-'.
|
170
232
|
case $src in
|
171
|
-
-*) src=./$src
|
233
|
+
-*) src=./$src;;
|
172
234
|
esac
|
173
235
|
|
174
236
|
if test -n "$dir_arg"; then
|
175
237
|
dst=$src
|
176
|
-
|
177
|
-
|
178
|
-
|
179
|
-
mkdircmd=:
|
180
|
-
chmodcmd=
|
181
|
-
else
|
182
|
-
mkdircmd=$mkdirprog
|
183
|
-
fi
|
238
|
+
dstdir=$dst
|
239
|
+
test -d "$dstdir"
|
240
|
+
dstdir_status=$?
|
184
241
|
else
|
242
|
+
|
185
243
|
# Waiting for this to be detected by the "$cpprog $src $dsttmp" command
|
186
244
|
# might cause directories to be created, which would be especially bad
|
187
245
|
# if $src (and thus $dsttmp) contains '*'.
|
@@ -190,71 +248,199 @@ do
|
|
190
248
|
exit 1
|
191
249
|
fi
|
192
250
|
|
193
|
-
if test -z "$
|
251
|
+
if test -z "$dst_arg"; then
|
194
252
|
echo "$0: no destination specified." >&2
|
195
253
|
exit 1
|
196
254
|
fi
|
197
255
|
|
198
|
-
dst=$
|
256
|
+
dst=$dst_arg
|
199
257
|
# Protect names starting with `-'.
|
200
258
|
case $dst in
|
201
|
-
-*) dst=./$dst
|
259
|
+
-*) dst=./$dst;;
|
202
260
|
esac
|
203
261
|
|
204
262
|
# If destination is a directory, append the input filename; won't work
|
205
263
|
# if double slashes aren't ignored.
|
206
264
|
if test -d "$dst"; then
|
207
265
|
if test -n "$no_target_directory"; then
|
208
|
-
echo "$0: $
|
266
|
+
echo "$0: $dst_arg: Is a directory" >&2
|
209
267
|
exit 1
|
210
268
|
fi
|
211
|
-
|
269
|
+
dstdir=$dst
|
270
|
+
dst=$dstdir/`basename "$src"`
|
271
|
+
dstdir_status=0
|
272
|
+
else
|
273
|
+
# Prefer dirname, but fall back on a substitute if dirname fails.
|
274
|
+
dstdir=`
|
275
|
+
(dirname "$dst") 2>/dev/null ||
|
276
|
+
expr X"$dst" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
|
277
|
+
X"$dst" : 'X\(//\)[^/]' \| \
|
278
|
+
X"$dst" : 'X\(//\)$' \| \
|
279
|
+
X"$dst" : 'X\(/\)' \| . 2>/dev/null ||
|
280
|
+
echo X"$dst" |
|
281
|
+
sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{
|
282
|
+
s//\1/
|
283
|
+
q
|
284
|
+
}
|
285
|
+
/^X\(\/\/\)[^/].*/{
|
286
|
+
s//\1/
|
287
|
+
q
|
288
|
+
}
|
289
|
+
/^X\(\/\/\)$/{
|
290
|
+
s//\1/
|
291
|
+
q
|
292
|
+
}
|
293
|
+
/^X\(\/\).*/{
|
294
|
+
s//\1/
|
295
|
+
q
|
296
|
+
}
|
297
|
+
s/.*/./; q'
|
298
|
+
`
|
299
|
+
|
300
|
+
test -d "$dstdir"
|
301
|
+
dstdir_status=$?
|
212
302
|
fi
|
213
303
|
fi
|
214
304
|
|
215
|
-
|
216
|
-
|
305
|
+
obsolete_mkdir_used=false
|
306
|
+
|
307
|
+
if test $dstdir_status != 0; then
|
308
|
+
case $posix_mkdir in
|
309
|
+
'')
|
310
|
+
# Create intermediate dirs using mode 755 as modified by the umask.
|
311
|
+
# This is like FreeBSD 'install' as of 1997-10-28.
|
312
|
+
umask=`umask`
|
313
|
+
case $stripcmd.$umask in
|
314
|
+
# Optimize common cases.
|
315
|
+
*[2367][2367]) mkdir_umask=$umask;;
|
316
|
+
.*0[02][02] | .[02][02] | .[02]) mkdir_umask=22;;
|
317
|
+
|
318
|
+
*[0-7])
|
319
|
+
mkdir_umask=`expr $umask + 22 \
|
320
|
+
- $umask % 100 % 40 + $umask % 20 \
|
321
|
+
- $umask % 10 % 4 + $umask % 2
|
322
|
+
`;;
|
323
|
+
*) mkdir_umask=$umask,go-w;;
|
324
|
+
esac
|
325
|
+
|
326
|
+
# With -d, create the new directory with the user-specified mode.
|
327
|
+
# Otherwise, rely on $mkdir_umask.
|
328
|
+
if test -n "$dir_arg"; then
|
329
|
+
mkdir_mode=-m$mode
|
330
|
+
else
|
331
|
+
mkdir_mode=
|
332
|
+
fi
|
333
|
+
|
334
|
+
posix_mkdir=false
|
335
|
+
case $umask in
|
336
|
+
*[123567][0-7][0-7])
|
337
|
+
# POSIX mkdir -p sets u+wx bits regardless of umask, which
|
338
|
+
# is incompatible with FreeBSD 'install' when (umask & 300) != 0.
|
339
|
+
;;
|
340
|
+
*)
|
341
|
+
tmpdir=${TMPDIR-/tmp}/ins$RANDOM-$$
|
342
|
+
trap 'ret=$?; rmdir "$tmpdir/d" "$tmpdir" 2>/dev/null; exit $ret' 0
|
343
|
+
|
344
|
+
if (umask $mkdir_umask &&
|
345
|
+
exec $mkdirprog $mkdir_mode -p -- "$tmpdir/d") >/dev/null 2>&1
|
346
|
+
then
|
347
|
+
if test -z "$dir_arg" || {
|
348
|
+
# Check for POSIX incompatibilities with -m.
|
349
|
+
# HP-UX 11.23 and IRIX 6.5 mkdir -m -p sets group- or
|
350
|
+
# other-writeable bit of parent directory when it shouldn't.
|
351
|
+
# FreeBSD 6.1 mkdir -m -p sets mode of existing directory.
|
352
|
+
ls_ld_tmpdir=`ls -ld "$tmpdir"`
|
353
|
+
case $ls_ld_tmpdir in
|
354
|
+
d????-?r-*) different_mode=700;;
|
355
|
+
d????-?--*) different_mode=755;;
|
356
|
+
*) false;;
|
357
|
+
esac &&
|
358
|
+
$mkdirprog -m$different_mode -p -- "$tmpdir" && {
|
359
|
+
ls_ld_tmpdir_1=`ls -ld "$tmpdir"`
|
360
|
+
test "$ls_ld_tmpdir" = "$ls_ld_tmpdir_1"
|
361
|
+
}
|
362
|
+
}
|
363
|
+
then posix_mkdir=:
|
364
|
+
fi
|
365
|
+
rmdir "$tmpdir/d" "$tmpdir"
|
366
|
+
else
|
367
|
+
# Remove any dirs left behind by ancient mkdir implementations.
|
368
|
+
rmdir ./$mkdir_mode ./-p ./-- 2>/dev/null
|
369
|
+
fi
|
370
|
+
trap '' 0;;
|
371
|
+
esac;;
|
372
|
+
esac
|
217
373
|
|
218
|
-
|
374
|
+
if
|
375
|
+
$posix_mkdir && (
|
376
|
+
umask $mkdir_umask &&
|
377
|
+
$doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir"
|
378
|
+
)
|
379
|
+
then :
|
380
|
+
else
|
219
381
|
|
220
|
-
|
221
|
-
|
222
|
-
|
223
|
-
'
|
224
|
-
IFS="${IFS-$defaultIFS}"
|
382
|
+
# The umask is ridiculous, or mkdir does not conform to POSIX,
|
383
|
+
# or it failed possibly due to a race condition. Create the
|
384
|
+
# directory the slow way, step by step, checking for races as we go.
|
225
385
|
|
226
|
-
|
227
|
-
|
228
|
-
|
229
|
-
|
230
|
-
|
231
|
-
IFS=$oIFS
|
386
|
+
case $dstdir in
|
387
|
+
/*) prefix='/';;
|
388
|
+
-*) prefix='./';;
|
389
|
+
*) prefix='';;
|
390
|
+
esac
|
232
391
|
|
233
|
-
|
392
|
+
eval "$initialize_posix_glob"
|
234
393
|
|
235
|
-
|
236
|
-
|
394
|
+
oIFS=$IFS
|
395
|
+
IFS=/
|
396
|
+
$posix_glob set -f
|
397
|
+
set fnord $dstdir
|
237
398
|
shift
|
238
|
-
|
239
|
-
|
240
|
-
|
241
|
-
|
242
|
-
|
243
|
-
|
399
|
+
$posix_glob set +f
|
400
|
+
IFS=$oIFS
|
401
|
+
|
402
|
+
prefixes=
|
403
|
+
|
404
|
+
for d
|
405
|
+
do
|
406
|
+
test -z "$d" && continue
|
407
|
+
|
408
|
+
prefix=$prefix$d
|
409
|
+
if test -d "$prefix"; then
|
410
|
+
prefixes=
|
411
|
+
else
|
412
|
+
if $posix_mkdir; then
|
413
|
+
(umask=$mkdir_umask &&
|
414
|
+
$doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir") && break
|
415
|
+
# Don't fail if two instances are running concurrently.
|
416
|
+
test -d "$prefix" || exit 1
|
417
|
+
else
|
418
|
+
case $prefix in
|
419
|
+
*\'*) qprefix=`echo "$prefix" | sed "s/'/'\\\\\\\\''/g"`;;
|
420
|
+
*) qprefix=$prefix;;
|
421
|
+
esac
|
422
|
+
prefixes="$prefixes '$qprefix'"
|
423
|
+
fi
|
424
|
+
fi
|
425
|
+
prefix=$prefix/
|
426
|
+
done
|
427
|
+
|
428
|
+
if test -n "$prefixes"; then
|
429
|
+
# Don't fail if two instances are running concurrently.
|
430
|
+
(umask $mkdir_umask &&
|
431
|
+
eval "\$doit_exec \$mkdirprog $prefixes") ||
|
432
|
+
test -d "$dstdir" || exit 1
|
433
|
+
obsolete_mkdir_used=true
|
244
434
|
fi
|
245
|
-
|
246
|
-
done
|
435
|
+
fi
|
247
436
|
fi
|
248
437
|
|
249
438
|
if test -n "$dir_arg"; then
|
250
|
-
$doit $
|
251
|
-
|
252
|
-
|
253
|
-
|
254
|
-
&& { test -z "$chmodcmd" || $doit $chmodcmd "$dst"; }
|
255
|
-
|
439
|
+
{ test -z "$chowncmd" || $doit $chowncmd "$dst"; } &&
|
440
|
+
{ test -z "$chgrpcmd" || $doit $chgrpcmd "$dst"; } &&
|
441
|
+
{ test "$obsolete_mkdir_used$chowncmd$chgrpcmd" = false ||
|
442
|
+
test -z "$chmodcmd" || $doit $chmodcmd $mode "$dst"; } || exit 1
|
256
443
|
else
|
257
|
-
dstfile=`basename "$dst"`
|
258
444
|
|
259
445
|
# Make a couple of temp file names in the proper directory.
|
260
446
|
dsttmp=$dstdir/_inst.$$_
|
@@ -262,10 +448,9 @@ do
|
|
262
448
|
|
263
449
|
# Trap to clean up those temp files at exit.
|
264
450
|
trap 'ret=$?; rm -f "$dsttmp" "$rmtmp" && exit $ret' 0
|
265
|
-
trap '(exit $?); exit' 1 2 13 15
|
266
451
|
|
267
452
|
# Copy the file name to the temp name.
|
268
|
-
$
|
453
|
+
(umask $cp_umask && $doit_exec $cpprog "$src" "$dsttmp") &&
|
269
454
|
|
270
455
|
# and set any options; do chmod last to preserve setuid bits.
|
271
456
|
#
|
@@ -273,51 +458,63 @@ do
|
|
273
458
|
# ignore errors from any of these, just make sure not to ignore
|
274
459
|
# errors from the above "$doit $cpprog $src $dsttmp" command.
|
275
460
|
#
|
276
|
-
{ test -z "$chowncmd" || $doit $chowncmd "$dsttmp"; }
|
277
|
-
|
278
|
-
|
279
|
-
|
280
|
-
|
281
|
-
#
|
282
|
-
|
283
|
-
|
284
|
-
|
285
|
-
|
286
|
-
|
287
|
-
|
288
|
-
|
289
|
-
|
290
|
-
|
291
|
-
|
292
|
-
|
293
|
-
|
294
|
-
|
295
|
-
|
296
|
-
|
297
|
-
|
298
|
-
|
299
|
-
|
300
|
-
|
301
|
-
|
302
|
-
|
303
|
-
|
304
|
-
|
305
|
-
|
306
|
-
|
307
|
-
|
308
|
-
|
309
|
-
|
310
|
-
|
461
|
+
{ test -z "$chowncmd" || $doit $chowncmd "$dsttmp"; } &&
|
462
|
+
{ test -z "$chgrpcmd" || $doit $chgrpcmd "$dsttmp"; } &&
|
463
|
+
{ test -z "$stripcmd" || $doit $stripcmd "$dsttmp"; } &&
|
464
|
+
{ test -z "$chmodcmd" || $doit $chmodcmd $mode "$dsttmp"; } &&
|
465
|
+
|
466
|
+
# If -C, don't bother to copy if it wouldn't change the file.
|
467
|
+
if $copy_on_change &&
|
468
|
+
old=`LC_ALL=C ls -dlL "$dst" 2>/dev/null` &&
|
469
|
+
new=`LC_ALL=C ls -dlL "$dsttmp" 2>/dev/null` &&
|
470
|
+
|
471
|
+
eval "$initialize_posix_glob" &&
|
472
|
+
$posix_glob set -f &&
|
473
|
+
set X $old && old=:$2:$4:$5:$6 &&
|
474
|
+
set X $new && new=:$2:$4:$5:$6 &&
|
475
|
+
$posix_glob set +f &&
|
476
|
+
|
477
|
+
test "$old" = "$new" &&
|
478
|
+
$cmpprog "$dst" "$dsttmp" >/dev/null 2>&1
|
479
|
+
then
|
480
|
+
rm -f "$dsttmp"
|
481
|
+
else
|
482
|
+
# Rename the file to the real destination.
|
483
|
+
$doit $mvcmd -f "$dsttmp" "$dst" 2>/dev/null ||
|
484
|
+
|
485
|
+
# The rename failed, perhaps because mv can't rename something else
|
486
|
+
# to itself, or perhaps because mv is so ancient that it does not
|
487
|
+
# support -f.
|
488
|
+
{
|
489
|
+
# Now remove or move aside any old file at destination location.
|
490
|
+
# We try this two ways since rm can't unlink itself on some
|
491
|
+
# systems and the destination file might be busy for other
|
492
|
+
# reasons. In this case, the final cleanup might fail but the new
|
493
|
+
# file should still install successfully.
|
494
|
+
{
|
495
|
+
test ! -f "$dst" ||
|
496
|
+
$doit $rmcmd -f "$dst" 2>/dev/null ||
|
497
|
+
{ $doit $mvcmd -f "$dst" "$rmtmp" 2>/dev/null &&
|
498
|
+
{ $doit $rmcmd -f "$rmtmp" 2>/dev/null; :; }
|
499
|
+
} ||
|
500
|
+
{ echo "$0: cannot unlink or rename $dst" >&2
|
501
|
+
(exit 1); exit 1
|
502
|
+
}
|
503
|
+
} &&
|
504
|
+
|
505
|
+
# Now rename the file to the real destination.
|
506
|
+
$doit $mvcmd "$dsttmp" "$dst"
|
507
|
+
}
|
508
|
+
fi || exit 1
|
509
|
+
|
510
|
+
trap '' 0
|
511
|
+
fi
|
311
512
|
done
|
312
513
|
|
313
|
-
# The final little trick to "correctly" pass the exit status to the exit trap.
|
314
|
-
{
|
315
|
-
(exit 0); exit 0
|
316
|
-
}
|
317
|
-
|
318
514
|
# Local variables:
|
319
515
|
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
320
516
|
# time-stamp-start: "scriptversion="
|
321
517
|
# time-stamp-format: "%:y-%02m-%02d.%02H"
|
322
|
-
# time-stamp-
|
518
|
+
# time-stamp-time-zone: "UTC"
|
519
|
+
# time-stamp-end: "; # UTC"
|
323
520
|
# End:
|