| @@ -1,370 +0,0 @@ | |||||
| Installation Instructions | |||||
| ************************* | |||||
| Copyright (C) 1994-1996, 1999-2002, 2004-2013 Free Software Foundation, | |||||
| Inc. | |||||
| Copying and distribution of this file, with or without modification, | |||||
| are permitted in any medium without royalty provided the copyright | |||||
| notice and this notice are preserved. This file is offered as-is, | |||||
| without warranty of any kind. | |||||
| Basic Installation | |||||
| ================== | |||||
| Briefly, the shell commands `./configure; make; make install' should | |||||
| configure, build, and install this package. The following | |||||
| more-detailed instructions are generic; see the `README' file for | |||||
| instructions specific to this package. Some packages provide this | |||||
| `INSTALL' file but do not implement all of the features documented | |||||
| below. The lack of an optional feature in a given package is not | |||||
| necessarily a bug. More recommendations for GNU packages can be found | |||||
| in *note Makefile Conventions: (standards)Makefile Conventions. | |||||
| The `configure' shell script attempts to guess correct values for | |||||
| various system-dependent variables used during compilation. It uses | |||||
| those values to create a `Makefile' in each directory of the package. | |||||
| It may also create one or more `.h' files containing system-dependent | |||||
| definitions. Finally, it creates a shell script `config.status' that | |||||
| you can run in the future to recreate the current configuration, and a | |||||
| file `config.log' containing compiler output (useful mainly for | |||||
| debugging `configure'). | |||||
| It can also use an optional file (typically called `config.cache' | |||||
| and enabled with `--cache-file=config.cache' or simply `-C') that saves | |||||
| the results of its tests to speed up reconfiguring. Caching is | |||||
| disabled by default to prevent problems with accidental use of stale | |||||
| cache files. | |||||
| If you need to do unusual things to compile the package, please try | |||||
| to figure out how `configure' could check whether to do them, and mail | |||||
| diffs or instructions to the address given in the `README' so they can | |||||
| be considered for the next release. If you are using the cache, and at | |||||
| some point `config.cache' contains results you don't want to keep, you | |||||
| may remove or edit it. | |||||
| The file `configure.ac' (or `configure.in') is used to create | |||||
| `configure' by a program called `autoconf'. You need `configure.ac' if | |||||
| you want to change it or regenerate `configure' using a newer version | |||||
| of `autoconf'. | |||||
| The simplest way to compile this package is: | |||||
| 1. `cd' to the directory containing the package's source code and type | |||||
| `./configure' to configure the package for your system. | |||||
| Running `configure' might take a while. While running, it prints | |||||
| some messages telling which features it is checking for. | |||||
| 2. Type `make' to compile the package. | |||||
| 3. Optionally, type `make check' to run any self-tests that come with | |||||
| the package, generally using the just-built uninstalled binaries. | |||||
| 4. Type `make install' to install the programs and any data files and | |||||
| documentation. When installing into a prefix owned by root, it is | |||||
| recommended that the package be configured and built as a regular | |||||
| user, and only the `make install' phase executed with root | |||||
| privileges. | |||||
| 5. Optionally, type `make installcheck' to repeat any self-tests, but | |||||
| this time using the binaries in their final installed location. | |||||
| This target does not install anything. Running this target as a | |||||
| regular user, particularly if the prior `make install' required | |||||
| root privileges, verifies that the installation completed | |||||
| correctly. | |||||
| 6. You can remove the program binaries and object files from the | |||||
| source code directory by typing `make clean'. To also remove the | |||||
| files that `configure' created (so you can compile the package for | |||||
| a different kind of computer), type `make distclean'. There is | |||||
| also a `make maintainer-clean' target, but that is intended mainly | |||||
| for the package's developers. If you use it, you may have to get | |||||
| all sorts of other programs in order to regenerate files that came | |||||
| with the distribution. | |||||
| 7. Often, you can also type `make uninstall' to remove the installed | |||||
| files again. In practice, not all packages have tested that | |||||
| uninstallation works correctly, even though it is required by the | |||||
| GNU Coding Standards. | |||||
| 8. Some packages, particularly those that use Automake, provide `make | |||||
| distcheck', which can by used by developers to test that all other | |||||
| targets like `make install' and `make uninstall' work correctly. | |||||
| This target is generally not run by end users. | |||||
| Compilers and Options | |||||
| ===================== | |||||
| Some systems require unusual options for compilation or linking that | |||||
| the `configure' script does not know about. Run `./configure --help' | |||||
| for details on some of the pertinent environment variables. | |||||
| You can give `configure' initial values for configuration parameters | |||||
| by setting variables in the command line or in the environment. Here | |||||
| is an example: | |||||
| ./configure CC=c99 CFLAGS=-g LIBS=-lposix | |||||
| *Note Defining Variables::, for more details. | |||||
| Compiling For Multiple Architectures | |||||
| ==================================== | |||||
| You can compile the package for more than one kind of computer at the | |||||
| same time, by placing the object files for each architecture in their | |||||
| own directory. To do this, you can use GNU `make'. `cd' to the | |||||
| directory where you want the object files and executables to go and run | |||||
| the `configure' script. `configure' automatically checks for the | |||||
| source code in the directory that `configure' is in and in `..'. This | |||||
| is known as a "VPATH" build. | |||||
| With a non-GNU `make', it is safer to compile the package for one | |||||
| architecture at a time in the source code directory. After you have | |||||
| installed the package for one architecture, use `make distclean' before | |||||
| reconfiguring for another architecture. | |||||
| On MacOS X 10.5 and later systems, you can create libraries and | |||||
| executables that work on multiple system types--known as "fat" or | |||||
| "universal" binaries--by specifying multiple `-arch' options to the | |||||
| compiler but only a single `-arch' option to the preprocessor. Like | |||||
| this: | |||||
| ./configure CC="gcc -arch i386 -arch x86_64 -arch ppc -arch ppc64" \ | |||||
| CXX="g++ -arch i386 -arch x86_64 -arch ppc -arch ppc64" \ | |||||
| CPP="gcc -E" CXXCPP="g++ -E" | |||||
| This is not guaranteed to produce working output in all cases, you | |||||
| may have to build one architecture at a time and combine the results | |||||
| using the `lipo' tool if you have problems. | |||||
| Installation Names | |||||
| ================== | |||||
| By default, `make install' installs the package's commands under | |||||
| `/usr/local/bin', include files under `/usr/local/include', etc. You | |||||
| can specify an installation prefix other than `/usr/local' by giving | |||||
| `configure' the option `--prefix=PREFIX', where PREFIX must be an | |||||
| absolute file name. | |||||
| You can specify separate installation prefixes for | |||||
| architecture-specific files and architecture-independent files. If you | |||||
| pass the option `--exec-prefix=PREFIX' to `configure', the package uses | |||||
| PREFIX as the prefix for installing programs and libraries. | |||||
| Documentation and other data files still use the regular prefix. | |||||
| In addition, if you use an unusual directory layout you can give | |||||
| options like `--bindir=DIR' to specify different values for particular | |||||
| kinds of files. Run `configure --help' for a list of the directories | |||||
| you can set and what kinds of files go in them. In general, the | |||||
| default for these options is expressed in terms of `${prefix}', so that | |||||
| specifying just `--prefix' will affect all of the other directory | |||||
| specifications that were not explicitly provided. | |||||
| The most portable way to affect installation locations is to pass the | |||||
| correct locations to `configure'; however, many packages provide one or | |||||
| both of the following shortcuts of passing variable assignments to the | |||||
| `make install' command line to change installation locations without | |||||
| having to reconfigure or recompile. | |||||
| The first method involves providing an override variable for each | |||||
| affected directory. For example, `make install | |||||
| prefix=/alternate/directory' will choose an alternate location for all | |||||
| directory configuration variables that were expressed in terms of | |||||
| `${prefix}'. Any directories that were specified during `configure', | |||||
| but not in terms of `${prefix}', must each be overridden at install | |||||
| time for the entire installation to be relocated. The approach of | |||||
| makefile variable overrides for each directory variable is required by | |||||
| the GNU Coding Standards, and ideally causes no recompilation. | |||||
| However, some platforms have known limitations with the semantics of | |||||
| shared libraries that end up requiring recompilation when using this | |||||
| method, particularly noticeable in packages that use GNU Libtool. | |||||
| The second method involves providing the `DESTDIR' variable. For | |||||
| example, `make install DESTDIR=/alternate/directory' will prepend | |||||
| `/alternate/directory' before all installation names. The approach of | |||||
| `DESTDIR' overrides is not required by the GNU Coding Standards, and | |||||
| does not work on platforms that have drive letters. On the other hand, | |||||
| it does better at avoiding recompilation issues, and works well even | |||||
| when some directory options were not specified in terms of `${prefix}' | |||||
| at `configure' time. | |||||
| Optional Features | |||||
| ================= | |||||
| If the package supports it, you can cause programs to be installed | |||||
| with an extra prefix or suffix on their names by giving `configure' the | |||||
| option `--program-prefix=PREFIX' or `--program-suffix=SUFFIX'. | |||||
| Some packages pay attention to `--enable-FEATURE' options to | |||||
| `configure', where FEATURE indicates an optional part of the package. | |||||
| They may also pay attention to `--with-PACKAGE' options, where PACKAGE | |||||
| is something like `gnu-as' or `x' (for the X Window System). The | |||||
| `README' should mention any `--enable-' and `--with-' options that the | |||||
| package recognizes. | |||||
| For packages that use the X Window System, `configure' can usually | |||||
| find the X include and library files automatically, but if it doesn't, | |||||
| you can use the `configure' options `--x-includes=DIR' and | |||||
| `--x-libraries=DIR' to specify their locations. | |||||
| Some packages offer the ability to configure how verbose the | |||||
| execution of `make' will be. For these packages, running `./configure | |||||
| --enable-silent-rules' sets the default to minimal output, which can be | |||||
| overridden with `make V=1'; while running `./configure | |||||
| --disable-silent-rules' sets the default to verbose, which can be | |||||
| overridden with `make V=0'. | |||||
| Particular systems | |||||
| ================== | |||||
| On HP-UX, the default C compiler is not ANSI C compatible. If GNU | |||||
| CC is not installed, it is recommended to use the following options in | |||||
| order to use an ANSI C compiler: | |||||
| ./configure CC="cc -Ae -D_XOPEN_SOURCE=500" | |||||
| and if that doesn't work, install pre-built binaries of GCC for HP-UX. | |||||
| HP-UX `make' updates targets which have the same time stamps as | |||||
| their prerequisites, which makes it generally unusable when shipped | |||||
| generated files such as `configure' are involved. Use GNU `make' | |||||
| instead. | |||||
| On OSF/1 a.k.a. Tru64, some versions of the default C compiler cannot | |||||
| parse its `<wchar.h>' header file. The option `-nodtk' can be used as | |||||
| a workaround. If GNU CC is not installed, it is therefore recommended | |||||
| to try | |||||
| ./configure CC="cc" | |||||
| and if that doesn't work, try | |||||
| ./configure CC="cc -nodtk" | |||||
| On Solaris, don't put `/usr/ucb' early in your `PATH'. This | |||||
| directory contains several dysfunctional programs; working variants of | |||||
| these programs are available in `/usr/bin'. So, if you need `/usr/ucb' | |||||
| in your `PATH', put it _after_ `/usr/bin'. | |||||
| On Haiku, software installed for all users goes in `/boot/common', | |||||
| not `/usr/local'. It is recommended to use the following options: | |||||
| ./configure --prefix=/boot/common | |||||
| Specifying the System Type | |||||
| ========================== | |||||
| There may be some features `configure' cannot figure out | |||||
| automatically, but needs to determine by the type of machine the package | |||||
| will run on. Usually, assuming the package is built to be run on the | |||||
| _same_ architectures, `configure' can figure that out, but if it prints | |||||
| a message saying it cannot guess the machine type, give it the | |||||
| `--build=TYPE' option. TYPE can either be a short name for the system | |||||
| type, such as `sun4', or a canonical name which has the form: | |||||
| CPU-COMPANY-SYSTEM | |||||
| where SYSTEM can have one of these forms: | |||||
| OS | |||||
| KERNEL-OS | |||||
| See the file `config.sub' for the possible values of each field. If | |||||
| `config.sub' isn't included in this package, then this package doesn't | |||||
| need to know the machine type. | |||||
| If you are _building_ compiler tools for cross-compiling, you should | |||||
| use the option `--target=TYPE' to select the type of system they will | |||||
| produce code for. | |||||
| If you want to _use_ a cross compiler, that generates code for a | |||||
| platform different from the build platform, you should specify the | |||||
| "host" platform (i.e., that on which the generated programs will | |||||
| eventually be run) with `--host=TYPE'. | |||||
| Sharing Defaults | |||||
| ================ | |||||
| If you want to set default values for `configure' scripts to share, | |||||
| you can create a site shell script called `config.site' that gives | |||||
| default values for variables like `CC', `cache_file', and `prefix'. | |||||
| `configure' looks for `PREFIX/share/config.site' if it exists, then | |||||
| `PREFIX/etc/config.site' if it exists. Or, you can set the | |||||
| `CONFIG_SITE' environment variable to the location of the site script. | |||||
| A warning: not all `configure' scripts look for a site script. | |||||
| Defining Variables | |||||
| ================== | |||||
| Variables not defined in a site shell script can be set in the | |||||
| environment passed to `configure'. However, some packages may run | |||||
| configure again during the build, and the customized values of these | |||||
| variables may be lost. In order to avoid this problem, you should set | |||||
| them in the `configure' command line, using `VAR=value'. For example: | |||||
| ./configure CC=/usr/local2/bin/gcc | |||||
| causes the specified `gcc' to be used as the C compiler (unless it is | |||||
| overridden in the site shell script). | |||||
| Unfortunately, this technique does not work for `CONFIG_SHELL' due to | |||||
| an Autoconf limitation. Until the limitation is lifted, you can use | |||||
| this workaround: | |||||
| CONFIG_SHELL=/bin/bash ./configure CONFIG_SHELL=/bin/bash | |||||
| `configure' Invocation | |||||
| ====================== | |||||
| `configure' recognizes the following options to control how it | |||||
| operates. | |||||
| `--help' | |||||
| `-h' | |||||
| Print a summary of all of the options to `configure', and exit. | |||||
| `--help=short' | |||||
| `--help=recursive' | |||||
| Print a summary of the options unique to this package's | |||||
| `configure', and exit. The `short' variant lists options used | |||||
| only in the top level, while the `recursive' variant lists options | |||||
| also present in any nested packages. | |||||
| `--version' | |||||
| `-V' | |||||
| Print the version of Autoconf used to generate the `configure' | |||||
| script, and exit. | |||||
| `--cache-file=FILE' | |||||
| Enable the cache: use and save the results of the tests in FILE, | |||||
| traditionally `config.cache'. FILE defaults to `/dev/null' to | |||||
| disable caching. | |||||
| `--config-cache' | |||||
| `-C' | |||||
| Alias for `--cache-file=config.cache'. | |||||
| `--quiet' | |||||
| `--silent' | |||||
| `-q' | |||||
| Do not print messages saying which checks are being made. To | |||||
| suppress all normal output, redirect it to `/dev/null' (any error | |||||
| messages will still be shown). | |||||
| `--srcdir=DIR' | |||||
| Look for the package's source code in directory DIR. Usually | |||||
| `configure' can determine that directory automatically. | |||||
| `--prefix=DIR' | |||||
| Use DIR as the installation prefix. *note Installation Names:: | |||||
| for more details, including other options available for fine-tuning | |||||
| the installation locations. | |||||
| `--no-create' | |||||
| `-n' | |||||
| Run the configure checks, but stop before creating any output | |||||
| files. | |||||
| `configure' also accepts some other, not widely useful, options. Run | |||||
| `configure --help' for more details. | |||||
| @@ -0,0 +1,72 @@ | |||||
| ANDROID_NDK_DIR=/opt/elear-solutions | |||||
| LIBICONV_INSTALL_DIR=/opt/elear-solutions/android | |||||
| declare -a COMPILE_ARCHITECTURES=("armv7" "arm64" "x86" "x86_64") | |||||
| SAVED_PATH="${PATH}" | |||||
| for ARCH in "${COMPILE_ARCHITECTURES[@]}" | |||||
| do | |||||
| make distclean | |||||
| autoreconf -i | |||||
| COMPILER_DIR="" | |||||
| COMPILER_PREFIX="" | |||||
| case ${ARCH} in | |||||
| "armv7" ) | |||||
| COMPILER_DIR=toolchain_armeabi_v7a_19 | |||||
| ;; | |||||
| "arm64" ) | |||||
| COMPILER_DIR=toolchain_aarch64_v8a_21 | |||||
| ;; | |||||
| "x86" ) | |||||
| COMPILER_DIR=toolchain_x86_19 | |||||
| ;; | |||||
| "x86_64" ) | |||||
| COMPILER_DIR=toolchain_x86_64_21 | |||||
| ;; | |||||
| esac | |||||
| export ANDROID_NDK_ROOT="${ANDROID_NDK_DIR}/${COMPILER_DIR}" | |||||
| ANDROID_NDK_BIN="${ANDROID_NDK_ROOT}/bin" | |||||
| ANDROID_SYSROOT_DIR="${ANDROID_NDK_ROOT}/sysroot" | |||||
| export PATH="${ANDROID_NDK_BIN}:${SAVED_PATH}" | |||||
| export CFLAGS="--sysroot=${ANDROID_SYSROOT_DIR}" | |||||
| export CXXFLAGS="--sysroot=${ANDROID_SYSROOT_DIR}" | |||||
| case ${ARCH} in | |||||
| "armv7" ) | |||||
| ABI_NAME=armv7 | |||||
| COMPILER_PREFIX=arm-linux-androideabi | |||||
| ;; | |||||
| "arm64" ) | |||||
| ABI_NAME=arm64 | |||||
| COMPILER_PREFIX=aarch64-linux-android | |||||
| ;; | |||||
| "x86" ) | |||||
| ABI_NAME=x86 | |||||
| COMPILER_PREFIX=i686-linux-android | |||||
| ;; | |||||
| "x86_64" ) | |||||
| ABI_NAME=x86_64 | |||||
| COMPILER_PREFIX=x86_64-linux-android | |||||
| ;; | |||||
| esac | |||||
| export CC=${ANDROID_NDK_BIN}/${COMPILER_PREFIX}-clang | |||||
| export CPP=${ANDROID_NDK_BIN}/${COMPILER_PREFIX}-cpp | |||||
| export CXX=${ANDROID_NDK_BIN}/${COMPILER_PREFIX}-clang++ | |||||
| export LD=${ANDROID_NDK_BIN}/${COMPILER_PREFIX}-ld | |||||
| export AR=${ANDROID_NDK_BIN}/${COMPILER_PREFIX}-ar | |||||
| export RANLIB=${ANDROID_NDK_BIN}/${COMPILER_PREFIX}-ranlib | |||||
| export STRIP=${ANDROID_NDK_BIN}/${COMPILER_PREFIX}-strip | |||||
| echo "---- Compiling for ${ARCH}" | |||||
| ./configure --host="${COMPILER_PREFIX}" --prefix="${LIBICONV_INSTALL_DIR}/${ABI_NAME}" | |||||
| make clean | |||||
| make install | |||||
| done | |||||
| export PATH="${SAVED_PATH}" | |||||
| @@ -1,347 +0,0 @@ | |||||
| #! /bin/sh | |||||
| # Wrapper for compilers which do not understand '-c -o'. | |||||
| scriptversion=2012-10-14.11; # UTC | |||||
| # Copyright (C) 1999-2013 Free Software Foundation, Inc. | |||||
| # Written by Tom Tromey <tromey@cygnus.com>. | |||||
| # | |||||
| # This program is free software; you can redistribute it and/or modify | |||||
| # it under the terms of the GNU General Public License as published by | |||||
| # the Free Software Foundation; either version 2, or (at your option) | |||||
| # any later version. | |||||
| # | |||||
| # This program is distributed in the hope that it will be useful, | |||||
| # but WITHOUT ANY WARRANTY; without even the implied warranty of | |||||
| # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |||||
| # GNU General Public License for more details. | |||||
| # | |||||
| # You should have received a copy of the GNU General Public License | |||||
| # along with this program. If not, see <http://www.gnu.org/licenses/>. | |||||
| # As a special exception to the GNU General Public License, if you | |||||
| # distribute this file as part of a program that contains a | |||||
| # configuration script generated by Autoconf, you may include it under | |||||
| # the same distribution terms that you use for the rest of that program. | |||||
| # This file is maintained in Automake, please report | |||||
| # bugs to <bug-automake@gnu.org> or send patches to | |||||
| # <automake-patches@gnu.org>. | |||||
| nl=' | |||||
| ' | |||||
| # We need space, tab and new line, in precisely that order. Quoting is | |||||
| # there to prevent tools from complaining about whitespace usage. | |||||
| IFS=" "" $nl" | |||||
| file_conv= | |||||
| # func_file_conv build_file lazy | |||||
| # Convert a $build file to $host form and store it in $file | |||||
| # Currently only supports Windows hosts. If the determined conversion | |||||
| # type is listed in (the comma separated) LAZY, no conversion will | |||||
| # take place. | |||||
| func_file_conv () | |||||
| { | |||||
| file=$1 | |||||
| case $file in | |||||
| / | /[!/]*) # absolute file, and not a UNC file | |||||
| if test -z "$file_conv"; then | |||||
| # lazily determine how to convert abs files | |||||
| case `uname -s` in | |||||
| MINGW*) | |||||
| file_conv=mingw | |||||
| ;; | |||||
| CYGWIN*) | |||||
| file_conv=cygwin | |||||
| ;; | |||||
| *) | |||||
| file_conv=wine | |||||
| ;; | |||||
| esac | |||||
| fi | |||||
| case $file_conv/,$2, in | |||||
| *,$file_conv,*) | |||||
| ;; | |||||
| mingw/*) | |||||
| file=`cmd //C echo "$file " | sed -e 's/"\(.*\) " *$/\1/'` | |||||
| ;; | |||||
| cygwin/*) | |||||
| file=`cygpath -m "$file" || echo "$file"` | |||||
| ;; | |||||
| wine/*) | |||||
| file=`winepath -w "$file" || echo "$file"` | |||||
| ;; | |||||
| esac | |||||
| ;; | |||||
| esac | |||||
| } | |||||
| # func_cl_dashL linkdir | |||||
| # Make cl look for libraries in LINKDIR | |||||
| func_cl_dashL () | |||||
| { | |||||
| func_file_conv "$1" | |||||
| if test -z "$lib_path"; then | |||||
| lib_path=$file | |||||
| else | |||||
| lib_path="$lib_path;$file" | |||||
| fi | |||||
| linker_opts="$linker_opts -LIBPATH:$file" | |||||
| } | |||||
| # func_cl_dashl library | |||||
| # Do a library search-path lookup for cl | |||||
| func_cl_dashl () | |||||
| { | |||||
| lib=$1 | |||||
| found=no | |||||
| save_IFS=$IFS | |||||
| IFS=';' | |||||
| for dir in $lib_path $LIB | |||||
| do | |||||
| IFS=$save_IFS | |||||
| if $shared && test -f "$dir/$lib.dll.lib"; then | |||||
| found=yes | |||||
| lib=$dir/$lib.dll.lib | |||||
| break | |||||
| fi | |||||
| if test -f "$dir/$lib.lib"; then | |||||
| found=yes | |||||
| lib=$dir/$lib.lib | |||||
| break | |||||
| fi | |||||
| if test -f "$dir/lib$lib.a"; then | |||||
| found=yes | |||||
| lib=$dir/lib$lib.a | |||||
| break | |||||
| fi | |||||
| done | |||||
| IFS=$save_IFS | |||||
| if test "$found" != yes; then | |||||
| lib=$lib.lib | |||||
| fi | |||||
| } | |||||
| # func_cl_wrapper cl arg... | |||||
| # Adjust compile command to suit cl | |||||
| func_cl_wrapper () | |||||
| { | |||||
| # Assume a capable shell | |||||
| lib_path= | |||||
| shared=: | |||||
| linker_opts= | |||||
| for arg | |||||
| do | |||||
| if test -n "$eat"; then | |||||
| eat= | |||||
| else | |||||
| case $1 in | |||||
| -o) | |||||
| # configure might choose to run compile as 'compile cc -o foo foo.c'. | |||||
| eat=1 | |||||
| case $2 in | |||||
| *.o | *.[oO][bB][jJ]) | |||||
| func_file_conv "$2" | |||||
| set x "$@" -Fo"$file" | |||||
| shift | |||||
| ;; | |||||
| *) | |||||
| func_file_conv "$2" | |||||
| set x "$@" -Fe"$file" | |||||
| shift | |||||
| ;; | |||||
| esac | |||||
| ;; | |||||
| -I) | |||||
| eat=1 | |||||
| func_file_conv "$2" mingw | |||||
| set x "$@" -I"$file" | |||||
| shift | |||||
| ;; | |||||
| -I*) | |||||
| func_file_conv "${1#-I}" mingw | |||||
| set x "$@" -I"$file" | |||||
| shift | |||||
| ;; | |||||
| -l) | |||||
| eat=1 | |||||
| func_cl_dashl "$2" | |||||
| set x "$@" "$lib" | |||||
| shift | |||||
| ;; | |||||
| -l*) | |||||
| func_cl_dashl "${1#-l}" | |||||
| set x "$@" "$lib" | |||||
| shift | |||||
| ;; | |||||
| -L) | |||||
| eat=1 | |||||
| func_cl_dashL "$2" | |||||
| ;; | |||||
| -L*) | |||||
| func_cl_dashL "${1#-L}" | |||||
| ;; | |||||
| -static) | |||||
| shared=false | |||||
| ;; | |||||
| -Wl,*) | |||||
| arg=${1#-Wl,} | |||||
| save_ifs="$IFS"; IFS=',' | |||||
| for flag in $arg; do | |||||
| IFS="$save_ifs" | |||||
| linker_opts="$linker_opts $flag" | |||||
| done | |||||
| IFS="$save_ifs" | |||||
| ;; | |||||
| -Xlinker) | |||||
| eat=1 | |||||
| linker_opts="$linker_opts $2" | |||||
| ;; | |||||
| -*) | |||||
| set x "$@" "$1" | |||||
| shift | |||||
| ;; | |||||
| *.cc | *.CC | *.cxx | *.CXX | *.[cC]++) | |||||
| func_file_conv "$1" | |||||
| set x "$@" -Tp"$file" | |||||
| shift | |||||
| ;; | |||||
| *.c | *.cpp | *.CPP | *.lib | *.LIB | *.Lib | *.OBJ | *.obj | *.[oO]) | |||||
| func_file_conv "$1" mingw | |||||
| set x "$@" "$file" | |||||
| shift | |||||
| ;; | |||||
| *) | |||||
| set x "$@" "$1" | |||||
| shift | |||||
| ;; | |||||
| esac | |||||
| fi | |||||
| shift | |||||
| done | |||||
| if test -n "$linker_opts"; then | |||||
| linker_opts="-link$linker_opts" | |||||
| fi | |||||
| exec "$@" $linker_opts | |||||
| exit 1 | |||||
| } | |||||
| eat= | |||||
| case $1 in | |||||
| '') | |||||
| echo "$0: No command. Try '$0 --help' for more information." 1>&2 | |||||
| exit 1; | |||||
| ;; | |||||
| -h | --h*) | |||||
| cat <<\EOF | |||||
| Usage: compile [--help] [--version] PROGRAM [ARGS] | |||||
| Wrapper for compilers which do not understand '-c -o'. | |||||
| Remove '-o dest.o' from ARGS, run PROGRAM with the remaining | |||||
| arguments, and rename the output as expected. | |||||
| If you are trying to build a whole package this is not the | |||||
| right script to run: please start by reading the file 'INSTALL'. | |||||
| Report bugs to <bug-automake@gnu.org>. | |||||
| EOF | |||||
| exit $? | |||||
| ;; | |||||
| -v | --v*) | |||||
| echo "compile $scriptversion" | |||||
| exit $? | |||||
| ;; | |||||
| cl | *[/\\]cl | cl.exe | *[/\\]cl.exe ) | |||||
| func_cl_wrapper "$@" # Doesn't return... | |||||
| ;; | |||||
| esac | |||||
| ofile= | |||||
| cfile= | |||||
| for arg | |||||
| do | |||||
| if test -n "$eat"; then | |||||
| eat= | |||||
| else | |||||
| case $1 in | |||||
| -o) | |||||
| # configure might choose to run compile as 'compile cc -o foo foo.c'. | |||||
| # So we strip '-o arg' only if arg is an object. | |||||
| eat=1 | |||||
| case $2 in | |||||
| *.o | *.obj) | |||||
| ofile=$2 | |||||
| ;; | |||||
| *) | |||||
| set x "$@" -o "$2" | |||||
| shift | |||||
| ;; | |||||
| esac | |||||
| ;; | |||||
| *.c) | |||||
| cfile=$1 | |||||
| set x "$@" "$1" | |||||
| shift | |||||
| ;; | |||||
| *) | |||||
| set x "$@" "$1" | |||||
| shift | |||||
| ;; | |||||
| esac | |||||
| fi | |||||
| shift | |||||
| done | |||||
| if test -z "$ofile" || test -z "$cfile"; then | |||||
| # If no '-o' option was seen then we might have been invoked from a | |||||
| # pattern rule where we don't need one. That is ok -- this is a | |||||
| # normal compilation that the losing compiler can handle. If no | |||||
| # '.c' file was seen then we are probably linking. That is also | |||||
| # ok. | |||||
| exec "$@" | |||||
| fi | |||||
| # Name of file we expect compiler to create. | |||||
| cofile=`echo "$cfile" | sed 's|^.*[\\/]||; s|^[a-zA-Z]:||; s/\.c$/.o/'` | |||||
| # Create the lock directory. | |||||
| # Note: use '[/\\:.-]' here to ensure that we don't use the same name | |||||
| # that we are using for the .o file. Also, base the name on the expected | |||||
| # object file name, since that is what matters with a parallel build. | |||||
| lockdir=`echo "$cofile" | sed -e 's|[/\\:.-]|_|g'`.d | |||||
| while true; do | |||||
| if mkdir "$lockdir" >/dev/null 2>&1; then | |||||
| break | |||||
| fi | |||||
| sleep 1 | |||||
| done | |||||
| # FIXME: race condition here if user kills between mkdir and trap. | |||||
| trap "rmdir '$lockdir'; exit 1" 1 2 15 | |||||
| # Run the compile. | |||||
| "$@" | |||||
| ret=$? | |||||
| if test -f "$cofile"; then | |||||
| test "$cofile" = "$ofile" || mv "$cofile" "$ofile" | |||||
| elif test -f "${cofile}bj"; then | |||||
| test "${cofile}bj" = "$ofile" || mv "${cofile}bj" "$ofile" | |||||
| fi | |||||
| rmdir "$lockdir" | |||||
| exit $ret | |||||
| # Local Variables: | |||||
| # mode: shell-script | |||||
| # sh-indentation: 2 | |||||
| # eval: (add-hook 'write-file-hooks 'time-stamp) | |||||
| # time-stamp-start: "scriptversion=" | |||||
| # time-stamp-format: "%:y-%02m-%02d.%02H" | |||||
| # time-stamp-time-zone: "UTC" | |||||
| # time-stamp-end: "; # UTC" | |||||
| # End: | |||||
| @@ -1,791 +0,0 @@ | |||||
| #! /bin/sh | |||||
| # depcomp - compile a program generating dependencies as side-effects | |||||
| scriptversion=2013-05-30.07; # UTC | |||||
| # Copyright (C) 1999-2013 Free Software Foundation, Inc. | |||||
| # This program is free software; you can redistribute it and/or modify | |||||
| # it under the terms of the GNU General Public License as published by | |||||
| # the Free Software Foundation; either version 2, or (at your option) | |||||
| # any later version. | |||||
| # This program is distributed in the hope that it will be useful, | |||||
| # but WITHOUT ANY WARRANTY; without even the implied warranty of | |||||
| # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |||||
| # GNU General Public License for more details. | |||||
| # You should have received a copy of the GNU General Public License | |||||
| # along with this program. If not, see <http://www.gnu.org/licenses/>. | |||||
| # As a special exception to the GNU General Public License, if you | |||||
| # distribute this file as part of a program that contains a | |||||
| # configuration script generated by Autoconf, you may include it under | |||||
| # the same distribution terms that you use for the rest of that program. | |||||
| # Originally written by Alexandre Oliva <oliva@dcc.unicamp.br>. | |||||
| case $1 in | |||||
| '') | |||||
| echo "$0: No command. Try '$0 --help' for more information." 1>&2 | |||||
| exit 1; | |||||
| ;; | |||||
| -h | --h*) | |||||
| cat <<\EOF | |||||
| Usage: depcomp [--help] [--version] PROGRAM [ARGS] | |||||
| Run PROGRAMS ARGS to compile a file, generating dependencies | |||||
| as side-effects. | |||||
| Environment variables: | |||||
| depmode Dependency tracking mode. | |||||
| source Source file read by 'PROGRAMS ARGS'. | |||||
| object Object file output by 'PROGRAMS ARGS'. | |||||
| DEPDIR directory where to store dependencies. | |||||
| depfile Dependency file to output. | |||||
| tmpdepfile Temporary file to use when outputting dependencies. | |||||
| libtool Whether libtool is used (yes/no). | |||||
| Report bugs to <bug-automake@gnu.org>. | |||||
| EOF | |||||
| exit $? | |||||
| ;; | |||||
| -v | --v*) | |||||
| echo "depcomp $scriptversion" | |||||
| exit $? | |||||
| ;; | |||||
| esac | |||||
| # Get the directory component of the given path, and save it in the | |||||
| # global variables '$dir'. Note that this directory component will | |||||
| # be either empty or ending with a '/' character. This is deliberate. | |||||
| set_dir_from () | |||||
| { | |||||
| case $1 in | |||||
| */*) dir=`echo "$1" | sed -e 's|/[^/]*$|/|'`;; | |||||
| *) dir=;; | |||||
| esac | |||||
| } | |||||
| # Get the suffix-stripped basename of the given path, and save it the | |||||
| # global variable '$base'. | |||||
| set_base_from () | |||||
| { | |||||
| base=`echo "$1" | sed -e 's|^.*/||' -e 's/\.[^.]*$//'` | |||||
| } | |||||
| # If no dependency file was actually created by the compiler invocation, | |||||
| # we still have to create a dummy depfile, to avoid errors with the | |||||
| # Makefile "include basename.Plo" scheme. | |||||
| make_dummy_depfile () | |||||
| { | |||||
| echo "#dummy" > "$depfile" | |||||
| } | |||||
| # Factor out some common post-processing of the generated depfile. | |||||
| # Requires the auxiliary global variable '$tmpdepfile' to be set. | |||||
| aix_post_process_depfile () | |||||
| { | |||||
| # If the compiler actually managed to produce a dependency file, | |||||
| # post-process it. | |||||
| if test -f "$tmpdepfile"; then | |||||
| # Each line is of the form 'foo.o: dependency.h'. | |||||
| # Do two passes, one to just change these to | |||||
| # $object: dependency.h | |||||
| # and one to simply output | |||||
| # dependency.h: | |||||
| # which is needed to avoid the deleted-header problem. | |||||
| { sed -e "s,^.*\.[$lower]*:,$object:," < "$tmpdepfile" | |||||
| sed -e "s,^.*\.[$lower]*:[$tab ]*,," -e 's,$,:,' < "$tmpdepfile" | |||||
| } > "$depfile" | |||||
| rm -f "$tmpdepfile" | |||||
| else | |||||
| make_dummy_depfile | |||||
| fi | |||||
| } | |||||
| # A tabulation character. | |||||
| tab=' ' | |||||
| # A newline character. | |||||
| nl=' | |||||
| ' | |||||
| # Character ranges might be problematic outside the C locale. | |||||
| # These definitions help. | |||||
| upper=ABCDEFGHIJKLMNOPQRSTUVWXYZ | |||||
| lower=abcdefghijklmnopqrstuvwxyz | |||||
| digits=0123456789 | |||||
| alpha=${upper}${lower} | |||||
| if test -z "$depmode" || test -z "$source" || test -z "$object"; then | |||||
| echo "depcomp: Variables source, object and depmode must be set" 1>&2 | |||||
| exit 1 | |||||
| fi | |||||
| # Dependencies for sub/bar.o or sub/bar.obj go into sub/.deps/bar.Po. | |||||
| depfile=${depfile-`echo "$object" | | |||||
| sed 's|[^\\/]*$|'${DEPDIR-.deps}'/&|;s|\.\([^.]*\)$|.P\1|;s|Pobj$|Po|'`} | |||||
| tmpdepfile=${tmpdepfile-`echo "$depfile" | sed 's/\.\([^.]*\)$/.T\1/'`} | |||||
| rm -f "$tmpdepfile" | |||||
| # Avoid interferences from the environment. | |||||
| gccflag= dashmflag= | |||||
| # Some modes work just like other modes, but use different flags. We | |||||
| # parameterize here, but still list the modes in the big case below, | |||||
| # to make depend.m4 easier to write. Note that we *cannot* use a case | |||||
| # here, because this file can only contain one case statement. | |||||
| if test "$depmode" = hp; then | |||||
| # HP compiler uses -M and no extra arg. | |||||
| gccflag=-M | |||||
| depmode=gcc | |||||
| fi | |||||
| if test "$depmode" = dashXmstdout; then | |||||
| # This is just like dashmstdout with a different argument. | |||||
| dashmflag=-xM | |||||
| depmode=dashmstdout | |||||
| fi | |||||
| cygpath_u="cygpath -u -f -" | |||||
| if test "$depmode" = msvcmsys; then | |||||
| # This is just like msvisualcpp but w/o cygpath translation. | |||||
| # Just convert the backslash-escaped backslashes to single forward | |||||
| # slashes to satisfy depend.m4 | |||||
| cygpath_u='sed s,\\\\,/,g' | |||||
| depmode=msvisualcpp | |||||
| fi | |||||
| if test "$depmode" = msvc7msys; then | |||||
| # This is just like msvc7 but w/o cygpath translation. | |||||
| # Just convert the backslash-escaped backslashes to single forward | |||||
| # slashes to satisfy depend.m4 | |||||
| cygpath_u='sed s,\\\\,/,g' | |||||
| depmode=msvc7 | |||||
| fi | |||||
| if test "$depmode" = xlc; then | |||||
| # IBM C/C++ Compilers xlc/xlC can output gcc-like dependency information. | |||||
| gccflag=-qmakedep=gcc,-MF | |||||
| depmode=gcc | |||||
| fi | |||||
| case "$depmode" in | |||||
| gcc3) | |||||
| ## gcc 3 implements dependency tracking that does exactly what | |||||
| ## we want. Yay! Note: for some reason libtool 1.4 doesn't like | |||||
| ## it if -MD -MP comes after the -MF stuff. Hmm. | |||||
| ## Unfortunately, FreeBSD c89 acceptance of flags depends upon | |||||
| ## the command line argument order; so add the flags where they | |||||
| ## appear in depend2.am. Note that the slowdown incurred here | |||||
| ## affects only configure: in makefiles, %FASTDEP% shortcuts this. | |||||
| for arg | |||||
| do | |||||
| case $arg in | |||||
| -c) set fnord "$@" -MT "$object" -MD -MP -MF "$tmpdepfile" "$arg" ;; | |||||
| *) set fnord "$@" "$arg" ;; | |||||
| esac | |||||
| shift # fnord | |||||
| shift # $arg | |||||
| done | |||||
| "$@" | |||||
| stat=$? | |||||
| if test $stat -ne 0; then | |||||
| rm -f "$tmpdepfile" | |||||
| exit $stat | |||||
| fi | |||||
| mv "$tmpdepfile" "$depfile" | |||||
| ;; | |||||
| gcc) | |||||
| ## Note that this doesn't just cater to obsosete pre-3.x GCC compilers. | |||||
| ## but also to in-use compilers like IMB xlc/xlC and the HP C compiler. | |||||
| ## (see the conditional assignment to $gccflag above). | |||||
| ## There are various ways to get dependency output from gcc. Here's | |||||
| ## why we pick this rather obscure method: | |||||
| ## - Don't want to use -MD because we'd like the dependencies to end | |||||
| ## up in a subdir. Having to rename by hand is ugly. | |||||
| ## (We might end up doing this anyway to support other compilers.) | |||||
| ## - The DEPENDENCIES_OUTPUT environment variable makes gcc act like | |||||
| ## -MM, not -M (despite what the docs say). Also, it might not be | |||||
| ## supported by the other compilers which use the 'gcc' depmode. | |||||
| ## - Using -M directly means running the compiler twice (even worse | |||||
| ## than renaming). | |||||
| if test -z "$gccflag"; then | |||||
| gccflag=-MD, | |||||
| fi | |||||
| "$@" -Wp,"$gccflag$tmpdepfile" | |||||
| stat=$? | |||||
| if test $stat -ne 0; then | |||||
| rm -f "$tmpdepfile" | |||||
| exit $stat | |||||
| fi | |||||
| rm -f "$depfile" | |||||
| echo "$object : \\" > "$depfile" | |||||
| # The second -e expression handles DOS-style file names with drive | |||||
| # letters. | |||||
| sed -e 's/^[^:]*: / /' \ | |||||
| -e 's/^['$alpha']:\/[^:]*: / /' < "$tmpdepfile" >> "$depfile" | |||||
| ## This next piece of magic avoids the "deleted header file" problem. | |||||
| ## The problem is that when a header file which appears in a .P file | |||||
| ## is deleted, the dependency causes make to die (because there is | |||||
| ## typically no way to rebuild the header). We avoid this by adding | |||||
| ## dummy dependencies for each header file. Too bad gcc doesn't do | |||||
| ## this for us directly. | |||||
| ## Some versions of gcc put a space before the ':'. On the theory | |||||
| ## that the space means something, we add a space to the output as | |||||
| ## well. hp depmode also adds that space, but also prefixes the VPATH | |||||
| ## to the object. Take care to not repeat it in the output. | |||||
| ## Some versions of the HPUX 10.20 sed can't process this invocation | |||||
| ## correctly. Breaking it into two sed invocations is a workaround. | |||||
| tr ' ' "$nl" < "$tmpdepfile" \ | |||||
| | sed -e 's/^\\$//' -e '/^$/d' -e "s|.*$object$||" -e '/:$/d' \ | |||||
| | sed -e 's/$/ :/' >> "$depfile" | |||||
| rm -f "$tmpdepfile" | |||||
| ;; | |||||
| hp) | |||||
| # This case exists only to let depend.m4 do its work. It works by | |||||
| # looking at the text of this script. This case will never be run, | |||||
| # since it is checked for above. | |||||
| exit 1 | |||||
| ;; | |||||
| sgi) | |||||
| if test "$libtool" = yes; then | |||||
| "$@" "-Wp,-MDupdate,$tmpdepfile" | |||||
| else | |||||
| "$@" -MDupdate "$tmpdepfile" | |||||
| fi | |||||
| stat=$? | |||||
| if test $stat -ne 0; then | |||||
| rm -f "$tmpdepfile" | |||||
| exit $stat | |||||
| fi | |||||
| rm -f "$depfile" | |||||
| if test -f "$tmpdepfile"; then # yes, the sourcefile depend on other files | |||||
| echo "$object : \\" > "$depfile" | |||||
| # Clip off the initial element (the dependent). Don't try to be | |||||
| # clever and replace this with sed code, as IRIX sed won't handle | |||||
| # lines with more than a fixed number of characters (4096 in | |||||
| # IRIX 6.2 sed, 8192 in IRIX 6.5). We also remove comment lines; | |||||
| # the IRIX cc adds comments like '#:fec' to the end of the | |||||
| # dependency line. | |||||
| tr ' ' "$nl" < "$tmpdepfile" \ | |||||
| | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' \ | |||||
| | tr "$nl" ' ' >> "$depfile" | |||||
| echo >> "$depfile" | |||||
| # The second pass generates a dummy entry for each header file. | |||||
| tr ' ' "$nl" < "$tmpdepfile" \ | |||||
| | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' -e 's/$/:/' \ | |||||
| >> "$depfile" | |||||
| else | |||||
| make_dummy_depfile | |||||
| fi | |||||
| rm -f "$tmpdepfile" | |||||
| ;; | |||||
| xlc) | |||||
| # This case exists only to let depend.m4 do its work. It works by | |||||
| # looking at the text of this script. This case will never be run, | |||||
| # since it is checked for above. | |||||
| exit 1 | |||||
| ;; | |||||
| aix) | |||||
| # The C for AIX Compiler uses -M and outputs the dependencies | |||||
| # in a .u file. In older versions, this file always lives in the | |||||
| # current directory. Also, the AIX compiler puts '$object:' at the | |||||
| # start of each line; $object doesn't have directory information. | |||||
| # Version 6 uses the directory in both cases. | |||||
| set_dir_from "$object" | |||||
| set_base_from "$object" | |||||
| if test "$libtool" = yes; then | |||||
| tmpdepfile1=$dir$base.u | |||||
| tmpdepfile2=$base.u | |||||
| tmpdepfile3=$dir.libs/$base.u | |||||
| "$@" -Wc,-M | |||||
| else | |||||
| tmpdepfile1=$dir$base.u | |||||
| tmpdepfile2=$dir$base.u | |||||
| tmpdepfile3=$dir$base.u | |||||
| "$@" -M | |||||
| fi | |||||
| stat=$? | |||||
| if test $stat -ne 0; then | |||||
| rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" | |||||
| exit $stat | |||||
| fi | |||||
| for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" | |||||
| do | |||||
| test -f "$tmpdepfile" && break | |||||
| done | |||||
| aix_post_process_depfile | |||||
| ;; | |||||
| tcc) | |||||
| # tcc (Tiny C Compiler) understand '-MD -MF file' since version 0.9.26 | |||||
| # FIXME: That version still under development at the moment of writing. | |||||
| # Make that this statement remains true also for stable, released | |||||
| # versions. | |||||
| # It will wrap lines (doesn't matter whether long or short) with a | |||||
| # trailing '\', as in: | |||||
| # | |||||
| # foo.o : \ | |||||
| # foo.c \ | |||||
| # foo.h \ | |||||
| # | |||||
| # It will put a trailing '\' even on the last line, and will use leading | |||||
| # spaces rather than leading tabs (at least since its commit 0394caf7 | |||||
| # "Emit spaces for -MD"). | |||||
| "$@" -MD -MF "$tmpdepfile" | |||||
| stat=$? | |||||
| if test $stat -ne 0; then | |||||
| rm -f "$tmpdepfile" | |||||
| exit $stat | |||||
| fi | |||||
| rm -f "$depfile" | |||||
| # Each non-empty line is of the form 'foo.o : \' or ' dep.h \'. | |||||
| # We have to change lines of the first kind to '$object: \'. | |||||
| sed -e "s|.*:|$object :|" < "$tmpdepfile" > "$depfile" | |||||
| # And for each line of the second kind, we have to emit a 'dep.h:' | |||||
| # dummy dependency, to avoid the deleted-header problem. | |||||
| sed -n -e 's|^ *\(.*\) *\\$|\1:|p' < "$tmpdepfile" >> "$depfile" | |||||
| rm -f "$tmpdepfile" | |||||
| ;; | |||||
| ## The order of this option in the case statement is important, since the | |||||
| ## shell code in configure will try each of these formats in the order | |||||
| ## listed in this file. A plain '-MD' option would be understood by many | |||||
| ## compilers, so we must ensure this comes after the gcc and icc options. | |||||
| pgcc) | |||||
| # Portland's C compiler understands '-MD'. | |||||
| # Will always output deps to 'file.d' where file is the root name of the | |||||
| # source file under compilation, even if file resides in a subdirectory. | |||||
| # The object file name does not affect the name of the '.d' file. | |||||
| # pgcc 10.2 will output | |||||
| # foo.o: sub/foo.c sub/foo.h | |||||
| # and will wrap long lines using '\' : | |||||
| # foo.o: sub/foo.c ... \ | |||||
| # sub/foo.h ... \ | |||||
| # ... | |||||
| set_dir_from "$object" | |||||
| # Use the source, not the object, to determine the base name, since | |||||
| # that's sadly what pgcc will do too. | |||||
| set_base_from "$source" | |||||
| tmpdepfile=$base.d | |||||
| # For projects that build the same source file twice into different object | |||||
| # files, the pgcc approach of using the *source* file root name can cause | |||||
| # problems in parallel builds. Use a locking strategy to avoid stomping on | |||||
| # the same $tmpdepfile. | |||||
| lockdir=$base.d-lock | |||||
| trap " | |||||
| echo '$0: caught signal, cleaning up...' >&2 | |||||
| rmdir '$lockdir' | |||||
| exit 1 | |||||
| " 1 2 13 15 | |||||
| numtries=100 | |||||
| i=$numtries | |||||
| while test $i -gt 0; do | |||||
| # mkdir is a portable test-and-set. | |||||
| if mkdir "$lockdir" 2>/dev/null; then | |||||
| # This process acquired the lock. | |||||
| "$@" -MD | |||||
| stat=$? | |||||
| # Release the lock. | |||||
| rmdir "$lockdir" | |||||
| break | |||||
| else | |||||
| # If the lock is being held by a different process, wait | |||||
| # until the winning process is done or we timeout. | |||||
| while test -d "$lockdir" && test $i -gt 0; do | |||||
| sleep 1 | |||||
| i=`expr $i - 1` | |||||
| done | |||||
| fi | |||||
| i=`expr $i - 1` | |||||
| done | |||||
| trap - 1 2 13 15 | |||||
| if test $i -le 0; then | |||||
| echo "$0: failed to acquire lock after $numtries attempts" >&2 | |||||
| echo "$0: check lockdir '$lockdir'" >&2 | |||||
| exit 1 | |||||
| fi | |||||
| if test $stat -ne 0; then | |||||
| rm -f "$tmpdepfile" | |||||
| exit $stat | |||||
| fi | |||||
| rm -f "$depfile" | |||||
| # Each line is of the form `foo.o: dependent.h', | |||||
| # or `foo.o: dep1.h dep2.h \', or ` dep3.h dep4.h \'. | |||||
| # Do two passes, one to just change these to | |||||
| # `$object: dependent.h' and one to simply `dependent.h:'. | |||||
| sed "s,^[^:]*:,$object :," < "$tmpdepfile" > "$depfile" | |||||
| # Some versions of the HPUX 10.20 sed can't process this invocation | |||||
| # correctly. Breaking it into two sed invocations is a workaround. | |||||
| sed 's,^[^:]*: \(.*\)$,\1,;s/^\\$//;/^$/d;/:$/d' < "$tmpdepfile" \ | |||||
| | sed -e 's/$/ :/' >> "$depfile" | |||||
| rm -f "$tmpdepfile" | |||||
| ;; | |||||
| hp2) | |||||
| # The "hp" stanza above does not work with aCC (C++) and HP's ia64 | |||||
| # compilers, which have integrated preprocessors. The correct option | |||||
| # to use with these is +Maked; it writes dependencies to a file named | |||||
| # 'foo.d', which lands next to the object file, wherever that | |||||
| # happens to be. | |||||
| # Much of this is similar to the tru64 case; see comments there. | |||||
| set_dir_from "$object" | |||||
| set_base_from "$object" | |||||
| if test "$libtool" = yes; then | |||||
| tmpdepfile1=$dir$base.d | |||||
| tmpdepfile2=$dir.libs/$base.d | |||||
| "$@" -Wc,+Maked | |||||
| else | |||||
| tmpdepfile1=$dir$base.d | |||||
| tmpdepfile2=$dir$base.d | |||||
| "$@" +Maked | |||||
| fi | |||||
| stat=$? | |||||
| if test $stat -ne 0; then | |||||
| rm -f "$tmpdepfile1" "$tmpdepfile2" | |||||
| exit $stat | |||||
| fi | |||||
| for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" | |||||
| do | |||||
| test -f "$tmpdepfile" && break | |||||
| done | |||||
| if test -f "$tmpdepfile"; then | |||||
| sed -e "s,^.*\.[$lower]*:,$object:," "$tmpdepfile" > "$depfile" | |||||
| # Add 'dependent.h:' lines. | |||||
| sed -ne '2,${ | |||||
| s/^ *// | |||||
| s/ \\*$// | |||||
| s/$/:/ | |||||
| p | |||||
| }' "$tmpdepfile" >> "$depfile" | |||||
| else | |||||
| make_dummy_depfile | |||||
| fi | |||||
| rm -f "$tmpdepfile" "$tmpdepfile2" | |||||
| ;; | |||||
| tru64) | |||||
| # The Tru64 compiler uses -MD to generate dependencies as a side | |||||
| # effect. 'cc -MD -o foo.o ...' puts the dependencies into 'foo.o.d'. | |||||
| # At least on Alpha/Redhat 6.1, Compaq CCC V6.2-504 seems to put | |||||
| # dependencies in 'foo.d' instead, so we check for that too. | |||||
| # Subdirectories are respected. | |||||
| set_dir_from "$object" | |||||
| set_base_from "$object" | |||||
| if test "$libtool" = yes; then | |||||
| # Libtool generates 2 separate objects for the 2 libraries. These | |||||
| # two compilations output dependencies in $dir.libs/$base.o.d and | |||||
| # in $dir$base.o.d. We have to check for both files, because | |||||
| # one of the two compilations can be disabled. We should prefer | |||||
| # $dir$base.o.d over $dir.libs/$base.o.d because the latter is | |||||
| # automatically cleaned when .libs/ is deleted, while ignoring | |||||
| # the former would cause a distcleancheck panic. | |||||
| tmpdepfile1=$dir$base.o.d # libtool 1.5 | |||||
| tmpdepfile2=$dir.libs/$base.o.d # Likewise. | |||||
| tmpdepfile3=$dir.libs/$base.d # Compaq CCC V6.2-504 | |||||
| "$@" -Wc,-MD | |||||
| else | |||||
| tmpdepfile1=$dir$base.d | |||||
| tmpdepfile2=$dir$base.d | |||||
| tmpdepfile3=$dir$base.d | |||||
| "$@" -MD | |||||
| fi | |||||
| stat=$? | |||||
| if test $stat -ne 0; then | |||||
| rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" | |||||
| exit $stat | |||||
| fi | |||||
| for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" | |||||
| do | |||||
| test -f "$tmpdepfile" && break | |||||
| done | |||||
| # Same post-processing that is required for AIX mode. | |||||
| aix_post_process_depfile | |||||
| ;; | |||||
| msvc7) | |||||
| if test "$libtool" = yes; then | |||||
| showIncludes=-Wc,-showIncludes | |||||
| else | |||||
| showIncludes=-showIncludes | |||||
| fi | |||||
| "$@" $showIncludes > "$tmpdepfile" | |||||
| stat=$? | |||||
| grep -v '^Note: including file: ' "$tmpdepfile" | |||||
| if test $stat -ne 0; then | |||||
| rm -f "$tmpdepfile" | |||||
| exit $stat | |||||
| fi | |||||
| rm -f "$depfile" | |||||
| echo "$object : \\" > "$depfile" | |||||
| # The first sed program below extracts the file names and escapes | |||||
| # backslashes for cygpath. The second sed program outputs the file | |||||
| # name when reading, but also accumulates all include files in the | |||||
| # hold buffer in order to output them again at the end. This only | |||||
| # works with sed implementations that can handle large buffers. | |||||
| sed < "$tmpdepfile" -n ' | |||||
| /^Note: including file: *\(.*\)/ { | |||||
| s//\1/ | |||||
| s/\\/\\\\/g | |||||
| p | |||||
| }' | $cygpath_u | sort -u | sed -n ' | |||||
| s/ /\\ /g | |||||
| s/\(.*\)/'"$tab"'\1 \\/p | |||||
| s/.\(.*\) \\/\1:/ | |||||
| H | |||||
| $ { | |||||
| s/.*/'"$tab"'/ | |||||
| G | |||||
| p | |||||
| }' >> "$depfile" | |||||
| echo >> "$depfile" # make sure the fragment doesn't end with a backslash | |||||
| rm -f "$tmpdepfile" | |||||
| ;; | |||||
| msvc7msys) | |||||
| # This case exists only to let depend.m4 do its work. It works by | |||||
| # looking at the text of this script. This case will never be run, | |||||
| # since it is checked for above. | |||||
| exit 1 | |||||
| ;; | |||||
| #nosideeffect) | |||||
| # This comment above is used by automake to tell side-effect | |||||
| # dependency tracking mechanisms from slower ones. | |||||
| dashmstdout) | |||||
| # Important note: in order to support this mode, a compiler *must* | |||||
| # always write the preprocessed file to stdout, regardless of -o. | |||||
| "$@" || exit $? | |||||
| # Remove the call to Libtool. | |||||
| if test "$libtool" = yes; then | |||||
| while test "X$1" != 'X--mode=compile'; do | |||||
| shift | |||||
| done | |||||
| shift | |||||
| fi | |||||
| # Remove '-o $object'. | |||||
| IFS=" " | |||||
| for arg | |||||
| do | |||||
| case $arg in | |||||
| -o) | |||||
| shift | |||||
| ;; | |||||
| $object) | |||||
| shift | |||||
| ;; | |||||
| *) | |||||
| set fnord "$@" "$arg" | |||||
| shift # fnord | |||||
| shift # $arg | |||||
| ;; | |||||
| esac | |||||
| done | |||||
| test -z "$dashmflag" && dashmflag=-M | |||||
| # Require at least two characters before searching for ':' | |||||
| # in the target name. This is to cope with DOS-style filenames: | |||||
| # a dependency such as 'c:/foo/bar' could be seen as target 'c' otherwise. | |||||
| "$@" $dashmflag | | |||||
| sed "s|^[$tab ]*[^:$tab ][^:][^:]*:[$tab ]*|$object: |" > "$tmpdepfile" | |||||
| rm -f "$depfile" | |||||
| cat < "$tmpdepfile" > "$depfile" | |||||
| # Some versions of the HPUX 10.20 sed can't process this sed invocation | |||||
| # correctly. Breaking it into two sed invocations is a workaround. | |||||
| tr ' ' "$nl" < "$tmpdepfile" \ | |||||
| | sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' \ | |||||
| | sed -e 's/$/ :/' >> "$depfile" | |||||
| rm -f "$tmpdepfile" | |||||
| ;; | |||||
| dashXmstdout) | |||||
| # This case only exists to satisfy depend.m4. It is never actually | |||||
| # run, as this mode is specially recognized in the preamble. | |||||
| exit 1 | |||||
| ;; | |||||
| makedepend) | |||||
| "$@" || exit $? | |||||
| # Remove any Libtool call | |||||
| if test "$libtool" = yes; then | |||||
| while test "X$1" != 'X--mode=compile'; do | |||||
| shift | |||||
| done | |||||
| shift | |||||
| fi | |||||
| # X makedepend | |||||
| shift | |||||
| cleared=no eat=no | |||||
| for arg | |||||
| do | |||||
| case $cleared in | |||||
| no) | |||||
| set ""; shift | |||||
| cleared=yes ;; | |||||
| esac | |||||
| if test $eat = yes; then | |||||
| eat=no | |||||
| continue | |||||
| fi | |||||
| case "$arg" in | |||||
| -D*|-I*) | |||||
| set fnord "$@" "$arg"; shift ;; | |||||
| # Strip any option that makedepend may not understand. Remove | |||||
| # the object too, otherwise makedepend will parse it as a source file. | |||||
| -arch) | |||||
| eat=yes ;; | |||||
| -*|$object) | |||||
| ;; | |||||
| *) | |||||
| set fnord "$@" "$arg"; shift ;; | |||||
| esac | |||||
| done | |||||
| obj_suffix=`echo "$object" | sed 's/^.*\././'` | |||||
| touch "$tmpdepfile" | |||||
| ${MAKEDEPEND-makedepend} -o"$obj_suffix" -f"$tmpdepfile" "$@" | |||||
| rm -f "$depfile" | |||||
| # makedepend may prepend the VPATH from the source file name to the object. | |||||
| # No need to regex-escape $object, excess matching of '.' is harmless. | |||||
| sed "s|^.*\($object *:\)|\1|" "$tmpdepfile" > "$depfile" | |||||
| # Some versions of the HPUX 10.20 sed can't process the last invocation | |||||
| # correctly. Breaking it into two sed invocations is a workaround. | |||||
| sed '1,2d' "$tmpdepfile" \ | |||||
| | tr ' ' "$nl" \ | |||||
| | sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' \ | |||||
| | sed -e 's/$/ :/' >> "$depfile" | |||||
| rm -f "$tmpdepfile" "$tmpdepfile".bak | |||||
| ;; | |||||
| cpp) | |||||
| # Important note: in order to support this mode, a compiler *must* | |||||
| # always write the preprocessed file to stdout. | |||||
| "$@" || exit $? | |||||
| # Remove the call to Libtool. | |||||
| if test "$libtool" = yes; then | |||||
| while test "X$1" != 'X--mode=compile'; do | |||||
| shift | |||||
| done | |||||
| shift | |||||
| fi | |||||
| # Remove '-o $object'. | |||||
| IFS=" " | |||||
| for arg | |||||
| do | |||||
| case $arg in | |||||
| -o) | |||||
| shift | |||||
| ;; | |||||
| $object) | |||||
| shift | |||||
| ;; | |||||
| *) | |||||
| set fnord "$@" "$arg" | |||||
| shift # fnord | |||||
| shift # $arg | |||||
| ;; | |||||
| esac | |||||
| done | |||||
| "$@" -E \ | |||||
| | sed -n -e '/^# [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \ | |||||
| -e '/^#line [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \ | |||||
| | sed '$ s: \\$::' > "$tmpdepfile" | |||||
| rm -f "$depfile" | |||||
| echo "$object : \\" > "$depfile" | |||||
| cat < "$tmpdepfile" >> "$depfile" | |||||
| sed < "$tmpdepfile" '/^$/d;s/^ //;s/ \\$//;s/$/ :/' >> "$depfile" | |||||
| rm -f "$tmpdepfile" | |||||
| ;; | |||||
| msvisualcpp) | |||||
| # Important note: in order to support this mode, a compiler *must* | |||||
| # always write the preprocessed file to stdout. | |||||
| "$@" || exit $? | |||||
| # Remove the call to Libtool. | |||||
| if test "$libtool" = yes; then | |||||
| while test "X$1" != 'X--mode=compile'; do | |||||
| shift | |||||
| done | |||||
| shift | |||||
| fi | |||||
| IFS=" " | |||||
| for arg | |||||
| do | |||||
| case "$arg" in | |||||
| -o) | |||||
| shift | |||||
| ;; | |||||
| $object) | |||||
| shift | |||||
| ;; | |||||
| "-Gm"|"/Gm"|"-Gi"|"/Gi"|"-ZI"|"/ZI") | |||||
| set fnord "$@" | |||||
| shift | |||||
| shift | |||||
| ;; | |||||
| *) | |||||
| set fnord "$@" "$arg" | |||||
| shift | |||||
| shift | |||||
| ;; | |||||
| esac | |||||
| done | |||||
| "$@" -E 2>/dev/null | | |||||
| sed -n '/^#line [0-9][0-9]* "\([^"]*\)"/ s::\1:p' | $cygpath_u | sort -u > "$tmpdepfile" | |||||
| rm -f "$depfile" | |||||
| echo "$object : \\" > "$depfile" | |||||
| sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s::'"$tab"'\1 \\:p' >> "$depfile" | |||||
| echo "$tab" >> "$depfile" | |||||
| sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s::\1\::p' >> "$depfile" | |||||
| rm -f "$tmpdepfile" | |||||
| ;; | |||||
| msvcmsys) | |||||
| # This case exists only to let depend.m4 do its work. It works by | |||||
| # looking at the text of this script. This case will never be run, | |||||
| # since it is checked for above. | |||||
| exit 1 | |||||
| ;; | |||||
| none) | |||||
| exec "$@" | |||||
| ;; | |||||
| *) | |||||
| echo "Unknown depmode $depmode" 1>&2 | |||||
| exit 1 | |||||
| ;; | |||||
| esac | |||||
| exit 0 | |||||
| # Local Variables: | |||||
| # mode: shell-script | |||||
| # sh-indentation: 2 | |||||
| # eval: (add-hook 'write-file-hooks 'time-stamp) | |||||
| # time-stamp-start: "scriptversion=" | |||||
| # time-stamp-format: "%:y-%02m-%02d.%02H" | |||||
| # time-stamp-time-zone: "UTC" | |||||
| # time-stamp-end: "; # UTC" | |||||
| # End: | |||||
| @@ -1,301 +0,0 @@ | |||||
| #!/bin/sh | |||||
| # | |||||
| # $NetBSD: install-sh.in,v 1.6 2012/01/11 13:07:31 hans Exp $ | |||||
| # This script now also installs multiple files, but might choke on installing | |||||
| # multiple files with spaces in the file names. | |||||
| # | |||||
| # install - install a program, script, or datafile | |||||
| # This comes from X11R5 (mit/util/scripts/install.sh). | |||||
| # | |||||
| # Copyright 1991 by the Massachusetts Institute of Technology | |||||
| # | |||||
| # Permission to use, copy, modify, distribute, and sell this software and its | |||||
| # documentation for any purpose is hereby granted without fee, provided that | |||||
| # the above copyright notice appear in all copies and that both that | |||||
| # copyright notice and this permission notice appear in supporting | |||||
| # documentation, and that the name of M.I.T. not be used in advertising or | |||||
| # publicity pertaining to distribution of the software without specific, | |||||
| # written prior permission. M.I.T. makes no representations about the | |||||
| # suitability of this software for any purpose. It is provided "as is" | |||||
| # without express or implied warranty. | |||||
| # | |||||
| # 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. | |||||
| # 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. | |||||
| awkprog="${AWKPROG-awk}" | |||||
| mvprog="${MVPROG-mv}" | |||||
| cpprog="${CPPROG-cp}" | |||||
| chmodprog="${CHMODPROG-chmod}" | |||||
| chownprog="${CHOWNPROG-chown}" | |||||
| chgrpprog="${CHGRPPROG-chgrp}" | |||||
| stripprog="${STRIPPROG-strip}" | |||||
| rmprog="${RMPROG-rm}" | |||||
| mkdirprog="${MKDIRPROG-mkdir}" | |||||
| instcmd="$cpprog" | |||||
| instflags="" | |||||
| pathcompchmodcmd="$chmodprog 755" | |||||
| chmodcmd="$chmodprog 755" | |||||
| chowncmd="" | |||||
| chgrpcmd="" | |||||
| stripcmd="" | |||||
| stripflags="" | |||||
| rmcmd="$rmprog -f" | |||||
| mvcmd="$mvprog" | |||||
| src="" | |||||
| msrc="" | |||||
| dst="" | |||||
| dir_arg="" | |||||
| suffix="" | |||||
| suffixfmt="" | |||||
| while [ x"$1" != x ]; do | |||||
| case $1 in | |||||
| -b) suffix=".old" | |||||
| shift | |||||
| continue;; | |||||
| -B) suffixfmt="$2" | |||||
| shift | |||||
| shift | |||||
| continue;; | |||||
| -c) instcmd="$cpprog" | |||||
| shift | |||||
| continue;; | |||||
| -d) dir_arg=true | |||||
| shift | |||||
| continue;; | |||||
| -m) chmodcmd="$chmodprog $2" | |||||
| shift | |||||
| shift | |||||
| continue;; | |||||
| -m*) | |||||
| chmodcmd="$chmodprog ${1#-m}" | |||||
| shift | |||||
| continue;; | |||||
| -o) chowncmd="$chownprog $2" | |||||
| shift | |||||
| shift | |||||
| continue;; | |||||
| -g) chgrpcmd="$chgrpprog $2" | |||||
| shift | |||||
| shift | |||||
| continue;; | |||||
| -s) stripcmd="$stripprog" | |||||
| shift | |||||
| continue;; | |||||
| -S) stripcmd="$stripprog" | |||||
| stripflags="-S $2 $stripflags" | |||||
| shift | |||||
| shift | |||||
| continue;; | |||||
| -p) instflags="-p" | |||||
| shift | |||||
| continue;; | |||||
| *) if [ x"$msrc" = x ] | |||||
| then | |||||
| msrc="$dst" | |||||
| else | |||||
| msrc="$msrc $dst" | |||||
| fi | |||||
| src="$dst" | |||||
| dst="$1" | |||||
| shift | |||||
| continue;; | |||||
| esac | |||||
| done | |||||
| if [ x"$dir_arg" = x ] | |||||
| then | |||||
| dstisfile="" | |||||
| if [ ! -d "$dst" ] | |||||
| then | |||||
| if [ x"$msrc" = x"$src" ] | |||||
| then | |||||
| dstisfile=true | |||||
| else | |||||
| echo "install: destination is not a directory" | |||||
| exit 1 | |||||
| fi | |||||
| fi | |||||
| else | |||||
| msrc="$msrc $dst" | |||||
| fi | |||||
| if [ x"$msrc" = x ] | |||||
| then | |||||
| echo "install: no destination specified" | |||||
| exit 1 | |||||
| fi | |||||
| for srcarg in $msrc; do | |||||
| if [ x"$dir_arg" != x ]; then | |||||
| dstarg="$srcarg" | |||||
| else | |||||
| dstarg="$dst" | |||||
| # Waiting for this to be detected by the "$instcmd $srcarg $dsttmp" command | |||||
| # might cause directories to be created, which would be especially bad | |||||
| # if $src (and thus $dsttmp) contains '*'. | |||||
| if [ -f "$srcarg" ] | |||||
| then | |||||
| doinst="$instcmd $instflags" | |||||
| elif [ -d "$srcarg" ] | |||||
| then | |||||
| echo "install: $srcarg: not a regular file" | |||||
| exit 1 | |||||
| elif [ "$srcarg" = "/dev/null" ] | |||||
| then | |||||
| doinst="$cpprog" | |||||
| else | |||||
| echo "install: $srcarg does not exist" | |||||
| exit 1 | |||||
| fi | |||||
| # If destination is a directory, append the input filename; if your system | |||||
| # does not like double slashes in filenames, you may need to add some logic | |||||
| if [ -d "$dstarg" ] | |||||
| then | |||||
| dstarg="$dstarg"/`basename "$srcarg"` | |||||
| fi | |||||
| fi | |||||
| ## this sed command emulates the dirname command | |||||
| dstdir=`echo "$dstarg" | sed -e 's,[^/]*$,,;s,/$,,;s,^$,.,'` | |||||
| # Make sure that the destination directory exists. | |||||
| # this part is taken from Noah Friedman's mkinstalldirs script | |||||
| # Skip lots of stat calls in the usual case. | |||||
| if [ ! -d "$dstdir" ]; then | |||||
| defaultIFS=' | |||||
| ' | |||||
| IFS="${IFS-${defaultIFS}}" | |||||
| oIFS="${IFS}" | |||||
| # Some sh's can't handle IFS=/ for some reason. | |||||
| IFS='%' | |||||
| set - `echo ${dstdir} | sed -e 's@/@%@g' -e 's@^%@/@'` | |||||
| IFS="${oIFS}" | |||||
| pathcomp='' | |||||
| while [ $# -ne 0 ] ; do | |||||
| pathcomp="${pathcomp}${1}" | |||||
| shift | |||||
| if [ ! -d "${pathcomp}" ] ; | |||||
| then | |||||
| $doit $mkdirprog "${pathcomp}" | |||||
| if [ x"$chowncmd" != x ]; then $doit $chowncmd "${pathcomp}"; else true ; fi && | |||||
| if [ x"$chgrpcmd" != x ]; then $doit $chgrpcmd "${pathcomp}"; else true ; fi && | |||||
| if [ x"$pathcompchmodcmd" != x ]; then $doit $pathcompchmodcmd "${pathcomp}"; else true ; fi | |||||
| else | |||||
| true | |||||
| fi | |||||
| pathcomp="${pathcomp}/" | |||||
| done | |||||
| fi | |||||
| if [ x"$dir_arg" != x ] | |||||
| then | |||||
| if [ -d "$dstarg" ]; then | |||||
| true | |||||
| else | |||||
| $doit $mkdirprog "$dstarg" && | |||||
| if [ x"$chowncmd" != x ]; then $doit $chowncmd "$dstarg"; else true ; fi && | |||||
| if [ x"$chgrpcmd" != x ]; then $doit $chgrpcmd "$dstarg"; else true ; fi && | |||||
| if [ x"$chmodcmd" != x ]; then $doit $chmodcmd "$dstarg"; else true ; fi | |||||
| fi | |||||
| else | |||||
| if [ x"$dstisfile" = x ] | |||||
| then | |||||
| file=$srcarg | |||||
| else | |||||
| file=$dst | |||||
| fi | |||||
| dstfile=`basename "$file"` | |||||
| dstfinal="$dstdir/$dstfile" | |||||
| # Make a temp file name in the proper directory. | |||||
| dsttmp=$dstdir/#inst.$$# | |||||
| # Make a backup file name in the proper directory. | |||||
| case x$suffixfmt in | |||||
| *%*) suffix=`echo x | | |||||
| $awkprog -v bname="$dstfinal" -v fmt="$suffixfmt" ' | |||||
| { cnt = 0; | |||||
| do { | |||||
| sfx = sprintf(fmt, cnt++); | |||||
| name = bname sfx; | |||||
| } while (system("test -f " name) == 0); | |||||
| print sfx; }' -`;; | |||||
| x) ;; | |||||
| *) suffix="$suffixfmt";; | |||||
| esac | |||||
| dstbackup="$dstfinal$suffix" | |||||
| # Move or copy the file name to the temp name | |||||
| $doit $doinst $srcarg "$dsttmp" && | |||||
| trap "rm -f ${dsttmp}" 0 && | |||||
| # 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 $instcmd $src $dsttmp" command. | |||||
| if [ x"$chowncmd" != x ]; then $doit $chowncmd "$dsttmp"; else true;fi && | |||||
| if [ x"$chgrpcmd" != x ]; then $doit $chgrpcmd "$dsttmp"; else true;fi && | |||||
| if [ x"$stripcmd" != x ]; then $doit $stripcmd $stripflags "$dsttmp"; else true;fi && | |||||
| if [ x"$chmodcmd" != x ]; then $doit $chmodcmd "$dsttmp"; else true;fi && | |||||
| # Now rename the file to the real destination. | |||||
| if [ x"$suffix" != x ] && [ -f "$dstfinal" ] | |||||
| then | |||||
| $doit $mvcmd "$dstfinal" "$dstbackup" | |||||
| else | |||||
| $doit $rmcmd -f "$dstfinal" | |||||
| fi && | |||||
| $doit $mvcmd "$dsttmp" "$dstfinal" | |||||
| fi | |||||
| done && | |||||
| exit 0 | |||||
| @@ -1,215 +0,0 @@ | |||||
| #! /bin/sh | |||||
| # Common wrapper for a few potentially missing GNU programs. | |||||
| scriptversion=2012-06-26.16; # UTC | |||||
| # Copyright (C) 1996-2013 Free Software Foundation, Inc. | |||||
| # Originally written by Fran,cois Pinard <pinard@iro.umontreal.ca>, 1996. | |||||
| # This program is free software; you can redistribute it and/or modify | |||||
| # it under the terms of the GNU General Public License as published by | |||||
| # the Free Software Foundation; either version 2, or (at your option) | |||||
| # any later version. | |||||
| # This program is distributed in the hope that it will be useful, | |||||
| # but WITHOUT ANY WARRANTY; without even the implied warranty of | |||||
| # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |||||
| # GNU General Public License for more details. | |||||
| # You should have received a copy of the GNU General Public License | |||||
| # along with this program. If not, see <http://www.gnu.org/licenses/>. | |||||
| # As a special exception to the GNU General Public License, if you | |||||
| # distribute this file as part of a program that contains a | |||||
| # configuration script generated by Autoconf, you may include it under | |||||
| # the same distribution terms that you use for the rest of that program. | |||||
| if test $# -eq 0; then | |||||
| echo 1>&2 "Try '$0 --help' for more information" | |||||
| exit 1 | |||||
| fi | |||||
| case $1 in | |||||
| --is-lightweight) | |||||
| # Used by our autoconf macros to check whether the available missing | |||||
| # script is modern enough. | |||||
| exit 0 | |||||
| ;; | |||||
| --run) | |||||
| # Back-compat with the calling convention used by older automake. | |||||
| shift | |||||
| ;; | |||||
| -h|--h|--he|--hel|--help) | |||||
| echo "\ | |||||
| $0 [OPTION]... PROGRAM [ARGUMENT]... | |||||
| Run 'PROGRAM [ARGUMENT]...', returning a proper advice when this fails due | |||||
| to PROGRAM being missing or too old. | |||||
| Options: | |||||
| -h, --help display this help and exit | |||||
| -v, --version output version information and exit | |||||
| Supported PROGRAM values: | |||||
| aclocal autoconf autoheader autom4te automake makeinfo | |||||
| bison yacc flex lex help2man | |||||
| Version suffixes to PROGRAM as well as the prefixes 'gnu-', 'gnu', and | |||||
| 'g' are ignored when checking the name. | |||||
| Send bug reports to <bug-automake@gnu.org>." | |||||
| exit $? | |||||
| ;; | |||||
| -v|--v|--ve|--ver|--vers|--versi|--versio|--version) | |||||
| echo "missing $scriptversion (GNU Automake)" | |||||
| exit $? | |||||
| ;; | |||||
| -*) | |||||
| echo 1>&2 "$0: unknown '$1' option" | |||||
| echo 1>&2 "Try '$0 --help' for more information" | |||||
| exit 1 | |||||
| ;; | |||||
| esac | |||||
| # Run the given program, remember its exit status. | |||||
| "$@"; st=$? | |||||
| # If it succeeded, we are done. | |||||
| test $st -eq 0 && exit 0 | |||||
| # Also exit now if we it failed (or wasn't found), and '--version' was | |||||
| # passed; such an option is passed most likely to detect whether the | |||||
| # program is present and works. | |||||
| case $2 in --version|--help) exit $st;; esac | |||||
| # Exit code 63 means version mismatch. This often happens when the user | |||||
| # tries to use an ancient version of a tool on a file that requires a | |||||
| # minimum version. | |||||
| if test $st -eq 63; then | |||||
| msg="probably too old" | |||||
| elif test $st -eq 127; then | |||||
| # Program was missing. | |||||
| msg="missing on your system" | |||||
| else | |||||
| # Program was found and executed, but failed. Give up. | |||||
| exit $st | |||||
| fi | |||||
| perl_URL=http://www.perl.org/ | |||||
| flex_URL=http://flex.sourceforge.net/ | |||||
| gnu_software_URL=http://www.gnu.org/software | |||||
| program_details () | |||||
| { | |||||
| case $1 in | |||||
| aclocal|automake) | |||||
| echo "The '$1' program is part of the GNU Automake package:" | |||||
| echo "<$gnu_software_URL/automake>" | |||||
| echo "It also requires GNU Autoconf, GNU m4 and Perl in order to run:" | |||||
| echo "<$gnu_software_URL/autoconf>" | |||||
| echo "<$gnu_software_URL/m4/>" | |||||
| echo "<$perl_URL>" | |||||
| ;; | |||||
| autoconf|autom4te|autoheader) | |||||
| echo "The '$1' program is part of the GNU Autoconf package:" | |||||
| echo "<$gnu_software_URL/autoconf/>" | |||||
| echo "It also requires GNU m4 and Perl in order to run:" | |||||
| echo "<$gnu_software_URL/m4/>" | |||||
| echo "<$perl_URL>" | |||||
| ;; | |||||
| esac | |||||
| } | |||||
| give_advice () | |||||
| { | |||||
| # Normalize program name to check for. | |||||
| normalized_program=`echo "$1" | sed ' | |||||
| s/^gnu-//; t | |||||
| s/^gnu//; t | |||||
| s/^g//; t'` | |||||
| printf '%s\n' "'$1' is $msg." | |||||
| configure_deps="'configure.ac' or m4 files included by 'configure.ac'" | |||||
| case $normalized_program in | |||||
| autoconf*) | |||||
| echo "You should only need it if you modified 'configure.ac'," | |||||
| echo "or m4 files included by it." | |||||
| program_details 'autoconf' | |||||
| ;; | |||||
| autoheader*) | |||||
| echo "You should only need it if you modified 'acconfig.h' or" | |||||
| echo "$configure_deps." | |||||
| program_details 'autoheader' | |||||
| ;; | |||||
| automake*) | |||||
| echo "You should only need it if you modified 'Makefile.am' or" | |||||
| echo "$configure_deps." | |||||
| program_details 'automake' | |||||
| ;; | |||||
| aclocal*) | |||||
| echo "You should only need it if you modified 'acinclude.m4' or" | |||||
| echo "$configure_deps." | |||||
| program_details 'aclocal' | |||||
| ;; | |||||
| autom4te*) | |||||
| echo "You might have modified some maintainer files that require" | |||||
| echo "the 'automa4te' program to be rebuilt." | |||||
| program_details 'autom4te' | |||||
| ;; | |||||
| bison*|yacc*) | |||||
| echo "You should only need it if you modified a '.y' file." | |||||
| echo "You may want to install the GNU Bison package:" | |||||
| echo "<$gnu_software_URL/bison/>" | |||||
| ;; | |||||
| lex*|flex*) | |||||
| echo "You should only need it if you modified a '.l' file." | |||||
| echo "You may want to install the Fast Lexical Analyzer package:" | |||||
| echo "<$flex_URL>" | |||||
| ;; | |||||
| help2man*) | |||||
| echo "You should only need it if you modified a dependency" \ | |||||
| "of a man page." | |||||
| echo "You may want to install the GNU Help2man package:" | |||||
| echo "<$gnu_software_URL/help2man/>" | |||||
| ;; | |||||
| makeinfo*) | |||||
| echo "You should only need it if you modified a '.texi' file, or" | |||||
| echo "any other file indirectly affecting the aspect of the manual." | |||||
| echo "You might want to install the Texinfo package:" | |||||
| echo "<$gnu_software_URL/texinfo/>" | |||||
| echo "The spurious makeinfo call might also be the consequence of" | |||||
| echo "using a buggy 'make' (AIX, DU, IRIX), in which case you might" | |||||
| echo "want to install GNU make:" | |||||
| echo "<$gnu_software_URL/make/>" | |||||
| ;; | |||||
| *) | |||||
| echo "You might have modified some files without having the proper" | |||||
| echo "tools for further handling them. Check the 'README' file, it" | |||||
| echo "often tells you about the needed prerequisites for installing" | |||||
| echo "this package. You may also peek at any GNU archive site, in" | |||||
| echo "case some other package contains this missing '$1' program." | |||||
| ;; | |||||
| esac | |||||
| } | |||||
| give_advice "$1" | sed -e '1s/^/WARNING: /' \ | |||||
| -e '2,$s/^/ /' >&2 | |||||
| # Propagate the correct exit status (expected to be 127 for a program | |||||
| # not found, 63 for a program that failed due to version mismatch). | |||||
| exit $st | |||||
| # Local variables: | |||||
| # eval: (add-hook 'write-file-hooks 'time-stamp) | |||||
| # time-stamp-start: "scriptversion=" | |||||
| # time-stamp-format: "%:y-%02m-%02d.%02H" | |||||
| # time-stamp-time-zone: "UTC" | |||||
| # time-stamp-end: "; # UTC" | |||||
| # End: | |||||
| @@ -1,127 +0,0 @@ | |||||
| #! /bin/sh | |||||
| # test-driver - basic testsuite driver script. | |||||
| scriptversion=2012-06-27.10; # UTC | |||||
| # Copyright (C) 2011-2013 Free Software Foundation, Inc. | |||||
| # | |||||
| # This program is free software; you can redistribute it and/or modify | |||||
| # it under the terms of the GNU General Public License as published by | |||||
| # the Free Software Foundation; either version 2, or (at your option) | |||||
| # any later version. | |||||
| # | |||||
| # This program is distributed in the hope that it will be useful, | |||||
| # but WITHOUT ANY WARRANTY; without even the implied warranty of | |||||
| # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |||||
| # GNU General Public License for more details. | |||||
| # | |||||
| # You should have received a copy of the GNU General Public License | |||||
| # along with this program. If not, see <http://www.gnu.org/licenses/>. | |||||
| # As a special exception to the GNU General Public License, if you | |||||
| # distribute this file as part of a program that contains a | |||||
| # configuration script generated by Autoconf, you may include it under | |||||
| # the same distribution terms that you use for the rest of that program. | |||||
| # This file is maintained in Automake, please report | |||||
| # bugs to <bug-automake@gnu.org> or send patches to | |||||
| # <automake-patches@gnu.org>. | |||||
| # Make unconditional expansion of undefined variables an error. This | |||||
| # helps a lot in preventing typo-related bugs. | |||||
| set -u | |||||
| usage_error () | |||||
| { | |||||
| echo "$0: $*" >&2 | |||||
| print_usage >&2 | |||||
| exit 2 | |||||
| } | |||||
| print_usage () | |||||
| { | |||||
| cat <<END | |||||
| Usage: | |||||
| test-driver --test-name=NAME --log-file=PATH --trs-file=PATH | |||||
| [--expect-failure={yes|no}] [--color-tests={yes|no}] | |||||
| [--enable-hard-errors={yes|no}] [--] TEST-SCRIPT | |||||
| The '--test-name', '--log-file' and '--trs-file' options are mandatory. | |||||
| END | |||||
| } | |||||
| # TODO: better error handling in option parsing (in particular, ensure | |||||
| # TODO: $log_file, $trs_file and $test_name are defined). | |||||
| test_name= # Used for reporting. | |||||
| log_file= # Where to save the output of the test script. | |||||
| trs_file= # Where to save the metadata of the test run. | |||||
| expect_failure=no | |||||
| color_tests=no | |||||
| enable_hard_errors=yes | |||||
| while test $# -gt 0; do | |||||
| case $1 in | |||||
| --help) print_usage; exit $?;; | |||||
| --version) echo "test-driver $scriptversion"; exit $?;; | |||||
| --test-name) test_name=$2; shift;; | |||||
| --log-file) log_file=$2; shift;; | |||||
| --trs-file) trs_file=$2; shift;; | |||||
| --color-tests) color_tests=$2; shift;; | |||||
| --expect-failure) expect_failure=$2; shift;; | |||||
| --enable-hard-errors) enable_hard_errors=$2; shift;; | |||||
| --) shift; break;; | |||||
| -*) usage_error "invalid option: '$1'";; | |||||
| esac | |||||
| shift | |||||
| done | |||||
| if test $color_tests = yes; then | |||||
| # Keep this in sync with 'lib/am/check.am:$(am__tty_colors)'. | |||||
| red='[0;31m' # Red. | |||||
| grn='[0;32m' # Green. | |||||
| lgn='[1;32m' # Light green. | |||||
| blu='[1;34m' # Blue. | |||||
| mgn='[0;35m' # Magenta. | |||||
| std='[m' # No color. | |||||
| else | |||||
| red= grn= lgn= blu= mgn= std= | |||||
| fi | |||||
| do_exit='rm -f $log_file $trs_file; (exit $st); exit $st' | |||||
| trap "st=129; $do_exit" 1 | |||||
| trap "st=130; $do_exit" 2 | |||||
| trap "st=141; $do_exit" 13 | |||||
| trap "st=143; $do_exit" 15 | |||||
| # Test script is run here. | |||||
| "$@" >$log_file 2>&1 | |||||
| estatus=$? | |||||
| if test $enable_hard_errors = no && test $estatus -eq 99; then | |||||
| estatus=1 | |||||
| fi | |||||
| case $estatus:$expect_failure in | |||||
| 0:yes) col=$red res=XPASS recheck=yes gcopy=yes;; | |||||
| 0:*) col=$grn res=PASS recheck=no gcopy=no;; | |||||
| 77:*) col=$blu res=SKIP recheck=no gcopy=yes;; | |||||
| 99:*) col=$mgn res=ERROR recheck=yes gcopy=yes;; | |||||
| *:yes) col=$lgn res=XFAIL recheck=no gcopy=yes;; | |||||
| *:*) col=$red res=FAIL recheck=yes gcopy=yes;; | |||||
| esac | |||||
| # Report outcome to console. | |||||
| echo "${col}${res}${std}: $test_name" | |||||
| # Register the test result, and other relevant metadata. | |||||
| echo ":test-result: $res" > $trs_file | |||||
| echo ":global-test-result: $res" >> $trs_file | |||||
| echo ":recheck: $recheck" >> $trs_file | |||||
| echo ":copy-in-global-log: $gcopy" >> $trs_file | |||||
| # Local Variables: | |||||
| # mode: shell-script | |||||
| # sh-indentation: 2 | |||||
| # eval: (add-hook 'write-file-hooks 'time-stamp) | |||||
| # time-stamp-start: "scriptversion=" | |||||
| # time-stamp-format: "%:y-%02m-%02d.%02H" | |||||
| # time-stamp-time-zone: "UTC" | |||||
| # time-stamp-end: "; # UTC" | |||||
| # End: | |||||