From 8bddb2d979c879c2081d7efe9a048362524dbd14 Mon Sep 17 00:00:00 2001 From: hajo Date: Tue, 2 Oct 2007 16:08:50 +0200 Subject: [PATCH] added: autoconf environment NOTE: --with-asterisk compiles, --use-misdn-socket not --- AUTHORS | 2 + ChangeLog | 0 INSTALL | 234 ++++++++++++++++++ Makefile.am | 492 ++++++++++++++++++++++++++++++++++++ NEWS | 0 acinclude.m4 | 797 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ autogen.sh | 15 ++ configure.ac | 165 +++++++++++++ depcomp | 584 +++++++++++++++++++++++++++++++++++++++++++ install-sh | 507 +++++++++++++++++++++++++++++++++++++ missing | 367 +++++++++++++++++++++++++++ 11 files changed, 3163 insertions(+) create mode 100644 AUTHORS create mode 100644 ChangeLog create mode 100644 INSTALL create mode 100644 Makefile.am create mode 100644 NEWS create mode 100644 acinclude.m4 create mode 100644 autogen.sh create mode 100644 configure.ac create mode 100755 depcomp create mode 100755 install-sh create mode 100755 missing diff --git a/AUTHORS b/AUTHORS new file mode 100644 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 index 0000000..e69de29 diff --git a/INSTALL b/INSTALL new file mode 100644 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 index 0000000..e5b97b2 --- /dev/null +++ b/Makefile.am @@ -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 index 0000000..e69de29 diff --git a/acinclude.m4 b/acinclude.m4 new file mode 100644 index 0000000..816bd1f --- /dev/null +++ b/acinclude.m4 @@ -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 < +#include +#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 < +#include +#include +#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 +dnl Copyright © 2006 Andreas Schwab +dnl Copyright © 2006 Guido U. Draheim +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 +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 +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 index 0000000..f087399 --- /dev/null +++ b/autogen.sh @@ -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 index 0000000..7249ad5 --- /dev/null +++ b/configure.ac @@ -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=, 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 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 . + +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 . +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 index 0000000..4fbbae7 --- /dev/null +++ b/install-sh @@ -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 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 , 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 ." + 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: -- 2.13.6