added: autoconf environment
authorhajo <habenich@bombodil.planetsserver.lan>
Tue, 2 Oct 2007 14:08:50 +0000 (16:08 +0200)
committerhajo <habenich@bombodil.planetsserver.lan>
Tue, 2 Oct 2007 14:08:50 +0000 (16:08 +0200)
NOTE: --with-asterisk compiles, --use-misdn-socket not

AUTHORS [new file with mode: 0644]
ChangeLog [new file with mode: 0644]
INSTALL [new file with mode: 0644]
Makefile.am [new file with mode: 0644]
NEWS [new file with mode: 0644]
acinclude.m4 [new file with mode: 0644]
autogen.sh [new file with mode: 0644]
configure.ac [new file with mode: 0644]
depcomp [new file with mode: 0755]
install-sh [new file with mode: 0755]
missing [new file with mode: 0755]

diff --git a/AUTHORS b/AUTHORS
new file mode 100644 (file)
index 0000000..e866f72
--- /dev/null
+++ b/AUTHORS
@@ -0,0 +1,2 @@
+Andreas Eversberg
+Joerg Habenicht
diff --git a/ChangeLog b/ChangeLog
new file mode 100644 (file)
index 0000000..e69de29
diff --git a/INSTALL b/INSTALL
new file mode 100644 (file)
index 0000000..5458714
--- /dev/null
+++ b/INSTALL
@@ -0,0 +1,234 @@
+Installation Instructions
+*************************
+
+Copyright (C) 1994, 1995, 1996, 1999, 2000, 2001, 2002, 2004, 2005,
+2006 Free Software Foundation, Inc.
+
+This file is free documentation; the Free Software Foundation gives
+unlimited permission to copy, distribute and modify it.
+
+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.
+
+   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.
+
+  4. Type `make install' to install the programs and any data files and
+     documentation.
+
+  5. 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.
+
+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 `..'.
+
+   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.
+
+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'.
+
+   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.
+
+   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'.
+
+Optional Features
+=================
+
+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.
+
+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 bug.  Until the bug is fixed you can use this workaround:
+
+     CONFIG_SHELL=/bin/bash /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 the options to `configure', and exit.
+
+`--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.
+
+`configure' also accepts some other, not widely useful, options.  Run
+`configure --help' for more details.
+
diff --git a/Makefile.am b/Makefile.am
new file mode 100644 (file)
index 0000000..e5b97b2
--- /dev/null
@@ -0,0 +1,492 @@
+## Makefile.am -- Process this file with automake to produce Makefile.in
+
+
+INSTALLATION_DEFINES = -DCONFIG_DATA="\"$(pkgsysconfdir)\"" -DSHARE_DATA="\"$(pkgdatadir)\"" -DLOG_DIR="\"$(pkglogdir)\"" -DPBX -DINSTALL_DATA="\"$(pkgdatadir)\""
+# FIXME: find a macro for the include path of linux
+# or is /lib/modules/$(uname -r)/source/include sufficient?
+# Do we take /usr/src/linux or /usr/src/linux-$(uname -r)
+# if complied without modules?
+# UPDATE: Not needed, compiles cleanly without.
+INCLUDES = $(all_includes) $(INSTALLATION_DEFINES) 
+
+
+bin_PROGRAMS = lcradmin gentones genwave #lcrwatch
+sbin_PROGRAMS = lcr genrc genextension 
+
+
+conditional_sources_common = \
+               main.c \
+       options.c \
+       interface.c \
+       extension.c \
+       cause.c \
+       alawulaw.c \
+       tones.c \
+       message.c \
+       route.c \
+       port.cpp \
+       mISDN.cpp \
+       dss1.cpp \
+       vbox.cpp \
+       endpoint.cpp \
+       endpointapp.cpp \
+       apppbx.cpp \
+       crypt.cpp \
+       action.cpp \
+       action_vbox.cpp \
+       action_efi.cpp \
+       mail.c \
+       join.cpp \
+       joinpbx.cpp \
+       joinremote.cpp \
+       admin_server.c \
+       trace.c 
+
+# extension.c  main.c     tones.c \
+# admin_server.c  message.c \
+# alawulaw.c      interface.c  options.c \
+# cause.c         mail.c       route.c \
+# action.cpp       crypt.cpp        port.cpp \
+# action_efi.cpp   dss1.cpp         rule.cpp \
+# action_vbox.cpp  endpointapp.cpp  ie.cpp \
+# apppbx.cpp       endpoint.cpp     vbox.cpp \
+# call.cpp         mISDN.cpp        vector.cpp \
+# admin.h         dss1.h         route.h \
+# admin_server.h  endpointapp.h  rule.h \
+# alawulaw.h      endpoint.h     interface.h  save.h \
+# apppbx.h        extension.h    main.h \
+# call.h          message.h      options.h    tones.h \
+# cause.h         mISDN.h        port.h       vbox.h \
+# crypt.h         q931.h         vector.h
+
+
+
+
+# wizzard is currently disabled.
+# it can be compiled with "make wizzard.o" but nothing more
+#wizzard_SOURCES = wizzard.c wizzard.h
+
+lcr_SOURCES = $(conditional_sources_common)
+lcr_LDADD = $(all_libraries) -lisdnnet -lmISDN
+if WITH_CRYPTO
+# TODO: maybe we could add crypt.{h,cpp} here?
+#lcr_LDADD += -lcrypto -ldl
+lcr_LDADD += -lcrypto
+INSTALLATION_DEFINES += -DCRYPTO
+endif
+
+if ENABLE_SOCKET_MISDN
+INSTALLATION_DEFINES += -DSOCKET_MISDN
+endif
+
+if ENABLE_ASTERISK_CHANNEL_DRIVER
+sbin_PROGRAMS += chan_lcr
+chan_lcr_SOURCES = asterisk_client.c
+endif
+
+lcradmin_SOURCES = admin_client.c cause.c
+genextension_SOURCES = genext.c options.c extension.c
+# genrc, gentones, genwave are made automaticaly
+lcrwatch_SOURCES = watch.c
+#gentones: gentones.c
+#genwave:genwave.c
+#genrc: genrc.c
+
+
+# test rule, nothing important
+#echo:
+#      -echo $(all_libraries) >&2
+
+
+# CAUTION: CRUDE CRUDE HACK !!
+# This transforms all compiling and linking calls from gcc into g++
+# This should better be removed and all .c files renamed to .cpp
+COMPILE=$(CXXCOMPILE)
+LINK=$(CXXLINK)
+# in the end, it should look like:
+# g++ -c -Wall -g -DINSTALL_DATA=\"/usr/local/lcr\" -I/usr/src/linux/include -I../mISDNuser/include -DPBX -DCRYPTO -I/usr/local/ssl/include route.cpp -o route.o
+
+
+
+pkglogdir=$(localstatedir)/log/@PACKAGE@
+# install runtime config in $prefix/etc/pbx4linux/ (e.g. /etc/pbx4linux)
+# and voice data in $prefix/share/pbx4linux/ (e.g. /usr/share/pbx4linux)
+pkgsysconfdir=$(sysconfdir)/@PACKAGE@
+dist_pkgsysconf_DATA = $(config_default)
+
+# install all voice data files along with their directory structure
+# into $prefix/share/pbx4linux
+nobase_dist_pkgdata_DATA = $(vbox_english) $(vbox_german) \
+       $(tones_american) $(tones_efi) $(tones_german)
+
+
+config_default = \
+       default/directory.list \
+       default/interface.conf \
+       default/options.conf \
+       default/routing.conf
+
+tones_american = \
+       tones_american/activated_loop.isdn \
+       tones_american/busy_loop.isdn \
+       tones_american/cause_01_loop.isdn \
+       tones_american/cause_02_loop.isdn \
+       tones_american/cause_03_loop.isdn \
+       tones_american/cause_05_loop.isdn \
+       tones_american/cause_06_loop.isdn \
+       tones_american/cause_12_loop.isdn \
+       tones_american/cause_13_loop.isdn \
+       tones_american/cause_14_loop.isdn \
+       tones_american/cause_15_loop.isdn \
+       tones_american/cause_16_loop.isdn \
+       tones_american/cause_1b_loop.isdn \
+       tones_american/cause_1c_loop.isdn \
+       tones_american/cause_1d_loop.isdn \
+       tones_american/cause_1f_loop.isdn \
+       tones_american/cause_22_loop.isdn \
+       tones_american/cause_26_loop.isdn \
+       tones_american/cause_29_loop.isdn \
+       tones_american/cause_2a_loop.isdn \
+       tones_american/cause_2f_loop.isdn \
+       tones_american/cause_31_loop.isdn \
+       tones_american/cause_32_loop.isdn \
+       tones_american/cause_39_loop.isdn \
+       tones_american/cause_3a_loop.isdn \
+       tones_american/cause_3f_loop.isdn \
+       tones_american/cause_41_loop.isdn \
+       tones_american/cause_42_loop.isdn \
+       tones_american/cause_45_loop.isdn \
+       tones_american/cause_46_loop.isdn \
+       tones_american/cause_55_loop.isdn \
+       tones_american/cause_80_loop.isdn \
+       tones_american/cause_81_loop.isdn \
+       tones_american/cause_82_loop.isdn \
+       tones_american/cause_83_loop.isdn \
+       tones_american/cause_84_loop.isdn \
+       tones_american/cause_85_loop.isdn \
+       tones_american/cause_86_loop.isdn \
+       tones_american/cause_87_loop.isdn \
+       tones_american/crypt_off.isdn \
+       tones_american/crypt_on.isdn \
+       tones_american/deactivated_loop.isdn \
+       tones_american/dialpbx.isdn \
+       tones_american/dialpbx_loop.isdn \
+       tones_american/error_loop.isdn \
+       tones_american/hold_loop.isdn \
+       tones_american/password_loop.isdn \
+       tones_american/redial.isdn \
+       tones_american/ringing_loop.isdn \
+       tones_american/ringpbx_loop.isdn \
+       tones_american/test_loop.isdn
+
+tones_efi = \
+       tones_efi/die.isdn \
+       tones_efi/number_00.isdn \
+       tones_efi/number_01.isdn \
+       tones_efi/number_02.isdn \
+       tones_efi/number_03.isdn \
+       tones_efi/number_04.isdn \
+       tones_efi/number_05.isdn \
+       tones_efi/number_06.isdn \
+       tones_efi/number_07.isdn \
+       tones_efi/number_08.isdn \
+       tones_efi/number_09.isdn
+
+tones_german = \
+       tones_german/activated_loop.isdn \
+       tones_german/busy_loop.isdn \
+       tones_german/cause_01_loop.isdn \
+       tones_german/cause_02_loop.isdn \
+       tones_german/cause_03_loop.isdn \
+       tones_german/cause_05_loop.isdn \
+       tones_german/cause_06_loop.isdn \
+       tones_german/cause_12_loop.isdn \
+       tones_german/cause_13_loop.isdn \
+       tones_german/cause_14_loop.isdn \
+       tones_german/cause_15_loop.isdn \
+       tones_german/cause_16_loop.isdn \
+       tones_german/cause_1b_loop.isdn \
+       tones_german/cause_1c_loop.isdn \
+       tones_german/cause_1d_loop.isdn \
+       tones_german/cause_1f_loop.isdn \
+       tones_german/cause_22_loop.isdn \
+       tones_german/cause_26_loop.isdn \
+       tones_german/cause_29_loop.isdn \
+       tones_german/cause_2a_loop.isdn \
+       tones_german/cause_2f_loop.isdn \
+       tones_german/cause_31_loop.isdn \
+       tones_german/cause_32_loop.isdn \
+       tones_german/cause_39_loop.isdn \
+       tones_german/cause_3a_loop.isdn \
+       tones_german/cause_3f_loop.isdn \
+       tones_german/cause_41_loop.isdn \
+       tones_german/cause_42_loop.isdn \
+       tones_german/cause_45_loop.isdn \
+       tones_german/cause_46_loop.isdn \
+       tones_german/cause_55_loop.isdn \
+       tones_german/cause_80_loop.isdn \
+       tones_german/cause_81_loop.isdn \
+       tones_german/cause_82_loop.isdn \
+       tones_german/cause_83_loop.isdn \
+       tones_german/cause_84_loop.isdn \
+       tones_german/cause_85_loop.isdn \
+       tones_german/cause_86_loop.isdn \
+       tones_german/cause_87_loop.isdn \
+       tones_german/deactivated_loop.isdn \
+       tones_german/dialpbx_loop.isdn \
+       tones_german/dialtone_loop.isdn \
+       tones_german/error_loop.isdn \
+       tones_german/password_loop.isdn \
+       tones_german/redial.isdn \
+       tones_german/release_loop.isdn \
+       tones_german/ringing.isdn \
+       tones_german/ringing_loop.isdn \
+       tones_german/ringpbx_loop.isdn \
+       tones_german/test_loop.isdn
+
+vbox_english = \
+       vbox_english/call_anonymous.isdn \
+       vbox_english/call_from.isdn \
+       vbox_english/day_01.isdn \
+       vbox_english/day_02.isdn \
+       vbox_english/day_03.isdn \
+       vbox_english/day_04.isdn \
+       vbox_english/day_05.isdn \
+       vbox_english/day_06.isdn \
+       vbox_english/day_07.isdn \
+       vbox_english/day_08.isdn \
+       vbox_english/day_09.isdn \
+       vbox_english/day_10.isdn \
+       vbox_english/day_11.isdn \
+       vbox_english/day_12.isdn \
+       vbox_english/day_13.isdn \
+       vbox_english/day_14.isdn \
+       vbox_english/day_15.isdn \
+       vbox_english/day_16.isdn \
+       vbox_english/day_17.isdn \
+       vbox_english/day_18.isdn \
+       vbox_english/day_19.isdn \
+       vbox_english/day_20.isdn \
+       vbox_english/day_21.isdn \
+       vbox_english/day_22.isdn \
+       vbox_english/day_23.isdn \
+       vbox_english/day_24.isdn \
+       vbox_english/day_25.isdn \
+       vbox_english/day_26.isdn \
+       vbox_english/day_27.isdn \
+       vbox_english/day_28.isdn \
+       vbox_english/day_29.isdn \
+       vbox_english/day_30.isdn \
+       vbox_english/day_31.isdn \
+       vbox_english/delete_ask.isdn \
+       vbox_english/delete_done.isdn \
+       vbox_english/intro.isdn \
+       vbox_english/menu.isdn \
+       vbox_english/minute.isdn \
+       vbox_english/minutes.isdn \
+       vbox_english/month_01.isdn \
+       vbox_english/month_02.isdn \
+       vbox_english/month_03.isdn \
+       vbox_english/month_04.isdn \
+       vbox_english/month_05.isdn \
+       vbox_english/month_06.isdn \
+       vbox_english/month_07.isdn \
+       vbox_english/month_08.isdn \
+       vbox_english/month_09.isdn \
+       vbox_english/month_10.isdn \
+       vbox_english/month_11.isdn \
+       vbox_english/month_12.isdn \
+       vbox_english/nothing.isdn \
+       vbox_english/number_00.isdn \
+       vbox_english/number_01.isdn \
+       vbox_english/number_02.isdn \
+       vbox_english/number_03.isdn \
+       vbox_english/number_04.isdn \
+       vbox_english/number_05.isdn \
+       vbox_english/number_06.isdn \
+       vbox_english/number_07.isdn \
+       vbox_english/number_08.isdn \
+       vbox_english/number_09.isdn \
+       vbox_english/number_10.isdn \
+       vbox_english/number_11.isdn \
+       vbox_english/number_12.isdn \
+       vbox_english/number_13.isdn \
+       vbox_english/number_14.isdn \
+       vbox_english/number_15.isdn \
+       vbox_english/number_16.isdn \
+       vbox_english/number_17.isdn \
+       vbox_english/number_18.isdn \
+       vbox_english/number_19.isdn \
+       vbox_english/number_20.isdn \
+       vbox_english/number_21.isdn \
+       vbox_english/number_22.isdn \
+       vbox_english/number_23.isdn \
+       vbox_english/number_24.isdn \
+       vbox_english/number_25.isdn \
+       vbox_english/number_26.isdn \
+       vbox_english/number_27.isdn \
+       vbox_english/number_28.isdn \
+       vbox_english/number_29.isdn \
+       vbox_english/number_30.isdn \
+       vbox_english/number_31.isdn \
+       vbox_english/number_32.isdn \
+       vbox_english/number_33.isdn \
+       vbox_english/number_34.isdn \
+       vbox_english/number_35.isdn \
+       vbox_english/number_36.isdn \
+       vbox_english/number_37.isdn \
+       vbox_english/number_38.isdn \
+       vbox_english/number_39.isdn \
+       vbox_english/number_40.isdn \
+       vbox_english/number_41.isdn \
+       vbox_english/number_42.isdn \
+       vbox_english/number_43.isdn \
+       vbox_english/number_44.isdn \
+       vbox_english/number_45.isdn \
+       vbox_english/number_46.isdn \
+       vbox_english/number_47.isdn \
+       vbox_english/number_48.isdn \
+       vbox_english/number_49.isdn \
+       vbox_english/number_50.isdn \
+       vbox_english/number_51.isdn \
+       vbox_english/number_52.isdn \
+       vbox_english/number_53.isdn \
+       vbox_english/number_54.isdn \
+       vbox_english/number_55.isdn \
+       vbox_english/number_56.isdn \
+       vbox_english/number_57.isdn \
+       vbox_english/number_58.isdn \
+       vbox_english/number_59.isdn \
+       vbox_english/oclock_am.isdn \
+       vbox_english/oclock_pm.isdn \
+       vbox_english/pause.isdn \
+       vbox_english/play.isdn \
+       vbox_english/record_ask.isdn \
+       vbox_english/record_play.isdn \
+       vbox_english/record_record.isdn \
+       vbox_english/store_ask.isdn \
+       vbox_english/store_done.isdn
+
+vbox_german = \
+       vbox_german/call_anonymous.isdn \
+       vbox_german/call_from.isdn \
+       vbox_german/day_01.isdn \
+       vbox_german/day_02.isdn \
+       vbox_german/day_03.isdn \
+       vbox_german/day_04.isdn \
+       vbox_german/day_05.isdn \
+       vbox_german/day_06.isdn \
+       vbox_german/day_07.isdn \
+       vbox_german/day_08.isdn \
+       vbox_german/day_09.isdn \
+       vbox_german/day_10.isdn \
+       vbox_german/day_11.isdn \
+       vbox_german/day_12.isdn \
+       vbox_german/day_13.isdn \
+       vbox_german/day_14.isdn \
+       vbox_german/day_15.isdn \
+       vbox_german/day_16.isdn \
+       vbox_german/day_17.isdn \
+       vbox_german/day_18.isdn \
+       vbox_german/day_19.isdn \
+       vbox_german/day_20.isdn \
+       vbox_german/day_21.isdn \
+       vbox_german/day_22.isdn \
+       vbox_german/day_23.isdn \
+       vbox_german/day_24.isdn \
+       vbox_german/day_25.isdn \
+       vbox_german/day_26.isdn \
+       vbox_german/day_27.isdn \
+       vbox_german/day_28.isdn \
+       vbox_german/day_29.isdn \
+       vbox_german/day_30.isdn \
+       vbox_german/day_31.isdn \
+       vbox_german/delete_ask.isdn \
+       vbox_german/delete_done.isdn \
+       vbox_german/intro.isdn \
+       vbox_german/menu.isdn \
+       vbox_german/minute.isdn \
+       vbox_german/minutes.isdn \
+       vbox_german/month_01.isdn \
+       vbox_german/month_02.isdn \
+       vbox_german/month_03.isdn \
+       vbox_german/month_04.isdn \
+       vbox_german/month_05.isdn \
+       vbox_german/month_06.isdn \
+       vbox_german/month_07.isdn \
+       vbox_german/month_08.isdn \
+       vbox_german/month_09.isdn \
+       vbox_german/month_10.isdn \
+       vbox_german/month_11.isdn \
+       vbox_german/month_12.isdn \
+       vbox_german/nothing.isdn \
+       vbox_german/number_00.isdn \
+       vbox_german/number_01.isdn \
+       vbox_german/number_02.isdn \
+       vbox_german/number_03.isdn \
+       vbox_german/number_04.isdn \
+       vbox_german/number_05.isdn \
+       vbox_german/number_06.isdn \
+       vbox_german/number_07.isdn \
+       vbox_german/number_08.isdn \
+       vbox_german/number_09.isdn \
+       vbox_german/number_10.isdn \
+       vbox_german/number_11.isdn \
+       vbox_german/number_12.isdn \
+       vbox_german/number_13.isdn \
+       vbox_german/number_14.isdn \
+       vbox_german/number_15.isdn \
+       vbox_german/number_16.isdn \
+       vbox_german/number_17.isdn \
+       vbox_german/number_18.isdn \
+       vbox_german/number_19.isdn \
+       vbox_german/number_20.isdn \
+       vbox_german/number_21.isdn \
+       vbox_german/number_22.isdn \
+       vbox_german/number_23.isdn \
+       vbox_german/number_24.isdn \
+       vbox_german/number_25.isdn \
+       vbox_german/number_26.isdn \
+       vbox_german/number_27.isdn \
+       vbox_german/number_28.isdn \
+       vbox_german/number_29.isdn \
+       vbox_german/number_30.isdn \
+       vbox_german/number_31.isdn \
+       vbox_german/number_32.isdn \
+       vbox_german/number_33.isdn \
+       vbox_german/number_34.isdn \
+       vbox_german/number_35.isdn \
+       vbox_german/number_36.isdn \
+       vbox_german/number_37.isdn \
+       vbox_german/number_38.isdn \
+       vbox_german/number_39.isdn \
+       vbox_german/number_40.isdn \
+       vbox_german/number_41.isdn \
+       vbox_german/number_42.isdn \
+       vbox_german/number_43.isdn \
+       vbox_german/number_44.isdn \
+       vbox_german/number_45.isdn \
+       vbox_german/number_46.isdn \
+       vbox_german/number_47.isdn \
+       vbox_german/number_48.isdn \
+       vbox_german/number_49.isdn \
+       vbox_german/number_50.isdn \
+       vbox_german/number_51.isdn \
+       vbox_german/number_52.isdn \
+       vbox_german/number_53.isdn \
+       vbox_german/number_54.isdn \
+       vbox_german/number_55.isdn \
+       vbox_german/number_56.isdn \
+       vbox_german/number_57.isdn \
+       vbox_german/number_58.isdn \
+       vbox_german/number_59.isdn \
+       vbox_german/number_eine.isdn \
+       vbox_german/number_ein.isdn \
+       vbox_german/oclock.isdn \
+       vbox_german/pause.isdn \
+       vbox_german/play.isdn \
+       vbox_german/record_ask.isdn \
+       vbox_german/record_play.isdn \
+       vbox_german/record_record.isdn \
+       vbox_german/store_ask.isdn \
+       vbox_german/store_done.isdn
diff --git a/NEWS b/NEWS
new file mode 100644 (file)
index 0000000..e69de29
diff --git a/acinclude.m4 b/acinclude.m4
new file mode 100644 (file)
index 0000000..816bd1f
--- /dev/null
@@ -0,0 +1,797 @@
+
+
+
+dnl ------------------------------------------------------------------------
+dnl create a small program to test the settings of mISDNuser package
+dnl ------------------------------------------------------------------------
+# ported from the KDE project
+AC_DEFUN([PBX_PRINT_MISDNUSER_PROGRAM],
+[
+cat > conftest.$ac_ext <<EOF
+#ifdef __cplusplus
+extern "C" {
+#endif
+#include <isdn_net.h>
+#include <mISDNlib.h>
+#ifdef __cplusplus
+}
+#endif
+
+int main()
+{
+       /* TODO: try to reference some function here */
+       return 0;
+}
+EOF
+])
+
+dnl ------------------------------------------------------------------------
+dnl create a small program to test the settings of mISDN package
+dnl ------------------------------------------------------------------------
+# ported from the KDE project
+AC_DEFUN([PBX_PRINT_MISDNKERNEL_PROGRAM],
+[
+cat > conftest.$ac_ext <<EOF
+#ifdef __cplusplus
+extern "C" {
+#endif
+#include <mISDNlib.h>
+#include <linux/isdn_compat.h>
+#include <linux/mISDNif.h>
+#ifdef __cplusplus
+}
+#endif
+
+#define MISDN_MAJOR_VERSION_TEST $misdn_kernel_major_version_demand
+#define MISDN_MINOR_VERSION_TEST $misdn_kernel_minor_version_demand
+#define MISDN_VERSION_TEST     ((MISDN_MAJOR_VERSION_TEST<<16) | MISDN_MINOR_VERSION_TEST)
+//#define MISDN_VERSION           ((MISDN_MAJOR_VERSION<<16) | MISDN_MINOR_VERSION)
+
+#if (MISDN_VERSION < MISDN_VERSION_TEST)
+# error mISDN version mismatch. Need at least $misdn_kernel_major_version_demand.$misdn_kernel_minor_version_demand
+#endif
+
+
+int main()
+{
+       static u16 sum1;
+       /* access some constants from misdn kernel headers */
+       u16 v1 = CMX_TXDATA_ON;
+       u16 v2 = CMX_TXDATA_OFF;
+       u16 v3 = CMX_DELAY;
+       u16 v4 = CMX_TX_DATA;
+       u16 v5 = CMX_JITTER;
+       
+       /* extend here more variables or function call
+        * to access more header information */
+        
+       
+       /* anti optimisation constuct */
+       sum1 = v1 + v2 + v3 + v4 + v5;
+       
+       return 0;
+}
+EOF
+])
+
+
+
+dnl prints a program.
+dnl $1 is the include file
+dnl $2 is the prefix before include
+dnl $3 is the suffix, e.g. some variable or class definitions
+dnl $4 is the program body within main()
+AC_DEFUN([PBX_PRINT_PROGRAM],
+[AC_LANG_PROGRAM([$2
+$1
+
+$3],
+[$4])
+])
+
+
+
+dnl ------------------------------------------------------------------------
+dnl if --enable-debug, it disables optimisation and enables debugging symbols
+dnl if --disable-debug (default) other way around
+dnl ------------------------------------------------------------------------
+AC_DEFUN([AC_CHECK_COMPILERS],
+[# taken from KDE project
+
+  # enable debugging options on demand
+  DEBUGGING=
+  AC_ARG_ENABLE([debug],
+                [AS_HELP_STRING([--enable-debug],
+                                [enable debugging symbols, turns off compiler optimisations (default=disable)])
+                ],
+                [use_debug_code="yes"],
+                [use_debug_code="no"]
+               )
+  AM_CONDITIONAL(ENABLE_DEBUGGING, test "x$DEBUGGING" == "xyes" )
+  AC_ARG_ENABLE(dummyoption,
+                AC_HELP_STRING([--disable-debug],
+                               [disables debugging symbols, turns on compiler optimisations]),
+                [:],
+                [:]
+               )
+
+  dnl this prevents stupid AC_PROG_CC to add "-g" to the default CFLAGS
+  CFLAGS=" $CFLAGS"
+  AC_PROG_CC
+  AC_PROG_CPP
+  
+  if test "$GCC" = "yes" ; then
+    if test "$use_debug_code" != "no"; then
+      CFLAGS="-g -O0 $CFLAGS"
+    else
+      CFLAGS="-O2 $CFLAGS"
+    fi
+  fi
+  
+  if test -z "$LDFLAGS" && test "$use_debug_code" = "no" && test "$GCC" = "yes"; then
+    LDFLAGS=""
+  fi
+  
+  CXXFLAGS=" $CXXFLAGS"
+  AC_PROG_CXX
+  
+  if test "$GXX" = "yes" ; then
+    if test "$use_debug_code" != "no"; then
+      CXXFLAGS="-g -O0 $CXXFLAGS"
+    else
+      CXXFLAGS="-O2 $CXXFLAGS"
+    fi
+  fi
+  
+])
+
+
+dnl ------------------------------------------------------------------------
+dnl Try to find the mISDN-user headers and libraries.
+dnl $(MISDN_LDFLAGS) will be -Lmisdnliblocation (if needed)
+dnl and $(MISDN_INCLUDES) will be -Imisdnhdrlocation (if needed)
+dnl ------------------------------------------------------------------------
+dnl
+AC_DEFUN([AC_PATH_MISDNUSER],
+[
+dnl AC_REQUIRE([K_PATH_X])
+dnl AC_REQUIRE([KDE_USE_MISDN])
+dnl AC_REQUIRE([KDE_CHECK_LIB64])
+
+dnl ------------------------------------------------------------------------
+dnl Add configure flag to enable linking to MT version of mISDN-user library.
+dnl ------------------------------------------------------------------------
+
+dnl AC_ARG_ENABLE(
+dnl   mt,
+dnl   AC_HELP_STRING([--disable-mt],[link to non-threaded mISDN-user (deprecated)]),
+dnl   pbx_use_misdn_mt=$enableval,
+dnl   [
+dnl     if test $pbx_misdnver = 3; then
+dnl       pbx_use_misdn_mt=yes
+dnl     else
+dnl       pbx_use_misdn_mt=no
+dnl     fi
+dnl   ]
+dnl )
+
+dnl USING_MISDN_MT=""
+
+dnl ------------------------------------------------------------------------
+dnl If we not get --disable-misdn-mt then adjust some vars for the host.
+dnl ------------------------------------------------------------------------
+
+dnl KDE_MT_LDFLAGS=
+dnl KDE_MT_LIBS=
+dnl if test "x$pbx_use_misdn_mt" = "xyes"; then
+dnl   KDE_CHECK_THREADING
+dnl   if test "x$pbx_use_threading" = "xyes"; then
+dnl     CPPFLAGS="$USE_THREADS -DMISDN_THREAD_SUPPORT $CPPFLAGS"
+dnl     KDE_MT_LDFLAGS="$USE_THREADS"
+dnl     KDE_MT_LIBS="$LIBPTHREAD"
+dnl   else
+dnl     pbx_use_misdn_mt=no
+dnl   fi
+dnl fi
+dnl AC_SUBST(KDE_MT_LDFLAGS)
+dnl AC_SUBST(KDE_MT_LIBS)
+
+dnl pbx_misdn_was_given=yes
+
+dnl ------------------------------------------------------------------------
+dnl If we haven't been told how to link to mISDN-user, we work it out for ourselves.
+dnl ------------------------------------------------------------------------
+dnl if test -z "$LIBMISDN_GLOB"; then
+dnl   if test "x$pbx_use_misdn_emb" = "xyes"; then
+dnl     LIBMISDN_GLOB="libmisdne.*"
+dnl   else
+dnl     LIBMISDN_GLOB="libmisdn.*"
+dnl   fi
+dnl fi
+
+dnl ------------------------------------------------------------
+dnl If we got --enable-embedded then adjust the mISDN-user library name.
+dnl ------------------------------------------------------------
+dnl if test "x$pbx_use_misdn_emb" = "xyes"; then
+dnl   misdnlib="misdne"
+dnl else
+   misdnlib="mISDN"
+dnl fi
+
+dnl pbx_int_misdn="-l$misdnlib"
+
+dnl if test -z "$LIBQPE"; then
+dnl ------------------------------------------------------------
+dnl If we got --enable-palmtop then add -lqpe to the link line
+dnl ------------------------------------------------------------
+dnl   if test "x$pbx_use_misdn_emb" = "xyes"; then
+dnl     if test "x$pbx_use_misdn_emb_palm" = "xyes"; then
+dnl       LIB_QPE="-lqpe"
+dnl     else
+dnl       LIB_QPE=""
+dnl     fi
+dnl   else
+dnl     LIB_QPE=""
+dnl   fi
+dnl fi
+
+dnl ------------------------------------------------------------------------
+dnl If we got --enable-misdn-mt then adjust the mISDN-user library name for the host.
+dnl ------------------------------------------------------------------------
+
+dnl if test "x$pbx_use_misdn_mt" = "xyes"; then
+dnl   LIBMISDN="-l$misdnlib-mt"
+dnl   pbx_int_misdn="-l$misdnlib-mt"
+dnl   LIBMISDN_GLOB="lib$misdnlib-mt.*"
+dnl   USING_MISDN_MT="using -mt"
+dnl else
+dnl   LIBMISDN="-l$misdnlib"
+dnl fi
+
+dnl if test $pbx_misdnver != 1; then
+
+dnl   AC_REQUIRE([AC_FIND_PNG])
+dnl   AC_REQUIRE([AC_FIND_JPEG])
+dnl   LIBMISDN="$LIBMISDN $LIBPNG $LIBJPEG"
+dnl fi
+
+dnl if test $pbx_misdnver = 3; then
+dnl   AC_REQUIRE([KDE_CHECK_LIBDL])
+dnl   LIBMISDN="$LIBMISDN $LIBDL"
+dnl fi
+
+dnl probably there could be a whole installation of misdn
+pbx_misdn_dirs="/usr/local/mISDNuser /usr/local/misdn /usr/lib/mISDNuser /usr/lib/misdn"
+
+
+AC_MSG_CHECKING([for mISDN-user])
+LIBMISDN="-l$misdnlib -lisdnnet"
+
+dnl if test "x$pbx_use_misdn_emb" != "xyes" && test "x$pbx_use_misdn_mac" != "xyes"; then
+dnl LIBMISDN="$LIBMISDN $X_PRE_LIBS -lXext -lX11 $LIBSM $LIBSOCKET"
+dnl fi
+ac_misdnuser_includes=NO ac_misdnuser_libraries=NO ac_misdnuser_bindir=NO
+misdnuser_libraries=""
+misdnuser_includes=""
+AC_ARG_WITH(misdnuser-dir,
+    AC_HELP_STRING([--with-misdnuser-dir=DIR],[where the root of mISDN-user is installed]),
+    [  ac_misdnuser_includes="$withval"/include
+       ac_misdnuser_libraries="$withval"/lib
+       ac_misdnuser_bindir="$withval"/bin
+    ])
+
+AC_ARG_WITH(misdnuser-includes,
+    AC_HELP_STRING([--with-misdnuser-includes=DIR],[where the mISDN-user includes are (default=$with-misdnuser-dir/include)]),
+    [
+       ac_misdnuser_includes="$withval"
+    ])
+
+pbx_misdn_libs_given=no
+
+AC_ARG_WITH(misdnuser-libraries,
+    AC_HELP_STRING([--with-misdnuser-libraries=DIR],[where the mISDN-user library is installed (default=$with-misdnuser-dir/lib)]),
+    [  ac_misdnuser_libraries="$withval"
+       pbx_misdn_libs_given=yes
+    ])
+
+AC_CACHE_VAL(ac_cv_have_misdn,
+[#try to guess mISDN-user locations
+
+misdn_incdirs=""
+for dir in $pbx_misdn_dirs; do
+   misdn_incdirs="$misdn_incdirs $dir/include $dir"
+done
+misdn_incdirs="$MISDNINC $misdn_incdirs /usr/include/mISDNuser /usr/include/misdn /usr/include"
+if test ! "$ac_misdnuser_includes" = "NO"; then
+   misdn_incdirs="$ac_misdnuser_includes $misdn_incdirs"
+fi
+
+dnl if test "$pbx_misdnver" != "1"; then
+  pbx_misdn_header=mISDNlib.h
+dnl  ->  und auch "isdn_net.h"
+dnl else
+dnl  pbx_misdn_header=qglobal.h
+dnl fi
+
+AC_FIND_FILE($pbx_misdn_header, $misdn_incdirs, misdn_incdir)
+ac_misdnuser_includes="$misdn_incdir"
+
+misdn_libdirs=""
+for dir in $pbx_misdn_dirs; do
+   misdn_libdirs="$misdn_libdirs $dir/lib $dir"
+done
+misdn_libdirs="$MISDNLIB $misdn_libdirs /usr/lib /usr/local/lib"
+if test ! "$ac_misdnuser_libraries" = "NO"; then
+  misdn_libdir=$ac_misdnuser_libraries
+else
+  misdn_libdirs="$ac_misdnuser_libraries $misdn_libdirs"
+  # if the mISDN-user was given, the chance is too big that libmisdn.* doesn't exist
+  misdn_libdir=NONE
+  for dir in $misdn_libdirs; do
+    try="ls -1 $dir/${LIBMISDN_GLOB}"
+    if test -n "`$try 2> /dev/null`"; then misdn_libdir=$dir; break; else echo "tried $dir" >&AC_FD_CC ; fi
+  done
+fi
+for a in $misdn_libdir/lib`echo ${pbx_int_misdn} | sed 's,^-l,,'`_incremental.*; do
+  if test -e "$a"; then
+    LIBMISDN="$LIBMISDN ${pbx_int_misdn}_incremental"
+    break
+  fi
+done
+
+ac_misdnuser_libraries="$misdn_libdir"
+
+AC_LANG_SAVE
+AC_LANG_CPLUSPLUS
+
+ac_cxxflags_safe="$CXXFLAGS"
+ac_ldflags_safe="$LDFLAGS"
+ac_libs_safe="$LIBS"
+
+CXXFLAGS="$CXXFLAGS -I$misdn_incdir $all_includes"
+LDFLAGS="$LDFLAGS -L$misdn_libdir $all_libraries $USER_LDFLAGS"
+LIBS="$LIBS $LIBMISDN"
+
+PBX_PRINT_MISDNUSER_PROGRAM
+
+if AC_TRY_EVAL(ac_link) && test -s conftest; then
+  rm -f conftest*
+else
+  echo "configure: failed program was:" >&AC_FD_CC
+  cat conftest.$ac_ext >&AC_FD_CC
+  ac_misdnuser_libraries="NO"
+fi
+rm -f conftest*
+CXXFLAGS="$ac_cxxflags_safe"
+LDFLAGS="$ac_ldflags_safe"
+LIBS="$ac_libs_safe"
+
+AC_LANG_RESTORE
+if test "$ac_misdnuser_includes" = NO || test "$ac_misdnuser_libraries" = NO; then
+  ac_cv_have_misdn="have_misdn=no"
+  ac_misdnuser_notfound=""
+  missing_misdn_mt=""
+  if test "$ac_misdnuser_includes" = NO; then
+    if test "$ac_misdnuser_libraries" = NO; then
+      ac_misdnuser_notfound="(headers and libraries)";
+    else
+      ac_misdnuser_notfound="(headers)";
+    fi
+  else
+dnl     if test "x$pbx_use_misdn_mt" = "xyes"; then
+dnl        missing_misdn_mt="Make sure that you have compiled mISDN-user with thread support!"
+dnl        ac_misdnuser_notfound="(library $misdnlib-mt)";
+dnl     else
+       ac_misdnuser_notfound="(library $misdnlib)";
+dnl     fi
+  fi
+
+  AC_MSG_ERROR([mISDN-user ($pbx_misdn_minversion) $ac_misdnuser_notfound not found. Please check your installation!
+For more details about this problem, look at the end of config.log.$missing_misdn_mt])
+else
+  have_misdn="yes"
+fi
+])
+
+
+eval "$ac_cv_have_misdn"
+
+if test "$have_misdn" != yes; then
+  AC_MSG_RESULT([$have_misdn]);
+else
+  ac_cv_have_misdn="have_misdn=yes \
+    ac_misdnuser_includes=$ac_misdnuser_includes ac_misdnuser_libraries=$ac_misdnuser_libraries"
+  AC_MSG_RESULT([libraries $ac_misdnuser_libraries, headers $ac_misdnuser_includes $USING_MISDN_MT])
+
+  misdnuser_libraries="$ac_misdnuser_libraries"
+  misdnuser_includes="$ac_misdnuser_includes"
+fi
+
+dnl if test ! "$pbx_misdn_libs_given" = "yes" && test ! "$pbx_misdnver" = 3; then
+dnl      KDE_CHECK_MISDN_DIRECT(misdnuser_libraries= ,[])
+dnl fi
+
+AC_SUBST(misdnuser_libraries)
+AC_SUBST(misdnuser_includes)
+
+if test -z "$misdnuser_includes"; then
+ MISDN_INCLUDES=""
+else
+ MISDN_INCLUDES="-I$misdnuser_includes"
+ all_includes="$MISDN_INCLUDES $all_includes"
+fi
+
+if test -z "$misdnuser_libraries"; then
+ MISDN_LDFLAGS=""
+else
+ MISDN_LDFLAGS="-L$misdnuser_libraries"
+ all_libraries="$MISDN_LDFLAGS $all_libraries"
+fi
+dnl test -z "$KDE_MT_LDFLAGS" || all_libraries="$all_libraries $KDE_MT_LDFLAGS"
+
+AC_SUBST(MISDN_INCLUDES)
+AC_SUBST(MISDN_LDFLAGS)
+dnl AC_PATH_MISDN_MOC_UIC
+
+dnl KDE_CHECK_MISDN_JPEG
+
+dnl if test "x$pbx_use_misdn_emb" != "xyes" && test "x$pbx_use_misdn_mac" != "xyes"; then
+dnl LIB_MISDN="$pbx_int_misdn $LIBJPEG_MISDN "'$(LIBZ) $(LIBPNG) -lXext $(LIB_X11) $(LIBSM)'
+dnl else
+dnl LIB_MISDN="$pbx_int_misdn $LIBJPEG_MISDN "'$(LIBZ) $(LIBPNG)'
+dnl fi
+dnl test -z "$KDE_MT_LIBS" || LIB_MISDN="$LIB_MISDN $KDE_MT_LIBS"
+dnl for a in $misdn_libdir/lib`echo ${pbx_int_misdn} | sed 's,^-l,,'`_incremental.*; do
+dnl   if test -e "$a"; then
+dnl      LIB_MISDN="$LIB_MISDN ${pbx_int_misdn}_incremental"
+dnl      break
+dnl   fi
+dnl done
+
+AC_SUBST(LIB_MISDN)
+dnl AC_SUBST(LIB_QPE)
+
+AC_SUBST(pbx_misdnver)
+
+])
+
+
+
+dnl ------------------------------------------------------------------------
+dnl Try to find the mISDN-kernel headers.
+dnl $(MISDNKERNEL_INCLUDES) will be -Imisdnkernelhdrlocation (if needed)
+dnl ------------------------------------------------------------------------
+dnl
+AC_DEFUN([AC_PATH_MISDNKERNEL],
+[
+
+   misdnlib="mISDN"
+misdn_kernel_major_version_demand=6
+misdn_kernel_minor_version_demand=0
+lcr_misdn_kernel_minversion=$misdn_kernel_major_version_demand.$misdn_kernel_minor_version_demand
+
+dnl ## TODO !! convert misdnuser variables to misdn kernel header variables
+
+dnl probably there could be a whole installation of misdn
+kernel_ver=$(uname -r)
+misdn_kernelheader_dirs="/lib/modules/$kernel_ver/source/include /usr/src/linux/include/"
+
+
+AC_MSG_CHECKING([for mISDN-kernel])
+dnl LIBMISDN="-l$misdnlib -lisdnnet"
+dnl 
+dnl if test "x$pbx_use_misdn_emb" != "xyes" && test "x$pbx_use_misdn_mac" != "xyes"; then
+dnl LIBMISDN="$LIBMISDN $X_PRE_LIBS -lXext -lX11 $LIBSM $LIBSOCKET"
+dnl fi
+dnl ac_misdnkernel_includes=NO ac_misdnkernel_libraries=NO ac_misdnkernel_bindir=NO
+ac_misdnkernel_includes=NO
+dnl misdnkernel_libraries=""
+misdnkernel_includes=""
+dnl AC_ARG_WITH(misdnkernel-dir,
+dnl     AC_HELP_STRING([--with-misdnkernel-dir=DIR],[where the mISDN-headers are installed ]),
+dnl     [  ac_misdnkernel_includes="$withval"/include
+dnl        ac_misdnkernel_libraries="$withval"/lib
+dnl        ac_misdnkernel_bindir="$withval"/bin
+dnl     ])
+
+AC_ARG_WITH(misdnkernel-includes,
+    AC_HELP_STRING([--with-misdnkernel-includes=DIR],[where the mISDN-kernel includes are. Used if enable-socket-misdn]),
+    [
+       ac_misdnkernel_includes="$withval"
+    ])
+
+dnl pbx_misdn_libs_given=no
+
+dnl AC_ARG_WITH(misdnkernel-libraries,
+dnl     AC_HELP_STRING([--with-misdnkernel-libraries=DIR],[where the mISDN-kernel library is installed.]),
+dnl     [  ac_misdnkernel_libraries="$withval"
+dnl        pbx_misdn_libs_given=yes
+dnl     ])
+
+AC_CACHE_VAL(ac_cv_have_misdnkernel,
+[#try to guess mISDN-user locations
+
+misdnkernel_incdirs=""
+for dir in $misdn_kernelheader_dirs; do
+   misdnkernel_incdirs="$misdnkernel_incdirs $dir/include $dir"
+done
+misdnkernel_incdirs="$MISDNKERNELINC $misdnkernel_incdirs /usr/include/mISDNuser /usr/include/misdn /usr/include"
+if test ! "$ac_misdnkernel_includes" = "NO"; then
+   misdnkernel_incdirs="$ac_misdnkernel_includes $misdnkernel_incdirs"
+fi
+
+  pbx_misdn_kernel_header=linux/mISDNif.h
+
+AC_FIND_FILE($pbx_misdn_kernel_header, $misdnkernel_incdirs, misdnkernel_incdir)
+ac_misdnkernel_includes="$misdnkernel_incdir"
+
+dnl misdn_libdirs=""
+dnl for dir in $misdn_kernelheader_dirs; do
+dnl    misdn_libdirs="$misdn_libdirs $dir/lib $dir"
+dnl done
+dnl misdn_libdirs="$MISDNLIB $misdn_libdirs /usr/lib /usr/local/lib"
+dnl if test ! "$ac_misdnkernel_libraries" = "NO"; then
+dnl   misdn_libdir=$ac_misdnkernel_libraries
+dnl else
+dnl   misdn_libdirs="$ac_misdnkernel_libraries $misdn_libdirs"
+dnl   # if the mISDN-user was given, the chance is too big that libmisdn.* doesn't exist
+dnl   misdn_libdir=NONE
+dnl   for dir in $misdn_libdirs; do
+dnl     try="ls -1 $dir/${LIBMISDN_GLOB}"
+dnl     if test -n "`$try 2> /dev/null`"; then misdn_libdir=$dir; break; else echo "tried $dir" >&AC_FD_CC ; fi
+dnl   done
+dnl fi
+dnl for a in $misdn_libdir/lib`echo ${pbx_int_misdn} | sed 's,^-l,,'`_incremental.*; do
+dnl   if test -e "$a"; then
+dnl     LIBMISDN="$LIBMISDN ${pbx_int_misdn}_incremental"
+dnl     break
+dnl   fi
+dnl done
+dnl 
+dnl ac_misdnkernel_libraries="$misdn_libdir"
+dnl 
+AC_LANG_SAVE
+AC_LANG_CPLUSPLUS
+
+ac_cxxflags_safe="$CXXFLAGS"
+ac_ldflags_safe="$LDFLAGS"
+ac_libs_safe="$LIBS"
+
+CXXFLAGS="$CXXFLAGS -I$misdnkernel_incdir $all_includes"
+LDFLAGS="$LDFLAGS -L$misdn_libdir $all_libraries $USER_LDFLAGS"
+LIBS="$LIBS $LIBMISDN"
+
+PBX_PRINT_MISDNKERNEL_PROGRAM
+
+if AC_TRY_EVAL(ac_compile) && test -s conftest.o; then
+  rm -f conftest*
+else
+  echo "configure: failed program was:" >&AC_FD_CC
+  cat conftest.$ac_ext >&AC_FD_CC
+  ac_misdnkernel_includes="NO"
+dnl   ac_misdnkernel_libraries="NO"
+fi
+rm -f conftest*
+CXXFLAGS="$ac_cxxflags_safe"
+LDFLAGS="$ac_ldflags_safe"
+LIBS="$ac_libs_safe"
+
+AC_LANG_RESTORE
+dnl if test "$ac_misdnkernel_includes" = NO || test "$ac_misdnkernel_libraries" = NO; then
+if test "$ac_misdnkernel_includes" = NO; then
+  ac_cv_have_misdnkernel="have_misdnkernel=no"
+  ac_misdnkernel_notfound=""
+  missing_misdn_mt=""
+dnl  if test "$ac_misdnkernel_includes" = NO; then
+dnl    if test "$ac_misdnkernel_libraries" = NO; then
+dnl      ac_misdnkernel_notfound="(headers and libraries)";
+dnl    else
+      ac_misdnkernel_notfound="(headers)";
+dnl    fi
+dnl  else
+dnl    ac_misdnkernel_notfound="(library $misdnlib)";
+dnl  fi
+
+  AC_MSG_ERROR([mISDN kernel header (version >= $lcr_misdn_kernel_minversion) not found. Please check your installation!
+For more details about this problem, look at the end of config.log.$missing_misdn_mt])
+else
+  have_misdnkernel="yes"
+fi
+])
+
+dnl check cache content
+dnl TODO: maybe move this to beginning (before compilation test?)
+eval "$ac_cv_have_misdnkernel"
+
+if test "$have_misdnkernel" != yes; then
+  AC_MSG_RESULT([$have_misdnkernel]);
+else
+  ac_cv_have_misdnkernel="have_misdnkernel=yes \
+   ac_misdnkernel_includes=$ac_misdnkernel_includes"
+dnl    ac_misdnkernel_libraries=$ac_misdnkernel_libraries"
+  AC_MSG_RESULT([headers $ac_misdnkernel_includes])
+
+dnl   misdnkernel_libraries="$ac_misdnkernel_libraries"
+  misdnkernel_includes="$ac_misdnkernel_includes"
+fi
+
+dnl if test ! "$pbx_misdn_libs_given" = "yes" && test ! "$pbx_misdnver" = 3; then
+dnl      KDE_CHECK_MISDN_DIRECT(misdnkernel_libraries= ,[])
+dnl fi
+
+dnl AC_SUBST(misdnkernel_libraries)
+AC_SUBST(misdnkernel_includes)
+
+if test -z "$misdnkernel_includes"; then
+ MISDNKERNEL_INCLUDES=""
+else
+ MISDNKERNEL_INCLUDES="-I$misdnkernel_includes"
+ all_includes="$MISDNKERNEL_INCLUDES $all_includes"
+fi
+
+dnl if test -z "$misdnkernel_libraries"; then
+dnl  MISDN_LDFLAGS=""
+dnl else
+dnl  MISDN_LDFLAGS="-L$misdnkernel_libraries"
+dnl  all_libraries="$MISDN_LDFLAGS $all_libraries"
+dnl fi
+dnl test -z "$KDE_MT_LDFLAGS" || all_libraries="$all_libraries $KDE_MT_LDFLAGS"
+
+AC_SUBST(MISDNKERNEL_INCLUDES)
+dnl AC_SUBST(MISDN_LDFLAGS)
+dnl AC_PATH_MISDN_MOC_UIC
+
+dnl KDE_CHECK_MISDN_JPEG
+
+dnl if test "x$pbx_use_misdn_emb" != "xyes" && test "x$pbx_use_misdn_mac" != "xyes"; then
+dnl LIB_MISDN="$pbx_int_misdn $LIBJPEG_MISDN "'$(LIBZ) $(LIBPNG) -lXext $(LIB_X11) $(LIBSM)'
+dnl else
+dnl LIB_MISDN="$pbx_int_misdn $LIBJPEG_MISDN "'$(LIBZ) $(LIBPNG)'
+dnl fi
+dnl test -z "$KDE_MT_LIBS" || LIB_MISDN="$LIB_MISDN $KDE_MT_LIBS"
+dnl for a in $misdn_libdir/lib`echo ${pbx_int_misdn} | sed 's,^-l,,'`_incremental.*; do
+dnl   if test -e "$a"; then
+dnl      LIB_MISDN="$LIB_MISDN ${pbx_int_misdn}_incremental"
+dnl      break
+dnl   fi
+dnl done
+
+dnl AC_SUBST(LIB_MISDN)
+dnl AC_SUBST(LIB_QPE)
+
+AC_SUBST(pbx_misdnver)
+
+])
+
+
+
+dnl ------------------------------------------------------------------------
+dnl Find a file (or one of more files in a list of dirs)
+dnl ------------------------------------------------------------------------
+AC_DEFUN([AC_FIND_FILE],
+[
+$3=NO
+for i in $2;
+do
+  for j in $1;
+  do
+    echo "configure: __oline__: $i/$j" >&AC_FD_CC
+    if test -r "$i/$j"; then
+      echo "taking that" >&AC_FD_CC
+      $3=$i
+      break 2
+    fi
+  done
+done
+])
+
+
+
+dnl ------------------------------------------------------------------------
+dnl Taken from http://autoconf-archive.cryp.to/ac_define_dir.html
+dnl Copyright © 2006 Stepan Kasal <kasal@ucw.cz>
+dnl Copyright © 2006 Andreas Schwab <schwab@suse.de>
+dnl Copyright © 2006 Guido U. Draheim <guidod@gmx.de>
+dnl Copyright © 2006 Alexandre Oliva
+dnl 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.
+dnl 
+dnl This macro sets VARNAME to the expansion of the DIR variable, taking care
+dnl  of fixing up ${prefix} and such.
+dnl ------------------------------------------------------------------------
+AC_DEFUN([AC_DEFINE_DIR], [
+  prefix_NONE=
+  exec_prefix_NONE=
+  test "x$prefix" = xNONE && prefix_NONE=yes && prefix=$ac_default_prefix
+  test "x$exec_prefix" = xNONE && exec_prefix_NONE=yes && exec_prefix=$prefix
+dnl In Autoconf 2.60, ${datadir} refers to ${datarootdir}, which in turn
+dnl refers to ${prefix}.  Thus we have to use `eval' twice.
+  eval ac_define_dir="\"[$]$2\""
+  eval ac_define_dir="\"$ac_define_dir\""
+  AC_SUBST($1, "$ac_define_dir")
+  AC_DEFINE_UNQUOTED($1, "$ac_define_dir", [$3])
+  test "$prefix_NONE" && prefix=NONE
+  test "$exec_prefix_NONE" && exec_prefix=NONE
+])
+
+
+dnl ------------------------------------------------------------------------
+dnl taken from http://autoconf-archive.cryp.to/ax_ext_check_header.html
+dnl Copyright © 2005 Duncan Simpson <dps@simpson.demon.co.uk>
+dnl 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.
+dnl 
+dnl Checks locations of headers in various places
+dnl Extended by Jörg Habenicht
+dnl ------------------------------------------------------------------------
+AC_DEFUN([AX_EXT_HAVE_HEADER],
+[AC_LANG_PUSH(C)
+ AC_CHECK_HEADER($1, [$3 got="yes"], [$4 got="no"], [$5])
+ hdr=`echo $1 | $as_tr_sh`
+ for dir in $2
+ do
+  if test "x${got}" = "xno"; then
+   ext_hashdr_cvdir=`echo $dir | $as_tr_sh`
+   AC_CACHE_CHECK([for $1 header with -I$dir],
+    [ext_cv${ext_hashdr_cvdir}_hashdr_${hdr}],
+    [ext_have_hdr_save_cflags=${CFLAGS}
+     CFLAGS="${CFLAGS} -I${dir}"
+     AC_COMPILE_IFELSE(
+      [AC_LANG_PROGRAM([#include <$1>])],
+      [got="yes"; eval "ext_cv${ext_hashdr_cvdir}_hashdr_${hdr}"="yes"],
+      [got="no"; eval "ext_cv${ext_hashdr_cvdir}_hashdr_${hdr}"="no"])
+     CFLAGS=$ext_have_hdr_save_cflags])
+   if eval `echo 'test x${'ext_cv${ext_hashdr_cvdir}_hashdr_${hdr}'}' = "xyes"`; then
+    CFLAGS="${CFLAGS} -I${dir}"
+    CPPFLAGS="${CPPFLAGS} -I${dir}"
+    got="yes";
+    hdr=`echo $1 | $as_tr_cpp`
+    AC_DEFINE_UNQUOTED(HAVE_${hdr}, 1,
+     [Define this if you have the $1 header])
+   fi; 
+  fi; 
+ done
+AC_LANG_POP])
+
+
+dnl ------------------------------------------------------------------------
+dnl taken from http://autoconf-archive.cryp.to/ax_ext_check_header.html
+dnl Copyright © 2005 Duncan Simpson <dps@simpson.demon.co.uk>
+dnl 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.
+dnl 
+dnl Checks locations of headers in various places
+dnl Extended by Jörg Habenicht
+dnl ------------------------------------------------------------------------
+dnl $1 include file name
+dnl $2 directory list
+dnl $3 action yes
+dnl $4 action no
+dnl $5 include prefix
+dnl $6 include suffix
+dnl $7 main() body content
+AC_DEFUN([PBX_EXT_HAVE_CXX_HEADER],
+[AC_LANG_PUSH(C++)
+ AC_CHECK_HEADER($1, [$3 got="yes"], [$4 got="no"], [$5])
+ hdr=`echo $1 | $as_tr_sh`
+ for dir in $2 ;  do
+  if test "x${got}" = "xno"; then
+   ext_hashdr_cvdir=`echo $dir | $as_tr_sh`
+   AC_CACHE_CHECK([for $1 header with -I$dir],
+    [ext_cv${ext_hashdr_cvdir}_hashdr_${hdr}],
+    [ext_have_hdr_save_cxxflags=${CXXFLAGS}
+     CXXFLAGS="${CXXFLAGS} -I${dir}"
+     AC_COMPILE_IFELSE(
+      [PBX_PRINT_PROGRAM([#include <$1>],[$5],[$6],[$7])],
+      [$3 got="yes"; eval "ext_cv${ext_hashdr_cvdir}_hashdr_${hdr}"="yes"],
+      [$4 got="no"; eval "ext_cv${ext_hashdr_cvdir}_hashdr_${hdr}"="no"])
+     CXXFLAGS=$ext_have_hdr_save_cxxflags])
+   if eval `echo 'test x${'ext_cv${ext_hashdr_cvdir}_hashdr_${hdr}'}' = "xyes"`; then
+    CXXFLAGS="${CXXFLAGS} -I${dir}"
+    CPPFLAGS="${CPPFLAGS} -I${dir}"
+    got="yes";
+    hdr=`echo $1 | $as_tr_cpp`
+    AC_DEFINE_UNQUOTED(HAVE_${hdr}, 1,
+     [Define this if you have the $1 header])
+   fi; 
+  fi; 
+ done
+AC_LANG_POP])
+
diff --git a/autogen.sh b/autogen.sh
new file mode 100644 (file)
index 0000000..f087399
--- /dev/null
@@ -0,0 +1,15 @@
+#!/bin/sh
+
+
+# call autoconf, autoheader and automake
+echo autoheader..
+autoheader || exit $?
+echo aclocal..
+aclocal || exit $?
+echo autoconf..
+autoconf || exit $?
+echo automake..
+automake || exit $?
+
+#./configure
+#make distcheck
diff --git a/configure.ac b/configure.ac
new file mode 100644 (file)
index 0000000..7249ad5
--- /dev/null
@@ -0,0 +1,165 @@
+##   -*- autoconf -*-
+
+dnl    This file is part of linux-call-router
+dnl    Copyright (C) 2007 Joerg Habenicht (j.habenicht@gmx.de)
+
+dnl    This program is free software; you can redistribute it and/or
+dnl    modify it under the terms of the GNU General Public License as
+dnl    published by the Free Software Foundation; either
+dnl    version 2 of the License, or (at your option) any later version.
+
+dnl    This program is distributed in the hope that it will be useful,
+dnl    but WITHOUT ANY WARRANTY; without even the implied warranty of
+dnl    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+dnl    GNU General Public License for more details.
+
+dnl    You should have received a copy of the GNU General Public License
+dnl    along with this library; see the file COPYING.  If not, write to
+dnl    the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
+dnl    Boston, MA 02110-1301, USA.
+
+
+
+dnl This keeps being the first instruction.
+dnl Change the 2nd argument if the version increases
+dnl 1st + 2nd argument is used for distribution package name
+AC_INIT(lcr, 0.1.20071001, pbx4linux@koeln.ccc.de)
+AC_PREREQ(2.61)
+AC_CONFIG_SRCDIR([main.c])
+AC_CONFIG_HEADER([config.h])
+
+# fix warnings from autoconf + automake
+AC_GNU_SOURCE
+AC_USE_SYSTEM_EXTENSIONS
+AM_INIT_AUTOMAKE([dist-bzip2])
+
+
+
+# Checks for programs.
+dnl AC_CHECK_COMPILERS contains AC_PROG_CC AC_PROG_CPP and AC_PROG_CXX
+AC_CHECK_COMPILERS
+dnl AC_PROG_CXX
+dnl AC_PROG_CC
+AC_PROG_INSTALL
+AC_PROG_MAKE_SET
+dnl required, if per binary CFLAGS are used
+dnl AM_PROG_CC_C_O
+
+
+# site specific configs
+dnl enable this to have all special options on one place
+dnl AC_PRESERVE_HELP_ORDER
+
+# enable socket access to misdn kernel module on demand
+dnl SOCKET_MISDN=
+AC_ARG_ENABLE([socket_misdn],
+              [AS_HELP_STRING([--enable-socket-misdn],
+                              [use socket connection to misdn kernel code (default=disable)])
+              ],
+              [use_misdn_socket="yes"],
+              [use_misdn_socket="no"]
+             )
+AM_CONDITIONAL(ENABLE_SOCKET_MISDN, test "x$use_misdn_socket" == "xyes" )
+
+# check for asterisk
+AC_ARG_WITH([asterisk],
+       [AS_HELP_STRING([--with-asterisk],
+                       [compile with built-in Asterisk channel driver @<:@default=no@:>@])
+       ],
+       [with_asterisk_channel_driver="yes"],
+       [with_asterisk_channel_driver="no"])
+AM_CONDITIONAL(ENABLE_ASTERISK_CHANNEL_DRIVER, test "x$with_asterisk_channel_driver" == "xyes" )
+
+# check for crypto
+AC_ARG_WITH([crypto],
+       [AS_HELP_STRING([--with-crypto],
+                       [compile with lib Crypto support @<:@default=check@:>@])
+       ],
+       [],
+       [with_crypto=check])
+LIBCRYPTO=
+AS_IF([test "x$with_crypto" != xno],
+      [AC_CHECK_HEADERS([openssl/rsa.h])
+       AC_CHECK_LIB([crypto], [main],
+                    [AC_SUBST([LIBCRYPTO], ["-lcrypto"])
+                     AC_DEFINE([HAVE_LIBCRYPTO], [1],
+                               [Define if you have libcrypto])
+                    ],
+                    [if test "x$with_crypto" != xcheck ; then
+                      AC_MSG_FAILURE(
+                        [--with-crypto was given, but test for lib Crypto failed])
+                     fi
+                    ],
+                    -lcrypto
+                   )
+      ]
+     )
+AM_CONDITIONAL(WITH_CRYPTO, test "x$LIBCRYPTO" == "x-lcrypto" )
+
+# check for isdn_net.h
+# check for mISDNlib.h
+# --with-isdn_net-include=<include>, default: env MISDNUSER= , $include/mISDNuser
+
+# self written test for mISDNuser lib
+AC_PATH_MISDNUSER
+
+# self written test for mISDN kernel header
+AC_PATH_MISDNKERNEL
+
+
+
+
+# Checks for libraries.
+dnl FIXME: Replace `main' with a function in `-ldl':
+dnl AC_CHECK_LIB([dl], [main])
+dnl FIXME: Replace `main' with a function in `-lh323_linux_x86_r':
+dnl AC_CHECK_LIB([h323_linux_x86_r], [main])
+dnl FIXME: Replace `main' with a function in `-lisdnnet':
+dnl AC_CHECK_LIB([isdnnet], [main])
+# FIXME: Replace `main' with a function in `-lm':
+AC_CHECK_LIB([m], [main])
+dnl FIXME: Replace `main' with a function in `-lmISDN':
+dnl AC_CHECK_LIB([mISDN], [main])
+# FIXME: Replace `main' with a function in `-lncurses':
+AC_CHECK_LIB([ncurses], [main])
+dnl FIXME: Replace `main' with a function in `-lpt_linux_x86_r':
+dnl AC_CHECK_LIB([pt_linux_x86_r], [main])
+# FIXME: Replace `main' with a function in `-lpthread':
+AC_CHECK_LIB([pthread], [main])
+
+# Checks for header files.
+AC_HEADER_DIRENT
+AC_HEADER_STDC
+AC_HEADER_SYS_WAIT
+AC_CHECK_HEADERS([fcntl.h netinet/in.h stdlib.h string.h sys/file.h sys/ioctl.h sys/socket.h sys/time.h unistd.h ctype.h assert.h])
+AC_HEADER_ASSERT
+
+# Checks for typedefs, structures, and compiler characteristics.
+AC_HEADER_STDBOOL
+AC_C_CONST
+AC_C_INLINE
+AC_TYPE_PID_T
+AC_HEADER_TIME
+AC_STRUCT_TM
+
+# Checks for library functions.
+AC_FUNC_FORK
+AC_PROG_GCC_TRADITIONAL
+AC_FUNC_LSTAT
+AC_FUNC_LSTAT_FOLLOWS_SLASHED_SYMLINK
+AC_FUNC_MALLOC
+AC_FUNC_MEMCMP
+AC_TYPE_SIGNAL
+AC_FUNC_STRNLEN
+AC_FUNC_STRTOD
+AC_FUNC_VPRINTF
+AC_CHECK_FUNCS([gettimeofday memmove memset mkdir socket strcasecmp strchr strerror strncasecmp strstr strtol strtoul])
+
+AC_SUBST(misdnuser_libraries)
+AC_SUBST(misdnuser_includes)
+AC_SUBST(misdnkernel_includes)
+AC_SUBST(all_includes)
+AC_SUBST(all_libraries)
+
+AC_CONFIG_FILES([Makefile])
+AC_OUTPUT
diff --git a/depcomp b/depcomp
new file mode 100755 (executable)
index 0000000..ca5ea4e
--- /dev/null
+++ b/depcomp
@@ -0,0 +1,584 @@
+#! /bin/sh
+# depcomp - compile a program generating dependencies as side-effects
+
+scriptversion=2006-10-15.18
+
+# Copyright (C) 1999, 2000, 2003, 2004, 2005, 2006 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, write to the Free Software
+# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
+# 02110-1301, USA.
+
+# 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 outputing dependencies.
+  libtool     Whether libtool is used (yes/no).
+
+Report bugs to <bug-automake@gnu.org>.
+EOF
+    exit $?
+    ;;
+  -v | --v*)
+    echo "depcomp $scriptversion"
+    exit $?
+    ;;
+esac
+
+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"
+
+# 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
+
+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 -eq 0; then :
+  else
+    rm -f "$tmpdepfile"
+    exit $stat
+  fi
+  mv "$tmpdepfile" "$depfile"
+  ;;
+
+gcc)
+## 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).
+## - 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 -eq 0; then :
+  else
+    rm -f "$tmpdepfile"
+    exit $stat
+  fi
+  rm -f "$depfile"
+  echo "$object : \\" > "$depfile"
+  alpha=ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz
+## 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.
+  tr ' ' '
+' < "$tmpdepfile" |
+## 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.
+## Some versions of the HPUX 10.20 sed can't process this invocation
+## correctly.  Breaking it into two sed invocations is a workaround.
+    sed -e 's/^\\$//' -e '/^$/d' -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 -eq 0; then :
+  else
+    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 ' ' '
+' < "$tmpdepfile" \
+    | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' | \
+    tr '
+' ' ' >> $depfile
+    echo >> $depfile
+
+    # The second pass generates a dummy entry for each header file.
+    tr ' ' '
+' < "$tmpdepfile" \
+   | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' -e 's/$/:/' \
+   >> $depfile
+  else
+    # The sourcefile does not contain any dependencies, so just
+    # store a dummy comment line, to avoid errors with the Makefile
+    # "include basename.Plo" scheme.
+    echo "#dummy" > "$depfile"
+  fi
+  rm -f "$tmpdepfile"
+  ;;
+
+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.
+  stripped=`echo "$object" | sed 's/\(.*\)\..*$/\1/'`
+  tmpdepfile="$stripped.u"
+  if test "$libtool" = yes; then
+    "$@" -Wc,-M
+  else
+    "$@" -M
+  fi
+  stat=$?
+
+  if test -f "$tmpdepfile"; then :
+  else
+    stripped=`echo "$stripped" | sed 's,^.*/,,'`
+    tmpdepfile="$stripped.u"
+  fi
+
+  if test $stat -eq 0; then :
+  else
+    rm -f "$tmpdepfile"
+    exit $stat
+  fi
+
+  if test -f "$tmpdepfile"; then
+    outname="$stripped.o"
+    # Each line is of the form `foo.o: dependent.h'.
+    # Do two passes, one to just change these to
+    # `$object: dependent.h' and one to simply `dependent.h:'.
+    sed -e "s,^$outname:,$object :," < "$tmpdepfile" > "$depfile"
+    sed -e "s,^$outname: \(.*\)$,\1:," < "$tmpdepfile" >> "$depfile"
+  else
+    # The sourcefile does not contain any dependencies, so just
+    # store a dummy comment line, to avoid errors with the Makefile
+    # "include basename.Plo" scheme.
+    echo "#dummy" > "$depfile"
+  fi
+  rm -f "$tmpdepfile"
+  ;;
+
+icc)
+  # Intel's C compiler understands `-MD -MF file'.  However on
+  #    icc -MD -MF foo.d -c -o sub/foo.o sub/foo.c
+  # ICC 7.0 will fill foo.d with something like
+  #    foo.o: sub/foo.c
+  #    foo.o: sub/foo.h
+  # which is wrong.  We want:
+  #    sub/foo.o: sub/foo.c
+  #    sub/foo.o: sub/foo.h
+  #    sub/foo.c:
+  #    sub/foo.h:
+  # ICC 7.1 will output
+  #    foo.o: sub/foo.c sub/foo.h
+  # and will wrap long lines using \ :
+  #    foo.o: sub/foo.c ... \
+  #     sub/foo.h ... \
+  #     ...
+
+  "$@" -MD -MF "$tmpdepfile"
+  stat=$?
+  if test $stat -eq 0; then :
+  else
+    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.
+  dir=`echo "$object" | sed -e 's|/[^/]*$|/|'`
+  test "x$dir" = "x$object" && dir=
+  base=`echo "$object" | sed -e 's|^.*/||' -e 's/\.o$//' -e 's/\.lo$//'`
+  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 -eq 0; then :
+  else
+     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,^.*\.[a-z]*:,$object:," "$tmpdepfile" > "$depfile"
+    # Add `dependent.h:' lines.
+    sed -ne '2,${; s/^ *//; s/ \\*$//; s/$/:/; p;}' "$tmpdepfile" >> "$depfile"
+  else
+    echo "#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.
+   dir=`echo "$object" | sed -e 's|/[^/]*$|/|'`
+   test "x$dir" = "x$object" && dir=
+   base=`echo "$object" | sed -e 's|^.*/||' -e 's/\.o$//' -e 's/\.lo$//'`
+
+   if test "$libtool" = yes; then
+      # With Tru64 cc, shared objects can also be used to make a
+      # static library.  This mechanism is used in libtool 1.4 series to
+      # handle both shared and static libraries in a single compilation.
+      # With libtool 1.4, dependencies were output in $dir.libs/$base.lo.d.
+      #
+      # With libtool 1.5 this exception was removed, and libtool now
+      # 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.libs/$base.lo.d   # libtool 1.4
+      tmpdepfile2=$dir$base.o.d          # libtool 1.5
+      tmpdepfile3=$dir.libs/$base.o.d    # libtool 1.5
+      tmpdepfile4=$dir.libs/$base.d      # Compaq CCC V6.2-504
+      "$@" -Wc,-MD
+   else
+      tmpdepfile1=$dir$base.o.d
+      tmpdepfile2=$dir$base.d
+      tmpdepfile3=$dir$base.d
+      tmpdepfile4=$dir$base.d
+      "$@" -MD
+   fi
+
+   stat=$?
+   if test $stat -eq 0; then :
+   else
+      rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" "$tmpdepfile4"
+      exit $stat
+   fi
+
+   for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" "$tmpdepfile4"
+   do
+     test -f "$tmpdepfile" && break
+   done
+   if test -f "$tmpdepfile"; then
+      sed -e "s,^.*\.[a-z]*:,$object:," < "$tmpdepfile" > "$depfile"
+      # That's a tab and a space in the [].
+      sed -e 's,^.*\.[a-z]*:[   ]*,,' -e 's,$,:,' < "$tmpdepfile" >> "$depfile"
+   else
+      echo "#dummy" > "$depfile"
+   fi
+   rm -f "$tmpdepfile"
+   ;;
+
+#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 $1 != '--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:^[  ]*[^: ][^:][^:]*\:[    ]*:'"$object"'\: :' > "$tmpdepfile"
+  rm -f "$depfile"
+  cat < "$tmpdepfile" > "$depfile"
+  tr ' ' '
+' < "$tmpdepfile" | \
+## Some versions of the HPUX 10.20 sed can't process this invocation
+## correctly.  Breaking it into two sed invocations is a workaround.
+    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 $1 != '--mode=compile'; do
+      shift
+    done
+    shift
+  fi
+  # X makedepend
+  shift
+  cleared=no
+  for arg in "$@"; do
+    case $cleared in
+    no)
+      set ""; shift
+      cleared=yes ;;
+    esac
+    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.
+    -*|$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"
+  cat < "$tmpdepfile" > "$depfile"
+  sed '1,2d' "$tmpdepfile" | tr ' ' '
+' | \
+## Some versions of the HPUX 10.20 sed can't process this invocation
+## correctly.  Breaking it into two sed invocations is a workaround.
+    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 $1 != '--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, regardless of -o,
+  # because we must use -o when running libtool.
+  "$@" || exit $?
+  IFS=" "
+  for arg
+  do
+    case "$arg" in
+    "-Gm"|"/Gm"|"-Gi"|"/Gi"|"-ZI"|"/ZI")
+       set fnord "$@"
+       shift
+       shift
+       ;;
+    *)
+       set fnord "$@" "$arg"
+       shift
+       shift
+       ;;
+    esac
+  done
+  "$@" -E |
+  sed -n '/^#line [0-9][0-9]* "\([^"]*\)"/ s::echo "`cygpath -u \\"\1\\"`":p' | sort | uniq > "$tmpdepfile"
+  rm -f "$depfile"
+  echo "$object : \\" > "$depfile"
+  . "$tmpdepfile" | sed 's% %\\ %g' | sed -n '/^\(.*\)$/ s::   \1 \\:p' >> "$depfile"
+  echo "       " >> "$depfile"
+  . "$tmpdepfile" | sed 's% %\\ %g' | sed -n '/^\(.*\)$/ s::\1\::p' >> "$depfile"
+  rm -f "$tmpdepfile"
+  ;;
+
+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-end: "$"
+# End:
diff --git a/install-sh b/install-sh
new file mode 100755 (executable)
index 0000000..4fbbae7
--- /dev/null
@@ -0,0 +1,507 @@
+#!/bin/sh
+# install - install a program, script, or datafile
+
+scriptversion=2006-10-14.15
+
+# This originates from X11R5 (mit/util/scripts/install.sh), which was
+# later released in X11R6 (xc/config/util/install.sh) with the
+# following copyright and license.
+#
+# Copyright (C) 1994 X Consortium
+#
+# Permission is hereby granted, free of charge, to any person obtaining a copy
+# of this software and associated documentation files (the "Software"), to
+# deal in the Software without restriction, including without limitation the
+# rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
+# sell copies of the Software, and to permit persons to whom the Software is
+# furnished to do so, subject to the following conditions:
+#
+# The above copyright notice and this permission notice shall be included in
+# all copies or substantial portions of the Software.
+#
+# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL THE
+# X CONSORTIUM BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
+# AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNEC-
+# TION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
+#
+# Except as contained in this notice, the name of the X Consortium shall not
+# be used in advertising or otherwise to promote the sale, use or other deal-
+# ings in this Software without prior written authorization from the X Consor-
+# tium.
+#
+#
+# FSF changes to this file are in the public domain.
+#
+# Calling this script install-sh is preferred over install.sh, to prevent
+# `make' implicit rules from creating a file called install from it
+# when there is no Makefile.
+#
+# This script is compatible with the BSD install script, but was written
+# from scratch.
+
+nl='
+'
+IFS=" ""       $nl"
+
+# set DOITPROG to echo to test this script
+
+# Don't use :- since 4.3BSD and earlier shells don't like it.
+doit="${DOITPROG-}"
+if test -z "$doit"; then
+  doit_exec=exec
+else
+  doit_exec=$doit
+fi
+
+# Put in absolute file names if you don't have them in your path;
+# or use environment vars.
+
+mvprog="${MVPROG-mv}"
+cpprog="${CPPROG-cp}"
+chmodprog="${CHMODPROG-chmod}"
+chownprog="${CHOWNPROG-chown}"
+chgrpprog="${CHGRPPROG-chgrp}"
+stripprog="${STRIPPROG-strip}"
+rmprog="${RMPROG-rm}"
+mkdirprog="${MKDIRPROG-mkdir}"
+
+posix_glob=
+posix_mkdir=
+
+# Desired mode of installed file.
+mode=0755
+
+chmodcmd=$chmodprog
+chowncmd=
+chgrpcmd=
+stripcmd=
+rmcmd="$rmprog -f"
+mvcmd="$mvprog"
+src=
+dst=
+dir_arg=
+dstarg=
+no_target_directory=
+
+usage="Usage: $0 [OPTION]... [-T] SRCFILE DSTFILE
+   or: $0 [OPTION]... SRCFILES... DIRECTORY
+   or: $0 [OPTION]... -t DIRECTORY SRCFILES...
+   or: $0 [OPTION]... -d DIRECTORIES...
+
+In the 1st form, copy SRCFILE to DSTFILE.
+In the 2nd and 3rd, copy all SRCFILES to DIRECTORY.
+In the 4th, create DIRECTORIES.
+
+Options:
+-c         (ignored)
+-d         create directories instead of installing files.
+-g GROUP   $chgrpprog installed files to GROUP.
+-m MODE    $chmodprog installed files to MODE.
+-o USER    $chownprog installed files to USER.
+-s         $stripprog installed files.
+-t DIRECTORY  install into DIRECTORY.
+-T         report an error if DSTFILE is a directory.
+--help     display this help and exit.
+--version  display version info and exit.
+
+Environment variables override the default commands:
+  CHGRPPROG CHMODPROG CHOWNPROG CPPROG MKDIRPROG MVPROG RMPROG STRIPPROG
+"
+
+while test $# -ne 0; do
+  case $1 in
+    -c) shift
+        continue;;
+
+    -d) dir_arg=true
+        shift
+        continue;;
+
+    -g) chgrpcmd="$chgrpprog $2"
+        shift
+        shift
+        continue;;
+
+    --help) echo "$usage"; exit $?;;
+
+    -m) mode=$2
+        shift
+        shift
+       case $mode in
+         *' '* | *'    '* | *'
+'*       | *'*'* | *'?'* | *'['*)
+           echo "$0: invalid mode: $mode" >&2
+           exit 1;;
+       esac
+        continue;;
+
+    -o) chowncmd="$chownprog $2"
+        shift
+        shift
+        continue;;
+
+    -s) stripcmd=$stripprog
+        shift
+        continue;;
+
+    -t) dstarg=$2
+       shift
+       shift
+       continue;;
+
+    -T) no_target_directory=true
+       shift
+       continue;;
+
+    --version) echo "$0 $scriptversion"; exit $?;;
+
+    --)        shift
+       break;;
+
+    -*)        echo "$0: invalid option: $1" >&2
+       exit 1;;
+
+    *)  break;;
+  esac
+done
+
+if test $# -ne 0 && test -z "$dir_arg$dstarg"; then
+  # When -d is used, all remaining arguments are directories to create.
+  # When -t is used, the destination is already specified.
+  # Otherwise, the last argument is the destination.  Remove it from $@.
+  for arg
+  do
+    if test -n "$dstarg"; then
+      # $@ is not empty: it contains at least $arg.
+      set fnord "$@" "$dstarg"
+      shift # fnord
+    fi
+    shift # arg
+    dstarg=$arg
+  done
+fi
+
+if test $# -eq 0; then
+  if test -z "$dir_arg"; then
+    echo "$0: no input file specified." >&2
+    exit 1
+  fi
+  # It's OK to call `install-sh -d' without argument.
+  # This can happen when creating conditional directories.
+  exit 0
+fi
+
+if test -z "$dir_arg"; then
+  trap '(exit $?); exit' 1 2 13 15
+
+  # Set umask so as not to create temps with too-generous modes.
+  # However, 'strip' requires both read and write access to temps.
+  case $mode in
+    # Optimize common cases.
+    *644) cp_umask=133;;
+    *755) cp_umask=22;;
+
+    *[0-7])
+      if test -z "$stripcmd"; then
+       u_plus_rw=
+      else
+       u_plus_rw='% 200'
+      fi
+      cp_umask=`expr '(' 777 - $mode % 1000 ')' $u_plus_rw`;;
+    *)
+      if test -z "$stripcmd"; then
+       u_plus_rw=
+      else
+       u_plus_rw=,u+rw
+      fi
+      cp_umask=$mode$u_plus_rw;;
+  esac
+fi
+
+for src
+do
+  # Protect names starting with `-'.
+  case $src in
+    -*) src=./$src ;;
+  esac
+
+  if test -n "$dir_arg"; then
+    dst=$src
+    dstdir=$dst
+    test -d "$dstdir"
+    dstdir_status=$?
+  else
+
+    # Waiting for this to be detected by the "$cpprog $src $dsttmp" command
+    # might cause directories to be created, which would be especially bad
+    # if $src (and thus $dsttmp) contains '*'.
+    if test ! -f "$src" && test ! -d "$src"; then
+      echo "$0: $src does not exist." >&2
+      exit 1
+    fi
+
+    if test -z "$dstarg"; then
+      echo "$0: no destination specified." >&2
+      exit 1
+    fi
+
+    dst=$dstarg
+    # Protect names starting with `-'.
+    case $dst in
+      -*) dst=./$dst ;;
+    esac
+
+    # If destination is a directory, append the input filename; won't work
+    # if double slashes aren't ignored.
+    if test -d "$dst"; then
+      if test -n "$no_target_directory"; then
+       echo "$0: $dstarg: Is a directory" >&2
+       exit 1
+      fi
+      dstdir=$dst
+      dst=$dstdir/`basename "$src"`
+      dstdir_status=0
+    else
+      # Prefer dirname, but fall back on a substitute if dirname fails.
+      dstdir=`
+       (dirname "$dst") 2>/dev/null ||
+       expr X"$dst" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
+            X"$dst" : 'X\(//\)[^/]' \| \
+            X"$dst" : 'X\(//\)$' \| \
+            X"$dst" : 'X\(/\)' \| . 2>/dev/null ||
+       echo X"$dst" |
+           sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{
+                  s//\1/
+                  q
+                }
+                /^X\(\/\/\)[^/].*/{
+                  s//\1/
+                  q
+                }
+                /^X\(\/\/\)$/{
+                  s//\1/
+                  q
+                }
+                /^X\(\/\).*/{
+                  s//\1/
+                  q
+                }
+                s/.*/./; q'
+      `
+
+      test -d "$dstdir"
+      dstdir_status=$?
+    fi
+  fi
+
+  obsolete_mkdir_used=false
+
+  if test $dstdir_status != 0; then
+    case $posix_mkdir in
+      '')
+       # Create intermediate dirs using mode 755 as modified by the umask.
+       # This is like FreeBSD 'install' as of 1997-10-28.
+       umask=`umask`
+       case $stripcmd.$umask in
+         # Optimize common cases.
+         *[2367][2367]) mkdir_umask=$umask;;
+         .*0[02][02] | .[02][02] | .[02]) mkdir_umask=22;;
+
+         *[0-7])
+           mkdir_umask=`expr $umask + 22 \
+             - $umask % 100 % 40 + $umask % 20 \
+             - $umask % 10 % 4 + $umask % 2
+           `;;
+         *) mkdir_umask=$umask,go-w;;
+       esac
+
+       # With -d, create the new directory with the user-specified mode.
+       # Otherwise, rely on $mkdir_umask.
+       if test -n "$dir_arg"; then
+         mkdir_mode=-m$mode
+       else
+         mkdir_mode=
+       fi
+
+       posix_mkdir=false
+       case $umask in
+         *[123567][0-7][0-7])
+           # POSIX mkdir -p sets u+wx bits regardless of umask, which
+           # is incompatible with FreeBSD 'install' when (umask & 300) != 0.
+           ;;
+         *)
+           tmpdir=${TMPDIR-/tmp}/ins$RANDOM-$$
+           trap 'ret=$?; rmdir "$tmpdir/d" "$tmpdir" 2>/dev/null; exit $ret' 0
+
+           if (umask $mkdir_umask &&
+               exec $mkdirprog $mkdir_mode -p -- "$tmpdir/d") >/dev/null 2>&1
+           then
+             if test -z "$dir_arg" || {
+                  # Check for POSIX incompatibilities with -m.
+                  # HP-UX 11.23 and IRIX 6.5 mkdir -m -p sets group- or
+                  # other-writeable bit of parent directory when it shouldn't.
+                  # FreeBSD 6.1 mkdir -m -p sets mode of existing directory.
+                  ls_ld_tmpdir=`ls -ld "$tmpdir"`
+                  case $ls_ld_tmpdir in
+                    d????-?r-*) different_mode=700;;
+                    d????-?--*) different_mode=755;;
+                    *) false;;
+                  esac &&
+                  $mkdirprog -m$different_mode -p -- "$tmpdir" && {
+                    ls_ld_tmpdir_1=`ls -ld "$tmpdir"`
+                    test "$ls_ld_tmpdir" = "$ls_ld_tmpdir_1"
+                  }
+                }
+             then posix_mkdir=:
+             fi
+             rmdir "$tmpdir/d" "$tmpdir"
+           else
+             # Remove any dirs left behind by ancient mkdir implementations.
+             rmdir ./$mkdir_mode ./-p ./-- 2>/dev/null
+           fi
+           trap '' 0;;
+       esac;;
+    esac
+
+    if
+      $posix_mkdir && (
+       umask $mkdir_umask &&
+       $doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir"
+      )
+    then :
+    else
+
+      # The umask is ridiculous, or mkdir does not conform to POSIX,
+      # or it failed possibly due to a race condition.  Create the
+      # directory the slow way, step by step, checking for races as we go.
+
+      case $dstdir in
+       /*) prefix=/ ;;
+       -*) prefix=./ ;;
+       *)  prefix= ;;
+      esac
+
+      case $posix_glob in
+        '')
+         if (set -f) 2>/dev/null; then
+           posix_glob=true
+         else
+           posix_glob=false
+         fi ;;
+      esac
+
+      oIFS=$IFS
+      IFS=/
+      $posix_glob && set -f
+      set fnord $dstdir
+      shift
+      $posix_glob && set +f
+      IFS=$oIFS
+
+      prefixes=
+
+      for d
+      do
+       test -z "$d" && continue
+
+       prefix=$prefix$d
+       if test -d "$prefix"; then
+         prefixes=
+       else
+         if $posix_mkdir; then
+           (umask=$mkdir_umask &&
+            $doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir") && break
+           # Don't fail if two instances are running concurrently.
+           test -d "$prefix" || exit 1
+         else
+           case $prefix in
+             *\'*) qprefix=`echo "$prefix" | sed "s/'/'\\\\\\\\''/g"`;;
+             *) qprefix=$prefix;;
+           esac
+           prefixes="$prefixes '$qprefix'"
+         fi
+       fi
+       prefix=$prefix/
+      done
+
+      if test -n "$prefixes"; then
+       # Don't fail if two instances are running concurrently.
+       (umask $mkdir_umask &&
+        eval "\$doit_exec \$mkdirprog $prefixes") ||
+         test -d "$dstdir" || exit 1
+       obsolete_mkdir_used=true
+      fi
+    fi
+  fi
+
+  if test -n "$dir_arg"; then
+    { test -z "$chowncmd" || $doit $chowncmd "$dst"; } &&
+    { test -z "$chgrpcmd" || $doit $chgrpcmd "$dst"; } &&
+    { test "$obsolete_mkdir_used$chowncmd$chgrpcmd" = false ||
+      test -z "$chmodcmd" || $doit $chmodcmd $mode "$dst"; } || exit 1
+  else
+
+    # Make a couple of temp file names in the proper directory.
+    dsttmp=$dstdir/_inst.$$_
+    rmtmp=$dstdir/_rm.$$_
+
+    # Trap to clean up those temp files at exit.
+    trap 'ret=$?; rm -f "$dsttmp" "$rmtmp" && exit $ret' 0
+
+    # Copy the file name to the temp name.
+    (umask $cp_umask && $doit_exec $cpprog "$src" "$dsttmp") &&
+
+    # and set any options; do chmod last to preserve setuid bits.
+    #
+    # If any of these fail, we abort the whole thing.  If we want to
+    # ignore errors from any of these, just make sure not to ignore
+    # errors from the above "$doit $cpprog $src $dsttmp" command.
+    #
+    { test -z "$chowncmd" || $doit $chowncmd "$dsttmp"; } \
+      && { test -z "$chgrpcmd" || $doit $chgrpcmd "$dsttmp"; } \
+      && { test -z "$stripcmd" || $doit $stripcmd "$dsttmp"; } \
+      && { test -z "$chmodcmd" || $doit $chmodcmd $mode "$dsttmp"; } &&
+
+    # Now rename the file to the real destination.
+    { $doit $mvcmd -f "$dsttmp" "$dst" 2>/dev/null \
+      || {
+          # The rename failed, perhaps because mv can't rename something else
+          # to itself, or perhaps because mv is so ancient that it does not
+          # support -f.
+
+          # Now remove or move aside any old file at destination location.
+          # We try this two ways since rm can't unlink itself on some
+          # systems and the destination file might be busy for other
+          # reasons.  In this case, the final cleanup might fail but the new
+          # file should still install successfully.
+          {
+            if test -f "$dst"; then
+              $doit $rmcmd -f "$dst" 2>/dev/null \
+              || { $doit $mvcmd -f "$dst" "$rmtmp" 2>/dev/null \
+                    && { $doit $rmcmd -f "$rmtmp" 2>/dev/null; :; }; }\
+              || {
+                echo "$0: cannot unlink or rename $dst" >&2
+                (exit 1); exit 1
+              }
+            else
+              :
+            fi
+          } &&
+
+          # Now rename the file to the real destination.
+          $doit $mvcmd "$dsttmp" "$dst"
+        }
+    } || exit 1
+
+    trap '' 0
+  fi
+done
+
+# Local variables:
+# eval: (add-hook 'write-file-hooks 'time-stamp)
+# time-stamp-start: "scriptversion="
+# time-stamp-format: "%:y-%02m-%02d.%02H"
+# time-stamp-end: "$"
+# End:
diff --git a/missing b/missing
new file mode 100755 (executable)
index 0000000..1c8ff70
--- /dev/null
+++ b/missing
@@ -0,0 +1,367 @@
+#! /bin/sh
+# Common stub for a few missing GNU programs while installing.
+
+scriptversion=2006-05-10.23
+
+# Copyright (C) 1996, 1997, 1999, 2000, 2002, 2003, 2004, 2005, 2006
+#   Free Software Foundation, Inc.
+# Originally 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, write to the Free Software
+# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
+# 02110-1301, USA.
+
+# 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
+
+run=:
+sed_output='s/.* --output[ =]\([^ ]*\).*/\1/p'
+sed_minuso='s/.* -o \([^ ]*\).*/\1/p'
+
+# In the cases where this matters, `missing' is being run in the
+# srcdir already.
+if test -f configure.ac; then
+  configure_ac=configure.ac
+else
+  configure_ac=configure.in
+fi
+
+msg="missing on your system"
+
+case $1 in
+--run)
+  # Try to run requested program, and just exit if it succeeds.
+  run=
+  shift
+  "$@" && exit 0
+  # Exit code 63 means version mismatch.  This often happens
+  # when the user try to use an ancient version of a tool on
+  # a file that requires a minimum version.  In this case we
+  # we should proceed has if the program had been absent, or
+  # if --run hadn't been passed.
+  if test $? = 63; then
+    run=:
+    msg="probably too old"
+  fi
+  ;;
+
+  -h|--h|--he|--hel|--help)
+    echo "\
+$0 [OPTION]... PROGRAM [ARGUMENT]...
+
+Handle \`PROGRAM [ARGUMENT]...' for when PROGRAM is missing, or return an
+error status if there is no known handling for PROGRAM.
+
+Options:
+  -h, --help      display this help and exit
+  -v, --version   output version information and exit
+  --run           try to run the given command, and emulate it if it fails
+
+Supported PROGRAM values:
+  aclocal      touch file \`aclocal.m4'
+  autoconf     touch file \`configure'
+  autoheader   touch file \`config.h.in'
+  autom4te     touch the output file, or create a stub one
+  automake     touch all \`Makefile.in' files
+  bison        create \`y.tab.[ch]', if possible, from existing .[ch]
+  flex         create \`lex.yy.c', if possible, from existing .c
+  help2man     touch the output file
+  lex          create \`lex.yy.c', if possible, from existing .c
+  makeinfo     touch the output file
+  tar          try tar, gnutar, gtar, then tar without non-portable flags
+  yacc         create \`y.tab.[ch]', if possible, from existing .[ch]
+
+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
+
+# Now exit if we have it, but it failed.  Also exit now if we
+# don't have it and --version was passed (most likely to detect
+# the program).
+case $1 in
+  lex|yacc)
+    # Not GNU programs, they don't have --version.
+    ;;
+
+  tar)
+    if test -n "$run"; then
+       echo 1>&2 "ERROR: \`tar' requires --run"
+       exit 1
+    elif test "x$2" = "x--version" || test "x$2" = "x--help"; then
+       exit 1
+    fi
+    ;;
+
+  *)
+    if test -z "$run" && ($1 --version) > /dev/null 2>&1; then
+       # We have it, but it failed.
+       exit 1
+    elif test "x$2" = "x--version" || test "x$2" = "x--help"; then
+       # Could not run --version or --help.  This is probably someone
+       # running `$TOOL --version' or `$TOOL --help' to check whether
+       # $TOOL exists and not knowing $TOOL uses missing.
+       exit 1
+    fi
+    ;;
+esac
+
+# If it does not exist, or fails to run (possibly an outdated version),
+# try to emulate it.
+case $1 in
+  aclocal*)
+    echo 1>&2 "\
+WARNING: \`$1' is $msg.  You should only need it if
+         you modified \`acinclude.m4' or \`${configure_ac}'.  You might want
+         to install the \`Automake' and \`Perl' packages.  Grab them from
+         any GNU archive site."
+    touch aclocal.m4
+    ;;
+
+  autoconf)
+    echo 1>&2 "\
+WARNING: \`$1' is $msg.  You should only need it if
+         you modified \`${configure_ac}'.  You might want to install the
+         \`Autoconf' and \`GNU m4' packages.  Grab them from any GNU
+         archive site."
+    touch configure
+    ;;
+
+  autoheader)
+    echo 1>&2 "\
+WARNING: \`$1' is $msg.  You should only need it if
+         you modified \`acconfig.h' or \`${configure_ac}'.  You might want
+         to install the \`Autoconf' and \`GNU m4' packages.  Grab them
+         from any GNU archive site."
+    files=`sed -n 's/^[ ]*A[CM]_CONFIG_HEADER(\([^)]*\)).*/\1/p' ${configure_ac}`
+    test -z "$files" && files="config.h"
+    touch_files=
+    for f in $files; do
+      case $f in
+      *:*) touch_files="$touch_files "`echo "$f" |
+                                      sed -e 's/^[^:]*://' -e 's/:.*//'`;;
+      *) touch_files="$touch_files $f.in";;
+      esac
+    done
+    touch $touch_files
+    ;;
+
+  automake*)
+    echo 1>&2 "\
+WARNING: \`$1' is $msg.  You should only need it if
+         you modified \`Makefile.am', \`acinclude.m4' or \`${configure_ac}'.
+         You might want to install the \`Automake' and \`Perl' packages.
+         Grab them from any GNU archive site."
+    find . -type f -name Makefile.am -print |
+          sed 's/\.am$/.in/' |
+          while read f; do touch "$f"; done
+    ;;
+
+  autom4te)
+    echo 1>&2 "\
+WARNING: \`$1' is needed, but is $msg.
+         You might have modified some files without having the
+         proper tools for further handling them.
+         You can get \`$1' as part of \`Autoconf' from any GNU
+         archive site."
+
+    file=`echo "$*" | sed -n "$sed_output"`
+    test -z "$file" && file=`echo "$*" | sed -n "$sed_minuso"`
+    if test -f "$file"; then
+       touch $file
+    else
+       test -z "$file" || exec >$file
+       echo "#! /bin/sh"
+       echo "# Created by GNU Automake missing as a replacement of"
+       echo "#  $ $@"
+       echo "exit 0"
+       chmod +x $file
+       exit 1
+    fi
+    ;;
+
+  bison|yacc)
+    echo 1>&2 "\
+WARNING: \`$1' $msg.  You should only need it if
+         you modified a \`.y' file.  You may need the \`Bison' package
+         in order for those modifications to take effect.  You can get
+         \`Bison' from any GNU archive site."
+    rm -f y.tab.c y.tab.h
+    if test $# -ne 1; then
+        eval LASTARG="\${$#}"
+       case $LASTARG in
+       *.y)
+           SRCFILE=`echo "$LASTARG" | sed 's/y$/c/'`
+           if test -f "$SRCFILE"; then
+                cp "$SRCFILE" y.tab.c
+           fi
+           SRCFILE=`echo "$LASTARG" | sed 's/y$/h/'`
+           if test -f "$SRCFILE"; then
+                cp "$SRCFILE" y.tab.h
+           fi
+         ;;
+       esac
+    fi
+    if test ! -f y.tab.h; then
+       echo >y.tab.h
+    fi
+    if test ! -f y.tab.c; then
+       echo 'main() { return 0; }' >y.tab.c
+    fi
+    ;;
+
+  lex|flex)
+    echo 1>&2 "\
+WARNING: \`$1' is $msg.  You should only need it if
+         you modified a \`.l' file.  You may need the \`Flex' package
+         in order for those modifications to take effect.  You can get
+         \`Flex' from any GNU archive site."
+    rm -f lex.yy.c
+    if test $# -ne 1; then
+        eval LASTARG="\${$#}"
+       case $LASTARG in
+       *.l)
+           SRCFILE=`echo "$LASTARG" | sed 's/l$/c/'`
+           if test -f "$SRCFILE"; then
+                cp "$SRCFILE" lex.yy.c
+           fi
+         ;;
+       esac
+    fi
+    if test ! -f lex.yy.c; then
+       echo 'main() { return 0; }' >lex.yy.c
+    fi
+    ;;
+
+  help2man)
+    echo 1>&2 "\
+WARNING: \`$1' is $msg.  You should only need it if
+        you modified a dependency of a manual page.  You may need the
+        \`Help2man' package in order for those modifications to take
+        effect.  You can get \`Help2man' from any GNU archive site."
+
+    file=`echo "$*" | sed -n "$sed_output"`
+    test -z "$file" && file=`echo "$*" | sed -n "$sed_minuso"`
+    if test -f "$file"; then
+       touch $file
+    else
+       test -z "$file" || exec >$file
+       echo ".ab help2man is required to generate this page"
+       exit 1
+    fi
+    ;;
+
+  makeinfo)
+    echo 1>&2 "\
+WARNING: \`$1' is $msg.  You should only need it if
+         you modified a \`.texi' or \`.texinfo' file, or any other file
+         indirectly affecting the aspect of the manual.  The spurious
+         call might also be the consequence of using a buggy \`make' (AIX,
+         DU, IRIX).  You might want to install the \`Texinfo' package or
+         the \`GNU make' package.  Grab either from any GNU archive site."
+    # The file to touch is that specified with -o ...
+    file=`echo "$*" | sed -n "$sed_output"`
+    test -z "$file" && file=`echo "$*" | sed -n "$sed_minuso"`
+    if test -z "$file"; then
+      # ... or it is the one specified with @setfilename ...
+      infile=`echo "$*" | sed 's/.* \([^ ]*\) *$/\1/'`
+      file=`sed -n '
+       /^@setfilename/{
+         s/.* \([^ ]*\) *$/\1/
+         p
+         q
+       }' $infile`
+      # ... or it is derived from the source name (dir/f.texi becomes f.info)
+      test -z "$file" && file=`echo "$infile" | sed 's,.*/,,;s,.[^.]*$,,'`.info
+    fi
+    # If the file does not exist, the user really needs makeinfo;
+    # let's fail without touching anything.
+    test -f $file || exit 1
+    touch $file
+    ;;
+
+  tar)
+    shift
+
+    # We have already tried tar in the generic part.
+    # Look for gnutar/gtar before invocation to avoid ugly error
+    # messages.
+    if (gnutar --version > /dev/null 2>&1); then
+       gnutar "$@" && exit 0
+    fi
+    if (gtar --version > /dev/null 2>&1); then
+       gtar "$@" && exit 0
+    fi
+    firstarg="$1"
+    if shift; then
+       case $firstarg in
+       *o*)
+           firstarg=`echo "$firstarg" | sed s/o//`
+           tar "$firstarg" "$@" && exit 0
+           ;;
+       esac
+       case $firstarg in
+       *h*)
+           firstarg=`echo "$firstarg" | sed s/h//`
+           tar "$firstarg" "$@" && exit 0
+           ;;
+       esac
+    fi
+
+    echo 1>&2 "\
+WARNING: I can't seem to be able to run \`tar' with the given arguments.
+         You may want to install GNU tar or Free paxutils, or check the
+         command line arguments."
+    exit 1
+    ;;
+
+  *)
+    echo 1>&2 "\
+WARNING: \`$1' is needed, and is $msg.
+         You might have modified some files without having the
+         proper tools for further handling them.  Check the \`README' file,
+         it often tells you about the needed prerequisites for installing
+         this package.  You may also peek at any GNU archive site, in case
+         some other package would contain this missing \`$1' program."
+    exit 1
+    ;;
+esac
+
+exit 0
+
+# Local variables:
+# eval: (add-hook 'write-file-hooks 'time-stamp)
+# time-stamp-start: "scriptversion="
+# time-stamp-format: "%:y-%02m-%02d.%02H"
+# time-stamp-end: "$"
+# End: